# **RK3326 IO Domain Configuration Developer Guide**

ID: RK-SM-YF-908

Release Version: V1.0.0

Release Date: 2021-05-15

Security Level: □Top-Secret □Secret □Internal ■Public

#### DISCLAIMER

THIS DOCUMENT IS PROVIDED "AS IS". ROCKCHIP ELECTRONICS CO., LTD. ("ROCKCHIP") DOES NOT PROVIDE ANY WARRANTY OF ANY KIND, EXPRESSED, IMPLIED OR OTHERWISE, WITH RESPECT TO THE ACCURACY, RELIABILITY, COMPLETENESS, MERCHANTABILITY, FITNESS FOR ANY PARTICULAR PURPOSE OR NON-INFRINGEMENT OF ANY REPRESENTATION, INFORMATION AND CONTENT IN THIS DOCUMENT. THIS DOCUMENT IS FOR REFERENCE ONLY. THIS DOCUMENT MAY BE UPDATED OR CHANGED WITHOUT ANY NOTICE AT ANY TIME DUE TO THE UPGRADES OF THE PRODUCT OR ANY OTHER REASONS.

#### **Trademark Statement**

"Rockchip", "瑞芯微", "瑞芯" shall be Rockchip's registered trademarks and owned by Rockchip. All the other trademarks or registered trademarks mentioned in this document shall be owned by their respective owners.

#### All rights reserved. ©2021. Rockchip Electronics Co., Ltd.

Beyond the scope of fair use, neither any entity nor individual shall extract, copy, or distribute this document in any form in whole or in part without the written approval of Rockchip.

Rockchip Electronics Co., Ltd.

No.18 Building, A District, No.89, software Boulevard Fuzhou, Fujian, PRC

Website: www.rock-chips.com

Customer service Tel: +86-4007-700-590

Customer service Fax: +86-591-83951833

Customer service e-Mail: fae@rock-chips.com

#### **Preface**

#### Overview

The IO level of the controller's power domain must be matched with the IO level of the connected peripheral chip, and the voltage configuration of the software must be consistent with the voltage of the hardware. Otherwise, it may cause IO damage at worst.

This document mainly introduce the ways to configure IO power domain of RK3326 Linux SDK platform, aiming to help developers to configure IO power domain correctly.

#### **Product Version**

| Chipset | System Version |
|---------|----------------|
| RK3326  | Linux 4.4      |

#### **Intended Audience**

This document (this guide) is mainly intended for:

- Technical support engineers
- Software development engineers
- Hardware development engineers

#### **Revision History**

| Version | Author      | Date       | Change Description |
|---------|-------------|------------|--------------------|
| V1.0.0  | Caesar Wang | 2021-05-15 | Initial version    |

#### Contents

#### **RK3326 IO Domain Configuration Developer Guide**

- 1. Step 1: Obtain the Hardware Schematic Diagram and Check the Design of the Hardware Power Supply
- 2. Step 2: Find the Corresponding Kernel dts Configuration File
- 3. Step 3: Modify the Power Domain Configuration Node pmu\_io\_domains of the Kernel dts
- 4. Step 4: Check the Current Firmware IO Domain Configuration from SDK
- 5. Step 5: Confirm Whether the Register Value is Correct after Flashing the Firmware

## 1. Step 1: Obtain the Hardware Schematic Diagram and Check the Design of the Hardware Power Supply

It will take RK\_EVB\_RK3326\_LP3S178P132SD4\_V12\_201801024 EVB as an example to introduce in this document.

Hardware schematic diagram is: RK EVB RK3326 LP3S178P132SD4 V12 201801024.pdf.

Power solution: checking from the hardware schematic, the power solution of the EVB RK EVB RK3326 LP3S178P132SD4 V12 2018010245 is with a PMU (RK817-1).

### 2. Step 2: Find the Corresponding Kernel dts Configuration File

From the first step, it can be seen that the hardware power supply design of the EVB is with a PMU, and the corresponding kernel dts configuration file is located in:

arch/arm64/boot/dts/rockchip/rk3326-evb-lp3-v10-linux.dts (The solution discussed in this document)

### 3. Step 3: Modify the Power Domain Configuration Node pmu io domains of the Kernel dts

Take **pmuio2-supply** for example, firstly, check the hardware schematic diagram to confirm the configuration of the pmuio2 power domain (PMUIO2) as shown in the below figure.

From the figure, you will find that the power supply of PMUIO2 is VCC3V0\_PMU (that is 3.0V)



### 4. Step 4: Check the Current Firmware IO Domain Configuration from SDK

```
Command: ./build.sh info
```

## 5. Step 5: Confirm Whether the Register Value is Correct after Flashing the Firmware

Take **RK3326** as an example, get PMU\_SOC\_CON0 register (0xFF010100) and GRF\_IO\_VSEL register (0xFF140180) from the manual, they are shown as follows:

#### PMUGRF\_SOC\_CON0

Address: Operational Base + offset (0x0100)

| Bit   | Attr | Reset Value | Description                                                                                                                                                                                                                                                                                                                  |  |
|-------|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31:16 | wo   | 0x0000      | write_enable When bit 16=1, bit0 can be written by software. When bit 16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software; When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by software; |  |

Copyright 2018 © FuZhou Rockchip Electronics Co., Ltd.

#### RK3326 TRM-Part1

| Bit  | Attr | Reset Value | Description                                                                                                                 |  |
|------|------|-------------|-----------------------------------------------------------------------------------------------------------------------------|--|
| 15   | RW   | 0×0         | poc_pmuio2_sel18<br>PMU VCCIO2 voltage select<br>1'b0: 3.3V<br>1'b1: 1.8V                                                   |  |
| 14   | RW   | 0x0         | poc_pmuio1_sel18<br>PMU VCCIO1 voltage select<br>1'b0: 3.3V<br>1'b1: 1.8V                                                   |  |
| 13   | RW   | 0×0         | ddrphy_bufferen_core<br>1'b1: enable ddrphy_bufferen;<br>1'b0: disable ddrphy_bufferen                                      |  |
| 12   | RW   | 0×0         | ddrphy_bufferen_sel<br>1'b1: ddrphy_bufferen from ddrphy_bufferen_core;<br>1'b0: ddrphy_bufferen from pmu and ddr_fail_safe |  |
| 11:7 | RO   | 0x0         | reserved                                                                                                                    |  |
| 6    | RW   | 0x0         | uart0_cts_sel<br>1'b1: reverse polarity of cts;                                                                             |  |
| 5    | RW   | 0x0         | uart0_rts_sel                                                                                                               |  |

18

### GRF\_IO\_VSEL

Address: Operational Base + offset (0x0180)

| Bit   | Bit Attr Reset Value Description |             |                                                                                                                                                                                                                                                                                                                           |  |
|-------|----------------------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| BIT   | Attr                             | Reset Value | Description                                                                                                                                                                                                                                                                                                               |  |
| 31:16 | wo                               | 0×0000      | write_enable When bit16=1, bit0 can be written by software. When bit16=0, bit 0 cannot be written by software; When bit 17=1, bit 1 can be written by software. When bit 17=0, bit 1 cannot be written by software When bit 31=1, bit 15 can be written by software. When bit 31=0, bit 15 cannot be written by software. |  |
| 15:8  | RO                               | 0x0         | reserved                                                                                                                                                                                                                                                                                                                  |  |
| 7     | RW                               | 0x0         | grf_vccio_oscgpi_vsel IO voltage select 1'b0:3.3V 1'b1:1.8V                                                                                                                                                                                                                                                               |  |
| 6     | RW                               | 0×0         | grf_vccio5_vsel<br>VCC IO5 voltage select<br>1'b0:3.3V<br>1'b1:1.8V                                                                                                                                                                                                                                                       |  |
| 5     | RW                               | 0×0         | grf_vccio4_vsel<br>VCC IO4 voltage select<br>1'b0:3.3V<br>1'b1:1.8V                                                                                                                                                                                                                                                       |  |
| 4     | RW                               | 0x0         | grf_vccio3_vsel<br>VCC IO3 voltage select<br>1'b0:3.3V<br>1'b1:1.8V                                                                                                                                                                                                                                                       |  |
| 3     | RW                               | 0×0         | grf_vccio2_vsel<br>VCC IO2 voltage select<br>1'b0:3.3V<br>1'b1:1.8V                                                                                                                                                                                                                                                       |  |

```
1  # io -r -4 0xFF010100

2  ff010100: 00002380

3  

4  # io -r -4 0xFF140180

5  ff140180: 00000017
```