Design a circuit that 1) counts the number of times the key-3 push-button is pressed 2) display the count on the board's LCD, 3) uses the push-button key- 0 to reset the system. The default value displayed on the LCD before key-3 is pressed for the first time is 0 . If the number of times the key- 3 push-button is pressed exceeds ten, the system should display the text:

YOU PUSHED TOO
MANY TIMES
On the DE2-115 board the FPGA controls the LCD via the interface shown in figure:


Figure 4-12 Connections between the LCD module and Cyclone IV E FPGA
*(1): Note the current LCD modules used on DE2-115 boards do not have backlight. Therefore the LCD_BLON signal should not be used in users' design projects.

Table 4-6 Pin Assignments for LCD Module

| Signal Name | FPGA Pin No. | Description | vo <br> Standard |
| :---: | :---: | :---: | :---: |
| LCD_DATA[7] | PIN_M5 | LCD Data[7] | 3.3V |
| LCD_DATA[6] | PIN_M3 | LCD Data[6] | 3.3 V |
| LCD_DATA[5] | PIN_K2 | LCD Data[5] | 3.3V |
| LCD_DATA[4] | PIN_K1 | LCD Data[4] | 3.3 V |
| LCD_DATA[3] | PIN_K7 | LCD Data[3] | 3.3 V |
| LCD_DATA[2] | PIN_L2 | LCD Data[2] | 3.3 V |
| LCD_DATA[1] | PIN_L1 | LCD Data[1] | 3.3 V |
| LCD_DATA[0] | PIN_L3 | LCD Data[0] | 3.3 V |
| LCD_EN | PIN_L4 | LCD Enable | 3.3 V |
| LCD_RW | PIN_M1 | LCD Read/Write Select, $0=$ Write, $1=$ Read | 3.3V |
| LCD_RS | PIN_M2 | LCD Command/Data Select, $0=$ Command, 1 = Data | 3.3V |
| LCD_ON | PIN_L5 | LCD Power ON/OFF | 3.3V |
| LCD_BLON | PIN_L6 | LCD Back Light ON/OFF | 3.3 V |

The $2 \times 16$ character LCD has a built in graphic controller.
The controller has three internal memory regions (DDRAM, CGROM, CGRAM), each with a specific purpose. The display must be initialized before accessing any of these memory regions.
The memory map, the command set of the internal controller and the operation and timing of the 8-bit Data Interface are described in the attached data sheet.

1. Write a short report documenting the main characteristic and performance of the system you designed (think of the document as the "data sheet" of your system)
2. Submit VHDL code for both design and test bench.
3. Submit the waveforms used for the test bench. Comment the waveforms and make sure to illustrate that the system works as expected
4. Analyze the synthesis and implementation reports and submit a short summary including area and timing.
5. Demonstrate the operation of the circuit on the prototyping board

Grading will be based on:
A. Correctness of the design [40 pts]
B. Coding style quality [20 pts]
C. Effectiveness of testing [30 pts]
D. Quality of the report [20 pts]

## Crystalfontz America, Inc.

| CUSTOMER |  |  |
| :---: | :--- | :--- |
| MODEL | CFAH1602B-TMC-JP |  |
| APPROVAL | BY: | DATA: |


| SALES BY | APPROVED BY | CHECKED BY | PREPARED BY |
| :---: | :---: | :---: | :---: |
|  |  |  |  |
|  |  |  |  |
|  |  |  |  |

## Crystalfontz America, Inc.

15611 East Washington Road
Valleyford, WA 99036-9747
Phone: (509) 291-3514
Fax: (509) 291-3345
e-mail: sales@crystalfontz.com
http://www.crystalfontz.com

## Contents

1.Module Classification Information
2.Precautions in use of LCD Modules
3.General Specification
4.Absolute Maximum Ratings
5.Electrical Characteristics
6.Optical Characteristics
7.Interface Pin Function
8.Counter drawing
9.Backlight Information
10.Function Description
11.Character Generator ROM Pattern
12.Instruction Table
13.Timing Characteristics
14.Initializing of LCM
15.Quality Assurance
16.Reliability

## 1.Module Classification Information

| CFA H | 1602 | $\underline{B}-\underline{T} \underline{M} \underline{C}-$ | JP |
| :---: | :---: | :---: | :---: |
| (1) (2) | (3) | (4) (5) (6) (7) | (8) |


| (1) | Brand: CRYSTALFONTZ AMERICA, INCORPORATED |  |  |
| :---: | :---: | :---: | :---: |
| (2) | Display Type: $\mathbf{H} \rightarrow$ Character Type, G $\rightarrow$ Graphic Type |  |  |
| (3) | Display's logical dimensions: $\mathbf{1 6}$ columns by $\mathbf{0 2}$ lines |  |  |
| (4) | Model serials no. |  |  |
| (5) | Backlight Type: | $\mathrm{N} \rightarrow$ Without backlight $\mathrm{B} \rightarrow$ EL, Blue green $\mathrm{D} \rightarrow$ EL, Green $\mathrm{W} \rightarrow$ EL, White $\mathrm{F} \rightarrow$ CCFL, White T $\rightarrow$ LED, White | $\begin{aligned} & \mathrm{Y} \rightarrow \text { LED, Yellow Green } \\ & \mathrm{A} \rightarrow \text { LED, Amber } \\ & \mathrm{R} \rightarrow \text { LED, Red } \\ & \mathrm{O} \rightarrow \text { LED, Orange } \\ & \mathrm{G} \rightarrow \text { LED, Green } \end{aligned}$ |
| (6) | LCD Mode: | $\begin{aligned} & \mathrm{B} \rightarrow \text { TN Positive, Gray } \\ & \mathrm{N} \rightarrow \text { TN Negative, } \\ & \mathrm{G} \rightarrow \text { STN Positive, Gray } \\ & \mathrm{Y} \rightarrow \text { STN Positive, Yellow Green } \end{aligned}$ | $\begin{aligned} & \mathrm{M} \rightarrow \text { STN Negative, Blue } \\ & \mathrm{F} \rightarrow \text { FSTN Positive } \\ & \mathrm{T} \rightarrow \text { FSTN Negative } \end{aligned}$ |
| (7) | LCD Polarizer Type, Temperature range, Viewing direction: | $\mathrm{A} \rightarrow$ Reflective, N.T, 6:00 $\mathrm{D} \rightarrow$ Reflective, N.T, 12:00 $\mathrm{G} \rightarrow$ Reflective, W. T, 6:00 $\mathrm{J} \rightarrow$ Reflective, W. T, 12:00 $\mathrm{B} \rightarrow$ Transflective, N.T,6:00 $\mathrm{E} \rightarrow$ Transflective, N.T.12:00 | $\mathrm{H} \rightarrow$ Transflective, W.T,6:00 $\mathrm{K} \rightarrow$ Transflective, W.T,12:00 $\mathrm{C} \rightarrow$ Transmissive, N.T,6:00 $\mathrm{F} \rightarrow$ Transmissive, N.T,12:00 $\mathrm{I} \rightarrow$ Transmissive, W. T, 6:00 $\mathrm{L} \rightarrow$ Transmissive, W.T,12:00 |
| (8) | Special Code: | $\mathrm{JP} \rightarrow$ English and Japanese stan | d font |

## 2.Precautions in use of LCD Modules

(1) Avoid applying excessive shocks to the module or making any alterations or modifications to it.
(2) Don't make extra holes on the printed circuit board, modify its shape or change the components of LCD module.
(3) Don't disassemble the LCM.
(4) Don't operate it above the absolute maximum rating.
(5) Don't drop, bend or twist LCM.
(6) Soldering:only to the I/O terminals.
(7) Storage:please storage in anti-static electricity container and clean environment.

## 3.General Specification

| ITEM | STANDARD VALUE | UNIT |  |
| :--- | :---: | :---: | :---: |
| Number of Characters: | 16 characters $\times 2$ Lines |  |  |
| Module dimension: | $80.0 \times 36.0 \times 13.5(\mathrm{MAX}) \mathrm{mm}$ | mm |  |
| View area: | $66.0 \times 16.0 \mathrm{~mm}$ | mm |  |
| Active area: | $56.2 \times 11.5 \mathrm{~mm}$ | mm |  |
| Character size: | $(\mathrm{L}) 2.95 \times(\mathrm{W}) 5.55 \mathrm{~mm}$ | mm |  |
| Character pitch: | $(\mathrm{L}) 3.55 \times(\mathrm{W}) 5.95 \mathrm{~mm}$ | mm |  |
| LCD type: | STN, Negative ,transmissive, Blue |  |  |
| Duty: | $1 / 16$ |  |  |
| View direction: | 6 o'clock |  |  |
| Backlight: | LED White |  |  |

## 4.Absolute Maximum Ratings

| ITEM | SYMBOL | MIN. | TYP. | MAX. | UNIT |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Operating Temperature | $\mathrm{T}_{\mathrm{OP}}$ | 0 | - | +50 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\mathrm{ST}}$ | -10 | - | +60 | ${ }^{\circ} \mathrm{C}$ |
| Input Voltage | $\mathrm{V}_{\mathrm{I}}$ | $\mathrm{V}_{\mathrm{SS}}$ | - | $\mathrm{V}_{\mathrm{DD}}$ | V |
| Supply Voltage For Logic | $\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{SS}}$ | -0.3 | - | 7 | V |
| Supply Voltage For LCD | $\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{0}$ | -0.3 | - | $\mathrm{Vdd}+0.3$ | V |
| Supply current FOR LED B/L | ILED | - | - | 25 | mA |

## 5.Electrical Characteristics

| ITEM | SYMBOL | CONDITION | MIN. | TYP. | MAX. | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage For Logic | $\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\text {SS }}$ | - | 4.5 | - | 5.5 | V |
| Supply Voltage For LCD | $\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{0}$ | $\mathrm{Ta}=0^{\circ} \mathrm{C}$ | - | 4.2 | 4.5 | V |
|  |  | $\mathrm{Ta}=25^{\circ} \mathrm{C}$ | - |  | - | V |
|  |  | $\mathrm{Ta}=50^{\circ} \mathrm{C}$ | 3.8 |  | - | V |
| Input High Vol | $\mathrm{V}_{\mathrm{IH}}$ | - | 2.2 | - | $\mathrm{V}_{\text {DD }}$ | V |
| Input Low Vol | $\mathrm{V}_{\text {IL }}$ | - | - | - | 0.6 | V |
| Output High Vol | $\mathrm{V}_{\mathrm{OH}}$ | - | 2.4 | - | - | V |
| Output Low Vol. | $\mathrm{V}_{\text {OL }}$ | - | - | - | 0.4 | V |
| Supply Current | $\mathrm{I}_{\mathrm{DD}}$ | $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ | - | 1.2 | - | mA |

## 6.Optical Characteristics

| ITEM | SYMBAL | CONDITION | MIN. | TYP. | MAX. | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| View Angle | (V) $\theta$ | $\mathrm{CR} \geqq 3$ | 10 |  | 105 | deg |
|  | (H) $\varphi$ | $\mathrm{CR} \geqq 3$ | -30 |  | 30 | deg |
|  | CR | - |  | 5 |  | - |
| Response Time | T rise | - |  | 200 | 300 | ms |
|  | T fall | - |  | 200 | 300 | ms |

### 6.1 Definitions


(Best visual angle direction)

## Contrast Ratio

$$
\mathrm{CR}=\frac{\text { Brightness at selected state }(\mathrm{BS})}{\text { Brightness at non-selected state }(\mathrm{Bns})}
$$



Operating voltage for LCD driving

Response Time


## 7.Interface Pin Function

| Pin No. | Symbol | Level | Description |
| :---: | :---: | :---: | :---: |
| 1 | $\mathrm{V}_{\text {SS }}$ | 0V | Ground |
| 2 | $\mathrm{V}_{\mathrm{DD}}$ | 5.0 V | Supply Voltage for logic |
| 3 | VO | (Variable) | Operating voltage for LCD |
| 4 | RS | H/L | H:DATA, L:Instruction code |
| 5 | R/W | H/L | $\mathrm{H}:$ Read(MPU $\rightarrow$ Module)L:Write(MPU $\rightarrow$ Module) |
| 6 | E | $\mathrm{H}, \mathrm{H} \rightarrow \mathrm{L}$ | Chip enable signal |
| 7 | DB0 | H/L | Data bit 0 |
| 8 | DB1 | H/L | Data bit 1 |
| 9 | DB2 | H/L | Data bit 2 |
| 10 | DB3 | H/L | Data bit 3 |
| 11 | DB4 | H/L | Data bit 4 |
| 12 | DB5 | H/L | Data bit 5 |
| 13 | DB6 | H/L | Data bit 6 |
| 14 | DB7 | H/L | Data bit 7 |
| 15 | A | - | Power supply for LED backlight ( + ) |
| 16 | K | - | Power supply for LED backlight ( - ) |

http://www.crystalfontz.com email: sales@crystalfontz.com

## 8.Counter drawing



| PINNO. | SYMBOL |
| :---: | :---: |
| 1 | Vss |
| 2 | Vdd |
| 3 | Vo |
| 4 | RS |
| 5 | R/ $\overline{\mathrm{W}}$ |
| 6 | E |
| 7 | DB0 |
| 8 | DB1 |
| 9 | DB2 |
| 10 | DB3 |
| 11 | DB4 |
| 12 | DB5 |
| 13 | DB6 |
| 14 | DB7 |
| 15 | A/Vee |
| 16 | K |

LED B/L Drive Method

1.Drive from A,K

(Will never get Vee output from pin15)
3.Drive from Vdd,Vss

(Contrast performance may go down.)
Recommanded Value
$\mathrm{V}_{\text {LED }}=3.3 \mathrm{~V}, \mathrm{I}_{\text {LED }}=25 \mathrm{~mA}$

Character located $\begin{array}{lllllllllllllllll}1 & 2 & 3 & 4 & 5 & 6 & 7 & 8 & 9 & 10 & 11 & 12 & 13 & 14 & 15 & 16\end{array}$
 DDRAM address 40414243444546474849 4A 4B 4C 4D 4E 4F

## 9. Backlight Information

### 9.1 Specification

| PARAMETER | SYMBOL | MIN | TYP | MAX | UNIT | TEST CONDITION |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Supply Current | ILED | - | 25 |  | mA | V=3.3V |
| Supply Voltage | V | - | 3.3 | 3.6 | V |  |
| Reverse Voltage | VR | - | - | 8 | V |  |
| Luminous Intensity | IV | 20 | - | - | $\mathrm{CD} / \mathrm{M}^{2}$ | ILED=25mA |
| Wave Length | $\lambda \mathrm{p}$ |  |  |  | nm | ILED=25mA |
| Life Time |  | - | 100000 | - | Hr | $\mathrm{V} \leqq 3.6 \mathrm{~V}$ |
| Color |  |  |  |  |  |  |

## 10.Function Description

The LCD display Module is built in a LSI controller, the controller has two 8-bit registers, an instruction register (IR) and a data register (DR).

The IR stores instruction codes, such as display clear and cursor shift, and address information for display data RAM (DDRAM) and character generator (CGRAM). The IR can only be written from the MPU. The DR temporarily stores data to be written or read from DDRAM or CGRAM. When address information is written into the $\mathbb{R}$, then data is stored into the DR from DDRAM or CGRAM. By the register selector (RS) signal, these two registers can be selected.

| RS | R/W | Operation |
| :---: | :---: | :--- |
| 0 | 0 | IR write as an internal operation (display clear, etc.) |
| 0 | 1 | Read busy flag (DB7) and address counter (DB0 to DB7) |
| 1 | 0 | Write data to DDRAM or CGRAM (DR to DDRAM or CGRAM) |
| 1 | 1 | Read data from DDRAM or CGRAM (DDRAM or CGRAM to DR) |

## Busy Flag (BF)

When the busy flag is 1 , the controller LSI is in the internal operation mode, and the next instruction will not be accepted. When $\mathrm{RS}=0$ and $\mathrm{R} / \mathrm{W}=1$, the busy flag is output to DB 7 . The next instruction must be written after ensuring that the busy flag is 0 .

## Address Counter (AC)

The address counter (AC) assigns addresses to both DDRAM and CGRAM

## Display Data RAM (DDRAM)

This DDRAM is used to store the display data represented in 8-bit character codes. Its extended capacity is $80 \times 8$ bits or 80 characters. Below figure is the relationships between DDRAM addresses and positions on the liquid crystal display.

High bits Low bits


Example:DDRAM addresses 4E

| 1 | 0 | 0 | 1 | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |

## DDRAM Address

Display position DDRAM address

| 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 0A | 0B | 0C | 0D | 0E | 0F |
| 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 4A | 4B | 4C | 4D | 4E | 4F |

2-Line by 16-Character Display

## Character Generator ROM (CGROM)

The CGROM generate $5 \times 8$ dot or $5 \times 10$ dot character patterns from 8 -bit character codes. See Table 2 .

## Character Generator RAM (CGRAM)

In CGRAM, the user can rewrite character by program. For $5 \times 8$ dots, eight character patterns can be written, and for $5 \times 10$ dots, four character patterns can be written.

Write into DDRAM the character code at the addresses shown as the left column of table 1 . To show the character patterns stored in CGRAM.

Phone: (509) 291-3514
Fax: (509) 291-3345
http://www.crystalfontz.com
email: sales@crystalfontz.com

## Relationship between CGRAM Addresses, Character Codes (DDRAM) and Character Patterns (CGRAM Data)

## Table 1.

For 5 * 8 dot character patterns

| Character Codes <br> (DDRAM data) | CGRAM Address | Character Patterns (CGRAM data) |  |
| :---: | :---: | :---: | :---: |
| $\begin{array}{llllllllll} 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\ & H \text { High } & & & \text { Low } \end{array}$ | 5 4 3 2 1 0 <br> High   Low   | $\begin{array}{cccccccc} \begin{array}{llllll} 7 & 6 & 5 & 4 & 3 & 2 \end{array} & 1 & 0 \\ & \text { High } & & \text { Low } \end{array}$ |  |
| $\begin{array}{llllllll} 0 & 0 & 0 & 0 & * & 0 & 0 & 0 \end{array}$ |  | $\begin{array}{lll\|lllll} * & * & * & & & & 0 \\ * & * & * & & 0 & 0 & 0 & \\ * & * & * & & 0 & 0 & 0 & \\ * & * & * & & & & 0 \\ * & * & * & & 0 & & 0 & 0 \\ * & * & * & & 0 & 0 & & 0 \\ * & * & * & & 0 & 0 & 0 & \\ * & * & * & 0 & 0 & 0 & 0 & 0 \\ * & * & * & & 0 & 0 & 0 & \\ * & * & * & 0 & & 0 & & 0 \\ * & * & * & & & & \\ * & * & * & 0 & 0 & & 0 & 0 \\ * & * & * & & & & & \\ * & * & * & 0 & 0 & & 0 & 0 \\ * & * & * & 0 & 0 & & 0 & 0 \\ * & * & * & 0 & 0 & 0 & 0 & 0 \\ \hline \end{array}$ | Character pattern (1) <br> Cursor pattern <br> Character pattern(2) <br> Cursor pattern |
|  | $\begin{array}{lll}0 & 0 & 0 \\ 0 & 0 & 1\end{array}$ | * ** |  |
|  | 1 1 1 1 0 0  <br>        <br> 1 0 1     <br> 1 1 0     <br>     1 1 1 | * ** |  |

For 5 * 10 dot character patterns

| Character Codes <br> ( DDRAM data) | CGRAM Address | Character Patterns (CGRAM data) |
| :---: | :---: | :---: |
| $\begin{array}{\|ccccccc} \hline 7 & 6 & 5 & 4 & 3 & 2 & 1 \end{array} 0$ | 5 4 3 2 1 0 <br> High   Low   | $\begin{array}{lllllllll} \hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\ & \\ & \text { High } \end{array}$ |
| $\begin{array}{llllllll}0 & 0 & 0 & 0 & * & 0 & 0 & 0\end{array}$ |  | $\begin{array}{lll\|lllll} * & * & * & 0 & 0 & 0 & 0 & 0 \\ * & * & * & 0 & 0 & 0 & 0 & 0 \\ * & * & * & & 0 & & & 0 \\ * & * & * & & & 0 & 0 & \\ * & * & * & & 0 & 0 & 0 & \\ * & * & * & & 0 & 0 & 0 & \\ * & * & * & & & & \\ * & * & * & & 0 & 0 & 0 & 0 \\ * & * & * & & 0 & 0 & 0 & 0 \\ * & * & * & & 0 & 0 & 0 & 0 \\ * & * & * & 0 & 0 & 0 & 0 & 0 \end{array}$ |
|  |  |  |
|  | $\begin{array}{llll}1 & 1 & 1\end{array}$ | * * * * * * * |

Character pattern

Cursor pattern

## 11. Character Generator ROM Pattern

Table. 2

|  | LLLL | LLLH | LLHL | LLHH | LHLL | LhLH | LHHL | LHнн | HLLL | HLLH | HLHL | HLHH | HhLL | HHLH | нннL | нннн |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LLLL | $\begin{aligned} & \text { CG } \\ & \text { RAM } \\ & (1) \end{aligned}$ |  |  |  |  | :": |  |  |  |  |  | -.. |  |  | : | -": |
| LLLH | (2) |  |  |  |  |  |  | ": |  |  | : $:$ |  | $: \because$ |  |  | : |
| LLHL | (3) |  | : : |  |  |  |  |  |  |  |  |  | : : | : |  | : |
| LLHH | (4) |  | : |  |  | - : |  |  |  |  | .. |  |  |  |  | ::-: |
| LHLL | (5) |  |  |  |  |  |  |  |  |  | $\cdots$ |  |  |  | : | :-: |
| LHLH | (6) |  |  | :".: | -. | : |  | : |  |  | : |  |  |  | : : : | - |
| LHHL | (7) |  |  | :" | :"- |  |  |  |  |  | -.." |  | --. | -...: | $:$ | .- |
| LHHH | (8) |  | : |  |  | : |  |  |  |  | -"." | : :-: | ":-: |  |  | ":" |
| HLLL | (1) |  | :" |  |  | $:=$ |  |  |  |  | - ': $^{\prime}$ | : | ..: |  | . ${ }^{-\cdots}$ | :-:-: |
| HLLH | (2) |  |  |  |  |  |  | :...: |  |  | :-': |  |  |  | -.: | : |
| HLHL | (3) |  | : : : : | $\begin{aligned} & \text { :: } \\ & \text { :: } \end{aligned}$ | ": |  |  |  |  |  | ":-... |  |  |  | - | : $:=$ |
| HLHH | (4) |  | ..:-. | :: | : |  |  |  |  |  |  | ! | :- |  |  | ": |
| HHLL | (5) |  | : |  | $\vdots$ |  | - | ! |  |  | : |  |  |  | : | : |
| HHLH | (6) |  | .- |  | : |  |  |  |  |  | --: |  |  |  |  | .:.. |
| HHHL | (7) |  | : |  |  |  |  | $\because$ |  |  | :.: | -: | --: |  |  |  |
| нннн | (8) |  | ..$^{-}$ |  | "... |  |  |  |  |  | : : : |  |  |  | : $:$ |  |

## 12. Instruction Table

| Instruction | Instruction Code |  |  |  |  |  |  |  |  |  | Description | Execution time (fosc=270Khz) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 |  |  |
| Clear Display | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | Write " 00 H " to DDRAM and set DDRAM address to " 00 H " from AC | 1.53 ms |
| Return Home | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | - | Set DDRAM address to "00H" from AC and return cursor to its original position if shifted. The contents of DDRAM are not changed. | 1.53 ms |
| Entry Mode Set | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | I/D | SH | Assign cursor moving direction and enable the shift of entire display. | $39 \mu \mathrm{~s}$ |
| Display ON/OFF Control | 0 | 0 | 0 | 0 | 0 | 0 | 1 | D | C | B | Set display (D), cursor (C ), and blinking of cursor (B) on/off control bit. | $39 \mu \mathrm{~s}$ |
| Cursor or Display Shift | 0 | 0 | 0 | 0 | 0 | 1 | S/C | R/L | - | - | Set cursor moving and display shift control bit, and the direction, without changing of DDRAM data. | $39 \mu \mathrm{~s}$ |
| Function Set | 0 | 0 | 0 | 0 | 1 | DL | N | F | - | - | Set interface data length (DL:8-bit/4-bit), numbers of display line ( $\mathrm{N}: 2$-line/1-line) and, display font type (F: $5 \times$ 11 dots $/ 5 \times 8$ dots) | $39 \mu \mathrm{~s}$ |
| Set CGRAM Address | 0 | 0 | 0 | 1 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 | Set CGRAM address in address counter. | $39 \mu \mathrm{~s}$ |
| Set DDRAM Address | 0 | 0 | 1 | AC6 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 | Set DDRAM address in address counter. | $39 \mu \mathrm{~s}$ |
| Read Busy Flag and Address | 0 | 1 | BF | AC6 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 | Whether during internal operation or not can be known by reading BF. The contents of address counter can also be read. | $0 \mu \mathrm{~s}$ |
| Write Data to RAM | 1 | 0 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Write data into internal RAM <br> (DDRAM/CGRAM). | $43 \mu \mathrm{~s}$ |
| Read Data from RAM | 1 | 1 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Read data from internal RAM <br> (DDRAM/CGRAM). | $43 \mu \mathrm{~s}$ |

## 13. Timing Characteristics

### 13.1 Write Operation



| Item | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Enable cycle time | $\mathrm{t}_{\mathrm{cycE}}$ | 500 | - | - | ns |
| Enable pulse width (high level) | $\mathrm{PW}_{\mathrm{EH}}$ | 230 | - | - | ns |
| Enable rise/fall time | $\mathrm{t}_{\mathrm{Er}, \mathrm{t} \mathrm{tef}}$ | - | - | 20 | ns |
| Address set-up time (RS, R/W to E) | $\mathrm{t}_{\mathrm{AS}}$ | 40 | - | - | ns |
| Address hold time | $\mathrm{t}_{\mathrm{AH}}$ | 10 | - | - | ns |
| Data set-up time | $\mathrm{t}_{\mathrm{DSW}}$ | 80 | - | - | ns |
| Data hold time | $\mathrm{t}_{\mathrm{H}}$ | 10 | - | - | ns |

### 13.2 Read Operation



NOTE: *VOL1 is assumed to be 0.8 V at 2 MHZ operation.

| ITEM | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Enable cycle time | $\mathrm{t}_{\mathrm{cycE}}$ | 500 | - | - | ns |
| Enable pulse width (high level) | $\mathrm{PW}_{\mathrm{EH}}$ | 230 | - | - | ns |
| Enable rise/fall time | $\mathrm{t}_{\mathrm{Er}}, \mathrm{t}_{\mathrm{Ef}}$ | - | - | 20 | ns |
| Address set-up time (RS, R/W to E) | $\mathrm{t}_{\mathrm{AS}}$ | 40 | - | - | ns |
| Address hold time | $\mathrm{t}_{\mathrm{AH}}$ | 10 | - | - | ns |
| Data delay time | $\mathrm{t}_{\mathrm{DDR}}$ | - | - | 160 | ns |
| Data hold time | $\mathrm{t}_{\mathrm{DHR}}$ | 5 | - | - | ns |

## 14. Initializing of LCM




4-Bit Ineterface

## 15. Quality Assurance

## Screen Cosmetic Criteria

| No. | Defect | Judgement Criterion | Partition |
| :---: | :---: | :---: | :---: |
| 1 | Spots | A)Clear <br> Note:Including pin holes and defective dots which must be within one pixel size. <br> B)Unclear | Minor |
| 2 | Bubbles in Polarizer | Size: d mm Acceptable Qty in active area <br> $\mathrm{d} \leqq 0.3$ Disregard <br> $0.3<\mathrm{d} \leqq 1.0$ 3 <br> $1.0<\mathrm{d} \leqq 1.5$ 1 <br> $1.5<\mathrm{d}$ 0 | Minor |
| 3 | Scratch | In accordance with spots cosmetic criteria. When the light reflects on the panel surface, the scratches are not to be remarkable. | Minor |
| 4 | Allowable Density | Above defects should be separated more than 30 mm each other. | Minor |
| 5 | Coloration | Not to be noticeable coloration in the viewing area of the LCD panels. <br> Back-light type should be judged with back-light on state only. | Minor |

Fax: (509) 291-3345

## 16. RELIABILITY

## Content of Reliability Test



[^0]
# HD44780U (LCD-II) <br> (Dot Matrix Liquid Crystal Display Controller/Driver) HITACHI 

## Description

The HD44780U dot-matrix liquid crystal display controller and driver LSI displays alphanumerics, Japanese kana characters, and symbols. It can be configured to drive a dot-matrix liquid crystal display under the control of a 4- or 8-bit microprocessor. Since all the functions such as display RAM, character generator, and liquid crystal driver, required for driving a dot-matrix liquid crystal display are internally provided on one chip, a minimal system can be interfaced with this controller/driver.

A single HD44780U can display up to one 8-character line or two 8-character lines.
The HD44780U has pin function compatibility with the HD44780S which allows the user to easily replace an LCD-II with an HD44780U. The HD44780U character generator ROM is extended to generate $2085 \times 8$ dot character fonts and $325 \times 10$ dot character fonts for a total of 240 different character fonts.

The low power supply $(2.7 \mathrm{~V}$ to 5.5 V$)$ of the HD 44780 U is suitable for any portable battery-driven product requiring low power dissipation.

## Features

- $5 \times 8$ and $5 \times 10$ dot matrix possible
- Low power operation support:
-2.7 to 5.5 V
- Wide range of liquid crystal display driver power
-3.0 to 11 V
- Liquid crystal drive waveform
- A (One line frequency AC waveform)
- Correspond to high speed MPU bus interface
-2 MHz (when $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ )
- 4-bit or 8-bit MPU interface enabled
- $80 \times 8$-bit display RAM ( 80 characters max.)
- 9,920-bit character generator ROM for a total of 240 character fonts
- 208 character fonts $(5 \times 8$ dot)
- 32 character fonts ( $5 \times 10$ dot)


## HD44780U

- $64 \times 8$-bit character generator RAM
-8 character fonts ( $5 \times 8$ dot)
- 4 character fonts $(5 \times 10$ dot $)$
- 16 -common $\times 40$-segment liquid crystal display driver
- Programmable duty cycles
- $1 / 8$ for one line of $5 \times 8$ dots with cursor
- $1 / 11$ for one line of $5 \times 10$ dots with cursor
- $1 / 16$ for two lines of $5 \times 8$ dots with cursor
- Wide range of instruction functions:
- Display clear, cursor home, display on/off, cursor on/off, display character blink, cursor shift, display shift
- Pin function compatibility with HD44780S
- Automatic reset circuit that initializes the controller/driver after power on
- Internal oscillator with external resistors
- Low power consumption


## Ordering Information

| Type No. | Package | CGROM |
| :--- | :--- | :--- |
| HD44780UA00FS | FP-80B | Japanese standard font |
| HCD44780UA00 | Chip |  |
| HD44780UA00TF | TFP-80F |  |
| HD44780UA02FS | FP-80B | European standard font |
| HCD44780UA02 | Chip |  |
| HD44780UA02TF | TFP-80F |  |
| HD44780UBxxFS | FP-80B | Custom font |
| HCD44780UBxx | Chip |  |
| HD44780UBxxTF | TFP-80F |  |

Note: xx: ROM code No.

## HD44780U Block Diagram



## HD44780U

## LCD-II Family Comparison

| Item |  | HD44780S | HD44780U |
| :---: | :---: | :---: | :---: |
| Power supply voltage |  | $5 \mathrm{~V} \pm 10 \%$ | 2.7 to 5.5 V |
| Liquid crystal drive voltage VLCD | 1/4 bias | 3.0 to 11.0 V | 3.0 to 11.0 V |
|  | 1/5 bias | 4.6 to 11.0 V | 3.0 to 11.0 V |
| Maximum display digits per chip |  | 16 digits ( 8 digits $\times 2$ lines) | 16 digits ( 8 digits $\times 2$ lines) |
| Display duty cycle |  | 1/8, 1/11, and 1/16 | 1/8, 1/11, and 1/16 |
| CGROM |  | 7,200 bits <br> (160 character fonts for $5 \times$ 7 dot and 32 character fonts for $5 \times 10$ dot) | 9,920 bits <br> (208 character fonts for $5 \times$ 8 dot and 32 character fonts for $5 \times 10$ dot) |
| CGRAM |  | 64 bytes | 64 bytes |
| DDRAM |  | 80 bytes | 80 bytes |
| Segment signals |  | 40 | 40 |
| Common signals |  | 16 | 16 |
| Liquid crystal drive waveform |  | A | A |
| Oscillator | Clock source | External resistor, external ceramic filter, or external clock | External resistor or external clock |
|  | $\mathrm{R}_{\mathrm{t}}$ oscillation frequency (frame frequency) | $270 \mathrm{kHz} \pm 30 \%$ <br> (59 to 110 Hz for $1 / 8$ and 1/16 duty cycles; 43 to 80 Hz for $1 / 11$ duty cycle) | $270 \mathrm{kHz} \pm 30 \%$ <br> (59 to 110 Hz for $1 / 8$ <br> and1/16 duty cycles; 43 to <br> 80 Hz for $1 / 11$ duty cycle) |
|  | $\mathrm{R}_{\mathrm{t}}$ resistance | $91 \mathrm{k} \Omega \pm 2 \%$ | $\begin{aligned} & 91 \mathrm{k} \Omega \pm 2 \% \text { (when } \mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \text { ) } \\ & 75 \mathrm{k} \Omega \pm 2 \% \text { (when } \mathrm{V}_{\mathrm{cc}}=3 \mathrm{~V} \text { ) } \end{aligned}$ |
| Instructions |  | Fully compatible within the HD | D44780S |
| CPU bus timing |  | 1 MHz | $\begin{aligned} & 1 \mathrm{MHz}\left(\text { when } \mathrm{V}_{\mathrm{cc}}=3 \mathrm{~V}\right) \\ & 2 \mathrm{MHz} \text { (when } \mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \text { ) } \end{aligned}$ |
| Package |  | $\begin{aligned} & \hline \text { FP-80 } \\ & \text { FP-80A } \end{aligned}$ | $\begin{aligned} & \hline \text { FP-80B } \\ & \text { TFP-80F } \end{aligned}$ |

## HD44780U Pin Arrangement (FP-80B)



## HD44780U

## HD44780U Pin Arrangement (TFP-80F)



## HD44780U Pad Arrangement



## HD44780U

## HCD44780U Pad Location Coordinates

Coordinate

| Pad No. | Function | X (um) | Y (um) |
| :---: | :---: | :---: | :---: |
| 1 | SEG22 | -2100 | 2313 |
| 2 | SEG21 | -2280 | 2313 |
| 3 | SEG20 | -2313 | 2089 |
| 4 | SEG19 | -2313 | 1833 |
| 5 | SEG18 | -2313 | 1617 |
| 6 | SEG17 | -2313 | 1401 |
| 7 | SEG16 | -2313 | 1186 |
| 8 | SEG15 | -2313 | 970 |
| 9 | SEG14 | -2313 | 755 |
| 10 | SEG13 | -2313 | 539 |
| 11 | SEG12 | -2313 | 323 |
| 12 | SEG11 | -2313 | 108 |
| 13 | SEG10 | -2313 | -108 |
| 14 | SEG9 | -2313 | -323 |
| 15 | SEG8 | -2313 | -539 |
| 16 | SEG7 | -2313 | -755 |
| 17 | SEG6 | -2313 | -970 |
| 18 | SEG5 | -2313 | -1186 |
| 19 | SEG4 | -2313 | -1401 |
| 20 | SEG3 | -2313 | -1617 |
| 21 | SEG2 | -2313 | -1833 |
| 22 | SEG1 | -2313 | -2073 |
| 23 | GND | -2280 | -2290 |
| 24 | OSC1 | -2080 | -2290 |
| 25 | OSC2 | -1749 | -2290 |
| 26 | V1 | -1550 | -2290 |
| 27 | V2 | -1268 | -2290 |
| 28 | V3 | -941 | -2290 |
| 29 | V4 | -623 | -2290 |
| 30 | V5 | -304 | -2290 |
| 31 | CL1 | -48 | -2290 |
| 32 | CL2 | 142 | -2290 |
| 33 | $\mathrm{V}_{\text {cc }}$ | 309 | -2290 |
| 34 | M | 475 | -2290 |
| 35 | D | 665 | -2290 |
| 36 | RS | 832 | -2290 |
| 37 | $\mathrm{R} / \overline{\mathrm{W}}$ | 1022 | -2290 |
| 38 | E | 1204 | -2290 |
| 39 | DB0 | 1454 | -2290 |
| 40 | DB1 | 1684 | -2290 |

Coordinate

| Pad No. | Function | X (um) | Y (um) |
| :---: | :---: | :---: | :---: |
| 41 | DB2 | 2070 | -2290 |
| 42 | DB3 | 2260 | -2290 |
| 43 | DB4 | 2290 | -2099 |
| 44 | DB5 | 2290 | -1883 |
| 45 | DB6 | 2290 | -1667 |
| 46 | DB7 | 2290 | -1452 |
| 47 | COM1 | 2313 | -1186 |
| 48 | COM2 | 2313 | -970 |
| 49 | COM3 | 2313 | -755 |
| 50 | COM4 | 2313 | -539 |
| 51 | COM5 | 2313 | -323 |
| 52 | COM6 | 2313 | -108 |
| 53 | COM7 | 2313 | 108 |
| 54 | COM8 | 2313 | 323 |
| 55 | COM9 | 2313 | 539 |
| 56 | COM10 | 2313 | 755 |
| 57 | COM11 | 2313 | 970 |
| 58 | COM12 | 2313 | 1186 |
| 59 | COM13 | 2313 | 1401 |
| 60 | COM14 | 2313 | 1617 |
| 61 | COM15 | 2313 | 1833 |
| 62 | COM16 | 2313 | 2095 |
| 63 | SEG40 | 2296 | 2313 |
| 64 | SEG39 | 2100 | 2313 |
| 65 | SEG38 | 1617 | 2313 |
| 66 | SEG37 | 1401 | 2313 |
| 67 | SEG36 | 1186 | 2313 |
| 68 | SEG35 | 970 | 2313 |
| 69 | SEG34 | 755 | 2313 |
| 70 | SEG33 | 539 | 2313 |
| 71 | SEG32 | 323 | 2313 |
| 72 | SEG31 | 108 | 2313 |
| 73 | SEG30 | -108 | 2313 |
| 74 | SEG29 | -323 | 2313 |
| 75 | SEG28 | -539 | 2313 |
| 76 | SEG27 | -755 | 2313 |
| 77 | SEG26 | -970 | 2313 |
| 78 | SEG25 | -1186 | 2313 |
| 79 | SEG24 | -1401 | 2313 |
| 80 | SEG23 | -1617 | 2313 |

Pin Functions

| Signal | No. of Lines | 1/0 | Device Interfaced with | Function |
| :---: | :---: | :---: | :---: | :---: |
| RS | 1 | I | MPU | Selects registers. <br> 0: Instruction register (for write) Busy flag: address counter (for read) <br> 1: Data register (for write and read) |
| $\overline{R / \bar{W}}$ | 1 | I | MPU | Selects read or write. <br> 0: Write <br> 1: Read |
| E | 1 | I | MPU | Starts data read/write. |
| DB4 to DB7 | 4 | I/O | MPU | Four high order bidirectional tristate data bus pins. Used for data transfer and receive between the MPU and the HD44780U. DB7 can be used as a busy flag. |
| DB0 to DB3 | 4 | I/O | MPU | Four low order bidirectional tristate data bus pins. Used for data transfer and receive between the MPU and the HD44780U. These pins are not used during 4-bit operation. |
| CL1 | 1 | O | Extension driver | Clock to latch serial data $D$ sent to the extension driver |
| CL2 | 1 | 0 | Extension driver | Clock to shift serial data D |
| M | 1 | O | Extension driver | Switch signal for converting the liquid crystal drive waveform to AC |
| D | 1 | O | Extension driver | Character pattern data corresponding to each segment signal |
| COM1 to COM16 | 16 | 0 | LCD | Common signals that are not used are changed to non-selection waveforms. COM9 to COM16 are non-selection waveforms at $1 / 8$ duty factor and COM12 to COM16 are non-selection waveforms at $1 / 11$ duty factor. |
| SEG1 to SEG40 | 40 | 0 | LCD | Segment signals |
| V1 to V5 | 5 | - | Power supply | Power supply for LCD drive $\mathrm{V}_{\mathrm{cc}}-\mathrm{V} 5=11 \mathrm{~V}$ (max) |
| $\mathrm{V}_{\mathrm{cc}}$, GND | 2 | - | Power supply | $\mathrm{V}_{\text {cc }}$ : 2.7 V to 5.5V, GND: 0 V |
| OSC1, OSC2 | 2 | - | Oscillation resistor clock | When crystal oscillation is performed, a resistor must be connected externally. When the pin input is an external clock, it must be input to OSC1. |

## HD44780U

## Function Description

## Registers

The HD44780U has two 8-bit registers, an instruction register (IR) and a data register (DR).
The IR stores instruction codes, such as display clear and cursor shift, and address information for display data RAM (DDRAM) and character generator RAM (CGRAM). The IR can only be written from the MPU.

The DR temporarily stores data to be written into DDRAM or CGRAM and temporarily stores data to be read from DDRAM or CGRAM. Data written into the DR from the MPU is automatically written into DDRAM or CGRAM by an internal operation. The DR is also used for data storage when reading data from DDRAM or CGRAM. When address information is written into the IR, data is read and then stored into the DR from DDRAM or CGRAM by an internal operation. Data transfer between the MPU is then completed when the MPU reads the DR. After the read, data in DDRAM or CGRAM at the next address is sent to the DR for the next read from the MPU. By the register selector (RS) signal, these two registers can be selected (Table 1).

## Busy Flag (BF)

When the busy flag is 1 , the HD44780U is in the internal operation mode, and the next instruction will not be accepted. When $\mathrm{RS}=0$ and $\mathrm{R} / \overline{\mathrm{W}}=1$ (Table 1 ), the busy flag is output to DB7. The next instruction must be written after ensuring that the busy flag is 0 .

## Address Counter (AC)

The address counter (AC) assigns addresses to both DDRAM and CGRAM. When an address of an instruction is written into the IR, the address information is sent from the IR to the AC. Selection of either DDRAM or CGRAM is also determined concurrently by the instruction.

After writing into (reading from) DDRAM or CGRAM, the AC is automatically incremented by 1 (decremented by 1). The AC contents are then output to DB0 to DB6 when RS $=0$ and $\mathrm{R} / \overline{\mathrm{W}}=1$ (Table $1)$.

Table 1 Register Selection

| $\mathbf{R S}$ | $\mathbf{R} / \overline{\mathbf{W}}$ | Operation |
| :--- | :--- | :--- |
| 0 | 0 | IR write as an internal operation (display clear, etc.) |
| 0 | 1 | Read busy flag (DB7) and address counter (DB0 to DB6) |
| 1 | 0 | DR write as an internal operation (DR to DDRAM or CGRAM) |
| 1 | 1 | DR read as an internal operation (DDRAM or CGRAM to DR) |

## Display Data RAM (DDRAM)

Display data RAM (DDRAM) stores display data represented in 8-bit character codes. Its extended capacity is $80 \times 8$ bits, or 80 characters. The area in display data RAM (DDRAM) that is not used for display can be used as general data RAM. See Figure 1 for the relationships between DDRAM addresses and positions on the liquid crystal display.

The DDRAM address $\left(\mathrm{A}_{\mathrm{DD}}\right)$ is set in the address counter (AC) as hexadecimal.

- 1-line display $(\mathrm{N}=0)$ (Figure 2)
- When there are fewer than 80 display characters, the display begins at the head position. For example, if using only the HD44780, 8 characters are displayed. See Figure 3.
When the display shift operation is performed, the DDRAM address shifts. See Figure 3.


Figure 1 DDRAM Address

| Display positio (digit) | 1 | 2 | 3 | 4 | 5 |  | 79 | 80 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DDRAM address | 00 | 01 | 02 | 03 | 04 | . | 4E | 4F |

Figure 2 1-Line Display


Figure 3 1-Line by 8-Character Display Example

## HD44780U

- 2-line display $(\mathrm{N}=1)$ (Figure 4 )
- Case 1: When the number of display characters is less than $40 \times 2$ lines, the two lines are
displayed from the head. Note that the first line end address and the second line start address are not consecutive. For example, when just the HD44780 is used, 8 characters $\times 2$ lines are displayed. See Figure 5.

When display shift operation is performed, the DDRAM address shifts. See Figure 5.


Figure 4 2-Line Display


Figure 5 2-Line by 8-Character Display Example

## HD44780U

- Case 2: For a 16-character $\times 2$-line display, the HD44780 can be extended using one 40 -output extension driver. See Figure 6.
When display shift operation is performed, the DDRAM address shifts. See Figure 6.


Figure 6 2-Line by 16-Character Display Example

## HD44780U

## Character Generator ROM (CGROM)

The character generator ROM generates $5 \times 8$ dot or $5 \times 10$ dot character patterns from 8-bit character codes (Table 4). It can generate $2085 \times 8$ dot character patterns and $325 \times 10$ dot character patterns. User-defined character patterns are also available by mask-programmed ROM.

## Character Generator RAM (CGRAM)

In the character generator RAM, the user can rewrite character patterns by program. For $5 \times 8$ dots, eight character patterns can be written, and for $5 \times 10$ dots, four character patterns can be written.

Write into DDRAM the character codes at the addresses shown as the left column of Table 4 to show the character patterns stored in CGRAM.

See Table 5 for the relationship between CGRAM addresses and data and display patterns.

Areas that are not used for display can be used as general data RAM.

## Modifying Character Patterns

- Character pattern development procedure

The following operations correspond to the numbers listed in Figure 7:

1. Determine the correspondence between character codes and character patterns.
2. Create a listing indicating the correspondence between EPROM addresses and data.
3. Program the character patterns into the EPROM.
4. Send the EPROM to Hitachi.
5. Computer processing on the EPROM is performed at Hitachi to create a character pattern listing, which is sent to the user.
6. If there are no problems within the character pattern listing, a trial LSI is created at Hitachi and samples are sent to the user for evaluation. When it is confirmed by the user that the character patterns are correctly written, mass production of the LSI proceeds at Hitachi.


Figure 7 Character Pattern Development Procedure

## HD44780U

- Programming character patterns

This section explains the correspondence between addresses and data used to program character patterns in EPROM. The HD44780U character generator ROM can generate $2085 \times 8$ dot character patterns and $325 \times 10$ dot character patterns for a total of 240 different character patterns.

- Character patterns

EPROM address data and character pattern data correspond with each other to form a $5 \times 8$ or $5 \times$ 10 dot character pattern (Tables 2 and 3).
Table 2 Example of Correspondence between EPROM Address Data and Character Pattern ( $5 \times 8$ Dots)


Notes: 1. EPROM addresses A11 to A4 correspond to a character code.
2. EPROM addresses $A 3$ to $A 0$ specify a line position of the character pattern.
3. EPROM data O 4 to O 0 correspond to character pattern data.
4. EPROM data O 5 to O 7 must be specified as 0 .
5. A lit display position (black) corresponds to a 1.
6. Line 9 and the following lines must be blanked with 0 s for a $5 \times 8$ dot character fonts.

- Handling unused character patterns

1. EPROM data outside the character pattern area: Always input 0s.
2. EPROM data in CGRAM area: Always input 0s. (Input 0s to EPROM addresses 00H to FFH.) 3. EPROM data used when the user does not use any HD44780U character pattern: According to the user application, handled in one of the two ways listed as follows.
a. When unused character patterns are not programmed: If an unused character code is written into DDRAM, all its dots are lit. By not programing a character pattern, all of its bits become lit. (This is due to the EPROM being filled with 1 s after it is erased.)
b. When unused character patterns are programmed as 0s: Nothing is displayed even if unused character codes are written into DDRAM. (This is equivalent to a space.)

Table 3 Example of Correspondence between EPROM Address Data and Character Pattern ( $5 \times 10$ Dots)


Notes: 1. EPROM addresses A11 to A3 correspond to a character code.
2. EPROM addresses $A 3$ to $A 0$ specify a line position of the character pattern.
3. EPROM data O 4 to O 0 correspond to character pattern data.
4. EPROM data O5 to O7 must be specified as 0 .
5. A lit display position (black) corresponds to a 1.
6. Line 11 and the following lines must be blanked with 0 s for a $5 \times 10$ dot character fonts.

## HD44780U

Table 4 Correspondence between Character Codes and Character Patterns (ROM Code: A00)


Note: The user can specify any pattern for character-generator RAM.

Table 4 Correspondence between Character Codes and Character Patterns (ROM Code: A02)


## HD44780U

Table 5 Relationship between CGRAM Addresses, Character Codes (DDRAM) and Character Patterns (CGRAM Data)


Notes: 1. Character code bits 0 to 2 correspond to CGRAM address bits 3 to 5 ( 3 bits: 8 types).
2. CGRAM address bits 0 to 2 designate the character pattern line position. The 8th line is the cursor position and its display is formed by a logical OR with the cursor.
Maintain the 8th line data, corresponding to the cursor display position, at 0 as the cursor display.
If the 8 th line data is 1,1 bits will light up the 8 th line regardless of the cursor presence.
3. Character pattern row positions correspond to CGRAM data bits 0 to 4 (bit 4 being at the left).
4. As shown Table 5, CGRAM character patterns are selected when character code bits 4 to 7 are all 0 . However, since character code bit 3 has no effect, the R display example above can be selected by either character code 00 H or 08 H .
5. 1 for CGRAM data corresponds to display selection and 0 to non-selection.

* Indicates no effect.

Table 5 Relationship between CGRAM Addresses, Character Codes (DDRAM) and Character Patterns (CGRAM Data) (cont)


Notes: 1. Character code bits 1 and 2 correspond to CGRAM address bits 4 and 5 ( 2 bits: 4 types).
2. CGRAM address bits 0 to 3 designate the character pattern line position. The 11th line is the cursor position and its display is formed by a logical OR with the cursor.
Maintain the 11th line data corresponding to the cursor display positon at 0 as the cursor display.
If the 11 th line data is " 1 ", " 1 " bits will light up the 11 th line regardless of the cursor presence. Since lines 12 to 16 are not used for display, they can be used for general data RAM.
3. Character pattern row positions are the same as $5 \times 8$ dot character pattern positions.
4. CGRAM character patterns are selected when character code bits 4 to 7 are all 0 .

However, since character code bits 0 and 3 have no effect, the P display example above can be selected by character codes $00 \mathrm{H}, 01 \mathrm{H}, 08 \mathrm{H}$, and 09 H .
5. 1 for CGRAM data corresponds to display selection and 0 to non-selection.

* Indicates no effect.


## HD44780U

## Timing Generation Circuit

The timing generation circuit generates timing signals for the operation of internal circuits such as DDRAM, CGROM and CGRAM. RAM read timing for display and internal operation timing by MPU access are generated separately to avoid interfering with each other. Therefore, when writing data to DDRAM, for example, there will be no undesirable interferences, such as flickering, in areas other than the display area.

## Liquid Crystal Display Driver Circuit

The liquid crystal display driver circuit consists of 16 common signal drivers and 40 segment signal drivers. When the character font and number of lines are selected by a program, the required common signal drivers automatically output drive waveforms, while the other common signal drivers continue to output non-selection waveforms.

Sending serial data always starts at the display data character pattern corresponding to the last address of the display data RAM (DDRAM).

Since serial data is latched when the display data character pattern corresponding to the starting address enters the internal shift register, the HD44780U drives from the head display.

## Cursor/Blink Control Circuit

The cursor/blink control circuit generates the cursor or character blinking. The cursor or the blinking will appear with the digit located at the display data RAM (DDRAM) address set in the address counter (AC).

For example (Figure 8), when the address counter is 08 H , the cursor position is displayed at DDRAM address 08 H .


Note: The cursor or blinking appears when the address counter (AC) selects the character generator RAM (CGRAM). However, the cursor and blinking become meaningless. The cursor or blinking is displayed in the meaningless position when the AC is a CGRAM address

Figure 8 Cursor/Blink Display Example

## Interfacing to the MPU

The HD44780U can send data in either two 4-bit operations or one 8 -bit operation, thus allowing interfacing with 4 - or 8-bit MPUs.

- For 4-bit interface data, only four bus lines (DB4 to DB7) are used for transfer. Bus lines DB0 to DB3 are disabled. The data transfer between the HD44780U and the MPU is completed after the 4-bit data has been transferred twice. As for the order of data transfer, the four high order bits (for 8-bit operation, DB4 to DB7) are transferred before the four low order bits (for 8-bit operation, DB0 to DB3).
The busy flag must be checked (one instruction) after the 4-bit data has been transferred twice. Two more 4-bit operations then transfer the busy flag and address counter data.
- For 8-bit interface data, all eight bus lines (DB0 to DB7) are used.


Figure 9 4-Bit Transfer Example

## HD44780U

## Reset Function

## Initializing by Internal Reset Circuit

An internal reset circuit automatically initializes the HD44780U when the power is turned on. The following instructions are executed during the initialization. The busy flag (BF) is kept in the busy state until the initialization ends $(\mathrm{BF}=1)$. The busy state lasts for 10 ms after $\mathrm{V}_{\mathrm{CC}}$ rises to 4.5 V .

1. Display clear
2. Function set:

DL $=1 ; 8$-bit interface data
$\mathrm{N}=0$; 1-line display
$\mathrm{F}=0 ; 5 \times 8$ dot character font
3. Display on/off control:
$\mathrm{D}=0$; Display off
C $=0$; Cursor off
$\mathrm{B}=0$; Blinking off
4. Entry mode set:
$\mathrm{I} / \mathrm{D}=1$; Increment by 1
S = 0; No shift
Note: If the electrical characteristics conditions listed under the table Power Supply Conditions Using Internal Reset Circuit are not met, the internal reset circuit will not operate normally and will fail to initialize the HD44780U. For such a case, initial-ization must be performed by the MPU as explained in the section, Initializing by Instruction.

## Instructions

## Outline

Only the instruction register (IR) and the data register (DR) of the HD44780U can be controlled by the MPU. Before starting the internal operation of the HD44780U, control information is temporarily stored into these registers to allow interfacing with various MPUs, which operate at different speeds, or various peripheral control devices. The internal operation of the HD44780U is determined by signals sent from the MPU. These signals, which include register selection signal (RS), read/
write signal ( $\mathrm{R} / \overline{\mathrm{W}}$ ), and the data bus (DB0 to DB7), make up the HD44780U instructions (Table 6). There are four categories of instructions that:

- Designate HD44780U functions, such as display format, data length, etc.
- Set internal RAM addresses
- Perform data transfer with internal RAM
- Perform miscellaneous functions

Normally, instructions that perform data transfer with internal RAM are used the most. However, autoincrementation by 1 (or auto-decrementation by 1) of internal HD44780U RAM addresses after each data write can lighten the program load of the MPU. Since the display shift instruction (Table 11) can perform concurrently with display data write, the user can minimize system development time with maximum programming efficiency.

When an instruction is being executed for internal operation, no instruction other than the busy flag/address read instruction can be executed.

Because the busy flag is set to 1 while an instruction is being executed, check it to make sure it is 0 before sending another instruction from the MPU.

Note: Be sure the HD44780U is not in the busy state $(B F=0)$ before sending an instruction from the MPU to the HD44780U. If an instruction is sent without checking the busy flag, the time between the first instruction and next instruction will take much longer than the instruction time itself. Refer to Table 6 for the list of each instruc-tion execution time.

Table 6 Instructions

| Instruction | Code |  |  |  |  |  |  |  |  |  | Description | Execution Time (max) (when $f_{\text {cp }}$ or $\mathrm{f}_{\text {osc }}$ is $\mathbf{2 7 0 ~ k H z )}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 |  |  |
| Clear display | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | Clears entire display and sets DDRAM address 0 in address counter. |  |
| Return home | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | - | Sets DDRAM address 0 in address counter. Also returns display from being shifted to original position. DDRAM contents remain unchanged. | 1.52 ms |
| Entry mode set | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | I/D | S | Sets cursor move direction and specifies display shift. These operations are performed during data write and read. | $37 \mu \mathrm{~s}$ |
| Display on/off control | 0 | 0 | 0 | 0 | 0 | 0 | 1 | D | C | B | Sets entire display (D) on/off, cursor on/off (C), and blinking of cursor position character (B). | $37 \mu \mathrm{~s}$ |
| Cursor or display shift | 0 | 0 | 0 | 0 | 0 | 1 | S/C | R/L | - | - | Moves cursor and shifts display without changing DDRAM contents. | $37 \mu \mathrm{~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). | $37 \mu \mathrm{~s}$ |
| Set CGRAM address | 0 | 0 | 0 | 1 | ACG | ACG | ACG | ACG | ACG | ACG | Sets CGRAM address. CGRAM data is sent and received after this setting. | $37 \mu \mathrm{~s}$ |
| Set DDRAM address | 0 | 0 | 1 | ADD | ADD | ADD | ADD | ADD | ADD | ADD | Sets DDRAM address. DDRAM data is sent and received after this setting. | $37 \mu \mathrm{~s}$ |
| Read busy flag \& address | 0 | 1 | BF | AC | AC | AC | AC | AC | AC | AC | Reads busy flag (BF) indicating internal operation is being performed and reads address counter contents. | $0 \mu \mathrm{~s}$ |

## HD44780U

Table 6 Instructions (cont)


Note: - indicates no effect.

* After execution of the CGRAM/DDRAM data write or read instruction, the RAM address counter is incremented or decremented by 1. The RAM address counter is updated after the busy flag turns off. In Figure 10, $\mathrm{t}_{\text {ADD }}$ is the time elapsed after the busy flag turns off until the address counter is updated.


Figure 10 Address Counter Update

## Instruction Description

## Clear Display

Clear display writes space code 20 H (character pattern for character code 20 H must be a blank pattern) into all DDRAM addresses. It then sets DDRAM address 0 into the address counter, and returns the display to its original status if it was shifted. In other words, the display disappears and the cursor or blinking goes to the left edge of the display (in the first line if 2 lines are displayed). It also sets I/D to 1 (increment mode) in entry mode. $S$ of entry mode does not change.

## Return Home

Return home sets DDRAM address 0 into the address counter, and returns the display to its original status if it was shifted. The DDRAM contents do not change.

The cursor or blinking go to the left edge of the display (in the first line if 2 lines are displayed).

## Entry Mode Set

I/D: Increments $(I / D=1)$ or decrements $(I / D=0)$ the DDRAM address by 1 when a character code is written into or read from DDRAM.

The cursor or blinking moves to the right when incremented by 1 and to the left when decremented by 1 . The same applies to writing and reading of CGRAM.

S: Shifts the entire display either to the right $(\mathrm{I} / \mathrm{D}=0)$ or to the left $(\mathrm{I} / \mathrm{D}=1)$ when S is 1 . The display does not shift if $S$ is 0 .

If $S$ is 1 , it will seem as if the cursor does not move but the display does. The display does not shift when reading from DDRAM. Also, writing into or reading out from CGRAM does not shift the display.

## Display On/Off Control

D: The display is on when D is 1 and off when D is 0 . When off, the display data remains in DDRAM, but can be displayed instantly by setting D to 1 .

C: The cursor is displayed when C is 1 and not displayed when C is 0 . Even if the cursor disappears, the function of I/D or other specifications will not change during display data write. The cursor is displayed using 5 dots in the 8th line for $5 \times 8$ dot character font selection and in the 11th line for the $5 \times 10$ dot character font selection (Figure 13).

B: The character indicated by the cursor blinks when B is 1 (Figure 13). The blinking is displayed as switching between all blank dots and displayed characters at a speed of $409.6-\mathrm{ms}$ intervals when $\mathrm{f}_{\mathrm{cp}}$ or $\mathrm{f}_{\text {osc }}$ is 250 kHz . The cursor and blinking can be set to display simultaneously. (The blinking frequency changes according to $f_{\text {oSc }}$ or the reciprocal of $f_{\text {cp }}$. For example, when $f_{c p}$ is $270 \mathrm{kHz}, 409.6 \times 250 / 270=$ 379.2 ms .)

## HD44780U

## Cursor or Display Shift

Cursor or display shift shifts the cursor position or display to the right or left without writing or reading display data (Table 7). This function is used to correct or search the display. In a 2-line display, the cursor moves to the second line when it passes the 40th digit of the first line. Note that the first and second line displays will shift at the same time.

When the displayed data is shifted repeatedly each line moves only horizontally. The second line display does not shift into the first line position.

The address counter (AC) contents will not change if the only action performed is a display shift.

## Function Set

DL: Sets the interface data length. Data is sent or received in 8-bit lengths (DB7 to DB0) when DL is 1, and in 4-bit lengths (DB7 to DB4) when DL is 0 . When 4-bit length is selected, data must be sent or received twice.
$\mathbf{N}$ : Sets the number of display lines.

F: Sets the character font.

Note: Perform the function at the head of the program before executing any instructions (except for the read busy flag and address instruction). From this point, the function set instruction cannot be executed unless the interface data length is changed.

## Set CGRAM Address

Set CGRAM address sets the CGRAM address binary AAAAAA into the address counter.

Data is then written to or read from the MPU for CGRAM.


Figure 11


Figure 12

## HD44780U

## Set DDRAM Address

Set DDRAM address sets the DDRAM address binary AAAAAAA into the address counter.
Data is then written to or read from the MPU for DDRAM.

However, when N is 0 (1-line display), AAAAAAA can be 00 H to 4 FH . When N is 1 (2-line display), AAAAAAA can be 00 H to 27 H for the first line, and 40 H to 67 H for the second line.

## Read Busy Flag and Address

Read busy flag and address reads the busy flag (BF) indicating that the system is now internally operating on a previously received instruction. If BF is 1 , the internal operation is in progress. The next instruction will not be accepted until BF is reset to 0 . Check the BF status before the next write operation. At the same time, the value of the address counter in binary AAAAAAA is read out. This address counter is used by both CG and DDRAM addresses, and its value is determined by the previous instruction. The address contents are the same as for instructions set CGRAM address and set DDRAM address.

Table 7 Shift Function

| $\mathbf{S} / \mathbf{C}$ | $\mathbf{R} / \mathbf{L}$ |  |
| :--- | :--- | :--- |
| 0 | 0 | Shifts the cursor position to the left. (AC is decremented by one.) |
| 0 | 1 | Shifts the cursor position to the right. (AC is incremented by one.) |
| 1 | 0 | Shifts the entire display to the left. The cursor follows the display shift. |
| 1 | 1 | Shifts the entire display to the right. The cursor follows the display shift. |

Table 8 Function Set

No. of
Display
Duty

| $\mathbf{N}$ | $\mathbf{F}$ | Lines | Character Font | Factor | Remarks |
| :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 1 | $5 \times 8$ dots | $1 / 8$ |  |
| 0 | 1 | 1 | $5 \times 10$ dots | $1 / 11$ |  |
| 1 | ${ }^{*}$ | 2 | $5 \times 8$ dots | $1 / 16$ | Cannot display two lines for $5 \times 10$ dot character font |
| Note: | ${ }^{*}$ | Indicates don't care. |  |  |  |



Figure 13 Cursor and Blinking


Figure 14

## HD44780U

## Write Data to CG or DDRAM

Write data to CG or DDRAM writes 8-bit binary data DDDDDDDD to CG or DDRAM.
To write into CG or DDRAM is determined by the previous specification of the CGRAM or DDRAM address setting. After a write, the address is automatically incremented or decremented by 1 according to the entry mode. The entry mode also determines the display shift.

## Read Data from CG or DDRAM

Read data from CG or DDRAM reads 8-bit binary data DDDDDDDD from CG or DDRAM.
The previous designation determines whether CG or DDRAM is to be read. Before entering this read instruction, either CGRAM or DDRAM address set instruction must be executed. If not executed, the first read data will be invalid. When serially executing read instructions, the next address data is normally read from the second read. The address set instructions need not be executed just before this read instruction when shifting the cursor by the cursor shift instruction (when reading out DDRAM). The operation of the cursor shift instruction is the same as the set DDRAM address instruction.

After a read, the entry mode automatically increases or decreases the address by 1 . However, display shift is not executed regardless of the entry mode.

Note: The address counter (AC) is automatically incremented or decremented by 1 after the write instructions to CGRAM or DDRAM are executed. The RAM data selected by the AC cannot be read out at this time even if read instructions are executed. Therefore, to correctly read data, execute either the address set instruction or cursor shift instruction (only with DDRAM), then just before reading the desired data, execute the read instruction from the second time the read instruction is sent.


Figure 15

## Interfacing the HD44780U

## Interface to MPUs

- Interfacing to an 8-bit MPU

See Figure 17 for an example of using a I/O port (for a single-chip microcomputer) as an interface device.
In this example, P30 to P37 are connected to the data bus DB0 to DB7, and P75 to P77 are connected to $\mathrm{E}, \mathrm{R} / \overline{\mathrm{W}}$, and RS, respectively.


Figure 16 Example of Busy Flag Check Timing Sequence


Figure 17 H8/325 Interface (Single-Chip Mode)

## HD44780U

- Interfacing to a 4-bit MPU

The HD44780U can be connected to the I/O port of a 4-bit MPU. If the I/O port has enough bits, 8-bit data can be transferred. Otherwise, one data transfer must be made in two operations for 4-bit data. In this case, the timing sequence becomes somewhat complex. (See Figure 18.)

See Figure 19 for an interface example to the HMCS4019R.
Note that two cycles are needed for the busy flag check as well as for the data transfer. The 4-bit operation is selected by the program.


Figure 18 Example of 4-Bit Data Transfer Timing Sequence


Figure 19 Example of Interface to HMCS4019R

## Interface to Liquid Crystal Display

Character Font and Number of Lines: The HD44780U can perform two types of displays, $5 \times 8$ dot and $5 \times 10$ dot character fonts, each with a cursor.

Up to two lines are displayed for $5 \times 8$ dots and one line for $5 \times 10$ dots. Therefore, a total of three types of common signals are available (Table 9).

The number of lines and font types can be selected by the program. (See Table 6, Instructions.)
Connection to HD44780 and Liquid Crystal Display: See Figure 20 for the connection examples.

## Table 9 Common Signals

| Number of Lines | Character Font | Number of Common Signals | Duty Factor |
| :--- | :--- | :--- | :--- |
| 1 | $5 \times 8$ dots + cursor | 8 | $1 / 8$ |
| 1 | $5 \times 10$ dots + cursor | 11 | $1 / 11$ |
| 2 | $5 \times 8$ dots + cursor | 16 | $1 / 16$ |



Figure 20 Liquid Crystal Display and HD44780 Connections

## HD44780U

Since five segment signal lines can display one digit, one HD44780U can display up to 8 digits for a 1line display and 16 digits for a 2-line display.

The examples in Figure 20 have unused common signal pins, which always output non-selection waveforms. When the liquid crystal display panel has unused extra scanning lines, connect the extra scanning lines to these common signal pins to avoid any undesirable effects due to crosstalk during the floating state (Figure 21).


Figure 20 Liquid Crystal Display and HD44780 Connections (cont)

|  |  |
| :---: | :---: | :---: | :---: | :---: |
| $5 \times 8$ dot <br> character font <br> Cursor display example | Alternating display |
| character font |  |

Figure 21 Using COM9 to Avoid Crosstalk on Unneeded Scanning Line

Connection of Changed Matrix Layout: In the preceding examples, the number of lines correspond to the scanning lines. However, the following display examples (Figure 22) are made possible by altering the matrix layout of the liquid crystal display panel. In either case, the only change is the layout. The display characteristics and the number of liquid crystal display characters depend on the number of common signals or on duty factor. Note that the display data RAM (DDRAM) addresses for 4 characters $\times 2$ lines and for 16 characters $\times 1$ line are the same as in Figure 20 .


Figure 22 Changed Matrix Layout Displays

## HD44780U

## Power Supply for Liquid Crystal Display Drive

Various voltage levels must be applied to pins V1 to V5 of the HD44780U to obtain the liquid crystal display drive waveforms. The voltages must be changed according to the duty factor (Table 10).

VLCD is the peak value for the liquid crystal display drive waveforms, and resistance dividing provides voltages V1 to V5 (Figure 23).

Table 10 Duty Factor and Power Supply for Liquid Crystal Display Drive

|  | Duty Factor |  |
| :--- | :--- | :--- |
|  | $\mathbf{1 / 8 , \mathbf { 1 / 1 1 }}$ | $\mathbf{1 / 1 6}$ |
| Power Supply | $\mathbf{1 / 4}$ | Bias |
| V 1 | $\mathrm{~V}_{\mathrm{cc}}-1 / 4 \mathrm{VLCD}$ | $\mathbf{1 / 5}$ |
| V 2 | $\mathrm{~V}_{\mathrm{cc}}-1 / 2 \mathrm{VLCD}$ | $\mathrm{V}_{\mathrm{cc}}-1 / 5 \mathrm{VLCD}$ |
| V 3 | $\mathrm{~V}_{\mathrm{cc}}-1 / 2 \mathrm{VLCD}$ | $\mathrm{V}_{\mathrm{cc}}-2 / 5 \mathrm{VLCD}$ |
| V 4 | $\mathrm{~V}_{\mathrm{cc}}-3 / 4 \mathrm{VLCD}$ | $\mathrm{V}_{\mathrm{cc}}-3 / 5 \mathrm{VLCD}$ |
| V 5 | $\mathrm{~V}_{\mathrm{cc}}-\mathrm{VLCD}$ | $\mathrm{V}_{\mathrm{cc}}-4 / 5 \mathrm{VLCD}$ |



Figure 23 Drive Voltage Supply Example

## Relationship between Oscillation Frequency and Liquid Crystal Display Frame Frequency

The liquid crystal display frame frequencies of Figure 24 apply only when the oscillation frequency is 270 kHz (one clock pulse of $3.7 \mu \mathrm{~s}$ ).


Figure 24 Frame Frequency

## HD44780U

## Instruction and Display Correspondence

- 8-bit operation, 8-digit $\times 1$-line display with internal reset

Refer to Table 11 for an example of an 8 -digit $\times 1$-line display in 8 -bit operation. The HD44780U functions must be set by the function set instruction prior to the display. Since the display data RAM can store data for 80 characters, as explained before, the RAM can be used for displays such as for advertising when combined with the display shift operation.
Since the display shift operation changes only the display position with DDRAM contents unchanged, the first display data entered into DDRAM can be output when the return home operation is performed.

- 4-bit operation, 8 -digit $\times 1$-line display with internal reset

The program must set all functions prior to the 4-bit operation (Table 12). When the power is turned on, 8-bit operation is automatically selected and the first write is performed as an 8-bit operation. Since DB0 to DB3 are not connected, a rewrite is then required. However, since one operation is completed in two accesses for 4-bit operation, a rewrite is needed to set the functions (see Table 12). Thus, DB4 to DB7 of the function set instruction is written twice.

- 8 -bit operation, 8 -digit $\times 2$-line display

For a 2-line display, the cursor automatically moves from the first to the second line after the 40th digit of the first line has been written. Thus, if there are only 8 characters in the first line, the DDRAM address must be again set after the 8th character is completed. (See Table 13.) Note that the display shift operation is performed for the first and second lines. In the example of Table 13, the display shift is performed when the cursor is on the second line. However, if the shift operation is performed when the cursor is on the first line, both the first and second lines move together. If the shift is repeated, the display of the second line will not move to the first line. The same display will only shift within its own line for the number of times the shift is repeated.

Note: When using the internal reset, the electrical characteristics in the Power Supply Conditions Using Internal Reset Circuit table must be satisfied. If not, the HD44780U must be initialized by instructions. See the section, Initializing by Instruction.

Table 11 8-Bit Operation, 8-Digit $\times$ 1-Line Display Example with Internal Reset


## HD44780U

Table 11 8-Bit Operation, 8-Digit $\times$ 1-Line Display Example with Internal Reset (cont)


Table 12 4-Bit Operation, 8-Digit $\times$ 1-Line Display Example with Internal Reset

| Step | Instruction |  |  |  |  |  | Display | Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| No. | RS | R/W | DB7 | DB6 | DB5 | DB4 |  |  |
| 1 | Power supply on (the HD44780U is initialized by the internal reset circuit) |  |  |  |  |  |  | Initialized. No display. |
| 2 | Fun 0 | ion se |  |  | 1 | 0 |  | Sets to 4-bit operation. In this case, operation is handled as 8 bits by initialization, and only this instruction completes with one write. |
| 3 | Fun 0 0 | ion se 0 0 | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | 1 | $\begin{aligned} & 0 \\ & * \end{aligned}$ |  | Sets 4-bit operation and selects 1 -line display and $5 \times 8$ dot character font. 4-bit operation starts from this step and resetting is necessary. (Number of display lines and character fonts cannot be changed after step \#3.) |
| 4 | Disp 0 0 | ay on/0 0 0 | ff cont 0 1 | $\begin{array}{r} \text { trol } \\ 0 \\ 1 \end{array}$ | 0 1 | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\square$ | Turns on display and cursor. Entire display is in space mode because of initialization. |
| 5 | Entry 0 0 | $\begin{aligned} & \text { mode } \\ & 0 \\ & 0 \end{aligned}$ | $\begin{gathered} \text { set } \\ 0 \\ 0 \end{gathered}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | - | Sets mode to increment the address by one and to shift the cursor to the right at the time of write to the DD/CGRAM. Display is not shifted. |
| 6 | Writ 1 1 | data to 0 0 | CGR 0 1 | AM/DD 1 0 | RAM 0 0 | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | H- | Writes H . <br> The cursor is incremented by one and shifts to the right. |

Note: The control is the same as for 8-bit operation beyond step \#6.

## HD44780U

Table 13 8-Bit Operation, 8-Digit $\times$ 2-Line Display Example with Internal Reset

|  |  |  |  |  | Instr | uction |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| No. | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | Display | Operation |
| 1 | Power supply on (the HD44780U is initialized by the internal reset circuit) |  |  |  |  |  |  |  |  |  |  | Initialized. No display. |
| 2 |  | tion se |  | 0 |  | 1 | 1 | 0 |  | * |  | Sets to 8-bit operation and selects 2 -line display and $5 \times 8$ dot character font. |
| 3 | Disp 0 | ay on/ | 0 |  | 0 | 0 | 1 | 1 | 1 | 0 |  | Turns on display and cursor. All display is in space mode because of initialization. |
| 4 |  | $\begin{aligned} & \text { mode } \\ & 0 \end{aligned}$ | $\begin{gathered} \text { set } \\ 0 \end{gathered}$ | $0$ |  | 0 | 0 |  |  | 0 |  | Sets mode to increment the address by one and to shift the cursor to the right at the time of write to the DD/CGRAM. Display is not shifted. |
| 5 |  | $\begin{aligned} & \text { data } \\ & 0 \end{aligned}$ | $\begin{aligned} & \hline \text { o CGF } \\ & 0 \end{aligned}$ | $\begin{aligned} & \text { AM/DD } \\ & 1 \end{aligned}$ | כRAM |  |  |  | 0 | 0 | H- | Writes H. DDRAM has already been selected by initialization when the power was turned on. The cursor is incremented by one and shifted to the right. |
| 6 |  |  |  |  |  |  |  |  |  |  |  |  |
| 7 |  | data $0$ | $\begin{aligned} & 0 \text { CGF } \\ & 0 \end{aligned}$ | 1 | $\begin{aligned} & \text { כRAM } \\ & 0 \end{aligned}$ | 0 | 1 | 0 | 0 | 1 | HITACHI | Writes I. |
| 8 |  | DRAM 0 | $1 \text { addr }$ $1$ | $\begin{gathered} \text { ess } \\ 1 \end{gathered}$ |  | 0 | 0 | 0 | 0 | 0 | $\begin{array}{\|l\|l\|} \hline \text { HITACHI } \\ \hline \end{array}$ | Sets DDRAM address so that the cursor is positioned at the head of the second line. |

Table 13 8-Bit Operation, 8-Digit $\times$ 2-Line Display Example with Internal Reset (cont)


## HD44780U

## Initializing by Instruction

If the power supply conditions for correctly operating the internal reset circuit are not met, initialization by instructions becomes necessary.

Refer to Figures 25 and 26 for the procedures on 8-bit and 4-bit initializations, respectively.


Figure 25 8-Bit Interface


Figure 26 4-Bit Interface

## HD44780U

| Absolute Maximum Ratings* |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- |
|  |  |  |  |  |
| Item | Symbol | Value | Unit | Notes |
| Power supply voltage (1) | $\mathrm{V}_{\mathrm{cc}}-\mathrm{GND}$ | -0.3 to +7.0 | V | 1 |
| Power supply voltage (2) | $\mathrm{V}_{\mathrm{cc}}-\mathrm{V} 5$ | -0.3 to +13.0 | V | 1,2 |
| Input voltage | Vt | -0.3 to $\mathrm{V}_{\mathrm{cc}}+0.3$ | V | 1 |
| Operating temperature | $\mathrm{T}_{\text {opr }}$ | -20 to +75 | ${ }^{\circ} \mathrm{C}$ |  |
| Storage temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +125 | ${ }^{\circ} \mathrm{C}$ | 4 |

Note: * If the LSI is used above these absolute maximum ratings, it may become permanently damaged. Using the LSI within the following electrical characteristic limits is strongly recommended for normal operation. If these electrical characteristic conditions are also exceeded, the LSI will malfunction and cause poor reliability.

DC Characteristics $\left(V_{c C}=\mathbf{2 . 7}\right.$ to $\mathbf{4 . 5} \mathrm{V}, \mathrm{T}_{\mathrm{a}}=\mathbf{- 2 0}$ to $+\mathbf{7 5}{ }^{\circ} \mathrm{C}^{*^{3}}$ )

| Item | Symbol | Min | Typ | Max | Unit | Test Condition | Notes* |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input high voltage (1) (except OSC1) | VIH1 | $0.7 \mathrm{~V}_{\text {cc }}$ | - | $\mathrm{V}_{\text {c }}$ | V |  | 6 |
| Input low voltage (1) (except OSC1) | VIL1 | -0.3 | - | 0.55 | V |  | 6 |
| $\begin{aligned} & \text { Input high voltage (2) } \\ & \text { (OSC1) } \end{aligned}$ | VIH2 | $0.7 \mathrm{~V}_{\text {cc }}$ | - | $\mathrm{V}_{\mathrm{cc}}$ | V |  | 15 |
| Input low voltage (2) (OSC1) | VIL2 | - | - | $0.2 \mathrm{~V}_{\text {cc }}$ | V |  | 15 |
| Output high voltage (1) (DB0-DB7) | VOH 1 | $0.75 \mathrm{~V}_{\text {cc }}$ | - | - | V | $-\mathrm{I}_{\mathrm{OH}}=0.1 \mathrm{~mA}$ | 7 |
| Output low voltage (1) (DB0-DB7) | VOL1 | - | - | $0.2 \mathrm{~V}_{\text {cc }}$ | V | $\mathrm{I}_{\mathrm{oL}}=0.1 \mathrm{~mA}$ | 7 |
| Output high voltage (2) (except DB0-DB7) | VOH 2 | 0.8 V cc | - | - | V | $-\mathrm{l}_{\mathrm{OH}}=0.04 \mathrm{~mA}$ | 8 |
| Output low voltage (2) (except DB0-DB7) | VOL2 | - | - | $0.2 \mathrm{~V}_{\text {cc }}$ | V | $\mathrm{I}_{\mathrm{oL}}=0.04 \mathrm{~mA}$ | 8 |
| Driver on resistance (COM) | $\mathrm{R}_{\text {com }}$ | - | 2 | 20 | k $\Omega$ | $\begin{aligned} & \pm \mathrm{Id}=0.05 \mathrm{~mA}, \\ & \mathrm{VLCD}=4 \mathrm{~V} \end{aligned}$ | 13 |
| Driver on resistance (SEG) | $\mathrm{R}_{\text {sEG }}$ | - | 2 | 30 | k $\Omega$ | $\begin{aligned} & \pm \mathrm{Id}=0.05 \mathrm{~mA}, \\ & \mathrm{VLCD}=4 \mathrm{~V} \end{aligned}$ | 13 |
| Input leakage current | $\mathrm{I}_{\mathrm{L}}$ | -1 | - | 1 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0$ to $\mathrm{V}_{\mathrm{cc}}$ | 9 |
| Pull-up MOS current (DB0-DB7, RS, R/W) | $-l_{p}$ | 10 | 50 | 120 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{cc}}=3 \mathrm{~V}$ |  |
| Power supply current | $\mathrm{I}_{\mathrm{cc}}$ | - | 0.15 | 0.30 | mA | $\mathrm{R}_{\mathrm{t}}$ oscillation, external clock $\begin{aligned} \mathrm{V}_{\mathrm{cc}} & =3 \mathrm{~V}, \\ \mathrm{f}_{\mathrm{osc}} & =270 \mathrm{kHz} \end{aligned}$ | 10, 14 |
| LCD voltage | VLCD1 | 3.0 | - | 11.0 | V | $\mathrm{V}_{\text {cc }}-\mathrm{V} 5,1 / 5$ bias | 16 |
|  | VLCD2 | 3.0 | - | 11.0 | V | $\mathrm{V}_{\text {cc }}-\mathrm{V} 5,1 / 4$ bias | 16 |

Note: * Refer to the Electrical Characteristics Notes section following these tables.

## HD44780U

AC Characteristics ( $\mathrm{V}_{\mathrm{cc}}=\mathbf{2 . 7}$ to $\mathbf{4 . 5} \mathrm{V}, \mathrm{T}_{\mathrm{a}}=\mathbf{- 2 0}$ to $+\mathbf{7 5}{ }^{\circ} \mathrm{C}^{*}{ }^{3}$ )

Clock Characteristics

| Item |  | Symbo | Min | Typ | Max | Unit | Test Condition | Note* |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| External clock operation | External clock frequency | $\mathrm{f}_{\mathrm{cp}}$ | 125 | 250 | 350 | kHz |  | 11 |
|  | External clock duty | Duty | 45 | 50 | 55 | \% |  |  |
|  | External clock rise time | $\mathrm{t}_{\text {cep }}$ | - | - | 0.2 | $\mu \mathrm{s}$ |  |  |
|  | External clock fall time | $\mathrm{t}_{\text {cp }}$ | - | - | 0.2 | $\mu \mathrm{s}$ |  |  |
| $\mathrm{R}_{\mathrm{t}}$ oscillation | Clock oscillation frequency | $\mathrm{f}_{\text {osc }}$ | 190 | 270 | 350 | kHz | $\begin{aligned} & \mathrm{R}_{\mathrm{f}}=75 \mathrm{k} \Omega, \\ & \mathrm{~V}_{\mathrm{cc}}=3 \mathrm{~V} \end{aligned}$ | 12 |

Note: * Refer to the Electrical Characteristics Notes section following these tables.

## Bus Timing Characteristics

Write Operation

| Item | Symbo | Min | Typ | Max | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Enable cycle time | $\mathrm{t}_{\text {cye }}$ | 1000 | - | - | ns | Figure 27 |
| Enable pulse width (high level) | $\mathrm{PW}_{\text {EH }}$ | 450 | - | - |  |  |
| Enable rise/fall time | $\mathrm{t}_{\mathrm{E},} \mathrm{t}_{\mathrm{E} \text { t }}$ | - | - | 25 |  |  |
| Address set-up time (RS, R/W to E) | $\mathrm{t}_{\text {As }}$ | 60 | - | - |  |  |
| Address hold time | $\mathrm{t}_{\text {AH }}$ | 20 | - | - |  |  |
| Data set-up time | $\mathrm{t}_{\text {osw }}$ | 195 | - | - |  |  |
| Data hold time | $\mathrm{t}_{\mathrm{H}}$ | 10 | - | - |  |  |

## Read Operation

| Item | Symbo | Min | Typ | Max | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Enable cycle time | $\mathrm{t}_{\text {cye }}$ | 1000 | - | - | ns | Figure 28 |
| Enable pulse width (high level) | $\mathrm{PW}_{\text {EH }}$ | 450 | - | - |  |  |
| Enable rise/fall time | $\mathrm{t}_{\text {E, }} \mathrm{t}_{\mathrm{Et}}$ | - | - | 25 |  |  |
| Address set-up time (RS, R/W to E) | $\mathrm{t}_{\text {AS }}$ | 60 | - | - |  |  |
| Address hold time | $\mathrm{t}_{\text {AH }}$ | 20 | - | - |  |  |
| Data delay time | $\mathrm{t}_{\text {DOR }}$ | - | - | 360 |  |  |
| Data hold time | $\mathrm{t}_{\text {онR }}$ | 5 | - | - |  |  |

Interface Timing Characteristics with External Driver

| Item |  | Symbol | Min | Typ | Max | Unit | Test Condition |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Clock pulse width | High level | $\mathrm{t}_{\mathrm{cWH}}$ | 800 | - | - | ns | Figure 29 |
|  | Low level | $\mathrm{t}_{\mathrm{cWL}}$ | 800 | - | - |  |  |
| Clock set-up time |  | $\mathrm{t}_{\mathrm{csu}}$ | 500 | - | - |  |  |
| Data set-up time | $\mathrm{t}_{\mathrm{SU}}$ | 300 | - | - |  |  |  |
| Data hold time | $\mathrm{t}_{\mathrm{DH}}$ | 300 | - | - |  |  |  |
| M delay time | $\mathrm{t}_{\mathrm{DM}}$ | -1000 | - | 1000 |  |  |  |
| Clock rise/fall time | $\mathrm{t}_{\mathrm{ct}}$ | - | - | 200 |  |  |  |

## Power Supply Conditions Using Internal Reset Circuit

| Item | Symbol | Min | Typ | Max | Unit | Test Condition |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Power supply rise time | $\mathrm{t}_{\mathrm{rcc}}$ | 0.1 | - | 10 | ms | Figure 30 |
| Power supply off time | $\mathrm{t}_{\text {off }}$ | 1 | - | - |  |  |

## HD44780U

DC Characteristics $\left(\mathrm{V}_{\mathrm{cC}}=4.5\right.$ to $5.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{a}}=\mathbf{- 2 0}$ to $\left.+\mathbf{7 5}{ }^{\circ} \mathrm{C}^{* 3}\right)$

| Item | Symbol | Min | Typ | Max | Unit | Test Condition | Notes* |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input high voltage (1) (except OSC1) | VIH1 | 2.2 | - | $\mathrm{V}_{\text {cc }}$ | V |  | 6 |
| Input low voltage (1) (except OSC1) | VIL1 | -0.3 | - | 0.6 | V |  | 6 |
| Input high voltage (2) (OSC1) | VIH2 | $\mathrm{V}_{\mathrm{cc}}-1.0$ | - | $\mathrm{V}_{\text {cc }}$ | V |  | 15 |
| Input low voltage (2) (OSC1) | VIL2 | - | - | 1.0 | V |  | 15 |
| Output high voltage (1) (DB0-DB7) | VOH 1 | 2.4 | - | - | V | $-\mathrm{I}_{\mathrm{OH}}=0.205 \mathrm{~mA}$ | 7 |
| Output low voltage (1) (DB0-DB7) | VOL1 | - | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=1.2 \mathrm{~mA}$ | 7 |
| Output high voltage (2) (except DB0-DB7) | VOH 2 | $0.9 \mathrm{~V}_{\mathrm{cc}}$ | - | - | V | $-\mathrm{I}_{\mathrm{OH}}=0.04 \mathrm{~mA}$ | 8 |
| Output low voltage (2) (except DB0-DB7) | VOL2 | - | - | $0.1 \mathrm{~V}_{\mathrm{cc}}$ | V | $\mathrm{I}_{\mathrm{OL}}=0.04 \mathrm{~mA}$ | 8 |
| Driver on resistance (COM) | RCOM | - | 2 | 20 | k $\Omega$ | $\begin{aligned} & \pm \mathrm{ld}=0.05 \mathrm{~mA} \\ & \mathrm{VLCD}=4 \mathrm{~V} \end{aligned}$ | 13 |
| Driver on resistance (SEG) | RSEG | - | 2 | 30 | k $\Omega$ | $\begin{aligned} & \pm \mathrm{ld}=0.05 \mathrm{~mA} \\ & \mathrm{VLCD}=4 \mathrm{~V} \end{aligned}$ | 13 |
| Input leakage current | $\mathrm{I}_{\mathrm{LI}}$ | -1 | - | 1 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0$ to $\mathrm{V}_{\mathrm{cc}}$ | 9 |
| Pull-up MOS current (DB0-DB7, RS, R/W) | $-l_{p}$ | 50 | 125 | 250 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V}$ |  |
| Power supply current | $\mathrm{I}_{\mathrm{cc}}$ | - | 0.35 | 0.60 | mA | $\mathrm{R}_{\mathrm{t}}$ oscillation, external clock $\begin{aligned} & \mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V}, \\ & \mathrm{f}_{\mathrm{osc}}=270 \mathrm{kHz} \end{aligned}$ | 10, 14 |
| LCD voltage | VLCD1 | 3.0 | - | 11.0 | V | $\mathrm{V}_{\text {cc }}-\mathrm{V} 5,1 / 5$ bias | 16 |
|  | VLCD2 | 3.0 | - | 11.0 | V | $\mathrm{V}_{\text {cc }}-\mathrm{V} 5,1 / 4$ bias | 16 |

Note: * Refer to the Electrical Characteristics Notes section following these tables.

## AC Characteristics $\left(V_{\mathrm{cc}}=4.5\right.$ to $5.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{a}}=\mathbf{- 2 0}$ to $\left.+\mathbf{7 5}{ }^{\circ} \mathrm{C}^{* 3}\right)$

Clock Characteristics

| Item |  | Symbol Min |  | Typ | Max | Unit | Test Condition | Notes* |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| External clock operation | External clock frequency | $\mathrm{f}_{\mathrm{cp}}$ | 125 | 250 | 350 | kHz |  | 11 |
|  | External clock duty | Duty | 45 | 50 | 55 | \% |  | 11 |
|  | External clock rise time | $\mathrm{t}_{\text {rcp }}$ | - | - | 0.2 | $\mu \mathrm{s}$ |  | 11 |
|  | External clock fall time | $\mathrm{t}_{\text {cip }}$ | - | - | 0.2 | $\mu \mathrm{s}$ |  | 11 |
| $\mathrm{R}_{\mathrm{t}}$ oscillation | Clock oscillation frequency | $\mathrm{f}_{\text {osc }}$ | 190 | 270 | 350 | kHz | $\begin{aligned} & \mathrm{R}_{\mathrm{f}}=91 \mathrm{k} \Omega \\ & \mathrm{~V}_{\mathrm{cc}}=5.0 \mathrm{~V} \end{aligned}$ | 12 |

Note: * Refer to the Electrical Characteristics Notes section following these tables.

## Bus Timing Characteristics

## Write Operation

| Item | Symbol | Min | Typ | Max | Unit | Test Condition |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Enable cycle time | $\mathrm{t}_{\mathrm{cyEE}}$ | 500 | - | - | ns | Figure 27 |
| Enable pulse width (high level) | $\mathrm{PW}_{\mathrm{EH}}$ | 230 | - | - |  |  |
| Enable rise/fall time | $\mathrm{t}_{\mathrm{Er}} \mathrm{t}_{\mathrm{Ef}}$ | - | - | 20 |  |  |
| Address set-up time (RS, R/W to E$)$ | $\mathrm{t}_{\mathrm{As}}$ | 40 | - | - |  |  |
| Address hold time | $\mathrm{t}_{\mathrm{AH}}$ | 10 | - | - |  |  |
| Data set-up time | $\mathrm{t}_{\mathrm{DSW}}$ | 80 | - | - |  |  |
| Data hold time | $\mathrm{t}_{\mathrm{H}}$ | 10 | - | - |  |  |

## Read Operation

| Item | Symbol | Min | Typ | Max | Unit | Test Condition |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Enable cycle time | $\mathrm{t}_{\mathrm{cyCE}}$ | 500 | - | - | ns | Figure 28 |
| Enable pulse width (high level) | $\mathrm{PW}_{\mathrm{EH}}$ | 230 | - | - |  |  |
| Enable rise/fall time | $\mathrm{t}_{\mathrm{Er}}, \mathrm{t}_{\mathrm{Et}}$ | - | - | 20 |  |  |
| Address set-up time (RS, R/ $\overline{\mathrm{W}}$ to E$)$ | $\mathrm{t}_{\mathrm{AS}}$ | 40 | - | - |  |  |
| Address hold time | $\mathrm{t}_{\mathrm{AH}}$ | 10 | - | - |  |  |
| Data delay time | $\mathrm{t}_{\mathrm{DDR}}$ | - | - | 160 |  |  |
| Data hold time | $\mathrm{t}_{\mathrm{DHR}}$ | 5 | - | - |  |  |

Interface Timing Characteristics with External Driver

| Item |  | Symbol | Min | Typ | Max | Unit | Test Condition |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Clock pulse width | High level | $\mathrm{t}_{\mathrm{cwH}}$ | 800 | - | - | ns | Figure 29 |
|  | Low level | $\mathrm{t}_{\mathrm{cwL}}$ | 800 | - | - |  |  |
| Clock set-up time |  | $\mathrm{t}_{\mathrm{csu}}$ | 500 | - | - |  |  |
| Data set-up time | $\mathrm{t}_{\mathrm{SU}}$ | 300 | - | - |  |  |  |
| Data hold time | $\mathrm{t}_{\mathrm{DH}}$ | 300 | - | - |  |  |  |
| M delay time | $\mathrm{t}_{\mathrm{DM}}$ | -1000 | - | 1000 |  |  |  |
| Clock rise/fall time | $\mathrm{t}_{\mathrm{ct}}$ | - | - | 100 |  |  |  |

## Power Supply Conditions Using Internal Reset Circuit

| Item | Symbol | Min | Typ | Max | Unit | Test Condition |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Power supply rise time | $\mathrm{t}_{\mathrm{rcc}}$ | 0.1 | - | 10 | ms | Figure 30 |
| Power supply off time | $\mathrm{t}_{\mathrm{ofF}}$ | 1 | - | - |  |  |

## Electrical Characteristics Notes

1. All voltage values are referred to $\mathrm{GND}=0 \mathrm{~V}$.


$$
\begin{array}{ll}
\mathrm{A}=\mathrm{V}_{C C}-\mathrm{V} 5 & \text { The conditions of } \mathrm{V} 1 \text { and } \mathrm{V} 5 \text { voltages are for proper } \\
\mathrm{B}=\mathrm{V}_{C C}-\mathrm{V} 1 & \text { operation of the LSI and not for the LCD output level. } \\
\mathrm{A} \geq 1.5 \mathrm{~V} & \text { The LCD drive voltage condition for the LCD output } \\
B \leq 0.25 \times \mathrm{A} & \text { level is specified as LCD voltage VLCD. }
\end{array}
$$

2. $\mathrm{V}_{\mathrm{cc}} \geq \mathrm{V} 1 \geq \mathrm{V} 2 \geq \mathrm{V} 3 \geq \mathrm{V} 4 \geq \mathrm{V} 5$ must be maintained.
3. For die products, specified up to $75^{\circ} \mathrm{C}$.
4. For die products, specified by the die shipment specification.
5. The following four circuits are I/O pin configurations except for liquid crystal display output.


## HD44780U

6. Applies to input pins and I/O pins, excluding the OSC1 pin.
7. Applies to I/O pins.
8. Applies to output pins.
9. Current flowing through pull-up MOSs, excluding output drive MOSs.
10. Input/output current is excluded. When input is at an intermediate level with CMOS, the excessive current flows through the input circuit to the power supply. To avoid this from happening, the input level must be fixed high or low.
11. Applies only to external clock operation.

| Oscillator |
| ---: |
| Open - OSC1 |
| OSC2 |



$$
\text { Duty }=\frac{\mathrm{Th}}{\mathrm{Th}+\mathrm{Tl}} \times 100 \%
$$

12. Applies only to the internal oscillator operation using oscillation resistor $\mathrm{R}_{\mathrm{f}}$.



13. RCOM is the resistance between the power supply pins $\left(\mathrm{V}_{\mathrm{CC}}, \mathrm{V} 1, \mathrm{~V} 4, \mathrm{~V} 5\right)$ and each common signal pin (COM1 to COM16).
RSEG is the resistance between the power supply pins ( $\left.\mathrm{V}_{\mathrm{CC}}, \mathrm{V} 2, \mathrm{~V} 3, \mathrm{~V} 5\right)$ and each segment signal pin (SEG1 to SEG40).
14. The following graphs show the relationship between operation frequency and current consumption.

15. Applies to the OSC1 pin.
16. Each COM and SEG output voltage is within $\pm 0.15 \mathrm{~V}$ of the LCD voltage ( $\left.\mathrm{V}_{\mathrm{CC}}, \mathrm{V} 1, \mathrm{~V} 2, \mathrm{~V} 3, \mathrm{~V} 4, \mathrm{~V} 5\right)$ when there is no load.

## HD44780U

## Load Circuits

Data Bus DB0 to DB7


External Driver Control Signals: CL1, CL2, D, M


Timing Characteristics


Figure 27 Write Operation


Figure 28 Read Operation

## HD44780U



Figure 29 Interface Timing with External Driver
$\mathrm{V}_{\mathrm{CC}}$


Notes: 1. toff compensates for the power oscillation period caused by momentary power supply oscillations.
2. Specified at 4.5 V for $5-\mathrm{V}$ operation, and at 2.7 V for $3-\mathrm{V}$ operation.
3. For if 4.5 V is not reached during $5-\mathrm{V}$ operation, the internal reset circuit will not operate normally.
In this case, the LSI must be initialized by software. (Refer to the Initializing by Instruction section.)

Figure 30 Internal Power Supply Reset

## INTRODUCTION

KS0066U is a dot matrix LCD driver \& controller LSI whichis fabricated by low power CMOS technology.
It can display 1 or 2 lines with the $5 \times 8$ dots format or 1 line with the $5 \times 11$ dots format.

## FUNCTIONS

- Character type dot matrix LCD driver \& controller.
- Internal driver: 16 common and 40 segment signal output.

- Easy interface with 4-bit or 8-bit MPU.
- Display character pattern: $5 \times 8$ dots format ( 208 kinds) \& $5 \times 11$ dots format ( 32 kinds).
- The Special character pattern is directly programmable by the Character Generator RAM.
- A customer character pattern is programmable by mask option.
- Programmable Driving Method by the same character font mask option: Display Waveform A-type and B-type
- It can drive a maximum at 80 characters by using the KS0065B or KS0063B externally.
- Various instruction functions.
- Built-in automatic power on reset.


## FEATURES

- Internal Memory
- Character Generator ROM (CGROM): 10,080 bits ( 204 characters $\times 5 \times 8$ dots) \& ( 32 characters $\times 5 \times 11$ dots)
- Character Generator RAM (CGRAM): $64 \times 8$ bits ( 8 characters $\times 5 \times 8$ dots)
- Display Data RAM (DDRAM): $80 \times 8$ bits ( 80 characters max.)
- Low power operation
- Power supply voltage range (VDD): 2.7 to 5.5 V
- LCD Drive voltage range (VDD-V5): 3.0 to 13.0 V
- CMOS process
- Programmable duty cycle: $1 / 8,1 / 11,1 / 16$
- Internal oscillator with external resistor
- Low power consumption
- 80 QFP or bare chip available


## simsung

## BLOCK DIAGRAM



## simsung

## PIN CONFIGURATION



## PAD DIAGRAM



NOTE: "KS0066U" marking is to make the PAD No. 65 easy to find.

## PAD LOCATION

Table 1. Pad Location
(Unit: $\mu \mathrm{m}$ )

| Pad No. | Pad Name | Coordinate |  | Pad No. | Pad Name | Coordinate |  | Pad No. | Pad <br> Name | Coordinate |  | Pad No. | Pad <br> Name | Coordinate |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | X | Y |  |  | X | Y |  |  | X | Y |  |  | X | Y |
| 1 | S22 | -1864 | 1465 | 21 | S2 | -1864 | -1034 | 41 | DB2 | 1864 | -1488 | 61 | C15 | 1864 | 1085 |
| 2 | S21 | -1864 | 1340 | 22 | S1 | -1864 | -1159 | 42 | DB3 | 1864 | -1362 | 62 | C16 | 1864 | 1210 |
| 3 | S20 | -1864 | 1215 | 23 | GND | -1864 | -1285 | 43 | DB4 | 1864 | -1238 | 63 | S40 | 1864 | 1341 |
| 4 | S19 | -1864 | 1090 | 24 | OSC1 | -1864 | -1414 | 44 | DB5 | 1864 | -1112 | 64 | S39 | 1864 | 1466 |
| 5 | S18 | -1864 | 965 | 25 | OSC2 | -1120 | -1754 | 45 | DB6 | 1864 | -988 | 65 | S38 | 886 | 1754 |
| 6 | S17 | -1864 | 840 | 26 | V1 | -970 | -1754 | 46 | DB7 | 1864 | -862 | 66 | S37 | 760 | 1754 |
| 7 | S16 | -1864 | 715 | 27 | V2 | -820 | -1754 | 47 | C1 | 1864 | -665 | 67 | S36 | 636 | 1754 |
| 8 | S15 | -1864 | 590 | 28 | V3 | -670 | -1754 | 48 | C2 | 1864 | -540 | 68 | S35 | 510 | 1754 |
| 9 | S14 | -1864 | 465 | 29 | V4 | -520 | -1754 | 49 | C3 | 1864 | -415 | 69 | S34 | 386 | 1754 |
| 10 | S13 | -1864 | 340 | 30 | V5 | -370 | -1754 | 50 | C4 | 1864 | -290 | 70 | S33 | 260 | 1754 |
| 11 | S12 | -1864 | 215 | 31 | CLK1 | -220 | -1754 | 51 | C5 | 1864 | -165 | 71 | S32 | 136 | 1754 |
| 12 | S11 | -1864 | 90 | 32 | CLK2 | -70 | -1754 | 52 | C6 | 1864 | -40 | 72 | S31 | 10 | 1754 |
| 13 | S10 | -1864 | -35 | 33 | VDD | 80 | -1754 | 53 | C7 | 1864 | 85 | 73 | S30 | -114 | 1754 |
| 14 | S9 | -1864 | -160 | 34 | M | 230 | -1754 | 54 | C8 | 1864 | 210 | 74 | S29 | -240 | 1754 |
| 15 | S8 | -1864 | -285 | 35 | D | 380 | -1754 | 55 | C9 | 1864 | 335 | 75 | S28 | -364 | 1754 |
| 16 | S7 | -1864 | -410 | 36 | RS | 518 | -1754 | 56 | C10 | 1864 | 460 | 76 | S27 | -490 | 1754 |
| 17 | S6 | -1864 | -535 | 37 | R/W | 642 | -1754 | 57 | C11 | 1864 | 585 | 77 | S26 | -614 | 1754 |
| 18 | S5 | -1864 | -660 | 38 | E | 768 | -1754 | 58 | C12 | 1864 | 710 | 78 | S25 | -740 | 1754 |
| 19 | S4 | -1864 | -785 | 39 | DB0 | 894 | -1754 | 59 | C13 | 1864 | 835 | 79 | S24 | -864 | 1754 |
| 20 | S3 | -1864 | -910 | 40 | DB1 | 1018 | -1754 | 60 | C14 | 1864 | 960 | 80 | S23 | -989 | 1754 |

## simsung

## PIN DESCRIPTION

Table 2. Pin Description

| Pin | Pin <br> No. | I/O | Name | Description | Interface |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VDD | 33 | - | Supply Voltage | Supply Voltage for logical circuit $(+3 \mathrm{~V} \pm 10 \%,+5 \mathrm{~V} \pm 10 \%)$ | Power Supply |
| GND | 23 |  |  | Ground (0V) |  |
| V1-V5 | 26-30 |  |  | Bias voltage level for LCD driving |  |
| S1-S40 | $\begin{aligned} & 1-22, \\ & 63-80 \end{aligned}$ | O | Segment output | Segment signal output for LCD drive | LCD |
| C1-C16 | 47-62 | 0 | Common output | Common signal output for LCD drive | LCD |
| OSC1 | 24 | 1 | Oscillator | Oscillator. When using internal oscillator, connect external Rf resistor. If external clock is used, connect it to OSC1. | External resistor/oscillator (OSC1) |
| OSC2 | 25 | 0 | Oscillator |  |  |
| CLK1 | 31 | O | Extension driver Latch clock | Extension driver latch clock | Extension driver |
| CLK2 | 32 | O | Extension driver Shift clock | Extension driver shift clock |  |
| M | 34 | O | Alternated signal for LCD driver output | Outputs the alternating signal to convert LCD driver waveform to AC. | Extension driver |
| D | 35 | O | Display data interface | Outputs extension driver data (the 41st dot's data) | Extension driver |
| RS | 36 | 1 | Register select | Used as register selection input. When RS = "High", Data register is selected. When RS = "Low", Instruction register is selected. | MPU |
| R/W | 37 | 1 | Read/Write | Used as read/write selection input. When RW = "High", read operation. When RW = 'Low", write operation. | MPU |
| E | 38 | 1 | Read/Write enable | Used as read/write enable signal. | MPU |
| DB0-DB3 | 39-42 | I/O | Data bus 0-7 | In 8-bit bus mode, used as low order bidirectional data bus. In 4-bit bus mode, open these pins. | MPU |
| DB4-DB7 | 43-46 |  |  | In 8-bit bus mode, used as high order bidirectional data bus. In 4-bit bus mode, used as both high and low order. <br> DB7 used for Busy Flag output. | MPU |

## simsung

## FUNCTION DESCRIPTION

## System Interface

This chip has both kinds of interface type with MPU: 4-bit bus and 8-bit bus.
4 -bit bus and 8 -bit bus are selected by the DL bit in the instruction register.
During read or write operation, two 8-bit registers are used.
One is the data register (DR), and the other is the instruction register (IR).
The data register (DR) is used as a temporary data storage place for being written into or read from DDRAM/CGRAM. The target RAM is selected by RAM address setting instruction.
Each internal operation, reading from or writing into RAM, is done automatically.
Thus, after MPU reads DR data, the data in the next DDRAM/CGRAM address is transferred into DR automatically. Also, after MPU writes data to DR, the data in DR is transferred into DDRAM/CGRAM automatically.

The Instruction register(IR) is used only to store instruction codes transferred from MPU.
MPU cannot use it to read instruction data.
To select a register, you can use RS input pin in 4-bit/8-bit bus mode.
Table 3. Various kinds of Operations according to RS and R/W bits

| RS | R/W | Operation |
| :---: | :---: | :--- |
| L | L | Instruction Write operation (MPU writes Instruction code into IR) |
| L | H | Read Busy flag(DB7) and address counter (DB0 to DB6) |
| H | L | Data Write operation (MPU writes data into DR) |
| H | H | Data Read operation (MPU reads data from DR) |

## Busy Flag (BF)

BF = "High", indicates that the internal operation is being processed.
So during this time the next instruction cannot be accepted. BF can be read through DB7 port when RS = "Low" and R/W = "High" (Read Instruction Operation).
Before executing the next instruction, be sure that BF is not "High".

## Address Counter (AC)

The address Counter (AC) stores DDRAM/CGRAM addresses, transferred from IR.
After writing into (reading from) DDRAM/CGRAM, AC is automatically increased (decreased) by 1.
When RS = "Low" and R/W = "High", AC can be read through ports DB0 to DB6.

## Display Data RAM (DDRAM)

DDRAM stores display data of maximum $80 \times 8$ bits ( 80 characters).
DDRAM address is set in the address counter(AC) as a hexadecimal number (Refer to Fig-1.)

| MSB |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| AC6 AC5 AC4 AC3 <br> AC2 AC1 AC0  |  |  |  |  |  |  |

Figure 1 . DDRAM Address

1) 1 -line display

In case of 1 -line display, the address range of DDRAM is $00 \mathrm{H}-4 \mathrm{FH}$.
An extension driver will be used. Fig-2 shows the example with 40 segment extension driver added.


Figure 2. 1-line $\times 24$ char. display with 40 SEG. extension driver

## snmsung:

2) 2-line display

In case of 2 -line display, the address range of DDRAM is $00 \mathrm{H}-27 \mathrm{H}$ and $40 \mathrm{H}-67 \mathrm{H}$.
An extension driver will be used. Fig-3 shows the example with 40 segment extension driver added.


Figure 3. 2-line $\times \mathbf{2 4}$ char. display with $\mathbf{4 0}$ SEG. extension driver

## simsung

## CGROM(Character Generator ROM)

CGROM has a $5 \times 8$ dots 204 characters pattern and a $5 \times 11$ dots 32 characters pattern (Refer to Table 4). CGROM has 204 character patterns of $5 \times 8$ dots, and 32 character patterns of $5 \times 11$ dots.

## CGRAM(Character Generator RAM)

CGRAM has up to $5 \times 8$ dots 8 characters.
By writing font data to CGRAM, user defined characters can be used (Refer to Table 5)

## Timing Generation Circuit

Timing generation circuit generates clock signals for the internal operations.

## LCD Driver Circuit

LCD Driver circuit has 16 common and 40 segment signals for LCD driving.
Data from CGRAM/CGROM is transferred to a 40-bit segment latch serially, and then is stored to 40-bit shift latch. When each common is selected by 16 -bit common register, segment data is also output through segment driver from a 40-bit segment latch.
In case of 1 -line display mode, COM1 to COM8 have $1 / 8$ duty or COM1 to COM11 have $1 / 11$ duty, and in 2-line mode, COM1 to COM16 have a $1 / 16$ duty ratio.

## Cursor/Blink Control Circuit

It controls the cursor/blink ON/OFF at cursor position.

## simsung

Table 4. CGROM Character Code Table

Table 5. Relationship between Character Code (DDRAM) and Character Pattern (CGRAM)


## INSTRUCTION DESCRIPTION

## Outline

To overcome the speed difference between the internal clock of KS0066U and the MPU clock, KS0066U performs internal operations by storing control informations to IR or DR. The internal operation is determined according to the signal from MPU, composed of read/write and data bus (Refer to Table 7).
Instructions can be divided largely into four groups:

1) KS0066U function set instructions (set display methods, set data length, etc.)
2) address set instructions to internal RAM
3) data transfer instructions with internal RAM
4) others

The address of the internal RAM is automatically increased or decreased by 1 .
Note: During internal operation, Busy Flag (DB7) is read "High".
Busy Flag check must be preceded by the next instruction.
When an MPU program with checking the Busy Flag (DB7) is made, it must be necessary $1 / 2$ fosc for executing the next instruction by the falling edge of the 'E' signal after the Busy Flag (DB7) goes to "Low".

## Contents

1) Clear Display

| RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 |  | DB2 | DB1 | DB0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |  |

Clear all the display data by writing " 20 H "(space code) to all DDRAM address, and set DDRAM address to " 00 H " into AC (address counter).
Return cursor to the original status, namely, bring the cursor to the left edge on the first line of the display. Make the entry mode increment ( $1 / \mathrm{D}=$ "High").
2) Return Home

| RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | - |

Return Home is cursor return home instruction.
Set DDRAM address to " 00 H " into the address counter.
Return cursor to its original site and return display to its original status, if shifted.
Contents of DDRAM does not change.

## simsung

3) Entry Mode Set

| RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | I/D | SH |

Set the moving direction of cursor and display.
I/D: Increment / decrement of DDRAM address (cursor or blink)
When I/D = 'High", cursor/blink moves to right and DDRAM address is increased by 1.
When I/D = "Low", cursor/blink moves to left and DDRAM address is decreased by 1.

* CGRAM operates the same way as DDRAM, when reading from or writing to CGRAM.


## SH: Shift of entire display

When DDRAM read (CGRAM read/write) operation or $\mathrm{SH}=$ "Low", shifting of entire display is not performed. If SH = 'High" and DDRAM write operation, shift of entire display is performed according to I/D value (I/D = 'High". shift left, I/D = 'Low". shift right).
4) Display ON/OFF Control

| RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 | D | C | B |

Control display/cursor/blink ON/OFF 1 bit register.

## D: Display ON/OFF control bit

When $\mathrm{D}=$ 'High", entire display is turned on.
When $D=$ 'Low", display is turned off, but display data remains in DDRAM.

## C: Cursor ON/OFF control bit

When C = "High", cursor is turned on.
When $\mathrm{C}=$ "Low", cursor is disappeared in current display, but I/D register preserves its data.

## B: Cursor Blink ON/OFF control bit

When B = "High", cursor blink is on, which performs alternately between all the "High"data and display characters at the cursor position.
When $\mathrm{B}=$ "Low", blink is off.

## simsung

5) Cursor or Display Shift

| RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 1 | S/C | R/L | - | - |

Shifting of right/left cursor position or display without writing or reading of display data.
This instruction is used to correct or search display data.(Refer to Table 6)
During 2 -line mode display, cursor moves to the 2nd line after the 40th digit of the 1 st line.
Note that display shift is performed simultaneously in all the lines.
When displayed data is shifted repeatedly, each line is shifted individually.
When display shift is performed, the contents of the address counter are not changed.

Table 6. Shift Patterns According to $\mathrm{S} / \mathrm{C}$ and $\mathrm{R} / \mathrm{L}$ Bits

| $\mathbf{S} / \mathbf{C}$ | R/L |  |
| :---: | :---: | :--- |
| 0 | 0 | Shift cursor to the left, AC is decreased by 1 |
| 0 | 1 | Shift cursor to the right, AC is increased by 1 |
| 1 | 0 | Shift all the display to the left, cursor moves according to the display |
| 1 | 1 | Shift all the display to the right, cursor moves according to the display |

6) Function Set
RS R/W DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0

| 0 | 0 | 0 | 0 | 1 | DL | N | F | - | - |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

## DL: Interface data length control bit

When DL = 'High", it means 8 -bit bus mode with MPU.
When DL = 'Low", it means 4-bit bus mode with MPU. Hence, DL is a signal to select 8 -bit or 4-bit bus mode. When 4-bit bus mode, it needs to transfer 4-bit data twice.

## N : Display line number control bit

When $N$ = "Low", 1 -line display mode is set.
When $\mathrm{N}=$ "High", 2 -line display mode is set.

## F: Display font type control bit

When $\mathrm{F}=$ "Low", $5 \times 8$ dots format display mode is set.
When $F=$ "High", $5 \times 11$ dots format display mode.

## simsung

## 7) Set CGRAM Address

| RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 0 0 1 AC5 AC4 AC3 AC2 | AC1 | AC0 |  |  |  |  |  |  |  |

Set CGRAM address to AC.
This instruction makes CGRAM data available from MPU.
8) Set DDRAM Address

| RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 1 | AC6 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 |

Set DDRAM address to AC.
This instruction makes DDRAM data available from MPU.
When 1 -line display mode ( $\mathrm{N}=\mathrm{Low}$ ), DDRAM address is from " OOH "to " 4 FH ".
In 2 -line display mode ( $\mathrm{N}=$ High), DDRAM address in the 1st line is from ' $00 \mathrm{H}^{\prime}$ "to ' 27 H ', and DDRAM address in the 2 nd line is from " 40 H " to " 67 H ".
9) Read Busy Flag \& Address

| RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 1 | BF | AC6 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 |

This instruction shows whether KS0066U is in internal operation or not.
If the resultant BF is "High", internal operation is in progress and should wait until BF is to be Low, which by then the next instruction can be performed. In this instruction you can also read the value of the address counter.

## SAMSUNG

10) Write data to RAM

| RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |

Write binary 8-bit data to DDRAM/CGRAM.
The selection of RAM from DDRAM, and CGRAM, is set by the previous address set instruction (DRAM address set, CGRAM address set).
RAM set instruction can also determine the AC direction to RAM.
After write operation, the address is automatically increased/decreased by 1 , according to the entry mode.

## 11) Read data from RAM

RS R/W DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0

| 1 | 1 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Read binary 8-bit data from DDRAM/CGRAM.
The selection of RAM is set by the previous address set instruction. If the address set instruction of RAM is not performed before this instruction, the data that has been read first is invalid, as the direction of AC is not Yet determined. If RAM data is read several times without RAM address instructions set before read operation, the correct RAM data can be obtained from the second. But the first data would be incorrect, as there is no time margin to transfer RAM data.
In case of DDRAM read operation, cursor shift instruction plays the same role as DDRAM address set instruction, it also transfers RAM data to output data register.
After read operation, address counter is automatically increased/decreased by 1 according to the entry mode.
After CGRAM read operation, display shift may not be executed correctly.
NOTE: In case of RAM write operation, AC is increased/decreased by 1 as in read operation.
At this time, AC indicates the next address position, but only the previous data can be read by the read instruction.

Table 7. Instruction Table

| Instruction | Instruction Code |  |  |  |  |  |  |  |  |  | Description | Execution time (fosc= 270 kHz) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 |  |  |
| Clear Display | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | Write "20H" to DDRAM and set DDRAM address to " 00 H " from AC | 1.53 ms |
| Return Home | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | - | Set DDRAM address to ${ }^{\circ} 0 \mathrm{OH}^{\prime}$ from $A C$ and return cursor to its original position if shifted. The contents of DDRAM are not changed. | 1.53 ms |
| Entry Mode Set | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | I/D | SH | Assign cursor moving direction and enable the shift of entire display. | $39 \mu \mathrm{~s}$ |
| Display ON/ OFF Control | 0 | 0 | 0 | 0 | 0 | 0 | 1 | D | C | B | Set display(D), cursor(C), and blinking of cursor(B) on/off control bit. | $39 \mu \mathrm{~s}$ |
| Cursor or Display Shift | 0 | 0 | 0 | 0 | 0 | 1 | S/C | R/L | - | - | Set cursor moving and display shift control bit, and the direction, without changing of DDRAM data. | $39 \mu \mathrm{~s}$ |
| Function Set | 0 | 0 | 0 | 0 | 1 | DL | N | F | - | - | Set interface data length (DL: 8-bit/4-bit), numbers of display line ( $\mathrm{N}: 2$-line/1-line) and, display font type ( $\mathrm{F}: 5 \times 11$ dots $/ 5 \times 8$ dots) | $39 \mu \mathrm{~s}$ |
| Set CGRAM Address | 0 | 0 | 0 | 1 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 | Set CGRAM address in address counter. | $39 \mu \mathrm{~s}$ |
| Set DDRAM Address | 0 | 0 | 1 | AC6 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 | Set DDRAM address in address counter. | $39 \mu \mathrm{~s}$ |
| Read Busy Flag and Address | 0 | 1 | BF | AC6 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 | Whether during internal operation or not can be known by reading $B F$. The contents of address counter can also be read. | $0 \mu \mathrm{~s}$ |
| Write Data to RAM | 1 | 0 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Write data into internal RAM (DDRAM/CGRAM). | $43 \mu \mathrm{~s}$ |
| Read Data from RAM | 1 | 1 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Read data from internal RAM (DDRAM/CGRAM). | $43 \mu \mathrm{~s}$ |

NOTE: When an MPU program with checking the Busy Flag(DB7) is made, it must be necessary $1 / 2$ Fosc is necessary for executing the next instruction by the falling edge of the 'E' signal after the Busy Flag (DB7) goes to "Low".

## simsung

## INTERFACE WITH MPU

1) Interface with 8-bit MPU

When interfacing data length are 8-bit, transfer is performed at a time through 8 ports, from DB0 to DB7.
Example of timing sequence is shown below.


Figure 4 . Example of 8-bit Bus Mode Timing Diagram
2) Interface with 4-bit MPU

When interfacing data length are 4-bit, only 4 ports, from DB4 to DB7, are used as data bus.
At First, the higher 4-bit (in case of 8-bit bus mode, the contents of DB4-DB7), and then the lower 4-bit (in case of 8-bit bus mode, the contents of DB0-DB3) are transferred. So transfer is performed twice Busy Flag outputs "High"after the second transfer is ended.
Example of timing sequence is shown below.


Figure 5 . Example of 4-bit Bus Mode Timing Diagram

## simsung

## APPLICATION INFORMATION ACCORDING TO LCD PANEL

1) LCD Panel: 8 characters $\times 1$-line format ( $5 \times 7$ dots +1 cursor line, $1 / 4$ bias, $1 / 8$ duty)

2) LCD Panel: 8 characters $\times 1$-line format ( $5 \times 10$ dots +1 cursor line, $1 / 4$ bias, $1 / 11$ duty $)$

3) LCD Panel: 8 characters $\times 2$-line format ( $5 \times 7$ dots + line, $1 / 5$ bias, $1 / 16$ duty)

4) LCD Panel: 16 characters $\times 1$-line format ( $5 \times 7$ dots +1 cursor line, $1 / 5$ bias, $1 / 16$ duty $)$


## SAMSUNG

electronics
5) LCD Panel: 4 characters $\times 2$-line format ( $5 \times 7$ dots +1 cursor line, $1 / 4$ bias, $1 / 8$ duty)

6) APPLICATION CIRCUIT


NOTE: When KS0065B is externally connected to the KS0066U, you can increase the number of display digits up to 80 characters.

## BIAS VOLTAGE DIVIDE CIRCUIT

$\begin{array}{ll}\text { 1) } 1 / 4 \text { bias, } 1 / 8 \text { or } 1 / 11 \text { duty } & \text { 2) } 1 / 5 \text { bias, } 1 / 16 \text { duty }\end{array}$



## simsung

## INITIALIZING

When the power is turned on, KS0066U is initialized automatically by power on reset circuit.
During the initialization, the following instructions are executed, and BF (Busy Flag) is kept "High" (busy state) to the end of initialization.
(1) Display Clear instruction: Write " 20 H " to all DDRAM
(2) Set Functions instruction: DL = "High": 8-bit bus mode
$N=$ Low". 1-line display mode
$F=$ Low": $5 \times 8$ font type
(3) Control Display ON/OFF instruction: D = "Low". Display OFF

C = "Low". Cursor OFF
B = 'Low". Blink OFF
(4) Set Entry Mode instruction: I/D = "High": Increment by 1

> SH = "Low": No entire display shift

## FRAME FREQUENCY

Programmable Driving Method by the same font mask option: Display waveform A-Type, B-Type

1) $1 / 8$ duty cycle
A) A-type Waveform

B) B-type Waveform


1-Line selection period $=400$ clocks
1 Frame $\quad=400 \times 8 \times 3.7 \mu \mathrm{~s}=11850 \mu \mathrm{~s}=11.9 \mathrm{~ms}(1$ clock=3.7 $\mu \mathrm{s}$, fosc= 270 kHz )
Frame frequency $\quad=1 / 11.9 \mathrm{~ms}=84.4 \mathrm{~Hz}$

## simsung

2) $1 / 11$ duty cycle
A) A-type Waveform

B) B-type Waveform


1-Line selection period $=400$ clocks

1 Frame
$=400 \times 11 \times 3.7 \mu \mathrm{~s}=16300 \mu \mathrm{~s}=16.3 \mathrm{~ms}(1$ clock $=3.7 \mu \mathrm{~s}$, fosc $=270 \mathrm{kHz})$
Frame frequency $\quad=1 / 16.3 \mathrm{~ms}=61.4 \mathrm{~Hz}$
3) $1 / 16$ duty cycle
A) A-type Waveform

B) B-type Waveform


1-Line selection period $=200$ clocks

1 Frame $=200 \times 16 \times 3.7 \mu \mathrm{~s}=11850 \mu \mathrm{~s}=11.9 \mathrm{~ms}(1$ clock $=3.7 \mu \mathrm{~s}$, fosc $=270 \mathrm{kHz})$ $=1 / 11.9 \mathrm{~ms}=84.3 \mathrm{~Hz}$

## SAMSUNG

## INITIALIZING BY INSTRUCTION

1) 8 -bit interface mode (Condition: fosc $=270 \mathrm{KHZ}$ )



| $F$ | 0 | display off |
| :---: | :---: | :---: |
|  | 1 | display on |


| D | 0 | display off |
| :---: | :---: | :---: |
|  | 1 | display on |


| C | 0 | cursor off |
| :---: | :---: | :---: |
|  | 1 | cursor on |


| $B$ | 0 | blink off |
| :---: | :---: | :---: |
|  | 1 | blink on |



| SH | 0 | entire shift off |
| :---: | :---: | :---: |
|  | 1 | entire shift on |

## simsung

2) 4-bit interface mode (Condition: fosc $=270 \mathrm{KHZ}$ )


| $N$ | 0 | 1 -line mode |
| :---: | :---: | :---: |
|  | 1 | 2 -line mode |


| $F$ | 0 | display off |
| :---: | :---: | :---: |
|  | 1 | display on |



| C | 0 | cursor off |
| :---: | :---: | :---: |
|  | 1 | cursor on |


| $B$ | 0 | blink off |
| :---: | :---: | :---: |
|  | 1 | blink on |


| $I / D$ | 0 | decrement mode |
| :---: | :---: | :---: |
|  | 1 | increment mode |


| SH | 0 | entire shift off |
| :---: | :---: | :---: |
|  | 1 | entire shift on |

## simsung

## MAXIMUM ABSOLUTE LIMIT

Table 8. Maximum Absolute Power Ratings

| Characteristic | Symbol | Unit | Value |
| :---: | :---: | :---: | :---: |
| Power Supply Voltage(1) | $\mathrm{V}_{\mathrm{DD}}$ | V | $-0.3 \sim+7.0$ |
| Power Supply Voltage(2) | $\mathrm{V}_{\mathrm{LCD}}$ | V | $\mathrm{V}_{\mathrm{DD}}-15.0 \sim \mathrm{~V}_{\mathrm{DD}}+0.3$ |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | V | $-0.3 \sim \mathrm{~V}_{\mathrm{DD}}+0.3$ |

NOTE: Voltage greater than above may damage the circuit.

$$
\mathrm{V}_{\mathrm{DD}} \geq \mathrm{V} 1 \geq \mathrm{V} 2 \geq \mathrm{V} 3 \geq \mathrm{V} 4 \geq \mathrm{V} 5
$$

## Table 9. Temperature characteristics

| Characteristic | Symbol | Unit | Value |
| :---: | :---: | :---: | :---: |
| Operating Temperature | ToPR | ${ }^{\circ} \mathrm{C}$ | $-30 \sim+85$ |
| Storage Temperature | TSTG | ${ }^{\circ} \mathrm{C}$ | $-55 \sim+125$ |

## ELECTRICAL CHARACTERISTICS

## DC Characteristics

Table 10. DC Characteristics ( $\mathrm{V}_{\mathrm{DD}}=4.5 \mathrm{~V} \sim 5.5 \mathrm{~V}, \mathrm{Ta}=-\mathbf{3 0} \sim+85^{\circ} \mathrm{C}$ )

| Characteristic | Symbol | Condition | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Operating Voltage | $\mathrm{V}_{\mathrm{DD}}$ | - | 4.5 | - | 5.5 | V |
| Supply Current | IDD | Internal oscillation or external clock. $\left(\mathrm{V}_{\mathrm{DD}}=5.0 \mathrm{~V}, \text { fosc }=270 \mathrm{kHz}\right)$ | - | 0.35 | 0.6 | mA |
| Input Voltage (1) (except OSC1) | $\mathrm{V}_{\mathrm{H} 1}$ | - | 2.2 | - | $\mathrm{V}_{\mathrm{DD}}$ | V |
|  | $\mathrm{V}_{\text {IL1 }}$ | - | -0.3 | - | 0.6 |  |
| Input Voltage (2) (OSC1) | $\mathrm{V}_{\mathrm{H} 2}$ | - | $\mathrm{V}_{\mathrm{DD}}-1.0$ | - | $\mathrm{V}_{\mathrm{DD}}$ | V |
|  | $\mathrm{V}_{\mathrm{IL} 2}$ | - | -0.2 | - | 1.0 |  |
| Output Voltage (1) (DB0 to DB7) | $\mathrm{V}_{\mathrm{OH} 1}$ | $\mathrm{I}_{\mathrm{OH}}=-0.205 \mathrm{~mA}$ | 2.4 | - | - | V |
|  | $\mathrm{V}_{\text {OL1 }}$ | $\mathrm{I}_{\mathrm{OL}}=1.2 \mathrm{~mA}$ | - | - | 0.4 |  |
| Output Voltage (2) (except DB0 to DB7) | $\mathrm{V}_{\mathrm{OH} 2}$ | $\mathrm{I}_{\mathrm{O}}=-40 \mu \mathrm{~A}$ | $0.9 \mathrm{~V}_{\mathrm{DD}}$ | - | - | V |
|  | $\mathrm{V}_{\text {OL2 }}$ | $\mathrm{I}_{\mathrm{O}}=40 \mu \mathrm{~A}$ | - | - | $0.1 \mathrm{~V}_{\mathrm{DD}}$ |  |
| Voltage Drop | $\mathrm{Vd}_{\text {com }}$ | $\mathrm{I}_{0}= \pm 0.1 \mathrm{~mA}$ | - | - | 1 | V |
|  | $\mathrm{Vd}_{\text {SEG }}$ |  | - | - | 1 |  |
| Input Leakage Current | $\mathrm{I}_{\text {IKG }}$ | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{DD}}$ | -1 | - | 1 | $\mu \mathrm{A}$ |
| Input Low Current | IIL | $\begin{gathered} \mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{DD}}=5 \mathrm{~V} \\ \text { (PULL UP) } \end{gathered}$ | -50 | -125 | -250 |  |
| Internal Clock (external Rf) | $\mathrm{f}_{\text {OSC1 }}$ | $\begin{gathered} \mathrm{Rf}=91 \mathrm{k} \Omega \pm 2 \% \\ \left(\mathrm{~V}_{\mathrm{DD}}=5 \mathrm{~V}\right) \end{gathered}$ | 190 | 270 | 350 | kHz |
| External Clock | $\mathrm{f}_{\text {OSc }}$ | - | 125 | 270 | 410 | kHz |
|  | duty |  | 45 | 50 | 55 | \% |
|  | $\mathrm{t}_{\mathrm{R},} \mathrm{t}_{\mathrm{F}}$ |  | - | - | 0.2 | $\mu \mathrm{s}$ |
| LCD Driving Voltage | $\mathrm{V}_{\text {LCD }}$ | $\mathrm{V}_{\mathrm{DD}} \mathrm{V}_{5}(1 / 5,1 / 4$ Bias $)$ | 3.0 | - | 13.0 | V |

## simsung



| Characteristic | Symbol | Condition | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Operating Voltage | $\mathrm{V}_{\mathrm{DD}}$ | - | 2.7 | - | 4.5 | V |
| Supply Current | IDD | Internal oscillation or external clock. $\left(\mathrm{V}_{\mathrm{DD}}=3.0 \mathrm{~V}, \text { fosc }=270 \mathrm{kHz}\right)$ | - | 0.15 | 0.3 | mA |
| Input Voltage (1) (except OSC1) | $\mathrm{V}_{\mathrm{IH} 1}$ | - | $0.7 \mathrm{~V}_{\mathrm{DD}}$ | - | $\mathrm{V}_{\mathrm{DD}}$ | V |
|  | $\mathrm{V}_{\text {IL1 }}$ | - | -0.3 | - | 0.55 |  |
| $\begin{aligned} & \text { Input Voltage (2) } \\ & \text { (OSC1) } \end{aligned}$ | $\mathrm{V}_{\mathrm{H} 2}$ | - | $0.7 \mathrm{~V}_{\mathrm{DD}}$ | - | $\mathrm{V}_{\mathrm{DD}}$ | V |
|  | $\mathrm{V}_{\mathrm{IL} 2}$ | - | - | - | $0.2 \mathrm{~V}_{\mathrm{DD}}$ |  |
| Output Voltage (1) (DB0 to DB7) | $\mathrm{V}_{\text {OH1 }}$ | $\mathrm{l}_{\mathrm{OH}}=-0.1 \mathrm{~mA}$ | $0.75 \mathrm{~V}_{\mathrm{DD}}$ | - | - | V |
|  | $\mathrm{V}_{\text {OL1 }}$ | $\mathrm{I}_{\mathrm{OL}}=0.1 \mathrm{~mA}$ | - | - | $0.2 \mathrm{~V}_{\text {DD }}$ |  |
| Output Voltage (2) (except DB0 to DB7) | $\mathrm{V}_{\mathrm{OH} 2}$ | $\mathrm{I}_{\mathrm{O}}=-40 \mu \mathrm{~A}$ | $0.8 \mathrm{~V}_{\mathrm{DD}}$ | - | - | V |
|  | $\mathrm{V}_{\mathrm{OL} 2}$ | $\mathrm{I}_{\mathrm{O}}=40 \mu \mathrm{~A}$ | - | - | $0.2 \mathrm{~V}_{\mathrm{DD}}$ |  |
| Voltage Drop | $\mathrm{Vd}_{\text {COM }}$ | $\mathrm{l}= \pm 0.1 \mathrm{~mA}$ | - | - | 1 | V |
|  | $\mathrm{Vd}_{\text {SEG }}$ |  | - | - | 1 |  |
| Input Leakage Current | $\mathrm{I}_{\mathrm{IKG}}$ | $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{DD}}$ | -1 | - | 1 | $\mu \mathrm{A}$ |
| Input Low Current |  | $\begin{gathered} \hline \mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{DD}}=3 \mathrm{~V} \\ \text { (PULL UP) } \end{gathered}$ | -10 | -50 | -120 |  |
| Internal Clock (external Rf) | $\mathrm{f}_{\mathrm{osC1}}$ | $\begin{gathered} \mathrm{Rf}=75 \mathrm{k} \Omega \pm 2 \% \\ \left(\mathrm{~V}_{\mathrm{DD}}=3 \mathrm{~V}\right) \end{gathered}$ | 190 | 270 | 350 | kHz |
| External Clock | $\mathrm{f}_{\mathrm{OSC} 2}$ | - | 125 | 270 | 410 | kHz |
|  | duty |  | 45 | 50 | 55 | \% |
|  | $\mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{F}}$ |  | - | - | 0.2 | $\mu \mathrm{s}$ |
| LCD Driving Voltage | $\mathrm{V}_{\text {LCD }}$ | $\mathrm{V}_{\mathrm{DD}} \mathrm{V}_{5}(1 / 5,1 / 4$ Bias $)$ | 3.0 | - | 13.0 | V |

## NOTE: LCD Driving Voltage

| Power | Duty | $\mathbf{1 / 8}, \mathbf{1 / 1 1}$ Duty | $\mathbf{1 / 1 6}$ Duty |
| :---: | :---: | :---: | :---: |
|  | Bias | $\mathbf{1 / 4}$ Bias | $\mathbf{1 / 5}$ Bias |
|  | $\mathrm{V}_{\mathrm{DD}}$ | $\mathrm{V}_{\mathrm{DD}}$ | $\mathrm{V}_{\mathrm{DD}}$ |
| $\mathrm{V}_{1}$ | $\mathrm{~V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{LCD}} / 4$ | $\mathrm{~V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{LCD}} / 5$ |  |
| $\mathrm{~V}_{2}$ | $\mathrm{~V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{LCD}} / 2$ | $\mathrm{~V}_{\mathrm{DD}}-2 \mathrm{~V}_{\mathrm{LCD}} / 5$ |  |
| $\mathrm{~V}_{3}$ | $\mathrm{~V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{LCD}} / 2$ | $\mathrm{~V}_{\mathrm{DD}}-3 \mathrm{~V}_{\mathrm{LCD}} / 5$ |  |
| $\mathrm{~V}_{4}$ | $\mathrm{~V}_{\mathrm{DD}}-3 \mathrm{~V}_{\mathrm{LCD}} / 4$ | $\mathrm{~V}_{\mathrm{DD}}-4 \mathrm{~V}_{\mathrm{LCD}} / 5$ |  |
| $\mathrm{~V}_{5}$ | $\mathrm{~V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{LCD}}$ | $\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{LCD}}$ |  |

## AC Characteristics

Table 12. AC Characteristics ( $\mathrm{V}_{\mathrm{DD}}=4.5 \mathrm{~V} \sim 5.5 \mathrm{~V}, \mathrm{Ta}=-30 \sim+85^{\circ} \mathrm{C}$ )

| Mode | Characteristic | Symbol | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Write Mode (Refer to Fig-6) | E Cycle Time | tc | 500 | - | - | ns |
|  | E Rise / Fall Time | $\mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{F}}$ | - | - | 20 |  |
|  | E Pulse Width (High, Low) | tw | 230 | - | - |  |
|  | R/W and RS Setup Time | tsu1 | 40 | - | - |  |
|  | R/W and RS Hold Time | $\mathrm{t}_{\mathrm{H} 1}$ | 10 | - | - |  |
|  | Data Setup Time | tsu2 | 80 | - | - |  |
|  | Data Hold Time | $\mathrm{t}_{\mathrm{H} 2}$ | 10 | - | - |  |
| Read Mode (Refer to Fig-7) | E Cycle Time | tc | 500 | - | - | ns |
|  | E Rise / Fall Time | $\mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{F}}$ | - | - | 20 |  |
|  | E Pulse Width (High, Low) | tw | 230 | - | - |  |
|  | R/W and RS Setup Time | tsu | 40 | - | - |  |
|  | R/W and RS Hold Time | $\mathrm{t}_{\mathrm{H}}$ | 10 | - | - |  |
|  | Data Output Delay Time | $t_{D}$ | - | - | 120 |  |
|  | Data Hold Time | $\mathrm{t}_{\mathrm{DH}}$ | 5 | - | - |  |

Table 13. AC Characteristics ( $\mathrm{V}_{\mathrm{DD}}=\mathbf{2 . 7 \mathrm { V }} \sim \mathbf{4 . 5 V}, \mathrm{Ta}=-\mathbf{3 0} \sim+85^{\circ} \mathrm{C}$ )

| Mode | Characteristic | Symbol | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Write Mode (Refer to Fig-6) | E Cycle Time | tc | 1000 | - | - | ns |
|  | E Rise / Fall Time | $\mathrm{t}_{\mathrm{R}} \mathrm{t}_{\mathrm{F}}$ | - | - | 25 |  |
|  | E Pulse Width (High, Low) | tw | 450 | - | - |  |
|  | R/W and RS Setup Time | tsu1 | 60 | - | - |  |
|  | R/W and RS Hold Time | $\mathrm{t}_{\mathrm{H} 1}$ | 20 | - | - |  |
|  | Data Setup Time | tsu2 | 195 | - | - |  |
|  | Data Hold Time | $\mathrm{t}_{\mathrm{H} 2}$ | 10 | - | - |  |
| Read Mode (Refer to Fig-7) | E Cycle Time | tc | 1000 | - | - | ns |
|  | E Rise / Fall Time | $\mathrm{t}_{\mathrm{R},} \mathrm{t}_{\mathrm{F}}$ | - | - | 25 |  |
|  | E Pulse Width (High, Low) | tw | 450 | - | - |  |
|  | R/W and RS Setup Time | tsu | 60 | - | - |  |
|  | R/W and RS Hold Time | $\mathrm{t}_{\mathrm{H}}$ | 20 | - | - |  |
|  | Data Output Delay Time | $\mathrm{t}_{\mathrm{D}}$ | - | - | 360 |  |
|  | Data Hold Time | $t_{\text {DH }}$ | 5 | - | - |  |

## simsung

Table 14. AC Characteristics ( $\mathrm{V}_{\mathrm{DD}}=2.7 \mathrm{~V} \sim 4.5 \mathrm{~V}, \mathrm{Ta}=-30 \sim+85^{\circ} \mathrm{C}$ )

| Mode | Characteristic | Symbol | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| Interface Mode <br> with | Clock Pulse Width (High, Low) | tc | 800 | - | - |  |
|  | Clock Rise / Fall Time | $\mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{F}}$ | - | - | 25 |  |
|  | Clock Setup Time | tsu1 | 500 | - | - |  |
|  | Data Setup Time | tsu2 | 300 | - | - |  |
|  | Data Hold Time | $\mathrm{t}_{\mathrm{DH}}$ | 300 | - | - |  |
|  | M Delay Time | $\mathrm{t}_{\mathrm{DM}}$ | -1000 | - | 1000 |  |



Figure 6 . Write Mode Timing Diagram


Figure 7. Read Mode Timing Diagram

## simsung



Figure 8. Interface Mode With Extension Driver Timing Diagram

## 80-QFP-1420C




[^0]:    $* * *$ Supply voltage for logic system $=5 \mathrm{~V}$. Supply voltage for LCD system $=$ Operating voltage at $25^{\circ} \mathrm{C}$

