

# HT16K23A RAM Mapping 20×4/16×8 LCD Controller Driver with Keyscan

#### **Feature**

- Logic voltage: 2.4V~5.5V
- · Integrated RC oscillator
- Various display modes
  - Max. 20×4 patterns, 20 segments, 4 commons, 1/3 bias, 1/4 duty
  - Max. 16×8 patterns, 16 segments, 8 commons, 1/4 bias, 1/8 duty
- I<sup>2</sup>C-bus interface
- · Key scan function
  - Max. 20×1 matrix key scanning in 20×4 display mode
  - Max. 16×1 matrix key scanning in 16×8 display mode
- 16×8 bits RAM for display data storage
- Selectable hardware interrupt
- · R/W address auto increment
- · Manufactured in silicon gate COMS process
- 28-pin SOP/SSOP package

### **Applications**

- · Industrial control indicator
- Digital clock, thermometer, counter, voltmeter
- · Combo set
- VCR set
- · Instrumentation readouts
- Other consumer application
- · LCD displays

### **General Description**

The HT16K23A is a memory mapping and multifunction LCD controller driver. The Max. display segment numbers in the device are 80 patterns (20 segments and 4 commons) or 128 patterns (16 segments and 8 commons). The Max. key scan circuits are  $20\times1$  matrix or  $16\times1$  matrix. The software configuration feature of the HT16K23A makes it suitable for multiple LCD applications including LCD modules and display subsystems. The HT16K23A supports a hardware interrupt using register setting.

The HT16K23A is compatible with most microcontrollers and communicates via a two-line bidirectional I<sup>2</sup>C-bus.

Rev. 1.20 1 December 06, 2022



## **Block Diagram**



## **Pin Assignment**





## **Pin Description**

| Pin Name                           | Туре | Description                                                                                                                                                                                                                                                                                                                                          |
|------------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SDA                                | I/O  | Serial Data Input/Output for I <sup>2</sup> C interface.                                                                                                                                                                                                                                                                                             |
| SCL                                | I    | Serial Clock Input for I <sup>2</sup> C.                                                                                                                                                                                                                                                                                                             |
| $V_{DD}$                           | _    | Positive power supply for logic circuits.                                                                                                                                                                                                                                                                                                            |
| V <sub>ss</sub>                    | _    | Negative power supply for logic circuits, ground.                                                                                                                                                                                                                                                                                                    |
| COM0 ~ COM3                        | 0    | LCD Common output.                                                                                                                                                                                                                                                                                                                                   |
| SEG0/K0 ~                          | I/O  | LCD Segment output.                                                                                                                                                                                                                                                                                                                                  |
| SEG14/K14                          |      | Key data input, internal pull-low during key scan.                                                                                                                                                                                                                                                                                                   |
|                                    |      | • When the "M" bit of the mode set command is set to "1", and the "INT/ROW" bit of the mode set command is set to "0", this pin becomes an LCD Segment output and key data input with internal pull-low during key scan.                                                                                                                             |
| SEG15/K15/INT                      | I/O  | • When the "M" bit of the mode set command is set to "1", and the "INT/ROW" bit of the mode set command is set to "1", this pin becomes an INT pin, interrupt signal out. INT is output active-low when the "ACT" bit of mode set command is set to "0", The INT output is active-high when the "ACT" bit of the mode set command is set to "1"      |
| SEG16/COM7/K16 ~<br>SEG18/COM5/K18 | I/O  | When the "M" bit of the mode set command is set to "0", this pin becomes an LCD Segment output and a key data input with internal pull-low during a key scan.                                                                                                                                                                                        |
| OLG 10/OGINIO/ICTO                 |      | • When the "M" bit of the mode set command is set to "1", this pin becomes an LCD Common output.                                                                                                                                                                                                                                                     |
|                                    |      | • When the "M" bit of the mode set command is set to "0", and the "INT/ROW" bit of the mode set command is set to "0", this pin becomes a LCD Segment output and a key data input with internal pull-low during key scan.                                                                                                                            |
| SEG19/COM4/K19/INT                 | I/O  | • When the "M" bit of the mode set command is set to "0", and the "INT/ROW" bit of the mode set command is set to "1", this pin becomes an INT pin, interrupt signal out. The INT output is active-low when the "ACT" bit of the mode set command is set to "0", The INT output active-high when the "ACT" bit of the mode set command is set to "1" |
|                                    |      | • When the "M" bit of the mode set command is set to "1", this pin becomes an LCD Common output.                                                                                                                                                                                                                                                     |

Rev. 1.20 3 December 06, 2022



## **Approximate Internal Connections**



## **Absolute Maximum Ratings**

| Supply Voltage        | $V_{SS}$ -0.3V to $V_{SS}$ +6.5V |
|-----------------------|----------------------------------|
| Input Voltage         | $V_{SS}$ -0.3V to $V_{DD}$ +0.3V |
| Storage Temperature   | -60°C to 150°C                   |
| Operating Temperature | -40°C to 85°C                    |

Note: These are stress ratings only. Stresses exceeding the range specified under "Absolute Maximum Ratings" may cause substantial damage to the device. Functional operation of this device at other conditions beyond those listed in the specification is not implied and prolonged exposure to extreme conditions may affect device reliability.

Rev. 1.20 4 December 06, 2022



## D.C. Characteristics

V<sub>DD</sub>=2.4V~5.5V; Ta=25°C (Unless otherwise specified)

| Comple - I       | Davamatau                                 |                     | Test condition                | DA:                | T    | Mari               | Unit |
|------------------|-------------------------------------------|---------------------|-------------------------------|--------------------|------|--------------------|------|
| Symbol           | Parameter                                 | V <sub>DD</sub>     | Condition                     | Min.               | Тур. | Max.               | Unit |
| $V_{DD}$         | Operating Voltage                         | _                   | _                             | 2.4                | _    | 5.5                | V    |
|                  | On a mating of Command                    | 3V No load, LCD On, |                               | _                  | 155  | 310                | μA   |
| I <sub>DD1</sub> | Operating Current                         | 5V                  | 20×4 display mode             | _                  | 260  | 420                | μA   |
|                  | Operating Current                         | 3V                  | No load, LCD Off,             | _                  | 8    | 30                 | μΑ   |
| I <sub>DD2</sub> | Operating Current                         | 5V                  | 20×4 display mode             | _                  | 20   | 60                 | μΑ   |
|                  | Standby Current                           | 3V                  | No load, standby mode         | _                  | 1    | 3                  | μΑ   |
| I <sub>STB</sub> | Standby Current                           | 5V                  | Two load, standby mode        | _                  | 2    | 5                  | μΑ   |
| $V_{\text{IL}}$  | Input Low Voltage                         | _                   | SDA, SCL                      | 0                  | _    | 0.3V <sub>DD</sub> | V    |
| $V_{IH}$         | Input High Voltage                        | _                   | SDA, SCL                      | 0.7V <sub>DD</sub> | _    | V <sub>DD</sub>    | V    |
| $I_{\rm IL}$     | Input leakage current                     | _                   | $V_{IN} = V_{SS}$ or $V_{DD}$ | -1                 | _    | 1                  | μΑ   |
| ı                | Low level output current                  | 3V                  | V <sub>OL</sub> =0.4V, SDA    | 3                  | _    | _                  | mA   |
| I <sub>OL</sub>  | Low level output current                  | 5V                  | V <sub>OL</sub> -0.4V, 3DA    | 6                  | _    | _                  | mA   |
| ı                | LCD Common Sink Current                   | 3V                  | V <sub>OL</sub> =0.3V         | 80                 | 160  | _                  | μΑ   |
| I <sub>OL1</sub> | LCD Common Sink Current                   | 5V                  | V <sub>OL</sub> =0.5V         | 180                | 360  | _                  | μΑ   |
| ı                | LCD Common Source Current                 | 3V                  | V <sub>OH</sub> =2.7V         | -80                | -120 | _                  | μΑ   |
| I <sub>OH1</sub> | LCD Common Source Current                 | 5V                  | V <sub>OH</sub> =4.5V         | -120               | -200 | _                  | μΑ   |
| I <sub>OL2</sub> | LCD Segment Sink Current                  | 3V                  | V <sub>OL</sub> =0.3V         | 60                 | 120  | _                  | μΑ   |
| IOL2             | Lob Segment Sink Current                  | 5V                  | V <sub>OL</sub> =0.5V         | 120                | 200  | _                  | μΑ   |
| 1                | LCD Segment Source Current                | 3V                  | V <sub>OH</sub> =2.7V         | -40                | -70  | _                  | μΑ   |
| I <sub>OH2</sub> | Lob Segment Source Current                | 5V                  | V <sub>OH</sub> =4.5V         | -70                | -140 | _                  | μΑ   |
| 1.               | INT Sink Current                          | 3V                  | V <sub>OL</sub> =0.3V         | 1                  | _    | _                  | mA   |
| I <sub>OL3</sub> | IIVI OIIIK OGITCITE                       | 5V                  | V <sub>OL</sub> =0.5V         | 2                  | _    | _                  | mA   |
| 1.               | INT Source Current                        | 3V                  | V <sub>OH</sub> =2.7V         | -1                 | _    | _                  | mA   |
| I <sub>OH3</sub> | iivi oodice odireiit                      | 5V                  | V <sub>OH</sub> =4.5V         | -2                 | _    | _                  | mA   |
| R <sub>PL</sub>  | R <sub>PI</sub> Input pull-low Resistance |                     | SEG0/K0~SEG19/K19,            | 220                | 400  | 600                | ΚΩ   |
| · vpL            | Input pull-low Itesistance                | 5V                  | during keyscan period         | 220                | 400  | 600                | 1777 |

### A.C. Characteristics

 $V_{DD}$ =2.4V~5.5V; Ta=25°C (Unless otherwise specified)

| Symbol                               | Doromotor                 |                        | Test condition                  | Min  | Turn | Mey  | l lmi4 |  |
|--------------------------------------|---------------------------|------------------------|---------------------------------|------|------|------|--------|--|
| Symbol Parameter                     |                           | <b>V</b> <sub>DD</sub> | Condition                       | Min. | Тур. | Max. | Unit   |  |
| f <sub>LCD</sub> LCD Frame Frequency |                           | 3V                     | 20×4 display mode               | 58   | 72   | 90   | Hz     |  |
| f <sub>LCD</sub>                     | LCD Frame Frequency       | 5V                     | 16×8 display mode               | 36   | 12   | 90   | ПZ     |  |
| t <sub>OFF</sub>                     | V <sub>DD</sub> OFF Times | _                      | V <sub>DD</sub> drop down to 0V | 20   | _    | _    | Ms     |  |
| t <sub>SR</sub>                      | V <sub>DD</sub> Slew Rate | _                      | _                               | 0.05 | _    | _    | V/ms   |  |

Note: 1. If the Power on Reset timing conditions are not satisfied in the power On/Off sequence, the internal Power on Reset circuit will not operate normally.

2. If  $V_{DD}$  drops below the minimum voltage of the operating voltage spec. during operating, the Power on Reset timing conditions must also be satisfied. That is,  $V_{DD}$  must drop to 0V and remain at 0V for 20ms (min.) before rising to the normal operating voltage.

Rev. 1.20 5 December 06, 2022



## A.C. Characteristics - I<sup>2</sup>C-Bus

Ta=25°C (Unless otherwise specified)

| Cumbal               | Dovemeter                                     | Test condition                                                               | V <sub>DD</sub> =2.4\ | / to 5.5V | V <sub>DD</sub> =3.0\ | / to 5.5V | Unit |
|----------------------|-----------------------------------------------|------------------------------------------------------------------------------|-----------------------|-----------|-----------------------|-----------|------|
| Symbol               | Parameter                                     | Condition                                                                    | Min.                  | Max.      | Min.                  | Max.      | Unit |
| f <sub>SCL</sub>     | Clock Frequency                               | _                                                                            | _                     | 100       | _                     | 400       | kHz  |
| t <sub>BUF</sub>     | Bus Free Time                                 | Time in which the bus<br>must be free before a new<br>transmission can start | 4.7                   | -         | 1.3                   | _         | μs   |
| t <sub>HD; STA</sub> | Start Condition Hold Time                     | After this period, the first clock pulse is generated                        | 4                     | _         | 0.6                   | _         | μs   |
| t <sub>LOW</sub>     | SCL Low Time                                  | _                                                                            | 4.7                   | _         | 1.3                   | _         | μs   |
| t <sub>HIGH</sub>    | SCL High Time                                 | _                                                                            | 4                     | _         | 0.6                   | _         | μs   |
| t <sub>SU; STA</sub> | Start Condition Set-up Time                   | Only relevant for repeated START condition.                                  | 4.7                   | _         | 0.6                   | _         | μs   |
| t <sub>HD; DAT</sub> | Data Hold Time                                | _                                                                            | 0                     | _         | 0                     | _         | μs   |
| t <sub>SU; DAT</sub> | Data Set-up Time                              | _                                                                            | 250                   | _         | 100                   | _         | ns   |
| t <sub>r</sub>       | Rise Time                                     | Note                                                                         | _                     | 1         | _                     | 0.3       | μs   |
| t <sub>f</sub>       | Fall Time                                     | Note                                                                         | _                     | 0.3       | _                     | 0.3       | μs   |
| t <sub>SU; STO</sub> | Stop Condition Set-up Time                    | _                                                                            | 4                     | _         | 0.6                   | _         | μs   |
| t <sub>AA</sub>      | Output Valid from Clock                       | _                                                                            | _                     | 3.5       | _                     | 0.9       | μs   |
| t <sub>SP</sub>      | Input Filter Time Constant (SDA and SCL Pins) | Noise suppression time                                                       | _                     | 100       | _                     | 50        | ns   |

Note: These parameters are periodically sampled but not 100% tested.

## **Timing Diagrams**

## I<sup>2</sup>C Timing



## **Power-on Reset Timing**



Rev. 1.20 6 December 06, 2022



## **Functional Description**

#### **Power-on Reset**

When power is turned on, the IC is initialised by the internal power-on reset circuit. The status of the internal circuit after initialization is as follows:

- Display mode is 20×4, 20 segments and 4 commons.
- · System oscillator is off.
- · LCD Display is off.
- · Key scan stopped.
- All common pins are set to VSS.
- All segment pins are in an input state.
- SEG19/COM4/INT pin is set to segment driver.
- The control registers, key data RAM and display data RAM are set to a default value.

Data transfers on the I<sup>2</sup>C-bus should be avoided for 1 ms following power-on to allow completion of the reset procedure.

### Standby Mode

In the standby mode, the HT16K23A cannot accept any input command or write data to the display RAM except for the system set command.

If standby mode is selected with the "S" bit of system set command is set to "0", the status of the standby mode is as follows:

- · System Oscillator is off.
- · LCD display is off.

- · Key scan stopped.
- All key data and INT flags are cleared, until the standby mode is cancelled.
- The key matrix is pushed by any key or if the "S" bit of the system set command is set to "1", this standby mode will be cancelled and the device will wake-up.
- All common pins are set to VSS.
- If the "INT/ROW" bit of mode set command is set to "0", all segment pins are changed to input pins.
- If the "INT/ROW" bit of mode set command is set to "1": all segment pins are changed to input pins except for the INT pin (output).
- The INT pin output keeps a high level when the "ACT" bit of the mode set command is set to "0",.

  The INT pin output keeps to a low level when the "ACT" bit of the mode set command is set to "1", if the "INT/ROW" bit of mode set command is set to "1".

#### Wake-up

- Wake-up is implemented by a key press by any key or if the "S" bit of the system set command is set to "1". Then a key scan is performed.
- System Oscillator restarts for normal operation.
- The previous output will be displayed until updated by each mode command set.
- The relationship between Wake-up and any key press delay timeless and INT output and INT flag status is as follows:



Rev. 1.20 7 December 06, 2022



#### **System Set Command**

This command is used to set the follow functions.

- The HT16K23A operates in normal mode or standby mode. Before the standby mode command is sent, it is strongly recommended to read key data first.
- · LCD display on/off

| Name       |    |    |    | Com | mand |    |    |    | Option | Description                                                     | Def. |
|------------|----|----|----|-----|------|----|----|----|--------|-----------------------------------------------------------------|------|
| Name       | D7 | D6 | D5 | D4  | D3   | D2 | D1 | D0 | Option | Description                                                     | Dei. |
| System set | 1  | 0  | 0  | 0   | 0    | 0  | 0  | s  | S      | Standby mode selecting • {0}: standby mode • {1}: normal mode   | 80H  |
| System set | '  | 0  | U  | 0   | U    | U  | D  | 3  | D      | LCD display on/off • {0}: LCD display off • {1}: LCD display on | оип  |

#### **Mode Set Command**

This command is used to set the follow functions.

- Display mode selecting, 20×4 display mode or 16×8 display mode.
- Set the HT16K23A SEG/INT port to be a segment output or an INT output.
- INT output is active-low or active-high.

| Name        |    |    |    | Co | mma | nd  |             |    | Option  | Description                                                                                                                                                                                                                                                                                    | Def. |
|-------------|----|----|----|----|-----|-----|-------------|----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| Ivallie     | D7 | D6 | D5 | D4 | D3  | D2  | D1          | D0 | Option  | Description                                                                                                                                                                                                                                                                                    | Dei. |
|             |    |    |    |    |     |     |             |    | М       | LCD display mode selecting • {0}: 20×4 display mode • {1}:16×8 display mode                                                                                                                                                                                                                    |      |
| Mode<br>set | 1  | 0  | 1  | 0  | 0   | ACT | INT/<br>ROW | M  | INT/ROW | Segment or INT pin selecting • {0}: Segment output SEG19/COM4/K19/INT is segment output in 20×4 display mode. SEG15/K15/INT is segment output in 16×8 display mode. • {1}: INT output SEG19/COM4/K19/INT is INT output in 20×4 display mode. SEG15/K15/INT is INT output in 16×8 display mode. | АОН  |
|             |    |    |    |    |     |     |             |    | ACT     | INT output level selection, • {0}: INT output is active-low. • {1}: INT output is active-high.                                                                                                                                                                                                 |      |

#### **System Oscillator**

The internal logic and the LCD driver signals of the HT16K23A are timed by the integrated RC oscillator.

The System Clock frequency ( $f_{SYS}$ ) determines the LCD frame frequency. A clock signal must always be supplied to the device as removing the clock may freeze the standby mode command is executed. At initial system power on, the System Oscillator is in the stop state.

#### **LCD Bias Generator**

The full-scale LCD voltage (Vop) is obtained from  $V_{\text{DD}} \sim V_{\text{SS}}.$ 

Fractional LCD biasing voltages are obtained from an internal voltage divider of three series resistors connected between  $V_{\rm LCD}$  and  $V_{\rm SS}$ . The centre resistor can be switched out of the circuit to provide a 1/3 bias voltage level for the 1/4 duty configuration or 1/4 bias voltage level for the 1/8 duty configuration.

Rev. 1.20 8 December 06, 2022



#### **Segment Driver Outputs**

The LCD driver section includes segment outputs which should be connected directly to the LCD panel. The segment output signals are generated in accordance with the multiplexed column signals and with the data resident in the display latch. The unused segment outputs should be left open-circuit.

### **Common Driver Outputs**

The LCD driver section includes column outputs which should be connected directly to the LCD panel. The common output signals are generated in accordance with the selected LCD drive mode. The unused column outputs should be left open-circuit.

#### **Display Memory - RAM Structure**

The display RAM is a static 16 x 8-bit RAM where the LCD data is stored. A logic "1" in the RAM bitmap indicates the "on" state of the corresponding LCD segment; similarly a logic 0 indicates the "off" state.

There is a one-to-one correspondence between the RAM addresses and the segment outputs, and between the individual bits of a RAM word and the column outputs. The following tables show the mapping from the RAM to the LCD pattern:

| Output | СОМЗ | COM2 | COM1 | СОМО | Output | сомз | COM2 | COM1 | COM0 | address |
|--------|------|------|------|------|--------|------|------|------|------|---------|
| SEG1   | _    | _    | _    | _    | SEG0   | _    | _    | _    | _    | 00H     |
| SEG3   | _    | _    | _    | _    | SEG2   | _    | _    | _    | _    | 01H     |
| SEG5   | _    | _    | _    | _    | SEG4   | _    | _    | _    | _    | 02H     |
| SEG7   | _    | _    | _    | _    | SEG6   | _    | _    | _    | _    | 03H     |
| SEG9   | _    | _    | _    | _    | SEG8   | _    | _    | _    | _    | 04H     |
| SEG11  | _    | _    | _    | _    | SEG10  | _    | _    | _    | _    | 05H     |
| SEG13  | _    | _    | _    | _    | SEG12  | _    | _    | _    | _    | 06H     |
| SEG15  | _    | _    | _    | _    | SEG14  | _    | _    | _    | _    | 07H     |
| SEG17  | _    | _    | _    | _    | SEG16  | _    | _    | _    | _    | 08H     |
| SEG19  | _    | _    | _    | _    | SEG18  | _    | _    | _    | _    | 09H     |
|        | D7   | D6   | D5   | D4   |        | D3   | D2   | D1   | D0   | Data    |

#### RAM Mapping of 20×4 Display Mode

| Output | COM7 | СОМ6 | COM5 | COM4 | сомз | COM2 | COM1 | СОМ0 | address |
|--------|------|------|------|------|------|------|------|------|---------|
| SEG0   | _    | _    | _    | _    | _    | _    | _    | _    | 00H     |
| SEG1   | _    | _    | _    | _    | _    | _    | _    | _    | 01H     |
| SEG2   | _    | _    | _    | _    | _    | _    | _    | _    | 02H     |
| SEG3   | _    | _    | _    | _    | _    | _    | _    | _    | 03H     |
| SEG4   | _    | _    | _    | _    | _    | _    | _    | _    | 04H     |
| SEG5   | _    | _    | _    | _    | _    | _    | _    | _    | 05H     |
| SEG6   | _    | _    | _    | _    | _    | _    | _    | _    | 06H     |
| SEG7   | _    | _    | _    | _    | _    | _    | _    | _    | 07H     |
| SEG8   | _    | _    | _    | _    | _    | _    | _    | _    | H80     |
| SEG9   | _    | _    | _    | _    | _    | _    | _    | _    | 09H     |
| SEG10  | _    | _    | _    | _    | _    | _    | _    | _    | 0AH     |
| SEG11  | _    | _    | _    | _    | _    | _    | _    | _    | 0BH     |
| SEG12  | _    | _    | _    | _    | _    | _    | _    | _    | 0CH     |
| SEG13  | _    | _    | _    | _    | _    | _    | _    | _    | 0DH     |
| SEG14  |      |      |      |      |      |      |      |      | 0EH     |
| SEG15  | _    | _    | _    | _    | _    | _    | _    | _    | 0FH     |
|        | D7   | D6   | D5   | D4   | D3   | D2   | D1   | D0   | Data    |

#### RAM Mapping of 16×8 Display Mode

| MS | В |    |    |    |    |    |    | LSB |
|----|---|----|----|----|----|----|----|-----|
| D7 |   | D6 | D5 | D4 | D3 | D2 | D1 | D0  |

Rev. 1.20 9 December 06, 2022



## **LCD Drive Mode Waveforms**

• 20×4 Display Mode, 1/4 Duty, 1/3 Bias



Rev. 1.20 December 06, 2022



• 16×8 Display Mode, 1/8 Duty, 1/4 Bias



Rev. 1.20 11 December 06, 2022



#### Keyscan

- The HT16K23A supports a 20×1 matrix key scan in the 20×4 display mode and a 16×1 matrix key scan in the 16×8 display mode.
- The hardware interrupt function is optional, allowing SEG19/COM4/K19/INT in the 20×4 display mode or SEG15/K15/INT to be used as an INT output or as a segment driver. The interrupt flag can be read (polled) through the serial interface instead.
- The key scan input pins are shared with segment output pins.
- The keyscan cycle loops continuously with time, with all keys experiencing a full keyscan debounce of over 20ms. A key press is debounced and an interrupt issued if at least one key that was not pressed in a previous cycle is found pressed during both sampling periods.
- INT output is active-low when the "act" bit of the mode set command is set to "0".
- INT output is active-high when the "act" bit of the mode set command is set to "1".

#### **Keyscan and INT Timing**

- The key data is updated and the INT function is changed if the key has been pressed for 2 keycycles.
- The INT function is changed when the first key has been pressed.
- · After the key data has been read, the key data registers are cleared to "0" and the INT flag bit is set to "0". The INT pin goes low when the "ACT" bit of the mode set command is set to "1".
- · After the key data has been read, the key data registers are cleared to "0" and the INT flag bit is set to "1", and the INT pin goes low when the "ACT" bit of the mode set command is set to "0".
- The INT flag register is shown below. To clear the INT flag status, the key data register must be read from 0x20H~0x22H in one operation.





- 2. The INT flag bit is set to "0"
- 3. The INT pin goes to low when "act" bit is set to "1"
- 4. The INT pin goes to high when "act" bit is ise to "0"

Rev. 1.20 12 December 06, 2022



#### **Key Matrix Configuration**

There is a key scan circuit integral to the HT16K23A which can detect a key press. It includes twenty inputs (K0 to K19, shared with SEG0 to SEG19) in the  $20\times4$  display mode or sixteen inputs (K0 to K15, shared with SEG0 to SEG15) in the  $16\times8$  display mode.

The key matrix has a  $20\times1$  matrix in the  $20\times4$  display mode or a  $16\times1$  matrix in the  $16\times8$  display configuration as shown below:



20×1 Matrix in 20×4 Display Mode



16×1 Matrix in 16×8 Display Mode

### **Key Data Register**

After the key data registers have been read, the key data registers are cleared to "0". To enable future key presses to be identified, if the key data register is not read, the key data accumulates. There is no FIFO register in the HT16K23A. Key-press order, or whether a key has been pressed more than once, cannot be determined unless the all of the key data RAM is read after each interrupt and before completion of the next keyscan cycle.

After the key data registers have been read, the INT output and INT flag status are cleared. If a key is pressed and held down, the key is reported as being debounced (and an INT is issued) only once. The key must be detected as released by the keyscan circuit before it is debounced again.

It is strongly recommended to read the key data registers from the address 0x20H only. The key data registers of addresses from 0x20H to 0x22H should be read continuously and completed in one operation.

There is a one-to-one correspondence between the key data register addresses and the key data outputs and between the individual bits of a key data register word and the key data outputs. The following shows the mapping from the RAM to the key data output:

The key data registers are read only. The key data register format is shown below:

| Key data register               | Address | R/W   | Register Data |     |     |     |     |     |     |     |      |
|---------------------------------|---------|-------|---------------|-----|-----|-----|-----|-----|-----|-----|------|
| Rey data register               | Code    | IX/VV | D7            | D6  | D5  | D4  | D3  | D2  | D1  | D0  | Def. |
|                                 | 0x20H   | R     | K7            | K6  | K5  | K4  | K3  | K2  | K1  | K0  | 00H  |
| Key data register address point | 0x21H   | R     | K15           | K14 | K13 | K12 | K11 | K10 | K9  | K8  | 00H  |
|                                 | 0x22H   | R     | 0             | 0   | 0   | 0   | K19 | K18 | K17 | K16 | 00H  |

Rev. 1.20 13 December 06, 2022



#### **Key Scan Period Setting Command**

- HT16K23A can adjust the key scan period through this command. The setting is show as below.
- The default value of key scan period is 2 clock cycle time in 20×4 display mode, 1 clock cycle time in 16×8 display mode.
- In generally, user does not need to use this command, when key data can be read correctly.
- Due to various LCD characteristic, it will have different RC time constant in key scan period. If the equivalent capacitance is larger in the LCD, it can not be charged or discharged fully in key scan period. The key can not be read correctly. To avoid read key error, user can adjust the key scan period through this command. If key scan period is too longer, it may affect the LCD visual quality.

| Name                    |    |    |    | Comi | mand |    |    |    | Option  | Description               | Def. |
|-------------------------|----|----|----|------|------|----|----|----|---------|---------------------------|------|
| Name                    | D7 | D6 | D5 | D4   | D3   | D2 | D1 | D0 | Option  | Description               | Dei. |
| Key scan period setting | 1  | 1  | 1  | 1    | 1    | P2 | P1 | P0 | [P2:P0] | To adjust key scan period | F8H  |

#### The Setting of Key Scan Period

| [P2:P0] | 20×4 Display Mode   | 16×8 Display Mode   |
|---------|---------------------|---------------------|
| 000     | 2 clock cycle time  | 1 clock cycle time  |
| 001     | 4 clock cycle time  | 3 clock cycle time  |
| 010     | 6 clock cycle time  | 5 clock cycle time  |
| 011     | 8 clock cycle time  | 7 clock cycle time  |
| 100     | 10 clock cycle time | 9 clock cycle time  |
| 101     | 12 clock cycle time | 11 clock cycle time |
| 110     | 14 clock cycle time | 13 clock cycle time |
| 111     | 16 clock cycle time | 15 clock cycle time |

#### The Relationship of Display Period and Key Scan Period



Rev. 1.20 14 December 06, 2022



### I<sup>2</sup>C Serial Interface

The device includes a I<sup>2</sup>C serial interface. The I<sup>2</sup>C bus is used 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 are connected to a positive supply via a pull-up resistor. When the bus is free, both lines are high. The output stages of devices connected to the bus must have an open-drain or open-collector output type to implement the required wired and function. Data transfer is initiated only when the bus is not busy.

#### **Data Validity**

The data on the SDA line must be stable during the high period of the clock. The high or low state of the data line can only change when the clock signal on the SCL line is Low (see as below).



#### **START and STOP Conditions**

- A high to low transition on the SDA line while SCL is high defines a START condition.
- A low to high transition on the SDA line while SCL is high defines a STOP condition.
- START and STOP conditions are always generated by the master. The bus is considered to be busy after the START condition. The bus is considered to be free again a certain time after the STOP condition.
- The bus stays busy if a repeated START (Sr) is generated instead of a STOP condition. In this respect, the START(S) and repeated START (Sr) conditions are functionally identical.



#### **Byte Format**

Every byte put on the SDA line must be 8-bits long. The number of bytes that can be transmitted per transfer is unrestricted. Each byte has to be followed by an acknowledge bit. Data is transferred with the most significant bit (MSB) first.



Rev. 1.20 15 December 06, 2022



### Acknowledge

- Each byte of eight bits is followed by a single acknowledge bit. This acknowledge bit is a low level which is placed on the bus by the receiver. The master generates an extra acknowledge related clock pulse.
- A slave receiver which is addressed must generate an acknowledge (ACK) after the reception of each byte.
- The acknowledging device must pull down the SDA line during the acknowledge clock pulse so that it remains at a stable low level during the high period of this clock pulse.
- A master receiver must signal an end of data status to the slave by generating a not-acknowledge (NACK) bit
  on the last byte that has been clocked out of the slave. In this case, the master receiver must leave the data line
  high during the 9th pulse to not acknowledge. The master will generate a STOP or repeated START condition.



#### **Device Addressing**

- The slave address byte is the first byte received following a START condition form the master device. The first seven bits of the first byte make up the slave address. The eighth bit defines whether a read or write operation is to be performed. When this R/W bit is "1", then a read operation is selected. A "0" selects a write operation.
- The HT16K23A address bit format is shown below. When an address byte is sent, the device compares the first seven bits after the START condition. If they match, the device outputs an acknowledge on the SDA line.

| MSB |   |   |   |   |   |   | LSB |  |
|-----|---|---|---|---|---|---|-----|--|
| 1   | 1 | 1 | 0 | 0 | 1 | 1 | R/W |  |

#### **Write Operation**

• Byte Write Operation

A byte write operation requires a START condition, a slave address with an  $R/\overline{W}$  bit, a valid Register Address, Data and a STOP condition. After each of the three bytes have been transmitted, the device responds with an ACK.



Note: If the byte following slave address is a command code, the byte following the command code will be ignored.

Rev. 1.20 16 December 06, 2022



· Page Write Operation

A START condition and a slave address with a  $R/\overline{W}$  bit placed on the bus indicates to the addressed device that a Register Address will follow and is to be written to the address pointer. The data to be written to the memory is next and the internal address pointer will be incremented to the next address location on the reception of an acknowledge clock. After reaching the memory location 0x8Ah in the 20x4 display mode or 0x8Fh in the 16x8 display mode, the pointer will be reset to 0x80h.



### **Read Operation**

- In this mode, the master reads the HT16K23A data after setting the slave address. Following a  $R/\overline{W}$  bit (="0") and an acknowledge bit, the register address (An) is written to the address pointer. Next a START condition and a slave address are repeated followed by a  $R/\overline{W}$  bit (="1"). The data which was addressed is then transmitted. The address pointer is only incremented on reception of an acknowledge clock. The HT16K23A will place the data at address An+1 on the bus. The master reads and acknowledges the new byte and the address pointer is incremented to "An+2". If the register address (An) is 0X00H  $\sim$  0X0FH, after reaching the memory location 0X0FH, the pointer will reset to 0X00H. If the register address (An) is 0X20H  $\sim$  0X22H, after reaching the memory location 0X22H, the pointer will reset to 0X20H.
- · This cycle of reading consecutive addresses will continue until the master sends a STOP condition.



Rev. 1.20 17 December 06, 2022



## **Command Summary**

| NI                              | Command / Address |       |                                                                              |     |                                                                                                |    |          |                                                   | 0                |                                                                                                                                                                                                                     |                                                                                                               |      |         |                                                       |     |  |  |  |  |  |  |  |  |  |   |                                                                             |  |
|---------------------------------|-------------------|-------|------------------------------------------------------------------------------|-----|------------------------------------------------------------------------------------------------|----|----------|---------------------------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|------|---------|-------------------------------------------------------|-----|--|--|--|--|--|--|--|--|--|---|-----------------------------------------------------------------------------|--|
| Name                            | D7                | D6    | D5                                                                           | D4  | D3                                                                                             | D2 | D2 D1 D0 |                                                   | Option           | Description                                                                                                                                                                                                         |                                                                                                               |      |         |                                                       |     |  |  |  |  |  |  |  |  |  |   |                                                                             |  |
| Display data<br>Address pointer | 0                 | 0     | 0                                                                            | 0   | А3                                                                                             | A2 | A1       | A0                                                | [A3:A0]<br>(R/W) | Four bits of immediate data, bits A0 to A4, are transferred to the data pointer to define display RAM addresses.                                                                                                    | 00H                                                                                                           |      |         |                                                       |     |  |  |  |  |  |  |  |  |  |   |                                                                             |  |
| Key data<br>Address pointer     | 0                 | 0     | 1                                                                            | 0   | 0                                                                                              | 0  | K1       | K0                                                | {K0~K1}<br>(R)   | It is strongly recommended that the key data registers with addresses from 0x20H to 0x22H should be read continuously and in one operation. Therefore the key data RAM addresses should be started form 0x20H only. | 20H                                                                                                           |      |         |                                                       |     |  |  |  |  |  |  |  |  |  |   |                                                                             |  |
| INT flag<br>Address pointer     | 0                 | 0     | 1                                                                            | 1   | 0                                                                                              | 0  | 0        | 0                                                 | (R)              | INT flag address for reading INT flag status.                                                                                                                                                                       | 30H                                                                                                           |      |         |                                                       |     |  |  |  |  |  |  |  |  |  |   |                                                                             |  |
| System set                      | 1                 | 0     | 0                                                                            | 0   | 0                                                                                              | 0  | D        | s                                                 | S                | Standby mode selecting • {0}: standby mode • {1}: normal mode                                                                                                                                                       | 80H                                                                                                           |      |         |                                                       |     |  |  |  |  |  |  |  |  |  |   |                                                                             |  |
| command                         | '                 | 0     | , U                                                                          | 0   | U                                                                                              | U  | U        | U                                                 | 5                | D                                                                                                                                                                                                                   | LCD display on/off • {0}: LCD display off • {1}: LCD display on                                               | OUFI |         |                                                       |     |  |  |  |  |  |  |  |  |  |   |                                                                             |  |
|                                 |                   |       |                                                                              |     |                                                                                                |    |          |                                                   |                  |                                                                                                                                                                                                                     |                                                                                                               |      |         |                                                       |     |  |  |  |  |  |  |  |  |  | М | LCD display mode selecting • {0}: 20×4 display mode • {1}:16×8 display mode |  |
|                                 |                   | 1 0 1 |                                                                              |     |                                                                                                |    |          |                                                   |                  |                                                                                                                                                                                                                     | Segment or INT pin selecting • {0}: Segment output SEG19/COM4/K19/INT is segment output in 20×4 display mode. |      |         |                                                       |     |  |  |  |  |  |  |  |  |  |   |                                                                             |  |
| Mode set                        | 1                 |       | 0                                                                            | 0   | 0                                                                                              | 0  | 1        | 0                                                 | 0                | ACT                                                                                                                                                                                                                 | INT/                                                                                                          | М    | INT/ROW | SEG15/K15/INT is segment output in 16×8 display mode. | A0H |  |  |  |  |  |  |  |  |  |   |                                                                             |  |
| command                         | ROW               |       | {1}: INT output<br>SEG19/COM4/K19/INT is INT output<br>in 20×4 display mode. |     |                                                                                                |    |          |                                                   |                  |                                                                                                                                                                                                                     |                                                                                                               |      |         |                                                       |     |  |  |  |  |  |  |  |  |  |   |                                                                             |  |
|                                 |                   |       |                                                                              |     |                                                                                                |    |          | SEG15/K15/INT is INT output in 16×8 display mode. |                  |                                                                                                                                                                                                                     |                                                                                                               |      |         |                                                       |     |  |  |  |  |  |  |  |  |  |   |                                                                             |  |
|                                 |                   |       |                                                                              | ACT | INT output level selection, • {0}: INT output is active-low. • {1}: INT output is active-high. |    |          |                                                   |                  |                                                                                                                                                                                                                     |                                                                                                               |      |         |                                                       |     |  |  |  |  |  |  |  |  |  |   |                                                                             |  |
| Key scan period setting         | 1                 | 1     | 1                                                                            | 1   | 1                                                                                              | P2 | P1       | P0                                                | [P2:P0]          | To adjust key scan period                                                                                                                                                                                           | F8H                                                                                                           |      |         |                                                       |     |  |  |  |  |  |  |  |  |  |   |                                                                             |  |

Note: If the programmed command data is not defined, the function will not be affected.

Rev. 1.20 18 December 06, 2022



## **Operation Flow Chart**

The access procedure is illustrated using the following flowcharts.

#### Initialisation



#### • Display Data Rewrite - Address Setting



### Key Data Read



Rev. 1.20 19 December 06, 2022



## **Power Supply Sequence**

- If the power is individually supplied on the LCD and VDD pins, it is strongly recommended to follow the Holtek power supply sequence requirement.
- If the power supply sequence requirement is not followed, it may result in malfunction.

Holtek Power Supply Sequence Requirement:

- 1. Power-on sequence: Turn on the logic power supply  $V_{\text{DD}}$  first and then turn on the LCD driver power supply  $V_{\text{LCD}}$ .
- 2. Power-off sequence: Turn off the LCD driver power supply  $V_{\text{LCD}}$ . First and then turn off the logic power supply  $V_{\text{DD}}$ .
- 3. The Holtek Power Supply Sequence Requirement must be followed no matter whether the  $V_{\text{LCD}}$  voltage is higher than the  $V_{\text{DD}}$  voltage.
- When the  $V_{\mbox{\tiny LCD}}$  voltage is smaller than or is equal to  $V_{\mbox{\tiny DD}}$  voltage application



Rev. 1.20 20 December 06, 2022



## **Application Circuit**

### • 20×4 Display Mode Without INT



#### • 19×4 Display Mode with INT



Note: R1=180k $\Omega \sim 220k\Omega,$  adjust R1 to fit the LCD visual quality.

Rev. 1.20 21 December 06, 2022



### • 16×8 Display Mode Without INT



### • 15×8 Display Mode With INT



Note: R1=180k $\Omega \sim 220k\Omega,$  adjust R1 to fit the LCD visual quality.

Rev. 1.20 December 06, 2022



## **Package Information**

Note that the package information provided here is for consultation purposes only. As this information may be updated at regular intervals users are reminded to consult the <u>Holtek website</u> for the latest version of the <u>Package/Carton Information</u>.

Additional supplementary information with regard to packaging is listed below. Click on the relevant section to be transferred to the relevant website page.

- Package Information (include Outline Dimensions, Product Tape and Reel Specifications)
- The Operation Instruction of Packing Materials
- Carton information

Rev. 1.20 23 December 06, 2022



## 28-pin SOP (300mil) Outline Dimensions







| Cumbal | Dimensions in inch |           |       |  |  |  |  |
|--------|--------------------|-----------|-------|--|--|--|--|
| Symbol | Min.               | Nom.      | Max.  |  |  |  |  |
| A      | _                  | 0.406 BSC | _     |  |  |  |  |
| В      | _                  | 0.295 BSC | _     |  |  |  |  |
| С      | 0.012              | _         | 0.020 |  |  |  |  |
| C,     | _                  | 0.705 BSC | _     |  |  |  |  |
| D      | _                  | _         | 0.104 |  |  |  |  |
| E      | _                  | 0.050 BSC | _     |  |  |  |  |
| F      | 0.004              | _         | 0.012 |  |  |  |  |
| G      | 0.016              | _         | 0.050 |  |  |  |  |
| Н      | 0.008              | _         | 0.013 |  |  |  |  |
| α      | 0°                 | _         | 8°    |  |  |  |  |

| Symbol | Dimensions in mm |           |      |  |  |  |  |
|--------|------------------|-----------|------|--|--|--|--|
| Symbol | Min.             | Nom.      | Max. |  |  |  |  |
| А      | _                | 10.30 BSC | _    |  |  |  |  |
| В      | _                | 7.50 BSC  | _    |  |  |  |  |
| С      | 0.31             | _         | 0.51 |  |  |  |  |
| C'     | _                | 17.90 BSC | _    |  |  |  |  |
| D      | _                | _         | 2.65 |  |  |  |  |
| E      | _                | 1.27 BSC  | _    |  |  |  |  |
| F      | 0.10             | _         | 0.30 |  |  |  |  |
| G      | 0.40             | _         | 1.27 |  |  |  |  |
| Н      | 0.20             | _         | 0.33 |  |  |  |  |
| α      | 0°               | _         | 8°   |  |  |  |  |

Rev. 1.20 24 December 06, 2022



## 28-pin SSOP (150mil) Outline Dimensions







| Cumbal | Dimensions in inch |           |       |  |  |  |  |
|--------|--------------------|-----------|-------|--|--|--|--|
| Symbol | Min.               | Nom.      | Max.  |  |  |  |  |
| A      | _                  | 0.236 BSC | _     |  |  |  |  |
| В      | _                  | 0.154 BSC | _     |  |  |  |  |
| С      | 0.008              | _         | 0.012 |  |  |  |  |
| C'     | _                  | 0.390 BSC | _     |  |  |  |  |
| D      | _                  | _         | 0.069 |  |  |  |  |
| E      | _                  | 0.025 BSC | _     |  |  |  |  |
| F      | 0.004              | _         | 0.010 |  |  |  |  |
| G      | 0.016              | _         | 0.050 |  |  |  |  |
| Н      | 0.004              | _         | 0.010 |  |  |  |  |
| α      | 0°                 | _         | 8°    |  |  |  |  |

| Cymphal | Dimensions in mm |           |      |  |  |  |  |
|---------|------------------|-----------|------|--|--|--|--|
| Symbol  | Min.             | Nom.      | Max. |  |  |  |  |
| A       | _                | 6.00 BSC  | _    |  |  |  |  |
| В       | _                | 3.90 BSC  | _    |  |  |  |  |
| С       | 0.20             | _         | 0.30 |  |  |  |  |
| C'      | _                | 9.90 BSC  | _    |  |  |  |  |
| D       | _                | _         | 1.75 |  |  |  |  |
| E       | _                | 0.635 BSC | _    |  |  |  |  |
| F       | 0.10             | _         | 0.25 |  |  |  |  |
| G       | 0.41             | _         | 1.27 |  |  |  |  |
| Н       | 0.10             | _         | 0.25 |  |  |  |  |
| α       | 0°               | _         | 8°   |  |  |  |  |

Rev. 1.20 25 December 06, 2022



Copyright<sup>©</sup> 2022 by HOLTEK SEMICONDUCTOR INC. All Rights Reserved.

The information provided in this document has been produced with reasonable care and attention before publication, however, HOLTEK does not guarantee that the information is completely accurate. The information contained in this publication is provided for reference only and may be superseded by updates. HOLTEK disclaims any expressed, implied or statutory warranties, including but not limited to suitability for commercialization, satisfactory quality, specifications, characteristics, functions, fitness for a particular purpose, and non-infringement of any third-party's rights. HOLTEK disclaims all liability arising from the information and its application. In addition, HOLTEK does not recommend the use of HOLTEK's products where there is a risk of personal hazard due to malfunction or other reasons. HOLTEK hereby declares that it does not authorise the use of these products in life-saving, life-sustaining or safety critical components. Any use of HOLTEK's products in life-saving/sustaining or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold HOLTEK harmless from any damages, claims, suits, or expenses resulting from such use. The information provided in this document, including but not limited to the content, data, examples, materials, graphs, and trademarks, is the intellectual property of HOLTEK (and its licensors, where applicable) and is protected by copyright law and other intellectual property laws. No license, express or implied, to any intellectual property right, is granted by HOLTEK herein. HOLTEK reserves the right to revise the information described in the document at any time without prior notice. For the latest information, please contact us.

Rev. 1.20 26 December 06, 2022