## SM5L1/SM5L2/SM5L3 <br> 4-Bit Single Chip Microcomputers

## FEATURES

- ROM capacity:
- 2,048 × 8-bits (SM5L1)
- 3,072 $\times 8$-bits (SM5L2)
- 4,096 $\times 8$-bits (SM5L3)
- RAM capacity:
- $69 \times 4$-bits, including $21 \times 4$-bits display RAM (SM5L1)
- $130 \times 4$-bits, including $34 \times 4$-bits display RAM (SM5L2)
- $170 \times 4$-bits, including $42 \times 4$-bits display RAM (SM5L3)
- 51 instruction sets
- Four levels of subroutine nesting
- I/O port:
- One input
- Five outputs
- Eight input/outputs
- Interrupts:
- Internal interrupt $\times 1$ (divider overflow)
- External interrupt $\times 1$ (INTA)
- Built-in main clock oscillator for system clock
- Signal generation for real time clock
- Built-in 15 stage divider for real time clock
- Built-in LCD driver:
- 84 segments (SM5L1), 136 segments (SM5L2), 168 segments (SM5L3), 1/2 bias, $1 / 4$ duty cycle
- Built-in melody generator circuit:
- Melody ROM
- 160 steps (SM5L1), 256 steps (SM5L2/3)
- Generating time (at 32.768 kHz )
- 20 sec. (MAX.) (SM5L1)
- 32 sec. (MAX.) (SM5L2/3)
- Instruction cycle time: $61 \mu \mathrm{~s}$ (TYP. at 32.768 kHz )
- Standby function
- Supply voltage: $1.5 \mathrm{~V} \pm 20 \%$
- Packages:
- 60-pin QFP (QFP060-P-1414) (SM5L1)
- 72-pin QFP (QFP072-P1010) (SM5L2)
- 80-pin QFP (QFP080-P-1420) (SM5L2/3)


## DESCRIPTION

The SM5L1/L2/L3 (SM5Lx series) are CMOS 4-bit single chip microcomputers operated on 1.5 V single power supply. This microcomputer integrates 4-bit parallel processing function, ROM, RAM, display RAM, 15-stage divider, two types of interrupt and four levels of subroutine stack. With a built-in LCD drive circuit for a maximum of 84/136/168 (SM5L1/L2/L3) elements, in a two-mode standby function, and a melody generator circuit in a single chip, the SM5Lx series permits the design of system configuration with a minimum of peripheral components. It can be used in a variety of products from handheld equipment to electrical appliances, such as audio timers, and also achieves lower power consumption.

## PIN CONNECTIONS



Figure 1. 60-pin QFP (SM5L1)


Figure 2. 72-pin QFP (SM5L2)


Figure 3. 80-pin QFP (SM5L2/3)

## BLOCK DIAGRAM



Figure 4. SM5L1/SM5L2/SM5L3 Block Diagram

## PIN DESCRIPTION

| PIN NAME | I/O | FUNCTION |
| :---: | :---: | :---: |
| GND, $\mathrm{V}_{\mathrm{M}}$ | I | Power supply pins. The $\mathrm{V}_{\mathrm{M}}$ pin applies a positive supply with respect to the GND. |
| $\mathrm{T}, \overline{\mathrm{T}}_{1}, \mathrm{~T}_{2}$ | 1 | LSI chip test pins. Cannot be used by the user. Connect $T$ and $T_{2}$ pin to GND. Connect $\mathrm{T}_{1}$ pin to $\mathrm{V}_{\mathrm{M}}$. |
| RESET | I | Input pin with built-in pull-up resistor. Hardware reset the LSI chip when a LOW level signal is input. Normally a capacitor is connected between it and GND to form a pow-er-on reset circuit. |
| $\underset{\mathrm{CK}_{2}}{\mathrm{OSC}_{\mathrm{IN}}, \mathrm{OSC}_{\text {OUT }}}$ | I/O | CR or crystal oscillator pins. Connect a CR or crystal oscillating element across $\mathrm{OSC}_{I N}-\mathrm{OSC}_{\mathrm{OUT}}$ (crystal) or $\mathrm{OSC}_{\mathrm{IN}}-\mathrm{CK}_{2}(\mathrm{CR})$ to form a clock generator circuit. Use of a CR or crystal oscillating element is determined by the mask option. |
| F | O | Melody output pin. Outputs the contents of a melody ROM with 12 musical scale ( 555 to $2,114 \mathrm{~Hz}$ ) in two octaves. |
| $\mathrm{H}_{0}-\mathrm{H}_{3}$ | 0 | Common output pins. Pins for the LCD's common signals. |
| $\begin{aligned} & \hline S_{0}-S_{20}(S M 5 L 1) \\ & S_{0}-S_{33}(\mathrm{SM} 5 \mathrm{~L} 2) \\ & \mathrm{S}_{0}-\mathrm{S}_{41}(\mathrm{SM} 5 \mathrm{~L} 3) \\ & \hline \end{aligned}$ | O | Pins for the LCD's segment signals. |
| INTA | 1 | Input pin for external interrupt. The IFA flag is set at the leading edge of INTA. |
| $\mathrm{PO}_{0}-\mathrm{PO}_{3}$ | O | Output pins. The accumulator $\mathrm{A}_{\mathrm{CC}}$ can be transferred to this port by instruction. |
| $\begin{aligned} & \mathrm{P} 1_{0}-\mathrm{P} 1_{3} \\ & \mathrm{P} 2_{0}-\mathrm{P} 2_{3} \end{aligned}$ | I/O | I/O pins which can switch to input or output pins in 4-bit units by instruction. They can be used as output pins when configured for a key matrix. The SM5Lx is forced to hardware reset when all of $\mathrm{P} 1_{0}-\mathrm{P} 1_{3}$ pins are HIGH level (by mask option). |

## ABSOLUTE MAXIMUM RATINGS

| PARAMETER | SYMBOL | RATING | UNIT | NOTE |
| :--- | :---: | :---: | :---: | :---: |
| Supply voltage | $\mathrm{V}_{\mathrm{M}}$ | -0.3 to 2.0 | V |  |
|  | $\mathrm{~V}_{\mathrm{DD}}$ | -0.3 to 4.0 | V |  |
| Input voltage | $\mathrm{V}_{\mathrm{I}}$ | -0.3 to $\mathrm{V}_{\mathrm{M}}+0.3$ | V |  |
| Output voltage | $\mathrm{V}_{\mathrm{O}}$ | -0.3 to $\mathrm{V}_{\mathrm{M}}+0.3$ | V |  |
| Source output current for each pin | $\mathrm{I}_{\mathrm{O} 1}$ | 2 | mA | 1 |
|  | $\mathrm{I}_{\mathrm{O} 2}$ | 2 | mA | 2 |
|  | $\mathrm{I}_{\mathrm{O} 3}$ | 2 | mA | 3 |
|  | $\mathrm{I}_{\mathrm{O} 4}$ | 2 | mA | 4 |
|  | $\mathrm{I}_{\mathrm{O} 5}$ | 2 | mA | 1 |
|  | $\mathrm{I}_{\mathrm{O} 6}$ | 100 | $\mu \mathrm{~A}$ | 2 |
|  | $\mathrm{I}_{\mathrm{O} 7}$ | 2 | mA | 3 |
|  | $\mathrm{I}_{\mathrm{O} 8}$ | 2 | mA | 4 |
| Total source output current | $\mathrm{I}_{\mathrm{OH}}$ | 10 | mA |  |
| Total sink output current | $\mathrm{I}_{\mathrm{OL}}$ | 10 | mA |  |
| Operating temperature | $\mathrm{T}_{\mathrm{OPR}}$ | 0 to 50 | ${ }^{\circ} \mathrm{C}$ |  |
| Storage temperature | $\mathrm{T}_{\mathrm{STG}}$ | -55 to 150 | ${ }^{\circ} \mathrm{C}$ |  |

## NOTES:

1. Applicable pins: $\mathrm{PO}_{0}-\mathrm{PO}_{3}$.
2. Applicable pins: $\mathrm{P1}_{0}-\mathrm{P1}_{3}, \mathrm{P}_{2}-\mathrm{P} 2_{3}$.
3. Applicable pin: F.
4. Applicable pins: $\mathrm{H}_{0}-\mathrm{H}_{3}, \mathrm{~S}_{0}-\mathrm{S}_{20}$ (SM5L1), $\mathrm{S}_{0}-\mathrm{S}_{33}(\mathrm{SM} 5 \mathrm{~L} 2), \mathrm{S}_{0}-\mathrm{S}_{41}$ (SM5L3).

RECOMMENDED OPERATING CONDITIONS

| PARAMETER | SYMBOL | RATING | UNIT | NOTE |
| :--- | :---: | :---: | :---: | :---: |
| Supply voltage | $\mathrm{V}_{\mathrm{M}}$ | 1.2 to 1.8 | V |  |
|  | $\mathrm{~V}_{\mathrm{DD}}$ | 2.4 to 3.6 | V |  |
| Instruction cycle | $\mathrm{T}_{\mathrm{SYS}}$ | 122 to 50 | $\mu \mathrm{~s}$ |  |
| Oscillation starting voltage | $\mathrm{V}_{\mathrm{OSC}}$ | 1.4 | V | 1 |

## NOTE:

1. Use the crystal oscillation circuit.

## Oscillation Circuit



Figure 5. Crystal Oscillation (Frequency $=32.768$ kHz)


Figure 6. CR Oscillation (Frequency $=\mathbf{4 0} \mathbf{k H z}$ )

NOTE: Mount the R, C and crystal as close to the LSI chip as possible to minimize the effects of stray capacitance.

## DC CHARACTERISTICS

$\mathrm{V}_{\mathrm{M}}=1.5 \mathrm{~V} \pm 0.1 \mathrm{~V}, \mathrm{~T}_{\mathrm{OPR}}=0^{\circ} \mathrm{C}$ to $50^{\circ} \mathrm{C}$

| PARAMETER | SYMBOL | CONDITIONS | MIN. ${ }^{1}$ | TYP. ${ }^{2}$ | MAX. ${ }^{1}$ | UNIT | NOTE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input voltage | $\mathrm{V}_{\mathrm{IH} 1}$ |  | $0.8 \times \mathrm{V}_{\mathrm{M}}$ |  | $\mathrm{V}_{\mathrm{M}}$ | V | 3 |
|  | $\mathrm{V}_{\text {IL1 }}$ |  | 0 |  | $0.2 \times \mathrm{V}_{\mathrm{M}}$ | V | 3 |
|  | $\mathrm{V}_{\mathrm{H} 2}$ |  | $\mathrm{V}_{\mathrm{M}}-0.25$ |  | $\mathrm{V}_{\mathrm{M}}$ | V | 4 |
|  | $\mathrm{V}_{\mathrm{IL} 2}$ |  | 0 |  | 0.25 | V | 4 |
| Input current | $\mathrm{I}_{\mathrm{H} 1}$ | $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{M}}$ |  |  | 1.0 | $\mu \mathrm{A}$ | 5 |
|  | $\mathrm{I}_{\mathrm{H} 2}$ | $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{M}}$ |  | 1.5/3/3 |  | $\mu \mathrm{A}$ | 6 |
|  | $\mathrm{I}_{\mathrm{LL} 1}$ | $\mathrm{V}_{\mathrm{IL}}=0 \mathrm{~V}$ |  | 1.5/3/3 |  | $\mu \mathrm{A}$ | 7 |
| Boost output voltage | $\mathrm{V}_{\mathrm{DD} 1}$ | $\begin{aligned} & \hline \mathrm{V}_{\mathrm{M}}=1.4 \mathrm{~V} \\ & \mathrm{RL}=5 \mathrm{M} \Omega \\ & \hline \end{aligned}$ | 2.5 |  |  | V | 8 |
|  | $\mathrm{V}_{\mathrm{DD} 2}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{M}}=1.6 \mathrm{~V} \\ & \mathrm{RL}=5 \mathrm{M} \Omega \end{aligned}$ | 2.9 |  |  | V | 8 |
| Output current | ${ }^{-} \mathrm{OH} 1$ | $\mathrm{V}_{\mathrm{OH}}=\mathrm{V}_{\mathrm{M}}-0.5 \mathrm{~V}$ | 100 |  |  | $\mu \mathrm{A}$ | 9 |
|  | l OL 1 | $\mathrm{V}_{\mathrm{OL}}=0.5 \mathrm{~V}$ | 100 |  |  | $\mu \mathrm{A}$ | 9 |
|  | ${ }^{-1} \mathrm{OH} 2$ | $\mathrm{V}_{\mathrm{OH}}=\mathrm{V}_{\mathrm{M}}-0.5 \mathrm{~V}$ | 100 |  |  | $\mu \mathrm{A}$ | 10 |
|  | $\mathrm{l}_{\mathrm{LL} 2}$ | $\mathrm{V}_{\mathrm{OL}}=0.5 \mathrm{~V}$ | 3.0 |  |  | $\mu \mathrm{A}$ | 10 |
| Output impedance | $\mathrm{D}_{\text {COM }}$ | $\mathrm{V}_{\mathrm{M}}=1.5 \mathrm{~V}$ |  | 15 |  | k $\Omega$ | 11 |
|  | $\mathrm{D}_{\mathrm{S}}$ | $\mathrm{V}_{\mathrm{M}}=1.5 \mathrm{~V}$ |  | 30 |  | $\mathrm{k} \Omega$ | 12 |
| Supply current | $\mathrm{I}_{\text {DA }}$ | $\begin{gathered} \mathrm{V}_{\mathrm{M}}=1.5 \mathrm{~V} \\ \mathrm{~T}_{\mathrm{SYS}}=122 \mu \mathrm{~S} \end{gathered}$ |  | 8/10/12 | 15 | $\mu \mathrm{A}$ | 13 |
|  | $I_{D H 1}$ <br> (Halt Mode) |  |  | 5/7/8 | 8 | $\mu \mathrm{A}$ | 14 |
|  | $\mathrm{I}_{\mathrm{D} 12}$ <br> (Halt Mode) |  |  | 3/4/5 | 5 | $\mu \mathrm{A}$ | 15 |
|  | $I_{D S}$ <br> (Stop Mode) |  |  | 1/1.5/2 | 3 | $\mu \mathrm{A}$ | 16 |

## NOTES:

1. SM5L1 specifications.
2. ${ }^{*} /{ }^{*}=$ SM5L1/L2/L3.
3. Applicable pins: $\mathrm{P1}_{0}-\mathrm{P} 1_{3}, \mathrm{P}_{2}-\mathrm{P} 2_{3}$.
4. Applicable pins: $\mathrm{OSC}_{\mathrm{IN}}, \overline{\text { RESET }}, \mathrm{T}$, INTA.
5. Applicable pins: $P 2_{0}-P 2_{3}$.
6. Applicable pins: $\mathrm{T}, \mathrm{INTA}, \mathrm{P} 1_{0}-\mathrm{P} 1_{3}$.
7. Applicable pin: $\overline{\operatorname{RESET}}$.
8. Applicable pin: $\mathrm{V}_{\mathrm{DD}}$.
9. Applicable pins; $\mathrm{PO}_{0}-\mathrm{PO}_{3}, \mathrm{~F}$.
10. Applicable pins: $\mathrm{P} 1_{0}-\mathrm{P} 1_{3}, \mathrm{P} 2_{0}-\mathrm{P} 2_{3}$.
11. Applicable pins: $\mathrm{H}_{0}-\mathrm{H}_{3}$.
12. Applicable pins: $S_{0}-S_{20}$ (SM5L1), $S_{0}-S_{33}$ (SM5L2), $\mathrm{S}_{0}-\mathrm{S}_{41}$ (SM5L3)
13. No load condition. Supply current under the operation when driving a CR oscillator
14. No load condition. Supply current when driving a CR oscillator and turning LCD ON placed the device in halt mode.
15. No load condition. Supply current when driving a CR oscillator and turning LCD OFF placed the device in halt mode.
16. No load condition. Supply current when the entire system is inactivated.


Figure 7. LCD Waveform Example

## SYSTEM CONFIGURATION

## A Register and X Register

The A register (or accumulator: $\mathrm{A}_{\mathrm{CC}}$ ) is a 4-bit general purpose register. The register is mainly used in conjunction with the ALU, C flag and RAM to transfer numerical value and data to perform various operations. The A register is also used to transfer data between input and output pins.

The X register (or auxiliary accumulator) is a 4-bit register and can be used as a temporary register. It loads contents of the A register or its content is transferred to the A register.

When the table reference instruction PAT is used, the $X$ and $A$ registers load ROM data. A pair of $A$ and $X$ registers can accommodate 8 -bit data.


5L1-8
Figure 8. Data Transfer Example Between A Register and X Register

## Arithmetic and Logic Unit (ALU) and Carry Signal Cy

The ALU performs 4-bit parallel operation. The ALU operates binary addition in conjunction with RAM, C flag and A register. The carry signal Cy is generated if a carry occurs during ALU operation. Some instructions use Cy: ADC instruction sets/clears the content of the C flag; ADX instruction causes the program to skip the next instruction. Note that Cy is the symbol for carry signal and not for C flag.


Figure 9. ALU

## $B$ Register and SB Register

## $B$ REGISTER ( $\mathrm{B}_{\mathrm{M}}, \mathrm{B}_{\mathrm{L}}$ )

The B register is an 8 -bit register that is used to specify the RAM address. The upper 4-bit section is called the $\mathrm{B}_{\mathrm{M}}$ register and lower 4-bit section is called the $B_{L}$ register.

## SB REGISTER

The SB register is an 8-bit register used as the save register for the B register. The contents of B register and SB register can be exchanged through EX instruction.


Figure 10. B Register and SB Register

## Data Memory (RAM)

The data memory (RAM) is used for storage. The RAM capacity consists of:

- SM5L1: $69 \times 4$-bit, includes $21 \times 4$-bit display RAM.
- SM5L2: $130 \times 4$-bit, includes $34 \times 4$-bit display RAM.
- SM5L3: $170 \times 4$-bit, includes $42 \times 4$-bit display RAM.

Display RAM, outputs data to an external pin for driving the segments of the LCD. Therefore, by writing data to the display RAM, the LCD can be driven at $1 / 4$ duty ( $1 / 2$ bias) to enable automatic display of the LCD.

As shown in Figure 14, the display RAM is connected to segment outputs.

- SM5L1: Port $\mathrm{S}_{0}$ to $\mathrm{S}_{20}$
- SM5L2: Port $\mathrm{S}_{0}$ to $\mathrm{S}_{33}$
- SM5L3: Port $\mathrm{S}_{0}$ to $\mathrm{S}_{41}$

These segment outputs correspond to the LCD common outputs $H_{0}$ to $H_{3}$. Data $M_{0}$ to $M_{3}$ is for one column of the display RAM and is output as a LCD drive waveform which corresponds to outputs $\mathrm{H}_{0}$ to $\mathrm{H}_{3}$. As a RAM, the display RAM operates exactly the same as other RAMs.

| $\mathrm{B}_{\mathrm{L}}$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | $A$ | $B$ | $C$ | $D$ | $E$ | $F$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 8 | $\mathrm{~S}_{0}$ | $\mathrm{~S}_{2}$ | $\mathrm{~S}_{4}$ | $\mathrm{~S}_{6}$ | $\mathrm{~S}_{8}$ | $\mathrm{~S}_{10}$ | $\mathrm{~S}_{12}$ | $\mathrm{~S}_{14}$ | $\mathrm{~S}_{16}$ | $\mathrm{~S}_{18}$ | $\mathrm{~S}_{20}$ |  |  |  |  |  |
| 9 | $\mathrm{~S}_{1}$ | $\mathrm{~S}_{3}$ | $\mathrm{~S}_{5}$ | $\mathrm{~S}_{7}$ | $\mathrm{~S}_{9}$ | $\mathrm{~S}_{11}$ | $\mathrm{~S}_{13}$ | $\mathrm{~S}_{15}$ | $\mathrm{~S}_{17}$ | $\mathrm{~S}_{19}$ |  |  |  |  |  |  |

NOTE: The area surrounded by the thick line represents the display RAM where $\mathrm{S}_{0}-\mathrm{S}_{20}$ corresponds to the segment output.

Figure 11. RAM Organization (SM5L1)

| $\mathrm{B}_{\mathrm{M}} \mathrm{B}_{\mathrm{L}}$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 3 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 4 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 5 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 8 | $\mathrm{~S}_{0}$ | $\mathrm{~S}_{2}$ | $\mathrm{~S}_{4}$ | $\mathrm{~S}_{6}$ | $\mathrm{~S}_{8}$ | $\mathrm{~S}_{10}$ | $\mathrm{~S}_{12}$ | $\mathrm{~S}_{14}$ | $\mathrm{~S}_{16}$ | $\mathrm{~S}_{18}$ | $\mathrm{~S}_{20}$ | $\mathrm{~S}_{22}$ | $\mathrm{~S}_{24}$ | $\mathrm{~S}_{26}$ | $\mathrm{~S}_{28}$ | $\mathrm{~S}_{30}$ |
| 9 | $\mathrm{~S}_{1}$ | $\mathrm{~S}_{3}$ | $\mathrm{~S}_{5}$ | $\mathrm{~S}_{7}$ | $\mathrm{~S}_{9}$ | $\mathrm{~S}_{11}$ | $\mathrm{~S}_{13}$ | $\mathrm{~S}_{15}$ | $\mathrm{~S}_{17}$ | $\mathrm{~S}_{19}$ | $\mathrm{~S}_{21}$ | $\mathrm{~S}_{23}$ | $\mathrm{~S}_{25}$ | $\mathrm{~S}_{27}$ | $\mathrm{~S}_{29}$ | $\mathrm{~S}_{31}$ |
| A | $\mathrm{S}_{32}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| B | $\mathrm{S}_{33}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

NOTE: The area surrounded by the thick line represents the display RAM where $\mathrm{S}_{0}-\mathrm{S}_{33}$ corresponds to the segment output.

Figure 12. SM5L2 RAM Organization

| $\mathrm{B}_{\text {M }}$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | $A$ | $B$ | $C$ | $D$ | $E$ | $F$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 3 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 4 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 5 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 6 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 7 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 8 | $\mathrm{~S}_{0}$ | $\mathrm{~S}_{2}$ | $\mathrm{~S}_{4}$ | $\mathrm{~S}_{6}$ | $\mathrm{~S}_{8}$ | $\mathrm{~S}_{10}$ | $\mathrm{~S}_{12}$ | $\mathrm{~S}_{14}$ | $\mathrm{~S}_{16}$ | $\mathrm{~S}_{18}$ | $\mathrm{~S}_{20}$ | $\mathrm{~S}_{22}$ | $\mathrm{~S}_{24}$ | $\mathrm{~S}_{26}$ | $\mathrm{~S}_{28}$ | $\mathrm{~S}_{30}$ |
| 9 | $\mathrm{~S}_{1}$ | $\mathrm{~S}_{3}$ | $\mathrm{~S}_{5}$ | $\mathrm{~S}_{7}$ | $\mathrm{~S}_{9}$ | $\mathrm{~S}_{11}$ | $\mathrm{~S}_{13}$ | $\mathrm{~S}_{15}$ | $\mathrm{~S}_{17}$ | $\mathrm{~S}_{19}$ | $\mathrm{~S}_{21}$ | $\mathrm{~S}_{23}$ | $\mathrm{~S}_{25}$ | $\mathrm{~S}_{27}$ | $\mathrm{~S}_{29}$ | $\mathrm{~S}_{31}$ |
| A | $\mathrm{S}_{32}$ | $\mathrm{~S}_{34}$ | $\mathrm{~S}_{36}$ | $\mathrm{~S}_{38}$ | $\mathrm{~S}_{40}$ |  |  |  |  |  |  |  |  |  |  |  |
| B | $\mathrm{S}_{33}$ | $\mathrm{~S}_{35}$ | $\mathrm{~S}_{37}$ | $\mathrm{~S}_{39}$ | $\mathrm{~S}_{41}$ |  |  |  |  |  |  |  |  |  |  |  |

NOTE: The area surrounded by the thick line represents the display
Figure 13. SM5L3 RAM Organization


Figure 14. Relationship between the Display RAM and LCD Segment Outputs/Common Outputs

## Program Counter PC and Stack Register SR

A ROM address is specified by the program counter (PC). The PC is comprised of 12 bits where 6 -bits ( $\mathrm{P}_{\mathrm{u}}$ ) are used to specify the page, and 6-bit are used to specify the step. $\mathrm{P}_{\mathrm{U}}$ is a register and $\mathrm{P}_{\mathrm{L}}$ is a binary counter. The program counter PC and the Stack Register SR are shown in Figure 15.

The table reference instruction PAT executes a similar operation to that of the subroutine jump and uses one level of the stack register.

## Program Memory (ROM)

The ROM is used for program storage. The ROM capacity of the SM5Lx is $2,048 / 3,072 / 4,096-$ step. The ROM is organized into $32 / 48 / 64$-page where one page is organized into 64 steps.


STACK REGISTER SR

Figure 15. Program Counter PC and Stack Register SR

| Page | $0^{+}$ | $01_{\mathrm{H}}$ | 02 ${ }_{H}$ | $03_{\mathrm{H}}$ | 04 ${ }_{H}$ | 05 ${ }_{\text {H }}$ | $06_{H}$ | $07_{H}$ | 08 ${ }_{\text {H }}$ | $09_{\mathrm{H}}$ | $0 \mathrm{~A}_{\mathrm{H}}$ | $0 \mathrm{~B}_{\mathrm{H}}$ | $0 \mathrm{C}_{\mathrm{H}}$ | $0 \mathrm{D}_{\mathrm{H}}$ | $0 \mathrm{E}_{\mathrm{H}}$ | $0 \mathrm{~F}_{\mathrm{H}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{P}_{\mathrm{U}}$ | 000000 | 000001 | 000010 | 000011 | 000100 | 000101 | 000110 | 000111 | 001000 | 001001 | 001010 | 001011 | 001100 | 001101 | 001110 | 001111 |
|  |  |  | $\begin{aligned} & \stackrel{\rightharpoonup}{3} \\ & \stackrel{y}{0} \\ & \underline{\underline{0}} \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |


| Page | $10_{H}$ | $11_{\text {H }}$ | $12_{\text {H }}$ | $13_{\text {H }}$ | $14_{H}$ | $15_{\mathrm{H}}$ | $16_{\text {H }}$ | $17_{\text {H }}$ | $18_{\text {H }}$ | $19_{\text {H }}$ | $1 \mathrm{~A}_{\mathrm{H}}$ | $1 \mathrm{~B}_{\mathrm{H}}$ | $1 \mathrm{C}_{\mathrm{H}}$ | $1 \mathrm{D}_{\mathrm{H}}$ | $1 \mathrm{E}_{\mathrm{H}}$ | $1 \mathrm{~F}_{\mathrm{H}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{P}_{\mathrm{U}}$ | 010000 | 010001 | 010010 | 010011 | 010100 | 010101 | 010110 | 010111 | 011000 | 011001 | 011010 | 011011 | 011100 | 011101 | 011110 | 111111 |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |


| Page | $20_{\text {H }}$ | $21_{\text {H }}$ | 22 ${ }_{\text {H }}$ | $23_{\mathrm{H}}$ | $24_{H}$ | $25_{\text {H }}$ | $26_{H}$ | $27_{\text {H }}$ | $28_{\text {H }}$ | 29 ${ }_{\text {H }}$ | $2 \mathrm{~A}_{\mathrm{H}}$ | $2 \mathrm{~B}_{\mathrm{H}}$ | $2 \mathrm{C}_{\mathrm{H}}$ | $2 \mathrm{D}_{\mathrm{H}}$ | $2 \mathrm{E}_{\mathrm{H}}$ | $2 \mathrm{~F}_{\mathrm{H}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{P}_{\mathrm{U}}$ | 100000 | 100001 | 100010 | 100011 | 100100 | 100101 | 100110 | 100111 | 101000 | 101001 | 101010 | 101011 | 101100 | 101101 | 101110 | 101111 |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |


| Page | $30_{H}$ | $31_{\mathrm{H}}$ | $32_{H}$ | $33_{\mathrm{H}}$ | $34_{\mathrm{H}}$ | $35_{H}$ | $36_{H}$ | $37_{H}$ | $38_{\mathrm{H}}$ | $39_{\mathrm{H}}$ | $3 \mathrm{~A}_{\mathrm{H}}$ | $3 \mathrm{~B}_{\mathrm{H}}$ | $3 \mathrm{C}_{\mathrm{H}}$ | $3 \mathrm{D}_{\mathrm{H}}$ | $3 \mathrm{E}_{\mathrm{H}}$ | $3 \mathrm{~F}_{\mathrm{H}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{P}_{\mathrm{U}}$ | 110000 | 110001 | 110010 | 110011 | 110100 | 110101 | 110110 | 110111 | 111000 | 111001 | 111010 | 111011 | 111100 | 111101 | 111110 | 111111 |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Figure 16. ROM Organization

## Flags

The SM5Lx provides three flag (C flag and interrupt request flags IFA and IFD) which can be used to set or determine conditions.

## Output Latch Registers and Mode Registers

The output latch registers are connected to the PO, P1 and P2 pins. By instruction, the contents of the $\mathrm{A}_{\mathrm{CC}}$ can be transferred to the output latch registers. The SM5Lx also contains mode registers RD, RE and RF. Setting the value of each register enables the LCD or interrupt to be controlled. Setting a register is performed in the same way as for the other output pins. The function of the mode registers are shown in Table 1.

## INTA PIN

- INTA level can be loaded to $\mathrm{A}_{\mathrm{CC}}$ (bit 0 ), as follows: LBLX 4 IN
- INTA level does not load directly through the noise debounce circuit (see Figure 17).


Figure 17. INTA Pin

## CAUTION

## Connecting Consideration of I/O Port

When using an I/O port as bidirectional bus such as data bus, avoid setting the I/O port to output when the target pin is also set output.
Whenever the output data conflict with each other, system failure will happen, due to damaged circuits or instantaneous supply voltage drop.


Figure 18. I/O Port Connection Precaution
Table 1. Mode Register Setting

| REGISTER |  | $\begin{aligned} & \text { SET } \\ & \text { VALUE } \end{aligned}$ | MODE DESCRIPTION |
| :---: | :---: | :---: | :---: |
| TYPE | BIT |  |  |
| RD | RD0 | 0 | Clears the ME F/F to stop a melody. |
|  |  | 1 | Sets the ME F/F to start a melody from a ROM pointer address. |
|  | RD1 | - | Sets by stop instruction (of melody code) and reset by TPB instruction. |
|  | RD2, RD3 | - | Sets '0' only. |
| RE | RE0 | 0 | Masks the interrupt based on the IFA flag. |
|  |  | 1 | Accepts the interrupt based on the IFA flag. |
|  | RE1 | - | Sets '0' only. |
|  | RE2 | 0 | Masks the interrupt based on the IFD flag. |
|  |  | 1 | Accepts the interrupt based on the IFD flag. |
|  | RE3 | - | No setting. |
| RF | RFO | 0 | Turns off the LCD. |
|  |  | 1 | Turns on the LCD. |
|  | RF1 | 0 | Stops the function of a booster circuit. |
|  |  | 1 | Operates the function of a booster circuit. |
|  | RF2 | 0 | Creates the system clock frequency by dividing the main oscillation frequency by 2 . |
|  |  | 1 | Creates the system clock frequency by dividing the main oscillation frequency by 4. |
|  | RF3 | - | Sets '0' only. |

## System Clock Generator and Dividers

The main oscillation frequency which is input through $\mathrm{OSC}_{\mathrm{IN}}-\mathrm{OSC}_{\text {OUT }}$ or $\mathrm{OSC}_{\mathrm{IN}}-\mathrm{CK}_{2}$ is divided into two or four to generate the system clock $\mathrm{f}_{\mathrm{SYS}}$. This function is shown in Figure 19.

System clock $\mathrm{f}_{\mathrm{SYS}}$ determines the execution instruction cycle so that the system clock period is the same as the instruction cycle.

However, the instruction execution cycle of twoword instruction is twice that of one word instructions.

Use of a CR oscillating element or a crystal oscillating element for the oscillator circuit is determined by the mask option. The crystal oscillator which is input through $\mathrm{OSC}_{\mathbb{I N}}-\mathrm{OSC}_{\text {OUT }}$ can be used as both real time clock
and display signal of LCD. On the final stage of the divider, fc can be set to 1 Hz or 2 Hz (in case of 32 kHz crystal oscillation) depending on the mask option.

Either of the system clock frequencies 16.384 kHz or 8.192 kHz (in case of 32.768 kHz oscillation) can be selected by the RF2 flag (see Table 2). The 8.192 kHz clock has slower command execution speed, but uses less power for the same function.

The system clock is initialized to 16.384 kHz after hardware reset operation.

Table 2 shows the relationship between the contents of RF2 flag for the OSC resonator and the generated frequency, fosys.

Table 2. OSC Resonator and Frequency $f_{S Y S}$

| FOR OSC RESONATOR | CONTENTS OF RF2 FLAG | GENERATED FREQUENCY $\mathbf{f}_{\text {SYS }}$ |
| :---: | :---: | :---: |
| 32.768 kHz crystal oscillation | 0 | 16.384 kHz |
|  | 1 | 8.192 kHz |
| 40 kHz CR oscillation | 0 | 20 kHz |
|  | 1 | 10 kHz |



Figure 19. System Clock Generator and Divider

## FUNCTIONAL DESCRIPTION

## Melody Output Function

The built-in melody generation circuit provides a variety of sound signals. Figure 20 shows the block diagram of the melody generating circuit.

The melody ROM can store notes, rest and stop commands in 160/256/256 step ( 1 step consists of 6 bits), allowing the generation of 12 scale over two octaves ( 555 to $2,097 \mathrm{~Hz}$ ) and the section of the time base for notes ( $125 / 62.5 \mathrm{~ms}$ ).


Figure 20. Melody Generating Circuit

## CONTROL PROCEDURE

The binary counter for designating the address of the melody ROM can be arbitrarily set using the PRE instruction. A performance is started and stopped by the RDO flag to ' 1 ' and ' 0 '.

The stop code generates a 'rest tell signal', and at the same time, sets the RD1 flag.

Accordingly, to stop a performance at the end of melody, the RDO flag must be clear upon detection of RD1 flag = 1 .

Next step of PRE instruction, put the NOP instruction.
The following is an example of a melody generating program.

| MELO | LAX | 2 |
| :--- | :--- | :--- |
|  | ATX |  |
|  | LAX | 1 |
|  | PRE |  |

;Set the starting address of the melody at the 21st hexadecimal step
NOP ;Dummy command


Using these functions, the user can generate music, sound effects, alarm signals, etc. as desired, and any portion of the music can be repeated. Figure 21 lists the melody output frequencies. The output frequency can be halved by making bit 5 (OCT) of the melody ROM LOW (' 0 '). In Figure 21, $m_{0}$ to $m_{3}$ show data in bits 1 to 4 of the melody ROM.

|  | $m_{3} m_{2} m_{1} m_{0}$ |  |  |  | OUTPUT FREQUENCY (Hz) | CLOCK NUMBER (NOTE 1) | (NOTE 2) |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| do | 0 | 0 | 1 | 0 | 2114.1 | 15.5 | 7 | 88 | 8 |  |
| si | 0 | 0 | 1 | 1 | 1985.9 | 16.5 | 8 | $8 \quad 8$ | 9 | L |
| la\# | 0 | 1 | 0 | 0 | 1872.4 | 17.5 | 7 | $9 \quad 9$ | 9 | - |
| la | 0 | 1 | 0 | 1 | 1771.2 | 18.5 | 7 | $9 \quad 9$ | 10 | L |
| sol\# | 0 | 1 | 1 | 0 | 1680.4 | 19.5 | 9 | $10 \quad 10$ | 10 | L |
| sol | 0 | 1 | 1 | 1 | 1560.4 | 21.0 | 10 | $11 \quad 10$ | 11 | L |
| fa\# | 1 | 0 | 0 | 0 | 1489.5 | 22.0 | 11 | $11 \quad 11$ | 11 | L |
| fa | 1 | 0 | 0 | 1 | 1394.4 | 23.5 | 11 | $12 \quad 12$ | 12 | L |
| mi | 1 | 0 | 1 | 0 | 1310.7 | 25.0 | 12 | $13 \quad 12$ | 13 | L |
| re\# | 1 | 0 | 1 | 1 | 1236.5 | 26.5 | 13 | $13 \quad 13$ | 14 | L |
| re | 1 | 1 | 0 | 0 | 1170.3 | 28.0 | 14 | $14 \quad 14$ | 14 | L |
| do\# | 1 | 1 | 0 | 1 | 1110.8 | 29.5 | 14 | $15 \quad 15$ | 15 | L |

NOTES:

1. Number of clocks for one cycle.
2. The number ( n ) in the waveforms represents the number of periods of the oscillation frequency ( 32.768 kHz ) from the crystal oscillator for the duration in that particular part of the waveform.

Figure 21. Melody Output Frequencies

## MELODY ROM INSTRUCTION

The melody ROM instruction is composed of 6 bits. The 6 -bit instruction (one set) corresponding to a musical note, generates a sound signal.

Table 3. Melody Bit Description

| BIT | DESCRIPTION |
| :---: | :--- |
| I | Control the tone length. When ' 1 ', $125 \mathrm{~ms} ;$ <br> when ' 0 ', 62.5 ms . |
| OCT | When the octave is ' 1 ', the frequency is de- <br> termined by $m_{3}-m_{0}$. When the octave is <br> ' 0 ', $1 / 2$ of the frequency determined by <br> $m_{3}-m_{0}$. |
| $m_{3}-m_{0}$ | Frequency as shown in Figure 21. Pause <br> when $m_{3}=m_{2}=m_{1}=m_{0}=0$, stop instruc- <br> tion when $m_{3}=m_{2}=m_{1}=0, m_{0}=1$. |

## EXAMPLE OF WRITING ON THE MELODY ROM

An example of writing a tone such as the following, on the melody ROM are shown in Figure 22 and Table 4.

The tone length of an initial musical note which is generated from ROM addressed data assigned by a PRE instruction has an error of maximum $\pm 4 \mathrm{~ms}$. Therefore, by applying a pause as an initial note, a melody performs with a precisely regulated tone length.


Figure 22. Melody ROM Tone Writing Example
Table 4. Melody ROM Instruction Example

| ADDRESS | DATA | MUSICAL NOTE <br> INSTRUCTION |
| :---: | :---: | :---: |
| 00 | 00 | pause |
| 01 | 27 | sol |
| 02 | 27 | sol |
| 03 | 27 | sol |
| 04 | 25 | la |
| 05 | 27 | sol |
| 06 | 27 | sol |
| 07 | $2 A$ | mi |
| 08 | $2 A$ | mo |
| 09 | 22 | do |
| 0 O | 22 | do |
| OB | 22 | re |
| 0 C | 3 C | do |
| $0 D$ | 22 | do |
| 0 E | 22 | la |
| OF | 25 | la |
| 10 | 25 | stop |
| 11 | 01 |  |

## Standby Function

A standby function is available which temporarily stops program execution to conserve power consumption. The state during which a program is in execution is called the operation mode and the state during which the execution is temporarily stopped is called the standby mode.

The standby mode further contains two modes, the stop mode and the halt mode. The stop mode stops the system section. In the stop mode, the display (LCD) is blanked. And the response speed of LCD returning to the display state (the operation) drops slightly.

The halt mode stops only the system clock generator circuit, the state of the LCD is retained. This mode is used to activate the system immediately after a condition causes a release to the operation mode.

To enter the standby mode, select either stop mode or halt mode, whichever is appropriate. See Figure 23.

During the standby mode, the contents of the RAM and C flag are retained. The contents of the flags, registers and output latches shown below are also retained.

- Flags
- IFA flag
- IFD flag
- IME flag
- Registers
- $\mathrm{A}_{\mathrm{CC}}$
- X register
- $\mathrm{B}_{\mathrm{M}}, \mathrm{B}_{\mathrm{L}}$ register
- SP
- SR
- Output latch registers
- P0 register
- P1 register
- P2 register

A release from the standby mode to the operation mode is performed by a reset port input, an interrupt from the nonmaskable INTA and divider. A maskable interrupt request cannot become a factor in releasing back to the operation mode. The mask setting is performed with RE register, see Table 1.

## CAUTION

When all of $\mathrm{P} 1_{0}$ to $\mathrm{P}_{3}$ levels are HIGH, the SM5Lx is programmed to release the standby mode and enter a normally hardware reset operation (mask option).

## TRANSITION FROM THE OPERATION MODE TO THE STANDBY MODE

The HALT instruction is executed to set the halt mode and the STOP instruction is executed to set the stop mode.

Since the interrupt is used to release from the standby mode, the mode does not transfer to the standby mode if any of the following conditions are satisfied during execution of the STOP or HALT instruction.

- REO is set and the INTA level is HIGH.
- RE2 is set and the IFD flag is set.

If any of the conditions above are satisfied, the mode does not transfer to the standby mode even if the STOP or HALT instruction is executed and the instruction at the address following that of the STOP or HALT instruction is executed. Therefore, place the JUMP instruction which specified step ' 0 ' on page 3 to the location at the address following that of the STOP or HALT instruction.


Figure 23. Operation Shift of Program

## RELEASE FROM THE STANDBY MODE TO THE OPERATION MODE

Release from the standby mode to the operation mode is based on an interrupt request from the INTA pin or divider overflow. However, the reset is limited to a nonmaskable interrupt request.

The program restarts from step 0 on page 3. However, if the IME flag is set, the instruction at step 0 on page 3 is executed and a subroutine jump is performed to the interrupt processing routine specified on page 2 according to the type of interrupt.

Even if LOW level input on INTA pin is removed before 900 command cycles, the stop mode is released.

However, the program will not jump to $20_{\mathrm{H}}$ page, interrupt process routine.

Interrupt request flag IFA is not set: the program continues at step 0 of $03_{\mathrm{H}}$ page.

## Interrupts

Interrupts originate from an INTA input or divider overflow. The IFA and IFD flags become interrupt request flags.

The interrupt block is composed of mask flags (REO, RE2), the IME flag and interrupt processing circuit.

As shown in Figure 24, resetting a mask flag enables the interrupt request flag to be independently masked. Thus, the mask flags can be used in a program to establish the interrupt priority. The priority for interrupts generated simultaneously is shown in Table 5.

Table 5. Interrupt Event Summary

| INTERRUPT REQUEST <br> (REQUEST FLAG) | JUMP DESTINATION |  | PRIORITY ORDER | INTERRUPT <br> ENABLE FLAG |
| :--- | :---: | :---: | :---: | :---: |
|  | PAGE | STEP |  | 1 |
| INTA input (IFA) | 2 | 0 | 2 | RE0 |
| Divider overflow (IFD) | 2 | 4 | 2 | RE2 |



Figure 24. Interrupt Block

When the IME flag is set, the interrupt circuit activates according to the interrupt request and a subroutine jump is performed to the specified address. The jump destinations according to interrupt origin are shown in Table 5. When the IME flag is cleared, an interrupt is not accepted even if an interrupt request is generated. The interrupt timing is shown in Figure 25 and Figure 26. The timing chart in Figure 25 shows the interrupt enable state when an interrupt request has been generated. In this case, the interrupt processing signal INT goes HIGH, one instruction cycle after the interrupt request flag is set. When INT goes HIGH, the contents of the program counter are pushed into the stack register and execution jumps to the specified address. At this time, the INT signal and the IME flag are cleared to establish the interrupt disable mode. The IME flag is set again when the RTNI instruction is executed to establish the interrupt enable mode.

The timing chart shown in Figure 26 shows the state when interrupts are enabled while multiple interrupts are generated. In this case, a subroutine jump is performed according to the interrupt having the highest priority. When returning from the subroutine by executing the RTNI instruction, the instruction (two words are executed for a two-word instruction) at the location of return is executed and the interrupt for the next highest priority is accepted.

If an interrupt request is generated during execution of a two cycle instruction, the instruction is executed after which interrupt processing is performed. If consecutive LAX instructions are skipped or if the SKIP conditions are satisfied, the skip operation is terminated after which interrupt processing is performed.

NOTE: Figures 25 and 26 show non-masked interrupt request flags.


Figure 25. Interrupt Timing Chart


Figure 26. Interrupt Timing Chart

## Hardware Reset Function

The hardware reset function mode is activated two instruction cycles after the falling edge from RESET pin. When the RESET pin is changed from HIGH to LOW, the pulse which is input by the $\mathrm{OSC}_{\text {IN }}$ pin is counter $2^{15}$ times after which the reset mode clears and the program counter starts from address 0 on page 0 .

The initialized status of the system after reset is shown in Table 6.

The following reset functions are available:

- The I/O port is set as an input port and the mode register RD, RE and RF are cleared. The output only port (PO) is cleared and output LOW.
- The interrupt request flags (IFA, IFD) and the interrupt enable flag (IME) are cleared and all interrupts become disabled.
- The program counter start from step 0 on page 0 .

For activate reset function, when power is turned on, you must connect a capacitor ( $0.1 \mu \mathrm{~F}$, TYP.) across the RESET pin and GND.

Table 6. Reset Status

| FLAG OR REGISTER, <br> REGISTER | STATUS $^{\mathbf{1}}$ | NOTES |
| :--- | :---: | :---: |
| PC | 0 |  |
| SP | Level 1 |  |
| RAM | Undefined | 2 |
| A $_{\text {CC }}$ | Undefined | 2 |
| X register | 0 | 2 |
| P0 - P2 output latch registers | 0 |  |
| Divider | 0 |  |
| IFA flag | 0 |  |
| IFD flag | 0 |  |
| IME flag | Undefined | 2 |
| C flag | Undefined | 2 |
| $\mathrm{~B}_{\mathrm{M}}, \mathrm{B}_{\mathrm{L}}$ registers | Undefined | 2 |
| Register RD (bit 1) | 0 |  |
| Register RD (bit 0) | 0 |  |
| Register RE (bit 2, 1, 0) | 0 |  |
| Register RF (bit 3, 2, 1, 0) | 0 |  |

## NOTES:

1. In reset mode and at program start.
2. Undefined flags and registers should be initialized by software.
3. When all P 1 pins $\left(\mathrm{P}_{0}\right.$ to $\left.\mathrm{P1}_{3}\right)$ level goes to HIGH, the SM5Lx is programmed to reset operation (mask option).

## LCD Function

## DISPLAY SEGMENT

The SM5Lx contains a built-in circuit which directly drive a $1 / 4$ duty, $1 / 2$ bias LCD. A sample LCD pattern is shown in Figure 27.

A segment of the LCD can be turned on or off by setting the corresponding bit in the display RAM (see Figure 14) to ' 1 ' or ' 0 '. The displayed segments can assume any configuration containing up to a maximum of $84 / 136 / 168$ segments. An example of seven segment numeric display is shown in Figure 28.


Figure 27. LCD Pattern


Figure 28. Sample LCD Pattern for Seven Segment Numeric Display

## LCD DRIVE WAVEFORMS

The LCD drive waveforms for the LCD pattern of Figure 28 displaying a ' 5 ' are shown in Figure 29 (the segment output uses $S_{0}$ and $S_{1}$ ). For Figure 29, 3 V is applied to the $\mathrm{V}_{\mathrm{DD}}$ pin, a 1.5 V is applied to the $\mathrm{V}_{\mathrm{M}}$ pin.


Figure 29. LCD Drive Waveforms

## BOOSTER CIRCUIT

The device contains a booster circuit which generates a voltage two time higher than 1.5 V power supply.

It is necessary to apply external capacitors between DDC pin and $V_{C C}$ pin as well as $V_{D D}$ pin and GND (see Figure 30).


Figure 30. Booster Circuit

## BLANK DISPLAY

There are two ways blank the entire display to match the purpose.

- Blanking the display for a short time
- Set bit 0 of the RF register to ' 1 ': Display
- Set bit 0 of the RF register to ' 0 ': Blank state
- Blanking the display for a long period mainly to reduce supply current.
- Set bit 0 and 1 of the RF register to ' 1 ': Display
- Set bit 0 and 1 of the RF register to ' 0 ': Blank state

When bit 1 of the RF register is set ' 0 ', the booster circuit does not operate and the common outputs and segment outputs are fixed to $\mathrm{V}_{\mathrm{M}}$ level, and the display blanks. By cutting off the function of the booster circuit, the supply current can be greatly reduced. However, when the display is blanked using the second method, the response speed of the LCD returning to the display state drops slightly. The RF register is on the blank state after initialization (reset state) from hardware reset.

## INSTRUCTION SET

## Definition of Symbols

The following symbols are used in descriptions for the instructions.

| SYMBOL | DEFINITION |
| :---: | :--- |
| $M$ | Content of RAM at the address specified by <br> the B register |
| $\leftarrow$ | Transfer direction |
| $\cup$ | Logical OR |
| $\cap$ | Logical AND |
| $\oplus$ | Logical XOR |
| Ai | ith bit of the ACC |
| Push | Contents of the PC are decremented to the <br> stack register |
| Pop | The decremented contents are transferred <br> back to the PC |
| Pj | Pj register ( $\mathrm{j}=3,2,1,0)$ |
| Rj | Rj register ( $\mathrm{j}=\mathrm{F}, \mathrm{E}, \mathrm{D}$ ) |
| $\mathrm{ROM} \mathrm{( } \mathrm{)}$ | ROM contents for address within ( ) |
| Cy | Carry of ALU (different from the C flag) |

- Each bit of a register can be represented. For example the ith bit of $X$ register and $R(0)$ register are represented as Xi and $\mathrm{R}(0) \mathrm{i}$. $(\mathrm{i}=0,1,2,3, \ldots$ )
- Increment and decrement denote the binary addition of $1_{H}$ and $F_{H}$, respectively.
- To skip a certain instruction means that the instruction is ignored and that no operation is performed until the execution transfers to the next instruction. In other words, the instruction is regarded as a NOP instruction. Therefore, one cycle is required to skip a one-word instruction and two cycles are required to skip a two word instruction.


## ROM Address Control Instructions

| MNEMONIC | $\begin{aligned} & \text { MACHINE } \\ & \text { CODE } \end{aligned}$ | OPERATIONS |
| :---: | :---: | :---: |
| TR x | 80 to BF | $\mathrm{P}_{\mathrm{L}} \leftarrow \mathrm{x}\left(\mathrm{l}_{5}-\mathrm{l}_{0}\right)$ |
| TL xy | $\begin{aligned} & \text { E0 to EF } \\ & 00 \text { to FF } \end{aligned}$ | $\begin{aligned} & \mathrm{P}_{\mathrm{U}} \leftarrow \mathrm{x}\left(\mathrm{I}_{11}-\mathrm{I}_{6}\right) \\ & \mathrm{P}_{\mathrm{L}} \leftarrow \mathrm{y}\left(\mathrm{I}_{5}-\mathrm{I}_{0}\right) \end{aligned}$ |
| TRS x | C0 to DF | Push, $\mathrm{P}_{\mathrm{U}} \leftarrow 01_{\mathrm{H}}$, $P_{L} \leftarrow x\left(l_{4}, I_{3}, I_{2}, I_{1}, I_{0}, 0\right)$ |
| CALL xy | $\begin{aligned} & \text { F0 to FF } \\ & 00 \text { to FF } \end{aligned}$ | $\begin{aligned} & \text { Push, } \mathrm{P}_{\mathrm{U}} \leftarrow \mathrm{x}\left(\mathrm{I}_{11}-I_{6}\right) \\ & \mathrm{P}_{\mathrm{L}} \leftarrow \mathrm{y}\left(\mathrm{I}_{5}-\mathrm{I}_{0}\right) \end{aligned}$ |
| RTN | 7D | Pop |
| RTNS | 7E | Pop, skip the next step |
| RTNI | 7F | Pop, $\mathrm{IME} \leftarrow 1$ |

## Data Transfer Instructions

| MNEMONIC | $\begin{aligned} & \hline \text { MACHINE } \\ & \text { CODE } \end{aligned}$ | OPERATIONS |
| :---: | :---: | :---: |
| LAX $x$ | 10 to 1F | $\mathrm{A}_{\mathrm{CC}} \leftarrow \mathrm{x}\left(\mathrm{I}_{3}-\mathrm{I}_{0}\right)$ |
| LBMX x | 30 to 2F | $\mathrm{B}_{\mathrm{M}} \leftarrow \mathrm{x}\left(\mathrm{I}_{3}-\mathrm{I}_{0}\right)$ |
| LBLX x | 20 to 2F | $\mathrm{B}_{\mathrm{L}} \leftarrow \mathrm{x}\left(\mathrm{I}_{3}-\mathrm{I}_{0}\right)$ |
| LDA x | 50 to 53 | $\begin{aligned} & \mathrm{A}_{\mathrm{Cc}} \leftarrow \mathrm{M}, \mathrm{~B}_{\mathrm{Mi}} \leftarrow \mathrm{~B}_{\mathrm{Mi}} \oplus \times\left(\mathrm{I}_{1}-\mathrm{I}_{0}\right) \\ & (\mathrm{i}=1,0) \end{aligned}$ |
| EXC x | 54 to 57 | $\begin{aligned} & \mathrm{M} \leftrightarrow \mathrm{~A}_{\mathrm{Cc}}, \mathrm{~B}_{\mathrm{Mi}} \leftarrow \mathrm{~B}_{\mathrm{Mi}} \oplus \times\left(\mathrm{I}_{1}-\mathrm{I}_{0}\right) \\ & (\mathrm{i}=1,0) \end{aligned}$ |
| EXCI $x$ | 58 to 5B | $\begin{aligned} & \mathrm{M} \leftrightarrow \mathrm{~A}_{\mathrm{CC}}, \mathrm{~B}_{\mathrm{L}} \leftarrow \mathrm{~B}_{\mathrm{L}}+1 \\ & \mathrm{~B}_{\mathrm{Mi}} \leftarrow \mathrm{~B}_{\mathrm{Mi}}^{\oplus} \times\left(\mathrm{I}_{1}-\mathrm{I}_{0}\right)(\mathrm{i}=1,0) \\ & \text { Skip if } \mathrm{Cy}=1\left(\mathrm{~B}_{\mathrm{L}}=0 \mathrm{~F}_{\mathrm{H}} \rightarrow 0\right) \end{aligned}$ |
| EXCD $x$ | 5C to 5F | $\begin{aligned} & \mathrm{M} \leftrightarrow \mathrm{~A}_{\mathrm{CC}}, \mathrm{~B}_{\mathrm{L}} \leftarrow \mathrm{~B}_{\mathrm{L}}+0 \mathrm{~F}_{\mathrm{H}} \\ & \mathrm{~B}_{\mathrm{Mi}} \leftarrow \mathrm{~B}_{\mathrm{Mi}} \oplus \times\left(\mathrm{I}_{1}-\mathrm{I}_{0}\right)(\mathrm{i}=1,0) \\ & \text { Skip if } \mathrm{Cy}=1\left(\mathrm{~B}_{\mathrm{L}}=0 \rightarrow 0 \mathrm{~F}_{\mathrm{H}}\right) \end{aligned}$ |
| EXAX | 64 | $\mathrm{A}_{\text {CC }} \leftrightarrow \mathrm{X}$ |
| ATX | 65 | $\mathrm{X} \leftarrow \mathrm{A}_{\mathrm{CC}}$ |
| EXBM | 66 | $\mathrm{B}_{\mathrm{M}} \leftrightarrow \mathrm{A}_{\mathrm{CC}}$ |
| EXBL | 67 | $\mathrm{B}_{\mathrm{L}} \leftrightarrow \mathrm{A}_{\mathrm{CC}}$ |
| EX | 68 | $B \leftrightarrow S B$ |

## Arithmetic Instructions

| MNE- <br> MONIC | MACHINE <br> CODE | OPERATIONS |
| :--- | :--- | :--- |
| ADX x | 00 to 0F | $A_{C C} \leftarrow \mathrm{~A}_{\mathrm{CC}}+x\left(\mathrm{I}_{3}-\mathrm{I}_{0}\right)$, <br> Skip if $\mathrm{Cy}=1$ |
| ADD | 7 A | $\mathrm{~A}_{\mathrm{CC}} \leftarrow \mathrm{A}_{\mathrm{CC}}+\mathrm{M}$ |
| ADC | 7 B | $\mathrm{A}_{\mathrm{CC}} \leftarrow \mathrm{A}_{\mathrm{CC}}+\mathrm{M}+\mathrm{C}, \mathrm{C} \leftrightarrow \mathrm{Cy}$ <br> Skip if $\mathrm{Cy}=1$ |
| COMA | 79 | $\mathrm{~A}_{\mathrm{CC}} \leftarrow \overline{\mathrm{A}}_{\mathrm{CC}}$ |
| INCB | 78 | $\mathrm{~B}_{\mathrm{L}} \leftarrow \mathrm{B}_{\mathrm{L}}+1$, Skip if $\mathrm{B}_{\mathrm{L}}=0 \mathrm{~F}_{\mathrm{H}}$ |
| DECB | 7 C | $\mathrm{B}_{\mathrm{L}} \leftarrow \mathrm{B}_{\mathrm{L}}-1$, Skip if $\mathrm{B}_{\mathrm{L}}=0$ |

## Test Instructions

| MNE- <br> MONIC | MACHINE <br> CODE | OPERATIONS |
| :--- | :--- | :--- |
| TAM | 6 F | Skip if $\mathrm{A}_{\mathrm{CC}}=\mathrm{M}$ |
| TC | 6 E | Skip if $\mathrm{C}=1$ |
| TM $x$ | 48 to 4 B | Skip if $\mathrm{Mi}=1(\mathrm{i}=3$ to 0$)$ |
| TABL | 6 B | Skip if $\mathrm{A}=\mathrm{B}_{\mathrm{L}}$ |
| TPB x | 4 C to 4 F | Skip if $\mathrm{P}(\mathrm{R}) \mathrm{i}=1,\left(\mathrm{i}=\mathrm{I}_{1}, \mathrm{I}_{0}\right)$ |
| TA | 6 C | Skip if IFA $=1$ and $(\mathrm{IFA} \leftarrow 0)$ |
| TD | 69 <br> 02 | Skip if IFD $=1$ and $(\mathrm{IFT} \leftarrow 0)$ |

## Bit Manipulation Instructions

| MNE- <br> MONIC | MACHINE <br> CODE | OPERATIONS |
| :--- | :--- | :--- |
| $\mathrm{SM} x$ | 44 to 47 | $\mathrm{Mi} \leftarrow 1(\mathrm{i}=3$ to 0$)$ |
| RM x | 40 to 43 | $\mathrm{Mi} \leftarrow 0(\mathrm{i}=3$ to 0$)$ |
| SC | 61 | $\mathrm{C} \leftarrow 1$ |
| RC | 60 | $\mathrm{C} \leftarrow 0$ |
| IE | 63 | $\mathrm{IME} \leftarrow 1$ |
| ID | 62 | $\mathrm{IME} \leftarrow 0$ |

## I/O Control Instructions

| MNE- <br> MONIC | MACHINE <br> CODE | OPERATIONS |
| :--- | :--- | :--- |
| INL | 70 | $\mathrm{~A}_{\mathrm{CC}} \leftarrow \mathrm{P} 1 \mathrm{i}(\mathrm{i}=3$ to 0$)$ |
| OUTL | 71 | $\mathrm{P} 0 \mathrm{i} \leftarrow \mathrm{A}_{\mathrm{CC}}(\mathrm{i}=3$ to 0$)$ |
| ANP | 72 | $\mathrm{Pj} \leftarrow \mathrm{Pj} \cap \mathrm{A}_{\mathrm{CC}}(\mathrm{j}=3$ to 0$)$ |
| ORP | 73 | $\mathrm{Pj} \leftarrow \mathrm{Pj} \cup \mathrm{A}_{\mathrm{CC}}(\mathrm{j}=3$ to 0$)$ |
| IN | 74 | $\mathrm{~A}_{\mathrm{CC}} \leftarrow \mathrm{Pj}(\mathrm{j}=3,2,1)$ |
| OUT | 75 | $\mathrm{Pj} \leftarrow \mathrm{A}_{\mathrm{CC}}(\mathrm{j}=3$ to 0$)$, <br> $\mathrm{Rj} \leftarrow \mathrm{A}_{\mathrm{CC}}(\mathrm{j}=\mathrm{F}$ to D$)$ |

## Table Reference Instructions

| MNE- <br> MONIC | MACHINE <br> CODE | OPERATIONS |
| :--- | :--- | :--- |
| PAT | $6 A$ <br> 00 to FF | Push <br> $\mathrm{PU}_{\mathrm{U}} \leftarrow(0,4), \mathrm{P}_{\mathrm{L}}\left(\mathrm{X}_{1}, \mathrm{X}_{0}, \mathrm{~A}_{\mathrm{CC}}\right)$ <br> $\left(\mathrm{X}, \mathrm{A}_{\mathrm{CC}}\right) \leftarrow \mathrm{I}_{7}-\mathrm{I}_{0}$ <br> Pop |

## Divider Instructions

| MNE- <br> MONIC | MACHINE <br> CODE | OPERATIONS |
| :--- | :--- | :--- |
| DR | 69 | DIV $\left(f_{7}-f_{0}\right)$ Reset |
|  | 03 | $A_{\text {CC }} \leftarrow$ Divider $\left(f_{3}-f_{0}\right)$ |
| DTA | 69 |  |
|  | 04 |  |

## Melody Control Instruction

| MNE- <br> MONIC | MACHINE <br> CODE | OPERATIONS |
| :--- | :--- | :--- |
| PRE | $6 D$ | Melody ROM pointer preset <br> Melody ROM pointer $\leftarrow \mathrm{X}, \mathrm{A}$ |

## Special Instructions

| MNE- <br> MONIC | MACHINE <br> CODE | OPERATIONS |
| :--- | :--- | :--- |
| STOP | 76 | Standby mode (STOP) |
| HALT | 77 | Standby mode (HALT) |
| NOP | 00 | No operation |

## SYSTEM CONFIGURATION EXAMPLES



Figure 31. Sports Watch Example


Figure 32. Watch and Calculator Example

## LIFE SUPPORT POLICY

SHARP components should not be used in medical devices with life support functions or in safety equipment (or similiar applications where component failure would result in loss of life or physical harm) without the written approval of an officer of the SHARP Corporation.

## LIMITED WARRANTY

SHARP warrants to its Customer that the Products will be free from defects in material and workmanship under normal use and service for a period of one year from the date of invoice. Customer's exclusive remedy for breach of this warranty is that SHARP will either (i) repair or replace, at its option, any Product which fails during the warranty period because of such defect (if Customer promptly reported the failure to SHARP in writing) or, (ii) if SHARP is unable to repair or replace, refund the purchase price of the Product upon its return to SHARP. This warranty does not apply to any Product which has been subjected to misuse, abnormal service or handling, or which has been altered or modified in design or construction, or which has been serviced or repaired by anyone other than Sharp. The warranties set forth herein are in lieu of, and exclusive of, all other warranties, express or implied. ALL EXPRESS AND IMPLIED WARRANTIES, INCLUDING THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR USE AND FITNESS FOR A PARTICULAR PURPOSE, ARE SPECIFICALLY EXCLUDED. In no event will Sharp be liable, or in any way responsible, for any incidental or consequential economic or property damage.

The above warranty is also extended to Customers of Sharp authorized distributors with the following exception: reports of failures of Products during the warranty period and return of Products that were purchased from an authorized distributor must be made through the distributor. In case Sharp is unable to repair or replace such Products, refunds will be issued to the distributor in the amount of distributor cost.

SHARP reserves the right to make changes in specifications at any time and without notice. SHARP does not assume any responsibility for the use of any circuitry described; no circuit patent licenses are implied.

## SHARP.

## NORTH AMERICA

SHARP Microelectronics of the Americas 5700 NW Pacific Rim Blvd. Camas, WA 98607, U.S.A.
Phone: (360) 834-2500
Telex: 49608472 (SHARPCAM)
Facsimile: (360) 834-8903
http://www.sharpsma.com

| EUROPE |
| :--- |
| SHARP Electronics (Europe) GmbH |
| Microelectronics Division |
| Sonninstraße 3 |
| 20097 Hamburg, Germany |
| Phone: (49) $402376-2286$ |
| Facsimile: (49) 40 2376-2232 |
| http://www.sharpmed.com |

EUROPE
SHARP Electronics (Europe) GmbH Microelectronics Division Sonninstraße 3
20097 Hamburg, Germany
Phone: (49) 40 2376-2286
http://www.sharpmed.com

ASIA
SHARP Corporation
Integrated Circuits Group 2613-1 Ichinomoto-Cho
Tenri-City, Nara, 632, Japan
Phone: (07436) 5-1321
Telex: LABOMETA-B J63428
Facsimile: (07436) 5-1532

