#### INTRODUCTION The S6A0071 is a dot matrix LCD controller & driver LSI which is fabricated by low power CMOS technology. It can display 1 line $\times$ 24 characters or 2 line $\times$ 24 characters with 5 $\times$ 7 dots format. ### **FUNCTION** - Character type dot matrix single chip LCD controller & driver - Internal driver: 32 common and 60 segment signal output - Easy interface with 4-bit or 8-bit MPU - Display character pattern: 5 × 7 dots format (240 kinds) - The Special character pattern is programmable by character generator RAM directly. - A customer character pattern is programmable by mask option. - Various instruction functions - Built-in automatic power on reset - Driving method is B-type (frame inversion) #### **FEATURES** ## **Internal Memory** - Character Generator ROM (CGROM): 8,400 bits (240 characters × 5 × 7 dots) - Character Generator RAM (CGRAM): 64 × 8 bits (8 characters × 5 × 8 dots) - Display Data RAM (DDRAM): 80 × 8 bits (80 characters max.) ## **Low Power Operation** - Power supply voltage range (VDD): 2.4 to 5.5V - LCD drive voltage range (VDD V5): 3.0 to 12.0V #### Voltage doubler generates about double from signals power supply On chip generation of LCD supply voltage from voltage doubler (external supply also possible) Programmable duty cycle - 1/16 duty: 1 line × 5 × 7 dots + cursor × 24 characters - 1/32 duty: 2 lines × 5 × 7 dots + cursor × 24 characters Internal oscillator with an external resistor 118 TCP or bare chip available ## **BLOCK DIAGRAM** #### **PAD DIAGRAM** NOTE: "S6A0071" marking is to make the PAD No. 95 easy to find. ## PAD CENTER COORDINATES | PAD | PAD | COORI | DINATE | PAD | PAD | COORI | DINATE | PAD | PAD | COORI | DINATE | |------|-------|-------|--------|------|-------|-------|--------|------|-------|-------|--------| | NUM. | NAME | Х | Υ | NUM. | NAME | Х | Υ | NUM. | NAME | Х | Υ | | 1 | SEG45 | -1794 | 2170 | 41 | V5OUT | -562 | -2374 | 81 | SEG7 | 1794 | 910 | | 2 | SEG46 | -1794 | 2030 | 42 | C1 | -438 | -2374 | 82 | SEG8 | 1794 | 1050 | | 3 | SEG47 | -1794 | 1890 | 43 | C2 | -312 | -2374 | 83 | SEG9 | 1794 | 1190 | | 4 | SEG48 | -1794 | 1750 | 44 | VCI | -188 | -2374 | 84 | SEG10 | 1794 | 1330 | | 5 | SEG49 | -1794 | 1610 | 45 | VDD | -62 | -2374 | 85 | SEG11 | 1794 | 1470 | | 6 | SEG50 | -1794 | 1470 | 46 | RS | 62 | -2374 | 86 | SEG12 | 1794 | 1610 | | 7 | SEG51 | -1794 | 1330 | 47 | R/W | 118 | -2374 | 87 | SEG13 | 1794 | 1750 | | 8 | SEG52 | -1794 | 1190 | 48 | Е | 312 | -2374 | 88 | SEG14 | 1794 | 1890 | | 9 | SEG53 | -1794 | 1050 | 49 | DB0 | 438 | -2374 | 89 | SEG15 | 1794 | 2030 | | 10 | SEG54 | -1794 | 910 | 50 | DB1 | 562 | -2374 | 90 | SEG16 | 1794 | 2170 | | 11 | SEG55 | -1794 | 770 | 51 | DB2 | 688 | -2374 | 91 | SEG17 | 1686 | 2374 | | 12 | SEG56 | -1794 | 630 | 52 | DB3 | 812 | -2374 | 92 | SEG18 | 1561 | 2374 | | 13 | SEG57 | -1794 | 490 | 53 | DB4 | 938 | -2374 | 93 | SEG19 | 1436 | 2374 | | 14 | SEG58 | -1794 | 350 | 54 | DB5 | 1062 | -2374 | 94 | SEG20 | 1311 | 2374 | | 15 | SEG59 | -1794 | 210 | 55 | DB6 | 1188 | -2374 | 95 | SEG21 | 1186 | 2374 | | 16 | SEG60 | -1794 | 70 | 56 | DB7 | 1312 | -2374 | 96 | SEG22 | 1061 | 2374 | | 17 | COM9 | -1794 | -70 | 57 | T2 | 1438 | -2374 | 97 | SEG23 | 936 | 2374 | | 18 | COM10 | -1794 | -210 | 58 | T1 | 1562 | -2374 | 98 | SEG24 | 811 | 2374 | | 19 | COM11 | -1794 | -350 | 59 | COM24 | 1794 | -2170 | 99 | SEG25 | 686 | 2374 | | 20 | COM12 | -1794 | -490 | 60 | COM23 | 1794 | -2030 | 100 | SEG26 | 561 | 2374 | | 21 | COM13 | -1794 | -630 | 61 | COM22 | 1794 | -1890 | 101 | SEG27 | 436 | 2374 | | 22 | COM14 | -1794 | -770 | 62 | COM21 | 1794 | -1750 | 102 | SEG28 | 311 | 2374 | | 23 | COM15 | -1794 | -910 | 63 | COM20 | 1794 | -1610 | 103 | SEG29 | 186 | 2374 | | 24 | COM16 | -1794 | -1050 | 64 | COM19 | 1794 | -1470 | 104 | SEG30 | 61 | 2374 | | 25 | COM25 | -1794 | -1190 | 65 | COM18 | 1794 | -1330 | 105 | SEG31 | -64 | 2374 | | 26 | COM26 | -1794 | -1330 | 66 | COM17 | 1794 | -1190 | 106 | SEG32 | -189 | 2374 | | 27 | COM27 | -1794 | -1470 | 67 | COM8 | 1794 | -1050 | 107 | SEG33 | -314 | 2374 | | 28 | COM28 | -1794 | -1610 | 68 | COM7 | 1794 | -910 | 108 | SEG34 | -439 | 2374 | | 29 | COM29 | -1794 | -1750 | 69 | COM6 | 1794 | -770 | 109 | SEG35 | -564 | 2374 | | 30 | COM30 | -1794 | -1890 | 70 | COM5 | 1794 | -630 | 110 | SEG36 | -689 | 2374 | | 31 | COM31 | -1794 | -2030 | 71 | COM4 | 1794 | -490 | 111 | SEG37 | -814 | 2374 | | 32 | COM32 | -1794 | -2170 | 72 | COM3 | 1794 | -350 | 112 | SEG38 | -939 | 2374 | # PAD CENTER COORDINATES (Continued) | PAD | PAD | COORI | DINATE | PAD | PAD | COORI | DINATE | PAD | PAD | COORD | INATE | |------|------|-------|--------|------|------|-------|--------|------|-------|-------|-------| | NUM. | NAME | Х | Υ | NUM. | NAME | Х | Y | NUM. | NAME | Х | Y | | 33 | VSS | -1562 | -2374 | 73 | COM2 | 1794 | -210 | 113 | SEG39 | -1064 | 2374 | | 34 | OSC1 | -1438 | -2374 | 74 | COM1 | 1794 | -70 | 114 | SEG40 | -1189 | 2374 | | 35 | OSC2 | -1312 | -2374 | 75 | SEG1 | 1794 | 70 | 115 | SEG41 | -1314 | 2374 | | 36 | V1 | -1188 | -2374 | 76 | SEG2 | 1794 | 210 | 116 | SEG42 | -1439 | 2374 | | 37 | V2 | -1062 | -2374 | 77 | SEG3 | 1794 | 350 | 117 | SEG43 | -1564 | 2374 | | 38 | V3 | -938 | -2374 | 78 | SEG4 | 1794 | 490 | 118 | SEG44 | -1689 | 2374 | | 39 | V4 | -812 | -2374 | 79 | SEG5 | 1794 | 630 | | | | | | 40 | V5 | -688 | -2374 | 80 | SEG6 | 1794 | 770 | | | | | ## PAD DESCRIPTION | PAD<br>( No.) | Pad No. | I/O | NAME | Description | Interface | |---------------------------------------|--------------------------------------|-----|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------| | V <sub>DD</sub> | 45 | | | For logical circuit (+3V, 5V) | | | V <sub>SS</sub> | 33 | | Supply voltage | Ground (0V) | Power supply | | V1-V5 | 36-40 | | | Bias voltage level for LCD driving | | | S1-S60 | 75-118,<br>1-16 | 0 | Segment output | Segment signal output for LCD drive | LCD | | C1-C8<br>C9-C16<br>C17-C24<br>C25-C32 | 74-67,<br>17-24,<br>66-59,<br>25-32, | 0 | Common output | Common signal output for LCD drive | LCD | | OSC1 | 34 | l | Oscillator | When using internal oscillator, connect external Rf resistor. | External resistor OSC/OSC2 | | OSC2 | 35 | 0 | Oscillator | If external clock is used, connect it to OSC1 | External clock (OSC1) | | RS | 46 | I | Register select | Used as register selection input. When RS = 1, Data register is selected. When RS = 0, Instruction register is selected. | MPU | | R/W | 47 | I | Read/write | Used as read/write selection input. When RW = 1, read operation. When RW = 0, write operation. | MPU | | E | 48 | I | Read/write<br>Enable | Used as read/write enable signal. | MPU | | DB0 - DB3 | 49 - 52 | I/O | Data bus 0-7 | In 8-bit bus mode, used as low order bidirectional data bus. In 4-bit bus mode, open these pins. | MPU | | DB4 - DB7 | 53 - 56 | I/O | Data bus 0-7 | In 8-bit bus mode, used as high order bidirectional data bus. In 4-bit bus mode, used as both high and low order. DB7 used for busy flag output. | MPU | | Vci | 44 | | Voltage doubler output | Input terminal for voltage doubler. (normally Vci = V <sub>DD</sub> ) | Power supply | | C1,C2 | 42, 43 | ı | Capacitor | Capacitor for voltage doubler connecting terminal (+). Capacitor for voltage doubler connecting terminal(-). | Capacitor | | V5OUT | 41 | 0 | Voltage doubler output | Voltage doubler output terminal connected to LCD supply voltage | V5 | | T1, T2 | 58, 57 | I | Test pin | Maker testing terminal (normally open) | | #### **FUNCTION DESCRIPTION** #### **System Interface** This chip has both kinds of interface type with MPU: 4-bit bus and 8-bits bus. 4-bit bus and 8-bit bus are selected by the DL bit in the instruction register. During read or write operation, two 8-bit registers are used. One is the data register (DR), and the other is the instruction register (IR). The data register (DR) is used as a temporary data storage place for being written into or read from DDRAW/CGRAM. Target RAM is selected by RAM address setting instruction. Each internal operation, reading from or writing into RAM, is done automatically. Thus, after MPU reads DR data, the data in the next DDRAM/CGRAM address is transferred into DR automatically. Also, after MPU writes data to DR, the data in DR is transferred into DDRAM/CGRAM automatically. The instruction register (IR) is used only to store instruction codes transferred from MPU. MPU cannot use it to read instruction data. To select a register, you can use the RS input pin in 4-bit/8-bit bus mode. 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 - DB7) 1 0 Data Write operation (MPU writes data into DR) 1 1 Data Read operation (MPU reads data into DR) Table 1. Various Kinds of Operations to RS and R/W Bits #### Busy Flag (BF) When BF = 1, it indicates that the internal operation is being processed. So during this time the next instruction cannot be accepted. BF can be read through DB7 port, when RS = 0, and R/W = 1. (Read Instruction Operation). Before executing the next instruction, be sure that BF is not 1. ### Address Counter (AC) The Address Counter (AC) stores DDRAM/CGRAM addresses, transferred from IR. After writing into (reading from) DDRAM/CGRAM. AC is automatically increased (decreased) by 1. When RS = 0 and R/W = 1, AC can be read through ports DB0 - DB6. ## Display Data RAM (DDRAM) The DDRAM stores display data of maximum $80 \times 8$ bits (80 characteristics). The DDRAM address is set in the address counter (AC) as a hexadecimal number. (Refer to fig-1). Figure 1. DDRAM Address #### 1) 1-line Display In case of a 1-line display, the address range of DDRAM is 00H - 04H. Figure 2. 1-line '24 char. Display ## 2) 2-line Display In case of a 2-line display, the address range of DDRAM is 00H - 27H and 40H - 67H. Figure 3. 2line '24 char. Display with 60 SEG. Extension Driver #### CGROM (Characteristic Generator ROM) CGROM has a 5 x 7 dots 240 character pattern. #### **CGRAM (Character Generator RAM)** CDRAM has up to 5 x 8 dots 8 characters. By writing font data to CGRAM, user defined characters can be used (Refer to table 3). ## **Timing Generation Circuit** The timing generation circuit generates clock signals for the internal operations. #### **LCD Driver Circuit** LCD Driver circuit has 32 common and 60 segment signals for LCD driving. Data from CGRAM/CGROM is transferred to an 60-bit segment latch serially, and then stored to an 60-bit shift latch. When each com is selected by a 32-bit common register, segment data is also outputs through the segment driver from and 60-bit segment latch. In case of a 1-line display mode, COM1 to COM8 have 1/6 duty, and in 2-line display mode, COM1 to COM32 have 1/32 duty ratio. #### **Cursor/Blink Control Circuit** It controls cursor/blink ON/OFF at cursor position. Table 3. Relationship Between Character Code (DDRAM) and Character Pattern (CGROM) | CI | hara | cter | Cod | e (DI | DRA | M da | ita) | | CGF | RAM | Add | Ires | 3 | | | C | GRA | M D | ata | | | Pattern | |----|------|------|-----|-------|-----|------|------|----|-----|-----|-----|------------|----|----|----|----|-----|-----|-----|----|----|-----------| | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | A5 | Α4 | А3 | A2 | <b>A</b> 1 | Α0 | P7 | P6 | P5 | P4 | Р3 | P2 | P1 | P0 | number | | 0 | 0 | 0 | 0 | х | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | х | х | х | 0 | 1 | 1 | 1 | 0 | Pattern 1 | | | | | | | | | | | | | 0 | 0 | 1 | | | | 1 | 0 | 0 | 0 | 1 | | | | | | | | | | | | | | 0 | 1 | 0 | | | | 1 | 0 | 0 | 0 | 1 | | | | | | | | | | | | | | 0 | 1 | 1 | | | | 1 | 1 | 1 | 1 | 1 | | | | | | | | | | | | • | | 1 | 0 | 0 | | | | 1 | 0 | 0 | 0 | 1 | | | | | | | | | | | | | | 1 | 0 | 1 | | | | 1 | 0 | 0 | 0 | 1 | | | | | | | | | | | | | | 1 | 1 | 0 | | | | 1 | 0 | 0 | 0 | 1 | | | | | | | | | | | | | | 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 | 1 | Pattern 8 | | | | | | | | | | | | | 0 | 0 | 1 | | | | 1 | 0 | 0 | 0 | 1 | | | | | | | | | | | | | | 0 | 1 | 0 | | | | 1 | 0 | 0 | 0 | 1 | | | | | | | | | | | | | | 0 | 1 | 1 | | | | 1 | 1 | 1 | 1 | 1 | | | | | | | • | | | | | • | | 1 | 0 | 0 | | | | 1 | 0 | 0 | 0 | 1 | | | | | | | | | | | | | | 1 | 0 | 1 | | | | 1 | 0 | 0 | 0 | 1 | | | | | | | | | | | | | | 1 | 1 | 0 | | | | 1 | 0 | 0 | 0 | 1 | | | | | | | | | | | | | | 1 | 1 | 1 | | | | 0 | 0 | 0 | 0 | 0 | | "X": Don't care. #### INSTRUCTION DESCRIPTION #### **OUTLINE** To overcome the speed difference between internal clock of S6A0071 and MPU clock, S6A0071 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 5) Instruction can be divided largely four kinds, - (1) S6A0071 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. **NOTE:** During internal operation, Busy Flag (DB7) is read "1". Busy Flag check must be precede by the next instruction. When you make an MPU program with checking the Busy Flag (DB7) is made, it must be necessary 1/2 fosc for executing the next instruction by falling E signal after the Busy Flag (DB7) goes to "0". #### Contents ## 1) Clear Display | R | S | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |---|---|-----|-----|-----|-----|-----|-----|-----|-----|-----| | ( | ) | 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 | RS | R/W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | х | \* "x": don't care 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 | SH | Set the moving direction of cursor and display. ## I/D: Increment /Decrement of DDRAMAddress Cursor orBlink) When I/D = "1", cursor/blink moves to right and DDRAM address is increased by 1. When I/D = "0", cursor/blink moves to left and DDRAM address is decreased by 1. \* CGRAM operates the same as DDRAM, when reading from or writing to CGRAM. ### SH: Shift of Entire Display When DDRAM is in the read (CGRAM read/write) operation or SH = "0", shift of entire display is not performed. If SH = "1" and DDRAM is in the write operation, shift of entire display is performed according to I/D value (I/D = "1": shift left, I/D = "0": 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 | С | В | Control display/cursor/blink ON/OFF 1 bit register. #### D: Display ON/OFFControlBit When D = "1", entire display is turned on. When D = "0", display is turned off, but display data remained in DDRAM. #### C: Cursor ON/OFFControlBit When C = "1", cursor is turned on. When C = "0", cursor is disappeared in current display, but I/D register preserves its data. #### B: Cursor Blink ON/OF/ControlBit When B = "1", cursor blink is on, which performs alternate between all the "1" data and display character at the cursor position. When B = "0", 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 | Х | Х | Without waiting or reading the display data, shift right/left cursor position or display. This instruction is used to correct or search display data (Refer to table 6). During 2-line mode display, cursor moves to the 2nd line after the 40th digit of the 1st line. Note that display shift is performed simultaneously for the whole line. When displayed data is shifted repeatedly, each line is shifts individually. When display shift is performed, the contents of the address counter are not changed. Table 6. 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 | Х | Х | Х | | ### DL: Interface data length control bit When DL = "1", it means 8-bit bus mode with MPU. When DL = "0", it means 4-bit bus mode with MPU. Hence, 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 = "0", it means 1-line display mode. When N = "1", 2-line display mode is set. ## 7) Set CGRAM Address | <br>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. #### 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 from MPU. When 1-line display mode (N=0), DDRAM address is from "00H" to "4FH". In 2-line display mode (N=1), DDRAM address in the 1st line is from "00H" to "27H", and DDRAM address in the 2nd 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 S6A0071 is in internal operation or not. If the resultant BF is "1", 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. #### 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 is 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 read operation, display shift may not be executed correctly. **NOTE:** In case of RAM write operation, 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. Table 6. Instruction Table | Instruction | | | | Ins | tructi | on C | ode | | | | Description | Execution | |----------------------------------|----|---------|---------|---------|---------|---------|---------|---------|---------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------|--------------------| | | RS | R/<br>W | DB<br>7 | DB<br>6 | DB<br>5 | DB<br>4 | DB<br>3 | DB<br>2 | DB<br>1 | DB<br>0 | Instruction Code | time(fsoc=270<br>) | | Clear Display | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | Write "20H" to DDRAM. and set DDRAM address to "00H" from AC. | 1.53ms | | Return Home | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | X | Set DDRAM address to "00H" from<br>the AC and return cursor to its<br>original position if shifted.<br>The contents of DDRAM are not<br>change. | 1.53ms | | Entry Mode<br>Set | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | I/D | SH | Assign cursor moving direction and make shift of entire display possible. | 39µs | | Display<br>ON/OFF<br>Control | 0 | 0 | 0 | 0 | 0 | 0 | 1 | D | С | В | Set display(D), cursor(C), and blinking of cursor(B) on/off control bit. | 39μs | | Cursor or<br>Display Shift | 0 | 0 | 0 | 0 | 0 | 1 | S/C | R/L | Х | Х | Set cursor moving and display shift control bit, and the direction, without changing of the AC. | 39µs | | Function Set | 0 | 0 | 0 | 0 | 1 | DL | N | Х | Х | Х | Set interface data length (DL : 4-bit/8-bit), numbers of display line (N : 1-line/2-line). | 39μs | | Set CGRAM<br>Address | 0 | 0 | 0 | 1 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 | Set CGRAM address in address counter. | 39µs | | Set DDRAM<br>Address | 0 | 0 | 1 | AC6 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 | Set DDRAM address in address counter. | 39µs | | 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. | 0μs | | Write Data to RAM | 1 | 0 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Write data into internal RAM (DDRAM/CGRAM). | 43µs | | Read Data from RAM | 1 | 1 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Read data from internal RAM (DDRAM/CGRAM). | 43µs | \*"x": don't care **NOTE:** When you make an MPU program, checking the Busy Flag (DB7), a time margin of 1/2 f<sub>OSC</sub> is necessary for executing the next instruction by the falling edge of the 'E' signal after the Busy Flag (DB7) goes to "0". #### **INTERFACE WITH MPU** #### 1) Interface with 8bit MPU When the interfacing data length are 8-bit, transfer is performed all at once through 8 ports, from DB0 to DB7. An example of the timing sequence is shown below. Figure 4. Example of &bit Bus Mode Timing Diagram #### 2) Interface with 4bit MPU When interfacing data length is 4-bit, only 4 ports, from DB4 to DB7, are used as data bus. At first higher 4-bit (in the case of 8-bit bus mode, the contents of DB4 - DB7), and then lower 4-bit (in case of 8-bit bus mode, the contents of DB0 - DB3) are transferred. So transfer is performed twice Busy Flag outputs "high" after the second transfer are ended. An example of timing sequence is shown below. Figure 5. Example of 4bit Bus Mode Timing Diagram ## APPLICATION INFORMATON ACCORDING TO LCD PANEL 1) LCD Panel: 24 character 1-line character format: 5 7 dots + 1 cursor line (1/5 bias, 1/16 duty) ## 2) LCD Panel: 24 character 2-line character format: 5 7 dots + 1 cursor line (1/6.7 bias, 123duty) ## POWER SUPPLY FOR DRNING LCD PANEL 1) When an external power supply is used 2) When an internal booster is used (Boosting twice) ## NOTES: - 1. Boosted output voltage should not exceed the maximum value (11V) of the LCD driving voltage. - 2. A voltage of over 5.5V should not be input into the reference voltage (Vci) when boosting twice. - 3. The value of resistance, according to the number of lines, duty ratio and the bias, is shown below. (Refer to table 8) Table 8. Duty Ratio and Power Supply for LCD Driving | | Item | Data | | | | | |---------------|----------|------|-------|--|--|--| | N | umber | 1 | 2 | | | | | Du | ty Ratio | 1/16 | 1/32 | | | | | | Bias | 1/5 | 1/6.7 | | | | | Divided | R | R | R | | | | | Resistance R0 | | R | 2.7R | | | | #### **INITIALIZING** When the power is turned on, S6A0071 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 Functions instructionDL = 1 : 8-bit bus modeN = 1 : 2-line display mode (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 SH = 0 : No entire display shift ## FRAME FREQUENCY ## **B-Type Waveform (Frame Inversion)** ## 1) 1/16 Duty Cycle | Item | Clock/Frequency | | | | | |-------------------------|-----------------|--|--|--|--| | 1-line selection period | 120 clocks | | | | | | Frame frequency | 140.7Hz | | | | | <sup>\*</sup> f<sub>OSC</sub> = 270kHz (1 clock = 3.7μs) ## 2) 1/32 duty cycle | Item | Clock/Frequency | | | | | |-----------------------|-----------------|--|--|--|--| | Line Selection Period | 120 clocks | | | | | | Frame Frequency | 70.4Hz | | | | | <sup>\*</sup> $f_{OSC} = 270 \text{kHz} (1 \text{ clock} = 3.7 \mu \text{s})$ ## INITIALIZING BY INSTRUCTION #### 1) 8-bit Interface mode #### 2) 4-bit Interface mode ## MAXIMUM ABSOLUTE LINT RATING ## **Maximum Absolute Power Ratings** | Description | Symbol | Unit | Value | |--------------------------|------------------|------|-----------------------------------------------| | Power Supply Voltage (1) | $V_{DD}$ | V | - 0.3 to +7.0 | | LCD Drive Voltage | V <sub>LCD</sub> | V | V <sub>DD</sub> -13.5 to V <sub>DD</sub> +3.0 | | Input Voltage | V <sub>IN</sub> | V | -0.3 to V <sub>DD</sub> +0.3 | **NOTE:** Voltage greater than above may damage the circuit. $(V_{DD} \ge V1 \ge 2 \ge V3 \ge V4 \ge V5)$ ## **Temperature Characteristics** | Description | Symbol | Unit | Value | |-----------------------|------------------|------|--------------| | Operating Temperature | T <sub>OPR</sub> | °C | - 3.0 to +85 | | Storage Temperature | T <sub>STG</sub> | °C | - 55 to +125 | ## ELECTRICAL CHARACTERSTICS ## DC Characteristics ( $V_{DD}$ = +5V ± 10%, Ta = -30 to +85°C) | Characteristic | Symbol | Condition | Min | Тур | Max | Unit | |------------------------------------------------|---------------------------------|------------------------------------------------------------------------------------------------------|----------------------|------|--------------------|------| | Operating voltage | V <sub>DD</sub> | - | 4.5 | 5.0 | 5.5 | V | | Supply current | I <sub>DD</sub> | Internal oscillation or external clock operation. (V <sub>DD</sub> = 5V, f <sub>OSC</sub> = 270 kHz) | - | 0.6 | 1.0 | mA | | Input voltage (1) | V <sub>IH1</sub> | - | 2.3 | - | V <sub>DD</sub> | V | | (except OSC1) | V <sub>IL1</sub> | - | - | - | 0.8 | | | Input voltage (2) | V <sub>IH2</sub> | - | V <sub>DD</sub> -1.0 | - | V <sub>DD</sub> | V | | (OSC1) | V <sub>IL2</sub> | - | - | - | 1.0 | | | Output voltage (1) | V <sub>OH1</sub> | I <sub>OH</sub> = -0.205mA | 2.4 | - | - | V | | (DB0 to DB7) | V <sub>OL1</sub> | I <sub>OL</sub> = 1.6mA | - | - | 0.4 | | | Output voltage (2) | V <sub>OH2</sub> | $I_O = -40\mu A$ | 0.9V <sub>DD</sub> | - | - | V | | (OSC2) | V <sub>OL2</sub> | I <sub>O</sub> = 40μA | - | - | 0.1V <sub>DD</sub> | | | Voltage drop | Vd <sub>COM</sub> | $I_{O} = \pm 0.1 \text{mA}$ | - | - | 1 | V | | | Vd <sub>SEG</sub> | | - | - | 1 | | | Input Leakage Current (1) E | I <sub>IL1</sub> | V <sub>IN</sub> = 0V to V <sub>DD</sub> | -1 | - | 1 | μΑ | | Input leakage current(2) (R/W, RS, DB0 to DB7) | I <sub>IL2</sub> | $V_{IN} = V_{DD}$ | -5 | - | 5 | | | Low Input Current (R/W, RS, DB0 to DB7) | I <sub>IN</sub> | $V_{IN} = 0V$ , $V_{DD} = 5V$ (pull up) | -50 | -125 | -250 | | | Internal Clock<br>(external Rf) | f <sub>IC</sub> | $Rf = 91k\Omega \pm 2\%$ $(V_{DD} = 5V)$ | 190 | 270 | 350 | kHz | | | f <sub>EC</sub> | | 160 | 250 | 350 | | | External Clock | duty | - | 45 | 50 | 55 | % | | | t <sub>R</sub> , t <sub>F</sub> | | - | - | 0.2 | μs | | | V5out | lout = 1mA, Ta = 25°C | -4.5 | -4.7 | - | V | | Voltage Doubler | V <sub>EF</sub> | R <sub>L</sub> = ∞ | 95 | 99.9 | - | % | | | Vci | Input voltage | 2.5 | - | 5.5 | V | | LCD Driving Voltage | $V_{LCD}$ | V <sub>DD</sub> -V <sub>5</sub> (1/5, 1/6.7 bias) | 3.0 | - | 13.5 | V | ## **DC** Characteristics (V<sub>DD</sub> = +3V $\pm$ 20%, Ta = -30 to +85°C) | Characteristic | Symbol | Condition | Min | Тур | Max | Unit | |------------------------------------------------|-------------------|-------------------------------------------------------------------------------------------|----------------------|-------|--------------------|------| | Operating voltage | V <sub>DD</sub> | - | 2.4 | 3.0 | 3.6 | V | | Supply current | I <sub>DD</sub> | Internal oscillation or external clock. (V <sub>DD</sub> = 3V, f <sub>OSC</sub> = 270kHz) | - | 0.2 | 0.3 | mA | | Input voltage (1) | V <sub>IH1</sub> | - | 0.8V <sub>DD</sub> | - | $V_{DD}$ | V | | (except OSC1) | V <sub>IL1</sub> | - | - | - | 0.2V <sub>DD</sub> | | | Input voltage (2) | V <sub>IH2</sub> | - | V <sub>DD</sub> -1.0 | - | V <sub>DD</sub> | V | | (OSC1) | V <sub>IL2</sub> | - | - | - | 1.0 | | | Output voltage (1) | V <sub>OH1</sub> | I <sub>OH</sub> = -0.205mA | 2.0 | - | - | V | | (DB0 to DB7) | V <sub>OL1</sub> | I <sub>OL</sub> = 1.6mA | - | - | 0.5 | | | Output voltage (2) | V <sub>OH2</sub> | I <sub>O</sub> = -40μA | 0.9V <sub>DD</sub> | - | - | V | | (OSC2) | V <sub>OL2</sub> | I <sub>O</sub> = 40μA | - | - | 0.1V <sub>DD</sub> | | | Voltage drop | Vd <sub>COM</sub> | $I_{O} = \pm 0.1 \text{mA}$ | - | - | 1 | V | | | Vd <sub>SEG</sub> | | - | - | 1 | | | Input Leakage Current (1) E | I <sub>IL1</sub> | V <sub>IN</sub> = 0V to V <sub>DD</sub> | -1 | - | 1 | μΑ | | Input leakage current(2) (R/W, RS, DB0 to DB7) | I <sub>IL2</sub> | $V_{IN} = V_{DD}$ | -5 | - | 5 | | | Low Input Current<br>(R/W, RS, DB0 to DB7) | I <sub>IN</sub> | $V_{IN} = 0V$ , $V_{DD} = 3V$ (pull up) | -10 | -25 | -50 | | | Internal Clock<br>(external Rf) | f <sub>IC</sub> | $Rf = 91k\Omega \pm 2\%$ $(V_{DD} = 3V)$ | 160 | 240 | 320 | kHz | | | V5out | lout = 1mA, Ta = 25°C | -2.5 | -2.75 | - | V | | Voltage Doubler | V <sub>EF</sub> | R <sub>L</sub> = ∞ | 95 | 99.9 | - | % | | | Vci | Input voltage | 1.8 | - | V <sub>DD</sub> | V | | LCD Driving Voltage | $V_{LCD}$ | V <sub>DD</sub> -V <sub>5</sub> (1/5, 1/6.7 bias) | 3.0 | - | 12.0 | V | # AC Characteristic $V_{DD} = 4.5 \text{ to } 5.5 \text{V}, \text{ Ta} = -30 \text{ to } +85 ^{\circ}\text{C}$ | Mode | Characteristic | Symbol | Min | Тур | Max | Unit | |-----------------------------------|-----------------------------|---------------------------------|-----|-----|-----|------| | Write Mode<br>(Refer to figure 6) | E Cycle Time | t <sub>C</sub> | 500 | - | - | ns | | | E Rise Time / Fall Time | t <sub>R</sub> , t <sub>F</sub> | | - | 20 | | | | E Pulse Width ( High, Low ) | t <sub>W</sub> | 220 | - | - | | | | R/W and RS Setup Time | t <sub>SU1</sub> | 40 | - | - | | | | R/W and RS Hold Time | t <sub>h1</sub> | 10 | - | - | | | | Data Setup Time | t <sub>SU2</sub> | 60 | - | - | | | | Data Hold Time | t <sub>h2</sub> | 10 | - | - | | | Read Mode<br>(Refer to figure 7) | E Cycle Time | t <sub>C</sub> | 500 | - | - | ns | | | E Rise Time / Fall Time | t <sub>R</sub> , t <sub>F</sub> | | - | 20 | | | | E Pulse Width ( High, Low ) | t <sub>W</sub> | 220 | - | - | | | | R/W and RS Setup Time | t <sub>SU</sub> | 40 | - | - | | | | R/W and RS Hold Time | t <sub>H</sub> | 10 | - | - | | | | Data Output Delay Time | t <sub>D</sub> | - | - | 120 | | | | Data Hold Time | t <sub>DH</sub> | 10 | - | - | | # AC Characteristic $V_{DD} = 2.4 \text{ to } 3.6 \text{V}, \text{ Ta} = -30 \text{ to } +85 ^{\circ}\text{C}$ | Mode | Characteristic | Symbol | Min | Тур | Max | Unit | |-----------------------------------|-----------------------------|---------------------------------|------|-----|-----|------| | Write Mode<br>(Refer to figure 6) | E Cycle Time | t <sub>C</sub> | 1400 | - | - | | | | E Rise Time / Fall Time | t <sub>r</sub> , t <sub>f</sub> | | - | 20 | | | | E Pulse Width ( High, Low ) | t <sub>W</sub> | 500 | - | - | | | | R/W and RS Setup Time | t <sub>SU1</sub> | 70 | - | - | ns | | | R/W and RS Hold Time | t <sub>h1</sub> | 10 | - | - | | | | Data Setup Time | t <sub>SU2</sub> | 195 | - | - | | | | Data Hold Time | t <sub>h2</sub> | 10 | - | - | | | Read Mode<br>(Refer to figure 7) | E Cycle Time | t <sub>C</sub> | 1400 | - | - | | | | E Rise Time / Fall Time | t <sub>R</sub> , t <sub>F</sub> | - | - | 20 | | | | E Pulse Width ( High, Low ) | t <sub>W</sub> | 500 | - | - | ns | | | R/W and RS Setup Time | t <sub>SU</sub> | 70 | - | - | | | | R/W and RS Hold Time | t <sub>H</sub> | 10 | - | - | | | | Data Output Delay Time | t <sub>D</sub> | - | - | 600 | | | | Data Hold Time | t <sub>DH</sub> | 20 | - | - | | Figure 6. Write Mode Timing Diagram Figure 7. Read Mode Timing Diagram