

## **LCD Controller/Driver**

#### Overview

The LC7985 series devices are low-power CMOS ICs that incorporate dot-matrix character generator, display controller and driver functions in a single device, making them ideal for use in portable equipment containing LCD displays.

The LC7985 series feature  $5 \times 7$ -pixel and  $5 \times 10$ -pixel character fonts including either eight or four user-defined characters, single-line and two-line display modes, built-in drivers for displays up to eight characters in size, and easy expansion to control displays of up to 80 characters by adding LC7930N display drivers.

The LC7985 series interface directly to both 4-bit and 8-bit microcontrollers. The instruction set includes display clear, cursor home, display ON/OFF, character blink, and cursor and display shift instructions. The built-in reset circuit automatically initializes the devices at power-ON.

The LC7985 series operate from a 5V supply and are available in 80-pin QIPs.

#### **Features**

- Controller and driver for dot-matrix LCD displays
- $5 \times 7$ -pixel and  $5 \times 10$ -pixel character fonts
- 160,  $5 \times 7$ -pixel characters and 32,  $5 \times 10$ -pixel characters in character generator ROM
- Eight,  $5 \times 7$ -pixel characters or four,  $5 \times 10$ -pixel characters in character generator RAM
- 80-character display data RAM
- Built-in drivers for 1-line × 8-character and 2-line × 8-character displays
- Easy expansion to 1-line × 80-character or 2-line × 40-character displays
- 4-bit or 8-bit microcontroller interface
- 11 microcontroller instructions
- Built-in reset circuit
- · Built-in oscillator
- 5V supply
- 80-pin QIP

## **Package Dimensions**

unit: mm

#### 3044B - QFP80A



unit: mm

#### 3177 - QFP80D



#### **Pin Assignment**



## **Block Diagram**



## **Specifications**

# Absolute Maximum Ratings at $Ta=25\pm2^{\circ}C,\,V_{SS}=0V$

| Parameter                        | Symbol                           | Ratings                                         | Unit |  |
|----------------------------------|----------------------------------|-------------------------------------------------|------|--|
| Supply voltage range             | V <sub>DD</sub>                  | -0.3 to +7.0                                    | V    |  |
| LCD drive supply voltage range*1 | V <sub>1</sub> to V <sub>5</sub> | V <sub>DD</sub> – 13.5 to V <sub>DD</sub> + 0.3 | V    |  |
| Input voltage range              | V <sub>I</sub>                   | -0.3 to V <sub>DD</sub> + 0.3                   | V    |  |
| Operating temperature range      | Topr                             | -20 to +75                                      | °C   |  |
| Storage temperature range        | Tstg                             | -55 to +125                                     | °C   |  |

Note: \*1.  $V_{DD}$  must obey the relationship :  $V_{DD} \ge V_1 \ge V_2 \ge V_3 \ge V_4 \ge V_5$ 

## Allowable Operating Ranges at $Ta = -20 \text{ to } +75^{\circ}\text{C}$

| Parameter                    | Symbol           | Conditions                                         | Ratings               |     |                        | Unit  |
|------------------------------|------------------|----------------------------------------------------|-----------------------|-----|------------------------|-------|
| raiailletei                  | Symbol           | Conditions                                         | min                   | typ | max                    | Ollit |
| Supply voltage range         | V <sub>DD</sub>  |                                                    | 4.5                   |     | 5.5                    | V     |
| Supply voltage <sup>*1</sup> | V <sub>D5</sub>  | $V_{D5} = V_{DD} - V_5$                            | 1.5                   |     |                        | V     |
| Supply voltage               | V <sub>D1</sub>  | V <sub>D1</sub> = V <sub>DD</sub> - V <sub>1</sub> |                       |     | V <sub>D5</sub> x 0.25 | V     |
| Input high level voltage     | V <sub>IH1</sub> | except OSCI                                        | 2.2                   |     | V <sub>DD</sub>        | V     |
| input nigit level voltage    | V <sub>IH2</sub> | OSCI only                                          | V <sub>DD</sub> - 1.0 |     | V <sub>DD</sub>        | V     |
| Input low level voltage      | V <sub>IH1</sub> | except OSCI                                        |                       |     | 0.6                    | V     |
| input low level voltage      | V <sub>IH2</sub> | OSCI only                                          |                       |     | 1.0                    | V     |

Note: \*1. These voltages guarantee correct operation of the LC7985NA and LC7985ND. They do not guarantee correct operation of the LCD panel. V<sub>LCD</sub> must also be observed.

# **Electrical Characteristics** at Ta = -20 to +75 °C, $V_{SS} = 0$ V, $V_{DD} = 5$ V $\pm$ 10%, unless otherwise noted

| Parameter                  | Symbol           | Conditions                                                                                          |                    | Ratings |                    | Unit |  |  |  |
|----------------------------|------------------|-----------------------------------------------------------------------------------------------------|--------------------|---------|--------------------|------|--|--|--|
| raiailletei                | Symbol           | Conditions                                                                                          | min                | typ     | max                | Onit |  |  |  |
| Output high-level voltage  | V <sub>OH1</sub> | I <sub>OH</sub> = -0.205mA<br>Input / Output pins                                                   | 2.4                | -       | -                  | V    |  |  |  |
|                            | V <sub>OH2</sub> | I <sub>OH</sub> = -0.04mA Output pins                                                               | 0.9V <sub>DD</sub> | -       | _                  | V    |  |  |  |
| Output low-level voltage   | V <sub>OL1</sub> | I <sub>OL</sub> = 1.2mA<br>Input / Output pins                                                      | -                  | -       | 0.4                | V    |  |  |  |
|                            | V <sub>OL2</sub> | I <sub>OL</sub> = 0.04mA Output pins                                                                | -                  | -       | 0.1V <sub>DD</sub> | V    |  |  |  |
| Driver fall voltage*1      | V <sub>COM</sub> | I <sub>d</sub> = 0.05mA<br>All common pins                                                          | -                  | -       | 2.9                | V    |  |  |  |
| Driver fall voltage        | V <sub>SEG</sub> | I <sub>d</sub> = 0.05mA<br>All segment pins                                                         | -                  | -       | 3.8                | .8 V |  |  |  |
| Leakage current            | IL               | $V_I = V_{SS}$ to $V_{DD}$                                                                          | -                  | -       | 1                  | μΑ   |  |  |  |
| Pull-up current*2          | l <sub>P</sub>   | V <sub>DD</sub> = 5V                                                                                | 50                 | 125     | 250                | μΑ   |  |  |  |
| Current drain              | I <sub>DD1</sub> | Ceramic resonator oscillator,<br>V <sub>DD</sub> = 5V, f <sub>OSC</sub> = 250kHz,<br>no output load | -                  | 0.55    | 0.8                | mA   |  |  |  |
| Current diam               | I <sub>DD2</sub> | Feedback resistor oscillator,<br>V <sub>DD</sub> = 5V, f <sub>OSC</sub> = 270kHz,<br>no output load | -                  | 0.35    | 0.6                | IIIA |  |  |  |
| External clock*3 Frequency | f <sub>CP</sub>  |                                                                                                     | 125                | 250     | 350                | kHz  |  |  |  |
| Duty cycle                 | DUTY             |                                                                                                     | 45                 | 50      | 55                 | %    |  |  |  |
| Rise time                  | t <sub>R</sub>   |                                                                                                     | -                  | -       | 0.2                | μs   |  |  |  |
| Fall time                  | t <sub>F</sub>   |                                                                                                     |                    | -       | 0.2                | μs   |  |  |  |

| Parameter                     | Symbol            | Conditions                                                                                               |                              | Unit |     |        |  |
|-------------------------------|-------------------|----------------------------------------------------------------------------------------------------------|------------------------------|------|-----|--------|--|
| i arameter                    | Symbol            | Conditions                                                                                               | min                          | typ  | max | O.I.I. |  |
|                               | f <sub>OSC1</sub> | Ceramic filter oscillator 245 2                                                                          | 250                          | 255  |     |        |  |
| Internal oscillator frequency | f <sub>OSC2</sub> | $ \begin{array}{l} \text{Feedback resistor oscillator,} \\ R_f = 91 \text{k}\Omega \pm 3\% \end{array} $ | 190                          | 270  | 350 | kHz    |  |
| LCD display voltage           | V <sub>LCD1</sub> | $1/5$ bias, $V_{LCD} = V_{DD} - V_5$                                                                     | DD - V <sub>5</sub> 4.6 - 11 |      | 11  | V      |  |
| LOD display voltage           | V <sub>LCD2</sub> | $1/4$ bias, $V_{LCD} = V_{DD} - V_5$                                                                     | 3.0                          | _    | 11  | v      |  |

Note: \*1. V<sub>COM</sub> is the voltage from VDD, V1, V4 and V5 to the LCD common drive pins OC1 to OC16. V<sub>SEG</sub> is the voltage from VDD, V2, V3 and V5 to the LCD segment drive pins OC1 to OC40.

Note: \*2. Applied pins are RS, R/W, and DB0 to DB7.

Note: \*3. External clock

## Switching Characteristics at Ta = -20 to +75°C, $VDD = 5V \pm 10\%$ , VSS = 0V

| Parameter                                  | Cumbal            | Conditions               | Ratings |     |      | Unit |
|--------------------------------------------|-------------------|--------------------------|---------|-----|------|------|
| Parameter                                  | Symbol            | Conditions               | min     | typ | max  | Unit |
| E cycle time                               | t <sub>ECYC</sub> |                          | 1000    | -   | -    | ns   |
| E high-level pulsewidth                    | t <sub>EW</sub>   |                          | 450     | -   | -    | ns   |
| E rise time                                | t <sub>ER</sub>   |                          | -       | -   | 25   | ns   |
| E fall time                                | t <sub>EF</sub>   |                          | -       | -   | 25   | ns   |
| RS and R/W to E setup time                 | t <sub>SU</sub>   |                          | 140     | -   | -    | ns   |
| E to RS and R/W address hold time          | t <sub>AH</sub>   |                          | 10      | -   | -    | ns   |
| DB0 to DB7 to E data setup time            | t <sub>DSU</sub>  |                          | 195     | -   | -    | ns   |
| Write cycle E to DB0 to DB7 data hold time | t <sub>DHW</sub>  |                          | 10      | -   | -    | ns   |
| Read cycle E to data valid delay time      | t <sub>DD</sub>   | See measurement circuit. | -       | -   | 320  | ns   |
| Read cycle E to DB0 to DB7 data hold time  | t <sub>DHR</sub>  |                          | 20      | -   | -    | ns   |
| CP low-level pulsewidth                    | t <sub>WL</sub>   |                          | 800     | -   | -    | ns   |
| CP high-level pulsewidth                   | t <sub>WH</sub>   |                          | 800     | -   | -    | ns   |
| CP to LOAD setup time                      | t <sub>CSU</sub>  |                          | 500     | -   | _    | ns   |
| D to CP data setup time                    | t <sub>DSU</sub>  |                          | 300     | -   | _    | ns   |
| CP to D data hold time                     | t <sub>DH</sub>   |                          | 300     | -   | _    | ns   |
| LOAD to M delay time                       | t <sub>DM</sub>   |                          | -1000   | -   | 1000 | ns   |

#### **Reset characteristics** at Ta = -20 to +75°C

| Parameter                 | Symbol             | Conditions |     | Ratings |     | Unit  |
|---------------------------|--------------------|------------|-----|---------|-----|-------|
| raiailietei               | Symbol             | Conditions | min | typ     | max | Offic |
| V <sub>DD</sub> rise time | t <sub>DDR</sub>   |            | 0.1 | -       | 10  | μs    |
| V <sub>DD</sub> off time  | t <sub>DDOFF</sub> |            | 1   | -       | -   | ms    |

#### **Clock Generator**

The internal oscillator that generates the clock for the internal circuit requires an external filter, a feedback resistor or an external clock input as shown in the following sections.

#### **External clock**



The input duty cycle should be between 45 and 55% as shown in the following figure.



#### **Ceramic filter**



Note. Rf  $\,$  = 1M  $\Omega$   $\pm$  10%, CI = CO = 680pF  $\pm$  10%, Rd = 3.3k  $\Omega$   $\pm$  5%

### Feedback resistor



Note. The resistor should be mounted as close as possible to OSCI and OSCO.

#### **Measurement Circuit**



Note.  $R_L$  = 2.4k $\Omega$ , C = 130pF, R = 11k $\Omega$ 

# Read/write cycle timing



## LC7930N interface timing



## **Power supply**



# **Pin Description**

| Name                                | Num | I/O | Connect to | Functions                                                                                                                                                                                     |
|-------------------------------------|-----|-----|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RS                                  | 1   | I   | MPU        | Data register or instruction register select input. Data register when "1" and instruction register when "0".                                                                                 |
| R/W                                 | 1   | I   | MPU        | Read or write select input "0" indicates write, "1"; read                                                                                                                                     |
| E                                   | 1   | I   | MPU        | Execution start input to write or read                                                                                                                                                        |
| DB <sub>4</sub> to DB <sub>7</sub>  | 4   | I/O | MPU        | 4-bit microcontroller interface data bus and 8-bit microcontroller interface high-order four bits data bus connections. Three-state bidirectional. DB <sub>7</sub> can be used as a busyflag. |
| DB <sub>0</sub> to DB <sub>3</sub>  | 4   | I/O | MPU        | 8-bit microcontroller interface low-order four bits data bus connections. No connection when 4-bit interface size is selected. Three-state bidirectional.                                     |
| LOAD                                | 1   | 0   | LC7930N    | Clock to latch the D serial data output to LC 7930N                                                                                                                                           |
| СР                                  | 1   | 0   | LC7930N    | Clock to shift the D serial data                                                                                                                                                              |
| М                                   | 1   | 0   | LC7930N    | Output to shift the LCD drive signal to alternating current signal                                                                                                                            |
| D                                   | 1   | 0   | LC7930N    | Display expansion serial data output "0" indicates unselected, "1"; selected                                                                                                                  |
| OC <sub>1</sub> to OC <sub>16</sub> | 16  | 0   | LCD        | LCD common driver outputs. All common signals unused are unselected wave forms.                                                                                                               |
| OS <sub>1</sub> to OS <sub>40</sub> | 40  | 0   | LCD        | LCD segment driver outputs                                                                                                                                                                    |
| V <sub>1</sub> to V <sub>5</sub>    | 5   |     | source     | Supply voltage for LCD display drive                                                                                                                                                          |
| V <sub>DD</sub> , V <sub>SS</sub>   | 2   |     | source     | V <sub>DD</sub> : +5V, V <sub>SS</sub> : 0V                                                                                                                                                   |
| OSCI, OSCO                          | 2   |     |            | Oscillator feedback resistor and ceramic filter connection, and external clock input                                                                                                          |

#### **Functional Description**

#### Registers

The LC7985 has two 8-bit registers—instruction register (IR) and data register (DR)—that are selected as shown in the following table.

| RS | R/W | Operation                                               |
|----|-----|---------------------------------------------------------|
| 0  | 0   | IR write, instruction execution                         |
| 0  | 1   | Busy flag (DB7) and address counter (DB0 to DB6) output |
| 1  | 0   | DR write, internal DR to DD RAM or CG RAM data transfer |
| 1  | 1   | DR read, internal DD RAM or CG RAM to DR data transfer  |

The instruction register is write-only. It contains instruction codes or DD RAM and CG RAM addresses written by the microcontroller.

#### **Busy Flag**

When busy flag is 1, the previous instruction is executing, and when 0, the instruction has completed. The next instruction cannot be received until BF is 0. The microcontroller should, therefore, confirm that BF is 0 before writing the next instruction.

#### **Display Data RAM (DD RAM)**

The display data RAM stores 80, 8-bit character codes, and the LC7985 can display a maximum of 80 characters. The address counter contains the location for the next display memory read or write operation as shown in the following figure.

The data register holds data read from or written to either DD RAM or CG RAM. Data written to the data register by the microcontroller is automatically transferred to the current DD RAM or CG RAM address. Data read from DD RAM or CG RAM is buffered in the data register.

When the microcontroller writes a DD RAM or CG RAM address to the instruction register, the data at that address is copied into the data register. The microcontroller then reads the data in the data register to complete the transfer. Once that data is read, the data from the next DD RAM or CG RAM address is copied into the data register in preparation for the next data read.

#### **Address Counter**

The address counter is used for both the DD RAM and the CG RAM. The address output on DB0 to DB7 is the counter value before the currently executing instruction began.



Display data addresses are in hexadecimal. For example, the address counter contents for location 4E are shown in the following figure.



To prevent undesirable effects such as display flicker during DD RAM accesses, the internal memory and the microprocessor interface have separate timing signals.

#### Single-line display mode (N = 0)

The DD RAM addresses and their corresponding display positions for an 80-character display are shown in the following figure.



A single LC7985, however, can drive up to eight characters. The display positions and DD RAM addresses for an unshifted 8-character display are shown in the following figure.

|        | 1   | 2   | 3   | 4   | 5   | 6   | 7   | 8   | ← Display character position |
|--------|-----|-----|-----|-----|-----|-----|-----|-----|------------------------------|
| Line 1 | 0 0 | 0 1 | 0 2 | 0 3 | 0 4 | 0 5 | 0 6 | 0 7 | ← DD RAM address (HEX)       |

The DD RAM addresses following left and right display shifts are shown in the following figure. Note that the displayed characters wrap around from addresses  $4F_H$  to  $00_H$ .



An LC7985 and a single LC7930N can drive a 16-character display. The display positions and DD RAM addresses for an unshifted display are shown in the following figure.



The DD RAM addresses following left and right display shifts are shown in the following figure.



The number of displayed characters can be increased by adding more LC7930Ns. An LC7985 and nine LC7930Ns can drive an 80-character display as shown in the following figure.



#### Two-line display mode (N = 1)

The DD RAM addresses and their corresponding display positions for a 2-line  $\times$  40-character display are shown in the following figure. Note that the address counter automatically increments from  $27_{\rm H}$  to  $40_{\rm H}$ .

|        | 1   | 2   | 3   | 4   | 5   | 39      | 40  | ← Display character position |
|--------|-----|-----|-----|-----|-----|---------|-----|------------------------------|
| Line 1 | 0 0 | 0 1 | 0 2 | 0 3 | 0 4 | <br>2 6 | 2 7 | ← DD RAM address (HEX)       |
| Line 2 | 4 0 | 4 1 | 4 2 | 4 3 | 4 4 | <br>66  | 6 7 |                              |

A single LC7985, however, can drive up to eight characters per line. The display positions and DD RAM addresses for an unshifted, 2-line × 8-character display are shown in the following figure.

|        | 1   | 2   | 3   | 4   | 5   | 6   | 7   | 8   | ← Display character position |
|--------|-----|-----|-----|-----|-----|-----|-----|-----|------------------------------|
| Line 1 | 0 0 | 0 1 | 0 2 | 0 3 | 0 4 | 0 5 | 0 6 | 0 7 | ← DD RAM address (HEX)       |
| Line 2 | 4 0 | 4 1 | 4 2 | 4 3 | 4 4 | 4 5 | 4 6 | 47  |                              |

The display positions following a left or right display shift are shown in the following figure. Note that the display shift is simultaneous for both lines, regardless of which line the cursor is in.

| (Left shift)  | 0.8 | 07  | 06  | 05  | 0 4 | 0 3 | 0 2      | 0 1 |
|---------------|-----|-----|-----|-----|-----|-----|----------|-----|
| (==::==:::::) | 4 8 | 4 7 | 4 6 | 4 5 | 4 4 | 4 3 | 4 2      | 4 1 |
|               |     |     |     |     |     |     | <u> </u> |     |
| (5: 1. 1:6)   | 06  | 0 5 | 0 4 | 0 3 | 0 2 | 0 1 | 0 0      | 2 7 |
| (Right shift) | 4 6 | 4 5 | 4 4 | 4 3 | 4 2 | 4 1 | 4 0      | 6 7 |

An LC7985 and a single LC7930N can drive a 2-line  $\times$  16-character display. The display positions and DD RAM addresses for an unshifted, 2-line  $\times$  16-character display are shown in the following figure.



The DD RAM addresses following left and right display shifts are shown in the following figure.

| 0 1 | 0 2 | 0 3 | 0 4 | 0 5 | 0 6 | 0 7 | 0 8 | 0 9 | 0 A | 0 B | 0 C | 0 D | 0 E | 0 F | 10  | (Left shift)    |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----------------|
| 4 1 | 42  | 4 3 | 4 4 | 4 5 | 4 6 | 47  | 4 8 | 49  | 4 A | 4 B | 4 C | 4 D | 4 E | 4 F | 5 0 | (Leit Sillit)   |
|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                 |
| 2 7 | 0 0 | 0 1 | 0 2 | 0 3 | 0 4 | 0 5 | 0 6 | 0 7 | 0.8 | 0 9 | 0 A | 0 B | 0 C | 0 D | 0 E | (Right shift)   |
| 6 7 | 4 0 | 4 1 | 4 2 | 4 3 | 4 4 | 4 5 | 46  | 4 7 | 4 8 | 49  | 4 A | 4 B | 4 C | 4 D | 4 E | (i light shift) |

The number of displayed characters can be increased by adding more LC7930Ns. An LC7985 and four LC7930Ns can drive a 2-line × 40-character display as shown in the following figure.



## **Character Generator ROM (CG ROM)**

The character generator ROM contains 160,  $5 \times 7$ -pixel bitmaps and 32,  $5 \times 10$ -pixel bitmaps as shown in the following figure. The characters are selected by their 8-bit character code.

#### **Character Generator RAM (CG RAM)**

The character generator RAM stores user-defined bitmaps for either eight,  $5 \times 7$ -pixel characters or four,  $5 \times 10$ -pixel characters. To display character patterns stored in CG RAM, write the character codes, shown in the leftmost column of the following figure, on DD RAM.

## Character cord and the character bitmap

| Upper<br>Lower 4 bit | 0000             | 0010 | 0011  | 0100 | 0101 | 0110 | 0111       | 1010 | 1011  | 1100 | 1101 | 1110 | 1111                                                                                   |
|----------------------|------------------|------|-------|------|------|------|------------|------|-------|------|------|------|----------------------------------------------------------------------------------------|
| ××××0000             | CG<br>RAM<br>(1) |      |       |      |      | ••   |            |      | ***** |      | •••  |      |                                                                                        |
| ××××0001             | (2)              | i    | •     | :!   |      | •••• | -:::       | :::  |       |      |      |      |                                                                                        |
| ××××0010             | (3)              | ::   |       |      |      |      | <b>:</b> . | •••  | •••   |      | ×    | :::: |                                                                                        |
| ××××0011             | (4)              |      | :     |      |      | :    | •          | •    |       | •    |      | ::   | :                                                                                      |
| ××××0100             | (5)              |      |       |      |      |      |            | ••   |       |      |      |      | :::                                                                                    |
| ××××0101             | (6)              |      |       |      |      |      |            | ::   |       |      |      | :::  |                                                                                        |
| ××××0110             | (7)              |      |       |      |      |      | i.,:       |      |       | •••  |      |      |                                                                                        |
| xxxx0}]]             | (8)              | :    |       |      |      |      | ii         |      |       |      | •••• |      |                                                                                        |
| ××××1000             | (1)              |      |       |      |      |      | :::        | .:   | •     |      | i,i  | .:   |                                                                                        |
| ××××1001             | (2)              |      |       |      | :::  |      | ::         |      |       | ,.!  |      | •• ; |                                                                                        |
| ××××1010             | (3)              | :    | ::    |      |      |      | ••••       |      |       |      |      |      |                                                                                        |
| ××××1011             | (4)              |      | :     |      |      |      | •          | :::  |       |      |      | ::   | :-:                                                                                    |
| ××××1100             | (5)              | :    | •:    |      | •    |      |            |      | ::::  |      |      | :::. |                                                                                        |
| ××××1101             | (6)              |      | ••••• |      | ***  |      |            |      |       | •••  |      |      | •                                                                                      |
| ××××1110             | (7)              | ::   |       |      | .••• |      | -:-        |      | •     | :    | •••  |      |                                                                                        |
| ××××1111             | (8)              |      | •     |      |      | :::: | •          | :::  |       | :    |      |      | 00 000<br>00 000<br>00 000<br>00 000<br>00 000<br>00 000<br>00 000<br>00 000<br>00 000 |

#### $5 \times 7$ -pixel characters

The layout and addressing for  $5 \times 7$ -pixel characters is shown in the following figure. Each character occupies eight bytes, where bits 3 to 5 of the CG RAM address correspond to bits 0 to 2 of the character code. Note that bit 3 of the character code is not significant so, for example, codes  $00_H$  and  $08_H$  select the same character.

Bits 0 to 2 of the CG RAM address are the bitmap row address, where row 000 is the topmost displayed row.

The cursor, when displayed, is formed by ORing the bottom row with all 1s. If the cursor is used, row 111 should contain all 0s so the cursor does not obscure the bottom row of the character.

Bits 0 to 4 of the CG RAM data contain the character bitmaps. When a bit is 1, the corresponding pixel is ON, and when 0, the pixel is OFF.

Bits 5 to 7 of the CG RAM data are present in memory, but are not used by the display circuit. These bits can be used as general-purpose RAM.

| Character code<br>(DD RAM data) | CG RAM address                                     | Character bitmap<br>(CG RAM data)                                                                                 |                    |
|---------------------------------|----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|--------------------|
| 7 6 5 4 3 2 1 0<br>←MSB LSB→    | 5 4 3 2 1 0<br>←MSB LSB→                           | 7 6 5 4 3 2 1 0<br>←MSB LSB→                                                                                      |                    |
| 0 0 0 0 * 0 0 0                 | 0 0 0<br>0 0 1<br>0 1 0<br>0 0 1 1<br>1 0 0        | * * * 1 1 1 1 0<br>1 0 0 0 1<br>1 0 0 0 1<br>1 1 1 1 0<br>1 0 1 0                                                 | Character bitmap 1 |
|                                 | 1 0 1<br>1 1 0<br>1 1 1<br>0 0 0                   | 1 0 0 1 0<br>1 0 0 0 1<br>* * * 0 0 0 0 0<br>* * * 1 0 0 0 1                                                      | ← Cursor position  |
| 0000*001                        | 0 0 1<br>0 0 1<br>0 1 1<br>1 0 0<br>1 1 0<br>1 1 1 | 0 1 0 1 0<br>1 1 1 1 1<br>0 0 1 0 0<br>1 1 1 1 1<br>0 0 1 0 0<br>1 1 1 1 1<br>0 0 1 0 0<br>0 0 1 0 0<br>0 0 1 0 0 | Character bitmap 2 |
|                                 | 0 0 0 0 0 0 0 1                                    | * * *                                                                                                             |                    |
| 0 0 0 0 * 1 1 1  * Don't care   | 1 1 1 1 0 0 1 1 1 0 0 1 1 1 1                      | * * *                                                                                                             |                    |

#### 5 × 10-pixel characters

The layout and addressing for  $5 \times 10$ -pixel characters is shown in the following figure. Each character occupies eleven bytes, where bits 4 and 5 of the CG RAM address correspond to bits 1 and 2 of the character code. Note that bits 0 and 3 of the character code are not significant so, for example, codes  $00_H$ ,  $01_H$ ,  $08_H$  and  $09_H$  all select the same character.

Bits 0 to 3 of the CG RAM address are the bitmap row address where row 000 is the topmost displayed row.

The cursor, when displayed, is formed by ORing the bottom row with all 1s. If the cursor is used, row 1010 should

contain all 0s so the cursor does not obscure the bottom row of the character.

Bits 0 to 4 of the CG RAM data contain the character bitmaps. When a bit is 1, the corresponding pixel is ON, and when 0, the pixel is OFF.

Bits 5 to 7 of the CG RAM data are present in memory, but are not used by the display circuit. These bits and the CG RAM bytes, rows 1011 to 1111 that are not used by the display circuit, can be used as general-purpose RAM.

| Character code<br>(DD RAM data) |   |   |   |   |          |         | (               | CG F     | RAM | ado | dress    | 3                | Character bitmap<br>(CG RAM data) |          |   |   |     |          |          |          |                   |
|---------------------------------|---|---|---|---|----------|---------|-----------------|----------|-----|-----|----------|------------------|-----------------------------------|----------|---|---|-----|----------|----------|----------|-------------------|
| 7 6 5<br>←MSB                   | 4 |   | 3 | 2 | 1<br>LSI | 0<br>3→ | 5<br><b>←</b> N | 4<br>ISB | 3   | 2   | 1<br>LSE | 0<br>3 <b>→</b>  | 7<br><b>←</b> N                   | 6<br>1SB | 5 | 4 | 3   | 2        | 1<br>LSI | 0<br>B→  |                   |
|                                 |   |   |   |   |          |         |                 |          | 0   | 0   | 0        | 0                | *                                 | *        | * | 0 | 0   | 0        | 0        | 0        |                   |
|                                 |   |   |   |   |          |         |                 |          | 0   | 0   | 0        | 1                |                                   | 1        |   | 0 | 0   | 0        | 0        | 0        |                   |
| İ                               |   |   |   |   |          |         |                 |          | 0   | 0   | 1        | 0                |                                   |          |   | 1 | 0   | 1        | 1        | 0        |                   |
|                                 |   |   |   |   |          |         |                 |          | 0   | 0   | 1        | 1                |                                   |          |   | 1 | _1_ | 0        | 0        | 1        |                   |
|                                 |   |   |   |   |          |         |                 |          | 0   | 1   | 0        | 0                |                                   |          |   | 1 | 0   | 0        | 0        | 1        | Character bitmap  |
| 0 0 0                           | 0 |   | * | 0 | 0        | *       | 0               | 0        | 0   | 1   | 0        | 1                |                                   |          |   | 1 | 0   | 0        | 0        | 1        |                   |
|                                 |   |   |   |   |          |         |                 |          | 0   | 1   | 1        | 0                |                                   |          |   | 1 | _1_ | 1        | 1        | 0        |                   |
|                                 |   |   |   |   |          |         |                 |          | 0   | 1   | 1        | 1                |                                   |          |   | 1 | 0   | 0        | 0        | 0        |                   |
|                                 |   |   |   |   |          |         |                 |          | 1   | 0   | 0        | 0                |                                   |          |   | 1 | 0   | 0        | 0        | 0        |                   |
|                                 |   |   |   |   |          |         |                 |          | 1   | 0   | 0        | 1                |                                   | •        |   | 1 | 0   | 0        | 0        | 0        |                   |
|                                 |   |   |   |   |          |         | <br>            |          | -1  | 0   | .1.      | . 0              | <br>*                             | *        | * | 0 | 0   | 0        | 0        | 0        | ← Cursor position |
|                                 |   |   |   |   |          |         |                 |          | 1   | 0   | 1        | 1                | *                                 | *        | * | * | *   | *        | *        | *        |                   |
|                                 |   |   |   |   |          |         |                 |          | 1   | 1   | 0        | 0                |                                   |          |   |   |     |          |          |          |                   |
|                                 |   |   |   |   |          |         |                 |          | 1   | 1   | 0        | 1                |                                   |          |   |   |     |          |          |          |                   |
|                                 |   |   |   |   |          |         |                 |          | 1   | 1   | 1        | 1                | *                                 | *        | * | * | *   | *        | *        | *        |                   |
|                                 |   |   |   |   | -        |         |                 |          | 0   | 0   | 0        | 0                |                                   | *        |   | ~ | ~   | <u> </u> | Τ.       | <u> </u> |                   |
|                                 |   |   |   |   |          |         |                 |          | 0   | 0   | 0        | 1                | -,-                               | 1        | 4 |   |     |          |          | _        |                   |
|                                 |   | _ |   |   |          |         | _               | _        |     |     | -        |                  |                                   |          |   |   |     |          | _        |          |                   |
| 0 0 0                           | 0 | : | * | 1 | 1        | *       | 1               | 1        | 1   | 0   | 0        | 1                |                                   | T        |   |   |     |          |          |          |                   |
|                                 | 3 |   |   |   |          |         | , .             |          | 1   | 0   | 1        | 0                | *                                 | *        | * |   |     |          |          |          |                   |
|                                 |   |   |   |   |          |         | <br>            |          | 1   | 0   | 1        | - <del>-</del> - | <br>*                             |          |   | * | *   | *        | *        | *        |                   |
|                                 |   |   |   |   |          |         |                 | ;        | 1   | 1   | 0        | 0                |                                   | 1        |   | : |     | 1        |          |          |                   |
|                                 |   |   |   |   |          |         |                 |          | 1   | 1   | 0        | 1                |                                   |          |   |   |     |          |          |          |                   |
|                                 |   |   |   |   |          |         |                 |          | 1   | 1   | 1        | 0                |                                   |          |   |   |     |          |          |          |                   |
|                                 |   |   |   |   |          |         |                 |          | 1   | 1   | 1        | 1                | *                                 | *        | * | * | *   | *        | *        | *        |                   |

\* Don't care

#### **Timing Generator**

This circuit generates timing signals both for internal circuit operation and for driving external LC7930Ns. The timing signals for the DD RAM, CG ROM and CG RAM are independent of the microcontroller interface so that memory accesses by the microcontroller do not cause interference with the display drive signals.

#### **Display Drivers**

The LC7985 incorporates 16 LCD common driver outputs and 40 LCD segment driver outputs. The character font and the number of display lines determine the number of active common outputs.

The segment drivers function identically to the LC7930N display drivers. The character bitmap data to be displayed is latched in the internal 40-bit shift register before being output on the segment drivers.

The display bitmap data for each pixel-row is generated starting with the right-most character position. The data shifts through the shift register and is output on the shift register serial data output. The shift register latches the last 40 bits in the row so the LC7985 displays the left-most eight characters. External LC7930Ns connect in series to the serial data output and each one latches and displays bitmap data for eight additional characters.

#### **Cursor Display and Blinking**

Cursor display and blinking of the character at the cursor position are controlled using the Display ON/OFF instruction. The cursor position is at the character corresponding to the address counter value as shown in the following fig-

ure. Note that the cursor and blinking character are also displayed at the address counter value when CG RAM is selected.





Cursor position

#### Microcontroller Interface

The LC7985 interfaces to both 4-bit and 8-bit microcontrollers.

DB0 to DB7 are used for the 4-bit data bus. Two read or write cycles, therefore, are required to transfer each data,

status or instruction byte. The high-order four bits—bits DB4 to DB7 in 8-bit interface mode—are transferred first. The low-order four bits are then transferred as shown in the following figure.



#### **Reset Circuit**

The internal reset circuit initializes the LC7985 at power-ON. The busy flag remains ON from power-ON until initialization is complete 10ms after  $V_{DD}$  reaches 4.5V. Note that if power supply conditions are such that the internal reset circuit does not operate to initialize the device, the LC7985 must be initialized using commands from the microcontroller.

The initialization sequence is as follows.

- 1. Clear Display
- 2. Set Function (D/L = 1, N = 0, F = 0) Sets 8-bit interface size, 1-line display size and  $5 \times 7$ -pixel character font.
- 3. Cursor/Display Control (D = 0, C = 0, B = 0) Sets the display, the cursor and character blinking OFF.
- Set Entry Mode (I/D = 1, S = 0)
   Sets address counter auto-increment and sets display shift OFF.