### **INTRODUCTION** KS0078 is a dot matrix LCD driver & controller LSI which is fabricated by low power CMOS technology. It can display 1, 2, or 4 lines with 5 x 8 or 6 x 8 dots format. ### **FUNCTIONS** - . Character type dot matrix LCD driver & controller . Internal driver : 34 common and 120 segment signal output . Easy interface with 4-bit or 8-bit MPU - . Clock synchronized serial Interface - . 5 x 8 dot matrix possible - . 6 x 8 dot matrix possible - . Bidirectional shift function - . All character reverse display - . Display shift per line . Voltage converter for LCD drive voltage : 13 V max (2 times / 3 times) . Various instruction functions - . Automatic power on reset ### KS0078 # **PRELIMINARY** 34COM/120SEG DRIVER & CONTROLLER FOR DOT MATRIX LCD ### **FEATURES** - Internal Memory Character Generator ROM (CGROM): 9,600 bits (240 characters x 5 x 8 dot) Character Generator RAM (CGRAM): 64 x 8 bits (8 characters x 5 x 8 dot) Segment Icon RAM (SEGRAM): 16 x 8 bits (96 icons max.) Display Data RAM (DDRAM): 96 x 8 bits (96 characters max.) Low power operation Power supply voltage range: 2.7~5.5 V (VDD) LCD Drive voltage range: 3.0 ~ 13.0 V (VDD V5) - . Programmable duty cycle : 1/17, 1/33 (refer to Table 1.) - . Internal oscillator with an external resistor - . Bare chip available Table 1. Programmable duty cycles #### 5-dot font width | Display Line | Duty Ratio | Single-chip Oper | ration | |--------------|------------|--------------------------|----------------| | Numbers | | Displayable characters | Possible icons | | 1 | 1/17 | 1 line of 48 characters | 80 | | 2 | 1/33 | 2 lines of 48 characters | 80 | | 4 | 1/33 | 4 lines of 24 characters | 80 | #### 6-dot font width | Display Line | Duty Ratio | Single-chip Oper | ration | |--------------|------------|--------------------------|----------------| | Numbers | | Displayable characters | Possible icons | | 1 | 1/17 | 1 line of 40 characters | 96 | | 2 | 1/33 | 2 lines of 40 characters | 96 | | 4 | 1/33 | 4 lines of 20 characters | 96 | ### **BLOCK DIAGRAM** ### **PAD CONFIGURATION** # KS0078 # PRELIMINARY 34COM/120SEG DRIVER & CONTROLLER FOR DOT MATRIX LCD # PAD DESCRIPTION | PAD (NO) | INPUT/ | NAME | DESCRIPTION | INTERFACE | |-----------------------|---------|-------------------|---------------------------------------------------------------------------------------------|---------------------| | | OUTPUT | | | | | VDD (60) | | | for logical circuit(+3V,+5V) | | | VSS1,VSS2 | - | | 0V(GND) | | | (66,81) | | | | | | V1~V5 | | Power supply | Bias voltage level for LCD driving. | Power supply | | (88 <sub>i</sub> -84) | | | | | | Vci (78) | Input | | Input voltage to the voltage converter to generate LCD drive voltage(Vci = $2.5_{i}$ 4.5V). | | | SEG1~SEG80 | Output | Segment output | Segment signal output for LCD drive. | LCD | | (106~42) | | | | | | COM0~COM33 | Output | Common output | Common signal output for LCD drive. | LCD | | (105~89, | | | | | | 43~59) | | | | | | OSC1,OSC2 | Input | Oscillator | When use internal oscillator, connect external Rf | External | | (61,62) | (OSC1), | | resistor. | resistor/oscillator | | | Output | | If external clock is used,connect it to OSC1. | (OSC1) | | | (OSC2) | | | | | C1,C2 (80,79) | Input | External | To use the voltage converter(2 times /3 times), | External | | | | capacitance input | these pins must be connected to the external capacitance. | capacitance | | RESET (63) | Input | Reset pin | Initialized to Low | - | | IE (65) | Input | Select pin | When IE = "High", Instruction set is | - | | | | of | selected as Table 6. | | | | | instruction | When IE = "Low", Instruction set is selected as | | | | | set | Table 10. | | | V5OUT2(82) | Output | Two times | The value of Vci is converted two times. To use | V5 | | | | converter | three times converter, the same capacitance as that of C1-C2 should be connected here. | capacitance | | | | output | | | | V5OUT3(83) | | Three times | The value of Vci is converted three times. | V5 | | | | converter | | | | | | output | | | # KS0078 # PRELIMINARY 34COM/120SEG DRIVER & CONTROLLER FOR DOT MATRIX LCD # PAD DESCRIPTIONcontinued) | PAD (NO) | INPUT/ | NAME | DESCRIPTION | INTERFACE | |----------------------------------|---------------------------------------|----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------| | | ОИТРИТ | | | | | IM (64) | Input | Interface mode selection | Select Interface mode with the MPU. When IM = "Low" : Serial mode, | - | | | | | When IM = "High" : 4-bit/8-bit bus mode. | | | RS/CS (67) | Input | Register select/<br>Chip select | When bus mode, used as register selection input. When RS/CS = "High", Data register is selected. When RS/CS = "Low", Instruction register is selected. | MPU | | | | | When serial mode, used as chip selection input. When RS/CS = "Low", selected. When RS/CS = "High", not selected.(Low access enable) | | | RW/SID (68) | Input | Read <sub>i</sub> ¤write/Serial input data | When bus mode, used as read/write selection input. When RW/SID = "High", read operation. When RW/SID = "Low", write operation. | MPU | | | | | When serial mode, used for data input pin. | | | E/SCLK (69) | Input | Read <sub>i</sub> ¤write<br>enable/Serial<br>clock | When bus mode, used as read; write enable signal. When serial mode, used as serial clock input | MPU | | | | 0.001. | pin. | | | DB0/SOD (70) | Input <sub>i</sub> ¤Output/Out<br>put | Data bus 0<br>bit/Serial output<br>data | When 8-bit bus mode, used as lowest bidirectional data bit. During 4-bit bus mode, Open this pin. | MPU | | | | | When serial mode, used as serial data output pin. If not in read operation, open this pin. | | | DB1~DB3<br>(71~73) | Input. | Data bus 1 ~ 7 | When 8-bit bus mode, used as low order bidirectional data bus. | MPU | | (1.1.13) | Ouptut | | During 4-bit bus mode or serial mode, open these pins. | | | DB4 <sub>i</sub> -DB7<br>(74~77) | | | When 8-bit bus mode, used as high order bidirectional data bus. In case of 4-bit bus mode, used as both high and low order. DB7 used for Busy Flag output. During serial mode, open these pins. | MPU | ### **FUNCTION DESCRIPTION** #### System Interface This chip has all three kinds interface type with MPU: serial, 4-bit bus and 8-bit bus. Serial and bus(4-bit/8-bit) is selected by IM input, and 4-bit bus and 8-bit bus is selected by DL bit in the instruction register. During read or write operation, two 8-bit registers are used. one is data register (DR), the other is instruction register(IR). The data register(DR) is used as temporary data storage place for being written into or read from DDRAM/CGRAM/SEGRAM, target RAM is selected by RAM address setting instruction. Each internal operation, reading from or writing into RAM, is done automatically. So to speak, after MPU reads DR data, the data in the next DDRAM/CGRAM/SEGRAM address is transferred into DR automatically. Also after MPU writes data to DR, the data in DR is transferred into DDRAM/CGRAM/SEGRAM automatically. The Instruction register(IR) is used only to store instruction code transferred from MPU. MPU cannot use it to read instruction data. To select register, use RS/CS input pin in 4-bit/8-bit bus mode(IM = "High") or RS bit in serial mode(IM = "Low"). Table 2. Various kinds of operations according to RS and R/W bits. | RS | R/W | Operation | |----|-----|-------------------------------------------------------------------| | 0 | 0 | Instruction Write operation (MPU writes Instruction code into IR) | | 0 | 1 | Read Busy flag(DB7) and address counter (DB0 <sub>i</sub> -DB6) | | 1 | 0 | Data Write operation (MPU writes data into DR) | | 1 | 1 | Data Read operation (MPU reads data from DR) | #### Busy Flag (BF) When BF = "High", it indicates that the internal operation is being processed. So during this time the next instruction cannot be accepted. BF can be read, when RS = Low and R/W = High(Read Instruction Operation), through DB7 Before excuting the next instruction, be sure that BF is not High. ### Display Data RAM (DDRAM) DDRAM stores display data of maximum 96 x 8 bits (96 characters). DDRAM address is set in the address counter (AC) as a hexadecimal number. (refer to Fig-1.) Fig-1. DDRAM Address - 1) Display of 5-dot font width character - (1) 5-dot 1 line display In case of 1 line display with 5-dot font, the address range of DDRAM is $00H_{i}$ - 5FH. (Refer to Fig-2) Fig-2. 1-line X 48ch. display ### (2) 5-dot 2 line display In case of 2 line display with 5-dot font, the address range of DDRAM is 00H~ 2FH, 40H ~ 6FH. (refer to Fig-3) Fig-3. 2-line X 48ch. display (5-dot font width) | | | Disp | play position | |---------------------------------------------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------| | 1 2 3 4 5 | | 20 21 22 23 24 25 26 27 28 29 | 44 45 46 47 48 | | COM1 00 01 02 08 04 | | 13 14 15 16 17 18 19 1A 1B 1C | 28 2 20 2 2 F COM9 | | COM17<br>40 41 42 43 44 | | 3 54 55 56 57 B 9 5A 3B 5C | 6B 6C 6D 6E 6F COM32 | | SEG1 | | SEG120 SEG1 DDRAM | addresss SEG120 | | | KS0078 | K | S0078 | | 1 2 3 4 5 COM1 COM8 COM8 COM8 COM8 COM8 COM8 COM8 COM8 | | 20 21 22 23 24 25 26 27 28 29<br>14 15 16 17 18 19 1A 1B 12 10 . | 44 45 46 47 48 2 2 2 2 7 0 COM9 | | COM17 4 4 4 4 45 | | 54 55 56 57 58 59 5A 5B 5C 5D | 60 60 66 6F 40 COM25 | | | | (After Shift Left) | | | | | | | | 1 2 3 4 5 | | 20 21 22 23 24 25 26 27 28 29 | 44 45 46 47 48 | | 2F 00 01 02 08 | | 12 13 14 15 16 77 18 19 1A 18 | 2A 2B 2C 2D 2E COM9 | | COM17<br>COM24 6F 40 41 42 43 | | 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 <td>6A 6B 6C 6D 6E COM32</td> | 6A 6B 6C 6D 6E COM32 | | | | (After Shift Right) | | (3) 5-dot 4 line display In case of 4 line display with 5-dot font, the address range of DDRAM is $00H_i$ - 17H, $20H_i$ - 37H, $40H_i$ - 57H, 60H ;- 77H. (refer to Fig-4) Fig-4. 4-line X 24ch. display (5-dot font width) ### 2) Display of 6-dot font width character ### (1) 6-dot 1 line display In case of 1 line display with 6-dot font, the address range of DDRAM is $00H\sim5FH$ . (refer to Fig-5) Fig-5. 1-line X 40ch. display ### (2)6-dot 2 line display In case of 2 line display with 6-dot font, the address range of DDRAM is $00H_{i^-}$ 2FH, $40H_{i^-}$ 6FH. (refer to Fig-6) Fig-6. 2-line X 40ch. display (6-dot font width) (3) 6-dot 4 line display In case of 4 line display with 6-dot font, the address range of DDARM is 00H $\sim$ 17H, 20H $\sim$ 37H, 40H $\sim$ 57H, 60H ~ 77H. (refer to Fig-7) Fig-7. 4-line X 20ch. display (6-dot font width) #### **Timing Generation Circuit** Timing generation circuit generates clock signals for the internal operations. #### Address Counter (AC) Address Counter(AC) stores DDRAM/CGRAM/SEGRAM address, transferred from IR. After writing into (reading from) DDRAM/CGRAM/SEGRAM, AC is automatically increased (decreased) by 1. When RS = "Low" and R/W = "High", AC can be read through DB0<sub>i</sub>-DB6 #### **Cursor/Blink Control Circuit** It controls cursor/blink ON/OFF and black/white inversion at cursor position. ### **LCD Driver Circuit** LCD Driver circuit has 34 common and 120 segment signals for LCD driving. Data from SEGRAM/CGRAM/CGROM is transferred to 120-bit segment latch serially, and then it is stored to 120-bit shift latch. When each com is selected by 34-bit common register, segment data also output through segment driver from 100-bit segment In case of 1-line display mode, COM0<sub>i</sub>- COM17 have 1/17 duty, and in 2-line or 4-line mode, COM0<sub>i</sub>- COM33 have 1/33 duty CGROM (Character Generator ROM) CGROM has 5 X 8-dot 240 character pattern. (refer to Table 3) Table 3. CGROM Character Code Table CGRAM (Character Generator RAM) CGRAM has up to 5 X 8-dot 8 characters. By writing font data to CGRAM, user defined character can be used. (Refer to Table 4) Table 4. Relationship between Character Code(DDRAM) and Character Pattern(CGRAM) ### 1) 5x8 dot Character pattern | С | hara | cte | r Cod | le ( DI | RAM | data | ı) | | CG | RAM a | addr | ess | | | | C | GRAM | data | a | | | Pattern | |----|------|-----|-------|---------|-----|------|----|----|----|-------|------|-----|----|----|----|----|------|-------|----|----|----|-----------| | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | A5 | Α4 | А3 | A2 | A1 | A0 | P7 | Р6 | P5 | P4 | Р3 | P2 | P1 | P0 | number | | 0 | 0 | 0 | 0 | Х | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | В1 | в0 | Х | 0 | "ç | "ç | "ç | 0 | pattern 1 | | | | | | | | | | | | | 0 | 0 | 1 | | | | ¢ | 0 | 0 | 0 | ¢ | | | | | | : | | | | | | : | | 0 | 1 | 0 | | : | | ¢ | 0 | 0 | 0 | ¢ | | | | | | : | | | | | | : | | 0 | 1 | 1 | | ÷ | | ¢ | <br>Ç | "ç | ¢ | ¢ | | | | | | : | | | | | | : | | 1 | 0 | 0 | | : | | "ç | 0 | 0 | 0 | "ç | | | | | | : | | | | | | : | | 1 | 0 | 1 | | | | "ç | 0 | 0 | 0 | "ç | | | | | | : | | | | | | : | | 1 | 1 | 0 | | : | | "ç | 0 | 0 | 0 | "ç | | | | | | ٠ | | | | | | ٠ | | 1 | 1 | 1 | | • | | 0 | 0 | 0 | 0 | 0 | | | | | | | : | | | | | : | | | : | | | | | | | | | | : | | 0 | 0 | 0 | 0 | Х | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | В1 | в0 | Х | "ç | 0 | 0 | 0 | "ç | pattern 8 | | | | | | | | | | | | | 0 | 0 | 1 | | | | ¢ | 0 | 0 | 0 | ¢ | | | | | | : | | | | | | : | | 0 | 1 | 0 | | : | | ¢ | 0 | 0 | 0 | ¢ | | | | | | : | | | | | | : | | 0 | 1 | 1 | | : | | "ç | "ç | "ç | "ç | "ç | | | | | | : | | | | | | : | | 1 | 0 | 0 | | : | | "ç | 0 | 0 | 0 | "ç | | | | | | : | | | | | | : | | 1 | 0 | 1 | | : | | ¢ | 0 | 0 | 0 | ¢ | | | | | | : | | | | | | : | | 1 | 1 | 0 | | : | | "ç | 0 | 0 | 0 | "ç | | | | | | : | | | | | | : | | 1 | 1 | 1 | | : | | 0 | 0 | 0 | 0 | 0 | | ### 2) 6x8 dot Character pattern | C | hara | cter | Cod | le (DI | RAM | data | ι) | | CG | RAM | addr | ess | | | C | GRAM data | Pattern | |----|------|------|-----|--------|-----|------|----|----|----|-----|------|-----|----|-------|----|----------------|-----------| | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | A5 | A4 | A3 | A2 | A1 | A0 | P7 P6 | P5 | P4 P3 P2 P1 P0 | number | | 0 | 0 | 0 | 0 | Х | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | B1 B0 | 0 | 0 "ç"ç"ç0 | pattern 1 | | | | | | | | | | | | | 0 | 0 | 1 | | 0 | "ç0 0 0 " | 2 | | | | | | : | | | | | : | | 0 | 1 | 0 | | 0 | "ç0 0 0 " | 3 | | | | | | | | | | | : | | 0 | 1 | 1 | : | 0 | "ç"ç"ç"ç | 2 | | | | | | : | | | | | : | | 1 | 0 | 0 | : | 0 | "ç0 0 0 "d | 2 | | | | | | : | | | | | : | | 1 | 0 | 1 | : | 0 | "ç0 0 0 "d | 2 | | | | | | : | | | | | : | | 1 | 1 | 0 | : | 0 | ¢ 0 0 0 | 3 | | | | | | • | | | | | • | | 1 | 1 | 1 | | 0 | 0 0 0 0 0 | | | | | | : | : | | | | | : | | | : | | | | : | : | | 0 | 0 | 0 | 0 | Х | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | В1 В0 | 0 | è 0 0 0 | pattern 8 | | | | | | | | | | | | | 0 | 0 | 1 | | 0 | "ç0 0 0 "d | 2 | | | | | | : | | | | | : | | 0 | 1 | 0 | : | 0 | ¢ 0 0 0 | 3 | | | | | | : | | | | | : | | 0 | 1 | 1 | : | 0 | "ç"ç"ç"ç | 2 | | | | | | : | | | | | : | | 1 | 0 | 0 | : | 0 | "ç000" | 2 | | | | | | : | | | | | : | | 1 | 0 | 1 | : | 0 | ¢ 0 0 0 | 2 | | | | | | : | | | | | : | | 1 | 1 | 0 | : | 0 | ¢ 0 0 0 | 3 | | | | | | • | | | | | • | | 1 | 1 | 1 | | 0 | 0 0 0 0 0 | | In case of 5-dot font width, when B1 = "1", enabled dots of P0 $_i$ - P4 will blink, and when B1 = "0" and B0 = "1", enabled dots in P4 will blink, when B1 = "0" and B0 = "0", blink will not happen. In case of 6-dot font width, when B1 = "1", enabled dots of P0;- P5 will blink, and when B1 = "0" and B0 = "1", enabled dots of P5 will blink, when B1 = "0" and B0 = "0", blink will not happen. 2. "X": Don't care SEGRAM (Segment Icon RAM) SEGRAM has segment control data and segment pattern data. During 1-line display mode, COM0(COM17) makes the data of SEGRAM enable to display icons. When used in 2/4-line display mode COM0(COM33) does that. Its higher 2-bits are blinking control data, and lower 6-bits are pattern data. (refer to Table 5 and Fig-8) Table 5. Relationship between SEGRAM address and display pattern | SEG | RAM | addr | ess | | | | | | SEGR | AM d | ata di | ispla | у ра | tter | n | | | | | |-----|-----|------|-----|----|----|------|-------|------|------|------|--------|-------|------|------|-------|------|------|-----|-----| | | | | | | | 5-do | ot fo | nt w | idth | ı | | | | 6-do | ot fo | nt w | idth | 1 | | | А3 | A2 | A1 | A0 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | | 0 | 0 | 0 | 0 | В1 | В0 | Х | S1 | S2 | S3 | S4 | S5 | В1 | В0 | S1 | S2 | S3 | S4 | S5 | S6 | | 0 | 0 | 0 | 1 | В1 | в0 | Х | S6 | s7 | S8 | S9 | S10 | В1 | в0 | S7 | S8 | S9 | S10 | S11 | S12 | | 0 | 0 | 1 | 0 | В1 | в0 | Х | S11 | S12 | S13 | S14 | S15 | В1 | в0 | S13 | S14 | S15 | S16 | S17 | S18 | | 0 | 0 | 1 | 1 | В1 | в0 | Х | S16 | S17 | S18 | S19 | S20 | В1 | в0 | S19 | S20 | S21 | S22 | S23 | S24 | | 0 | 1 | 0 | 0 | В1 | в0 | Х | S21 | S22 | S23 | S24 | S25 | В1 | в0 | S25 | S26 | S27 | S28 | S29 | S30 | | 0 | 1 | 0 | 1 | В1 | в0 | Х | S26 | S27 | S28 | S29 | S30 | В1 | в0 | S31 | S32 | s33 | S34 | S35 | S36 | | 0 | 1 | 1 | 0 | В1 | в0 | Х | S31 | S32 | S33 | s34 | S35 | В1 | в0 | S37 | S38 | s39 | S40 | S41 | S42 | | 0 | 1 | 1 | 1 | В1 | в0 | Х | S36 | s37 | S38 | s39 | S40 | В1 | в0 | S43 | S44 | S45 | S46 | S47 | S48 | | 1 | 0 | 0 | 0 | В1 | в0 | Х | S41 | S42 | S43 | S44 | S45 | В1 | в0 | S49 | S50 | S51 | S52 | S53 | S54 | | 1 | 0 | 0 | 1 | В1 | в0 | Х | S46 | S47 | S48 | S49 | S50 | В1 | в0 | S55 | S56 | S57 | S58 | S59 | S60 | | 1 | 0 | 1 | 0 | В1 | в0 | Х | S51 | S52 | S53 | S54 | S55 | В1 | в0 | S61 | S62 | S63 | S64 | S65 | S66 | | 1 | 0 | 1 | 1 | В1 | в0 | Х | S56 | S57 | S58 | S59 | S60 | В1 | в0 | S67 | S68 | S69 | S70 | S71 | S72 | | 1 | 1 | 0 | 0 | В1 | в0 | Х | S61 | S62 | S63 | S64 | S65 | В1 | в0 | S73 | S74 | S75 | S76 | S77 | S78 | | 1 | 1 | 0 | 1 | в1 | в0 | Х | S66 | S67 | S68 | S69 | S70 | В1 | в0 | S79 | S80 | S81 | S82 | S83 | S84 | | 1 | 1 | 1 | 0 | В1 | в0 | Х | S71 | S72 | S73 | S74 | S75 | В1 | В0 | S85 | S86 | S87 | S88 | S89 | S90 | | 1 | 1 | 1 | 1 | В1 | в0 | Х | S76 | S77 | S78 | S79 | S80 | В1 | в0 | S91 | S92 | S93 | S94 | S95 | S96 | ## \* 1. B1, B0 : Blinking control bit | Control Bit | Blinkir | ng Port | |-------------|------------------|------------------| | BE B1 B0 | 5-dot font width | 6-dot font width | | 0 X X | No blink | No blink | | 1 0 0 | No blink | No blink | | 1 0 1 | D4 | D5 | | 1 1 X | D4 ~ D0 | D5 ~ D0 | 2. S1~S80: Icon pattern ON/OFF in 5-dot font width S1~S96: Icon pattern ON/OFF in 6-dot font width 3. "X": Don't care **INSTRUCTION DESCRIPTION** ### OUTLINE To overcome the speed differance between internal clock of KS0078 and MPU clock, KS0078 performs internal operation by storing control information 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 6/10) Instruction can be divided largely four kinds, - (1) KS0078 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 internal RAM is automatically increased or decreased by 1. When IE = "High", KS0078 is operated according to Instruction Set 1(Table 6) and when IE = "Low", KS0078 is operated according to Instruction Set 2(Table 10). \* Note : During internal operation, Busy Flag (DB7) is read High. Busy Flag check must precede the next instruction. # (1) INSTRUCTION DESCRIPTION 1 (IE = "High") Table 6. Instruction Set 1 | Instruction | RE | | | Instruction Code | Description | Execution<br>Time | |------------------------------|----|----|-----|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------| | | | RS | R/W | DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 | | (fosc = 270KHz) | | Clear<br>Display | Х | 0 | 0 | 0 0 0 0 0 0 0 1 | Write "20H" to DDRAM. and set DDRAM address to "00H" from AC. | 1.52ms | | Return<br>Home | 0 | 0 | 0 | 0 0 0 0 0 0 1 X | Set DDRAM address to "00H" from AC and return cursor to its original position if shifted. The contents of DDRAM are not changed. | 1.52ms | | Power<br>Down<br>Mode | 1 | 0 | 0 | 0 0 0 0 0 0 1 PD | Set power down mode bit. PD = "1" :power down mode set, PD = "0" :power down mode disable | 37 μs | | Entry<br>Mode<br>Set | 0 | 0 | 0 | 0 0 0 0 0 1 I/D S | Assign cursor moving direction. I/D = "1" : increment, I/D = "0" : decrement and display shift enable bit. S = "1" : make display shift of the enabled lines by the DS4 -DS1 bits in the Shift Enable instruction. S = "0":display shift disable | 37 μs | | | 1 | 0 | 0 | 0 0 0 0 0 1 1 BID | Segment bidirection funtion. BID = "1" : Seg1 ; & Seg80, BID = "0" : Seg80 ; & Seg1. | | | Display<br>ON/OFF<br>Control | 0 | 0 | 0 | 0 0 0 0 1 D C B | Set display/cursor/blink on/off D = "1": display on, D = "0": display off, C = "1": cursor on, C = "0": cursor off, B = "1": blink on, B = "0": blink off. | 37 μs | | Extended function set | 1 | 0 | 0 | 0 0 0 0 1 FW B/W NW | Assign font width, black/white inverting of cursor, and 4-line display mode control bit. FW = "1" : 6-dot font width, FW = "0" : 5-dot font width, B/W = "1" : black/white inverting of cursor enable, B/W = "0" : black/white inverting of cursor disable NW = "1" : 4-line display mode, NW = "0" : 1-line or 2-line display mode. | 37 μs | ### (Table 6. continued) | | | 1 | | (Table 6. Contil | T | | |----------------------------------|----|----|-----|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------| | Instruction | RE | | | Instruction Code | Description | Execution<br>Time | | | | | | | 1 | (fosc = | | | | RS | R/W | DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 | | 270 KHz) | | Cursor<br>or<br>Display<br>Shift | 0 | 0 | 0 | 0 0 0 1 S/C R/L X X | Cursor or display shift. S/C = "1": display shift, S/C = "0": cursor shift, R/L = "1": shift to right, R/L = "0": shift to left. | 37 μs | | Shift<br>Enable | 1 | 0 | 0 | 0 0 0 1 DS4 DS3 DS2 DS1 | (when DH = "1") Determine the line for display shift . DS1 = "1/0": 1st line display shift enable/disable DS2 = "1/0": 2nd line display shift enable/disable DS3 = "1/0": 3rd line display shift enable/disable DS4 = "1/0": 4th line display shift enable/disable. | 37 μs | | Scroll<br>Enable | 1 | 0 | 0 | 0 0 0 1 HS4 HS3 HS2 HS1 | (when DH = "0") Determine the line for horizontal smooth scroll. HS1 = "1/0": 1st line dot scroll enable/disable HS2 = "1/0": 2nd line dot scroll enable/disable HS3 = "1/0": 3rd line dot scroll enable/disable HS4 = "1/0": 4th line dot scroll enable/disable. | 37 μs | | Function<br>Set | 0 | 0 | 0 | 0 0 1 DL N RE(0) DH REV | Set interface data length (DL = "1" : 8-bit, DL = "0" : 4-bit), numbers of display line when NW = "0", (N = "1" : 2-line, N = "0" : 1-line), extension register, RE("0"), shift/scroll enable DH = "1" : display shift enable DH = "0" : dot scroll enable. reverse bit REV = "1" : reverse display, REV = "0" : normal display. | 37 μs | | | 1 | 0 | 0 | 0 0 1 DL N RE(1) BE 0 | Set DL, N, RE("1") and<br>CGRAM/SEGRAM blink enable (BE)<br>BE = " 1/0" : CGRAM/SEGRAM<br>blink enable/disable | 37 μs | # (Table 6. continued) | Instruction | RE | | | Instruction Code | Description | Execution<br>Time | |-------------------------------------|----|----|-----|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------| | | | RS | R/W | DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 | | (fosc = 270 KHz) | | Set<br>CGRAM<br>Address | 0 | 0 | 0 | 0 1 AC5 AC4 AC3 AC2 AC1 AC0 | Set CGRAM address in address counter. | 37 μs | | Set<br>SEGRAM<br>Address | 1 | 0 | 0 | 0 1 X X AC3 AC2 AC1 AC0 | Set SEGRAM address in address counter. | 37 μs | | Set<br>DDRAM<br>Address | 0 | 0 | 0 | 1 AC6 AC5 AC4 AC3 AC2 AC1 AC0 | Set DDRAM address in address counter. | 37 μs | | Set<br>Scroll<br>Quantity | 1 | 0 | 0 | 1 X SQ5 SQ4 SQ3 SQ2 SQ1 SQ0 | Set the quantity of horizontal dot scroll. | 37 μs | | Read<br>Busy<br>flag and<br>Address | х | 0 | 1 | BF AC6 AC5 AC4 AC3 AC2 AC1 AC0 | Can be known whether during internal operation or not by reading BF. The contents of address counter can also be read. BF = "1": busy state, BF = "0": ready state. | 0 μs | | Write<br>Data | Х | 1 | 0 | D7 D6 D5 D4 D3 D2 D1 D0 | Write data into internal RAM (DDRAM / CGRAM / SEGRAM). | 43 μs | | Read<br>Data | Х | 1 | 1 | D7 D6 D5 D4 D3 D2 D1 D0 | Read data from internal RAM (DDRAM / CGRAM / SEGRAM). | 43 μs | \* "X" : don't care ### 1) Display Clear | 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, bring the cursor to the left edge on first line of the display. Make entry mode increment (I/D = "1"). #### 2) Return Home: (RE = 0) | 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) Power Down Mode Set: (RE = 1) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---| | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | PD | Ī | Power down mode enable bit set instruction. When PD = "High", it makes KS0078 suppress current consumption except the current needed for data storage by executing next three functions. - 1. make the output value of all the COM/SEG ports VDD - 2. make the COM/SEG output value of extension driver VDD by setting D output to "High" and M output to "Low" - 3. disable voltage converter to remove the current through the divide resistor of power supply. You can use this instruction as power sleep mode. When PD = "Low", power down mode becomes disabled. 4) Entry Mode Set (1) (RE = 0) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | I/D | s | Set the moving direction of cursor and display. | Increment / decrement of DDRAM address (cursor or blink) | When I/D = "High", cursor/blink moves to right and DDRAM address is increased by 1. | When I/D = "Low", cursor/blink moves to left and DDRAM address is decreased by 1. | \* CGRAM/SEGRAM operates the same as DDRAM, when read from or write to CGRAM/SEGRAM. When S = "High", after DDRAM write, the display of enabled line by DS1 - DS4 bits in the Shift Enable instruction is shifted to the right (I/D = "0") or to the left(I/D = "1"). But it will seem as if the cursor does not move. When S = "Low", or DDRAM read, or CGRAM/SEGRAM read/write operation, shift of display like this function is not performed. (2) (RE = 1) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | BID | Set the data shift direction of segment in the application set. BID: Data Shift Direction of Segment When BID = "Low", segment data shift direction is set to normal order from SEG1 to SEG120. When BID = "High", segment data shift direction is set to reverslyfrom SEG80 to SEG1. By using this instruction, you can raise the efficiency of application board area. \* The BID setting instruction is recommended to be set at the same time level of function set instruction. <sup>\*</sup> DB1 bit must be set to "1". ### 5) Display ON/OFF Control ( RE = 0 ) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----|--| | 0 | 0 | 0 | 0 | 0 | 0 | 1 | D | С | В | | 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 is remained in DDRAM. C: Cursor ON/OFF control bit When C = "High", cursor is turned on. When C = "Low", cursor is disappeared in current display, but I/D register remains its data. B: Cursor Blink ON/OFF control bit When B = "High", cursor blink is on, that performs alternate between all the high data and display character at the cursor position. If fosc has 270 Khz frequency, blinking has 370 ms interval. When B = "Low", blink is off. #### 6) Extended Function Set ( RE = 1 ) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 0 | 0 | 0 | 0 | 1 | FW | B/W | NW | #### FW: Font Width control When FW = "High", display character font width is assigned to 6-dot and execution time becomes 6/5 times than that of 5-dot font width. The user font, specified in CGRAM, is displayed into 6-dot font width, bit-5 to bit-0,including the leftmost space bit of CGRAM.(refer to Fig-9) When FW = "Low", 5-dot font width is set. #### B/W: Black/White Inversion enable bit When B/W = "High", black/white inversion at the cursor position is set. In this case C/B bit of display ON/OFF control instruction becomes don't care condition. If fosc has frequancy of 270 Khz, inversion has 370 ms intervals. #### NW: 4 Line mode enable bit When NW = "High", 4 line display mode is set. In this case N bit of function set instruction becomes don't care condition. Fig-9. 6-dot font width CGROM/CGRAM ### 7) Cursor or Display Shift (RE = 0) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---| | 0 | 0 | 0 | 0 | 0 | 1 | S/C | R/L | - | _ | Ī | Without writing or reading of display data, shift right/left cursor position or display. This instruction is used to correct or search display data. (Refer to Table 7) During 2-line mode display, cursor moves to the 2nd line after 48th digit of 1st line. When 4-line mode, cursor moves to the next line, only after every 24th digit of the current line. Note that display shift is performed simultaneously in all the line enabled by DS1 - DS4 in the Shift Enable instruction. When displayed data is shifted repeatedly, each line shifted individually. When display shift is performed, the contents of address counter are not changed. During low power consumption mode, display shift may not be performed normally. Table 7. Shift patterns according to S/C and R/L bits | S/C | R/L | Operation | |-----|-----|---------------------------------------------------------------------------| | 0 | 0 | Shift cursor to the left, ADDRESS COUNTER is decreased by 1 | | 0 | 1 | Shift cursor to the right, ADDRESS COUNTER 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 | 8) Shift/Scroll Enable (RE = 1) (1) (DH = 0) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---| | 0 | 0 | 0 | 0 | 0 | 1 | HS4 | HS3 | HS2 | HS1 | Ī | HS: Horizontal Scroll per Line Enable This instruction makes valid dot shift by a display line unit. HS1, HS2, HS3 and HS4 indicate each line to be dot scrolled, and each scroll is performed individually in each line. If you want to scroll the line in 1-line display mode or the 1st line in 2-line display mode, set HS1 and HS2 to "High". If the 2nd line scroll is needed in 2-line mode, set HS3 and HS4 to "High". (refer to Table 8) (2) (DH = 1) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 0 | 0 | 0 | 1 | DS4 | DS3 | DS2 | DS1 | DS: Display Shift per Line Enable This instruction selects shifting line to be shifted according to each line mode in display shift right/left instruction. DS1, DS2, DS3 and DS4 indicate each line to be shifted, and each shift is performed individually in each line. If you set DS1 and DS2 to "High" (enable) in 2 line mode, only the 1st line is shifted and the 2nd line is not shifted. When only DS1 = "High", only the half of the 1st line is shifted. If all the DS bits (DS1 to DS4) are set to "Low" (disable), no display is shifted. Table 8. Relationship between DS and COM signal | Enable bit | Enabled common signals | Description | |------------|--------------------------|------------------------------------------------------| | | during shift | | | HS1/DS1 | COM1 ;- COM8 | | | HS2/DS2 | COM9 <sub>i</sub> -COM16 | The part of display line that corresponds to enabled | | HS3/DS3 | COM17 i- COM24 | common signal can be shifted. | | HS4/DS4 | COM25 ¡- COM32 | | ### 9) Function Set ### (1) (RE = 0) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|-----|-----|-----|-----|-----|-----|--------|-----|-----| | 0 | 0 | 0 | 0 | 1 | DL | N | RE (0) | DH | REV | DL: Interface data length control bit When DL = "High", it means 8-bit bus mode with MPU. When DL = "Low", it means 4-bit bus mode with MPU. So to speak, DL is a signal to select 8-bit or 4-bit bus mode. When 4-bit bus mode, it needs to transfer 4-bit data by two times. N : Display line number control bit It is variable only when NW bit of extended function set instruction is Low. When N = "Low", it means 1-line display mode. When N = "High", 2-line display mode is set. When NW = "High", N bit is invalid, it means 4-line mode independent of N bit. RE: Extended function registers enable bit At this instruction, RE must be "Low". DH: Display shift enable selection bit. When DH = "High", display shift per line becomes enable. When DH = "Low", smooth dot scroll becomes enable. This bit can be accessed only when IE pin input is "High". REV: Reverse enable bit When REV = "High", all the display datas are reversed. Namely, all the white dots become black and black dots become white. When REV = "Low", the display mode set normal display. #### (2) (RE = 1) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | |----|-----|-----|-----|-----|-----|-----|--------|-----|-----|---| | 0 | 0 | 0 | 0 | 1 | DL | N | RE (1) | BE | 0 | I | DL: Interface data length control bit When DL = "High", it means 8-bit bus mode with MPU. When DL = "Low", it means 4-bit bus mode with MPU. So to speak, DL is a signal to select 8-bit or 4-bit bus mode. When 4-bit bus mode, it needs to transfer 4-bit data by two times. N : Display line number control bit When N = "Light", N bit is invalid, it means 4-line mode independent of N bit. When N = "High", 2-line display mode is set. When N = "High", N bit is invalid, it means 4-line mode independent of N bit. RE: Extended function registers enable bit When RE = "High", extended function set registers, SEGRAM address set registers, BID bit, HS/DS bits of shift/scroll enable instruction and BE bits of function set register can be accessed. BE: CGRAM/SEGRAM data blink enable bit If BE is "High", It makes user font of CGRAM and segment of SEGRAM blinkable. The quantity of blink is assigned the highest 2 bit of CGRAM/SEGRAM. #### 10) Set CGRAM Address (RE = 0) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 0 | 1 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 | #### Set CGRAM address to AC This instruction makes CGRAM data available from MPU. #### 11) Set SEGRAM Address (RE = 1) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----|--| | 0 | 0 | 0 | 1 | - | - | AC3 | AC2 | AC1 | AC0 | | #### Set CGRAM address to AC. This instruction makes CGRAM data available from MPU. ### 12) Set DDRAM Address (RE = 0) | 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. Set DDRAM address to AC. This instruction makes DDRAM data available from MPU. When 1-line display mode (N = 0, NW = 0), DDRAM address is from "00H" to "5FH". In 2-line display mode (N = 1, NW = 0), DDRAM address in the 1st line is from "00H" to "2FH", and DDRAM address in the 2nd line is from "40H" to "6FH". In 4-line display mode (NW = 1), DDRAM address is from "00H" to "13H" in the 1st line, from "20H" to "37H" in the 2nd line, from "40H" to "57H" in the 3rd line and from "60H" to "77H" in the 4th line. ### 13) Set Scroll Quantity (RE = 1) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---| | 0 | 0 | 1 | х | SQ5 | SQ4 | SQ3 | SQ2 | SQ1 | SQ0 | ĺ | As set SQ5 to SQ0, horizontal scroll quantity can be controlled in dot units. (Refer to Table 9). In this case KS0078 can show hidden areas of DDRAM by executing smooth scroll from 1 to 48 dots. Table 9. Scroll quantity according to HDS bits | SQ5 | SQ4 | SQ3 | SQ2 | SQ1 | SQ0 | Function | |-----|-----|-----|-----|-----|-----|----------------------| | 0 | 0 | 0 | 0 | 0 | 0 | No shift | | 0 | 0 | 0 | 0 | 0 | 1 | shift left by 1-dot | | 0 | 0 | 0 | 0 | 1 | 0 | shift left by 2-dot | | 0 | 0 | 0 | 0 | 1 | 1 | shift left by 3-dot | | : | : | : | : | • | : | : | | 1 | 0 | 1 | 1 | 1 | 1 | shift left by 47-dot | | 1 | 1 | Х | X | X | X | shift left by 48-dot | ### KS0078 ## **PRELIMINARY** 34COM/120SEG DRIVER & CONTROLLER FOR DOT MATRIX LCD #### 14) 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 KS0078 is in internal operation or not. If the resultant BF is High, it means the internal operation is in progress and you have to wait until BF to be Low, and then the next instruction can be performed. In this instruction you can read also the value of address counter. #### 15) 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 | I | Write binary 8-bit data to DDRAM/CGRAM/SEGRAM. The selection of RAM from DDRAM, CGRAM, or SEGRAM, is set by the previous address set instruction : DDRAM address set, CGRAM address set, SEGRAM address set. RAM set instruction can also determines the AC direction to RAM. After write operation, the address is automatically increased/decreased by 1, according to the entry mode. #### 16) 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 | I | ### Read binary 8-bit data from DDRAM/CGRAM/SEGRAM. The selection of RAM is set by the previous address set instruction. If address set instruction of RAM is not performed before this instruction, the data that read first is invalid, because the direction of AC is not determined. If you read RAM data several times without RAM address set instruction before read operation, you can get correct RAM data from the second, but the first data would be incorrect, because 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 transfer RAM data to output data register. After read operation address counter is automatically increased/decreased by 1 according to the entry mode. After CGRAM/SEGRAM read operation, display shift may not be executed correctly. \* In case of RAM write operation, after this AC is increased/decreased by 1 like read operation. In this time, AC indicates the next address position, but you can read only the previous data by read instruction. # (2) INSTRUCTION DESCRIPTION 2 (IE = "LOW") Table 10. Instruction Set 2 | Instruction | RE | | | Instruction Code | Description | Execution<br>Time | |----------------------------------|----|----|-----|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------| | | | RS | R/W | DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 | | (fosc = 270KHz) | | Clear<br>Display | Х | 0 | 0 | 0 0 0 0 0 0 0 1 | Write "20H" to DDRAM. and set DDRAM address to "00H" from AC. | 1.52ms | | Return<br>Home | Х | 0 | 0 | 0 0 0 0 0 0 1 X | Set DDRAM address to "00H" from AC and return cursor to its original position if shifted. The contents of DDRAM are not changed. | 1.52ms | | Entry<br>Mode<br>Set | X | 0 | 0 | 0 0 0 0 0 1 I/D S | Assign cursor moving direction. I/D = "1" : increment, I/D = "0" : decrement. and display shift enable bit. S = "1" :make entire display shift of all lines during DDRAM write, S = "0":display shift disable | 37 μs | | Display<br>ON/OFF<br>Control | 0 | 0 | 0 | 0 0 0 0 1 D C B | Set display/cursor/blink on/off D = "1" : display on, D = "0" : display off, C = "1" : cursor on, C = "0" : cursor off, B = "1" : blink on, B = "0" : blink off. | 37 μs | | Extended function set | 1 | 0 | 0 | 0 0 0 0 1 FW B/W NW | Assign font width, black/white inverting of cursor, and 4-line display mode control bit. FW = "1": 6-dot font width, FW = "0": 5-dot font width, B/W = "1": black/white inverting of cursor enable, B/W = "0": black/white inverting of cursor disable NW = "1": 4-line display mode, NW = "0": 1-line or 2-line display mode | 37 μs | | Cursor<br>or<br>Display<br>Shift | 0 | 0 | 0 | 0 0 0 1 S/C R/L X X | Cursor or display shift. S/C = "1": display shift, S/C = "0": cursor shift, R/L = "1": shift to right, R/L = "0": shift to left | 37 μs | # KS0078 # PRELIMINARY 34COM/120SEG DRIVER & CONTROLLER FOR DOT MATRIX LCD (Table 10. continued) | Instruction | RE | | | Instruction Code | Description | Execution<br>Time | |-------------------------------------|----|----|-----|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------| | | | PS | R/W | DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 | | (fosc = | | Scroll<br>Enable | 1 | 0 | 0 | 0 0 0 1 HS4 HS3 HS2 HS1 | Determine the line for horizontal smooth scroll. HS1 = "1/0" : 1st line dot scroll enable/disable HS2 = "1/0" : 2nd line dot scroll enable/disable HS3 = "1/0" : 3rd line dot scroll enable/disable HS4 = "1/0" : 4th line dot scroll enable/disable | 270 KHz) 37 μs | | Function<br>Set | 0 | 0 | 0 | 0 0 1 DL N RE(0) X X | Set interface data length DL = "1" : 8-bit, DL = "0" : 4-bit numbers of display line when NW = "0", N = "1" : 2-line, N = "0" : 1-line extension register, RE("0"), | 37 μs | | | 1 | 0 | 0 | 0 0 1 DL N RE(1) BE 0 | Set DL, N, RE("1") and CGRAM/SEGRAM blink enable (BE) BE = " 1/0" : CGRAM/SEGRAM blink enable/disable | 37 μs | | Set<br>CGRAM<br>Address | 0 | 0 | 0 | 0 1 AC5 AC4 AC3 AC2 AC1 AC0 | Set CGRAM address in address counter. | 37 μs | | Set<br>SEGRAM<br>Address | 1 | 0 | 0 | 0 1 X X AC3 AC2 AC1 AC0 | Set SEGRAM address in address counter. | 37 μs | | Set<br>DDRAM<br>Address | 0 | 0 | 0 | 1 AC6 AC5 AC4 AC3 AC2 AC1 AC0 | Set DDRAM address in address counter. | 37 μs | | Set<br>Scroll<br>Quantinty | 1 | 0 | 0 | 1 X QC5 QC4 QC3 QC2 QC1 QC0 | Set the quantity of horizontal dot scroll. | 37 μs | | Read<br>Busy<br>flag and<br>Address | Х | 0 | 1 | BF AC6 AC5 AC4 AC3 AC2 AC1 AC0 | Can be known whether during internal operation or not by reading BF. The contents of address counter can also be read. BF = "1": busy state, BF = "0": ready state. | 0 μs | | Write<br>Data | Х | 1 | 0 | D7 D6 D5 D4 D3 D2 D1 D0 | Write data into internal RAM (DDRAM / CGRAM / SEGRAM). | 43 μs | | Read<br>Data | Х | 1 | 1 | D7 D6 D5 D4 D3 D2 D1 D0 | Read data from internal RAM (DDRAM / CGRAM / SEGRAM). | 43 μs | \* "X" : don't care #### 1) Display Clear | 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, bring the cursor to the left edge on first line of the display. And entry mode is set to increment mode (I/D = "1"). ### 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 | 1 | I/D | s | I | 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 incresed by 1. When I/D = "Low", cursor/blink moves to left and DDRAM address is decreased by 1. \* CGRAM/SEGRAM operates the same as DDRAM, when read from or write to CGRAM/SEGRAM. When S = "High",after DDRAM write, the entire display of all lines is shifted to the right (I/D = "0") or to the left(I/D = "1"). But it will seem as if the cursor does not move. When S = "Low", or DDRAM read, or CGRAM/SEGRAM read/write operation, shift of entire display is not performed. #### 4) Display ON/OFF Control ( RE = 0 ) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---| | 0 | 0 | 0 | 0 | 0 | 0 | 1 | D | С | В | Ī | 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 is remained in DDRAM. C: Cursor ON/OFF control bit When C = "High", cursor is turned on. When C = "Low", cursor is disappeared in current display, but I/D register remains its data. B: Cursor Blink ON/OFF control bit When B = "High", cursor blink is on, that performs alternate between all the high data and display character at the cursor position. If fosc has 270 KHz frequency, blinking has 370 ms interval. When B = "Low", blink is off. ### 5) Extended Function Set ( RE = 1 ) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---| | 0 | 0 | 0 | 0 | 0 | 0 | 1 | FW | B/W | NW | I | #### FW : Font Width control When FW = "High", display character font width is assigned to 6-dot and execution time becomes 6/5 times than that of 5-dot font width. The user font, specified in CGRAM, is displayed into 6-dot font width, bit-5 to bit-0,including the leftmost space bit of CGRAM.(Refer to Fig-10) When FW = "Low", 5-dot font width is set. ### B/W : Black/White Inversion enable bit When B/W = "High", black/white inversion at the cursor position is set. In this case C/B bit of display ON/OFF control instruction becomes don't care condition. If fosc has frequancy of 270 KHz, inversion has 370 ms intervals. ### NW: 4 Line mode enable bit When NW = "High", 4 line display mode is set. In this case N bit of function set instruction becomes don't care condition. Fig-10. 6-dot font width CGROM/CGRAM # 6) Cursor or Display Shift (RE = 0) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---| | 0 | 0 | 0 | 0 | 0 | 1 | S/C | R/L | - | - | Ī | Without writing or reading of display data, shift right/left cursor position or display. This instruction is used to correct or search display data.(Refer to Table 7) During 2-line mode display, cursor moves to the 2nd line after 48th digit of 1st line. When 4-line mode, cursor moves to the next line, only after every 24th digit of the current line. Note that display shift is performed simultaneously in all the line. When displayed data is shifted repeatedly, each line shifted individually. When display shift is performed, the contents of address counter are not changed. Table 11. Shift patterns according to S/C and R/L bits | S/C | R/L | Operation | |-----|-----|---------------------------------------------------------------------------| | 0 | 0 | Shift cursor to the left, ADDRESS COUNTER is decreased by 1 | | 0 | 1 | Shift cursor to the right, ADDRESS COUNTER 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 | # 7) Scroll Enable (RE = 1) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---| | 0 | 0 | 0 | 0 | 0 | 1 | HS4 | HS3 | HS2 | HS1 | Ĭ | HS: Horizontal Scroll per Line Enable This instruction makes valid dot shift by a display line unit. HS1, HS2, HS3 and HS4 indicate each line to be dot scrolled, and each scroll is performed individually in each line. If you want to scroll the line in 1-line display mode or the 1st line in 2-line display mode, set HS1 and HS2 to "High". If the 2nd line scroll is needed in 2-line mode, set HS3 and HS4 to "High". (refer to Table 8) # 8) Function Set # (1) (RE = 0) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | |----|-----|-----|-----|-----|-----|-----|--------|-----|-----|---| | 0 | 0 | 0 | 0 | 1 | DL | N | RE (0) | - | - | Ī | DL : Interface data length control bit When DL = "High", it means 8-bit bus mode with MPU. When DL = "Low", it means 4-bit bus mode with MPU. So to speak, DL is a signal to select 8-bit or 4-bit bus mode. When 4-bit bus mode, it needs to transfer 4-bit data by two times. N : Display line number control bit When N = "Low", the display mode. When N = "High", 2-line display mode is set. When N = "High", N bit is invalid, it means 4-line mode independent of N bit. RE: Extended function registers enable bit At this instruction, RE must be "Low". #### (2) (RE = 1) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|-----|-----|-----|-----|-----|-----|--------|-----|-----| | 0 | 0 | 0 | 0 | 1 | DL | N | RE (1) | BE | 0 | $$\label{eq:decomposition} \begin{split} DL: & \text{Interface data length control bit} \\ & \text{When DL} = \text{"High", it means 8-bit bus mode with MPU.} \\ & \text{When DL} = \text{"Low", it means 4-bit bus mode with MPU.} \end{split}$$ So to speak, DL is a signal to select 8-bit or 4-bit bus mode. When 4-bit bus mode, it needs to transfer 4-bit data by two times. #### N : Display line number control bit It is variable only when NW bit of extended function set instruction is Low. When N = "Low", it means 1-line display mode. When N = "High", 2-line display mode is set. When NW = "High", N bit is invalid, it means 4-line mode independent of N bit. #### RE: Extended function registers enable bit When RE = "High", extended function set registers, SEGRAM address set registers, HS bits of scroll enable instruction and BE bits of function set register can be accessed. #### BE: CGRAM/SEGRAM data blink enable bit If BE is "High", It makes user font of CGRAM and segment of SEGRAM blinkable. The quantity of blink is assigned the highest 2 bit of CGRAM/SEGRAM. #### 9) Set CGRAM Address (RE = 0) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 0 | 1 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 | #### Set CGRAM address to AC. This instruction makes CGRAM data available from MPU. ### 10) Set SEGRAM Address (RE = 1) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 0 | 1 | - | - | AC3 | AC2 | AC1 | AC0 | #### Set SEGRAM address to AC. This instruction makes SEGRAM data available from MPU. # 11) Set DDRAM Address (RE = 0) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 1 | AC6 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 | #### Set DDRAM address to AC. This instruction makes DDRAM data available from MPU. When 1-line display mode (N = 0, NW = 0), DDRAM address is from "00H" to "5FH". In 2-line display mode (N = 1, NW = 0), DDRAM address in the 1st line is from "00H" to "2FH", and DDRAM address in the 2nd line is from "40H" to "6FH". In 4-line display mode (NW = 1), DDRAM address is from "00H" to "17H" in the 1st line, from "20H" to "37H" in the 2nd line, from "40H" to "57H" in the 3rd line and from "60H" to "77H" in the 4th line. # 12) Set Scroll Quantity (RE = 1) | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 1 | Х | SQ5 | SQ4 | SQ3 | SQ2 | SQ1 | SQ0 | As set SQ5 to SQ0, horizontal scroll quantity can be controlled in dot units. (Refer to Table 12). In this case KS0078 execute dot smooth scroll from 1 to 48 dots. Table 12. Scroll quantity according to HDS bits | SQ5 | SQ4 | SQ3 | SQ2 | SQ1 | SQ0 | Function | |-----|-----|-----|-----|-----|-----|----------------------| | 0 | 0 | 0 | 0 | 0 | 0 | No shift | | 0 | 0 | 0 | 0 | 0 | 1 | shift left by 1-dot | | 0 | 0 | 0 | 0 | 1 | 0 | shift left by 2-dot | | 0 | 0 | 0 | 0 | 1 | 1 | shift left by 3-dot | | : | : | : | : | : | : | : | | 1 | 0 | 1 | 1 | 1 | 1 | shift left by 47-dot | | 1 | 1 | Х | Х | Х | Х | shift left by 48-dot | #### KS0078 # PRELIMINARY 34COM/120SEG DRIVER & CONTROLLER FOR DOT MATRIX LCD #### 13) 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 KS0078 is in internal operation or not. If the resultant BF is High, it means the internal operation is in progress and you have to wait until BF to be Low, and then the next instruction can be performed. In this instruction you can read also the value of address counter. #### 14) 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 | I | #### Write binary 8-bit data to DDRAM/CGRAM/SEGRAM. The selection of RAM from DDRAM, CGRAM, or SEGRAM, is set by the previous address set instruction: DDRAM address set, CGRAM address set, SEGRAM address set. RAM set instruction can also determines the AC direction to RAM. After write operation, the address is automatically increased/decreased by 1, according to the entry mode. #### 15) 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/SEGRAM. The selection of RAM is set by the previous address set instruction. If address set instruction of RAM is not performed before this instruction, the data that read first is invalid, because the direction of AC is not determined. If you read RAM data several times without RAM address set instruction before read operation, you can get correct RAM data from the second, but the first data would be incorrect, because 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 transfer RAM data to output data register. After read operation address counter is automatically increased/decreased by 1 according to the entry mode. After CGRAM/SEGRAM read operation, display shift may not be executed correctly. \* In case of RAM write operation, after this AC is increased/decreased by 1 like read operation. In this time, AC indicates the next address position, but you can read only the previous data by read instruction. # **INTERFACE WITH MPU** KS0078 can transfer data in bus mode (4-bit or 8-bit) or serial mode with MPU. So you can use any type 4 or 8-bit MPU. In case of 4-bit bus mode, data transfer is performed by two times to transfer 1 byte data. - (1) When interfacing data length are 4-bit, only 4 ports, from DB4 to DB7, are used as data bus. At first higher 4-bit (in case of 8-bit bus mode, the contents of DB4 DB7) are transferred, and then lower 4-bit (in case of 8-bit bus mode, the contents of DB0 DB3) are transferred. So transfer is performed by two times. Busy Flag outputs "High" after the second transfer are ended. - (2) When interfacing data length are 8-bit, transfer is performed at a time through 8 ports, from DB0 to DB7. - (3) If IM is set to "Low", serial transfer mode is set. # Interface with MPU in Bus Mode # 1) Interface with 8-bits MPU If 8-bits MPU is used, KS0078 can connect directly with that. In this case, port E, RS, R/W and DB0 to DB7 need to interface each other. Example of timing sequence is shown below. Fig 11. Example of 8-bit Bus Mode Timing Sequence # 2) Interface with 4-bits MPU If 4-bits MPU is used, KS0078 can connect directly with this. In this case, port E, RS, R/W and DB4 to DB7 need to interface each other. The transfer is performed by two times. Example of timing sequence is shown below. Fig 12. Example of 4-bit Bus Mode Timing Sequence #### Interface with MPU in Serial Mode When IM port input is "Low", serial interface mode is started. At this time, all three ports, SCLK (synchronizing transfer clock), SID (serial input data), and SOD (serial output data), are used. If you want to use KS0078 with other chips, chip select port (CS) can be used. By setting CS to "Low", KS0078 can receive SCLK input. If CS is set to "High", KS0078 reset the internal transfer counter. Before transfer real data, start byte has to be transferred. It is composed of succeeding 5 "High" bits, register selection bit (RS), read write control bit (R/W), and end bit that indicates the end of start byte. Whenever succeeding 5 "High" bits are detected by KS0078, it makes serial transfer counter reset and ready to receive next informations. The next input data are register selection bit that determine which register will be used, and read write control bit that determine the direction of data. Then end bit is transferred, which must have "Low" value to show the end of start byte. (Refer to Fig 13. Fig 14) #### (1) Write Operation (R/W = 0) After start byte is transferred from MPU to KS0078, 8-bit data is transferred which is divided into 2 bytes, each byte has 4 bit's real data and 4 bit's partition token data. For example, if real data is "10110001" (D0 - D7), then serially transferred data becomes "1011 0000 0001 0000" where 2nd and 4th 4 bits must be "0000" for safe transfer. To transfer several bytes continuously without changing RS bit and RW bit, start byte transfer is needed only at first starting time. Namely, after first start byte is transferred, real data can be transferred succeedingly. # (2) Read Operation (R/W = 1) After start byte is transferred to KS0078, MPU can receive 8-bit data through the SOD port at a time from the LSB. Wait time is needed to insert between start byte and data reading, because internal reading from RAM requires some delay. Continuous data reading is possible like serial write operation. It also needs only one start bytes, only if you insert some delay between reading operations of each byte. During the reading operation, KS0078 observes succeeding 5 "High" from MPU. If it is detected, KS0078 restarts serial operation at once and ready to receive RS bit. So in continuous reading operation, SID port must be "0". Fig 13. Timing Diagram of Serial Data Transfer # Fig 14. Timing Diagram of Continuous Data Transfer # APPLICATION INFORMATION ACCORDING TO LCD PANEL 1) LCD Panel: 48 character x 1 line format (5-dot font,1/17 duty) 2) LCD Panel: 48 character x 2 line format (5-dot font, 1/33 duty) 3) LCD Panel: 24 character x 4 line format (5-dot font, 1/33 bias) 4) LCD Panel: 20 character x 4 line format (6-dot font, 1/33 bias) # **INITIALIZING** # 1) Initializing by Internal Reset Circuit When the power is turned on, KS0078 is initialized automatically by power on reset circuit. During the initialization, the following instructions are executed, and BF(Busy Flag) is kept "High"(busy state) to the end of initialization. (1) Display Clear instruction Write "20H" to all DDRAM (2) Set Fuctions instruction DL = 1 : 8-bit bus mode N = 1 : 2-line display mode RE = 0 : Extension register disable BE = 0 : CGRAM/SEGRAM blink OFF DH = 0 : Horizontal scroll enable REV = 0 : Normal display (Not reversed display) (3) Control Display ON/OFF instruction D = 0 : Display OFF C = 0 : Cursor OFF B = 0 : Blink OFF (4) Set Entry Mode instruction I/D = 1 : Increment by 1 S = 0 : No entire display shift BID = 0 : Normal direction segment port (5) Set Extension Function instruction FW = 0 : 5-dot font width character display B/W = 0 : Normal cursor (8th line) NW = 0 : Not 4-line display mode, 2-line mode is set because of N("1") (6) Enable Shift instruction HS = 0000 : Scroll per line disable DS = 0000 : Shift per line disable (7) Set scroll Quantity instruction SQ = 000000 : Not scroll # 2) Initializing by Hardware RESET input When RESET pin = "Low", KS0078 can be initialized like the case of power on reset. During the power on reset operation, this pin is ignored.