## **GDM2004D** # SPECIFICATIONS OF LCD MODULE #### **Features** - 1. 5x8 dots - 2. Built-in controller (S6A0069 or equivalent) - 3. +5V power supply - 4. 1/16 duty cycle - 5. LED Backlight #### **Outline dimension** Unit: mm **Absolute maximum ratings** | Item | Symbol | | Standard | | Unit | |-----------------------------|-----------------------------------|-----|----------|-----|-------------------------| | Power voltage | $V_{\text{DD}}$ - $V_{\text{SS}}$ | 0 | - | 7.0 | V | | Input voltage | VIN | VSS | - | VDD | V | | Operating temperature range | Top | 0 | - | +50 | $^{\circ}\! \mathbb{C}$ | | Storage temperature range | Tst | -10 | - | +60 | C | | Environmental Humidity | | RH≤ | 70% | | | | Expected Life Time | | ≥50 | 0000 | | Н | Wide temperature range is available (operating/storage temperature as $-20 \sim +70/-30 \sim +80$ °C) ## **Block diagram** **Interface pin description** | Pin no. | Symbol | External connection | Function | |---------|-------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | $V_{ss}$ | | Signal ground for LCM (GND) | | 2 | $V_{ m DD}$ | Power supply | Power supply for logic (+5V) for LCM | | 3 | $V_0$ | | Contrast adjust | | 4 | RS | MPU | Register select signal | | 5 | R/W | MPU | Read/write select signal | | 6 | Е | MPU | Operation (data read/write) enable signal | | 7~10 | DB0~DB3 | MPU | Four low order bi-directional three-state data bus lines. Used for data transfer between the MPU and the LCM. These four are not used during 4-bit operation. | | 11~14 | DB4~DB7 | MPU | Four high order bi-directional three-state data bus lines. Used for data transfer between the MPU | | 15 | LED+ | LED BKL power | Power supply for BKL (Anode) | | 16 | LED- | Supply | Power supply for BKL (GND) | ## **Contrast adjust** A) For Single Source For Module with Normal Temperature Range Fluid V<sub>DD~</sub>V<sub>0</sub>: LCD Driving voltage VR: 10k~20k ## **Optical characteristics** STN type display module (Ta=25°C, VDD=5.0V) | Item | Symbol | Condition | Min. | Typ. | Max. | Unit | |----------------------|--------|-----------|------|------|------|------| | Viewing angle | θ | Cr≥2 | -60 | - | 35 | dog | | | Ф | Cr = 2 | -40 | - | 40 | deg | | Contrast ratio | Cr | | - | 15 | - | - | | Response time (rise) | Tr | - | - | 150 | 250 | mg | | Response time (fall) | Tr | - | - | 150 | 250 | ms | ## **Electrical characteristics** LED ratings | EED Tatings | | | | | | |-----------------------------|------------------|-----|------|------|-------------------| | Item | Symbol | Min | Тур. | Max | Unit | | Forward Voltage | $V_{\mathrm{F}}$ | 3.8 | 4.0 | 4.4 | V | | Forward current | IF | | 240 | | mA | | Power | P | | | 1.01 | W | | Peak wave length | λр | | 568 | | nm | | Luminance | Lv | | 185 | | Cd/m <sup>2</sup> | | Operating temperature range | VOP | -20 | - | +70 | °C | | Storage temperature range | VST | -25 | - | +80 | | ### DC characteristics | Parameter | Symbol | Conditions | Min. | Typ. | Max. | Unit | |------------------------------------------|------------------|--------------------------------|------|------|-------------------|------| | Supply voltage for LCD | $V_{DD}$ - $V_0$ | Ta =25°C | - | 4.6 | - | * 7 | | Input voltage | $V_{ m DD}$ | | 4.7 | - | 5.5 | V | | Backlight supply voltage | $V_{F}$ | | - | 4.1 | 4.3 | | | Supply current | $I_{DD}$ | Ta=25°C, V <sub>DD</sub> =5.0V | - | 1.5 | 3 | A | | Backlight supply current | $I_{\mathrm{F}}$ | V <sub>DD</sub> =5.0V R=6.8 | 150 | | | mA | | Input leakage current | Ilkg | | - | - | 1.0 | uA | | "H" level input voltage | $V_{\text{IH}}$ | | 2.2 | - | $V_{\mathrm{DD}}$ | | | "L" level input voltage | VIL | Twice initial value or less | 0 | - | 0.6 | V | | "H" level output voltage V <sub>OH</sub> | | LOH=-0.25mA | 2.4 | - | - | V | | "L" level output voltage V <sub>OL</sub> | | LOH=1.6mA | - | - | 0.4 | | ## **Read cycle** (Ta=25°C, VDD=5.0V) | Parameter | Symbol | Test pin | Min. | Typ. | Max. | Unit | |---------------------------|-------------|----------|------|------|------|------| | Enable cycle time | tc | | 500 | - | - | | | Enable pulse width | $t_{ m w}$ | Е | 300 | - | - | | | Enable rise/fall time | tr, tf | | - | - | 25 | | | RS; R/W setup time | <b>t</b> su | RS; R/W | 100 | - | - | ns | | RS; R/W address hold time | th | RS; R/W | 10 | - | - | | | Read data output delay | <b>t</b> d | DB0~DB7 | 60 | - | 90 | | | Read data hold time | <b>t</b> dh | ן שט~טפט | 20 | - | - | | Write cycle | Parameter | Symbol | Test pin | Min. | Typ. | Max. | Unit | |---------------------------|--------------|----------|------|------|------|------| | Enable cycle time | te | | 500 | - | - | | | Enable pulse width | $t_{ m w}$ | Е | 300 | - | - | | | Enable rise/fall time | tr, tf | | - | - | 25 | | | RS; R/W setup time | <b>t</b> su1 | RS; R/W | 100 | - | - | ns | | RS; R/W address hold time | <b>t</b> h1 | RS; R/W | 10 | - | - | | | Read data output delay | tsu2 | DD0 DD7 | 60 | - | - | | | Read data hold time | th2 | DB0~DB7 | 10 | - | - | | ## Write mode timing diagram ## Read mode timing diagram ## **Instruction description** #### **Outline** To overcome the speed difference between the internal clock of KS0066U and the MPU clock, KS0066U performs internal operations by storing control in formations to IR or DR. The internal operation is determined according to the signal from MPU, composed of read/write and data bus (Refer to Table 7). Instructions can be divided largely into four groups: - 1) KS0066U function set instructions (set display methods, set data length, etc.) - 2) Address set instructions to internal RAM - 3) Data transfer instructions with internal RAM - 4) Others The address of the internal RAM is automatically increased or decreased by 1. Note: during internal operation, busy flag (DB7) is read "High". Busy flag check must be preceded by the next instruction. When an MPU program with checking the busy flag (DB7) is made, it must be necessary 1/2 fuss for executing the next instruction by the falling edge of the "E" signal after the busy flag (DB7) goes to "LOW". #### **Contents** #### 1) Clear display | Ī | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |---|----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | Clear all the display data by writing "20H" (space code) to all DDRAM address, and set DDRAM address to "00H" into AC (address counter). Return cursor to the original status, namely, brings the cursor to the left edge on the fist line of the display. Make the entry mode increment (I/D="High"). #### 2) Return home | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | • | Return home is cursor return home instruction. Set DDRAM address to "00H" into the address counter. Return cursor to its original site and return display to its original status, if shifted. Contents of DDRAM does not change. #### 3) Entry mode set | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | I/D | SH | Set the moving direction of cursor and display. #### I/D: increment / decrement of DDRAM address (cursor or blink) When I/D="high", cursor/blink moves to right and DDRAM address is increased by 1. When I/D="Low", cursor/blink moves to left and DDRAM address is increased by 1. \*CGRAM operates the same way as DDRAM, when reading from or writing to CGRAM. (I/D="high". shift left, I/D="Low". Shift right). #### 4) Display ON/OFF control | | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|--------|-----|-----|-----|-----|-----|-----|-----|-----|------------| | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | D | С | В | | VE | ER 1.0 | | | | 5/ | 9 | | | | 2003/12/09 | Control display/cursor/blink ON/OFF 1 bit register. #### D: Display ON/OFF control bit When D="High", entire display is turned on. When D="Low", display is turned off, but display data remains in DDRAM. #### C: cursor ON/OFF control bit When D="High", cursor is turned on. When D="Low", cursor is disappeared in current display, but I/D register preserves its data. #### B: Cursor blink ON/OFF control bit When B="High", cursor blink is on, which performs alternately between all the "High" data and display characters at the cursor position. When B="Low", blink is off. #### 5) Cursor or display shift | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 0 | 0 | 0 | 1 | S/C | R/L | 1 | - | Shifting of right/left cursor position or display without writing or reading of display data. This instruction is used to correct or search display data. (Refer to Table 6) During 2-line mode display, cursor moves to the 2<sup>nd</sup> line after the 40<sup>th</sup> digit of the 1<sup>st</sup> line. When display data is shifted repeatedly, each line is shifted individually. When display shift is performed, the contents of the address counter are not changed. #### Shift patterns according to S/C and R/L bits | S/C | R/L | Operation | |-----|-----|---------------------------------------------------------------------------| | 0 | 0 | Shift cursor to the left, AC is decreased by 1 | | 0 | 1 | Shift cursor to the right, AC is increased by 1 | | 1 | 0 | Shift all the display to the left, cursor moves according to the display | | 1 | 1 | Shift all the display to the right, cursor moves according to the display | #### 6) Function set | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 0 | 0 | 1 | DL | N | F | - | - | #### DL: Interface data length control bit When DL="High", it mans 8-bit bus mode with MPU. When DL="Low", it mans 4-bit bus mode with MPU. Hence, DL is a signal to select 8-bit or 4-bit bus mode. When 4-but bus mode, it needs to transfer 4-bit data twice. #### N: Display line number control bit When N="Low", 1-line display mode is set. When N="High", 2-line display mode is set. #### F: Display line number control bit When F="Low", 5x8 dots format display mode is set. When F="High", 5x11 dots format display mode. #### 7) Set CGRAM address | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 0 | 1 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 | Set CGRAM address to AC. The instruction makes CGRAM data available from MPU. #### 8) Set DDRAM address | | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |---|----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | Ī | 0 | 0 | 1 | AC6 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 | #### Set DDRAM address to AC. This instruction makes DDRAM data available form MPU. When 1-line display mode (N=LOW), DDRAM address is form "00H" to "4FH". In 2-line display mode (N=High), DDRAM address in the 1<sup>st</sup> line form "00H" to "27H", and DDRAM address In the 2<sup>nd</sup> line is from "40H" to "67H". 9) Read busy flag & address | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 1 | BF | AC6 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 | This instruction shows whether KS0066U is in internal operation or not. If the resultant BF is "High", internal operation is in progress and should wait BF is to be LOW, which by then if the nest instruction can be performed. In this instruction you can also read the value of the address counter. #### 10) Write data to RAM | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 1 | 0 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Write binary 8-bit data to DDRAM/CGRAM. The selection of RAM from DDRAM, and CGRAM, is set by the previous address set instruction (DDRAM address set, CGRAM address set). RAM set instruction can also determine the AC direction to RAM. After write operation. The address is automatically increased/decreased by 1, according to the entry mode. #### 11) Read data from RAM | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 1 | 1 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | #### Read binary 8-bit data from DDRAM/CGRAM. The selection of RAM is set by the previous address set instruction. If the address set instruction of RAM is not performed before this instruction, the data that has been read first is invalid, as the direction of AC is not yet determined. If RAM data is read several times without RAM address instructions set before, read operation, the correct RAM data can be obtained from the second. But the first data would be incorrect, as there is no time margin to transfer RAM data. In case of DDRAM read operation, cursor shift instruction plays the same role as DDRAM address set instruction, It also transfers RAM data to output data register. After read operation, address counter is automatically increased/decreased by 1 according to the entry mode. After CGRAM read operation, display shift may not be executed correctly. NOTE: In case of RAM write operation, AC is increased/decreased by 1 as in read operation. At this time, AC indicates next address position, but only the previous data can be read by the read instruction. ## **Instruction table** | | | | | In | struct | ion co | de | | | | | Execution | |----------------------------------|----|-----|-----|-----|--------|--------|-----|-----|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------|------------------------| | Instruction | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | Description | Time (fosc=<br>270 KHZ | | Clear<br>Display | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | Write "20H" to DDRA and set<br>DDRAM address to "00H"<br>from AC | 1.53ms | | Return<br>Home | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | - | Set DDRAM address to "00H"<br>From AC and return cursor to<br>Its original position if shifted.<br>The contents of DDRAM are<br>not changed. | 1.53ms | | Entry mode<br>Set | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | I/D | SH | Assign cursor moving direction<br>And blinking of entire display | 39us | | Display ON/<br>OFF control | 0 | 0 | 0 | 0 | 0 | 0 | 1 | D | С | В | Set display (D), cursor (C), and<br>Blinking of cursor (B) on/off<br>Control bit. | | | Cursor or<br>Display shift | 0 | 0 | 0 | 0 | 0 | 1 | S/C | R/L | - | - | Set cursor moving and display<br>Shift control bit, and the<br>Direction, without changing of<br>DDRAM data. | 39us | | Function set | 0 | 0 | 0 | 0 | 1 | DL | N | F | - | - | Set interface data length (DL: 8-Bit/4-bit), numbers of display<br>Line (N: =2-line/1-line) and,<br>Display font type (F: 5x11/5x8) | 39us | | Set CGRAM<br>Address | 0 | 0 | 0 | 1 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 | Set CGRAM address in address Counter. | 39us | | Set DDRAM<br>Address | 0 | 0 | 1 | AC6 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 | Set DDRAM address in address Counter. | 39us | | Read busy<br>Flag and<br>Address | 0 | 1 | BF | AC6 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 | Whether during internal Operation or not can be known By reading BF. The contents of Address counter can also be read. | 0us | | Write data to<br>Address | 1 | 0 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Write data into internal RAM (DDRAM/CGRAM). | 43us | | Read data<br>From RAM | 1 | 1 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Read data from internal RAM (DDRAM/CGRAM). | 43us | NOTE: When an MPU program with checking the busy flag (DB7) is made, it must be necessary 1/2fosc is necessary for executing the next instruction by the falling edge of the "E" signal after the busy flag (DB7) goes to "Low". ## DDRAM address: Display position | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----| | 00 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 0A | 0B | 0C | 0D | 0E | 0F | 10 | 11 | 12 | 13 | | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 4A | 4B | 4C | 4D | 4E | 4F | 50 | 51 | 52 | 53 | | 14 | 15 | 16 | 17 | 18 | 19 | 1A | 1B | 1C | 1D | 1E | 1F | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | | 54 | 55 | 56 | 57 | 58 | 59 | 5A | 5B | 5C | 5D | 5E | 5F | 60 | 61 | 62 | 63 | 64 | 65 | 66 | 67 | DDRAM address Standard character pattern | Stanua | ii u C | nai av | cter p | atter | 11 | | | | | | | | | | | | |--------------------------------|------------------|--------|--------|-------|------|------|------|------|------|------|----------------------------------|------|-------------------------|------|------|------| | Upper<br>4bit<br>Lower<br>4bit | LLLL | LLLH | LLHL | LLHH | LHLL | LHLH | LHHL | LННН | HLLL | HLLH | HLHL | нгнн | HHLL | ннгн | нннг | нннн | | LLLL | CG<br>RAM<br>(1) | | | | | | | | | | | | | | | | | LLLH | (2) | | | | | | | | | | | | | | | | | LLHL | (3) | | | | | | | | | | | | | | | | | LLHH | (4) | | | | | | | | | | | | | | | | | LHLL | (5) | | | | | | | | | | 00000<br>00000<br>00000<br>00000 | | | | | | | LHLH | (6) | | | | | | | | | | | | | | | | | LHHL | (7) | | | | | | | | | | | | | | | | | ІННН | (8) | | | | | | | | | | | | | | | | | HLLL | (1) | | | | | | | | | | | | | | | | | HLLH | (2) | | | | | | | | | | | | | | | | | HLHL | (3) | | | | | | | | | | | | | | | | | нгнн | (4) | | | | | | | | | | | | #0000<br>#0000<br>#0000 | | | | | HHLL | (5) | | | | | | | | | | | | | | | | | ннгн | (6) | | | | | | | | | | | | | | | | | нннг | (7) | | | | | | | | | | | | | | | | | нннн | (8) | 00000 | | | | | | | | | | | | | | |