## DATA SHEET

# PCF2104x LCD controller/driver 

Product specification
Supersedes data of 1997 Apr 01
File under Integrated Circuits, IC12

## CONTENTS

| 1 | FEATURES |
| :--- | :--- |
| 2 | APPLICATIONS |
| 3 | GENERAL DESCRIPTION |

$3.1 \quad$ Packages
3.2 Available types

4 ORDERING INFORMATION
5 BLOCK DIAGRAM

6 PINNING

## 7 PIN FUNCTIONS

7.1 RS: register select (parallel control)
7.2 R/W: read/write (parallel control)
7.3 E: data bus clock (parallel control)
7.4 DB0 to DB7: data bus (parallel control)
7.5 $\quad$ C1 to C60: column driver outputs
7.6 R1 to R32: row driver outputs
7.7 VLCD: LCD power supply
7.8 OSC: oscillator
7.9 SCL: serial clock line
7.10 SDA: serial data line
7.11 SAO: address pin
7.12 T1: test pad

8 FUNCTIONAL DESCRIPTION
8.1 LCD bias voltage generator
8.2 Oscillator
8.3 External clock
8.4 Power-on reset
8.5 Registers
8.6 Busy Flag
8.7 Address Counter (AC)
8.8 Display data RAM (DDRAM)
$8.9 \quad$ Character generator ROM (CGROM)
8.10 Character generator RAM (CGRAM)
8.11 Cursor control circuit
8.12 Timing generator
8.13 LCD row and column drivers
8.14 Programming of MUX 1:16 displays with PCF2104x
8.15 Programming of MUX 1:32 displays with PCF2104x
8.16 Reset function

9 INSTRUCTIONS
9.1 Clear display
9.2 Return home
9.3 Entry mode set
9.3.1 I/D
9.3.2 S
9.4 Display on/off control
9.4.1 D
9.4.2 C
9.4.3 B
9.5 Cursor/display shift
9.6 Function set
9.6.1 DL (parallel mode only)
9.6.2 N, M
9.7 Set CGRAM address
9.8 Set DDRAM address
9.9 Read busy flag and address
9.10 Write data to CGRAM or DDRAM
9.11 Read data from CGRAM or DDRAM

10

11
11.1
11.2
11.3
11.4
11.5
11.6

12
13
14
15
16
17

INTERFACE TO MICROCONTROLLER
(PARALLEL INTERFACE)
INTERFACE TO MICROCONTROLLER
( ${ }^{2} \mathrm{C}-\mathrm{BUS}$ INTERFACE)
Characteristics of the $\mathrm{I}^{2} \mathrm{C}$-bus
Bit transfer
Start and stop conditions
System configuration
Acknowledge
${ }^{2}$ ²-bus protocol
LIMITING VALUES
HANDLING
DC CHARACTERISTICS
AC CHARACTERISTICS
TIMING DIAGRAMS
APPLICATION INFORMATION
8 -bit operation, $2 \times 12$ display using internal reset
4-bit operation, $2 \times 12$ display using internal reset
8 -bit operation, $2 \times 24$ display
$\mathrm{I}^{2} \mathrm{C}$ operation, $2 \times 12$ display
Initializing by instruction
BONDING PAD LOCATIONS
DEFINITIONS
LIFE SUPPORT APPLICATIONS
PURCHASE OF PHILIPS ${ }^{2} \mathrm{C}$ COMPONENTS

## 1 FEATURES

- Single chip LCD controller/driver
- 1 or 2-line display of up to 24 characters per line, or

2 or 4 lines of up to 12 characters per line

- $5 \times 7$ character format plus cursor; $5 \times 8$ for kana (Japanese syllabary) and user-defined symbols
- On-chip:
- generation of intermediate LCD bias voltages
- oscillator requires no external components (external clock also possible)
- Display data RAM: 80 characters
- Character generator ROM: 240 characters
- Character generator RAM: 16 characters
- 4 or 8 -bit parallel bus or 2 -wire $\mathrm{I}^{2} \mathrm{C}$-bus interface
- CMOS/TTL compatible
- 32 row, 60 column outputs
- MUX rates 1:32 and 1:16
- Uses common 11 code instruction set
- Logic supply voltage range, $\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{SS}}: 2.5$ to 6 V
- Display supply voltage range, $\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{LCD}}: 3.5$ to 9 V
- Low power consumption.
- ${ }^{2}$ C-bus address: 011101 SA0.


## 2 APPLICATIONS

- Telecom equipment
- Portable instruments
- Point-of-sale terminals.


## 3 GENERAL DESCRIPTION

The PCF2104x integrated circuit is similar to the PCF2114x (described in the "PCF2116 family"data sheet)
but does not contain the high voltage generator of that device.

The PCF2104x is optimized for chip-on-glass applications. The ' $x$ ' in 'PCF2104x' represents a specific letter code for a character set in the character generator ROM (CGROM).

Two standard character sets are currently available, specified by the letters ' $C$ ' and ' $L$ ' (see Figs 5 and 6 ). Other character sets are available on request.
The PCF2104x is a low-power CMOS LCD controller and driver, designed to drive a split screen dot matrix LCD display of 1 or 2 lines by 24 characters or 2 or 4 lines by 12 characters with a $5 \times 8$ dot format. All necessary functions for the display are provided in a single chip, including on-chip generation of LCD bias voltages which results in a minimum of external components and lower system power consumption. To allow partial $\mathrm{V}_{\mathrm{DD}}$ shutdown the ESD protection system of the SCL and SDA pins does not use a diode connected to $V_{D D}$.

The chip contains a character generator and displays alphanumeric and kana characters. The PCF2104x interfaces to most microcontrollers via a 4 or 8 -bit bus, or via the 2 -wire $\mathrm{I}^{2} \mathrm{C}$-bus.

### 3.1 Packages

- PCF2104xU/2; chip with bumps in tray
- PCF2104xU/7; chip with bumps on tape.

For further details see Chapter 18.

### 3.2 Available types

- PCF2104CU/x: character set 'C' in CGROM
- PCF2104LU/x: character set 'L' in CGROM
- PCF2104NU/x: character set ' $N$ ' in CGROM.


## 4 ORDERING INFORMATION

| TYPE NUMBER | PACKAGE |  |  |
| :--- | :---: | :--- | :---: |
|  | NAME | DESCRIPTION | VERSION |
| PCF2104CU/2 | - | chip with bumps in tray | - |
| PCF2104CU/7 | - | chip with bumps on tape | - |
| PCF2104LU/2 | - | chip with bumps in tray | - |
| PCF2104LU/7 | - | chip with bumps on tape | - |
| PCF2104NU/2 | - | chip with bumps in tray | - |
| PCF2104NU/7 | - | chip with bumps on tape | - |

5 BLOCK DIAGRAM


Fig. 1 Block diagram.

## 6 PINNING

| SYMBOL | FFC PAD | TYPE | DESCRIPTION |
| :--- | :---: | :---: | :--- |
| OSC | 1 | I | oscillator/external clock input |
| V $_{\text {DD }}$ | 2 | P | logic supply voltage |
| SA0 | 3 | I | I $^{2}$ C-bus address pin input |
| V $_{\text {SS }}$ | 4 | P | ground |
| R8 to R5 | 5 to 8 | O | LCD row driver outputs |
| R32 to R29 | 9 to12 | O | LCD row driver outputs |
| R24 to R17 | 13 to 20 | O | LCD row driver outputs |
| C60 to C1 | 21 to 80 | O | LCD column driver outputs |
| R9 to R16 | 81 to 88 | O | LCD row driver outputs |
| R25 to R28 | 89 to 92 | O | LCD row driver outputs |
| R1 to R4 | 93 to 96 | O | LCD row driver outputs |
| SCL | 97 | I | I $^{2} C$-bus serial clock input |
| E | 98 | I | data bus clock input |
| RS | 99 | I | register select input |
| R/W | 100 | I | read/write input |
| T1 | 101 | I | test pad input |
| DB7 to DB0 | 102 to 109 | I/O | 8-bit bidirectional data bus input/output |
| SDA | 110 | I/O | I $^{2} C$-bus serial data input/output |
| VLCD | 111 | I | LCD supply voltage input |

## 7 PIN FUNCTIONS

### 7.1 RS: register select (parallel control)

RS selects the register to be accessed for read and write when the device is controlled by the parallel interface.
RS = logic 0 selects the instruction register for write and the Busy Flag and Address Counter for read. RS = logic 1 selects the data register for both read and write. There is an internal pull-up on pin RS.

### 7.2 R//W: read/write (parallel control)

$R / \bar{W}$ selects either the read ( $R / \bar{W}=$ logic 1 ) or write ( $R / \bar{W}=$ logic 0 ) operation when control is by the parallel interface. There is an internal pull-up on this pin.

### 7.3 E: data bus clock (parallel control)

The E pin is set HIGH to signal the start of a read or write operation when the device is controlled by the parallel interface. Data is clocked in or out of the chip on the negative edge of the clock. Note that this pin must be tied to logic $0\left(\mathrm{~V}_{\mathrm{SS}}\right)$ when $\mathrm{I}^{2} \mathrm{C}$-bus control is used.

### 7.4 DB0 to DB7: data bus (parallel control)

The bidirectional, 3-state data bus transfers data between the system controller and the PCF2104x. DB7 may be used as the Busy Flag, signalling that internal operations are not yet completed. In 4 -bit operations the 4 higher order lines DB4 to DB7 are used; DB0 to DB3 must be left open circuit. There is an internal pull-up on each of the data lines. Note that these pins must be left open circuit when $\mathrm{I}^{2} \mathrm{C}$-bus control is used.

### 7.5 C1 to C60: column driver outputs

These pins output the data for pairs of columns.
This arrangement permits optimized chip-on-glass (COG) layout for 4 -line by 12 characters.

### 7.6 R1 to R32: row driver outputs

These pins output the row select waveforms to the left and right halves of the display.

### 7.7 VLCD: LCD power supply

Negative power supply for the liquid crystal display.

### 7.8 OSC: oscillator

When the on-chip oscillator is used, this pin must be connected to $\mathrm{V}_{\mathrm{DD}}$. An external clock signal, if used, is input at this pin.

### 7.9 SCL: serial clock line

Input for the $\mathrm{I}^{2} \mathrm{C}$-bus clock signal.

### 7.10 SDA: serial data line

Input/output for the $\mathrm{I}^{2} \mathrm{C}$-bus data line.

### 7.11 SAO: address pin

The hardware sub-address line is used to program the device sub-address for 2 different PCF2104xs on the same $\mathrm{I}^{2} \mathrm{C}$-bus.

### 7.12 T1: test pad

Must be connected to $\mathrm{V}_{\mathrm{Ss}}$. Not user accessible.

## 8 FUNCTIONAL DESCRIPTION (see Fig.1)

### 8.1 LCD bias voltage generator

The intermediate bias voltages for the LCD display are also generated on-chip. This removes the need for an external resistive bias chain and significantly reduces the system power consumption. The optimum levels depend on the multiplex rate and are selected automatically when the number of lines in the display is defined.

The optimum value of $\mathrm{V}_{\mathrm{OP}}$ depends on the multiplex rate, the LCD threshold voltage $\left(\mathrm{V}_{\mathrm{th}}\right)$ and the number of bias levels. The relationships are given in Table 1.

Using a 5-level bias scheme for $1: 16$ MUX rate allows $\mathrm{V}_{\mathrm{OP}}<5 \mathrm{~V}$ for most LCD liquids. The effect on the display contrast is negligible.

Table 1 Optimum values for $V_{O P}$

| MUX <br> RATE | NUMBER <br> OF BIAS <br> LEVELS | $\mathbf{V}_{\text {OP }} / \mathbf{v}_{\text {th }}$ | DISCRIMINATION <br> $\mathbf{V}_{\text {on }} / \mathbf{V}_{\text {off }}$ |
| :---: | :---: | :---: | :---: |
| $1: 16$ | 5 | 3.67 | 1.277 |
| $1: 32$ | 6 | 5.19 | 1.196 |

### 8.2 Oscillator

The on-chip oscillator provides the clock signal for the display system. No external components are required. Pin OSC must be connected to $\mathrm{V}_{\mathrm{DD}}$.

### 8.3 External clock

If an external clock is to be used, it must be input at pin OSC. The resulting display frame frequency is given by $f_{\text {frame }}=1 / 2304 f_{\text {osc }}$. A clock signal must always be present, otherwise the LCD may be frozen in a DC state.

### 8.4 Power-on reset

The Power-on reset block initializes the chip after power-on or power failure.

### 8.5 Registers

The PCF2104x has two 8-bit registers, an instruction register (IR) and a data register (DR). The register select signal (RS) determines which register will be accessed.

The instruction register stores instruction codes such as display clear and cursor shift, and address information for the Display Data RAM (DDRAM) and Character Generator RAM (CGRAM). The instruction register can be written to, but not read from, by the system controller.

The data register temporarily stores data to be read from the DDRAM and CGRAM. When reading, data from the DDRAM or CGRAM (corresponding to the address in the Address Counter) is written to the data register prior to being read by the 'Read data' instruction.

### 8.6 Busy Flag

The Busy Flag indicates the free/busy status of the PCF2104x. Logic 1 indicates that the chip is busy and further instructions will not be accepted. The Busy Flag is output at pin DB7 when $R S=\operatorname{logic} 0$ and $R / \bar{W}=\operatorname{logic} 1$. Instructions should only be written after checking that the Busy Flag is at logic 0 or waiting for the required number of clock cycles.

### 8.7 Address Counter (AC)

The Address Counter assigns addresses to the DDRAM and CGRAM for reading and writing and is set by the instructions 'Set CGRAM address' and
'Set DDRAM address'. After a read/write operation the Address Counter is automatically incremented or decremented by 1. The Address Counter contents are output to the bus (DB0 to DB6) when RS = logic 0 and $R / \bar{W}=\operatorname{logic} 1$.

### 8.8 Display data RAM (DDRAM)

The DDRAM stores up to 80 characters of display data, represented by 8 -bit character codes. DDRAM locations not used for storing display data can be used as general purpose RAM. The basic DDRAM-to-display mapping scheme is shown in Fig.2. With no display shift, the characters represented by the codes in the first 12 or 24 RAM locations, starting at address 00 in line 1, are displayed. Subsequent lines display data starting at addresses 20, 40, or 60 Hex. Figures 3 and 4 show the DDRAM-to-display mapping scheme when the display is shifted.
The address range for a 1 -line display is 00 to 4 F ; for a 2-line display from 00 to 27 (line 1) and 40 to 67 (line 2); for a 4 -line display from 00 to 13,20 to 33,40 to 53 and 60 to 73 for lines 1, 2, 3 and 4 respectively. For 2 and 4 -line displays the end address of one line and the start address of the next line are not consecutive. When the display is shifted each line wraps around independently of the others (see Figs 3 and 4).
When data is written to the DDRAM wrap-around occurs from 4 F to 00 in 1 -line mode and from 27 to 40 and 67 to 00 in 2-line mode; from 13 to 20,33 to 40,53 to 60 and 73 to 00 in 4 -line mode.

### 8.9 Character generator ROM (CGROM)

The character generator ROM generates 240 character patterns in $5 \times 8$ dot format from 8 -bit character codes. Figures 5 and 6 show the character sets currently available.

### 8.10 Character generator RAM (CGRAM)

Up to 16 user-defined characters may be stored in the character generator RAM. The CGROM and CGRAM use a common address space, of which the first column is reserved for the CGRAM (see Fig.5). Figure 8 shows the addressing principle for the CGRAM.

### 8.11 Cursor control circuit

The cursor control circuit generates the cursor (underline and/or character blink as shown in Fig.9) at the DDRAM address contained in the Address Counter. When the Address Counter contains the CGRAM address the cursor will be inhibited.

### 8.12 Timing generator

The timing generator produces the various signals required to drive the internal circuitry. Internal chip operation is not disturbed by operations on the data buses.

### 8.13 LCD row and column drivers

The PCF2104x contains 32 row and 60 column drivers, which connect the appropriate LCD bias voltages in sequence to the display, in accordance with the data to be displayed. The bias voltages and the timing are selected automatically when the number of lines in the display is selected. Figures 10 and 11 show typical waveforms.
In the 1 -line mode ( $1: 16$ ) the row outputs are driven in pairs: R1/R17, R2/R18 for example. This allows the output pairs to be connected in parallel, thereby providing greater drive capability.
Unused outputs should be left unconnected.


Fig. 2 DDRAM-to-display mapping; no shift (PCF2104x).

## LCD controller/driver



Fig. 3 DDRAM-to-display mapping; right shift (PCF2104x).


Fig. 4 DDRAM-to-display mapping; left shift (PCF2104x).


Fig. 5 Character set ' $C$ ' in CGROM; PCF2104C.


Fig. 6 Character set 'L' in CGROM; PCF2104L.


Fig. 7 Character set ' N ' in CGROM; PCF2104N.


Character code bits 0 to 3 correspond to CGRAM address bits 3 to 6 .
CGRAM address bits 0 to 2 designate character pattern line position. The $8^{\text {th }}$ line is the cursor position and display is performed by logical OR with the cursor. Data in the $8^{\text {th }}$ line will appear in the cursor position.
Character pattern column positions correspond to CGRAM data bits 0 to 4 ; bit 4 being at the left end, as shown in the figure.
CGRAM character patterns are selected when character code bits 4 to 7 are all logic 0 . CGRAM data $=$ logic 1 corresponds to selection for display.
Only bits 0 to 5 of the CGRAM address are set by the 'Set CGRAM address' instruction. Bit 6 can be set using the 'Set DDRAM address' instruction or by using the auto-increment feature during CGRAM write. All bits 0 to 6 can be read using the 'Read Busy Flag and address' instruction.

Fig. 8 Relationship between CGRAM addresses, data and display patterns.


Fig. 9 Cursor and blink display examples.


Fig. 10 Typical LCD waveforms; 1 -line mode.


Fig. 11 Typical LCD waveforms; 2-line mode.

### 8.14 Programming of MUX 1 : 16 displays with PCF2104x

The PCF2104x can be used in the following ways:

- 1-line mode to drive a 2 -line display
- $2 \times 12$ characters with MUX rate $1: 16$, resulting in better contrast. The internal data flow of the chip is optimized for this purpose.

Using the 'Function set' instruction, M and N are set to 0,0 (respectively). Figures 12, 13 and 14 show the DDRAM addresses of the display characters. The second row of each table corresponds to either the right half of a 1 -line display or to the second line of a 2 -line display. Wrap around of data during display shift or when writing data is non-standard.

| display position | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DDRAM address |  |  |  |  |  |  |  |  |  |  |  |  | |  | 00 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | $0 A$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

Fig. 12 DDRAM-to-display mapping; no shift (PCF2104x).


Fig. 13 DDRAM-to-display mapping; right shift (PCF2104x).


Fig. 14 DDRAM-to-display mapping; left shift (PCF2104x).

## LCD controller/driver

### 8.15 Programming of MUX 1: 32 displays with PCF2104x

To drive a 2 -line by 24 characters MUX 1: 32 display, use instruction 'Function set' to set $\mathrm{M}, \mathrm{N}$ to 0,1 (respectively).
To drive a 4-line by 12 characters MUX 1:32 display, use instruction 'Function set' to set M, N to 1, 1 (respectively).

### 8.16 Reset function

The PCF2104 automatically initializes (resets) when power is turned on. The state after reset is given in Table 2.

Table 2 State after reset

| STEP | DESCRIPTION |
| :---: | :---: |
| 1 | Display clear. |
| 2 | Function set: <br> $D L=1: 8$-bit interface <br> $\mathrm{M}, \mathrm{N}=0$ 1-line display <br> $\mathrm{G}=0$ : not used |
| 3 | Display on/off control: <br> $\mathrm{D}=0$ : display off <br> C = 0: cursor off; <br> B = 0: blink off; |
| 4 | Entry mode set: <br> I/D = 1: +1 (increment) <br> $\mathrm{G}=0$ : not used |
| 5 | Default address pointer to DDRAM. The Busy Flag (BF) indicates the busy state (BF = logic 1) until initialization ends. The busy state lasts 2 ms . The chip may also be initialized by software. See Tables 10 and 11. |
| 6 | $1^{2} \mathrm{C}$-bus interface reset. |

## 9 INSTRUCTIONS

Only two PCF2104x registers, the instruction register (IR) and the data register (DR) can be directly controlled by the microcontroller. Before internal operation, control information is stored temporarily in these registers to allow interface to various types of microcontrollers which operate at different speeds or to allow interfacing to peripheral control ICs.
The PCF2104x operation is controlled by the instructions shown in Table 3 together with their execution time. Details are explained in subsequent sections.

Instructions are of 4 categories, those that:

1. Designate PCF2104x functions such as display format, data length, etc.
2. Set internal RAM addresses
3. Perform data transfer with internal RAM
4. Others.

In normal use, category 3 instructions are used most frequently. However, automatic incrementing by 1 (or decrementing by 1 ) of internal RAM addresses after each data write lessens the microcontroller program load. The display shift in particular can be performed concurrently with display data write, thus enabling the designer to develop systems in minimum time with maximum programming efficiency.
During internal operation, no instruction other than the Busy Flag/address read instruction will be executed.

Because the Busy Flag is set to logic 1 while an instruction is being executed, it is advisable to ensure that the flag it is at logic 0 before sending the next instruction or wait for the maximum instruction execution time, as given in Table 3. An instruction sent while the Busy Flag is HIGH will not be executed.

| INSTRUCTION | RS | R／TW | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | DESCRIPTION | $\begin{aligned} & \text { REQUIRED } \\ & \text { CLOCK } \\ & \text { CYCLES } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NOP | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | No operation． | 0 |
| Clear display | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | Clears entire display and sets DDRAM address 0 in Address Counter． | 165 |
| Return home | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | Sets DDRAM address 0 in Address Counter Also returns shifted display to original position DDRAM contents remain unchanged． | 3 |
| Entry mode set | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | I／D | S | Sets cursor move direction and specifies shift of display．These operations are performed during data write and read． | 3 |
| Display control | 0 | 0 | 0 | 0 | 0 | 0 | 1 | D | C | B | Sets entire display on／off（D），cursor on／off（C） and blink of cursor position character（B）． | 3 |
| Cursor／display shift | 0 | 0 | 0 | 0 | 0 | 1 | S／C | R／L | 0 | 0 | Moves cursor and shifts display without changing DDRAM contents． | 3 |
| Function set | 0 | 0 | 0 | 0 | 1 | DL | N | M | G | 0 | Sets interface data length（DL），number of display lines（ $\mathrm{N}, \mathrm{M}$ ）and voltage generator control（G）． | 3 |
| Set CGRAM address | 0 | 0 | 0 | 1 | $\mathrm{A}_{\text {CG }}$ |  |  |  |  |  | Sets CGRAM address． | 3 |
| Set DDRAM address | 0 | 0 | 1 | $\mathrm{A}_{\text {DD }}$ |  |  |  |  |  |  | Sets DDRAM address． | 3 |
| Read busy flag and address | 0 | 1 | BF | $\mathrm{A}_{\mathrm{C}}$ |  |  |  |  |  |  | Reads Busy Flag（BF）indicating internal operation is being performed and reads Address Counter contents． | 0 |
| Read data | 1 | 1 | read data |  |  |  |  |  |  |  | Reads data from CGRAM or DDRAM． | 3 |
| Write data | 1 | 0 | write data |  |  |  |  |  |  |  | Writes data to CGRAM or DDRAM． | 3 |

## Notes

1．In the $\mathrm{I}^{2} \mathrm{C}$－bus mode the DL bit is don＇t care． 8 －bit mode is assumed．
In the $\mathrm{I}^{2} \mathrm{C}$－bus mode a control byte is required when RS or $\mathrm{R} / \overline{\mathrm{W}}$ is changed；control byte： $\mathrm{Co}, \mathrm{RS}, \mathrm{R} / \overline{\mathrm{W}}, 0,0,0,0,0$ ；command byte：DB7 to DB 0 ．
2．Example： $\mathrm{f}_{\mathrm{osc}}=150 \mathrm{kHz}, \mathrm{T}_{\mathrm{cy}}=\frac{1}{\mathrm{f}_{\mathrm{osc}}}=6.67 \mu \mathrm{~s} ; 3$ cycles $=20 \mu \mathrm{~s}, 165$ cycles $=1.1 \mathrm{~ms}$ ．

## LCD controller/driver

PCF2104x

Table 4 Command bit identities

| BIT | LOGIC 0 |  |
| :--- | :--- | :--- |
| I/D | decrement | increment |
| S | display freeze | display shift |
| D | display off | display on |
| C | Cursor off | cursor on |
| B | character at cursor position does not blink | character at cursor position blinks |
| S/C | cursor move | display shift |
| R/L | left shift | right shift |
| DL | 4 bits | 8 bits |
| N $(\mathrm{M}=0)$ | 2 line $\times$ 12 characters; MUX 1: 16 | 2 lines $\times$ 24 characters; MUX 1 : 32 |
| N $(\mathrm{M}=1)$ | reserved | 4 lines $\times 12$ characters; MUX 1 : 32 |
| BF | end of internal operation | internal operation in progress |
| Co | last control byte, only data bytes to follow | next two bytes are a data byte and another control byte |



Fig. 15 4-bit transfer example.


Fig. 16 An example of 4-bit data transfer timing sequence.


Fig. 17 Example of Busy Flag check timing sequence.

### 9.1 Clear display

'Clear display' writes space code 20 (hexadecimal) into all DDRAM addresses (the character pattern for character code 20 must be a blank pattern), sets the DDRAM Address Counter to logic 0 and returns the display to its original position if it was shifted. Consequently, the display disappears and the cursor or blink position goes to the left edge of the display (the first line if 2 or 4 lines are displayed) and sets the entry mode to $1 / D=$ logic 1 (increment mode). S of entry mode does not change.

The instruction 'Clear display' requires extra execution time. This may be allowed for by checking the Busy Flag (BF) or by waiting until 2 ms has elapsed. The latter must be applied where no read-back options are foreseen, as in some chip-on-glass (COG) applications.

### 9.2 Return home

'Return home' sets the DDRAM Address Counter to logic 0 and returns the display to its original position if it was shifted. DDRAM contents do not change. The cursor or blink position goes to the left of the display (the first line if 2 or 4 lines are displayed). I/D and $S$ of entry mode do not change.

### 9.3 Entry mode set

### 9.3.1 I/D

When I/D = logic 1 (0) the DDRAM or CGRAM address increments (decrements) by 1 when data is written to or read from the DDRAM or CGRAM. The cursor or blink position moves to the right when incremented and to the left when decremented. The cursor and blink are inhibited when the CGRAM is accessed.

### 9.3.2 S

When $S=\operatorname{logic} 1$, the entire display shifts either to the right (I/D = logic 0 ) or to the left (I/D = logic 1 ) during a DDRAM write. Consequently, it looks as if the cursor stands still and the display moves. The display does not shift when reading from the DDRAM, or when writing to or reading from the CGRAM. When $S=$ logic 0 the display does not shift.

### 9.4 Display on/off control

### 9.4.1 D

The display is on when $\mathrm{D}=$ logic 1 and off when $\mathrm{D}=$ logic 0 . Display data in the DDRAM is not affected and can be displayed immediately by setting $D$ to logic 1 .

### 9.4.2 C

The cursor is displayed when $\mathrm{C}=\operatorname{logic} 1$ and inhibited when $\mathrm{C}=\operatorname{logic} 0$. Even if the cursor disappears, the display functions $I / D$, etc. remain in operation during display data write. The cursor is displayed using 5 dots in the 8th line (see Fig.9).

### 9.4.3 B

The character indicated by the cursor blinks when $B=\operatorname{logic} 1$. The blink is displayed by switching between display characters and all dots on with a period of 1 second when $f_{\text {osc }}=150 \mathrm{kHz}$ (see Fig.9). At other clock frequencies the blink period is equal to $150 \mathrm{kHz} / \mathrm{f}_{\text {osc }}$. The cursor and the blink can be set to display simultaneously.

### 9.5 Cursor/display shift

'Cursor/display shift' moves the cursor position or the display to the right or left without writing or reading display data. This function is used to correct a character or move the cursor through the display. In 2 or 4 -line displays, the cursor moves to the next line when it passes the last position of the line ( 40 or 20 decimal). When the displayed data is shifted repeatedly all lines shift at the same time; displayed characters do not shift into the next line. The Address Counter (AC) content does not change if the only action performed is shift display, but increments or decrements with the cursor shift.

### 9.6 Function set

### 9.6.1 DL (PARALLEL MODE ONLY)

Sets interface data width. Data is sent or received in bytes (DB7 to DB0) when DL = logic 1 or in two nibbles (DB7 to DB4) when DL $=$ logic 0 . When 4 -bit width is selected, data is transmitted in two cycles using the parallel bus ${ }^{(1)}$.
Function set from $\mathrm{I}^{2} \mathrm{C}$-bus interface: DL bit can not bet set to logic 0 from the $\mathrm{I}^{2} \mathrm{C}$-bus interface. If bit DL has been set to logic 0 via the parallel bus, programming via the $I^{2} \mathrm{C}$-bus interface is complicated.

### 9.6.2 N, M

Sets number of display lines.
(1) In a 4-bit application DB3 to DB0 are left open (internal pull-ups). Hence in the first function set instruction after power-on $G$ and $H$ are set to 1 . A second function set must then be sent ( 2 nibbles) to set $G$ and $H$ to their required values.

### 9.7 Set CGRAM address

'Set CGRAM address' sets bits 0 to 5 of the CGRAM address ( $\mathrm{A}_{\mathrm{CG}}$ in Table 3) into the Address Counter (binary $A[5]$ to $A[0])$. Data can then be written to or read from the CGRAM.

Only bits 0 to 5 of the CGRAM address are set by the 'Set CGRAM address' instruction. Bit 6 can be set using the 'Set DDRAM address' instruction or by using the auto-increment feature during CGRAM write. All bits 0 to 6 can be read using the 'Read busy flag and address' instruction.

### 9.8 Set DDRAM address

Set DDRAM address sets the DDRAM address ( $A_{D D}$ in Table 3) into the Address Counter (binary A[6] to A[0). Data can then be written to or read from the DDRAM.

Table 5 Hexadecimal address ranges

| ADDRESS | FUNCTION |
| :--- | :--- |
| 00 to 4 F | 1 -line by 24 |
| 00 to 0 B and 0 C to 4 F | 2 -line by 12 |
| 00 to 27 and 40 to 67 | 2 -line by 24 |
| 00 to 13,20 to 33,40 to 53 <br> and 60 to 73 | 4 -line by 12 |

### 9.9 Read busy flag and address

'Read busy flag and address' reads the Busy Flag (BF). When $\mathrm{BF}=$ logic 1 it indicates that an internal operation is in progress. The next instruction will not be executed until $B F=$ logic 0 , so $B F$ should be checked before sending another instruction.

At the same time, the value of the Address Counter expressed in binary $A[6]$ to $A[0]$ is read out. The Address Counter is used by both CGRAM and DDRAM and its value is determined by the previous instruction.

### 9.10 Write data to CGRAM or DDRAM

Writes binary 8 -bit data $\mathrm{D}[7]$ to $\mathrm{D}[0]$ to the CGRAM or the DDRAM.

Whether the CGRAM or DDRAM is to be written to is determined by the previous specification of CGRAM or DDRAM address setting. After writing, the address automatically increments or decrements by 1 , in accordance with the entry mode. Only bits D0 to D4 of CGRAM data are valid, bits D5 to D7 are 'don't care'.

### 9.11 Read data from CGRAM or DDRAM

Reads binary 8-bit data $D[7]$ to $D[0]$ from the CGRAM or DDRAM.

The most recent 'Set address' instruction determines whether the CGRAM or DDRAM is to be read.

The 'Read data' instruction gates the content of the data register (DR) to the bus while $\mathrm{E}=\mathrm{HIGH}$. After E goes LOW again, internal operation increments (or decrements) the AC and stores RAM data corresponding to the new AC into the DR.

Remark: the only three instructions that update the data register (DR) are:

- 'Set CGRAM address'
- 'Set DDRAM address'
- 'Read data' from CGRAM or DDRAM.

Other instructions (e.g. 'Write data, 'Cursor/display shift', 'Clear display', 'Return home') will not modify the data register content.

## 10 INTERFACE TO MICROCONTROLLER (PARALLEL INTERFACE)

The PCF2104x can send data in either two 4-bit operations or one 8 -bit operation and can thus interface to 4 -bit or 8 -bit microcontrollers.

In the 8-bit mode data is transferred as 8 -bit bytes using the 8 data lines DB0 to DB7. Three further control lines E, $R S$, and $R / \bar{W}$ are required.

In the 4-bit mode data is transferred in two cycles of 4-bits each. The higher order bits (corresponding to DB4 to DB7 in 8-bit mode) are sent in the first cycle and the lower order bits (DB0 to DB3 in 8-bit mode) in the second cycle. Data transfer is complete after two 4-bit data transfers. It should be noted that two cycles are also required for the Busy Flag check. 4-bit operation is selected by instruction. See Figs 15, 16 and 17 for examples of bus protocol.
In the 4-bit mode pins DB3 to DB0 must be left open-circuit. They are pulled up to $\mathrm{V}_{\mathrm{DD}}$ internally.

## LCD controller/driver

## 11 INTERFACE TO MICROCONTROLLER ( ${ }^{2} \mathrm{C}-\mathrm{BUS}$ INTERFACE)

### 11.1 Characteristics of the $I^{2} \mathrm{C}$-bus

The $I^{2} \mathrm{C}$-bus is for bidirectional, two-line communication between different ICs or modules. The two lines are a serial data line (SDA) and a serial clock line (SCL).
Both lines must be connected to a positive supply via a pull-up resistor. Data transfer may be initiated only when the bus is not busy.

### 11.2 Bit transfer

One data bit is transferred during each clock pulse. The data on the SDA line must remain stable during the HIGH period of the clock pulse as changes in the data line at this time will be interpreted as a control signal.

### 11.3 Start and stop conditions

Both data and clock lines remain HIGH when the bus is not busy. A HIGH-to-LOW transition of the data line, while the clock is HIGH is defined as the START condition (S). A LOW-to-HIGH transition of the data line while the clock is HIGH is defined as the STOP condition (P).

### 11.4 System configuration

A device generating a message is a 'transmitter', a device receiving a message is the 'receiver'. The device that controls the message is the 'master' and the devices which are controlled by the master are the 'slaves'.

### 11.5 Acknowledge

The number of data bytes transferred between the start and stop conditions from transmitter to receiver is unlimited. Each byte of eight bits is followed by an acknowledge bit. The acknowledge bit is a HIGH level signal put on the bus by the transmitter during which time the master generates an extra acknowledge related clock pulse. A slave receiver which is addressed must generate an acknowledge after the reception of each byte. Also a master receiver must generate an acknowledge after the reception of each byte that has been clocked out of the slave transmitter. The device that acknowledges must pull-down the SDA line during the acknowledge clock pulse, so that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse (set-up and hold times must be taken into consideration). A master receiver must signal an end of data to the transmitter by not generating an acknowledge on the last byte that has been clocked out of the slave. In this event the transmitter must leave the data line HIGH to enable the master to generate a stop condition.

## $11.6 \quad \mathrm{I}^{2} \mathrm{C}$-bus protocol

Before any data is transmitted on the ${ }^{2} \mathrm{C}$-bus, the device which should respond is addressed first. The addressing is always carried out with the first byte transmitted after the start procedure. The $\mathrm{I}^{2} \mathrm{C}$-bus configuration for the different PCF2104x READ and WRITE cycles is illustrated in Figs 22, 23 and 24.


Fig. 18 Bit transfer.

## LCD controller/driver

## SDA

SCL


Fig. 19 Definition of START and STOP conditions.


Fig. 20 System configuration.


Fig. 21 Acknowledgement on the $\mathrm{I}^{2} \mathrm{C}$-bus.

Fig. 22 Master transmits to slave receiver; WRITE mode.



Fig. 24 Master reads slave immediately after first byte; READ mode (RS previously defined).



## 12 LIMITING VALUES

In accordance with the Absolute Maximum Rating System (IEC 134).

| SYMBOL | PARAMETER | MIN. | MAX. | UNIT |
| :--- | :--- | :--- | :--- | :--- |
| $\mathrm{V}_{\mathrm{DD}}$ | supply voltage | -0.5 | +8.0 | V |
| $\mathrm{~V}_{\mathrm{LCD}}$ | LCD supply voltage | $\mathrm{V}_{\mathrm{DD}}-11$ | $\mathrm{~V}_{\mathrm{DD}}$ | V |
| $\mathrm{V}_{\mathrm{I}}$ | input voltage OSC, RS, R/W, E and DB0 to DB7 | $\mathrm{V}_{\mathrm{SS}}-0.5$ | $\mathrm{~V}_{\mathrm{DD}}+0.5$ | V |
| $\mathrm{~V}_{\mathrm{O}}$ | output voltage R1 to R32, C 1 to C60 and $\mathrm{V}_{\mathrm{LCD}}$ | $\mathrm{V}_{\mathrm{LCD}}-0.5$ | $\mathrm{~V}_{\mathrm{DD}}+0.5$ | V |
| $\mathrm{I}_{\mathrm{I}}$ | DC input current | -10 | +10 | mA |
| $\mathrm{I}_{\mathrm{O}}$ | DC output current | -10 | +10 | mA |
| $\mathrm{I}_{\mathrm{DD}}, \mathrm{I}_{\text {SS }}, \mathrm{I}_{\mathrm{LCD}}$ | $\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\text {SS }}$ or $\mathrm{V}_{\mathrm{LCD}}$ current | -50 | +50 | mA |
| $\mathrm{P}_{\text {tot }}$ | total power dissipation | - | 400 | mW |
| $\mathrm{P}_{\mathrm{O}}$ | power dissipation per output | - | 100 | mW |
| $\mathrm{~T}_{\text {stg }}$ | storage temperature | -65 | +150 | ${ }^{\circ} \mathrm{C}$ |

## 13 HANDLING

Inputs and outputs are protected against electrostatic discharge in normal handling. However, to be totally safe, it is desirable to take normal precautions appropriate to handling MOS devices (see "Handling MOS Devices").

## 14 DC CHARACTERISTICS

$\mathrm{V}_{\mathrm{DD}}=2.5$ to $6 \mathrm{~V} ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{V}_{\mathrm{LCD}}=\mathrm{V}_{\mathrm{DD}}-3.5$ to $\mathrm{V}_{\mathrm{DD}}-9 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=-40$ to $+85^{\circ} \mathrm{C}$; unless otherwise specified.

| SYMBOL | PARAMETER | CONDITIONS | MIN. | TYP. | MAX. | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Supplies |  |  |  |  |  |  |
| $V_{\text {DD }}$ | supply voltage |  | 2.5 | - | 6.0 | V |
| $V_{\text {LCD }}$ | LCD supply voltage |  | $\mathrm{V}_{\mathrm{DD}}-9$ | - | $V_{D D}-3.5$ | V |
| $\mathrm{I}_{\mathrm{DD}}$ | supply current external V LCD | note 1 | - | - | - |  |
| $\mathrm{I}_{\text {DD1 }}$ | supply current 1 |  | - | 200 | 500 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\text {DD2 }}$ | supply current 2 | $\begin{aligned} & \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} ; \mathrm{V}_{\mathrm{OP}}=9 \mathrm{~V} ; \\ & \mathrm{f}_{\mathrm{osc}}=150 \mathrm{kHz} ; \\ & \mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C} \end{aligned}$ | - | 200 | 300 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\mathrm{DD} 3}$ | supply current 3 | $\begin{aligned} & \mathrm{V}_{\mathrm{DD}}=3 \mathrm{~V} ; \mathrm{V}_{\mathrm{OP}}=5 \mathrm{~V} ; \\ & \mathrm{f}_{\mathrm{osc}}=150 \mathrm{kHz} ; \\ & \mathrm{T}_{\mathrm{amb}}=25^{\circ} \mathrm{C} \end{aligned}$ | - | 150 | 200 | $\mu \mathrm{A}$ |
| ILCD | $\mathrm{V}_{\text {LCD }}$ input current | notes 1 and 6 | - | 50 | 100 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {POR }}$ | Power-on reset voltage level | note 2 | - | 1.3 | 1.8 | V |


| SYMBOL | PARAMETER | CONDITIONS | MIN. | TYP. | MAX. | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Logic |  |  |  |  |  |  |
| $\mathrm{V}_{\text {IL } 1}$ | LOW level input voltage pins E, RS, R/W, DB0 to DB7 and SA0 |  | $\mathrm{V}_{S S}$ | - | $0.3 V_{\text {DD }}$ | V |
| $\mathrm{V}_{\mathrm{H} 1}$ | HIGH level input voltage pins E, RS, R/W, DB0 to DB7 and SA0 |  | $0.7 \mathrm{~V}_{\mathrm{DD}}$ | - | $V_{D D}$ | V |
| $\mathrm{V}_{\text {IL }}$ (osc) | LOW level input voltage pin OSC |  | $\mathrm{V}_{\text {SS }}$ | - | $\mathrm{V}_{\mathrm{DD}}-1.5$ | V |
| $\mathrm{V}_{\mathrm{IH} \text { (osc) }}$ | HIGH level input voltage pin OSC |  | $V_{D D}-0.1$ | - | $\mathrm{V}_{\mathrm{DD}}$ | V |
| $\mathrm{I}_{\mathrm{pu}}$ | pull-up current at pins DB0 to DB7, RS and R/ $\bar{W}$ | $\mathrm{V}_{1}=\mathrm{V}_{\text {SS }}$ | 0.04 | 0.15 | 1.00 | $\mu \mathrm{A}$ |
| $\mathrm{IOL}(\mathrm{DB})$ | LOW level output current pins DB0 to DB7 | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V} ; \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ | 1.6 | - | - | mA |
| $\mathrm{I}_{\mathrm{OH}(\mathrm{DB})}$ | HIGH level output current pins DB0 to DB7 | $\mathrm{V}_{\mathrm{OH}}=4 \mathrm{~V} ; \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ | -1.0 | - | - | mA |
| $\mathrm{L}_{\mathrm{L} 1}$ | leakage current pins OSC, E, RS, R/W, DB0 to DB7 and SA0 | $\mathrm{V}_{\mathrm{I}}=\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{S S}$ | -1 | - | +1 | $\mu \mathrm{A}$ |

## $1^{2} \mathrm{C}$-bus

SDA, SCL

| $\mathrm{V}_{\mathrm{IL} 2}$ | LOW level input voltage | note 3 | $\mathrm{V}_{\mathrm{SS}}$ | - | $0.3 \mathrm{~V}_{\mathrm{DD}}$ | V |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\mathrm{V}_{\mathrm{IH} 2}$ | HIGH level input voltage | note 3 | $0.7 \mathrm{~V}_{\mathrm{DD}}$ | - | $\mathrm{V}_{\mathrm{DD}}$ | V |
| $\mathrm{I}_{\mathrm{L} 2}$ | leakage current | $\mathrm{V}_{\mathrm{I}}=\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{\mathrm{SS}}$ | -1 | - | +1 | $\mu \mathrm{~A}$ |
| $\mathrm{C}_{\mathrm{i}}$ | input capacitance | note 4 | - | - | 7 | pF |
| $\mathrm{I}_{\mathrm{OL}(\text { SDA })}$ | LOW level output current (SDA) | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V} ; \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ | 3 | - | - | mA |

## LCD outputs

| $R_{\text {Row }}$ | row output resistance pins <br> R1 to R32 | note 5 | - | 1.5 | 3 | $\mathrm{k} \Omega$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $R_{\text {COL }}$ | column output resistance pins <br> C1 to C60 | note 5 | - | 3 | 6 | $\mathrm{k} \Omega$ |
| $V_{\text {tol1 }}$ | bias voltage tolerance pins <br> $R 1$ to R32 and C1 to C60 | note 6 | - | $\pm 20$ | $\pm 130$ | mV |

## Notes

1. LCD outputs are open-circuit; inputs at $\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{\mathrm{SS}} ; \mathrm{V}_{0}=\mathrm{V}_{\mathrm{DD}}$; bus inactive; internal or external clock with duty cycle 50\% (ldD1 only).
2. Resets all logic when $V_{D D}<V_{P O R}$.
3. When the voltages are above or below the supply voltages $\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{\mathrm{SS}}$, an input current may flow; this current must not exceed $\pm 0.5 \mathrm{~mA}$.
4. Tested on sample basis.
5. Resistance of output terminals ( $R 1$ to $R 32$ and $C 1$ to $C 60$ ) with load current $I_{\text {load }}=150 \mu A ; V_{O P}=V_{D D}-V_{L C D}=9 \mathrm{~V}$; outputs measured one at a time.
6. LCD outputs open-circuit.

## 15 AC CHARACTERISTICS

$\mathrm{V}_{\mathrm{DD}}=2.5$ to $6.0 \mathrm{~V} ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{V}_{\mathrm{LCD}}=\mathrm{V}_{\mathrm{DD}}-3.5 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{DD}}-9 \mathrm{~V} ; \mathrm{T}_{\mathrm{amb}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$; unless otherwise specified.

| SYMBOL | PARAMETER | CONDITIONS | MIN. | TYP. | MAX. | UNIT |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\mathrm{f}_{\mathrm{FR}}$ | LCD frame frequency (internal clock) | note 1 | 40 | 65 | 100 | Hz |
| $\mathrm{f}_{\text {osc }}$ | external clock frequency |  | 90 | 150 | 225 | kHz |


| Bus timing characteristics: Parallel Interface; notes 1 and 2 |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Write operation (WRiting data from microcontroller to PCF2104x) |  |  |  |  |  |
| $\mathrm{T}_{\text {cy }}$ | enable cycle time | 500 | - | - | ns |
| PW ${ }_{\text {EH }}$ | enable pulse width | 220 | - | - | ns |
| $\mathrm{t}_{\text {ASU }}$ | address set-up time | 50 | - | - | ns |
| $t_{\text {AH }}$ | address hold time | 25 | - | - | ns |
| $\mathrm{t}_{\text {DSW }}$ | data set-up time | 60 | - | - | ns |
| $t_{\text {HD }}$ | data hold time | 25 | - | - | ns |
| REAd operation (READING data from PCF2104x to microcontroller) |  |  |  |  |  |
| $\mathrm{T}_{\text {cy }}$ | enable cycle time | 500 | - | - | ns |
| PW ${ }_{\text {EH }}$ | enable pulse width | 220 | - | - | ns |
| $\mathrm{t}_{\text {ASU }}$ | address set-up time | 50 | - | - | ns |
| $t_{\text {AH }}$ | address hold time | 25 | - | - | ns |
| $t_{\text {DHD }}$ | data delay time | - | - | 150 | ns |
| $\mathrm{t}_{\mathrm{HD}}$ | data hold time | 20 | - | 100 | ns |

Timing characteristics: ${ }^{2} \mathbf{C}$-bus interface; note 2

| $\mathrm{f}_{\mathrm{SCL}}$ | SCL clock frequency | - | - | 100 | kHz |
| :---: | :---: | :---: | :---: | :---: | :---: |
| tsw | tolerable spike width on bus | - | - | 100 | ns |
| $t_{\text {buF }}$ | bus free time | 4.7 | - | - | $\mu \mathrm{S}$ |
| tsu;STA | set-up time for a repeated START condition | 4.7 | - | - | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{HD} ; \text { STA }}$ | start condition hold time | 4 | - | - | $\mu \mathrm{S}$ |
| tLow | SCL LOW time | 4.7 | - | - | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {HIGH }}$ | SCL HIGH time | 4 | - | - | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{r}}$ | SCL and SDA rise time | - | - | 1 | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{f}}$ | SCL and SDA fall time | - | - | 0.3 | $\mu \mathrm{S}$ |
| tsu;DAT | data set-up time | 250 | - | - | ns |
| $\mathrm{t}_{\text {HD } ; \text { DAT }}$ | data hold time | 0 | - | - | ns |
| $\mathrm{t}_{\text {Su; }}$ STO | set-up time for STOP condition | 4 | - | - | $\mu \mathrm{s}$ |

## Notes

1. $V_{D D}=5.0 \mathrm{~V}$.
2. All timing values are valid within the operating supply voltage and ambient temperature range and are referenced to $V_{I L}$ and $V_{I H}$ with an input voltage swing of $V_{S S}$ to $V_{D D}$.

## LCD controller/driver

## 16 TIMING DIAGRAMS



Fig. 26 Parallel bus write operation sequence; writing data from microcontroller to PCF2104x.


Fig. 27 Parallel bus read operation sequence; reading data from PCF2104x to microcontroller.

## LCD controller/driver

## 17 APPLICATION INFORMATION



Fig. 28 Direct connection to 8-bit microcontroller; 8-bit bus.


Fig. 29 Direct connection to 8-bit microcontroller; 4-bit bus.


Fig. 30 Typical application using parallel interface.


Fig. 31 Application using $\mathrm{I}^{2} \mathrm{C}$-bus interface.

## LCD controller/driver

### 17.1 8-bit operation, $2 \times 12$ display using internal reset

Table 7 shows an example of a 1 -line display in 8 -bit operation. The PCF2104x functions must be set by the function set instruction prior to display. Since the display data RAM can store data for 80 characters, the RAM can be used for advertising displays when combined with display shift operation. Since the display shift operation changes the display position only and DDRAM contents remain unchanged. Display data entered first can be displayed when the 'Return home' instruction is performed.

### 17.2 4-bit operation, $2 \times 12$ display using internal reset

The program must set functions prior to 4-bit operation. Table 6 shows an example. When power is turned on, 8 -bit operation is automatically selected and the PCF2104x attempts to perform the first write as an 8-bit operation. Since nothing is connected to DB0 to DB3, a rewrite is then required. However, since one operation is completed in two accesses of 4-bit operation, a rewrite is required to set the functions (see Table 6 step 3).
Thus, DB4 to DB7 of the function set are written twice.

### 17.3 8-bit operation, $2 \times 24$ 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 set after the eighth character is completed (see Table 8). It should be noted that both lines of the display are always shifted together, data does not shift from one line to the other.

## $17.4 \quad I^{2} \mathrm{C}$ operation, $2 \times 12$ display

A control byte is required with most instructions (see Table 9).

### 17.5 Initializing by instruction

If the power supply conditions for correctly operating the internal reset circuit are not met, the PCF2104x must be initialized by instruction. Tables 10 and 11 show how this may be performed for 8-bit and 4-bit operation.

Table 6 4-bit operation, 1-line display example; using internal reset

| STEP | INSTRUCTION | DISPLAY | OPERATION |
| :---: | :---: | :---: | :---: |
| 1 | Power supply on (PCF2104x is initialized by the internal reset circuit). |  | Initialized. No display appears. |
| 2 | Function set: $\begin{aligned} & \mathrm{RS}=0 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 7=0 ; \mathrm{DB6}=0 ; \\ & \mathrm{DB5}=1 ; \mathrm{DB4}=0 \end{aligned}$ |  | Sets to 4-bit operation. In this instance operation is handled as 8 -bits by initialization and only this instruction completes with one write. |
| 3 | Function set: $\begin{aligned} & R S=0 ; R / \bar{W}=0 ; D B 7=0 ; D B 6=0 ; \\ & D B 5=1 ; D B 4=0 \\ & R S=0 ; R / \bar{W}=0 ; D B 7=0 ; D B 6=0 ; \\ & D B 5=0 ; D B 4=0 \end{aligned}$ |  | Sets to 4 -bit operation, selects $2 \times 12$ display. <br> 4-bit operation starts from this point and resetting is needed. |
| 4 | Display on/off control: $\begin{aligned} & R S=0 ; R / \bar{W}=0 ; D B 7=0 ; D B 6=0 ; \\ & D B 5=0 ; D B 4=0 \\ & R S=0 ; R / \bar{W}=0 ; D B 7=1 ; D B 6=1 ; \\ & D B 5=1 ; D B 4=0 \end{aligned}$ |  | Turns on display and cursor. <br> Entire display is blank after initialization. |
| 5 | Entry mode set: $\begin{aligned} & \mathrm{RS}=0 ; \mathrm{R} / \bar{W}=0 ; \mathrm{DB} 7=0 ; \mathrm{DB}=0 ; \\ & \mathrm{DB5}=0 ; \mathrm{D} 4=0 \\ & \mathrm{RS}=0 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 7=0 ; \mathrm{DB} 6=1 ; \\ & \mathrm{DB5}=1 ; \mathrm{DB} 4=0 \end{aligned}$ | - | Sets mode to increment the address by 1 and to shift the cursor to the right at the time of write to the DD/CGRAM. Display is not shifted. |
| 6 | Write data to CGRAM/DDRAM: $\begin{aligned} & \mathrm{RS}=1 ; \mathrm{R} / \bar{W}=0 ; \mathrm{DB} 7=0 ; D B 6=1 ; \\ & \mathrm{DB5}=0 ; \mathrm{D} 4=1 \\ & \mathrm{RS}=1 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 7=0 ; \mathrm{DB}=1 ; \\ & \mathrm{DB} 5=1 ; \mathrm{D} 4=0 \end{aligned}$ | $\mathrm{P}_{-}$ | Writes ' $P$ '. The DDRAM has already been selected by initialization at power-on. <br> The cursor is incremented by 1 and shifted to the right. |


| STEP | INSTRUCTION | DISPLAY | OPERATION |
| :---: | :---: | :---: | :---: |
| 1 | Power supply on（PCF2104x is initialized by the internal reset function）． |  | Initialized．No display appears． |
| 2 | Function set： $\begin{aligned} & \mathrm{RS}=0 ; \mathrm{R} \overline{\mathrm{~W}}=0 ; \mathrm{DB} 4=0 ; \mathrm{DB6}=0 ; \mathrm{DB} 5=1 ; \mathrm{DB} 4=1 ; \\ & \mathrm{DB} 3=0 ; \mathrm{DB} 2=0 ; \mathrm{DB} 1=0 ; \mathrm{DB} 0=0 \end{aligned}$ |  | Sets to 8 －bit operation，selects $2 \times 12$ display． |
| 3 | Display mode on／off control： $\begin{aligned} & \mathrm{RS}=0 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 7=0 ; \mathrm{DB} 6=0 ; \mathrm{DB} 5=0 ; \mathrm{DB} 4=0 ; \\ & \mathrm{DB} 3=1 ; \mathrm{DB} 2=1 ; \mathrm{DB} 1=1 ; \mathrm{DB} 0=0 \end{aligned}$ | － | Turns on display and cursor．Entire display is blank after initialization． |
| 4 | $\begin{aligned} & \hline \text { Entry mode set: } \\ & \text { RS }=0 ; \mathrm{R} / \mathrm{W}=0 ; \mathrm{DB} 1=0 ; \mathrm{DB6}=0 ; \mathrm{DB} 5=0 ; \mathrm{DB} 4=0 ; \\ & \mathrm{DB} 3=0 ; \mathrm{DB} 2=1 ; \mathrm{DB} 1=1 ; \mathrm{DB} 0=0 \\ & \hline \end{aligned}$ | － | Sets mode to increment the address by 1 and to shift the cursor to the right at the time of the write to the DD／CGRAM．Display is not shifted． |
| 5 | Write data to CGRAM／DDRAM： $\begin{aligned} & \mathrm{RS}=1 ; \mathrm{R} \overline{\mathrm{~W}}=0 ; \mathrm{DB7}=0 ; \mathrm{DB6}=1 ; \mathrm{DB5}=0 ; \mathrm{DB4}=1 ; \\ & \mathrm{DB} 3=0 ; \mathrm{DB} 2=0 ; \mathrm{DB} 1=0 ; \mathrm{DB} 0=0 \end{aligned}$ | $\mathbf{P}_{-}$ | Writes＇P＇．The DDRAM has already been selected by initialization at power－on．The cursor is incremented by 1 and shifted to the right． |
| 6 | Write data to CGRAM／DDRAM： <br> $R S=1 ; R \bar{W}=0 ; D B 7=0 ; D B 6=1 ; D B 5=1 ; D B 4=1 ;$ <br> $\mathrm{DB} 3=1 ; \mathrm{DB} 2=0 ; \mathrm{DB} 1=0 ; \mathrm{DB}=0$ | PH＿ | Writes＇H＇． |
| 7 | ｜ |  |  |
| 8 | Write data to CGRAM／DDRAM： <br> $\mathrm{RS}=1 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 7=0 ; \mathrm{DB} 6=1 ; \mathrm{DB} 5=0 ; \mathrm{DB4}=1$ ； <br> $\mathrm{DB} 3=0 ; \mathrm{DB} 2=0 ; \mathrm{DB} 1=1 ; \mathrm{DB} 0=1$ | PHILIPS＿ | Writes＇S＇． |
| 9 | Entry mode set： $\begin{aligned} & \mathrm{RS}=0 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 4=0 ; \mathrm{DB} 6=0 ; \mathrm{DB} 5=0 ; \mathrm{DB} 4=0 ; \\ & \mathrm{DB} 3=0 ; \mathrm{DB} 2=1 ; \mathrm{DB} 1=1 ; \mathrm{DB} 0=1 \end{aligned}$ | PHILIPS＿ | Sets mode for display shift at the time of write． |
| 10 | Write data to CGRAM／DDRAM： $\begin{aligned} & \mathrm{RS}=1 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 4=0 ; \mathrm{DB} 6=0 ; \mathrm{DB} 5=1 ; \mathrm{DB} 4=0 ; \\ & \mathrm{DB} 3=0 ; \mathrm{DB} 2=0 ; \mathrm{DB} 1=0 ; \mathrm{DB} 0=0 \end{aligned}$ | HILIPS＿ | Writes space． |
| 11 | Write data to CGRAM／DDRAM： $\begin{aligned} & \mathrm{RS}=1 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 4=0 ; \mathrm{DB} 6=1 ; \mathrm{DB} 5=0 ; \mathrm{DB} 4=0 ; \\ & \mathrm{DB} 3=1 ; \mathrm{DB} 2=1 ; \mathrm{DB} 1=0 ; \mathrm{DB} 0=1 \end{aligned}$ | ILIPS M＿ | Writes＇${ }^{\text {＇}}$＇． |
| 12 | $\begin{aligned} & \hline \text { I } \\ & \text { I } \\ & \hline \end{aligned}$ |  |  |


| STEP | INSTRUCTION | DISPLAY | OPERATION |
| :---: | :---: | :---: | :---: |
| 13 | Write data to CGRAM／DDRAM： <br> $R S=1 ; R \bar{W}=0 ; D B 7=0 ; D B 6=1 ; D B 5=0 ; D B 4=0 ;$ <br> $\mathrm{DB} 3=1 ; \mathrm{DB} 2=1 ; \mathrm{DB} 1=1 ; \mathrm{DB} 0=1$ | MICROKO＿ | Writes＇O＇． |
| 14 | Cursor or display shift： $\begin{aligned} & \mathrm{RS}=0 ; \mathrm{R} \overline{\mathrm{~W}}=0 ; \mathrm{DB} 1=0 ; \mathrm{DB6}=0 ; \mathrm{DB} 5=0 ; \mathrm{DB4}=1 ; \\ & \mathrm{DB} 3=0 ; \mathrm{DB} 2=0 ; \mathrm{DB} 1=0 ; \mathrm{DB} 0=0 \end{aligned}$ | MICROKO | Shifts only the cursor position to the left． |
| 15 | Cursor or display shift： <br> $\mathrm{RS}=0 ; \mathrm{R} \overline{\mathrm{W}}=0 ; \mathrm{DB} 4=0 ; \mathrm{DB6}=0 ; \mathrm{DB} 5=0 ; \mathrm{DB4}=1$ ； <br> $\mathrm{DB} 3=0 ; \mathrm{DB} 2=0 ; \mathrm{DB} 1=0 ; \mathrm{DB} 0=0$ | MICROKO | Shifts only the cursor position to the left． |
| 16 | Write data to CGRAM／DDRAM： <br> $R S=1 ; R \bar{W}=0 ; D B 7=0 ; D B 6=1 ; D B 5=0 ; D B 4=0 ;$ <br> $\mathrm{DB} 3=0 ; \mathrm{DB} 2=0 ; \mathrm{DB} 1=1 ; \mathrm{DB} 0=1$ | ICROCO | Writes＇C＇correction．The display moves to the left． |
| 17 | $\begin{aligned} & \text { Cursor or display shift: } \\ & R S=0 ; R / \bar{W}=0 ; D B 7=0 ; D B 6=0 ; D B 5=0 ; D B 4=1 ; \\ & D B 3=1 ; D B 2=1 ; D B 1=0 ; D B 0=0 \end{aligned}$ | MICROCO | Shifts the display and cursor to the right． |
| 18 | $\begin{aligned} & \text { Cursor or display shift: } \\ & R S=0 ; R \bar{W}=0 ; D B 7=0 ; D B 6=0 ; D B 5=0 ; D B 4=1 ; \\ & D B 3=0 ; D B 2=1 ; D B 1=0 ; D B 0=0 \end{aligned}$ | MICROCO＿ | Shifts only the cursor to the right． |
| 19 | Write data to CGRAM／DDRAM： <br> $\mathrm{RS}=1 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 7=0 ; \mathrm{DB6}=1 ; \mathrm{DB5}=0 ; \mathrm{DB4}=0$ ； <br> $\mathrm{DB} 3=1 ; \mathrm{DB} 2=1 ; \mathrm{DB} 1=0 ; \mathrm{DB}=1$ | ICROCOM＿ | Writes＇ M ＇． |
| 20 | $\begin{aligned} & 1 \\ & 1 \\ & \hline \end{aligned}$ |  |  |
| 21 | Return home： <br> $R S=0 ; R \bar{W}=0 ; D B 7=0 ; D B 6=0 ; D B 5=0 ; D B 4=0$ ； <br> $\mathrm{DB} 3=0 ; \mathrm{DB} 2=0 ; \mathrm{DB} 1=1 ; \mathrm{DB} 0=0$ | $\underline{\text { PHILIPS M }}$ | Returns both display and cursor to the original position （address 0）． |


| STEP | INSTRUCTION | DISPLAY | OPERATION |
| :---: | :---: | :---: | :---: |
| 1 | Power supply on（PCF2104x is initialized by the internal reset function）． |  | Initialized．No display appears． |
| 2 | Function set： $\begin{aligned} & \mathrm{RS}=0 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 4=0 ; \mathrm{DB6}=0 ; \mathrm{DB} 5=1 ; \mathrm{DB} 4=1 ; \\ & \mathrm{DB} 3=1 ; \mathrm{DB} 2=0 ; \mathrm{DB} 1=0 ; \mathrm{DB} 0=0 \end{aligned}$ |  | Sets to 8－bit operation，selects $2 \times 24$ display |
| 3 | Display on／off control： $\begin{aligned} & R S=0 ; R / \bar{W}=0 ; D B 7=0 ; D B 6=0 ; D B 5=0 ; D B 4=0 ; \\ & D B 3=1 ; D B 2=1 ; D B 1=1 ; D B 0=0 \end{aligned}$ | － | Turns on display and cursor．Entire display is blank after initialization． |
| 4 | $\begin{array}{\|l} \hline \text { Entry mode set: } \\ \text { RS = } 0 ; R / \bar{W}=0 ; D B 7=0 ; D B 6=0 ; D B 5=0 ; D B 4=0 ; \\ D B 3=0 ; D B 2=1 ; D B 1=1 ; D B 0=0 \\ \hline \end{array}$ | － | Sets mode to increment the address by 1 and to shift the cursor to the right at the time of write to the CG／DDRAM． Display is not shifted． |
| 5 | Write data to CGRAM／DDRAM： $\begin{aligned} & \mathrm{RS}=1 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 1=0 ; \mathrm{DB6}=1 ; \mathrm{DB} 5=0 ; \mathrm{DB} 4=1 ; \\ & \mathrm{DB} 3=0 ; \mathrm{DB} 2=0 ; \mathrm{DB} 1=0 ; \mathrm{DB} 0=0 \end{aligned}$ | P＿ | Writes＇P＇．The DDRAM has already been selected by initialization at power－on．The cursor is incremented by 1 and shifted to the right． |
| 6 |  | \| |  |
| 7 | Write data to CGRAM／DDRAM： $\begin{aligned} & \mathrm{RS}=1 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 4=0 ; \mathrm{DB} 6=1 ; \mathrm{DB} 5=0 ; \mathrm{DB} 4=1 ; \\ & \mathrm{DB} 3=0 ; \mathrm{DB} 2=0 ; \mathrm{DB} 1=1 ; \mathrm{DB} 0=1 \end{aligned}$ | PHILIPS | Writes＇S＇． |
| 8 | Set DDRAM address： $\begin{aligned} & \mathrm{RS}=0 ; \mathrm{R} \overline{\mathrm{~W}}=0 ; \mathrm{DB} 1=1 ; \mathrm{DB6}=1 ; \mathrm{DB} 5=0 ; \mathrm{DB} 4=0 ; \\ & \mathrm{DB} 3=0 ; \mathrm{DB} 2=0 ; \mathrm{DB} 1=0 ; \mathrm{DB} 0=0 \end{aligned}$ | PHILIPS | Sets DDRAM address to position the cursor at the head of the 2nd line． |
| 9 | Write data to CGRAM／DDRAM： $\begin{aligned} & R S=1 ; R \bar{W}=0 ; D B 7=0 ; D B 6=1 ; D B 5=0 ; D B 4=0 ; \\ & D B 3=1 ; D B 2=1 ; D B 1=0 ; D B 0=1 \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { PHILIPS } \\ \hline \mathbf{M}_{-} \\ \hline \end{array}$ | Writes＇M＇． |
| 10 |  | $1$ |  |
| 11 | Write data to CGRAM／DDRAM： $\begin{aligned} & \mathrm{RS}=1 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 4=0 ; \mathrm{DB6}=1 ; \mathrm{DB} 5=0 ; \mathrm{DB} 4=0 ; \\ & \mathrm{DB} 3=1 ; \mathrm{DB} 2=1 ; \mathrm{DB} 1=1 ; \mathrm{DB} 0=1 \end{aligned}$ | PHILIPS <br> MICROCO＿ | Writes＇O＇． |
| 12 | Write data to CGRAM／DDRAM： <br> $\mathrm{RS}=0 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 7=0 ; \mathrm{DB6}=0 ; \mathrm{DB} 5=0 ; \mathrm{DB} 4=0$ ； <br> $\mathrm{DB} 3=0 ; \mathrm{DB} 2=1 ; \mathrm{DB} 1=1 ; \mathrm{DB} 0=1$ | PHILIPS | Sets mode for display shift at the time of write． |


| STEP | INSTRUCTION | DISPLAY | OPERATION |
| :---: | :---: | :---: | :---: |
| 13 | Write data to CGRAM/ DDRAM:$\begin{aligned} & \text { RS = 1; R/W }=0 ; D B 7=0 ; D B 6=1 ; D B 5=0 ; D B 4=0 ; \\ & D B 3=1 ; D B 2=1 ; D B 1=0 ; D B 0=1 \end{aligned}$ | HILIPS | Writes ' M '. Display is shifted to the left. The first and second lines shift together. |
|  |  | ICROCOM |  |
| 14 |  |  |  |
| 15 | $\begin{aligned} & \text { Return home: } \\ & \text { RS =0; } / \bar{W}=0 ; D B 1=0 ; D B 6=0 ; D B 5=0 ; D B 4=0 ; \\ & D B 3=0 ; D B 2=0 ; D B 1=1 ; D B 0=0 \end{aligned}$ | PHILIPS | Returns both display and cursor to the original position (address 0). |
|  |  | MICROCOM |  |


| STEP | $1^{2} \mathrm{C}$－BUS BYTE | DISPLAY | OPERATION |
| :---: | :---: | :---: | :---: |
| 1 | $1^{2} \mathrm{C}$－bus start |  | Initialized．No display appears． |
| 2 | Slave address for write： $\begin{aligned} & S A 6=0 ; S A 5=1 ; S A 4=1 ; S A 3=1 ; S A 2=0 ; S A 1=1 ; \\ & S A 0=0 ; R / \bar{W}=0 ; A c k=1 \end{aligned}$ |  | During the acknowledge cycle SDA will be pulled－down by the PCF2104x． |
| 3 | Send a control byte for function set： $\mathrm{Co}=0 ; \mathrm{RS}=0 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{Ack}=1$ |  | Control byte sets RS and R／W for following data bytes． |
| 4 | $\begin{aligned} & \text { Function set: } \\ & \text { DB7 }=0 ; D B 6=0 ; D B 5=1 ; D B 4=X ; D B 3=0 ; D B 2=0 ; \\ & D B 1=0 ; D B 0=0 ; A c k=1 \end{aligned}$ |  | Selects 1 －line display；SCL pulse during acknowledge cycle starts execution of instruction． |
| 5 | Display on／off control： $\begin{aligned} & \mathrm{DB} 7=0 ; \mathrm{DB6}=0 ; \mathrm{DB5}=0 ; \mathrm{DB4}=0 ; \mathrm{DB} 3=1 ; \mathrm{DB2}=1 ; \\ & \mathrm{DB} 1=1 ; \mathrm{DB} 0=0 ; A c k=1 \end{aligned}$ | － | Turns on display and cursor．Entire display shows character Hex 20 （blank in ASCII－like character sets）． |
| 6 | $\begin{aligned} & \text { Entry mode set: } \\ & \text { DB7 }=0 ; D B 6=0 ; D B 5=0 ; D B 4=0 ; D B 3=0 ; D B 2=1 ; \\ & D B 1=1 ; D B 0=0 ; A c k=1 \\ & \hline \end{aligned}$ | － | Sets mode to increment the address by 1 and to shift the cursor to the right at the time of write to the DDRAM or CGRAM．Display is not shifted． |
| 7 | ${ }^{1} 2 \mathrm{C}$－bus start | － | For writing data to DDRAM，RS must be set to 1 ． Therefore a control byte is needed． |
| 8 | Slave address for write： $\begin{aligned} & S A 6=0 ; S A 5=1 ; S A 4=1 ; S A 3=1 ; S A 2=0 ; S A 1=1 ; \\ & S A 0=0 ; R / \bar{W}=0 ; A c k=1 \end{aligned}$ | － |  |
| 9 | Send a control byte for write data： $C o=0 ; R S=1 ; R / \bar{W}=0 ; A c k=1$ | － |  |
| 10 | Write data to DDRAM： $\begin{aligned} & \mathrm{DB} 4=0 ; \mathrm{DB6}=1 ; \mathrm{DB5}=0 ; \mathrm{DB4}=1 ; \mathrm{DB} 3=0 ; \mathrm{DB} 2=0 ; \\ & \mathrm{DB} 1=0 ; \mathrm{DB} 0=0 ; \mathrm{Ack}=1 \end{aligned}$ | $\mathbf{P}_{-}$ | Writes＇$P$＇．The DDRAM has been selected at power－up． The cursor is incremented by 1 and shifted to the right． |
| 11 | Write data to DDRAM： $\begin{aligned} & \mathrm{DB} 1=0 ; \mathrm{DB6}=1 ; \mathrm{DB} 5=0 ; \mathrm{DB} 4=0 ; \mathrm{DB} 3=1 ; \mathrm{DB2}=0 ; \\ & \mathrm{DB} 1=0 ; \mathrm{DB} 0=0 ; \mathrm{Ack}=1 \end{aligned}$ | PH＿ | Writes＇H＇． |
| 12 to 15 |  | $1$ |  |
| 16 | Write data to DDRAM： $\begin{aligned} & \mathrm{DB} 4=0 ; \mathrm{DB6}=1 ; \mathrm{DB5}=0 ; \mathrm{DB4}=1 ; \mathrm{DB} 3=0 ; \mathrm{DB} 2=0 ; \\ & \mathrm{DB} 1=1 ; \mathrm{DB} 0=1 ; \mathrm{Ack}=1 \end{aligned}$ | PHILIPS＿ | Writes＇S＇． |


| $\stackrel{\rightharpoonup}{\circ}$ | STEP | I2C－BUS BYTE | DISPLAY | OPERATION |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { V} \\ & \stackrel{\rightharpoonup}{0} \\ & \stackrel{1}{\sigma} \end{aligned}$ | 17 | （optional $\mathrm{I}^{2} \mathrm{C}$－bus stop） $\mathrm{I}^{2} \mathrm{C}$－bus start＋slave address for write （as step 8） | PHILIPS |  |
|  | 18 | Control byte： $\mathrm{Co}=1 ; \mathrm{RS}=0 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{Ack}=1$ | PHILIPS＿ |  |
|  | 19 | Return home： $\begin{aligned} & \mathrm{DB}=0 ; \mathrm{DB6}=0 ; \mathrm{DB} 5=0 ; \mathrm{DB} 4=0 ; \mathrm{DB} 3=0 ; \mathrm{DB} 2=0 ; \\ & \mathrm{DB} 1=1 ; \mathrm{DB}=0 ; \mathrm{Ack}=1 \end{aligned}$ | PHILIPS | Sets DDRAM address 0 in Address Counter．（Also returns shifted display to original position．DDRAM contents unchanged）．This instruction does not update the Data Register（DR）． |
|  | 20 | Control byte for read： $\mathrm{Co}=0 ; \mathrm{RS}=1 ; \mathrm{R} / \overline{\mathrm{W}}=1 ; \text { Ack }=1$ | PHILIPS | DDRAM content will be read from following instructions． The $\mathrm{R} / \overline{\mathrm{W}}$ has to be set to 1 while still in $\mathrm{I}^{2} \mathrm{C}$－bus write mode． |
|  | 21 | $1^{2} \mathrm{C}$－bus start | PHILIPS |  |
|  | 22 | $\begin{aligned} & \text { Slave address for read: } \\ & \text { SA } 6=0 ; S A 5=1 ; S A 4=1 ; S A 3=1 ; S A 2=0 ; S A 1=1 ; \\ & S A 0=0 ; R / \bar{W}=1 ; A c k=1 \end{aligned}$ | PHILIPS | During the acknowledge cycle the content of the DR is loaded into the internal $\mathrm{I}^{2} \mathrm{C}$－bus interface to be shifted out． In the previous instruction neither a＇Set address＇nor a ＇Read data＇has been performed．Therefore the content of the DR was unknown． |
| ట | 23 | $\begin{aligned} & \text { Read data: } 8 \times \text { SCL + master acknowledge; note } 2: \\ & \text { DB7 }=X ; D B 6=X ; D B 5=X ; D B 4=X ; D B 3=X ; D B 2=X ; \\ & \text { DB1 }=X ; D B 0=X ; A c k=1 \end{aligned}$ | PHILLIPS | $8 \times$ SCL；content loaded into interface during previous acknowledge cycle is shifted out over SDA．MSB is DB7． During master acknowledge content of DDRAM address 01 is loaded into the $\mathrm{I}^{2} \mathrm{C}$－bus interface． |
|  | 24 | Read data： $8 \times$ SCL＋master acknowledge；note 2： $\begin{aligned} & \mathrm{DB7}=0 ; \mathrm{DB6}=1 ; \mathrm{D} 55=0 ; \mathrm{DB4}=0 ; \mathrm{DB}=1 ; \mathrm{DB2}=0 ; \\ & \mathrm{DB1}=0 ; \mathrm{DB} 0=0 ; \text { Ack }=0 \end{aligned}$ | PHILIPS | $8 \times$ SCL；code of letter＇ H ＇is read first．During master acknowledge code of＇ 1 ＇is loaded into the $I^{2} \mathrm{C}$－bus interface． |
|  | 25 | Read data： $8 \times$ SCL + no master acknowledge；note 2 ： $\mathrm{DB} 7=0 ; \mathrm{DB6}=1 ; \mathrm{DB} 5=0 ; \mathrm{DB} 4=0 ; \mathrm{DB} 3=1 ; \mathrm{DB} 2=0 ;$ $\mathrm{DB} 1=0 ; \mathrm{DB} 0=1 ; \text { Ack }=1$ | PHILIPS | No master acknowledge；After the content of the $\mathrm{I}^{2} \mathrm{C}$－bus interface register is shifted out no internal action is performed．No new data is loaded to the interface register， Data Register（DR）is not updated，Address Counter（AC） is not incremented and cursor is not shifted． |
|  | 26 | $1^{2} \mathrm{C}$ stop | PHILIPS |  |

Notes
1．$X=$ don＇t care．
2．SDA is left at high－impedance by the microcontroller during the READ acknowledge．

| STEP | DESCRIPTION |
| :---: | :---: |
| Power-on or unknown state |  |
| I |  |
| Wait 2 ms after $\mathrm{V}_{\mathrm{DD}}$ rises above $\mathrm{V}_{\text {POR }}$ |  |
| I |  |
| $\begin{gathered} \mathrm{RS}=0 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 4=0 ; \mathrm{DB} 6=0 ; \mathrm{DB} 5=1 ; \mathrm{DB} 4=1 ; \\ \mathrm{DB3}=\mathrm{X} ; \mathrm{DB} 2=\mathrm{X} ; \mathrm{DB} 1=\mathrm{X} ; \mathrm{DB} 0=X \end{gathered}$ | BF cannot be checked before this instruction. 'Function set' (interface is 8 -bits long). |
| 1 |  |
| Wait 2 ms |  |
| \| |  |
| $\begin{gathered} \mathrm{RS}=0 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 7=0 ; \mathrm{DB6}=0 ; \mathrm{DB} 5=1 ; D B 4=1 ; \\ \mathrm{DB} 3=X ; D B 2=X ; D B 1=X ; D B 0=X \end{gathered}$ | BF cannot be checked before this instruction.' Function set' (interface is 8 -bits long). |
| I |  |
| Wait more than $40 \mu \mathrm{~s}$ |  |
| \\| |  |
| $\begin{gathered} R S=0 ; R / \bar{W}=0 ; D B 7=0 ; D B 6=0 ; D B 5=1 ; D B 4=1 ; \\ D B 3=X ; D B 2=X ; D B 1=X ; D B 0=X \end{gathered}$ | BF cannot be checked before this instruction. 'Function set' (interface is 8 -bits long). |
| \| | BF can be checked after the following instructions. When BF is not checked, the waiting time between instructions is the specified instruction time (see Table 3). |
| $\begin{gathered} \mathrm{RS}=0 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 7=0 ; \mathrm{DB} 6=0 ; D B 5=1 ; D B 4=1 ; \\ \mathrm{DB} 3=\mathrm{N} ; \mathrm{DB} 2=\mathrm{M} ; \mathrm{DB} 1=\mathrm{X} ; \mathrm{DB} 0=0 \end{gathered}$ | 'Function set' (interface is 8 -bits long). Specify the number of display lines. |
| $\begin{gathered} \mathrm{RS}=0 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 7=0 ; \mathrm{DB6}=0 ; \mathrm{DB} 5=0 ; D B 4=0 ; \\ \mathrm{DB3}=1 ; \mathrm{DB2}=0 ; \mathrm{DB} 1=0 ; D B 0=0 \end{gathered}$ | 'Display off'. |
| $\begin{gathered} \mathrm{RS}=0 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 7=0 ; \mathrm{DB6}=0 ; \mathrm{DB} 5=0 ; \mathrm{DB4}=0 ; \\ \mathrm{DB3}=0 ; \mathrm{DB2}=0 ; \mathrm{DB} 1=0 ; D B 0=1 \end{gathered}$ | 'Clear display'. |
| $\begin{aligned} & \mathrm{RS}=0 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 4=0 ; \mathrm{DB6}=0 ; \mathrm{DB} 5=0 ; \mathrm{DB} 4=0 ; \\ & \mathrm{DB} 3=0 ; \mathrm{DB} 2=1 ; \mathrm{DB} 1=I / D ; D B 0=S \end{aligned}$ | 'Entry mode set'. |
| \| |  |
| Initialization ends |  |

Note

1. $X=$ don't care.

| STEP | DESCRIPTION |
| :---: | :---: |
| Power-on or unknown state |  |
| I |  |
| Wait 2 ms after $\mathrm{V}_{\text {DD }}$ rises above $\mathrm{V}_{\text {POR }}$ |  |
| \\| |  |
| $R S=0 ; R / \bar{W}=0 ; D B 7=0 ; D B 6=0 ; D B 5=1 ; D B 4=1$ | BF cannot be checked before this instruction. 'Function set' (interface is 8 -bits long). |
| I |  |
| Wait 2 ms |  |
| 1 |  |
| $R S=0 ; R / \bar{W}=0 ; D B 7=0 ; D B 6=0 ; D B 5=1 ; D B 4=1$ | BF cannot be checked before this instruction. 'Function set' (interface is 8 -bits long). |
| 1 |  |
| Wait $40 \mu \mathrm{~s}$ |  |
| 1 |  |
| $R S=0 ; R / \bar{W}=0 ; D B 7=0 ; D B 6=0 ; D B 5=1 ; D B 4=1$ | BF cannot be checked before this instruction. 'Function set' (interface is 8 -bits long). |
| \| | BF can be checked after the following instructions. When BF is not checked, the waiting time between instructions is the specified instruction time (see Table 3). |
| $\mathrm{RS}=0 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 7=0 ; \mathrm{DB6}=0 ; \mathrm{DB} 5=1 ; \mathrm{DB4}=0$ | 'Function set' (set interface to 4-bits long). Interface is 8-bits long. |
| RS = 0; R/ $\bar{W}=0 ; \mathrm{DB} 7=0 ; \mathrm{DB6}=0 ; \mathrm{DB} 5=1 ; \mathrm{DB4}=0$ | 'Function set' (interface is 4-bits long). |
| $\mathrm{RS}=0 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 7=\mathrm{N} ; \mathrm{DB6}=\mathrm{M} ; \mathrm{DB} 5=0 ; \mathrm{DB4}=0$ | Specify number of display lines and voltage generator characteristic. |
| RS = 0; R/W $=0 ; \mathrm{DB} 7=0 ; \mathrm{DB6}=0 ; \mathrm{DB} 5=0 ; \mathrm{DB4}=0$ |  |
| $\mathrm{RS}=0 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 7=1 ; \mathrm{DB6}=0 ; \mathrm{DB} 5=0 ; \mathrm{DB4}=0$ | Display off. |
| $\mathrm{RS}=0 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 7=0 ; \mathrm{DB6}=0 ; \mathrm{DB5}=0 ; \mathrm{DB4}=0$ | 'Clear display'. |
| $\mathrm{RS}=0 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 7=1 ; \mathrm{DB6}=0 ; \mathrm{DB} 5=0 ; \mathrm{DB4}=0$ | 'Clear display . |
| RS = 0; R/W = 0; DB7 = 0; DB6 = 0; DB5 = 0; DB4 = 0 | 'Entry mode set' |
| $\mathrm{RS}=0 ; \mathrm{R} / \overline{\mathrm{W}}=0 ; \mathrm{DB} 7=0 ; \mathrm{DB6}=1 ; \mathrm{DB5}=\mathrm{I} / \mathrm{D} ; \mathrm{DB4}=\mathrm{S}$ | Entry mode set. |
| I |  |
| Initialization ends |  |



Fig. 32 Example of $4 \times 12$ display layout (PCF2104x).


Fig. 33 Display example (PCF2104x); 2 lines by 12 characters.


Fig. 34 Chip-on-glass application.

18 BONDING PAD LOCATIONS


Fig. 35 Bonding pad locations.

## LCD controller/driver

Table 12 Bonding pad locations (dimensions in $\mu \mathrm{m}$ ).
All $\mathrm{x} / \mathrm{y}$ coordinates are referenced to centre of chip, see Fig. 35

| SYMBOL | PAD | $\mathbf{x}$ | $\mathbf{y}$ |
| :--- | :---: | :---: | :---: |
| OSC | 1 | -2184.5 | -2637 |
| V $_{\text {DD }}$ | 2 | -2024.5 | -2637 |
| SA0 | 3 | -1864.5 | -2637 |
| V SS $^{\text {R8 }}$ | 4 | -1704.5 | -2637 |
| R7 | 5 | -1339 | -2637 |
| R6 | 6 | -1179 | -2637 |
| R5 | 7 | -1019 | -2637 |
| R32 | 8 | -859 | -2637 |
| R31 | 10 | -699 | -2637 |
| R30 | 11 | -539 | -2637 |
| R29 | 12 | -219 | -2637 |
| R24 | 13 | -59 | -2637 |
| R23 | 14 | 101 | -2637 |
| R22 | 15 | 261 | -2637 |
| R21 | 16 | 421 | -2637 |
| R20 | 17 | 581 | -2637 |
| R19 | 18 | 741 | -2637 |
| R18 | 19 | 901 | -2637 |
| R17 | 20 | 1061 | -2637 |
| C60 | 21 | 1221 | -2637 |
| C59 | 22 | 1381 | -2637 |
| C58 | 23 | 1541 | -2637 |
| C57 | 24 | 1701 | -2637 |
| C56 | 25 | 1861 | -2637 |
| C55 | 26 | 2021 | -2637 |
| C54 | 27 | 2181 | -2637 |
| C53 | 28 | 2350 | -2445 |
| C52 | 29 | 2350 | -2285 |
| C51 | 30 | 2350 | -2125 |
| C50 | 31 | 2350 | -1965 |
| C49 | 32 | 2350 | -1805 |
| C48 | 33 | 2350 | -1645 |
| C47 | 34 | 2350 | -1485 |
| C46 | 2350 | -1325 |  |
| C45 | 2350 | -1165 |  |
| C43 | 2350 | -1005 |  |
|  | 2350 | -845 |  |


| SYMBOL | PAD | $\mathbf{x}$ | $\mathbf{y}$ |
| :--- | :---: | :---: | :---: |
| C42 | 39 | 2350 | -685 |
| C41 | 40 | 2350 | -525 |
| C40 | 41 | 2350 | -365 |
| C39 | 42 | 2350 | -205 |
| C38 | 43 | 2350 | -45 |
| C37 | 44 | 2350 | 115 |
| C36 | 45 | 2350 | 275 |
| C35 | 46 | 2350 | 435 |
| C34 | 47 | 2350 | 595 |
| C33 | 48 | 2350 | 755 |
| C32 | 49 | 2350 | 915 |
| C31 | 50 | 2350 | 1075 |
| C30 | 51 | 2350 | 1235 |
| C29 | 52 | 2350 | 1395 |
| C28 | 53 | 2350 | 1555 |
| C27 | 54 | 2350 | 1715 |
| C26 | 55 | 2350 | 1875 |
| C25 | 56 | 2350 | 2035 |
| C24 | 57 | 2350 | 2195 |
| C23 | 58 | 2350 | 2355 |
| C22 | 59 | 2185 | 2637.5 |
| C21 | 60 | 2025 | 2637.5 |
| C20 | 61 | 1865 | 2637.5 |
| C19 | 62 | 1705 | 2637.5 |
| C18 | 63 | 1545 | 2637.5 |
| C17 | 64 | 1385 | 2637.5 |
| C16 | 65 | 1225 | 2637.5 |
| C15 | 66 | 1065 | 2637.5 |
| C14 | 67 | 905 | 2637.5 |
| C13 | 68 | 745 | 2637.5 |
| C12 | 69 | 585 | 2637.5 |
| C11 | 70 | 425 | 2637.5 |
| C10 | 71 | 265 | 2637.5 |
| C9 | 72 | 105 | 2637.5 |
| C8 | 73 | -55 | 2637.5 |
|  | -215 | 2637.5 |  |
| -375 | 2637.5 |  |  |
| C6 | -535 | 2637.5 |  |


| SYMBOL | PAD | $\mathbf{x}$ | $\mathbf{y}$ |
| :--- | :---: | :---: | :---: |
| C4 | 77 | -695 | 2637.5 |
| C3 | 78 | -855 | 2637.5 |
| C2 | 79 | -1015 | 2637.5 |
| C1 | 80 | -1175 | 2637.5 |
| R9 | 81 | -1385 | 2637.5 |
| R10 | 82 | -1545 | 2637.5 |
| R11 | 83 | -1705 | 2637.5 |
| R12 | 84 | -1865 | 2637.5 |
| R13 | 85 | -2025 | 2637.5 |
| R14 | 86 | -2185 | 2637.5 |
| R15 | 87 | -2349 | 2308 |
| R16 | 88 | -2349 | 2148 |
| R25 | 89 | -2349 | 1988 |
| R26 | 90 | -2349 | 1828 |
| R27 | 91 | -2349 | 1668 |
| R28 | 92 | -2349 | 1508 |
| R1 | 93 | -2349 | 1348 |
| R2 | 94 | -2349 | 1188 |
| R3 | 95 | -2349 | 1028 |
| R4 | 96 | -2349 | 868 |
| SCL | 97 | -2349 | 632 |
| E | 98 | -2349 | 472 |
| RS | 99 | -2349 | 312 |
| R/W | 100 | -2349 | 142 |
| T1 | 101 | -2349 | -34 |
| DB7 | 102 | -2349 | -233 |
| DB6 | 103 | -2349 | -393 |
| DB5 | 104 | -2349 | -668 |
| DB4 | 105 | -2349 | -828 |
| DB3 | 106 | -2349 | -1103 |
| DB2 | 107 | -2349 | -1263 |
| DB1 | 108 | -2349 | -1538 |
| DB0 | 109 | -2349 | -1698 |
| SDA | 110 | -2349 | -1933 |
| VLCD | -2349 | -2453 |  |
| RECPAT 'F' | -2327.5 | 2427.5 |  |
| RECPAT 'C' | -2027.5 | -2512.5 |  |
| RECPAT 'C | 1982.5 | 2297.5 |  |
|  |  |  |  |

## LCD controller/driver

## 19 DEFINITIONS

| Data sheet status |  |
| :--- | :--- |
| Objective specification | This data sheet contains target or goal specifications for product development. |
| Preliminary specification | This data sheet contains preliminary data; supplementary data may be published later. |
| Product specification | This data sheet contains final product specifications. |
| Limiting values |  |
| Limiting values given are in accordance with the Absolute Maximum Rating System (IEC 134). Stress above one or <br> more of the limiting values may cause permanent damage to the device. These are stress ratings only and operation <br> of the device at these or at any other conditions above those given in the Characteristics sections of the specification <br> is not implied. Exposure to limiting values for extended periods may affect device reliability. |  |
| Application information | Where application information is given, it is advisory and does not form part of the specification. |

## 20 LIFE SUPPORT APPLICATIONS

These products are not designed for use in life support appliances, devices, or systems where malfunction of these products can reasonably be expected to result in personal injury. Philips customers using or selling these products for use in such applications do so at their own risk and agree to fully indemnify Philips for any damages resulting from such improper use or sale.

## 21 PURCHASE OF PHILIPS $I^{2} \mathrm{C}$ COMPONENTS

Purchase of Philips $I^{2} \mathrm{C}$ components conveys a license under the Philips' $I^{2} \mathrm{C}$ patent to use the components in the $I^{2} \mathrm{C}$ system provided the system conforms to the $\mathrm{I}^{2} \mathrm{C}$ specification defined by Philips. This specification can be ordered using the code 939839340011.

## Philips Semiconductors - a worldwide company

Argentina: see South America
Australia: 34 Waterloo Road, NORTH RYDE, NSW 2113, Tel. +61 29805 4455, Fax. +61 298054466
Austria: Computerstr. 6, A-1101 WIEN, P.O. Box 213,
Tel. +43 160 101, Fax. +43 1601011210
Belarus: Hotel Minsk Business Center, Bld. 3, r. 1211, Volodarski Str. 6, 220050 MINSK, Tel. +375 172200 733, Fax. +375 172200773
Belgium: see The Netherlands
Brazil: see South America
Bulgaria: Philips Bulgaria Ltd., Energoproject, 15th floor,
51 James Bourchier Blvd., 1407 SOFIA,
Tel. +359 2689 211, Fax. +359 2689102
Canada: PHILIPS SEMICONDUCTORS/COMPONENTS,
Tel. +1 8002347381
China/Hong Kong: 501 Hong Kong Industrial Technology Centre,
72 Tat Chee Avenue, Kowloon Tong, HONG KONG,
Tel. +852 2319 7888, Fax. +852 23197700
Colombia: see South America
Czech Republic: see Austria
Denmark: Prags Boulevard 80, PB 1919, DK-2300 COPENHAGEN S,
Tel. +45 3288 2636, Fax. +45 31571949
Finland: Sinikalliontie 3, FIN-02630 ESPOO,
Tel. +3589615800, Fax. +358961580/xxx
France: 4 Rue du Port-aux-Vins, BP317, 92156 SURESNES Cedex, Tel. +33 14099 6161, Fax. +33 140996427
Germany: Hammerbrookstraße 69, D-20097 HAMBURG,
Tel. +49 402353 60, Fax. +49 4023536300
Greece: No. 15, 25th March Street, GR 17778 TAVROS/ATHENS, Tel. +30 14894 339/239, Fax. +30 14814240
Hungary: see Austria
India: Philips INDIA Ltd, Shivsagar Estate, A Block, Dr. Annie Besant Rd. Worli, MUMBAI 400 018, Tel. +91 224938 541, Fax. +91 224938722
Indonesia: see Singapore
Ireland: Newstead, Clonskeagh, DUBLIN 14,
Tel. +35317640 000, Fax. +353 17640200
Israel: RAPAC Electronics, 7 Kehilat Saloniki St, TEL AVIV 61180, Tel. +972 3645 0444, Fax. +972 36491007
Italy: PHILIPS SEMICONDUCTORS, Piazza IV Novembre 3,
20124 MILANO, Tel. +39 26752 2531, Fax. +39 267522557
Japan: Philips Bldg 13-37, Kohnan 2-chome, Minato-ku, TOKYO 108,
Tel. +81 33740 5130, Fax. +81 337405077
Korea: Philips House, 260-199 Itaewon-dong, Yongsan-ku, SEOUL, Tel. +82 2709 1412, Fax. +82 27091415
Malaysia: No. 76 Jalan Universiti, 46200 PETALING JAYA, SELANGOR, Tel. +60 3750 5214, Fax. +60 37574880
Mexico: 5900 Gateway East, Suite 200, EL PASO, TEXAS 79905,
Tel. +9-5 8002347381
Middle East: see Italy

Netherlands: Postbus 90050,5600 PB EINDHOVEN, Bldg. VB,
Tel. +31 4027 82785, Fax. +31 402788399
New Zealand: 2 Wagener Place, C.P.O. Box 1041, AUCKLAND,
Tel. +64 9849 4160, Fax. +64 98497811
Norway: Box 1, Manglerud 0612, OSLO,
Tel. +472274 8000, Fax. +4722748341
Philippines: Philips Semiconductors Philippines Inc., 106 Valero St. Salcedo Village, P.O. Box 2108 MCC, MAKATI, Metro MANILA, Tel. +63 2816 6380, Fax. +63 28173474

## Poland: Ul. Lukiska 10, PL 04-123 WARSZAWA,

Tel. +48 22612 2831, Fax. +48 226122327

## Portugal: see Spain

Romania: see Italy
Russia: Philips Russia, UI. Usatcheva 35A, 119048 MOSCOW, Tel. +7 095755 6918, Fax. +7 0957556919
Singapore: Lorong 1, Toa Payoh, SINGAPORE 1231,
Tel. +65 350 2538, Fax. +65 2516500
Slovakia: see Austria
Slovenia: see Italy
South Africa: S.A. PHILIPS Pty Ltd., 195-215 Main Road Martindale, 2092 JOHANNESBURG, P.O. Box 7430 Johannesburg 2000,
Tel. +27 11470 5911, Fax. +27 114705494
South America: Rua do Rocio 220, 5th floor, Suite 51,
04552-903 São Paulo, SÃO PAULO - SP, Brazil,
Tel. +55 11821 2333, Fax. +55 118291849
Spain: Balmes 22, 08007 BARCELONA,
Tel. +34 3301 6312, Fax. +34 33014107
Sweden: Kottbygatan 7, Akalla, S-16485 STOCKHOLM,
Tel. +46 8632 2000, Fax. +46 86322745
Switzerland: Allmendstrasse 140, CH-8027 ZÜRICH,
Tel. +41 1488 2686, Fax. +41 14817730
Taiwan: Philips Semiconductors, 6F, No. 96, Chien Kuo N. Rd., Sec. 1,
TAIPEI, Taiwan Tel. +886 22134 2870, Fax. +886 221342874
Thailand: PHILIPS ELECTRONICS (THAILAND) Ltd.,
209/2 Sanpavuth-Bangna Road Prakanong, BANGKOK 10260,
Tel. +66 2745 4090, Fax. +66 23980793
Turkey: Talatpasa Cad. No. 5, 80640 GÜLTEPE/ISTANBUL,
Tel. +90 212279 2770, Fax. +90 2122826707
Ukraine: PHILIPS UKRAINE, 4 Patrice Lumumba str., Building B, Floor 7, 252042 KIEV, Tel. +380 44264 2776, Fax. +380 442680461
United Kingdom: Philips Semiconductors Ltd., 276 Bath Road, Hayes,
MIDDLESEX UB3 5BX, Tel. +44 181730 5000, Fax. +44 1817548421
United States: 811 East Arques Avenue, SUNNYVALE, CA 94088-3409, Tel. +1 8002347381
Uruguay: see South America
Vietnam: see Singapore
Yugoslavia: PHILIPS, Trg N. Pasica 5/v, 11000 BEOGRAD,
Tel. +381 11625 344, Fax.+381 11635777

For all other countries apply to: Philips Semiconductors, Marketing \& Sales Communications, Building BE-p, P.O. Box 218, 5600 MD EINDHOVEN, The Netherlands, Fax. +31 402724825
© Philips Electronics N.V. 1997
Internet: http://www.semiconductors.philips.com

SCA53
All rights are reserved. Reproduction in whole or in part is prohibited without the prior written consent of the copyright owner.
The information presented in this document does not form part of any quotation or contract, is believed to be accurate and reliable and may be changed without notice. No liability will be accepted by the publisher for any consequence of its use. Publication thereof does not convey nor imply any license under patent- or other industrial or intellectual property rights.
Printed in The Netherlands
417067/1200/04/pp56
Date of release: 1997 Dec 16
Document order number: 939775002924

## Philips <br> Semiconductors



PHILIPS

