### Introduction

**Seiko Instruments** intelligent dot matrix liquid crystal display modules have on-board controller and LSI drivers, which display alpha numerics, Japanese KATA KANA characters and a wide variety of other symbols in either 5 x 7 dot matrix.

The internal operation in the KS0066 controller chip is determined by signals sent from the MPU. The signals

include: 1) Register select RS input consisting of instruction register (IR) when RS = 0 and data register (DR) when RS = 1; 2) Read/write (R/W); 3) Data bus (DB7 $\sim$  DB0); and 4) Enable strobe (E) depending on the MPU or through an external parallel I/O port. Details on instructions data entry, execution times, etc. are explained in the following sections.

### READ AND WRITE TIMING DIAGRAMS AND TABLES

The following timing characteristics are applicable for all of Seiko's LCD dot matrix character modules.

| READ TIMING CHARACTERISTICS Voc=5.0V±5%, Vss=OV, Ta=0°C to 50°C |                                   |      |      |    |  |  |  |  |  |  |  |
|-----------------------------------------------------------------|-----------------------------------|------|------|----|--|--|--|--|--|--|--|
| Item Symbol Standard                                            |                                   |      |      |    |  |  |  |  |  |  |  |
|                                                                 |                                   | Min. | Max. |    |  |  |  |  |  |  |  |
| Enable cycle time                                               | t <sub>cyc</sub> E                | 500  | _    | ns |  |  |  |  |  |  |  |
| Enable pulse width High Level                                   | PW <sub>EH</sub>                  | 230  | _    | ns |  |  |  |  |  |  |  |
| Enable rise and fall time                                       | t <sub>ER</sub> , t <sub>EF</sub> | _    | 20   | ns |  |  |  |  |  |  |  |
| Address setup time RS,R/W—E                                     | t <sub>AS</sub>                   | 40   | -    | ns |  |  |  |  |  |  |  |
| Address hold time                                               | t <sub>AH</sub>                   | 10   | _    | ns |  |  |  |  |  |  |  |
| Data delay time                                                 | t <sub>DDR</sub>                  | _    | 160  | ns |  |  |  |  |  |  |  |
| Data hold time                                                  | t <sub>H</sub>                    | 5    | _    | ns |  |  |  |  |  |  |  |

| Write Timing Characteristics V <sub>00</sub> =5.0V±5%, V <sub>88</sub> =OV, T <sub>a</sub> =0°C to 50°C |                               |      |      |      |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------|-------------------------------|------|------|------|--|--|--|--|--|--|--|
| Item                                                                                                    | Symbol                        | Stan | dard | Unit |  |  |  |  |  |  |  |
|                                                                                                         |                               | Min. | Max. |      |  |  |  |  |  |  |  |
| Enable cycle time                                                                                       | t <sub>cyc</sub> E            | 500  | _    | ns   |  |  |  |  |  |  |  |
| Enable pulse width High Level                                                                           | $PW_{EH}$                     | 230  | _    | ns   |  |  |  |  |  |  |  |
| Enable rise and fall time                                                                               | $t_{\text{ER}},t_{\text{EF}}$ | _    | 20   | ns   |  |  |  |  |  |  |  |
| Address setup time RS,R/W—E                                                                             | t <sub>AS</sub>               | 40   | _    | ns   |  |  |  |  |  |  |  |
| Address hold time                                                                                       | t <sub>AH</sub>               | 10   | _    | ns   |  |  |  |  |  |  |  |
| Data setup time                                                                                         | t <sub>DSW</sub>              | 80   | _    | ns   |  |  |  |  |  |  |  |
| Data hold time                                                                                          | t <sub>H</sub>                | 10   | _    | ns   |  |  |  |  |  |  |  |





DATA READ FROM MODULE TO MPU

DATA WRITE FROM MPU TO MODULE

### **INTRODUCTION CODES**

| Instruction                         | S<br>RS                              | et<br>R/W | DB7 | DB6 | Instr<br>DB5 | uction (         | Code<br>DB3        | DB2                 | DB1 | DB0                  | Description                                                                                                               | Execution<br>(when f <sub>cp</sub><br>is 250 kHz | or f <sub>osc</sub>       |
|-------------------------------------|--------------------------------------|-----------|-----|-----|--------------|------------------|--------------------|---------------------|-----|----------------------|---------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|---------------------------|
| Clear Display                       | 0                                    | 0         | 0   | 0   | 0            | 0                | 0                  | 0                   | 0   | 1                    | Clears all display memory and returns the cursor to the home position (Address 0).                                        | 82 μs ~ 1                                        | 64ms                      |
| Return Home                         | 0                                    | 0         | 0   | 0   | 0            | 0                | 0                  | 0                   | 1   | *                    | Returns the cursor to the home position (Address 0) shifted to the original position. DD RAM contents remain unchanged.   | 40 μs ~ 1.                                       | 6ms                       |
| Entry<br>Mode Set                   | 0                                    | 0         | 0   | 0   | 0            | 0                | 0                  | 1                   | I/D | S                    | Sets the cursor move direction<br>and specifies to or not to shift<br>the display. These operations<br>write and read.    | 40 μs ~ 1                                        | 64ms                      |
| Display<br>ON/OFF<br>Control        | 0                                    | 0         | 0   | 0   | 0            | 0                | 1                  | D                   | С   | В                    | (D) is display ON/OFF control;<br>memory remains unchanged<br>in OFF condition. (C) cursor<br>ON/OFF (B) blinking cursor. | 40 μs                                            |                           |
| Cursor or<br>Display Shift          | 0                                    | 0         | 0   | 0   | 0            | 1                | S/C                | R/L                 | *   | *                    | Moves the cursor and shifts the display without changing DD RAM contents.                                                 | 40 μs                                            |                           |
| Function Set                        | 0                                    | 0         | 0   | 0   | 1            | DL               | N                  | F                   | *   | *                    | Sets interface data length (DL), number of display lines (N), and character font (F).                                     | 40 μs                                            |                           |
| Set CG RAM<br>Address               | 0                                    | 0         | 0   | 1   |              |                  | A <sub>CG</sub>    |                     |     |                      | Sets the CG RAM address.<br>CG RAM data is sent and<br>received after this setting.                                       | 40 μs                                            |                           |
| Set DD RAM<br>Address               | 0                                    | 0         | 1   |     |              | $A_{DD}$         |                    |                     |     |                      | Sets the DD RAM address.<br>DD RAM data is sent and<br>received after this setting.                                       | 40 μs                                            |                           |
| Read<br>Busy Flag<br>& Address      | 0                                    | 1         | BF  |     |              | AC               |                    |                     |     |                      | Reads Busy Flag (BF) indicating internal operation is being performed and reads address counter contents.                 | 1 μs                                             |                           |
| Write Data<br>to CG or<br>to DD RAM | 1                                    | 0         |     |     | Write        | e Data           |                    |                     |     |                      | Writes data into DD RAM or CG RAM.                                                                                        | 40 μs                                            |                           |
| Read Data<br>from CG or<br>DD RAM   | 1                                    | 1         |     |     | Read         | d Data           |                    |                     |     |                      | Reads data from DD RAM or CG RAM.                                                                                         | 40 μs                                            |                           |
| * Doesn't matte                     | er                                   |           | Į.  |     |              |                  |                    |                     |     | ļ                    |                                                                                                                           |                                                  |                           |
|                                     | play data R <i>I</i><br>aracter gene |           | 1   |     |              | ) = 1:<br>) = 0: | Increme            |                     |     | C = 1:<br>C = 0:     | Cursor ON<br>Cursor OFF                                                                                                   | R/L = 1:<br>R/L = 0:                             | Right shift<br>Left shift |
| CG                                  | RAM addres                           |           |     |     |              | = 1:<br>= 0:     | Display<br>No disp | shift<br>olay shift |     | B = 1:<br>B = 0:     | Blink ON<br>Blink OFF                                                                                                     | DL = 1:                                          | 8 bits                    |
| cur                                 | RAM address                          |           |     |     | D            | = 1:<br>= 0:     | Display<br>Display | ON                  |     | S/C = 1:<br>S/C = 0: | Display shift<br>Cursor movement                                                                                          | DL = 0:<br>N = 1:                                | 4 bits<br>2 lines (L1671) |
| 0                                   | dress counte<br>M and CG R           |           |     | )   | _            | -                |                    |                     |     | BF = 1:<br>BF = 0:   | Internal operation in progress<br>Instruction can be accepted                                                             | F = 0:                                           | 5 x 7 dot matrix          |

Execution times in the above table indicate the minimum values when operating frequency is 250 kHz.

When  $f_{OSC}$  is 270 kHz:  $40\mu s \times 250/250 = 37\mu s$ 

### Introduction Code Explanations

The two registers 1) Instruction Register (IR) and the 2) Data Register (DR) in the KS0066 controller chip are directly controlled by the MPU. Control information is temporarily stored in these registers prior to internal operation start. This allows interface to various types of MPUs which operate at different

speeds from that of the KS0066, and allows interface from peripheral control ICs. Internal operations of the KS0066 are determined from the signals sent from the MPU. These signals, including register selection signals (RS), Read/Write (R/W) and data bus signals (DB0 - DB7) are polled instructions.

|    | REGISTER SELECTION |                                                                    |  |  |  |  |  |  |  |
|----|--------------------|--------------------------------------------------------------------|--|--|--|--|--|--|--|
| RS | R/W                | Operation                                                          |  |  |  |  |  |  |  |
| 0  | 0                  | IR selection, IR write. Internal operation: Display clear          |  |  |  |  |  |  |  |
| 0  | 1                  | Busy flag (DB7) and address counter (DB0 to DB6) read              |  |  |  |  |  |  |  |
| 1  | 0                  | DR selection, DR write. Internal operation: DR to DD RAM or CG RAM |  |  |  |  |  |  |  |
| 1  | 1                  | DR selection, DR read. Internal operation: DD RAM or CG RAM to DR  |  |  |  |  |  |  |  |

DDD

### **ADDRESS COUNTER (AC)**

The counter specifies an address when data is written into DD RAM or CG RAM and the data stored in DD RAM or CG RAM is read out. If an Address Set instruction (for DD RAM or CG RAM) is written in the IR, the address information is transferred from the IR to the AC. When display data is writ-

ten into or read from DD RAM or CG RAM, the AC is automatically incremented or decremented by one according to the Entry Mode Set. The contents of the AC are output to DB0 to DB6; refer to above "Register Selection Table" when RS = 0 and R/W = 1.

# CLEAR DISPLAY RS R/W DB7 \_\_\_\_\_

|      | K3 | IX/ VV | וטט |   |   |   |   |   |   | _DD0 |
|------|----|--------|-----|---|---|---|---|---|---|------|
| Code | 0  | 0      | 0   | 0 | 0 | 0 | 0 | 0 | 0 | 1    |

Clear all display memory and return the cursor to the

home position. In other words, the cursor returns to the first character block on the first line on all 1, 2, and 4 line character modules except L4044. I the above is entered on E2 (the second controller for lines 3 and 4), the cursor will return to the first character on the third line.

#### CURSOR HOME

|      | RS | R/W | DB7 |   |   |   |   |    |        | _DB0   |
|------|----|-----|-----|---|---|---|---|----|--------|--------|
| Code | 0  | 0   | 0   | 0 | 0 | 0 | 0 | 0  | 1      | *      |
|      |    |     |     |   |   |   |   | *D | oesn't | matter |

Returns cursor to home position. First line first character

blocks on all 1, 2 and 4 line display; except L4044 refer "clear display": (Address 0;  $A_{DD}$  "80"). The contents of the DD RAM remain unchanged.

| Conditions of use                                                                                 | Restrictions                                                                                      |
|---------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|
| When executing the Display Clear or Cursor Home                                                   | The Cursor Home instruction should be executed again immediately                                  |
| instruction when the display is shifted                                                           | after the Display Clear or Cursor Home instruction is executed.                                   |
| (after execution of Display Shift instruction).                                                   | Do not leave an interval of a multiple of 400/f <sub>OSC</sub> * second after the first execution |
|                                                                                                   | • L4052: f <sub>osc</sub> = 250 kHz                                                               |
|                                                                                                   | • The other modules: f <sub>OSC</sub> = 270 kHz                                                   |
|                                                                                                   | *f <sub>osc</sub> : Oscillation frequency                                                         |
| When 23 <sub>H</sub> , 27 <sub>H</sub> , 63 <sub>H</sub> , or 67 <sub>H</sub> is used as a DD RAM | Before executing the Cursor Home instruction, the data of the four DD                             |
| address to execute Cursor Home instruction.                                                       | RAM addresses given at the left should be read and saved. After execution, w                      |
|                                                                                                   | the data again in DD RAM. (This restriction is necessary to prevent the conte                     |
|                                                                                                   | of the DD RAM addresses from being destroyed after the Cursor Home                                |
|                                                                                                   | instruction has been executed.)                                                                   |

#### **ENTRY MODE SET**

|      | RS | R/W | DB7 |   |   |   |   |   |     | _DB0 |
|------|----|-----|-----|---|---|---|---|---|-----|------|
| Code | 0  | 0   | 0   | 0 | 0 | 0 | 0 | 1 | I/D | S    |

**I/D:** Increments (I/D = 1) or decrements (I/D = 0) the DD RAM address by one block when writing or reading a character code from DD RAM or CG RAM. The cursor automatically moves to the right when incremented by one or to the left if decremented by one.

S: Shifts the entire display to either the right or left when S = 1 (high). When S = 1 and I/D = 1 the display shifts one position to the left. When S = 1 and 1/D = 0 the display shifts one position to the right. This right or left shift occurs after each data write to DD RAM. Display is not shifted when reading from DD RAM. Display is not shifted when S = 0.

#### DISPLAY AND CURSOR ON/OFF CONTROL

|      | RS | R/W | DB7 |   |   |   |   |   |   | _DB0 |
|------|----|-----|-----|---|---|---|---|---|---|------|
| Code | 0  | 0   | 0   | 0 | 0 | 0 | 1 | D | С | В    |

D: Display is turned ON when D=1 and OFF when D=0. When display is OFF, display data in DD RAM remains unchanged. Information comes back immediately when D=1 is entered.

C: Cursor is displayed when C = 1 and not displayed when C = 0. If the cursor disappears, function of I/D etc.

does not change during display data write. In a 5 x 7 dot matrix there is an eighth line which functions as the cursor.

B: When B = 1, the character at the cursor position starts blinking. When B = 0 the cursor does not blink. The blink is done by stiching between the all black dot matrix and displayed character at 0.4 seconds intervals. The cursor and the blink can be set at the same time (fosc = 250 kHz).

#### 5 x 7 DOT MATRIX

C = 1 (cursor display)







#### CURSOR OR DISPLAY SHIFT

|      | RS | R/W | DB7 |   |   |   |     |     |   | _DB0 |
|------|----|-----|-----|---|---|---|-----|-----|---|------|
| Code | 0  | 0   | 0   | 0 | 0 | 1 | S/C | R/L | * | *    |
|      |    | Ů   | 0   | 0 | ) |   | õ   | -   |   |      |

\* Doesn't Matter

Cursor/Display Shift moves the cursor or shifts the display without changing the DD RAM contents.

The cursor position and the AC contents match. This instruction is available for display correction and retrieval because the cursor position or display can be shifted without writing or reading display data. In case of a 2-line display, the

cursor is shifted from character block 40 of line 1 to character block 1 of line 2. Displays of lines 1 and 2 are shifted at the same time. In case of a 4-line display, the cursor does not move continuously from line 2 to line 3. The cursor is shifted from character block 40 of line 3 to character block 1 of line 4. Displays of lines 3 and 4 are shifted at the same time. The display pattern of line 2 or 4 is not shifted to line 1 or 3.

| S/C | R/L | Operation                                                           |
|-----|-----|---------------------------------------------------------------------|
| 0   | 0   | The cursor position is shifted to the left (the AC decrements one)  |
| 0   | 1   | The cursor position is shifted to the right (the AC increments one) |
| 1   | 0   | The entire display is shifted to the left with the cursor           |
| 1   | 1   | The entire display is shifted to the right with the cursor          |

#### **FUNCTION SET**



Function Set sets the interface data length, the number of display lines and the character font.

DL: Interface data length

When DL = 1, the data length is set at 8 bits (DB7 to DB0). When DL = 0, the data length is set at 4 bits (DB7 to DB4).

The upper 4 bits are transferred first, then the lower 4 bits follow.

N: Number of display lines

F: Sets character font

| N | F | Number of display lines | Character font   | <b>Duty Cycle</b> | LCD Module                |
|---|---|-------------------------|------------------|-------------------|---------------------------|
| 1 | 0 | 2                       | 5 x 7 dot matrix | 1/16              | All character LCD modules |
|   |   |                         |                  |                   |                           |
|   |   |                         |                  |                   |                           |

The Function Set instruction must be executed prior to all other instructions except for Busy Flag/Address Read. If another instruction is executed first, no function instruction except changing the interface data length can be executied.

#### CG RAM ADDRESS SET

|      | RS | R/W | DB7 |       |        |   |   |   |      | _DB0  |
|------|----|-----|-----|-------|--------|---|---|---|------|-------|
| Code | 0  | 0   | 0   | 1     | Α      | Α | Α | Α | Α    | Α     |
|      |    |     |     | ← Upp | er bit |   |   | I | ower | bit → |

CG RAM addresses, expressed as binary AAAAAA, are set to the AC. Then data in CG RAM is written from or read to the MPU.

#### **DD RAM ADDRESS SET**



DD RAM addresses expressed as binary AAAAAA are set to the AC. Then data in DD RAM is written from or read to the MPU.

#### **BUSY FLAG/ADDRESS READ**

|      | RS | R/W | DB7 |       |        |   |   |   |      | _DB0  |
|------|----|-----|-----|-------|--------|---|---|---|------|-------|
| Code | 0  | 0   | BF  | Α     | Α      | Α | Α | Α | Α    | Α     |
|      |    |     |     | ← Upp | er bit |   |   | L | ower | bit → |

The BF signal can be read to verify if the controller is indicating that the module is working on a current instruction.

When BF = 1, the module is working internally and the next instruction cannot be accepted until the BF value becomes 0.

When BF = 0, the next instruction can be accepted.

Therefore, make sure that BF = 0 before writing the next instruction. The AC values of binary AAAAAA are read out at the same time as reading the busy flag. The AC addresses are used for both CG RAM and DD RAM but the address set before execution of the instruction determines which address is to be used.

#### DATA WRITE TO CG RAM OR DD RAM



Binary eight-bit data DDDDDDDD is written into CG RAM or DD RAM. The CG RAM Address Set instruction or the DD RAM Address Set instruction before this instruction selects either RAM. After the write operation, the address and display shift are determined by the entry mode setting.

#### DATA READ TO CG RAM OR DD RAM



Binary eight-bit data DDDDDDDD is read from CG RAM or DD RAM. The CG RAM Address Set instruction or the DD RAM Address Set instruction before this instruction selects either RAM. In addition, either instruction is executed immediately before this instruction. If no Address Set instruction is executed before a read instruction, the first data read becomes invalid. If read instructions are executed consecutively, data is normally read from the second time. However, if the cursor is shifted by the Cursor Shift instruction when reading DD RAM, there is no need to execute an address set instruction because the Cursor Shift instruction does this.

After the read operation, the address is automatically incremented or decremented by one according to the entry mode, but the display is not shifted.

**Note:** The AC is automatically incremented or decremented by one according to the entry mode after a write instruction is excecuted to write data in CG RAM or DD RAM. However, the data of the RAM selected by the AC are not read out even if a read instruction is executed immediately afterwards.

### $5 \times 7 + CURSOR$

Relationships between CG RAM addresses and character codes (DD RAM) and character patterns (CG RAM data), (5 x 7 dot matrix).5 X 7 Table

|                                        |                            | rn<br>)                         | itter<br>ata)                        | pa<br>VI da                     | cter<br>RAI                     | ara<br>CG I | CI<br>( |   |                                 | ess                             | addr                            | RAM      | CG F     |         |          |           | ode<br>ata) |   |          |           |          |   |
|----------------------------------------|----------------------------|---------------------------------|--------------------------------------|---------------------------------|---------------------------------|-------------|---------|---|---------------------------------|---------------------------------|---------------------------------|----------|----------|---------|----------|-----------|-------------|---|----------|-----------|----------|---|
|                                        | 0<br>oit                   |                                 | 2<br>_ow                             | 3<br>L                          | 4<br>it                         | 5<br>er b   | -       | 7 | 0<br>t                          | 1<br>wer b                      | 2<br>Lo                         | 3<br>bit | 4<br>per | 5<br>Up | 0<br>oit | 1<br>er b | 2<br>_ow    | 3 | 4<br>oit | 5<br>er b | 6<br>Upp | 7 |
| Example of<br>character<br>pattern (R) | 1<br>1<br>0<br>0           | 1<br>0<br>0<br>1<br>0<br>1<br>0 | 1<br>0<br>0<br>1<br>1<br>0<br>0      | 1<br>0<br>0<br>1<br>0<br>0      | 1<br>1<br>1<br>1<br>1<br>1      | *           | *       | * | 0<br>1<br>0<br>1<br>0<br>1<br>0 | 0<br>0<br>1<br>1<br>0<br>0      | 0<br>0<br>0<br>0<br>1<br>1<br>1 | 0        | 0        | 0       | 0        | 0         | 0           | * | 0        | 0         | 0        | 0 |
| Cursor position                        | 0                          | 0                               | 0                                    | 0                               | 0                               | *           | *       | * | 1                               | 1                               | 1                               |          |          |         |          |           |             |   |          |           |          |   |
| Example of character pattern (¥)       | 0<br>1<br>0<br>1<br>0<br>0 | 1<br>0<br>1<br>0                | 0<br>0<br>1<br>1<br>1<br>1<br>1<br>0 | 0<br>1<br>1<br>0<br>1<br>0<br>0 | 1<br>0<br>1<br>0<br>1<br>0<br>0 | *           | *       | * | 0<br>1<br>0<br>1<br>0<br>1<br>0 | 0<br>0<br>1<br>1<br>0<br>0<br>1 | 0<br>0<br>0<br>0<br>1<br>1<br>1 | 1        | 0        | 0       | 1        | 0         | 0           | * | 0        | 0         | 0        | 0 |
|                                        |                            |                                 |                                      |                                 |                                 | *           | *       | * | 0                               | 0                               | 0                               |          |          |         |          |           |             |   |          |           |          |   |
|                                        |                            |                                 |                                      |                                 |                                 | *           | *       | * | 0<br>1<br>0<br>1                | 0<br>0<br>1<br>1                | 1<br>1<br>1                     | 1        | 1        | 1       | 1        | 1         | 1           | * | 0        | 0         | 0        | 0 |

Notes: ▶

- ▶ In CG RAM data, 1 corresponds to Selection and 0 to Non-selection on the display.
- ▶ Character code bits 0 to 2 and CG RAM address bits 3 to 5 correspond with each other (three bits, eight types).
- ▶ CG RAM address bits 0 to 2 specify a line position for a character pattern. Line 8 of a character pattern is the cursor position where the logical sum of the cursor and CG RAM data is displayed. Set the data of line 8 to 0 to display the cursor. If the data is charged to 1, one bit lights, regardless of the cursor.
- ▶ The character pattern column position corresponds to CG RAM data bits 0 to 4 and bit 4 comes to the left end. CG RAM data bits 5 to 7 are not displayed but can be used as general data RAM.
- When reading a character pattern from CG RAM, set to 0 all of character code bits 4 to 7. Bits 0 to 2 determine which pattern will be read out. Since bit 3 is not valid, 00<sup>H</sup> and 08<sup>H</sup> select the same character.

## PROGRAMMING THE CHARACTER GENERATOR RAM (CG RAM)

The character generator RAM (CG RAM) allows the user to create up to eight custom 5 x 7 characters + cursor (5 x 8). Once programmed, the custom characters or symbols are accessed exactly as if they were in ROM. However since the RAM is a volatile memory, power must be continually maintained. Otherwise, the custom characters/symbols must be programmed into non-volatile external ROM and sent to the display after each display initialization. All dots in the 5 x 8 dot matrix can be programmed, which includes the cursor position.

The modules RAM are divided into two parts: data display RAM (DD RAM) and custom character generator RAM (CG RAM). This is not to be confused programming the custom character generator RAM with the 192 character generator ROM. The CG RAM is located between hex 40 and 7F and is contiguous. Locations 40 thru 47 hold the first custom character (5 x 8), 48 thru 4F hold the second custom character, 50 thru 57 hold the third CG, and so forth to 78 thru 7F for the eighth CG character/symbol.

If during initialization the display was programmed to automatically increment, then only the single initial address, 40, need be sent. Consecutive row data will automatically appear at 41, 42, etc. until the completed character is formed. All eight custom CG characters can be programmed in 64 consecutive "writes" after sending the single initial 40 address.

The CG RAM is 8 bits wide, although only the right-most 5-bits are used for a custom CG character row. The left-most dot of programming the CG RAM character corresponds to D4 in the most significant nibble (XXXD4) of the data bus code, with the remaining 4 dots in the row corresponding to the least significant nibble (D3 thru D0), D0 being the right-most dot. Thus, hex 1F equals all dots on and hex 00 equals all dots off. Examples include hex 15 (10101) equal to 3 dots on the hex 0A (01010) equal 2 dots on. In each case the key 5-bits of the 8-bit code program one row of a custom CG character. When all 7 or 8 rows are programmed, the character is complete. A graphic example is shown below:

| RS | R/W | Data | Display | Description                                                                                          |
|----|-----|------|---------|------------------------------------------------------------------------------------------------------|
| 0  | 0   | 40   | _       | addresses 1st row, 1st CG character                                                                  |
| 1  | 0   | 11   | * *     | result of 11, 1st row                                                                                |
| 1  | 0   | 0A   | * *     | result of 0A, 2nd row                                                                                |
| 1  | 0   | 1F   | ****    | result of 1F, 3rd row                                                                                |
| 1  | 0   | 04   | *       | result of 04, 4th row                                                                                |
| 1  | 0   | 1F   | ****    | result of 1F, 5th row                                                                                |
| 1  | 0   | 04   | *       | result of 04, 6th row                                                                                |
| 1  | 0   | 04   | *       | result of 04, 7th row                                                                                |
| 1  | 0   | 00   | _       | result of 00, 8th row (cursor position)                                                              |
| 1  | 0   | 15   | ***     | 1st row, 2nd CG character. <b>Note:</b> Addressing not now required; hex 48 is next in the sequence. |

### **Address Locations**

**1) L1671-Series** (16 characters x 1 line)

|        | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 |
|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Line 1 | 80 | 81 | 82 | 83 | 84 | 85 | 86 | 87 | CO | C1 | C2 | С3 | C4 | C5 | C6 | C7 |

**NOTE:** L1671 series is initialized as a 2 line display, because of the absence of an LCD driver. You must address character no. 9 as you would the first position on the 2nd line which is (CO).

2) L1672-Series (16 characters x 2 lines) L1682-Series

L1692-SERIES

|        | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 |
|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Line 1 | 80 | 81 | 82 | 83 | 84 | 85 | 86 | 87 | 88 | 89 | 8A | 8B | 8C | 8D | 8E | 8F |
| Line 2 | CO | C1 | C2 | C3 | C4 | C5 | C6 | C7 | C8 | С9 | CA | СВ | CC | CD | CE | CF |

**3) L1634-Series** (16 characters x 4 lines)

|        | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 |
|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Line 1 | 80 | 81 | 82 | 83 | 84 | 85 | 86 | 87 | 88 | 89 | 8A | 8B | 8C | 8D | 8E | 8F |
| Line 2 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Line 3 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Line 4 | D0 | D1 | D2 | D3 | D4 | D5 | D6 | D7 | D8 | D9 | DA | DB | DC | DD | DE | DF |

4) L2032-Series (20 characters x 2 lines)

|        | _ ' | 2  | 3  | 4  | Э  | 0  | - / | ŏ  | 9  | 10 | 1.1 | 12 | 13 | 14 | 10 | 10 | 17 | 18 | 19 | 20 |
|--------|-----|----|----|----|----|----|-----|----|----|----|-----|----|----|----|----|----|----|----|----|----|
| Line 1 | 80  | 81 | 82 | 83 | 84 | 85 | 86  | 87 | 88 | 89 | 8A  | 8B | 8C | 8D | 8E | 8F | 90 | 91 | 92 | 93 |
| Line 2 | C0  | C1 | C2 | С3 | C4 | C5 | С6  | C7 | C8 | С9 | CA  | СВ | CC | CD | CE | CF | D0 | D1 | D2 | D3 |

**L2034-Series** (20 characters x 4 lines)

|        | I  |    | 3  |    |    |    |    |    |    |    |    | 12 |    |    |    |    |    |            |    |    |
|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|----|----|
| Line 1 | 80 | 81 | 82 | 83 | 84 | 85 | 86 | 87 | 88 | 89 | 8A | 8B | 8C | 8D | 8E | 8F | 90 | 91         | 92 | 93 |
| Line 2 | CO | C1 | C2 | C3 | C4 | C5 | С6 | C7 | C8 | С9 | CA | СВ | CC | CD | CE | CF | D0 | D1         | D2 | D3 |
| Line 3 | 94 | 95 | 96 | 97 | 98 | 99 | 9A | 9B | 9C | 9D | 9E | 9F | Α0 | A1 | A2 | А3 | A4 | <b>A</b> 5 | A6 | A7 |
| Line 4 | D4 | D5 | D6 | D7 | D8 | D9 | DA | DB | DC | DD | DE | DF | E0 | E1 | E2 | E3 | E4 | E5         | E6 | E7 |

**L2462-Series** (24 characters x 2 lines)

|        | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 |
|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Line 1 | 80 | 81 | 82 | 83 | 84 | 85 | 86 | 87 | 88 | 89 | 8A | 8B | 8C | 8D | 8E | 8F | 90 | 91 | 92 | 93 | 94 | 95 | 96 | 97 |
| Line 2 | CO | C1 | C2 | С3 | C4 | C5 | С6 | C7 | C8 | С9 | CA | СВ | СС | CD | CE | CF | D0 | D1 | D2 | D3 | D4 | D5 | D6 | D7 |

7) L4052-SERIES (40 characters x 2 lines) L4044-SERIES (40 characters x 4 lines)

|        | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38         | 39 | 40 |
|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|----|----|
| Line 1 | 80 | 81 | 82 | 83 | 84 | 85 | 86 | 87 | 88 | 89 | 8A | 8B | 80 | 8D | 8E | 8F | 90 | 91 | 92 | 93 | 94 | 95 | 96 | 97 | 98 | 99 | 9A | 9B | 9C | 9D | 9E | 9F | A0 | A1 | A2 | А3 | A4 | <b>A</b> 5 | A6 | A7 |
| Line 2 | CO | C1 | C2 | C3 | C4 | C5 | C6 | C7 | C8 | С9 | CA | СВ | CC | CD | CE | CF | D0 | D1 | D2 | D3 | D4 | D5 | D6 | D7 | D8 | D9 | DA | DB | DC | DD | DE | DF | E0 | E1 | E2 | E3 | E4 | E5         | E6 | E7 |
| Line 3 | 80 | 81 | 82 | 83 | 84 | 85 | 86 | 87 | 88 | 89 | 8A | 8B | 80 | 8D | 8E | 8F | 90 | 91 | 92 | 93 | 94 | 95 | 96 | 97 | 98 | 99 | 9A | 9B | 9C | 9D | 9E | 9F | A0 | A1 | A2 | А3 | A4 | <b>A</b> 5 | A6 | A7 |
| Line 4 | CO | C1 | C2 | С3 | C4 | C5 | C6 | C7 | C8 | C9 | CA | СВ | CC | CD | CE | CF | D0 | D1 | D2 | D3 | D4 | D5 | D6 | D7 | D8 | D9 | DA | DB | DC | DD | DE | DF | E0 | E1 | E2 | E3 | E4 | E5         | E6 | E7 |

### CHARACTER FONT CODES (5 x 7 DOT MATRIX)

# Upper 4 Bit Hexadecimal

|                           |                  |               | T           | r            |                      | T           |                 |             | Γ            |              |                   |             |             |
|---------------------------|------------------|---------------|-------------|--------------|----------------------|-------------|-----------------|-------------|--------------|--------------|-------------------|-------------|-------------|
| Upper 4 bits Lower 4 bits | 0000             | 0010          | 0011        | 0100<br>(4)  | 01 <b>0</b> 1<br>(5) | 0110<br>(6) | <b>0111</b> (7) | 1010<br>(A) | 1011<br>(B)  | 1100<br>(C)  | 1101<br>(D)       | 1110<br>(E) | 1111<br>(F) |
| ××××0000<br>(0)           | CG<br>RAM<br>(1) |               |             |              | :                    | ٠.          | <b>:::</b> ·    |             | ••••         | :::          | <b></b> .         |             | ::          |
| ××××0001<br>(1)           | (2)              |               | :           |              |                      | •:::        | ·:::            | :::         | `;;·         | ::::         | i;                |             |             |
| ××××0010<br>(2)           | (3)              | ::            | ::::        |              |                      |             | ····            | •           |              | : <u>;</u> : | .::: <sup>1</sup> | ::::        |             |
| ××××0011 (3)              | (4)              |               |             | <b></b> .    | ::                   | <b>:</b> .  | ·               | !           | :::          | ·::-         |                   | ::::        | ::::        |
| ××××0100<br>(4)           | (5)              | ::::          | :: <b>.</b> | <b>:::</b> : |                      | :::         | •               | ٠.          |              | <b>!</b> ··  | •                 |             | ::::        |
| ××××0101<br>(5)           | (6)              | ::.·          |             |              |                      | ::::        | 1               | ::          |              |              |                   | :::.        | 11          |
| ××××0110<br>(6)           | (7)              | ::::          | ::::        |              |                      |             | i:              | :::         |              | •••          |                   | <i>:</i> :: | ::          |
| ××××0111 (7)              | (8)              | ::            | :::         |              |                      | :           | 1,.,1           | .;.·        | ::::::       | ::: <b>:</b> |                   |             | .:          |
| ××××1000<br>(8)           | (1)              | : <u>`</u>    |             |              | :::                  |             | ;:::            | ·:'         | :::          |              | <u>.</u> :        | !"          | ::::        |
| ××××1001<br>(9)           | (2)              |               | ::::        |              | i.,.i                | i.          | ·!              | ::::        | •            |              | :::               | :           |             |
| ××××1010<br>(A)           | (3)              | : <b>!</b> :: | ::          |              | :::                  | :           | ::              |             |              | ••           |                   |             | ::::        |
| ××××1011<br>(B)           | (4)              |               | ::          | <b>::</b> :  |                      | ·::         | ·               | :::         | :::          |              |                   | :·:         |             |
| ××××1100<br>(C)           | (5)              | ::            | ·:.         |              |                      |             |                 | :::         | ::           |              | : <u>.</u> :      | :::.        |             |
| x x x x 1101<br>(D)       | (6)              | ••••          |             |              |                      | :::         | <u>;</u> :-     | .::.        | .:: <u>.</u> | ٠٠٠;         | ·                 | :           |             |
| ××××1110<br>(E)           | (7)              | ::            | ::-         | ·            |                      | j.";        | •:•             |             |              | : :          | •.•               |             |             |
| ××××1111 (F)              | (8)              |               | ••••        |              |                      | :::::       | •               | • : :       | ·i           | ·::          | :::               | ::::        |             |

Lower 4 Bit Hexadecimal

### **EXAMPLES OF 8-BIT AND 4-BIT DATA TRANSFER OPERATION**

#### **DISPLAY INITIALIZATION**

Each time the module is turned on or reset, an initialization procedure must be executed. The procedure consists of sending a sequence of hex codes from the microprocessor or parallel I/O port. The initialization sequence turns on the cursor, clears the display, and sets the module onto an auto-increment mode.

The initial hex code 30, 34, or 38 is sent two or more times to ensure the module enters the 8-bit or 4-bit data

mode. All the initialization sequences are performed under the condition of Register Select (RS) = 0 (low) and Read/Write (R/W) = 0 (low).

The 4-bit data bus microcontroller may operate the display module by sending the initialization sequence in 4-bit format. Since 4-bit operation requires the data to be sent twice over the higher 4-bit bus lines (D4-D7), memory requirements are doubled.

### A. Example for the module with 5 x 7 Character Format Under 8-Bit Data Transfer



Note:

- 1) Both RS and R/W terminals shall be "0" in this sequence.
- 2) RS, R/W and Data are latched at the falling edge of the Enable signal, (falling edge is typically 10nSec; Max: 20nSec).
- 3) L4044 has t obe initialized on E1 and E2 respectively.

### Examples of 8-Bit and 4-Bit Data Transfer Operation

### B. Example for the module with 5 x 7 Character Format Under 4-Bit Data Transfer



Note:

- 1) Both RS and R/W terminals shall be "0" in this sequence.
- 2) RS, R/W and Data are latched at the falling edge of the Enable signal,
- 3) Enable signal has to be sent after every 4-bit Data transfer.

- 1) Display "THIS IS SEIKO LCD MODULE" on L1672.
  - ► Set RS = R/W = 0 (low), then send hex codes 38, 38, 06, 0E, 01, 80. (80 is the home position of the DD RAM)
  - ► Set RS = 1 and R/W = 0, then send hex codes 54, 48, 49,53, 20, 49, 53, 20, 53,45,49, 4B, 4F.
  - ► Set RS = R/W = 0, then send hex code C0 to start from beginning of the second line.
  - ► Set RS = 1 and R/W = 0, then send hex codes 4C, 43, 44, 20, 4D, 44, 55, 4C, 45.
- 2) Display "ONE", "TWO", "THREE", and "FOUR" on each line of L4044.
  - Set RS = R/W = E2 = 0, E1 = 1, then send hex codes 38, 38, 06, 0E, 01, 80.
  - ► Set RS = R/W = E1 = 0, E2 = 1, then send hex codes 38, 06, 0C, 01.
  - ► Set RS = E1 = 1, R/W = E2 = 0, then send hex codes 4F, 4E, 45.
  - Set RS = R/W = E2 = 0, E1 = 1, then send hex code C0.
  - ► Set RS = E1 = 1, R/W = E2 = 0, then send hex codes 54, 57, 4F.

- Set RS = R/W = E2 = 0, E1 = 1, then send hex code 0C.
- ► Set RS = R/W = E1 = 0, E2 = 1, then send hex codes 0E, 80.
- Set RS = E2 = 1, R/W = E1 = 0, then send hex codes 45, 48, 52, 45, 45.
- Set RS = R/W = E1 = 0, E2 = 1, then send hex code C0.
- ► Set RS = E2 = 1, R/W = E1 = 0, then send hex code 46, 4F, 55, 52.
- 2) Display "L1671 LCD MODULE" on L1671. (Special case in the LCD modules)
  - Set RS = R/W = 0, then send hex codes 38, 38, 06, 0E, 01, 80.
  - Set RS = 1 and R/W = 0, then send hex codes 38, 06, 0C, 01.
  - ► Set RS = R/W = 0, then send hex code C0 to start from 9th character.
  - Set RS = 1 and R/W = 0, then send hex codes 44, 20, 4D, 4F, 44, 55, 4C, 45.

### INTERFACE PROBLEMS AND POSSIBLE SOLUTIONS

Although the following problems and possible solutions are not all inclusive, they do represent the most common problems experienced not only by the first-time user, but also experienced users. If the user is experiencing problems, please review all of the following information. If the user still has problems, please call **Seiko Instruments** in Torrance, California at (310) 517-7771.

#### **SYMPTOMS**

- Display is blank after power ON and initialization: Check 1- 6.
- 2) Wrong information being displayed: Check 3,4,6,7,8,9.
- Symptoms same as 2, except multiple components are tied to the data bus: Check 8,9,10.
- 4) ICs become HOT: Check 1,11,12,13.
- 5) Cannot enter information to the 2nd line or lines 3 and 4 of the 4-line display: Check 4,14,15.

#### POSSIBLE SOLUTION(S)

- 1) Check +5 VDC and ground lines and connections.
- 2) A variable resistor or fixed resistor must be used on the V<sub>LC</sub> pin for all LCD modules. V<sub>LC</sub> voltage range is: 0~.7 volts (ref: Contrast Adjustment Circuit).
- 3) Data is being transmitted too fast:
  - Wait 4.5 mS after Power ON, or until V<sub>DD</sub> reaches 4.5 volts. Wait more than 15 mS after V<sub>DD</sub> reaches 4.5 volts.

- ► Allow 1.6mS, after entering hexadecimal 01 or 02 at the end of the initialization sequence, then enter data.
- ► Time interval between other data entries should be 50uS or greater.
- 4) Failure to properly initialize the display: Check initialization examples for either 4 or 8-bit. Make sure to enter first hexadecimal entry at least twice in the initialization sequence. This sets the LCD to either a 1 or 2 line display.
- 5) LCD input assumed to be configured as an IC. (This is not correct.)
- 6) Check the time interval on the falling edge of the enable pulse. Should not exceed 20nS (typical is 10nS).
- 7) Enable pulse width is shorter than 230nS.
- 8) More than one external bus being selected: Check data bus connection.
- 9) Signal levels are too low: Insure that V(IH & OH) is more than 2.4 volts.
- 10) All data bus components do not have TTL type outputs.
- 11) V<sub>DD</sub> and V<sub>SS</sub> pins are reversed.
- 12) Too much voltage on V<sub>DD</sub> (Max. 7VDC).
- 13) Load being put on data lines, when power is OFF on the V<sub>DD</sub> pin.
- 14) Check address locations for the first position on the second line for each 2 lines (ref: Address Location Chart).
- 15) L4044 has two controllers: E1 for lines 1 & 2 and E2 for lines 3 & 4. Initialization must be done for E1 and the same for E2.