# **OKI** semiconductor ## MSM5052 # CMOS 4 BIT SINGLE CHIP VERY LOW POWER MICROCONTROLLER WITH TEMPERATURE DETECTION CIRCUIT AND LCD DRIVER #### **GENERAL DESCRIPTION** The OKI MSS5052 is a low-power and high-performance single-chip microcontroller employing complementary metal oxide semiconductor technology. Integrated onto a single chip are a 4 bit ALU, 18K bits of mask programmable ROM, 248 bits of data RAM, crystal oscillator, voltage doubler, timer, LCD driver, input port, output port and CR oscillator for temperature detection. The MSM5052 is widely used in electronic products requiring low power operation, for example, thermometer and clinical thermometer with a time piece. #### **FEATURES** - Low Power Consumption 3 μA Typical - 1280 × 14 Internal ROM - 62 × 4 Internal RAM - 4 × 2 Input Port - 5 Output Port - 4 × 4 Key Matrix Input (K1~K4, M1~M4) - 26 LCD Driver (1/2 Duty, 1/2 Bias, 52 Segment) - 42 Instructions - 1.5 V Operating Voltage - 32.768 kHz Crystal Oscillator - 122.1 μs Instruction Cycle - −20 to 75°C Operating Temperature - 61 pad die ## **FUNCTIONAL BLOCK DIAGRAM** ### LOGIC SYMBOL #### **CHIP PAD LAYOUT** ### **PIN DESCRIPTION** | Designation | Function | |-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------| | V <sub>DD</sub> | Circuit ground potential | | V <sub>SS1</sub> | Power source (-1.5 V) | | V <sub>SS₂</sub> | Power source for LCD driver (–3.0 V) This terminal is connected to VDD terminal through a 0.1 $\mu$ F capacitor. | | V <sub>CP</sub> , V <sub>CM</sub> | Booster capacitor connection terminals $V_{CP}$ terminal is connected to $V_{CM}$ terminal through a 0.1 $\mu$ F capacitor. | | OSC1, OSC3 | Input and output terminals of oscillator inverter, 32.768 kHz crystal is connected to these terminals. | | T1 ~ T5 | Terminals to test internal logic, T1 $\sim$ T3 and T5 are pulled down to V <sub>SS1</sub> . T4 is output. Test pins must be normally open. | | AC | Terminal to clear internal logic pulled down to V <sub>SS1</sub> . After power is turned on, the MSM5052 must be reset by this terminal. | | BD | Buzzer output | | TH, R, C, IN | Terminal to CR oscillation circuit for temperature detection, fundamental resistor, thermistor, capacitor connection terminal. | #### **FUNCTIONAL DESCRIPTION** A block diagram of the MSM5052 is given on page 91. Each block of logic will be briefly discussed. For more information, please refer to the MSM5052 user's manual. #### **Program ROM** The MSM5052 addresses up to 1.25 K words of internal mask programmable ROM. Each word consists of 14 bits and all instructions are one word. The instructions are routed to a programmed logic array which generates the signals necessary for control of logic. #### Data RAM Data is organized in 4-bit nibbles. Internal data RAM consists of 62 nibbles. The RAM is addressed by page address and column address. Normally page address is specified with page register, but direct addressing is available in Page 0. Column address is directly addressed by operand of various instructions. #### ALU The ALU performs 4-bit parallel operation on RAM and ACC contents, or RAM contents and an immediate digit. It sets or resets the flags (Z, C) depending on the condition. #### **Program Counter (PC)** The program counter is 11 bits wide and specifies the address of the program ROM. The PC is incremented by one every execution of the instruction, and then specifies the next instruction to be executed. However, the contents of the PC are rewritten by the execution of the Jump or Branch instruction. There is no boundary in the ROM, so a Jump or Branch instruction can be put anywhere in the ROM. #### Input/Output Port Input Port (S1 ~ S4) The input port (S1 $\sim$ S4) is a 4 bit parallel input port. Each pin of the port is pulled down to VSS1 by an internal resistor, and the status of the port is fetched by an input instruction. #### Input Port (K1 ~ K4) The input port $(K1 \sim K4)$ is a 4 bit parallel input port. Each pin of the port is pulled down to $V_{SS1}$ by an internal resistor, and the status of the port is fetched by an input instruction. #### Output Port (M1 $\sim$ M4) The output port (M1 $\sim$ M4) is a 4 bit parallel output port. This port consists of data latches and buffers, and the contents of the data latches are rewritten by an output instruction. #### **Output Port (LD)** The output port (LD) is single output port. This terminal is used for loading of M1 to M4 data. #### **Display Function** The MSM5052 is provided with a segment output terminal which can directly drive a 1/2 bias, 1/2 duty LCD and the common drive output terminal COM1 and COM2. The segment drive circuit consists of the display data latch, multiplexer and driver. If the data is sent to the display data latch with a display instruction, the LCD drive waveform is output to the segment drive output terminal. #### Time Base The time base for the CPU is provided by connecting a 32.768 kHz crystal to the OSC1 and OSC3 pins. One machine cycle is 122.1 $\mu$ s. A hardware divider up to 1 Hz is provided enabling programs to implement a clock function by counting signals between 16 and 1 Hz. #### **Temperature Detection Circuit** The temperature detection circuit is composed of an external thermistor, a fundamental resistor, a capacitor and a built-in CR oscillation circuit. Two types of temperature measurement circuit, as shown below, are available. ## **ABSOLUTE MAXIMUM RATINGS** | Parameter | Symbol | Conditions | Limits | Unit | |---------------------|------------------------------------|------------|--------------------------------|------| | Supply Voltage 1 | V <sub>DD</sub> - V <sub>SS1</sub> | Ta = 25°C | -0.3 to +2.0 | V | | Supply Voltage 2 | V <sub>DD</sub> - V <sub>SS2</sub> | Ta = 25°C | -0.3 to +4.0 | V | | Input Voltage | V <sub>IN1</sub> | Ta = 25°C | V <sub>SS</sub> , -0.3 to +0.3 | V | | Storage Temperature | Tstg | | -55 to 125 | °C | ## **OPERATING CONDITIONS** | Parameter | Symbol | Limits | Unit | |-----------------------|-----------------------------------|--------------|------| | Operating Voltage | V <sub>DD</sub> -V <sub>SS1</sub> | 1.25 to 1.65 | ٧ | | Operating Temperature | Topr | -20 to 75 | °C | ## DC CHARACTERISTICS $(V_{DD} = 0V, V_{SS_1} = -1.55V, V_{SS_2} = -3.0V, C_I = 30k\Omega, Ta = 25^{\circ}C)$ | Donomotor | 0 | O and distant | | Unit | | | | |-------------------------------|-------------------|---------------------------------|------|------|------|-----|--| | Parameter | Symbol | Condition | Min. | Тур. | Мах. | | | | Power supply current 1 | I <sub>DD</sub> 1 | Temperature sampling off | _ | 3.0 | _ | μΑ | | | Power supply current 2 | I <sub>DD2</sub> | Temperature sampling on | _ | 100 | _ | μΑ | | | Oscillation start voltage | -vosc | Within 10 seconds VSS1 terminal | 1.45 | _ | - | ٧ | | | | lOH1 | V <sub>OH1</sub> = -0.2V | -4 | _ | _ | Ī | | | Output current 1<br>COM | I <sub>OM</sub> 1 | $V_{OM_1} = V_{SS_1} \pm 0.2V$ | 4/-4 | _ | _ | μΑ | | | | l <sub>OL1</sub> | $V_{OL_1} = -2.8V$ | 4 | _ | _ | | | | Output current 2 | lOH₂ | $V_{OH_2} = -0.2V$ | -0.4 | _ | - | μΑ | | | SEGMENT | IOL2 | $V_{OL_2} = -2.8V$ | 0.4 | | _ | | | | Output current 3 | lOH₃ | $V_{OH_3} = -0.4 \text{ V}$ | -400 | _ | - | μΑ | | | C. R. TH | I <sub>OL3</sub> | $V_{OL_3} = -1.15V$ | 400 | _ | _ | μ^_ | | | Output current 4 | lOH₄ | $V_{OH_4} = -0.4V$ | -100 | - | - | | | | M1∼M₄ LD | loL₄ | $V_{OL_4} = -1.15V$ | 10 | - | | μΑ | | | Output current 5 | lOH₅ | $V_{OH_5} = -0.4V$ | -50 | - | -500 | | | | BD | lOL₅ | $V_{OL_5} = -1.15V$ | 4 | - | - | μΑ | | | Input current | IIH1 | V <sub>IH1</sub> = 0V | 1 | 10 | 100 | | | | S1~S4 K1~K4 | IIL1 | $V_{ L_1} = -1.55V$ | - | _ | -0.2 | μΑ | | | Oscillator built-in capacitor | CD | | _ | 25 | _ | pF | | ## **MEASURING CIRCUIT** ### TYPICAL APPLICATION ## **DESCRIPTION OF INSTRUCTIONS** | | Instruction Code | | | | | | | | | | | Operation | | | | | | | |----------------------|------------------|---------------|----|----|----|---|---|---|-----|---|---------------|-----------|---|---|---|---------------------------------------------|--|--| | | IVIIIemonic | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Operation | | | | | ADD ACC, AP | 0 | 0 | 0 | 0 | 0 | Р | 0 | 1 | 0 | 0 | | _ | 4 | | AP - (AP) + (ACC) | | | | | ADD #D, AP | 0 | 1 | 1 | 0 | 0 | Р | | ( | ) | | | - | A | | AP ← (AP) — D | | | | | ADC AP | 0 | 0 | 0 | 0 | 0 | Р | 0 | 1 | 0 | 1 | | - | Α | | AP ← Decimal adjust {(AP) + (ACC) + (C)} | | | | 5 | SUB ACC, AP | 0 | 0 | 0 | 0 | 1 | Р | 0 | 1 | 0 | 0 | | - | 4 | | AP ← (AP) – (ACC) | | | | erat | SUB #D, AP | 0 | 1 | 1 | 0 | 1 | Р | | ( | ) | | | , | 4 | | AP ← (AP) — D | | | | Arithmetic operation | SBC AP | 0 | 0 | 0 | 0 | 1 | Р | 0 | 1 | 0 | 1 | | , | A | | AP ← Decimal adjust<br>{(AP) – (ACC) – (C)} | | | | Ħ | CMP ACC, AP | 0 | 0 | 0 | 0 | 1 | Р | 1 | 1 | 1 | 0 | | , | Ą | | (AP) - (ACC) | | | | Arit | CMP #D, AP | 0 | 1 | 0 | 1 | 1 | Р | | ( | ) | | | - | Ą | | (AP) — D | | | | | INC AP | 0 | 1 | 1 | 0 | 0 | P | 0 | 0 | 0 | 1 | | , | A | | AP ← (AP) + 1 | | | | | DEC AP | 0 | 1 | 1 | 0 | 1 | Р | 0 | 0 | 0 | 1 | | - | A | | A ← (AP) — 1 | | | | | XOR ACC, AP | 0 | 0 | 0 | 0 | 0 | Р | 0 | 1 | 1 | 1 | | - | A | | AP ← (AP) ★ (ACC) | | | | | XOR #D, AP | 0 | 1 | 1 | 1 | 1 | Р | | ( | D | | | - | A | | AP ← (AP) ♥ D | | | | | BIT ACC, AP | 0 | 0 | 0 | 0 | 0 | Р | 1 | 1 | 1 | 0 | | | A | | (AP) V (ACC) | | | | Ĕ | BIT #D, AP | 0 | 1 | 0 | 1 | 0 | Р | | ı | D | | | | A | | (AP) V D | | | | Bit operation | BIS ACC, AP | 0 | 0 | 0 | 0 | 0 | Р | 0 | 1 | 1 | 0 | | | A | | AP ← (AP) V (ACC) | | | | obe | BIS #D, AP | P 0 1 0 0 0 P | | 1 | D | | | | A | | AP ← (AP) V D | | | | | | | | | Bit | BIC ACC, AP | 0 | 0 | 0 | 0 | 1 | Р | 0 | 1 | 1 | 0 | | | A | | AP ← (AP) Λ(ACC) | | | | | BIC #D, AP | 0 | 1 | 0 | 0 | 1 | Р | | - 1 | D | | | | A | | $AP \leftarrow (AP) \land \overline{D}$ | | | | # | ASR AP | 0 | 0 | 0 | 0 | 0 | Р | 0 | 0 | 1 | 1 | | | A | | (C) 0 → (AP) | | | | Shift | ASL AP | 0 | 0 | 0 | 0 | 1 | Р | 0 | 0 | 1 | 1 | | | Α | | (C) ← (AP) ← 0 | | | | | CLZ | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | z ← 0 | | | | o | CLC | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | c ← o | | | | erati | CLA | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | z ← 0, c ← 0 | | | | Flag operation | SEZ | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | Z ← 1 | | | | Flag | SEC | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | C ← 1 | | | | | SEA | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | Z ← 1, C ← 1 | | | | | MOV ACC, AP | 1 | 1 | 1 | 1 | 0 | Р | 0 | 0 | 0 | 0 | | | A | | AP ← (ACC) | | | | | MOV ACC, AX | 1 | 1 | 1 | 1 | 0 | 0 | 0 | | Х | | | | Α | | AX ← (ACC) | | | | Data transfer | MOV #D, AP | 0 | 1 | 1 | 1 | 0 | Р | | | D | | | | A | | AP ← D | | | | tran | MOV AP, ACC | 1 | 1 | 1 | 1 | 1 | Р | 0 | 0 | 0 | 0 | | | A | | ACC ← (AP) | | | | ata | MOV AX, ACC | 1 | 1 | 1 | 1 | 1 | 0 | 0 | | Х | | | | Α | | ACC ← (AX) | | | | Ω | CHG AP | 1 | 1 | 1 | 0 | 0 | Р | 0 | 0 | 0 | 0 | | | A | | (ACC) ←→ (AP) | | | | | CHG AX | 1 | 1 | 1 | 0 | 0 | 0 | 0 | | Х | | | | A | | (ACC) ← (AX) | | | ## **DESCRIPTION OF INSTRUCTIONS (CONT.)** | | Mnemonic | Instruction Code | | | | | | | | | | | | | Operation | | | | | |------------------|------------------|------------------|----|----|-----|----|----------------|----|----------------|----------------|----------------|----------------|----------------|----|----------------|------------------------------------------|--|--|--| | | Willemonic | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Operation | | | | | | JMP adrs | 1 | 0 | 0 | a,, | a, | a <sub>8</sub> | a, | a <sub>6</sub> | a <sub>s</sub> | a <sub>4</sub> | a <sub>3</sub> | a <sub>2</sub> | aı | a <sub>o</sub> | PC ← adrs | | | | | | JMP @AP | 0 | 0 | 0 | 0 | 0 | P | 1 | 1 | 0 | 1 | | | 4 | | PC ← (PC) + (AP) + 1 | | | | | | JMPIO @AP | 0 | 0 | 0 | 0 | 1 | Р | 1 | 1 | 0 | 1 | | , | Δ. | | PC ← (PC) + [(AP)A7H] ++1 | | | | | | BEP +n<br>BZE +n | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | n <sub>4</sub> | n <sub>3</sub> | n, | n, | n <sub>o</sub> | PC ← (PC) + n + 1, if Z = 1 | | | | | du | BNE +n<br>BNZ +n | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | n <sub>4</sub> | n <sub>3</sub> | n, | n, | n <sub>o</sub> | PC ← (PC) + n + 1, if Z = 0 | | | | | Jump | BCS +n<br>BLT +n | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | n <sub>4</sub> | n, | n <sub>2</sub> | n, | n <sub>o</sub> | PC ← (PC) + n + 1, if C = 1 | | | | | | BCC +n<br>BGE +n | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | n <sub>4</sub> | n <sub>3</sub> | n <sub>2</sub> | n, | n <sub>o</sub> | PC ← (PC) + n + 1, if C = 0 | | | | | | BGT +n | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | n <sub>4</sub> | n <sub>3</sub> | n <sub>2</sub> | n, | n <sub>o</sub> | PC ← (PC) + n + 1, if Z = 0<br>and C = 0 | | | | | | BLE +n | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | n <sub>4</sub> | n <sub>3</sub> | n <sub>2</sub> | n, | n <sub>o</sub> | PC ← (PC) + n + 1, if Z = 1<br>or C = 1 | | | | | ıt. | INP Port, AP | 1 | 1 | 0 | 1 | 0 | Р | | Po | rt | | | - | 4 | | AP ← (Port) | | | | | Input/<br>Output | OUT AP, Port | 1 | 1 | 0 | 1 | 1 | Ρ | | Pc | rt | | | - | 4 | | Port ← (AP) | | | | | =0 | OUT #D, Port | 0 | 0 | 0 | 1 | 0 | 0 | | Po | rt | | | ( | ) | | Port ← D | | | | | Display | DSP digit, AP | 0 | 0 | 1 | 0 | 0 | P | | di | git | | | - | 4 | | digit ← (AP), (ACC) | | | | | Disp | DSPF digit, AP | 0 | 0 | 1 | 1 | 0 | P | | di | git | | | - | 4 | | digit ← (AP) via table | | | | | CPU | HALT | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Halt CPU | | | | | CPU | NOP | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | No Operation | | | |