## NEC NG-87243-001 LCD initialisation sequence

v1.2 05 Feb 2021

These were recovered from an NEC DTR-16D-1A phone manufactured around 2003 to 2006. LCD controller compatible with Hitachi HD44780.

| LCD 16 pin interface: led, led, led, RS, E, D0, D1, D2, D3, Vcc, Gnd, Contrast?, Vcc, -, Gnd, - |                                                                                |  |  |  |
|-------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|--|--|--|
| LED K                                                                                           | Green LED cathode                                                              |  |  |  |
| Common                                                                                          | LED anodes                                                                     |  |  |  |
| LED K                                                                                           | Red LED cathode                                                                |  |  |  |
| RS                                                                                              | Register select, low for commands, high for data                               |  |  |  |
| E                                                                                               | Enable, clocks in each 4 byte nibble on the trailing edge.                     |  |  |  |
| D0 - D3                                                                                         | Data lines. These are actually lines D4 through D7 as far as the HD44780 is    |  |  |  |
|                                                                                                 | concerned – the other 4 data-lines aren't brought out to the interface, and so |  |  |  |
|                                                                                                 | communication is via 4 bit mode.                                               |  |  |  |
| Vcc                                                                                             | 3.3V, logic power supply.                                                      |  |  |  |
| GND                                                                                             | 0V                                                                             |  |  |  |
| Contrast?                                                                                       | Varies from 1.7V to 1.9V, maybe contrast control                               |  |  |  |
| Vcc?                                                                                            | Seems to be tied high                                                          |  |  |  |
| -                                                                                               | no connection                                                                  |  |  |  |
| GND                                                                                             | Seems to be tied low, R/W maybe?                                               |  |  |  |
| -                                                                                               | no connection                                                                  |  |  |  |

Once the controller is in 4 bit mode, bytes are sent to the controller as two successive nibbles, with two E clock pulses 39uS apart, most significant nibble first. Generally there is a 39uS delay between nibbles forming one byte and a 72uS delay between successive command bytes.

#### LCD initialisation:

(each byte is a command, unless designated with a "d" as data, ie RS was high) Typical initialisation sequence for Hitachi HD44780, starts off assuming it is unknown whether the chip is in 8 bit or 4 bit mode. The first 3 bytes are written with a single E clock pulse each (the MPU is only asserting 4 bits of data each time. It assumes the other 4 datalines (which aren't brought out to the interface) are all tied low.

3 3 3 2 28 08 01 06 0C
30 Function set interface to be 8 bits long

#### 8mS delay

30 Function set interface to be 8 bits long

If the chip happened to have been in 4 bit mode already, it has now received the command 33 which would also set it to 8 bit mode

#### 194uS delay

30 Function set interface to be 8 bits long

#### Now chip is definitely in 8 bit mode, set it to 4 bit mode!

- 20 Function set interface to be 4 bits long
- 28 Function set 4bits, 2 rows of character, 5x7 font
- 08 Set display OFF, cursor OFF, blink OFF
- 01 Clear display
- 06 Set increment

| 0c | Set display ON | cursor OFF, | blink OFF |
|----|----------------|-------------|-----------|
|----|----------------|-------------|-----------|

### 2S delay

|                                                                                                    | <u>e test sequence:</u>                  |
|----------------------------------------------------------------------------------------------------|------------------------------------------|
| 0c                                                                                                 | Set display ON, cursor OFF, blink OFF    |
| 80                                                                                                 | Set display RAM address 0                |
| "TES                                                                                               | r push= "                                |
| 54 <b>d</b>                                                                                        |                                          |
| 45 <b>d</b>                                                                                        |                                          |
| 53 <b>d</b>                                                                                        |                                          |
| 54 <b>d</b>                                                                                        |                                          |
| 20 <b>d</b><br>20 <b>d</b>                                                                         |                                          |
| 20 <b>u</b><br>50 <b>d</b>                                                                         |                                          |
| 55 <b>d</b>                                                                                        |                                          |
| 53 <b>d</b>                                                                                        |                                          |
| 48d                                                                                                |                                          |
| 3d <b>d</b>                                                                                        |                                          |
| 20 <b>d</b><br>20 <b>d</b>                                                                         |                                          |
| zuu                                                                                                |                                          |
| 20d                                                                                                |                                          |
| 20 <b>d</b><br>20 <b>d</b>                                                                         |                                          |
| 20 <b>d</b><br>20 <b>d</b>                                                                         |                                          |
| 20 <b>d</b><br>a0                                                                                  | Set display RAM address 32               |
| 20 <b>d</b><br>a0<br>"                                                                             | Set display RAM address 32<br>NEXT=F12 " |
| 20 <b>d</b><br>a0<br>"<br>20 <b>d</b>                                                              |                                          |
| 20d<br>a0<br>"<br>20d<br>20d                                                                       |                                          |
| 20d<br>a0<br>"<br>20d<br>20d<br>20d                                                                |                                          |
| 20d<br>a0<br>"<br>20d<br>20d<br>20d<br>20d                                                         |                                          |
| 20d<br>a0<br>"<br>20d<br>20d<br>20d<br>20d<br>20d                                                  |                                          |
| 20d<br>a0<br>"<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d                                           |                                          |
| 20d<br>a0<br>"<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d                                    |                                          |
| 20d<br>a0<br>"<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d                                           |                                          |
| 20d<br>a0<br>"<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d                             |                                          |
| 20d<br>a0<br>"<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d                             |                                          |
| 20d<br>a0<br>"<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d<br>4ed<br>45d<br>58d |                                          |
| 20d<br>a0<br>"<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d                             |                                          |

| 20d<br>20d<br>20d<br>20d<br>20d<br>20d                                        |                                        |
|-------------------------------------------------------------------------------|----------------------------------------|
| c0<br>"<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d<br>20d | Set display RAM address 64<br>L16+B 0" |

# Store 8 programmable character patterns4040Set character generator address 0

| 04d<br>0ed<br>15d<br>04d   |                                       |
|----------------------------|---------------------------------------|
| 04d<br>04d                 |                                       |
| 04 <b>d</b><br>00 <b>d</b> |                                       |
|                            |                                       |
| 04d                        |                                       |
| 04d<br>04d<br>04d          | · · · · · · · · · · · · · · · · · · · |
| 04d                        |                                       |
| 04d<br>04d<br>04d          |                                       |

| 08 <b>d</b>                | • | • | • | • |   | • | • | • |
|----------------------------|---|---|---|---|---|---|---|---|
| 04d                        | • | • | • | • | • |   | • | • |
| 00 <b>d</b>                | • | • | • | • | • | • | • | • |
| 0ed                        | • | • | • | • |   |   |   | • |
| 11d                        | • | • | • |   | • | • | • |   |
| 1fd                        | • | • | • |   |   |   |   |   |
| 11 <b>d</b>                | • | • | • |   | • | • | • |   |
| 00 <b>d</b>                | • | • | • | • | • | • | • | • |
| 02 <b>d</b>                |   |   |   |   |   |   |   |   |
| 04d                        | • | • | • | • | • | • |   | • |
| 00 <b>d</b>                | • |   |   |   |   |   |   |   |
| 0ed                        |   |   |   |   |   |   | • |   |
| 11d                        |   |   |   | Ē |   |   |   | • |
| 1fd                        | • | • | • |   | - | - | - |   |
| 11 <b>d</b>                |   |   |   |   |   |   |   |   |
| 00 <b>d</b>                |   |   |   |   | • |   |   |   |
|                            |   |   |   |   |   |   |   |   |
| 04 <b>d</b>                | • | • | • | • | • |   | • | • |
| 0a <b>d</b>                | • | • | • | • |   | • |   | • |
| 00 <b>d</b>                | • | • | • | • | • | • | • | • |
| 0ed                        | • | • | • | • |   |   |   | • |
| 11 <b>d</b>                | • | • | • |   | • | • | • |   |
| 1fd                        | • | • | • |   |   |   |   |   |
| 11 <b>d</b>                | • | • | • |   | • | • | • |   |
| 00 <b>d</b>                | • | • | • | • | • | • | • | • |
|                            |   |   |   |   |   |   | 1 |   |
| 05 <b>d</b>                | • | • | • | • | • |   | • |   |
| 0ad                        | • | • | • | • |   | • |   | • |
| 00 <b>d</b>                | • | • | • | • | • | • | • | • |
| 0ed                        | • | • | • | • |   |   |   | • |
| 11 <b>d</b><br>1f <b>d</b> | • | • | • |   | • | • | • |   |
| 11d                        | • | • | • |   |   |   |   |   |
| 00d                        | • | • | • |   | • | • | • |   |
| 000                        | • | • | • | • | • | • | • | • |
| 04 <b>d</b>                |   |   |   |   |   |   |   |   |
| 0ad                        | • |   |   |   | • |   | • |   |
| 1fd                        |   |   |   | - |   | - |   | - |
| 10 <b>d</b>                |   |   |   |   |   |   |   |   |
| 1e <b>d</b>                |   | • | • |   |   |   |   | • |
| 10 <b>d</b>                | • |   |   |   |   |   |   | • |
| 1fd                        | • |   |   |   |   |   |   |   |
| 00 <b>d</b>                |   | • | • |   |   |   |   |   |
|                            |   |   |   |   |   |   |   |   |
| 05 <b>d</b>                | • | • | • | • | • |   | • |   |
| 0a <b>d</b>                | • | • | • | • |   | • |   | • |
| 00 <b>d</b>                | • | • | • | • | • | • | • | • |
| 0ed                        | • | • | • | • |   |   |   | • |
| 11d                        | • | • | • |   | • | • | • |   |
| 11d                        | • | • | • |   | • | • | • |   |
| 1ed                        | • | • | • |   |   |   |   | • |
| 00 <b>d</b>                | • | • | • | • | • | • | • | • |

## After this point the display and programmable characters appear to be refreshed over and over while it waits for input (key-presses to test the phone):

0c Set display ON, cursor OFF, blink OFF

80 Set display RAM address 0

"TEST"

54**d** 

45**d** 

53**d** 

54**d** 

• • •