# **LAPIS Semiconductor** FEDL9042-01 Issue Date: Nov. 19, 2003 # ML9042-xx # DOT MATRIX LCD CONTROLLER DRIVER #### **GENERAL DESCRIPTION** The ML9042 used in combination with an 8-bit or 4-bit microcontroller controls the operation of a character type dot matrix LCD. #### **FEATURES** - Easy interfacing with an 8-bit or 4-bit microcontroller - Switchable between serial and parallel interfaces - Dot-matrix LCD controller driver for a $5 \times 8$ dot font - Built-in circuit allowing automatic resetting at power-on - Built-in 17 common signal drivers and 100 segment signal drivers - Two built-in character generator ROMs each capable of generating 240 characters (5 × 8 dots) The character generator ROM can be selected by bank switching (ROM1S) pin. - Creation of character patterns by programming: up to 8 character patterns (5 × 8 dots) - Built-in RC oscillation circuit using external or internal resistors - Program-selectable duties - When ABE bit is "L": 1/8 duty (1 line: $5 \times 8$ dots), or 1/16 duty (2 lines: $5 \times 8$ dots) - When ABE bit is "H": 1/9 duty (1 line: $5 \times 8$ dots + arbitrator), or 1/17 duty (2 lines: $5 \times 8$ dots + arbitrator) - Cursor display - Built-in bias dividing resistors to drive the LCD - Bi-directional transfer of segment outputs - Bi-directional transfer of common outputs - 100-dot arbitrator display - · Line display shifting - Built-in voltage multiplier circuit - Gold Bump Chip # ML9042-xx CVWA/DVWA - \*xx indicates a character generator ROM code number. - \*01, 11 and 21 indicate general character generator ROM code numbers. - CVWA indicates a bump chip with high hardness, and DVWA indicates a bump chip with low hardness. # **BLOCK DIAGRAM** # I/O CIRCUITS Applied to pins $T_1$ , $T_2$ , and $T_3$ Applied to pins RW/SI, RS1, and RS0/CSB Applied to pins E/SHTB, SP, ROM1S, and BE Applied to pins DB<sub>0</sub>(SO) to DB<sub>7</sub> # PIN DESCRIPTIONS | Symbol | Description | | | | | | | |-----------------------------------------|-----------------------------------------------------------------------------------------------------|-------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | RW/SI | The input pin with a pull-up resistor to select Read ("H") or Write ("L") in the Parallel I/F Mode. | | | | | | | | RW/3i | | ata in the Serial I/F Mod<br>ng edge of the E/SHTB | de. Each instruction code and each data are signal. | | | | | | | The input pins with | n a pull-up resistor to se | elect a register in the Parallel I/F Mode. | | | | | | | RS <sub>1</sub> RS <sub>0</sub> /CSB Name of register | | | | | | | | DO /OOD DO | H | Н | Data register | | | | | | RS <sub>0</sub> /CSB, RS <sub>1</sub> | H | L | Instruction register | | | | | | | L | L | Expansion Instruction register | | | | | | | | is configured as a chip<br>to "L" allows the I/F to b | enable input in the Serial I/F Mode. Setting pe provided. | | | | | | | | lata input/output betwee<br>ons in the Parallel I/F M | en the CPU and the ML9042 and for Mode. | | | | | | E/SHTB | PW/SI pin is synch | nronized to the rising ed | t in the Serial I/F Mode. The data input to the lge of the clock, and the data output from the g edge of the shift clock. | | | | | | | | | ower-order 4 bits between the CPU and the sare not used for the 4-bit interface. | | | | | | DB <sub>0</sub> (SO) to DB <sub>3</sub> | & address and da | | data output in the Serial I/F Mode. Busy flag zed to the falling edge of the E/SHTB signal. s not output. | | | | | | | Each pin is equipp | ed with a pull-up resisto | or, so this pin should be open when not used. | | | | | | DB <sub>4</sub> to DB <sub>7</sub> | | | upper 4 bits between the CPU and the sare not used for the serial interface. | | | | | | DB4 to DB7 | Each pin is equipp<br>Mode when not us | | or, so this pin should be open in the Serial I/F | | | | | | | | on pins required for LC ctions sent from the CP | D drive signals and the operation of the U. | | | | | | | To input external of pins should be op- | • | ould be used. The $OSC_{R3}$ , $OSC_{R5}$ , and $OSC_2$ | | | | | | OSC₁<br>OSC₂ | | | or, the resistor should be connected between d OSC <sub>R5</sub> pins should be open. | | | | | | ${\sf OSC_{R3}} \ {\sf OSC_{R5}}$ | | • | al resistor, the $OSC_2$ and $OSC_{R5}$ pins should ne $OSC_1$ and $OSC_{R3}$ pins should be open. | | | | | | | | • | al resistor, the $OSC_2$ and $OSC_{R3}$ pins should ne $OSC_1$ and $OSC_{R5}$ pins should be open. | | | | | | | (The OSC <sub>2</sub> , OSC <sub>8</sub> and the OSC <sub>1</sub> pin | • | also be short-circuited outside the ML9042, | | | | | | | The LCD commor | signal output pins. | | | | | | | COM <sub>1</sub> to COM <sub>17</sub> | 1/9 duty, non-sele | - | eforms are output via COM <sub>9</sub> to COM <sub>17</sub> . For ms are output via COM <sub>10</sub> to COM <sub>17</sub> . For 1/16 is output via COM <sub>17</sub> . | | | | | | SEG <sub>1</sub> to SEG <sub>100</sub> | The LCD segmen | t signal output pins. | | | | | | | Symbol | Description | |-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DOMAG | The input pin to switch the ROM bank. "H" selects ROM1 and "L" selects ROM0. | | ROM1S | Switching after power-on is prohibited. | | | The pins to output bias voltages to the LCD. | | $V_1\;,V_2,V_{3A},V_{3B},V_4$ | For $1/4$ bias : The $V_2$ and $V_{3B}$ pins are shorted. | | | For 1/5 bias : The V <sub>3A</sub> and V <sub>3B</sub> pins are shorted. | | | The input pin to enable or disable the voltage multiplier circuit. | | | "L" disables the voltage multiplier circuit. "H" enables the voltage multiplier circuit. | | BE | The voltage multiplier circuit doubles the input voltage between the $V_{\text{IN}}$ pin and the GND pin, and the multiplied voltage referenced to the GND is output to the $V_{\text{OUT}}$ pin. The voltage multiplier circuit can be used only when generating a level higher than the $V_{\text{DD}}$ . | | TEST <sub>IN</sub> | The input pin for test circuits. Normally connect this pin to V <sub>DD</sub> . | | TEST <sub>OUT</sub> | The output pin for the test circuits. Normally leave this pin open. | | V <sub>IN</sub> | The pin to input voltage to the voltage multiplier. | | | The pins to supply the LCD drive voltage. | | $V_0$ , $V_{OUT}$ | The same potential as the $V_{DD}$ potential is supplied to the $V_{OUT}$ and $V_0$ pins when the voltage multiplier is not used (BE = "0" or BE = "1", and the capacitor is not connected to the $V_C$ and $V_{CC}$ pins) When the voltage multiplier is used (BE = "1"), the multiplied voltage is output to the $V_{OUT}$ pin, so that the $V_{OUT}$ pin and $V_0$ pin should be connected. | | | Capacitors for the voltage multiplier should be connected between the GND and the $V_{\text{OUT}}$ pin. | | V <sub>C</sub> | The pin to connect the negative pin of the capacitor for the voltage multiplier. Leave the pin open when the voltage multiplier circuit is not used. | | Vcc | The pin to connect the positive pin of the capacitor used for the voltage multiplier. Leave the pin open when the voltage multiplier circuit is not used. | | $T_1, T_2, T_3$ | The input pins for test circuits (normally open). Each of these pins is equipped with a pull-down resistor, so this pin should be left open. | | $V_{DD}$ | The power supply pin. | | GND | The ground level input pin. | | | The input pin to select the serial or parallel interface. | | SP | "L" selects the parallel interface. | | | "H" selects the serial interface. | | DUMMYV <sub>DD</sub> | The output pin to fix the adjacent input pin to the $V_{\text{DD}}$ level. Use this pin only for this purpose. | | DUMMYGND | The output pin to fix the adjacent input pin to the GND level. Use this pin only for this purpose. | | DUMMY | NC (No Connection) pin. | #### ABSOLUTE MAXIMUM RATINGS (GND = 0 V) | Parameter | Symbol | Condition | Rating | Unit | Applicable pins | |---------------------|--------------------------------------|-----------|------------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Supply Voltage | $V_{DD}$ | Ta = 25°C | -0.3 to +6.5 | V | $V_{DD}$ | | LCD Driving Voltage | $V_{0}, V_{1}, V_{2}, V_{3}, V_{4},$ | Ta = 25°C | -0.3 to +6.5 | V | V <sub>OUT</sub> , V <sub>0</sub> , V <sub>1</sub> , V <sub>2</sub> , V <sub>3A</sub> , V <sub>3B</sub> , V <sub>4</sub> , GND | | Input Voltage | Vı | Ta = 25°C | -0.3 to V <sub>DD</sub> +0.3 | ٧ | RW/SI, E/SHTB, SP,<br>RS <sub>0</sub> /CSB, RS <sub>1</sub> , BE,<br>ROM1S, T <sub>1</sub> to T <sub>3</sub> , DB <sub>0</sub> (SO)<br>to DB <sub>7</sub> , V <sub>IN</sub> | | Storage Temperature | T <sub>STG</sub> | _ | -55 to +150 | °C | _ | #### RECOMMENDED OPERATING CONDITIONS (GND = 0 V) | Parameter | Symbol | Condition | Range | Unit | Applicable pins | |---------------------------------|------------------------------|-----------|-------------|------|-----------------------| | Supply Voltage | $V_{DD}$ | _ | 2.7 to 5.5 | V | $V_{DD}$ | | LCD Driving Voltage | V <sub>0</sub><br>(See Note) | _ | 2.7 to 5.5 | V | $V_{\text{OUT}}, V_0$ | | Voltage Multipler Input Voltage | V <sub>MUL</sub> | BE = "1" | 1.8 to 2.75 | V | V <sub>IN</sub> | | Operating Temperature | T <sub>op</sub> | _ | -40 to +85 | °C | _ | Note: This voltage should be applied across $V_0$ and GND. The following voltages are output to the $V_1$ , $V_2$ , $V_{3A}$ ( $V_{3B}$ ) and $V_4$ pins: • 1/4 bias (V<sub>2</sub> and V<sub>3B</sub> are short-circuited) $V_1 = 3 V_0/4 \pm 0.15 V$ $V_2 = V_{3B} = V_0/2 \pm 0.15 \text{ V}$ $V_4 = V_0/4 \pm 0.15 \text{ V}$ • 1/5 bias (V<sub>3A</sub> and V<sub>3B</sub> are short-circuited) $V_1 = 4 V_0/5 \pm 0.15 V$ $V_2 = 3 V_0/5 \pm 0.15 V$ $V_{3A} = V_{3B} = 2 \ V_0/5 \ \pm 0.15 \ V$ $V_4 = V_0/5 \pm 0.15 \text{ V}$ The voltages at the V<sub>0</sub>, V<sub>1</sub>, V<sub>2</sub>, V<sub>3A</sub> (V<sub>3B</sub>), V<sub>4</sub> and GND pins should satisfy $$V_0 > V_1 > V_2 > V_{3A} (V_{3B}) > V_4 > GND$$ (Higher $\leftarrow \rightarrow Lower$ ) - \* If the chip is attached on a substrate using COG technology, the chip tends to be susceptible to electrical characteristics of the chip due to trace resistance on the glass substrate. It is recommended to use the chip by confirming that it operates on the glass substrate properly. Trace resistance, especially, V<sub>DD</sub> and V<sub>SS</sub> trace resistance, between the chip on the LCD panel and the flexible cable should be designed as low as possible. Trace resistance that cannot be very well decreased, larger size of the LCD panel, or greater trace capacitance between the microcontroller and the ML9042 device can cause device malfunction. In order to avoid the device malfunction, power noise should be reduced by serial interfacing of the microcontroller and the ML9042 device. - \* Do not apply short-circuiting across output pins and across an output pin and an input/output pin or the power supply pin in the output mode. # **ELECTRICAL CHARACTERISTICS** # **DC** Characteristics $(GND = 0 \text{ V}, \text{ V}_{DD} = 2.7 \text{ to } 5.5 \text{ V}, \text{ Ta} = -40 \text{ to } +85^{\circ}\text{C})$ | | $(GND = 0 \text{ V}, \text{V}_{DD} = 2.7 \text{ to } 5.5 \text{ V},$ | | | | | | V, Ia | $t = -40 \text{ to } +85^{\circ}\text{C}$ | | |-----------------------------------------------|----------------------------------------------------------------------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|---------------------------|---------------------|-------|---------------------------------------------------------------------------------------|--| | Parameter | Symbol | Cond | ition | Min. | Тур. | Max. | Unit | Applicable pin | | | "H" Input Voltage | V <sub>IH</sub> | | _ | | _ | $V_{DD}$ | | RW/SI,<br>RS <sub>0</sub> /CSB, RS <sub>1</sub> ,<br>E/SHTB, | | | "L" Input Voltage | V <sub>IL</sub> | _ | | | _ | 0.2V <sub>DD</sub> | V | DB <sub>0</sub> (SO) to<br>DB <sub>7</sub> , SP,<br>OSC <sub>1</sub> , BE,<br>ROM1S | | | "H" Output Voltage 1 | $V_{OH1}$ | $I_{OH} = -0.1 \text{ mA}$ | | $0.9V_{DD}$ | _ | — | V | DB <sub>0</sub> (SO) to | | | "L" Output Voltage 1 | $V_{OL1}$ | $I_{OL} = +0.1 \text{ mA}$ | | _ | _ | $0.1V_{DD}$ | V | DB <sub>7</sub> | | | "H" Output Voltage 2 | $V_{OH2}$ | $I_{OH} = -13 \mu A$ | | $0.9V_{DD}$ | _ | | V | 000 | | | "L" Output Voltage 2 | V <sub>OL2</sub> | $I_{OL}$ = +13 $\mu$ A | | _ | _ | $0.1V_{DD}$ | V | OSC <sub>2</sub> | | | | V <sub>CH</sub> | $I_{OCH} = -4 \mu A$ | | V <sub>0</sub> -0.3 | V <sub>0</sub> –<br>0.012 | V <sub>0</sub> | | | | | COM Voltage Drop | V <sub>CMH</sub> | $I_{OCMH} = \pm 4 \mu A$ | V <sub>0</sub> –GND = 5 V | V <sub>1</sub> -0.3 | V <sub>1</sub> ± 0.012 | V <sub>1</sub> +0.3 | V | COM <sub>1</sub> to | | | COM Vollage Drop | V <sub>CML</sub> | $I_{OCML} = \pm 4 \mu A$ | Note 1 | V <sub>4</sub> -0.3 | V <sub>4</sub> ± 0.012 | V <sub>4</sub> +0.3 | V | COM <sub>17</sub> | | | | V <sub>CL</sub> | I <sub>OCL</sub> = +4 μA | | GND | GND+<br>0.012 | GND+0.3 | | | | | | V <sub>SH</sub> I <sub>OSH</sub> | $I_{OSH} = -4 \mu A$ | | V <sub>0</sub> -0.3 | V <sub>0</sub> –<br>0.012 | V <sub>0</sub> | | | | | SEG Voltage Drop | V <sub>SMH</sub> | $I_{OSMH} = \pm 4 \mu A$ | V <sub>0</sub> –GND = 5 V | V <sub>2</sub> -0.3 | V <sub>2</sub> ± 0.012 | V <sub>2</sub> +0.3 | V | SEG <sub>1</sub> to<br>SEG <sub>100</sub> | | | SEG Vollage Diop | V <sub>SML</sub> | $I_{OSML} = \pm 4 \mu A$ | Note 1 | V <sub>3</sub> -0.3 | V <sub>3</sub> ± 0.012 | V <sub>3</sub> +0.3 | V | | | | | V <sub>SL</sub> | l <sub>OSL</sub> = +4 μA | | GND | GND+<br>0.012 | GND+0.3 | | | | | Input Leakage Current | IIL | $V_{DD} = 5 \text{ V}, \text{ V}_{I} =$ | 5 V or 0 V | _ | _ | 1.0 | μΑ | E/SHTB, BE,<br>SP, V <sub>IN</sub> | | | | | $V_{DD} = 5 V, V_I =$ | GND | 10 | 25 | 61 | | RW/SI, | | | Input Current 1 | 1 | Excluding curre through the pull | V <sub>DD</sub> = 5 V, V <sub>I</sub> = V <sub>DD</sub> ,<br>Excluding current flowing<br>through the pull-up resistor<br>and the output driving MOS | | _ | 2.0 | μΑ | RS <sub>0</sub> /CSB, RS <sub>1</sub> ,<br>DB <sub>0</sub> (SO) to<br>DB <sub>7</sub> | | | | | $V_{DD} = 5 V, V_I =$ | V <sub>DD</sub> | 15 | 45 | 105 | - | | | | Input Current 2 | | Excluding curre | V <sub>DD</sub> = 5 V, V <sub>I</sub> = GND<br>Excluding current flowing<br>through the pull-down resistor | | _ | 2.0 | μΑ | T <sub>1</sub> , T <sub>2</sub> , T <sub>3</sub> | | | Supply Current | I <sub>DD</sub> | $V_{DD} = 5 \text{ V}$ | Note 2 | _ | | 1.2 | mΑ | V <sub>DD</sub> -GND | | | Oscillation Frequency of External Resistor Rf | f <sub>osc1</sub> | Rf = 85 k $\Omega$ ±2% | Note 3 | 175 | 270 | 400 | kHz | OSC <sub>1</sub> , OSC <sub>2</sub> | | | Oscillation Frequency of Internal Resistor Rf | | | $V_{DD} = 4.0 \text{ to } 5.5 \text{ V}$ $Ta = -20 \text{ to } 75^{\circ}\text{C}$ $OSC_1 \text{ and } OSC_{R3}$ : Ope $OSC_2 \text{ and } OSC_{R5}$ : Short-circuited | en<br>Note 4 | 200 | 270 | 351 | kHz | OSC <sub>1</sub> , OSC <sub>2</sub> ,<br>OSC <sub>R5</sub> | |-----------------------------------------------|--------------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-----|------|------|-----|----------------------------------------------------------------------------------------------------------------| | | | f <sub>osc2</sub> | $V_{DD}$ = 2.7 to 3.6 V<br>Ta = -20 to 75°C<br>$OSC_1$ and $OSC_{R5}$ : Open<br>$OSC_2$ and $OSC_{R3}$ :<br>Short-circuited Note 4 | | 200 | 280 | 364 | kHz | OSC <sub>1</sub> , OSC <sub>2</sub> ,<br>OSC <sub>R3</sub> | | lock | Clock Input<br>Frequency | f <sub>in</sub> | OSC <sub>2</sub> , OSC <sub>R</sub> : Open<br>Input from OSC <sub>1</sub> | | 175 | | 400 | kHz | | | <u>~</u> | Input Clock Duty | f <sub>duty</sub> | | Note 5 | 45 | 50 | 55 | % | OSC <sub>1</sub> | | External Clock | Input Clock Rise<br>Time | f <sub>rf</sub> | | Note 6 | _ | | 0.2 | μS | 0001 | | ш | Input Clock Fall Time | f <sub>ff</sub> | | Note 6 | _ | _ | 0.2 | μS | | | LCD Bias Resistor | | | -0x code | | 1.4 | 2.0 | 2.6 | kΩ | V <sub>0</sub> , V <sub>1</sub> , V <sub>2</sub> , V <sub>3A</sub> ,<br>V <sub>3B</sub> , V <sub>4</sub> , GND | | | | R <sub>LB</sub> | -1x code | | 2.8 | 4.0 | 5.2 | kΩ | V <sub>0</sub> , V <sub>1</sub> , V <sub>2</sub> , V <sub>3A</sub> ,<br>V <sub>3B</sub> , V <sub>4</sub> , GND | | | | | -2x code | | 7.0 | 10.0 | 13.0 | kΩ | V <sub>0</sub> , V <sub>1</sub> , V <sub>2</sub> , V <sub>3A</sub> ,<br>V <sub>3B</sub> , V <sub>4</sub> , GND | $(GND = 0 \text{ V}, \text{ V}_{DD} = 2.7 \text{ to } 5.5 \text{ V}, \text{ Ta} = -40 \text{ to } +85^{\circ}\text{C})$ | Parameter | Symbol | Condition | | Min. | Тур. | Max. | Unit | Applicable pins | |--------------------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------|------|--------------------------------------------|------|-----------------------| | Voltage Multiplier<br>Input Voltage | V <sub>MUL</sub> | Note 7 | | 1.8 | _ | 2.75 | V | V <sub>IN</sub> | | | | $V_{DD} = 2.7 \text{ V}, V_{IN} = 2.25 \text{ V}$<br>f = 175 kHz<br>A capacitor for the voltage | 1/5<br>bias | 4.3 | _ | (V <sub>DD</sub> -V <sub>IN</sub> )<br>× 2 | | | | Voltage Multiplier<br>Output Voltage | V <sub>оит</sub> | multiplier = 1 to 4.7 $\mu$ F<br>$V_{OUT}$ load current = 54 $\mu$ A<br>BE = "H"<br>Applied to LCD bias<br>resistance of 10 $k\Omega$ (TYP)<br>only | 1/4<br>bias | 4.3 | _ | (V <sub>DD</sub> -V <sub>IN</sub> )<br>× 2 | V | V <sub>оит</sub> | | Bias Voltage for Driving LCD | V <sub>LCD1</sub> | V <sub>0</sub> –GND Note 8 | 1/5<br>bias | 2.7 | _ | 5.5 | V | V <sub>0</sub> | | | V <sub>LCD2</sub> | Note o | 1/4<br>bias | 2.7 | _ | 5.5 | V | <b>v</b> <sub>0</sub> | Note 1: Applied to the voltage drop occurring between any of the $V_0$ , $V_1$ , $V_4$ and GND pins and any of the common pins (COM<sub>1</sub> to COM<sub>17</sub>) when the current of 4 $\mu$ A flows in or flows out at one common pin. Also applied to the voltage drop occurring between any of the $V_0$ , $V_2$ , $V_{3A}$ ( $V_{3B}$ ) and GND pins and any of the segment pins (SEG<sub>1</sub> to SEG<sub>100</sub>) when the current of 4 $\mu$ A flows in or flows out at one segment pin. The current of 4 $\mu$ A flows out when the output level is $V_{DD}$ or flows in when the output level is $V_5$ . Note 2: Applied to the current flowing into the $V_{DD}$ pin when the external clock ( $f_{OSC2} = f_{in} = 270$ kHz) is fed to the internal $R_f$ oscillation or OSC<sub>1</sub> under the following conditions: $V_{DD} = V_0 = 5 \text{ V}$ GND = 0 V, $V_1$ , $V_2$ , $V_{3A}$ ( $V_{3B}$ ) and $V_4$ : Open E/SHTB and BE: "L" (fixed) Other input pins: "L" or "H" (fixed) Other output pins: No load Note 3: Note 4: OSC<sub>2</sub> and R<sub>f</sub> should be as short as possible. Keep OSC<sub>R3</sub> and OSC<sub>R5</sub> open. The wire between OSC<sub>1</sub> and R<sub>f</sub> and the wire between The wire between OSC<sub>R3</sub> and OSC<sub>2</sub>, or between OSC<sub>R5</sub> and OSC<sub>2</sub> should be as short as possible. Keep open between OSC<sub>1</sub> and OSC<sub>R3</sub>, or between OSC<sub>1</sub> and OSC<sub>R5</sub>. ## Note 5: # Note 6: Applied to the pulses entering from the OSC<sub>1</sub> pin - The maximum value of the voltage multiplier input voltage should be set at 2.75 V, and the Note 7: minimum value of the voltage multiplier input voltage should be set by monitoring the voltage of V<sub>0</sub> in actual use so that the voltage multiplier output voltage meets the specification for the bias voltage for driving LCD after contrast adjustment. - Note 8: For 1/4 bias, $V_2$ and $V_{3B}$ pins are short-circuited. $V_{3A}$ pin is open. For 1/5 bias, $V_{3A}$ and $V_{3B}$ pins are short-circuited. $V_2$ pin is open. # I/O Characteristics ## • Parallel Interface Mode The timing for the input from the CPU and the timing for the output to the CPU are as shown below: # 1) WRITE MODE (Timing for input from the CPU) $(V_{DD} = 2.7 \text{ to } 4.5 \text{ V}, \text{ Ta} = -40 \text{ to } +85^{\circ}\text{C})$ | Parameter | Symbol | Min. | Тур. | Max. | Unit | |---------------------------------------------------------------|----------------|------|------|------|------| | RW/SI, RS <sub>0</sub> /CSB, RS <sub>1</sub> Setup Time | t <sub>B</sub> | 40 | _ | _ | ns | | E/SHTB Pulse Width | t <sub>W</sub> | 450 | _ | _ | ns | | RW/SI, RS <sub>0</sub> /CSB, RS <sub>1</sub> Hold Time | t <sub>A</sub> | 10 | _ | _ | ns | | E/SHTB Rise Time | t <sub>r</sub> | _ | _ | 125 | ns | | E/SHTB Fall Time | t <sub>f</sub> | _ | _ | 125 | ns | | E/SHTB Pulse Width | t∟ | 430 | _ | _ | ns | | E/SHTB Cycle Time | t <sub>C</sub> | 1000 | _ | _ | ns | | DB <sub>0</sub> (SO) to DB <sub>7</sub> Input Data Setup Time | tı | 195 | _ | _ | ns | | DB <sub>0</sub> (SO) to DB <sub>7</sub> Input Data Hold Time | t <sub>H</sub> | 10 | _ | _ | ns | $(V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, \text{ Ta} = -40 \text{ to } +85^{\circ}\text{C})$ | Parameter | Symbol | Min. | Тур. | Max. | Unit | |---------------------------------------------------------------|----------------|------|------|------|------| | RW/SI, RS <sub>0</sub> /CSB, RS <sub>1</sub> Setup Time | t <sub>B</sub> | 40 | _ | _ | ns | | E/SHTB Pulse Width | t <sub>W</sub> | 220 | _ | _ | ns | | RW/SI, RS <sub>0</sub> /CSB, RS <sub>1</sub> Hold Time | t <sub>A</sub> | 10 | _ | _ | ns | | E/SHTB Rise Time | t <sub>r</sub> | _ | _ | 125 | ns | | E/SHTB Fall Time | t <sub>f</sub> | _ | _ | 125 | ns | | E/SHTB Pulse Width | t∟ | 220 | _ | _ | ns | | E/SHTB Cycle Time | t <sub>C</sub> | 500 | _ | _ | ns | | DB <sub>0</sub> (SO) to DB <sub>7</sub> Input Data Setup Time | tı | 60 | _ | _ | ns | | DB <sub>0</sub> (SO) to DB <sub>7</sub> Input Data Hold Time | t <sub>H</sub> | 10 | _ | _ | ns | # 2) READ MODE (Timing for output to the CPU) $(V_{DD} = 2.7 \text{ to } 4.5 \text{ V}, \text{ Ta} = -40 \text{ to } +85^{\circ}\text{C})$ | Parameter | Symbol | Min. | Тур. | Max. | Unit | |----------------------------------------------------------------|----------------|------|------|------|------| | RW/SI, RS <sub>1</sub> , RS <sub>0</sub> /CSB Setup Time | t <sub>B</sub> | 40 | _ | _ | ns | | E/SHTB Pulse Width | t <sub>W</sub> | 450 | _ | _ | ns | | RW/SI, RS <sub>1</sub> , RS <sub>0</sub> /CSB Hold Time | t <sub>A</sub> | 10 | _ | _ | ns | | E/SHTB Rise Time | t <sub>r</sub> | _ | _ | 125 | ns | | E/SHTB Fall Time | t <sub>f</sub> | _ | _ | 125 | ns | | E/SHTB Pulse Width | t <sub>L</sub> | 430 | _ | _ | ns | | E/SHTB Cycle Time | t <sub>C</sub> | 1000 | _ | _ | ns | | DB <sub>0</sub> (SO) to DB <sub>7</sub> Output Data Delay Time | t <sub>D</sub> | _ | _ | 350 | ns | | DB <sub>0</sub> (SO) to DB <sub>7</sub> Output Data Hold Time | to | 20 | _ | _ | ns | Note: A load capacitance of each of $DB_0(SO)$ to $DB_7$ must be 50 pF or less. $(V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, \text{ Ta} = -40 \text{ to } +85^{\circ}\text{C})$ | | ( v | טט – ד.ס נס כ | 7.5 v, ra – | <del>1</del> 0 10 +03 0) | | |----------------------------------------------------------------|----------------|---------------|-------------|--------------------------|------| | Parameter | Symbol | Min. | Тур. | Max. | Unit | | RW/SI, RS <sub>1</sub> , RS <sub>0</sub> /CSB Setup Time | t <sub>B</sub> | 40 | _ | _ | ns | | E/SHTB Pulse Width | t <sub>W</sub> | 220 | _ | _ | ns | | RW/SI, RS <sub>1</sub> , RS <sub>0</sub> /CSB Hold Time | t <sub>A</sub> | 10 | _ | _ | ns | | E/SHTB Rise Time | t <sub>r</sub> | _ | _ | 125 | ns | | E/SHTB Fall Time | t <sub>f</sub> | _ | _ | 125 | ns | | E/SHTB Pulse Width | t <sub>L</sub> | 220 | _ | _ | ns | | E/SHTB Cycle Time | t <sub>C</sub> | 500 | _ | _ | ns | | DB <sub>0</sub> (SO) to DB <sub>7</sub> Output Data Delay Time | t <sub>D</sub> | _ | _ | 250 | ns | | DB <sub>0</sub> (SO) to DB <sub>7</sub> Output Data Hold Time | t <sub>O</sub> | 20 | _ | _ | ns | Note: A load capacitance of each of $DB_0(SO)$ to $DB_7$ must be 50 pF or less. # • Serial Interface Mode $(V_{DD} = 2.7 \text{ to } 5.5 \text{ V}, \text{ Ta} = -40 \text{ to } +85^{\circ}\text{C})$ | | | · · · · · · · · · · · · · · · · · · · | | , | | |---------------------------------------------|-------------------|---------------------------------------|------|------|------| | Parameter | Symbol | Min. | Тур. | Max. | Unit | | E/SHTB Cycle Time | tscy | 500 | | _ | ns | | RS <sub>0</sub> /CSB Setup Time | t <sub>CSU</sub> | 100 | 1 | _ | ns | | RS <sub>0</sub> /CSB Hold Time | t <sub>CH</sub> | 100 | 1 | _ | ns | | RS <sub>0</sub> /CSB "H" Pulse Width | t <sub>CSWH</sub> | 200 | - | _ | ns | | E/SHTB Setup Time | t <sub>SSU</sub> | 60 | 1 | _ | ns | | E/SHTB Hold Time | t <sub>SH</sub> | 200 | 1 | _ | ns | | E/SHTB "H" Pulse Width | tswH | 200 | 1 | _ | ns | | E/SHTB "L" Pulse Width | t <sub>SWL</sub> | 200 | - | _ | ns | | E/SHTB Rise Time | t <sub>SR</sub> | _ | 1 | 125 | ns | | E/SHTB Fall Time | t <sub>SF</sub> | _ | - | 125 | ns | | RW/SI Setup Time | t <sub>DISU</sub> | 100 | _ | _ | ns | | RW/SI Hold Time | t <sub>DIH</sub> | 100 | _ | _ | ns | | DB <sub>0</sub> (SO) Output Data Delay Time | t <sub>DOD</sub> | _ | _ | 160 | ns | | DB <sub>0</sub> (SO) Output Data Hold Time | t <sub>CDH</sub> | 0 | _ | _ | ns | | | | | | | | #### **FUNCTIONAL DESCRIPTION** ### Instruction Register (IR), Data Register (DR), and Expansion Instruction Register (ER) These registers are selected by setting the level of the Register Selection input pins $RS_0/CSB$ and $RS_1$ . The DR is selected when both $RS_0/CSB$ and $RS_1$ are "H". The IR is selected when $RS_0/CSB$ is "L" and $RS_1$ is "H". The ER is selected when both $RS_0/CSB$ and $RS_1$ are "L". (When $RS_0/CSB$ is "H" and $RS_1$ is "L", the ML9042 is not selected.) The IR stores an instruction code and sets the address code of the display data RAM (DDRAM) or the character generator RAM (CGRAM). The microcontroller (CPU) can write but cannot read the instruction code. The ER sets the display positions of the arbitrator and the address code of the arbitrator RAM (ABRAM). The CPU can write but cannot read the display positions of the arbitrator. The DR stores data to be written in the DDRAM, ABRAM and CGRAM and also stores data read from the DDRAM, ABRAM and CGRAM. The data written in the DR by the CPU is automatically written in the DDRAM, ABRAM or CGRAM. When an address code is written in the IR or ER, the data of the specified address is automatically transferred from the DDRAM, ABRAM or CGRAM to the DR. The data of the DDRAM, ABRAM and CGRAM can be checked by allowing the CPU to read the data stored in the DR. After the CPU writes data in the DR, the data of the next address in the DDRAM, ABRAM or CGRAM is selected to be ready for the next writing by the CPU. Similarly, after the CPU reads the data in the DR, the data of the next address in the DDRAM, ABRAM or CGRAM is set in the DR to be ready for the next reading by the CPU. Writing in or reading from these 3 registers is controlled by changing the status of the RW/SI pin. RW/SI RS<sub>0</sub>/CSB RS₁ Operation L L Н Writing in the IR Н L Н Reading the Busy flag (BF) and the address counter (ADC) Н L Η Writing in the DR Н Н Н Reading from the DR L L L Writing in the ER Disabled (Not in a busy state, not performing the reads. Н L L Note that the data bus goes into a high impedance state.) Disabled (Not in a busy state, not performing the writes) L L Н Disabled (Not in a busy state, not performing the reads. Н Н L Note that the data bus goes into a high impedance state.) Table 1 RW/SI pin status and register operation #### **Busy Flag (BF)** The status "1" of the Busy Flag (BF) indicates that the ML9042 is carrying out internal operation. When the BF is "1", any new instruction is ignored. When RW/SI = "H", $RS_0/CSB = "L"$ and $RS_1 = "H"$ , the data in the BF is output to the $DB_7$ . New instructions should be input when the BF is "0". When the BF is "1", the output code of the address counter (ADC) is undefined. ## Address Counter (ADC) The address counter provides a read/write address for the DDRAM, ABRAM or CGRAM and also provides a cursor display address. When an instruction code specifying DDRAM, ABRAM or CGRAM address setting is input to the pre-defined register, the register selects the specified DDRAM, ABRAM or CGRAM and transfers the address code to the ADC. The address data in the ADC is automatically incremented (or decremented) by 1 after the display data is written in or read from the DDRAM, ABRAM or CGRAM. The data in the ADC is output to $DB_0(SO)$ to $DB_6$ when RW/SI = "H", $RS_0/CSB = "L"$ , $RS_1 = "H"$ and BF = "0". ## **Timing Generator** The timing generator generates timing signals for the internal operation of the ML9042 activated by the instruction sent from the CPU or for the operation of the internal circuits of the ML9042 such as DDRAM, ABRAM, CGRAM and CGROM. Timing signals are generated so that the internal operation carried out for LCD displaying will not be interfered by the internal operation initiated by accessing from the CPU. For example, when the CPU writes data in the DDRAM, the display of the LCD not corresponding to the written data is not affected. ## **Display Data RAM (DDRAM)** This RAM stores the 8-bit character codes (see Table 2). The DDRAM addresses correspond to the display positions (digits) of the LCD as shown below. The DDRAM addresses (to be set in the ADC) are represented in hexadecimal. 1) Relationship between DDRAM addresses and display positions (1-line display mode) In the 1-line display mode, the ML9042 can display up to 20 characters from digit 1 to digit 20. While the DDRAM has addresses "00" to "4F" for up to 80 character codes, the area not used for display can be used as a RAM area for general data. When the display is shifted by instruction, the relationship between the LCD display position and the DDRAM address changes as shown below: 2) Relationship between DDRAM addresses and display positions (2-line display mode) In the 2-line mode, the ML9042 can display up to 40 characters (20 characters per line) from digit 1 to digit 20. | | Digi | t | | | | | | | | | |--------|------|----|----|----|----|---------------|----|----|---|-----------------------| | | | | | 4 | | | | | | Display position | | Line 1 | 00 | 01 | 02 | 03 | 04 | $\overline{}$ | 12 | 13 | - | DD RAM | | Line 2 | 40 | 41 | 42 | 43 | 44 | $\sim$ | 52 | 53 | • | address (hexadecimal) | Note: The DDRAM address at digit 20 in the first line is not consecutive to the DDRAM address at digit 1 in the second line. When the display is shifted by instruction, the relationship between the LCD display position and the DDRAM address changes as shown below: # **Character Generator ROM (CGROM)** The CGROM generates character patterns ( $5 \times 8$ dots, 240 patterns) from the 8-bit character code signals in the DDRAM. The bank switching pin (ROM1S) can switch to the other ROM that generates character patterns ( $5 \times 8$ dots, 240 patterns), allowing a total of 480 characters to be controlled. When the 8-bit character code corresponding to a character pattern in the CGROM is written in the DDRAM, the character pattern is displayed in the display position specified by the DDRAM address. Character codes 10 to FF are contained in the ROM area in the CG ROM. The general character generator ROM codes are 01/11/21. The relationship between character codes and general purpose character patterns in Bank0 (ROM0) and Bank1 (ROM1) are indicated in Table 2-1 and Table 2-2, respectively. #### **Character Generator RAM (CGRAM)** The CGRAM is used to generate user-specific character patterns that are not in the CGROM. CGRAM (64 bytes = 512 bits) can store up to 8 character patterns ( $5 \times 8 \text{ dots}$ ). When displaying a character pattern stored in the CGRAM, write an 8-bit character code (00 to 07 or 08 to 0F; hex.) to the DDRAM. This enables outputting the character pattern to the LCD display position corresponding to the DDRAM address. The cursor or blink is also displayed even when a CGRAM or ABRAM address is set in the ADC. Therefore, the cursor or blink display should be inhibited while the ADC is holding a CGRAM or ABRAM address. The following describes how character patterns are written in and read from the CGRAM. (See Tables 2-1 and 2-2.) #### (1) A method of writing character patterns to the CGRAM from the CPU The three CGRAM address bit weights 0 to 2 select one of the lines constituting a character pattern. First, set the mode to increment or decrement from the CPU, and then input the CGRAM address. Write each line of the character pattern in the CGRAM through DB<sub>0</sub>(SO) to DB<sub>7</sub>. The data lines DB<sub>0</sub>(SO) to DB<sub>7</sub> correspond to the CGRAM data bit weights 0 to 7, respectively (see Table 3-1). Input data "1" represents the ON status of an LCD dot and "0" represents the OFF status. Since the ADC is automatically incremented or decremented by 1 after the data is written to the CGRAM, it is not necessary to set the CGRAM address again. The bottom line of a character pattern (the CGRAM address bit weights 0 to 2 are all "1", which means 7 in hexadecimal) is the cursor line. The ON/OFF pattern of this line is ORed with the cursor pattern for displaying on the LCD. Therefore, the pattern data for the cursor position should be all zeros to display the cursor. Whereas the data given by the CGRAM data bit weights 0 to 4 is output to the LCD as display data, the data given by the CGRAM data bit weights 5 to 7 is not. Therefore, the CGRAM data bit weights 5 to 7 can be used as a RAM area. #### (2) A method of displaying CGRAM character patterns on the LCD The CGRAM is selected when the higher-order 4 bits of a character code are all zeros. Since bit weight 3 of a character code is not used, the character pattern "0" in Table 3-1 can be selected using the character code "00" or "08" in hexadecimal. When the 8-bit character code corresponding to a character pattern in the CGRAM is written to the DDRAM, the character pattern is displayed in the display position specified by the DDRAM address. (The DDRAM data bit weights 0 to 2 correspond to the CGRAM address bit weights 3 to 5, respectively.) #### **Arbitrator RAM (ABRAM)** The arbitrator RAM (ABRAM) stores arbitrator display data. 100 dots can be displayed in both 1-line and 2-line display modes. The arbitrator RAM has the addresses (hexadecimal) from "00" to "1F" and the valid display address area is from 00 to 19 (0H to 13H). The area of 20 to 31 (14H to 1FH) not used for display can be used as a data RAM area for general data. Even if the display is shifted by instruction, the arbitrator display is not shifted. A capacity of 8 bits by 32 addresses (= 256 bits) is available for data write. First set the mode to increment or decrement from the CPU, and then input the ABRAM address. Write Display-ON data in the ABRAM through DB<sub>0</sub>(SO) to DB<sub>7</sub>. $DB_0(SO)$ to $DB_7$ correspond to the ABRAM data bit weights 0 to 7 respectively. Input data "1" represents the ON status of an LCD dot and "0" represents the OFF status. Since ADC is automatically incremented or decremented by 1 after the data is written to the ABRAM, it is not necessary to set the ABRAM address again. Whereas ABRAM data bit weights 0 to 4 are output as display data to the LCD, the ABRAM data bit weights 5 to 7 are not. These bits can be used as a RAM area. The cursor or blink is also displayed even when a CGRAM or ABRAM address is set in the ADC. Therefore, the cursor or blink display should be inhibited while the ADC is holding a CGRAM or ABRAM address. The arbitrator RAM can store a maximum of 100 dots of the arbitrator Display-ON data in units of 5 dots. The relationship with the LCD display positions is shown below. Table 2-1 Character Codes in Bank0 (ROM1S = "0") | | l | | | | | | | | | I | | | | l | I | | |--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|---------------------------------------|--------------|-----------------------------------------|--------------|--------------|--------------| | Lower 4 bits | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 | 1000 | 1001 | 1010 | 1011 | 1100 | 1101 | 1110 | 1111 | | 0000 | CGRAM<br>(1) | CGRAM<br>(2) | CGRAM<br>(3) | CGRAM<br>(4) | CGRAM<br>(5) | CGRAM<br>(6) | CGRAM<br>(7) | CGRAM<br>(8) | CGRAM<br>(1) | CGRAM<br>(2) | CGRAM<br>(3) | CGRAM<br>(4) | CGRAM<br>(5) | CGRAM<br>(6) | CGRAM<br>(7) | CGRAM<br>(8) | | 0001 | :-: | | | | | # | <b>=</b> | : | # :- | | | €. | | | -= | | | 0010 | | i | ## | | | #· | | ••• | ·. | <b>&gt;</b> | : | | ; | | == | ••• | | 0011 | | | | • | | | | • | | | ## | : | • | | | •*** | | 0100 | | | | | <b></b> - | | | - | | | | | | | | | | 0101 | | | | = | | | | = = = | | | | | | | | | | 0110 | ••• | | | <b>=</b> | | | | | | | • • • • • • • • • • • • • • • • • • • | | ••••••••••••••••••••••••••••••••••••••• | | | | | 0111 | | | - | -:::- | | | | | × | | | <b></b> | ••••• | | | - | | 1000 | | | | -== | | | | • ••• | | | | | | | | | | 1001 | | • | | | | | | | | | | | | | | | | 1010 | | | : | | ••• | == | | <b>:</b> | <b>'</b> | | | | #: | | | • <u>•</u> • | | 1011 | | | • | • | | | | | ••• | • | | •• | <b></b> .• | | | •!<br>! | | 1100 | -:: | = | ij | | • | <b>.</b> | | <b>.</b> :: | # | | • | <b></b> | • | ••• | - : - | • | | 1101 | | | <b>"</b> ×. | | | | | • | | | <b>.</b> | | • | | | | | 1110 | | | | | | | | | # | | ₽₩ | <b>::</b> | | | | | | 1111 | | | | * | | <b></b> | | <b></b> | ₩. | | | | <b>.</b> | <b>. !</b> | | | Table 2-2 Character Codes in Bank1 (ROM1S = "1") | Lower 4 bits | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 | 1000 | 1001 | 1010 | 1011 | 1100 | 1101 | 1110 | 1111 | |--------------|--------------|--------------|------------------|--------------|----------------------------------------|--------------|--------------|----------------------------------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------| | 0000 | CGRAM<br>(1) | CGRAM<br>(2) | CGRAM<br>(3) | CGRAM<br>(4) | CGRAM<br>(5) | CGRAM<br>(6) | CGRAM<br>(7) | CGRAM<br>(8) | CGRAM<br>(1) | CGRAM<br>(2) | CGRAM<br>(3) | CGRAM<br>(4) | CGRAM<br>(5) | CGRAM<br>(6) | CGRAM<br>(7) | CGRAM<br>(8) | | 0001 | | | | | ٠ | | | | | ="="= | | | | | • | -::- | | 0010 | | | | | ==== | | | <b></b> | <b>!</b> | <b>}</b> | <b>:</b> | | ;= | | == | ••• | | 0011 | | | | | | | | •••• | | | ## | :: | | | • | • | | 0100 | | | | | <b>=</b> - | = | | | | | ! | | | | | | | 0101 | | | | | | | | | | | | | | | •••• | | | 0110 | •• | | | <b>=</b> | | | ₽ | | | | | | | | <b>!-"</b> ! | | | 0111 | | | | | | | <b>!!</b> | | × | | | •••• | | <sup></sup> | • | - | | 1000 | | | ▎ ▗▘ | <b>₽</b> . | L∎ ≣ | | <b>=</b> _ | | | | | = = | | | | | | 1001 | | | | | | | | | | | | === | | ••••• | | | | 1010 | | | <b>■</b> | | - <sub>-</sub> | # | | | • <b>•</b> • | | | | | | | : : : | | 1011 | | • | • | | | •••• | | | | | | _ | <b>∷</b> | | = | •• | | 1100 | -=== | <b></b> | | <b></b> | <b>.</b> | <b>!</b> | | •••••••••••••••••••••••••••••••••••••• | <b></b> | ! | | | | ••• | | ••• | | 1101 | | | .:: <sup>‡</sup> | | | | | •••• | | | <b>.</b> | | • •• | ••<br>•••• | ••• | | | 1110 | | | | • | •••••••••••••••••••••••••••••••••••••• | | | | | | | | | | | | | 1111 | | | | | | | | | | | | | | | | | Note: The same CGRAM character patterns are displayed in Bank0 and Bank1. Table 3-1 Relationship between CGRAM address bits, CGRAM data bits (character pattern) and DDRAM data bits (character code) in $5 \times 7$ dot character mode. (Examples) | CĢ | | | CG F | | | | | DD RAM data | |--------------|---------------------------------|-----------------------------------------------|--------------|-----------------------------------------|------------------------------------------------------|-----------------------------------------------|---|----------------------------| | add | | _ | (Char | | | | | (Character code) | | 5 4 3<br>MSB | | 1 (<br>LSE | 7 6 5<br>MSB | 4 | | LSB | | 7 6 5 4 3 2 1 0<br>MSB LSB | | 0 0 0 | 0<br>0<br>0<br>0<br>1<br>1<br>1 | 0 0<br>0 1<br>1 0<br>1 1<br>0 0<br>1 1<br>1 1 | | 1<br>1<br>1<br>1<br>0 | 1 1<br>0 0<br>0 0<br>0 0<br>0 0<br>0 0<br>1 1<br>0 0 | 1 0<br>0 1<br>0 1<br>0 1<br>0 1<br>1 0<br>0 0 | | 0000×000 | | 0 0 1 | 0<br>0<br>0<br>0<br>1<br>1<br>1 | 0 C<br>0 1<br>1 C<br>1 1<br>0 C<br>0 1<br>1 C | | 1<br>1<br>1<br>1 | 0 0<br>0 0<br>0 1<br>1 0<br>0 1<br>0 0<br>0 0 | 0 1<br>1 0<br>0 0<br>0 0<br>0 0<br>1 0<br>0 1 | | 0000×001 | | | | | | | | | ŀ | | | 1 1 1 | 0<br>0<br>0<br>1 | 0 0<br>0 1<br>1 0<br>1 1<br>0 0<br>0 1<br>1 0 | ××× | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 1<br>0 1<br>0 1<br>0 1<br>0 1<br>0 1<br>1 1 | 1 0<br>0 0<br>0 0<br>0 0<br>0 0<br>1 0<br>0 0 | | 0000×111 | x: Don't Care #### **Cursor/Blink Control Circuit** This circuit generates the cursor and blink of the LCD. The operation of this circuit is controlled by the program of the CPU. The cursor/blink display is carried out in the position corresponding to the DDRAM address set in the ADC (Address Counter). For example, when the ADC stores a value of "07" (hexadecimal), the cursor or blink is displayed as follows: Note: The cursor or blink is also displayed even when a CGRAM or ABRAM address is set in the ADC. Therefore, the cursor or blink display should be inhibited while the ADC is holding a CGRAM or ABRAM address. # LCD Display Circuit (COM1 to COM17, SEG1 to SEG100, SSR and CSR) The ML9042 has 17 common signal outputs and 100 segment signal outputs to display 20 characters (in the 1-line display mode) or 40 characters (in the 2-line display mode). The character pattern is converted into serial data and transferred in series through the shift register. The transfer direction of serial data is determined by the SSR bit. The shift direction of common signals is determined by the CSR bit. The following tables show the transfer and shift directions: | SSR bit | | Tra | ansfer dire | ection | | |---------|---------|------|--------------------------|------------------|-------------------------| | L | | S | $EG_1 \rightarrow SE$ | G <sub>100</sub> | | | H | | S | $EG_{100} \rightarrow S$ | SEG <sub>1</sub> | | | ABE bit | CSR bit | duty | AS bit | Shift Direction | Arbitrator's common pin | | L | L | 1/8 | L | COM1→COM8 | None | | L | L | 1/8 | Н | COM1→COM8 | None | | L | L | 1/16 | L | COM1→COM16 | None | | L | L | 1/16 | Н | COM1→COM16 | None | | L | Н | 1/8 | L | COM8→COM1 | None | | L | Н | 1/8 | Н | COM8→COM1 | None | | L | Н | 1/16 | L | COM16→COM1 | None | | L | Н | 1/16 | Н | COM16→COM1 | None | | Н | L | 1/9 | L | COM1→COM9 | СОМ9 | | Н | L | 1/9 | Н | COM1→COM9 | COM1 | | Н | L | 1/17 | L | COM1→COM17 | COM17 | | Н | L | 1/17 | Н | COM1→COM17 | COM1 | | Н | Н | 1/9 | L | COM9→COM1 | COM1 | | Н | Н | 1/9 | Н | COM9→COM1 | COM9 | | Н | Н | 1/17 | L | COM17→COM1 | COM1 | | | | | | | | <sup>\*</sup> Refer to the Expansion Instruction Codes section about the ABE bit, SSR bit, CSR bit, and AS bit. COM17→COM1 COM17 Н Н 1/17 Н Signals to be input to the SSR bit, CSR bit, ABE bit, and AS bit should be initially determined at power-on and be kept unchanged. #### **Built-in Reset Circuit** The ML9042 is automatically initialized when the power is turned on. During initialization, the Busy Flag (BF) is "1" and the ML9042 does not accept any instruction from the CPU (other than the Read BF instruction). The Busy Flag is "1" for about 15 ms after the $V_{\text{DD}}$ becomes 2.7 V or higher. During this initialization, the ML9042 performs the following instructions: 1) Display clearing 2) CPU interface data length = 8 bits (DL = "1")1-line LCD display (N = "0")3) (I/D = "1")ADC counting = Increment 4) (S = "0")5) Display shifting = None (D = "0")Display = Off6) Cursor = Off(C = "0")7) (B = "0")8) Blinking = Off9) Arbitrator = Displayed in the lower line (AS = "0")10) Arbitrator = Not displayed (ABE = "0")(SSR = "0") 11) Segment shift direction = $SEG_1 \rightarrow SEG_{100}$ 12) Common shift direction = $COM_1 \rightarrow COM_{17}$ To use the built-in reset circuit, the power supply conditions shown below should be satisfied. Otherwise, the built-in reset circuit may not work properly. In such a case, initialize the ML9042 with the instructions from the CPU. The use of a battery always requires such initialization from the CPU. (See "Initial Setting of Instructions") (CSR = "0") Figure 1 Power-on and Power-off Waveform ## I/F with CPU #### Parallel interface mode The ML9042 can transfer either 8 bits once or 4 bits twice on the data bus for interfacing with any 8-bit or 4-bit microcontroller (CPU). ## 1) 8-bit interface data length The ML9042 uses all of the 8 data bus lines DB<sub>0</sub>(SO) to DB<sub>7</sub> at a time to transfer data to and from the CPU. ## 2) 4-bit interface data length The ML9042 uses only the higher-order 4 data bus lines $DB_4$ to $DB_7$ twice to transfer 8-bit data to and from the CPU. The ML9042 first transfers the higher-order 4 bits of 8-bit data ( $DB_4$ to $DB_7$ in the case of 8-bit interface data length) and then the lower-order 4 bits of the data ( $DB_0(SO)$ to $DB_3$ in the case of 8-bit interface data length). The lower-order 4 bits of data should always be transferred even when only the transfer of the higher-order 4 bits of data is required. (Example: Reading the Busy Flag) Two transfers of 4 bits of data complete the transfer of a set of 8-bit data. Therefore, when only one access is made, the following data transfer cannot be completed properly. Figure 2 8-Bit Data Transfer Figure 3 4-Bit Data Transfer #### **Serial Interface Mode** In the Serial I/F Mode, the ML9042 interfaces with the CPU via the $RS_0/CSB$ , E/SHTB, RW/SI, and $DB_0(SO)$ pins. Writing and reading operations are executed in units of 16 bits after the $RS_0/CSB$ signal falls down. If the $RS_0/CSB$ signal rises up before the completion of 16-bit unit access, this access is ignored. When the BF bit is "1", the ML9042 cannot accept any other instructions. Before inputting a new instruction, check that the BF bit is "0". Any access when the BF bit is "1" is ignored. Data format is LSB-first. Examples of Access in the Serial I/F Mode - Note 1: Higher 5 bits of each instruction must be input at a "H" level. - Note 2: Lower 8 bits are "don't care" when the instructions in the READ MODE are set. - Note 3: After one instruction is input, the next instruction must be input after the $RS_0/CSB$ pin is pulled at a "H" level. # **Instruction Codes** # Table of Instruction Codes | Tuble of Institu | | Code | | | | | | | | | | | Execution | |--------------------------------|-----|--------------------------|-----------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------| | Instruction | RS₁ | RS <sub>0</sub> /<br>CSB | RW/<br>SI | DB <sub>7</sub> | DB <sub>6</sub> | DB <sub>5</sub> | DB <sub>4</sub> | DB <sub>3</sub> | DB <sub>2</sub> | DB <sub>1</sub> | DB <sub>0</sub><br>(SO) | Function | Time<br>f = 270 kHz | | Display Clear | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | Clears all the displayed digits of the LCD and sets the DDRAM address 00 in the address counter. The arbitrator data is cleared. | 1.52 ms | | Cursor Home | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | Х | Sets the DDRAM address 00 in the address counter and shifts the display back to the original. The content of the DDRAM remains unchanged. | 1.52 ms | | Entry Mode<br>Setting | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | I/D | S | Determines the direction of movement of the cursor and whether or not to shift the display. This instruction is executed when data is written or read. | 37 μs | | Display<br>ON/OFF Control | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | D | С | В | Sets LCD display ON/OFF (D), cursor ON/OFF (C) or cursor-position character blinking ON/OFF (B). | 37 μs | | Cursor/Display<br>Shift | 1 | 0 | 0 | 0 | 0 | 0 | 1 | S/C | R/L | Х | х | Moves the cursor or shifts the display without changing the content of the DDRAM. | 37 μs | | Function Setting | 1 | 0 | 0 | 0 | 0 | 1 | DL | N | ABE | SSR | CSR | Sets the interface data length (DL), the number of display lines (N), the arbitrator display (ABE), the segment data shift direction (SSR), or the common data shift direction (CSR). | 37 μs | | CGRAM<br>Address Setting | 1 | 0 | 0 | 0 | 1 | | | A | CG | • | • | Sets on CGRAM address. After that,<br>CGRAM data is transferred to and from<br>the CPU. | 37 μs | | DDRAM<br>Address Setting | 1 | 0 | 0 | 1 | | | | ADD | ) | | | Sets a DDRAM address. After that,<br>DDRAM data is transferred to and from<br>the CPU. | 37 μs | | Busy Flag/<br>Address Read | 1 | 0 | 1 | BF | | | ADC th | | | | | Reads the Busy Flag (indicating that the ML9042 is operating) and the content of the address counter. | 0 μs | | RAM Data Write | 1 | 1 | 0 | | | ٧ | WRITE DATA | | | | | Writes data in DDRAM, ABRAM or CGRAM. | 37 μs | | RAM Data Read | 1 | 1 | 1 | | | | | | | | | Reads data from DDRAM, ABRAM or CGRAM. | 37 μs | | Arbitrator<br>Display Line Set | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 0 1 AS S | | AS | Sets the arbitrator display line. | 37 μs | | | | ABRAM<br>Address Setting | 0 | 0 | 0 | 0 | 1 | 1 | AAB | | | | | Sets an ABRAM address. After that, ABRAM data is transferred to and from the CPU. | 37 μs | | | | (Increment) | I/D = "0" | (Decrement) | DD RAM: | Display data RAM | The | |----|----------|-----------------------------------------|-----------|---------------------|---------|----------------------------|-----------| | | | (Shifts the display.) | | | CG RAM: | Character generator RAM | execution | | | | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | | (Moves the cursor.) | ABRAM. | Arbitrator data RAM | time is | | | | ` ' | | (Left shift) | ACG: | CGRAM address | dependent | | | | (8-bit data) | | | | | upon | | | | | N = "0" | (1 line) | ADD: | DDRAM address | frequen- | | | | " (Arbitrator displaye | | | | (Corresponds to the cursor | cies. | | | | " (Arbitrator not displ | | 0=0 ) | | address) | | | | | " (Transfer direction: | | ., | AAB: | ABRAM address | | | _ | | " (Transfer direction: | | / | ADC: | Address counter (Used by | | | | | " (Transfer direction: | | , | | DDRAM, ABRAM and | | | | | " (Transfer direction: | | , | | CGRAM) | | | - | BF = "1" | (Busy) | BL = .0. | (Ready to accept | | , | | | - | . "4" | (For a la La sa la Bartelana) | | an instruction) | | | | | _ | | (Enables blinking) | ` | | | | | | | | (Displays the cursor | , | | | | | | | | (Displays a characte | | | | | | | Į. | | (Arbitrator Displays | | | | | | | | | arbitrator on the | | arbitrator on the | | | | | | | upper line) | | lower line) | | | | x: Don't Care # **Instruction Codes** An instruction code is a signal sent from the CPU to access the ML9042. The ML9042 starts operation as instructed by the code received. The busy status of the ML9042 is rather longer than the cycle time of the CPU, since the internal processing of the ML9042 starts at a timing which does not affect the display on the LCD. In the busy status (Busy Flag is "1"), the ML9042 cannot input the Busy Flag Read instruction only. Therefore, the CPU should ensure that the Busy Flag is "0" before sending an instruction code to the ML9042. #### 1) Display Clear | | $RS_1$ | $RS_0$ | R/W | $DB_7$ | $DB_6$ | $DB_5$ | $DB_4$ | $DB_3$ | $DB_2$ | $DB_1$ | $DB_0$ | |-------------------|--------|--------|-----|--------|--------|--------|--------|--------|--------|--------|--------| | Instruction Code: | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | When this instruction is executed, the LCD display including arbitrator display is cleared and the I/D entry mode is set to "Increment". The value of "S" (Display shifting) remains unchanged. The position of the cursor or blink being displayed moves to the left end of the LCD (or the left end of the line 1 in the 2-line display mode). Note: All DDRAM and ABRAM data turn to "20" and "00" in hexadecimal, respectively. The value of the address counter (ADC) turns to the one corresponding to the address "00" (hexadecimal) of the DDRAM. The execution time of this instruction is 1.52 ms (maximum) at an oscillation frequency of 270 kHz. #### 2) Cursor Home When this instruction is executed, the cursor or blink position moves to the left end of the LCD (or the left end of line 1 in the 2-line display mode). If the display has been shifted, the display returns to the original display position before shifting. Note: The value of the address counter (ADC) goes to the one corresponding to the address "00" (hexadecimal) of the DDRAM). The execution time of this instruction is 1.52 ms (maximum) at an oscillation frequency of 270 kHz. ### 3) Entry Mode Setting | | $RS_1$ | $RS_0$ | R/W | $DB_7$ | $DB_6$ | DB <sub>5</sub> | $DB_4$ | $DB_3$ | $DB_2$ | DB₁ | $DB_0$ | |-------------------|--------|--------|-----|--------|--------|-----------------|--------|--------|--------|-----|--------| | Instruction code: | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | I/D | S | (1) When the I/D is set, the cursor or blink shifts to the right by 1 character position (ID= "1"; increment) or to the left by 1 character position (I/D= "0"; decrement) after an 8-bit character code is written to or read from the DDRAM. At the same time, the address counter (ADC) is also incremented by 1 (when I/D = "1"; increment) or decremented by 1 (when I/D = "0"; decrement). After a character pattern is written to or read from the CGRAM, the address counter (ADC) is incremented by 1 (when I/D = "1"; increment) or decremented by 1 (when I/D = "0"; decrement). Also after data is written to or read from the ABRAM, the address counter (ADC) is incremented by 1 (when I/D = "1"; increment) or decremented by 1 (when I/D = "0"; decrement). (2) When S = "1", the cursor or blink stops and the entire display shifts to the left (I/D = "1") or to the right (I/D = "0") by 1 character position after a character code is written to the DDRAM. In the case of S = "1", when a character code is read from the DDRAM, when a character pattern is written to or read from the CGRAM or when data is written to or read from the ABRAM, normal read/write is carried out without shifting of the entire display. (The entire display does not shift, but the cursor or blink shifts to the right (I/D = "1") or to the left (I/D = "0") by 1 character position.) When S = "0", the display does not shift, but normal write/read is performed. Note: The execution time of this instruction is 37 $\mu s$ (maximum) at an oscillation frequency of 270 kHz. ## 4) Display ON/OFF Control disappear. | | RS₁ | $RS_0$ | R/W | DB <sub>7</sub> | $DB_6$ | DB <sub>5</sub> | $DB_4$ | $DB_3$ | $DB_2$ | DB <sub>1</sub> | $DB_0$ | |-------------------|-----|--------|-----|-----------------|--------|-----------------|--------|--------|--------|-----------------|--------| | Instruction code: | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | D | С | В | (1) The "D" bit (DB2) of this instruction determines whether or not to display character patterns on the LCD. When the "D" bit is "1", character patterns are displayed on the LCD. When the "D" bit is "0", character patterns are not displayed on the LCD and the cursor/blinking also Note: Unlike the Display Clear instruction, this instruction does not change the character code in the DDRAM . - (2) When the "C" bit (DB1) is "0", the cursor turns off. When both the "C" and "D" bits are "1", the cursor turns on. - (3) When the "B" bit (DB0) is "0", blinking is canceled. When both the "B" and "D" bits are "1", blinking is performed. In the Blinking mode, all dots including those of the cursor, the character pattern and the cursor are alternately displayed. Note: The execution time of this instruction is 37 $\mu s$ (maximum) at an oscillation frequency of 270 kHz. ## 5) Cursor/Display Shift DB<sub>6</sub> $\mathsf{DB}_0$ R/W DB<sub>7</sub> RS<sub>1</sub> RS<sub>0</sub> DB<sub>5</sub> DB₄ DB<sub>3</sub> DB<sub>2</sub> DB<sub>4</sub> 1 0 0 0 0 0 S/C Instruction code: R/L × x: Don't Care S/C = "0", R/L = "0" This instruction shifts left the cursor and blink positions by 1 (decrements the content of the ADC by 1). S/C = "0", R/L = "1" This instruction shifts right the cursor and blink positions by 1 (increments the content of the ADC by 1). S/C = "1", R/L = "0" This instruction shifts left the entire display by 1 character position. The cursor and blink positions move to the left together with the entire display. The Arbitrator display is not shifted. (The content of the ADC remains unchanged.) S/C = "1", R/L = "1" This instruction shifts right the entire display by 1 character position. The cursor and blink positions move to the right together with the entire display. The Arbitrator display is not shifted. (The content of the ADC remains unchanged.) In the 2-line mode, the cursor or blink moves from the first line to the second line when the cursor at digit 40 (27; hex) of the first line is shifted right. When the entire display is shifted, the character pattern, cursor or blink will not move between the lines (from line 1 to line 2 or vice versa). Note: The execution time of this instruction is 37 µs at an oscillation frequency (OSC) of 270 kHz. #### 6) Function Setting RS₁ $\mathsf{RS}_0$ R/W DB<sub>7</sub> $DB_6$ DB<sub>5</sub> DB<sub>4</sub> $DB_3$ DB<sub>2</sub> DB<sub>1</sub> $DB_0$ 1 ABE SSR **CSR** Instruction code: x: Don't Care x. Don't Ga - (1) When the "DL" bit (DB<sub>4</sub>) of this instruction is "1", the data transfer to and from the CPU is performed once by the use of 8 bits DB<sub>7</sub> to DB<sub>0</sub>. - When the "DL" bit (DB<sub>4</sub>) of this instruction is "0", the data transfer to and from the CPU is performed twice by the use of 4 bits DB<sub>7</sub> to DB<sub>4</sub>. - (2) The 2-line display mode is selected when the "N" bit (DB<sub>3</sub>) of this instruction is "1". The 1-line display mode is selected when the "N" bit is "0". The arbitrator is displayed when the "ABE" bit (DB<sub>2</sub>) of this instruction is "1". The arbitrator is not displayed when the "ABE" bit (DB<sub>2</sub>) of this instruction is "0". - (3) The transfer direction of the segment signal output data is controlled. - When the "SSR" bit (DB<sub>1</sub>) of this instruction is "1", the data is transferred from SEG<sub>100</sub> to SEG<sub>1</sub>. When the "SSR" bit (DB<sub>1</sub>) of this instruction is "0", the data is transferred from SEG<sub>1</sub> to SEG<sub>100</sub>. The transfer direction of the common signal output data is controlled. instruction can be executed. In the Serial I/F Mode, DL setting is ignored. At 1/n duty, When the "CSR" bit $(DB_0)$ of this instruction is "1", the data is transferred from COMn to COM1. When the "CSR" bit $(DB_0)$ of this instruction is "0", the data is transferred from COM1 to COMn. After the ML9042 is powered on, this function setting should be carried out before execution of any instruction except the Busy Flag Read. After this function setting, no instructions other than the DL Set | N | ABE | Number of display lines | Font size | Duty | Number of biases | Number of common signals | |---|-----|-------------------------|-----------|------|------------------|--------------------------| | 0 | 0 | 1 | 5 × 8 | 1/8 | 4 | 8 | | 0 | 1 | 1 | 5 × 8 | 1/9 | 4 | 9 | | 1 | 0 | 2 | 5 × 8 | 1/16 | 5 | 16 | | 1 | 1 | 2 | 5 × 8 | 1/17 | 5 | 17 | Note: The execution time of this instruction is 37 μs at an oscillation frequency (OSC) of 270 kHz #### 7) CGRAM Address Setting | | $RS_1$ | $RS_0$ | R/W | $DB_7$ | $DB_6$ | $DB_5$ | $DB_4$ | $DB_3$ | $DB_2$ | DB₁ | $DB_0$ | | |-------------------|--------|--------|-----|--------|--------|----------------|----------------|----------------|----------------|----------------|----------------|--| | Instruction code: | 1 | 0 | 0 | 0 | 1 | C <sub>5</sub> | C <sub>4</sub> | C <sub>3</sub> | C <sub>2</sub> | C <sub>1</sub> | C <sub>0</sub> | | This instruction sets the CGRAM address to the data represented by the bits $C_5$ to $C_0$ (binary). The CGRAM addresses are valid until DDRAM or ABRAM addresses are set. The CPU writes or reads character patterns starting from the one represented by the CGRAM address bits $C_5$ to $C_0$ set in the instruction code at that time. Note: The execution time of this instruction is 37 µs at an oscillation frequency (OSC) of 270 kHz. #### 8) DDRAM Address Setting | | RS <sub>1</sub> | $RS_0$ | R/W | DB <sub>7</sub> | $DB_6$ | $DB_5$ | $DB_4$ | $DB_3$ | $DB_2$ | DB <sub>1</sub> | $DB_0$ | | |-------------------|-----------------|--------|-----|-----------------|----------------|----------------|----------------|----------------|----------------|-----------------|----------------|--| | Instruction code: | 1 | 0 | 0 | 1 | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | | This instruction sets the DDRAM address to the data represented by the bits $D_6$ to $D_0$ (binary). The DDRAM addresses are valid until CGRAM or ABRAM addresses are set. The CPU writes or reads character codes starting from the one represented by the DDRAM address bits $D_6$ to $D_0$ set in the instruction code at that time. In the 1-line mode (the "N" bit is "0"), the DDRAM address represented by bits $D_6$ to $D_0$ (binary) should be in the range "00" to "4F" in hexadecimal. In the 2-line mode (the "N" bit is "1"), the DDRAM address represented by bits $D_6$ to $D_0$ (binary) should be in the range "00" to "27" or "40" to "67" in hexadecimal. If an address other than above is input, the ML9042 cannot properly write a character code in or read it from the DDRAM. Note: The execution time of this instruction is 37 µs at an oscillation frequency (OSC) of 270 kHz. ## 9) DDRAM/ABRAM/CGRAM Data Write | | RS <sub>1</sub> | $RS_0$ | $R/\overline{W}$ | $DB_7$ | $DB_6$ | $DB_5$ | $DB_4$ | $DB_3$ | $DB_2$ | $DB_1$ | $DB_0$ | |-------------------|-----------------|--------|------------------|----------------|----------------|----------------|--------|----------------|----------------|----------------|----------------| | Instruction code: | 1 | 1 | 0 | E <sub>7</sub> | E <sub>6</sub> | E <sub>5</sub> | E₄ | E <sub>3</sub> | E <sub>2</sub> | E <sub>1</sub> | E <sub>0</sub> | A character code $(E_7 \text{ to } E_0)$ is written to the DDRAM, Display-ON data $(E_7 \text{ to } E_0)$ to the ABRAM or a character pattern $(E_7 \text{ to } E_0)$ to the CGRAM. The DDRAM, ABRAM or CGRAM is selected at the preceding address setting. After data is written, the address counter (ADC) is incremented or decremented as set by the Entry Mode Setting instruction (see 3). Note: The execution time of this instruction is 37 µs at an oscillation frequency (OSC) of 270 kHz. 10) Busy Flag/Address Counter Read (Execution time: 0 μs) | | RS₁ | $RS_0$ | R/W | $DB_7$ | $DB_6$ | $DB_5$ | $DB_4$ | $DB_3$ | $DB_2$ | DB₁ | $DB_0$ | |-------------------|-----|--------|-----|--------|----------------|----------------|----------------|----------------|----------------|----------------|----------------| | Instruction code: | 1 | 0 | 1 | BF | O <sub>6</sub> | O <sub>5</sub> | O <sub>4</sub> | O <sub>3</sub> | O <sub>2</sub> | O <sub>1</sub> | O <sub>0</sub> | The "BF" bit (DB7) of this instruction tells whether the ML9042 is busy in internal operation (BF = "1") or not (BF = "0"). When the "BF" bit is "1", the ML9042 cannot accept any other instructions. Before inputting a new instruction, check that the "BF" bit is "0". When the "BF" bit is "0", the ML9042 outputs the correct value of the address counter. The value of the address counter is equal to the DDRAM, ABRAM or CGRAM address. Which of the DDRAM, ABRAM and CGRAM addresses is set in the counter is determined by the preceding address setting. When the "BF" bit is "1", the value of the address counter is not always correct because it may have been incremented or decremented by 1 during internal operation. #### 11) DDRAM/ABRAM/CGRAM Data Read | | RS₁ | $RS_0$ | R/W | DB <sub>7</sub> | $DB_6$ | $DB_5$ | $DB_4$ | $DB_3$ | $DB_2$ | $DB_1$ | DB <sub>0</sub> | |-------------------|-----|--------|-----|-----------------|----------------|----------------|----------------|----------------|----------------|----------------|-----------------| | Instruction code: | 1 | 1 | 1 | P <sub>7</sub> | P <sub>6</sub> | P <sub>5</sub> | P <sub>4</sub> | P <sub>3</sub> | P <sub>2</sub> | P <sub>1</sub> | P <sub>0</sub> | A character code $(P_7 \text{ to } P_0)$ is read from the DDRAM, Display-ON data $(P_7 \text{ to } P_0)$ from the ABRAM or a character pattern $(P_7 \text{ to } P_0)$ from the CGRAM. The DDRAM, ABRAM or CGRAM is selected at the preceding address setting. After data is read, the address counter (ADC) is incremented or decremented as set by the Entry Mode Setting instruction (see 3). Note: Conditions for reading correct data - (1) The DDRAM, ABRAM or CGRAM Setting instruction is input before this data read instruction is input. - (2) When reading a character code from the DDRAM, the Cursor/Display Shift instruction (see 5) is input before this Data Read instruction is input. - (3) When two or more consecutive RAM Data Read instructions are executed, the following read data is correct. Correct data is not output under conditions other than the cases (1), (2) and (3) above. Note: The execution time of this instruction is 37 µs at an oscillation frequency (OSC) of 270 kHz. #### **Expansion Instruction Codes** The busy status of the ML9042 is rather longer than the cycle time of the CPU, since the internal processing of the ML9042 starts at a timing which does not affect the display on the LCD. In the busy status (Busy Flag is "1"), the ML9042 executes the Busy Flag Read instruction only. Therefore, the CPU should ensure that the Busy Flag is "0" before sending an expansion instruction code to the ML9042. #### 1) Arbitrator Display Line Set | | RS₁ | $RS_0$ | R/W | $DB_7$ | $DB_6$ | DB <sub>5</sub> | $DB_4$ | $DB_3$ | $DB_2$ | DB₁ | $DB_0$ | |-----------------------------|-----|--------|-----|--------|--------|-----------------|--------|--------|--------|-----|--------| | Expansion instruction code: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | AS | This expansion instruction code sets the Arbitrator display line. The relationship between the status of this bit and the common outputs is as follows: For display examples, refer to LCD Drive Waveforms section. | ABE bit | CSR bit | duty | AS bit | Shift direction | Arbitrator's common pin | |---------|---------|------|--------|-----------------|-------------------------| | L | L | 1/8 | L | COM1→COM8 | None | | L | L | 1/8 | Н | COM1→COM8 | None | | L | L | 1/16 | L | COM1→COM16 | None | | L | L | 1/16 | Н | COM1→COM16 | None | | L | Н | 1/8 | L | COM8→COM1 | None | | L | Н | 1/8 | Н | COM8→COM1 | None | | L | Н | 1/16 | L | COM16→COM1 | None | | L | Н | 1/16 | Н | COM16→COM1 | None | | Н | L | 1/9 | L | COM1→COM9 | COM9 | | Н | L | 1/9 | Н | COM1→COM9 | COM1 | | Н | L | 1/17 | L | COM1→COM17 | COM17 | | Н | L | 1/17 | Н | COM1→COM17 | COM1 | | Н | Н | 1/9 | L | COM9→COM1 | COM1 | | Н | Н | 1/9 | Н | COM9→COM1 | COM9 | | Н | Н | 1/17 | L | COM17→COM1 | COM1 | | Н | Н | 1/17 | Н | COM17→COM1 | COM17 | Note: The execution time of this instruction is 37 $\mu s$ at an oscillation frequency (OSC) of 270 kHz. #### 2) ABRAM Address Setting | | $RS_1$ | $RS_0$ | $R/\overline{W}$ | $DB_7$ | $DB_6$ | $DB_5$ | $DB_4$ | $DB_3$ | $DB_2$ | $DB_1$ | $DB_0$ | |-----------------------------|--------|--------|------------------|--------|--------|--------|----------------|----------------|----------------|----------------|----------------| | Expansion instruction code: | 0 | 0 | 1 | 0 | 1 | 1 | H <sub>4</sub> | H <sub>3</sub> | H <sub>2</sub> | H <sub>1</sub> | H <sub>0</sub> | This instruction sets the ABRAM address to the data represented by the bits $H_4$ to $H_0$ (binary). The ABRAM addresses are valid until CGRAM or DDRAM addresses are set. The CPU writes or reads the Display-ON data starting from the one represented by the ABRAM address bits $H_4$ to $H_0$ set in the instruction code at that time. When the ABRAM address represented by bits $H_4$ to $H_0$ (binary) is in the range "00" to "13" in hexadecimal, data is output to the LCD as the arbitrator. Note: The execution time of this instruction is 37 µs at an oscillation frequency (OSC) of 270 kHz. ### **Examples of Combinations of ML9042 and LCD Panel** (1) Driving the LCD of one 20-character line under the conditions of the 1-line display mode and no arbitrator display • COM<sub>9</sub> to COM<sub>17</sub> output Display-OFF common signals. • COM<sub>9</sub> to COM<sub>17</sub> output Display-OFF common signals. (2) Driving the LCD of one 20-character line under the conditions of the 1-line display mode and the arbitrator display • COM<sub>10</sub> to COM<sub>17</sub> output Display-OFF common signals. • COM<sub>10</sub> to COM<sub>17</sub> output Display-OFF common signals. • $COM_{10}$ to $COM_{17}$ output Display-OFF common signals. • COM<sub>10</sub> to COM<sub>17</sub> output Display-OFF common signals. (3) Driving the LCD of two 20-character lines under the conditions of the 2-line display mode and no arbitrator display $$(1/16 \text{ duty}, ABE = "0", AS = "0" \text{ or "1"}, CSR = "0", SSR = "1")$$ • COM<sub>17</sub> outputs Display-OFF common signal. • COM<sub>17</sub> outputs Display-OFF common signal. (4) Driving the LCD of two 20-character lines under the conditions of the 2-line display mode and the arbitrator display $$(1/17 \text{ duty}, ABE = "1", AS = "1", CSR = "1", SSR = "0")$$ ## **EXAMPLES OF VLCD GENERATION CIRCUITS** • With 1/4 bias, a voltage multiplier - With 1/4 bias, no voltage multiplier - 1) Apply $V_{DD}$ to $V_{OUT}$ and $V_{0.}$ - 2) Apply $V_{DD}$ to $V_{OUT}$ , and apply the $V_0$ level to $V_0$ externally. With 1/5 bias, a voltage multiplier - With 1/5 bias, no voltage multiplier - 1) Apply $V_{DD}$ to $V_{OUT}$ and $V_0$ . 2) Apply $V_{DD}$ to $V_{OUT}$ , and apply the $V_0$ level to $V_0$ externally. #### **LCD Drive Waveforms** The COM and SEG waveforms (AC signal waveforms for display) vary according to the duty (1/9 and 1/17 duties). See 1) and 2) below. The relationship between the duty ratio and the frame frequency is as follows: | Duty ratio | Frame Frequency | | | |------------|-----------------|--|--| | 1/8 | 84.4 Hz | | | | 1/9 | 75.0 Hz | | | | 1/16 | 84.4 Hz | | | | 1/17 | 79.4 Hz | | | Note: At an oscillation frequency (OSC) of 270 kHz ### 1) COM and SEG Waveforms on 1/9 Duty (ABE = "1") ### 2) COM and SEG Waveforms on 1/17 Duty (ABE = "1") #### **Initial Setting of Instructions** - (a) Data transfer from and to the CPU using 8 bits of DB<sub>0</sub> to DB<sub>7</sub> - 1) Turn on the power. - 2) Wait for 15 ms or more after $V_{DD}$ has reached 2.7 V or higher. - 3) Set "8 bits" with the Function Setting instruction. - 4) Wait for 4.1 ms or more. - 5) Set "8 bits" with the Function Setting instruction. - 6) Wait for 100 μs or more. - 7) Set "8 bits" with the Function Setting instruction. - 8) Check the Busy Flag for No Busy (or wait for 100 us or more). - 9) Set "8 bits", "Number of LCD lines" and "Font size" with the Function Setting instruction. (After this, the number of LCD lines and the font size cannot be changed.) - 10) Check the Busy Flag for No Busy. - 11) Execute the Display ON/OFF control Instruction, Display Clear Instruction, Entry Mode Setting instruction and Arbitrator Display Line Setting Instruction. - 12) Check the Busy Flag for No Busy. - 13) Initialization is completed. An example of instruction code for 3), 5) and 7) | RS <sub>1</sub> | $RS_0$ | R/W | DB <sub>7</sub> | DB <sub>6</sub> | DB <sub>5</sub> | $DB_4$ | DB <sub>3</sub> | $DB_2$ | DB <sub>1</sub> | DB <sub>0</sub> | |-----------------|--------|-----|-----------------|-----------------|-----------------|--------|-----------------|--------|-----------------|-----------------| | 1 | 0 | 0 | 0 | 0 | 1 | 1 | × | × | × | × | x: Don't Care - (b) Data transfer from and to the CPU using 4 bits of DB<sub>4</sub> to DB<sub>7</sub> - 1) Turn on the power. - 2) Wait for 15 ms or more after $V_{DD}$ has reached 2.7 V or higher. - 3) Set "8 bits" with the Function Setting instruction. - 4) Wait for 4.1 ms or more. - 5) Set "8 bits" with the Function Setting instruction. - 6) Wait for 100 µs or more. - 7) Set "8 bits" with the Function Setting instruction. - 8) Check the Busy Flag for No Busy (or wait for 100 µs or longer). - 9) Set "4 bits" with the Function Setting instruction. - 10) Wait for 100 μs or longer. - 11) Set "4 bits", "Number of LCD lines" and "Font size" with the Function Setting instruction. (After this, the number of LCD lines and the font size cannot be changed.) - 12) Check the Busy Flag for No Busy. - 13) Execute the Display ON/OFF control Instruction, Display Clear Instruction, Entry Mode Setting instruction and Arbitrator Display Line Setting Instruction. - 14) Check the Busy Flag for No Busy. - 15) Initialization is completed. An example of instruction code for 3), 5) and 7) | $RS_1$ | $RS_0$ | R/W | DB <sub>7</sub> | DB <sub>6</sub> | DB <sub>5</sub> | DB <sub>4</sub> | |--------|--------|-----|-----------------|-----------------|-----------------|-----------------| | 1 | 0 | 0 | 0 | 0 | 1 | 1 | An example of instruction code for 9) | $RS_1$ | $RS_0$ | $R/\overline{W}$ | DB <sub>7</sub> | $DB_6$ | $DB_5$ | $DB_4$ | |--------|--------|------------------|-----------------|--------|--------|--------| | 1 | 0 | 0 | 0 | 0 | 1 | 0 | <sup>\*:</sup> From 11), input data twice by the use of 4-bit data. - (c) Data transfer from and to the CPU using the serial I/F - 1) Turn on the power. - 2) Wait for 15 ms or more after $V_{DD}$ has reached 2.7 V or higher. - 3) Check the busy flag for No Busy. - 4) Set "Number of LCD lines" and "Font size" with the Function Setting Instruction. (After this, the number of LCD lines and the font size cannot be changed.) - 5) Check the busy flag for No Busy. - 6) Execute the Display ON/OFF control Instruction, the Display Clear Instruction, the Entry Mode Instruction and the Arbitrator Display Line Setting Instruction. - 7) Check the busy flag for No Busy. - 8) Initialization is completed. <sup>\*:</sup> In 13), check the Busy Flag for No Busy before executing each instruction. <sup>\*:</sup> In 6), check the Busy Flag for No Busy before executing each instruction. # ML9042-xx CVWA/DVWA PAD CONFIGURATION ## **Pad Layout** $\begin{array}{ll} \text{Chip Size:} & 7.8 \times 1.8 \text{ mm} \\ \text{Chip Thickness:} & 625 \pm 20 \text{ } \mu\text{m} \\ \text{Bump Size:} & 100 \times 44 \text{ } \mu\text{m} \end{array}$ ### **Pad Coordinates** | Pad | Symbol | X (μm) | Υ (μm) | Pad | Symbol | X (μm) | Υ (μm) | |-----|---------------|--------|--------|-----|--------|--------|-------------| | 1 | DUMMY | -3750 | -750 | 21 | DUMMY | -2250 | -750 | | 2 | OSC2 | -3675 | -750 | 22 | E/SHTB | -2175 | -750 | | 3 | OSCR5 | -3600 | -750 | 23 | E/SHTB | -2100 | -750 | | 4 | OSCR3 | -3525 | -750 | 24 | DUMMY | -2025 | -750 | | 5 | OSC1 | -3450 | -750 | 25 | DUMMY | -1950 | -750 | | 6 | DUMMYGND | -3375 | -750 | 26 | DB0/SO | -1875 | <b>-750</b> | | 7 | T1 | -3300 | -750 | 27 | DB0/SO | -1800 | -750 | | 8 | T2 | -3225 | -750 | 28 | DUMMY | -1725 | <b>-750</b> | | 9 | T3 | -3150 | -750 | 29 | DUMMY | -1650 | <b>-750</b> | | 10 | ROM1S | -3075 | -750 | 30 | DB1 | -1575 | -750 | | 11 | $DUMMYV_{DD}$ | -3000 | -750 | 31 | DB1 | -1500 | -750 | | 12 | RS1 | -2925 | -750 | 32 | DUMMY | -1425 | -750 | | 13 | RS1 | -2850 | -750 | 33 | DUMMY | -1350 | <b>-750</b> | | 14 | RSO/CSB | -2775 | -750 | 34 | DB2 | -1275 | -750 | | 15 | RSO/CSB | -2700 | -750 | 35 | DB2 | -1200 | -750 | | 16 | DUMMY | -2625 | -750 | 36 | DUMMY | -1125 | -750 | | 17 | DUMMY | -2550 | -750 | 37 | DUMMY | -1050 | -750 | | 18 | RW/SI | -2475 | -750 | 38 | DB3 | -975 | -750 | | 19 | RW/SI | -2400 | -750 | 39 | DB3 | -900 | -750 | | 20 | DUMMY | -2325 | -750 | 40 | DUMMY | -825 | -750 | | Pad | Symbol | X (μm) | Υ (μm) | Pad | Symbol | X (μm) | Υ (μm) | |-----|----------------------|--------|------------------|-----|--------------------|--------|--------| | 41 | DUMMY | -750 | -750 | 81 | V0 | 2250 | -750 | | 42 | DB4 | -675 | -750 | 82 | V0 | 2325 | -750 | | 43 | DB4 | -600 | -750 | 83 | V0 | 2400 | -750 | | 44 | DUMMY | -525 | -750 | 84 | V0 | 2475 | -750 | | 45 | DUMMY | -450 | -750 | 85 | V1 | 2550 | -750 | | 46 | DB5 | -375 | -750 | 86 | V2 | 2625 | -750 | | 47 | DB5 | -300 | -750 | 87 | V2 | 2700 | -750 | | 48 | DUMMY | -225 | -750 | 88 | V3A | 2775 | -750 | | 49 | DUMMY | -150 | -750 | 89 | V3A | 2850 | -750 | | 50 | DB6 | -75 | -750 | 90 | V3B | 2925 | -750 | | 51 | DB6 | 0 | -750 | 91 | V3B | 3000 | -750 | | 52 | DUMMY | 75 | -750 | 92 | V4 | 3075 | -750 | | 53 | DUMMY | 150 | -750 | 93 | Vc | 3150 | -750 | | 54 | DB7 | 225 | -750 | 94 | Vc | 3225 | -750 | | 55 | DB7 | 300 | -750 | 95 | Vc | 3300 | -750 | | 56 | DUMMYV <sub>DD</sub> | 375 | -750 | 96 | Vc | 3375 | -750 | | 57 | SP | 450 | -750 | 97 | V <sub>CC</sub> | 3450 | -750 | | 58 | GND | 525 | -750 | 98 | Vcc | 3525 | -750 | | 59 | GND | 600 | <b>-750</b> | 99 | V <sub>CC</sub> | 3600 | -750 | | 60 | GND | 675 | -750 | 100 | DUMMY | 3675 | -750 | | 61 | GND | 750 | <b>-750</b> | 101 | DUMMY | 3750 | -462 | | 62 | GND | 825 | <b>-750</b> | 102 | COM <sub>17</sub> | 3750 | -392 | | 63 | GND | 900 | <b>-750</b> | 103 | COM <sub>16</sub> | 3750 | -322 | | 64 | BE | 975 | -750 | 104 | COM <sub>15</sub> | 3750 | -252 | | 65 | $V_{DD}$ | 1050 | -750 | 105 | COM <sub>14</sub> | 3750 | -182 | | 66 | $V_{DD}$ | 1125 | <b>-750</b> | 106 | COM <sub>13</sub> | 3750 | -112 | | 67 | $V_{DD}$ | 1200 | <b>-750</b> | 107 | COM <sub>12</sub> | 3750 | -42 | | 68 | $V_{DD}$ | 1275 | -750 | 108 | COM <sub>11</sub> | 3750 | 28 | | 69 | $V_{DD}$ | 1350 | <b>-750</b> | 109 | COM <sub>10</sub> | 3750 | 98 | | 70 | $V_{DD}$ | 1425 | <b>-750</b> | 110 | COM <sub>9</sub> | 3750 | 168 | | 71 | TEST <sub>IN</sub> | 1500 | <b>–750</b> | 111 | DUMMY | 3750 | 238 | | 72 | TEST <sub>IN</sub> | 1575 | <del>-7</del> 50 | 112 | DUMMY | 3750 | 308 | | 73 | TEST <sub>OUT</sub> | 1650 | <del>-7</del> 50 | 113 | DUMMY | 3750 | 378 | | 74 | TEST <sub>OUT</sub> | 1725 | <b>-750</b> | 114 | DUMMY | 3750 | 448 | | 75 | $V_{IN}$ | 1800 | <b>-750</b> | 115 | DUMMY | 3675 | 750 | | 76 | V <sub>IN</sub> | 1875 | <b>-750</b> | 116 | DUMMY | 3605 | 750 | | 77 | V <sub>OUT</sub> | 1950 | <b>-750</b> | 117 | DUMMY | 3535 | 750 | | 78 | V <sub>OUT</sub> | 2025 | <b>–750</b> | 118 | SEG <sub>100</sub> | 3465 | 750 | | 79 | V0 | 2100 | <b>-750</b> | 119 | SEG <sub>99</sub> | 3395 | 750 | | 80 | V0 | 2175 | -750 | 120 | SEG <sub>98</sub> | 3325 | 750 | | Pad | Symbol | X (μm) | Υ (μm) | Pad | Symbol | X (μm) | Υ (μm) | |-----|-------------------|--------|--------|-----|-------------------|--------|--------| | 121 | SEG <sub>97</sub> | 3255 | 750 | 161 | SEG <sub>57</sub> | 455 | 750 | | 122 | SEG <sub>96</sub> | 3185 | 750 | 162 | SEG <sub>56</sub> | 385 | 750 | | 123 | SEG <sub>95</sub> | 3115 | 750 | 163 | SEG <sub>55</sub> | 315 | 750 | | 124 | SEG <sub>94</sub> | 3045 | 750 | 164 | SEG <sub>54</sub> | 245 | 750 | | 125 | SEG <sub>93</sub> | 2975 | 750 | 165 | SEG <sub>53</sub> | 175 | 750 | | 126 | SEG <sub>92</sub> | 2905 | 750 | 166 | SEG <sub>52</sub> | 105 | 750 | | 127 | SEG <sub>91</sub> | 2835 | 750 | 167 | SEG <sub>51</sub> | 35 | 750 | | 128 | SEG <sub>90</sub> | 2765 | 750 | 168 | SEG <sub>50</sub> | -35 | 750 | | 129 | SEG <sub>89</sub> | 2695 | 750 | 169 | SEG <sub>49</sub> | -105 | 750 | | 130 | SEG <sub>88</sub> | 2625 | 750 | 170 | SEG <sub>48</sub> | -175 | 750 | | 131 | SEG <sub>87</sub> | 2555 | 750 | 171 | SEG <sub>47</sub> | -245 | 750 | | 132 | SEG <sub>86</sub> | 2485 | 750 | 172 | SEG <sub>46</sub> | -315 | 750 | | 133 | SEG <sub>85</sub> | 2415 | 750 | 173 | SEG <sub>45</sub> | -385 | 750 | | 134 | SEG <sub>84</sub> | 2345 | 750 | 174 | SEG <sub>44</sub> | -455 | 750 | | 135 | SEG <sub>83</sub> | 2275 | 750 | 175 | SEG <sub>43</sub> | -525 | 750 | | 136 | SEG <sub>82</sub> | 2205 | 750 | 176 | SEG <sub>42</sub> | -595 | 750 | | 137 | SEG <sub>81</sub> | 2135 | 750 | 177 | SEG <sub>41</sub> | -665 | 750 | | 138 | SEG <sub>80</sub> | 2065 | 750 | 178 | SEG <sub>40</sub> | -735 | 750 | | 139 | SEG <sub>79</sub> | 1995 | 750 | 179 | SEG <sub>39</sub> | -805 | 750 | | 140 | SEG <sub>78</sub> | 1925 | 750 | 180 | SEG <sub>38</sub> | -875 | 750 | | 141 | SEG <sub>77</sub> | 1855 | 750 | 181 | SEG <sub>37</sub> | -945 | 750 | | 142 | SEG <sub>76</sub> | 1785 | 750 | 182 | SEG <sub>36</sub> | -1015 | 750 | | 143 | SEG <sub>75</sub> | 1715 | 750 | 183 | SEG <sub>35</sub> | -1085 | 750 | | 144 | SEG <sub>74</sub> | 1645 | 750 | 184 | SEG <sub>34</sub> | -1155 | 750 | | 145 | SEG <sub>73</sub> | 1575 | 750 | 185 | SEG <sub>33</sub> | -1225 | 750 | | 146 | SEG <sub>72</sub> | 1505 | 750 | 186 | SEG <sub>32</sub> | -1295 | 750 | | 147 | SEG <sub>71</sub> | 1435 | 750 | 187 | SEG <sub>31</sub> | -1365 | 750 | | 148 | SEG <sub>70</sub> | 1365 | 750 | 188 | SEG <sub>30</sub> | -1435 | 750 | | 149 | SEG <sub>69</sub> | 1295 | 750 | 189 | SEG <sub>29</sub> | -1505 | 750 | | 150 | SEG <sub>68</sub> | 1225 | 750 | 190 | SEG <sub>28</sub> | -1575 | 750 | | 151 | SEG <sub>67</sub> | 1155 | 750 | 191 | SEG <sub>27</sub> | -1645 | 750 | | 152 | SEG <sub>66</sub> | 1085 | 750 | 192 | SEG <sub>26</sub> | -1715 | 750 | | 153 | SEG <sub>65</sub> | 1015 | 750 | 193 | SEG <sub>25</sub> | -1785 | 750 | | 154 | SEG <sub>64</sub> | 945 | 750 | 194 | SEG <sub>24</sub> | -1855 | 750 | | 155 | SEG <sub>63</sub> | 875 | 750 | 195 | SEG <sub>23</sub> | -1925 | 750 | | 156 | SEG <sub>62</sub> | 805 | 750 | 196 | SEG <sub>22</sub> | -1995 | 750 | | 157 | SEG <sub>61</sub> | 735 | 750 | 197 | SEG <sub>21</sub> | -2065 | 750 | | 158 | SEG <sub>60</sub> | 665 | 750 | 198 | SEG <sub>20</sub> | -2135 | 750 | | 159 | SEG <sub>59</sub> | 595 | 750 | 199 | SEG <sub>19</sub> | -2205 | 750 | | 160 | SEG <sub>58</sub> | 525 | 750 | 200 | SEG <sub>18</sub> | -2275 | 750 | | Pad | Symbol | X (μm) | Υ (μm) | |-----|-------------------|--------|--------| | 201 | SEG <sub>17</sub> | -2345 | 750 | | 202 | SEG <sub>16</sub> | -2415 | 750 | | 203 | SEG <sub>15</sub> | -2485 | 750 | | 204 | SEG <sub>14</sub> | -2555 | 750 | | 205 | SEG <sub>13</sub> | -2625 | 750 | | 206 | SEG <sub>12</sub> | -2695 | 750 | | 207 | SEG <sub>11</sub> | -2765 | 750 | | 208 | SEG <sub>10</sub> | -2835 | 750 | | 209 | SEG <sub>9</sub> | -2905 | 750 | | 210 | SEG <sub>8</sub> | -2975 | 750 | | 211 | SEG <sub>7</sub> | -3045 | 750 | | 212 | SEG <sub>6</sub> | -3115 | 750 | | 213 | SEG₅ | -3185 | 750 | | 214 | SEG <sub>4</sub> | -3255 | 750 | | 215 | SEG <sub>3</sub> | -3325 | 750 | | 216 | SEG <sub>2</sub> | -3395 | 750 | | 217 | SEG₁ | -3465 | 750 | | 218 | DUMMY | -3535 | 750 | | 219 | DUMMY | -3605 | 750 | | 220 | DUMMY | -3675 | 750 | | 221 | DUMMY | -3750 | 448 | | 222 | DUMMY | -3750 | 378 | | 223 | DUMMY | -3750 | 308 | | 224 | DUMMY | -3750 | 238 | | 225 | COM <sub>1</sub> | -3750 | 168 | | 226 | COM <sub>2</sub> | -3750 | 98 | | 227 | COM <sub>3</sub> | -3750 | 28 | | 228 | COM <sub>4</sub> | -3750 | -42 | | 229 | COM <sub>5</sub> | -3750 | -112 | | 230 | COM <sub>6</sub> | -3750 | -182 | | 231 | COM <sub>7</sub> | -3750 | -252 | | 232 | COM <sub>8</sub> | -3750 | -322 | | 233 | DUMMY | -3750 | -392 | ## ML9042-xx CVWA/DVWA ALIGNMENT MARK SPECIFICATION ## **Alignment Mark Coordinates** | Alignment Mark | X (μm) | Υ (μm) | | | |----------------|--------|-------------|--|--| | Α | -3770 | 770 | | | | В | 3770 | 770 | | | | С | 3770 | <b>–770</b> | | | The coordinates (X, Y) indicate the distances to the center of an alignment mark (the center of the maximum outline of the L shape). ## **Alignment Mark Layer** Gold bump ### **Alignment Mark Gold Bump Specification** | Symbol | Parameter | Mark | Size (μm) | |--------|----------------------|---------|-----------| | а | Alignment Mark Width | A, B, C | 30 | | b | Alignment Mark Size | A, B, C | 80 | # ML9042-xx CVWA GOLD BUMP SPECIFICATION (HIGH HARDNESS) ## **Gold Bump Specification** (Unit: µm) | Symbol | Parameter | MIN | TYP | MAX | |--------|------------------------------------------------------|-----|-----|-----| | Α | Bump Pitch (I/O Section: Pitch Direction) | 70 | _ | _ | | В | Bump Size (I/O Section: Pitch Direction) | 40 | 44 | 48 | | С | Bump Size (I/O Section: Depth Direction) | 96 | 100 | 104 | | D | Bump-to-Bump Distance (I/O Section: Pitch Direction) | 22 | 26 | 30 | | Е | Bump Size (L-mark Section: Length) | 76 | 80 | 84 | | F | Bump Size (L-mark Section: Width) | 26 | 30 | 34 | | G | Sliding of Total Bump Pitches | _ | _ | 2 | | Н | Bump Height | 10 | 15 | 20 | | | Bump Height Dispersion Inside Chip (Range) | _ | _ | 4 | | | Bump Edge Height | _ | _ | 5 | | J | Shear Strength (g) | 27 | _ | _ | | K | Bump Hardness (Hv: 25 g load) | 50 | 90 | 130 | $\lambda \acute{E}$ Wafer Thickness; 625 ±20 μm $\lambda \acute{E}$ Chip Size; 7.80 mm $\times$ 1.80 mm ## **Top View and Cross Section View** # ML9042-xx CVWA GOLD BUMP SPECIFICATION (LOW HARDNESS) ## **Gold Bump Specification** (Unit: µm) | Symbol | Parameter | MIN | TYP | MAX | |--------|------------------------------------------------------|-----|-----|-----| | Α | Bump Pitch (I/O Section: Pitch Direction) | 70 | _ | _ | | В | Bump Size (I/O Section: Pitch Direction) | 40 | 44 | 48 | | С | Bump Size (I/O Section: Depth Direction) | 96 | 100 | 104 | | D | Bump-to-Bump Distance (I/O Section: Pitch Direction) | 22 | 26 | 30 | | Е | Bump Size (L-mark Section: Length) | 76 | 80 | 84 | | F | Bump Size (L-mark Section: Width) | 26 | 30 | 34 | | G | Sliding of Total Bump Pitches | _ | _ | 2 | | Н | Bump Height | 10 | 15 | 20 | | | Bump Height Dispersion Inside Chip (Range) | _ | _ | 4 | | | Bump Edge Height | _ | _ | 5 | | J | Shear Strength (g) | 27 | _ | _ | | K | Bump Hardness (Hv: 25 g load) | 30 | _ | 80 | $\lambda \acute{E}$ Wafer Thickness; 625 ±20 μm $\lambda \acute{E}$ Chip Size; 7.80 mm $\times$ 1.80 mm ## **Top View and Cross Section View** # **REVISION HISTORY** | Document | | Page | | | | |-------------|------------------|----------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | No. | Date | Previous | Current | Description | | | | | Edition | Edition | | | | PEDL9042-01 | Jun. 16, 2003 | _ | _ | Preliminary first edition | | | | | 5 | 5 | Changed descriptions of Symbols V <sub>C</sub> and V <sub>CC</sub> | | | FEDL9042-01 | 01 Nov. 19, 2003 | | 8 | Changed DC Characteristics Condition VDD = 4.5 to 5.5V→VDD = 4.0 to 5.5V Ta = 25°C→Ta =- 20 to 75°C Spec Min. 175 Typ. 270 Max. 365 →Min. 200 Typ. 270 Max. 351 Min. 175 Typ. 270 Max. 365 →Min. 200 Typ. 280 Max. 364 | | | | | 25 | 25 | Added of table | | | | | 44 | 44 | Partially changed figure of generation circuits | | | | | | | $(V_C+)\rightarrow (V_{CC}+)$ and $V_2,V_{3A},V_{3B}$ | | | | | 45 | 45 | Partially changed figure of generation circuits $(V_C+)\rightarrow (V_{CC}+)$ | | #### **NOTICE** No copying or reproduction of this document, in part or in whole, is permitted without the consent of LAPIS Semiconductor Co., Ltd. The content specified herein is subject to change for improvement without notice. The content specified herein is for the purpose of introducing LAPIS Semiconductor's products (hereinafter "Products"). If you wish to use any such Product, please be sure to refer to the specifications, which can be obtained from LAPIS Semiconductor upon request. Examples of application circuits, circuit constants and any other information contained herein illustrate the standard usage and operations of the Products. The peripheral conditions must be taken into account when designing circuits for mass production. Great care was taken in ensuring the accuracy of the information specified in this document. However, should you incur any damage arising from any inaccuracy or misprint of such information, LAPIS Semiconductor shall bear no responsibility for such damage. The technical information specified herein is intended only to show the typical functions of and examples of application circuits for the Products. LAPIS Semiconductor does not grant you, explicitly or implicitly, any license to use or exercise intellectual property or other rights held by LAPIS Semiconductor and other parties. LAPIS Semiconductor shall bear no responsibility whatsoever for any dispute arising from the use of such technical information. The Products specified in this document are intended to be used with general-use electronic equipment or devices (such as audio visual equipment, office-automation equipment, communication devices, electronic appliances and amusement devices). The Products specified in this document are not designed to be radiation tolerant. While LAPIS Semiconductor always makes efforts to enhance the quality and reliability of its Products, a Product may fail or malfunction for a variety of reasons. Please be sure to implement in your equipment using the Products safety measures to guard against the possibility of physical injury, fire or any other damage caused in the event of the failure of any Product, such as derating, redundancy, fire control and fail-safe designs. LAPIS Semiconductor shall bear no responsibility whatsoever for your use of any Product outside of the prescribed scope or not in accordance with the instruction manual. The Products are not designed or manufactured to be used with any equipment, device or system which requires an extremely high level of reliability the failure or malfunction of which may result in a direct threat to human life or create a risk of human injury (such as a medical instrument, transportation equipment, aerospace machinery, nuclear-reactor controller, fuel-controller or other safety device). LAPIS Semiconductor shall bear no responsibility in any way for use of any of the Products for the above special purposes. If a Product is intended to be used for any such special purpose, please contact a ROHM sales representative before purchasing. If you intend to export or ship overseas any Product or technology specified herein that may be controlled under the Foreign Exchange and the Foreign Trade Law, you will be required to obtain a license or permit under the Law. Copyright 2003-2011 LAPIS Semiconductor Co., Ltd.