

## **P42101** 128x128 White OLED Application Note (For SPI Interface)



| Version | Content                          |
|---------|----------------------------------|
| X01     | First release(For SPI Interface) |

## **CD** RITEK GROUP RiTdisplay Corporation

#### DESCRIPTION

P42101 is a 128X128 dot matrix white passive OLED module with controller for many compact portable applications.

### FEATURE

- Panel matrix: 128x128.
- Driver IC: SSD1327.
- 16 gray scale
- V<sub>CC</sub> =14V
- Internal VDD: VCI = 2.6V~3.5V
- (Must use relative the circuit and the initial code.)
- External VDD: VCI = 1.65V~2.6V
- (Must use relative the circuit and the initial code.)
- Serial Peripheral Interface, I<sup>2</sup>C Interface.

### FUNCTION BLOCK DIAGRAM



CD WRITEK GROUP Ritdisplay Corporation

## Application circuit

(Internal VDD: VCI =2.6V~3.5V)



#### **Recommend components:**

C1, C4: 4.7uF/25V or 35V (Tantalum type) or VISHAY (572D475X0025A2T) C2, C3: 1uF/16V R1: 1M ohm 1 %( 0603)

#### Note: This circuit is for SPI interface.

**CD**<sup>®RITEK GROUP</sup> **RiTdisplay Corporation** 

## Application circuit

(External VDD: VCI =1.65V~2.6V)



#### **Recommend components:**

C1, C3: 4.7uF/25V or 35V (Tantalum type) or VISHAY (572D475X0025A2T) C2: 1uF/16V R1: 1M ohm 1 %( 0603)

#### Note: This circuit is for SPI interface.

## **CD** <sup>©</sup>RITEK GROUP **RiTdisplay Corporation**

**DC-DC** application circuit for OLED module



#### **Recommend components:**

The C1: 0.1uF/6.3V. The C2: 4.7 uF/6.3V. The C3: 22pF/16V. The C4: 4.7uF/25V Tantalum type capacitor. The R1: 1.2M ohm1%. The R2: 115K ohm1%. The D1: SCHOTTY DIODE. The L1: 10uH. The U1: TPS61045

Note: The R1, R2 and C3 value should be fine tune by customer.



## Pin Assignments

| PIN NAME |         |                                                                                                                                                        | Setting at each interface |      |        |  |  |
|----------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|------|--------|--|--|
|          | PIN NO. | DESCRIPTION                                                                                                                                            | 8080<br>Parallel          | SPI  | IIC    |  |  |
| VSS      | 1       | Ground pin.                                                                                                                                            |                           |      |        |  |  |
| VCC      | 2       | Power supply for panel driving voltage.                                                                                                                |                           |      |        |  |  |
| VDD      | 3       | Power supply pin for core logic operation.                                                                                                             |                           |      |        |  |  |
| BS1      | 4       | MCU bus interface selection pins.                                                                                                                      | NC                        | Low  | High   |  |  |
| VSS      | 5       | Ground pin.                                                                                                                                            |                           |      |        |  |  |
| IREF     | 6       | This pin is the segment output current reference pin.<br>A resistor should be connected between this pin and VSS.                                      |                           |      |        |  |  |
| CS#      | 7       | This pin is the chip select input connecting to the MCU.                                                                                               | NA                        | CS#  | Low    |  |  |
| RES#     | 8       | This pin is reset signal input.<br>When the pin is pulled LOW, initialization of the chip is executed.                                                 | NA                        | RES# | RES#   |  |  |
| D/C#     | 9       | This pin is Data/Command control pin connecting to the MCU.                                                                                            | NA                        | D/C# | Low    |  |  |
| D0       | 10      | When serial interface mode is selected, D0 will be the serial clock input:                                                                             | NA                        | SCLK | SCL    |  |  |
| D1       | 11      | SCLK; D1 will be the serial data input: SDIN and D2 should be kept NC.                                                                                 | NA                        | SDIN | SADIN  |  |  |
| D2       | 12      | When I <sup>2</sup> C mode is selected, D2, D1 should be tied together and serve as SDAout,SDAin in application and D0 is the serial clock input, SCL. | NA                        | NC   | SDAOUT |  |  |
| VCI      | 13      | Low voltage power supply and power supply for interface logic level.                                                                                   |                           |      |        |  |  |
| VCOMH    | 14      | COM signal deselected voltage level.<br>A capacitor should be connected between this pin and VSS.                                                      |                           |      |        |  |  |
| VCC      | 15      | Power supply for panel driving voltage.                                                                                                                |                           |      |        |  |  |

#### Note

- (1) Low is connected to VSS
- (2) High is connected to VCI

## **CD** RITEK GROUP Ritdisplay Corporation

```
Application Initial Setting (Internal VDD: VCI = 2.6V~3.5V)
```

/\*128x128 OLED driver program \*/ void initial(void) { comm\_out(0xae);//Set display off

comm\_out(0xa0);//Set re-map comm\_out(0x43);

comm\_out(0xa1);//Set display start line comm\_out(0x00);

comm\_out(0xa2);//Set display offset comm\_out(0x00);

comm\_out(0xa4);//Normal Display

comm\_out(0xa8);//Set multiplex ratio
comm\_out(0x7f);

## comm\_out(0xab);//Function Selection A comm\_out(0x01);//Enable internal VDD regulator

comm\_out(0x81);//Set contrast comm\_out(0x53);//For VCC=14V

```
comm_out(0xb1);//Set Phase Length
comm_out(0x31);
```

comm\_out(0xb3);//Set Front Clock Divider /Oscillator Frequency comm\_out(0xc1);//105 Hz

```
comm_out(0xb4); //For brightness enhancement
comm_out(0xb5);
```

```
comm_out(0xb6);//Set Second pre-charge Period
comm_out(0x0d);
```

## **CD** <sup>© RITEK GROUP</sup> RITDISPLAY Corporation

comm\_out(0xbc);//Set Pre-charge voltage comm\_out(0x04);

```
comm_out(0xbe);//Set VCOMH
comm_out(0x07);
```

comm\_out(0xd5);//Function Selection B
comm\_out(0x60);

cleanDDR ();//Clear the whole DDRAM

```
comm_out(0xaf);//Display on
}
```

## **CD** RITEK GROUP RiTdisplay Corporation

```
Application Initial Setting (External VDD: VCI =1.65V~2.6V)
```

/\*128x128 OLED driver program \*/ void initial(void) { comm\_out(0xae);//Set display off

comm\_out(0xa0);//Set re-map comm\_out(0x43);

comm\_out(0xa1);//Set display start line comm\_out(0x00);

comm\_out(0xa2);//Set display offset comm\_out(0x00);

comm\_out(0xa4);//Normal Display

comm\_out(0xa8);//Set multiplex ratio
comm\_out(0x7f);

```
comm_out(0xab);//Function Selection A
comm_out(0x00);//Select external VDD
```

comm\_out(0x81);//Set contrast comm\_out(0x53);//For VCC=14V

```
comm_out(0xb1);//Set Phase Length
comm_out(0x31);
```

comm\_out(0xb3);//Set Front Clock Divider /Oscillator Frequency comm\_out(0xc1);//105Hz

```
comm_out(0xb4); //For brightness enhancement
comm_out(0xb5);
```

comm\_out(0xb6);//Set Second pre-charge Period
comm\_out(0x0d);

## **CD** <sup>© RITEK GROUP</sup> RITDISPLAY Corporation

comm\_out(0xbc);//Set Pre-charge voltage comm\_out(0x04);

```
comm_out(0xbe);//Set VCOMH
comm_out(0x07);
```

comm\_out(0xd5);//Function Selection B
comm\_out(0x60);

cleanDDR ();//Clear the whole DDRAM

```
comm_out(0xaf);//Display on
}
```

Rindisplay Corporation

```
void cleanDDR(void)
```

{

```
int i,j;
comm_out(0x15);//Set column address
comm_out(0x00);//Column Start Address
comm_out(0x3f);//Column End Address
comm_out(0x75);//Set row address
comm_out(0x70);//Row Start Address
comm_out(0x7f);//Row End Address
for(i=0;i<128;i++)
{
for(j=0;j<64;j++)
{
data_out(0x00);
}
}
```

### After initial the driver IC, user can display all pixels on.

```
void show data(void)
{
  int i,j;
  comm out(0x15);//Set column address
  comm out(0x00);//Column Start Address
  comm out(0x3f);//Column End Address
  comm out(0x75);//Set row address
  comm out(0x00);//Row Start Address
  comm out(0x7f);//Row End Address
  for(i=0;i<128;i++)
  {
    for(j=0;j<64;j++)
    {
     data_out(0xff);
    }
  }
}
```

## C) RITEK GROUP RiTdisplay Corporation

#### Power ON / OFF Sequence

#### Power ON sequence:

- 1. Power ON  $V_{CI}$ .
- 2. After V<sub>CI</sub> becomes stable, set wait time at least 1ms ( $t_0$ ) for internal V<sub>DD</sub> become stable. Then set RES# pin LOW (logic low) for at least 100us ( $t_1$ )<sup>(4)</sup> and then HIGH (logic high).
- 3. After set RES# pin LOW (logic low), wait for at least 100us ( $t_2$ ). Then Power ON V<sub>CC</sub>.<sup>(1)</sup>
- 4. After V<sub>CC</sub> become stable, send command AFh for display ON. SEG/COM will be ON after 200ms(t<sub>AF</sub>).



#### Power OFF sequence:

- 1. Send command AEh for display OFF.
- 2. Power OFF  $V_{CC}$ .<sup>(1), (2), (3)</sup>
- 3. Wait for t<sub>OFF</sub>. Power OFF V<sub>CI</sub>. (where Minimum t<sub>OFF</sub>=80ms <sup>(5)</sup>, Typical t<sub>OFF</sub>=100ms)

The Power OFF sequence



#### Note:

- (1) Since an ESD protection circuit is connected between V<sub>CI</sub> and V<sub>CC</sub>, V<sub>CC</sub> becomes lower than V<sub>CI</sub> whenever V<sub>CI</sub> is ON and V<sub>CC</sub> is OFF as shown in the dotted line of V<sub>CC</sub> in above figures.
- (2)  $V_{CC}$  should be kept disable when it is OFF.
- (3) Power pins ( $V_{CI}$ ,  $\dot{V}_{CC}$ ) can never be pulled to ground under any circumstance.
- (4) The register values are reset after t<sub>1</sub>.
- (5)  $V_{CI}$  should not be Power OFF before  $V_{CC}$  Power OFF.

## C) RITEK GROUP RiTdisplay Corporation

#### Graphic Display Data RAM Address Map

The GDDRAM is a bit mapped static RAM holding the bit pattern to be displayed. The size of the RAM is 128x128x4 bits. For mechanical flexibility, re-mapping on both Segment and Common outputs can be selected by software. The GDDRAM address maps below tables show some examples on using the command "Set Re-map" A0h to re-map the GDDRAM. In the following tables, the lower nibble and higher nibble of D0, D1, D2 ... D8189, D8190, D8191 represent the 128x128 data bytes in the GDDRAM.

The GDDRAM map under the following condition:

- Command "Set Re-map" A0h is set to: Disable Column Address Re-map (A[0]=0)
   Disable Nibble Re-map (A[1]=0)
   Enable Horizontal Address Increment (A[2]=0)
   Disable COM Re-map (A[4]=0)
- Display Start Line=00h
- Data byte sequence: D0, D1, D2 ... D8191

|                |                         | SEG0       | SEG1       | SEG2       | SEG3       |  | SEG124     | SEG125     | SEG126     | SEG127     |   |
|----------------|-------------------------|------------|------------|------------|------------|--|------------|------------|------------|------------|---|
|                |                         | (          | )0         | (          | )1         |  | 3          | E          | 3          | F          | С |
| COM0           | 00                      | D0[3:0]    | D0[7:4]    | D1[3:0]    | D1[7:4]    |  | D62[3:0]   | D62[7:4]   | D63[3:0]   | D63[7:4]   |   |
| COM1           | 01                      | D64[3:0]   | D64[7:4]   | D65[3:0]   | D65[7:4]   |  | D126[3:0]  | D126[7:4]  | D127[3:0]  | D127[7:4]  |   |
| Ι              |                         |            |            |            |            |  |            |            |            |            |   |
| COM126         | 7E                      | D8064[3:0] | D8064[7:4] | D8065[3:0] | D8065[7:4] |  | D8126[3:0] | D8126[7:4] | D8127[3:0] | D8127[7:4] |   |
| COM127         | 7F                      | D8128[3:0] | D8128[7:4] | D8129[3:0] | D8129[7:4] |  | D8190[3:0] | D8190[7:4] | D8191[3:0] | D8191[7:4] |   |
| COM<br>Outputs | Row<br>Address<br>(HEX) |            |            |            |            |  |            |            |            |            | • |

#### GDDRAM address map 1

SEG Outputs Column Address (HEX)

RITDISPLAY CORPORATION

Nibble re-map A[1]=0

## **CD** ©RITEK GROUP RiTdisplay Corporation

The GDDRAM map under the following condition:

- Command "Set Re-map" A0h is set to: Disable Column Address Re-map (A[0]=0)
   Disable Nibble Re-map (A[1]=0)
   Enable Vertical Address Increment (A[2]=1)
   Disable COM Re-map (A[4]=0)
- Display Start Line=00h
- Data byte sequence: D0, D1, D2 ... D8191



The GDDRAM map under the following condition:

- Command "Set Re-map" A0h is set to: Enable Column Address Re-map (A[0]=1) Enable Nibble Re-map (A[1]=1) Enable Horizontal Address Increment (A[2]=0) Disable COM Re-map (A[4]=0)
- Display Start Line=00h
- Data byte sequence: D0, D1, D2 ... D8191

#### GDDRAM address map 3



## CD ©RITEK GROUP Ritdisplay Corporation

The example in which the display start line register is set to 10h with the following condition:

- Command "Set Re-map" A0h is set to: Disable Column Address Re-map (A[0]=0) Disable Nibble Re-map (A[1]=0) Enable Horizontal Address Increment (A[2]=0) Enable COM Re-map (A[4]=1)
- Display Start Line=78h (corresponds to COM119)
- Data byte sequence: D0, D1, D2 ... D8191



The GDDRAM map under the following condition:

- Command "Set Re-map" A0h is set to: Disable Column Address Re-map (A[0]=0) Disable Nibble Re-map (A[1]=0) Enable Horizontal Address Increment (A[2]=0) Disable COM Re-map (A[4]=0)
- Display Start Line=00h
- Column Start Address=01h
- Column End Address=3Eh
- Row Start Address=01h
- Row End Address=7Eh
- Data byte sequence: D0, D1, D2 ... D7811





# **Thank You**

