

# P30004 64x32 White OLED Application Notes (for IIC Interface)



Revision History

| Version | REVISION DESCRIPTION |
|---------|----------------------|
| X01     | First release        |

# **CD** © RITEK GROUP RiTdisplay Corporation

#### DESCRIPTION

P30004 is a 64×32 dot matrix white passive OLED module with controller for many compact portable applications.

### FEATURE

- Panel matrix 64x32
- Driver IC: SSD1306
- VBAT=3.5~4.2V(For Charge Pump)
- VDD = 1.65~3.3V
- I<sup>2</sup>C Interface
- Embedded 128 x 64 bit SRAM display buffer.
- Screen saving continuous scrolling function in both horizontal and vertical direction.
- On-Chip Oscillator.
- Row Re-mapping and Column Re-mapping.

# FUNCTION BLOCK DIAGRAM



RITdisplay 64X32 OLED Module

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

# **APPLICATION CIRCUIT**

(Charge Pump)



#### Recommended components :

C1,C6: 4.7uF/16V(0805)

C2,C3,C4,C5: 1uF/16V(0603)

R1: 560Kohm (0603) 1%

R2, R3: 10K ohm(0603)

This circuit is for  $I^2C$  interface.

# **CD** RITEK GROUP RiTdisplay Corporation

# **PIN ASSIGNMENTS**

| PIN<br>NAME | PIN NO.   | DESCRIPTION                                                                                                             | Setting at each interface |     |      |
|-------------|-----------|-------------------------------------------------------------------------------------------------------------------------|---------------------------|-----|------|
|             |           |                                                                                                                         | 8080<br>parallel          | SPI | IIC  |
| 1           | C2P       | C2P/C2N – Pin for charge pump<br>capacitor; Connect to each other with a                                                |                           |     |      |
| 2           | C2N       | capacitor.                                                                                                              |                           |     |      |
| 3           | C1P       | C1P/C1N – Pin for charge pump                                                                                           |                           |     |      |
| 4           | C1N       | capacitor; Connect to each other with a capacitor.                                                                      |                           |     |      |
| 5           | VBAT      | Power supply for charge pump regulator<br>circuit.                                                                      |                           |     |      |
| 6           | VBREF(NC) | No connection.                                                                                                          |                           |     |      |
| 7           | VSS       | Ground pin.                                                                                                             |                           |     |      |
| 8           | VDD       | Power supply pin for core logic operation.                                                                              |                           |     |      |
| 9           | RES#      | This pin is reset signal input.                                                                                         | NA                        | NA  | RES# |
| 10          | SCL       | I <sup>2</sup> C serial clock pin.                                                                                      | NA                        | NA  | SCL  |
| 11          | SDA       | I <sup>2</sup> C serial data pin.                                                                                       | NA                        | NA  | SDA  |
| 12          | IREF      | This pin is the segment output current<br>reference pin. A resistor<br>should be connected between this pin and<br>VSS. |                           |     |      |
| 13          | VCOMH     | COM signal deselected voltage level. A capacitor should be connected between this pin and VSS.                          |                           |     |      |
| 14          | VCC       | Power supply for panel driving voltage.                                                                                 |                           |     |      |

#### Note

(1) Low is connected to  $V \mbox{ss}$ 

 ${}_{(2)}\,High~is~connected~to~V_{\text{DD}}$ 

# **CD ORITEK GROUP RiTdisplay Corporation**

#### **Application Initial Setting**

/\*64x32 OLED driver program (For Charge Pump) \*/

/\* The more detail of  $I^2C$  sequence please refer to the SSD1306 datasheet \*/

```
void initial(void)
```

```
{
start ();
comm_out(0x78);//mast code
comm_out(0x00);
```

comm\_out(0xae);//Set Display OFF

comm\_out(0x40);//Set Display Start Line

comm\_out(0x81);//Set Contrast Control
comm\_out(0x75);

comm\_out(0xa1);//Set Segment Re-map

comm\_out(0xa4);//Resume to RAM content display

comm\_out(0xa6);//Set Normal Display

comm\_out(0xa8);//Set Multiplex Ratio
comm\_out(0x1f);

comm\_out(0xc8);//Set COM Output Scan Direction

```
comm_out(0xd3);//Set Display Offset
comm_out(0x00);
```

comm\_out(0xd5);//Set Display Clock Divide Ratio/Oscillator Frequency
comm\_out(0xc1);

comm\_out(0xd9);//Set Pre-charge Period
comm\_out(0xf1);

# **CD** RITEK GROUP RiTdisplay Corporation

comm\_out(0xda);//Set COM Pins Hardware Configuration
comm\_out(0x12);

comm\_out(0xdb);//Set VCOMH Deselect Level
comm\_out(0x40);

comm\_out(0x8d);//Charge Pump Setting
comm\_out(0x14);//Enable Charge Pump

### stop ( );

cleanDDR(); //Clear the whole DDRAM

start ();

```
comm_out(0x78);//mast code
comm_out(0x00);
```

```
comm_out(0xaf);//Set Display ON
```

```
stop ( );
}
```

```
CD RITEK GROUP
RiTdisplay Corporation
```

```
void cleanDDR(void)
{
int i,j;
for(i=0;i<8;i++)
    {
    start ();
    comm_out(0x78);//mast code
    comm_out(0x00);
    comm_out(0xb0+i); //Set Page
    comm out(0x00); //Lower Column Address
    comm out(0x10); //Higher Column Address
    stop();
    start ();
    comm_out(0x78);//mast code
    comm_out(0x40);
    for(j=0;j<128;j++)
        {
        data_out(0x00);
        }
        stop();
    }
}
```

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

```
void show_data(void)
{
    int i,j;
    for(i=0;i<4;i++)
        {
        start ( );
        comm_out(0x78);//mast code
        comm_out(0x00);
    }
}</pre>
```

```
comm_out(0xb0+i); //Set Page
comm_out(0x00); //Lower Column Address
comm_out(0x12); //Higher Column Address
```

**CD** RITEK GROUP Ritdisplay Corporation

```
stop ( );
start ( );
comm_out(0x78);//mast code
comm_out(0x40);
for(j=0;j<64;j++)
        {
        data_out(0xff);
        }
        stop ( );
}</pre>
```

}

# **()** RITEK GROUP **RiTdisplay Corporation**

## Power ON / OFF Sequence

#### Power ON and OFF sequence with Charge Pump Application

The following figures illustrate the recommended power ON and power OFF sequence of SSD1306 with charge pump application.

#### Power ON sequence :

- 1. Power ON VDD
- 2. Wait for ton. Power ON VBAT.<sup>(1)</sup> (where Minimum ton = 0ms)
- 3. After VBAT become stable, set RES# pin LOW (logic low) for at least 3us
- $(t_1)^{(4)}$  and then HIGH (logic high).

4. After set RES# pin LOW (logic low), wait for at least 3us (t2). Then input commands with below sequence:

- for enabling charge pump at 7.5V mode a. 8Dh 14h
- b. AFh for display ON
- 5. SEG/COM will be ON after 100ms (tap).



#### The Power ON Sequence With Charge Pump Application

#### Power OFF sequence :

- 1. Send command AEh for display OFF
- 2. Send command 8Dh 10h to disable charge pump
- 3. Power OFF VBAT after tOFF. (1), (2), (3) (Typical tOFF = 100ms)
- 4. Power OFF VDD after toFF2. (where Minimum toFF2 = 0ms<sup>(5)</sup>, Typical toFF2=5ms) The Power OFF Sequence With Charge Pump Application





#### Note:

(1) Since an ESD protection circuit is connected between V\_DD and VBAT, VBAT becomes lower

than VDD whenever VDD is ON and VBAT is OFF as shown in the dotted line of VBAT.

(2) VBAT should be kept float (i.e. disable) when it is OFF.

 $\ensuremath{\scriptscriptstyle (3)}$  Power Pins (VBAT) can never be pulled to ground under any circumstance.

 $\ensuremath{^{(4)}}$  The register values are reset after t1.

(5) VDD should not be Power OFF before VBAT Power OFF

# **CD** <sup>© RITEK GROUP</sup> **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 128 x 64 bits and the RAM is divided into eight pages, from PAGE0 to PAGE7, which are used for monochrome 128x64 dot matrix display, as shown in below figures.

|                     |            | Row re-mapping       |
|---------------------|------------|----------------------|
| PAGE0 (COM0-COM7)   | Page 0     | PAGE0 (COM 63-COM56) |
| PAGE1 (COM8-COM15)  | Page 1     | PAGE1 (COM 55-COM48) |
| PAGE2 (COM16-COM23) | Page 2     | PAGE2 (COM47-COM40)  |
| PAGE3 (COM24-COM31) | Page 3     | PAGE3 (COM39-COM32)  |
| PAGE4 (COM32-COM39) | Page 4     | PAGE4 (COM31-COM24)  |
| PAGE5 (COM40-COM47) | Page 5     | PAGE5 (COM23-COM16)  |
| PAGE6 (COM48-COM55) | Page 6     | PAGE6 (COM15-COM8)   |
| PAGE7 (COM56-COM63) | Page 7     | PAGE7 (COM 7-COM0)   |
|                     | SEG0SEG127 |                      |
| Column re-mapping   | SEG127SEG0 |                      |

#### GDDRAM pages structure of SSD1306

When one data byte is written into GDDRAM, all the rows image data of the same page of the current column are filled (i.e. the whole column (8 bits) pointed by the column address pointer is filled.). Data bit D0 is written into the top row, while data bit D7 is written into bottom row as shown in below figures.



~ Each box represents one bit of image data

For mechanical flexibility, re-mapping on both Segment and Common outputs can be selected by software.

For vertical shifting of the display, an internal register storing the display start line can be set to control the portion of the RAM data to be mapped to the display (command D3h).



# **Thank You**

