0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Banana Pi BPI-W3 RK3588平台驱动调试篇 [ PCIE篇一 ] - PCIE的开发指南

bananapi开源硬件 来源:bananapi开源硬件 作者:bananapi开源硬件 2023-11-02 09:22 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

RK3588平台驱动调试篇 [ PCIE篇 ] - PCIE的开发指南

1、PCIE接口概述

PCIe(Peripheral Component Interconnect Express)是一种用于连接计算机内部组件的高速接口标准。以下是关于PCIe接口的简要介绍:

高速传输: PCIe接口提供了高速的数据传输通道,可用于连接各种硬件设备,如图形卡、存储设备、网络适配器等。它的速度通常以每秒传输的数据位数(例如PCIe x1、x4、x8、x16等)来表示,每个通道的带宽可以根据需要扩展。

点对点连接: PCIe采用点对点连接的架构,这意味着每个设备都直接连接到主板上的PCIe插槽,而不需要与其他设备共享带宽。这有助于减少延迟并提高性能。

热插拔支持: PCIe接口支持热插拔,允许用户在计算机运行时添加或移除PCIe设备,而不需要重新启动计算机。

广泛应用: PCIe接口广泛用于连接图形卡、固态硬盘(SSD)、扩展卡、网络适配器和其他高性能设备。这使得计算机用户可以根据需要扩展和升级系统的性能和功能。

PCIe接口是一种计算机硬件连接标准,它提供了高速、高性能的数据传输通道,支持多种设备的连接。

2、传输速率简介

PCIe 分类、速度,按lane的个数分有 x1 x2 x4 x8 x16 (最大可支持32个通道),按代来分 有 gen1 gen2 gen3 gen4

wKgaomVC-dmAdRZWAACj2N-ckc0705.jpg

PCIe gen1 和 PCIe gen2 采用的编解码方式是 8b/10b,PCIe gen3 和 之后的 采用的是 128b/130b 的编码方式。

8b/10b 意思是说,当我们要传输8b的数据时,实际在通道上传输的是10b的数据,解码的时候,我们希望得到的是8b的有效数据。这样,相当于有效的带宽是实际带宽的 80%。

同理128b/130b,是传输128bit数据实际线路中传输的是130bit数据。

速率图中的单位间的关系:

传输速率单位 GT/s,表示 千兆传输/秒,是实际每秒传输的位数,他不包括额外吞吐量的开销位。

两个例子:

PCIe gen1 x1 传输速率 2.5GT/s = 2500MT/s = ( 2500 / 10 ) MB/s

PCIe gen3 x1 传输速率 8GT/s = 8000MT/s = ( 8000 / 130 ) x ( 128/8 ) MB/s= 984.6153... MB/s

PCIe 可⽤带宽:吞吐量 = 传输速率 * 编码⽅案

例如:PCIe 2.0 协议的每⼀条 Lane ⽀持58 / 10 = 4 Gbps = 500 MB/s 的速率,Pcie 2.0 x 8的通道为例,x8的可⽤带宽为 48 = 32 Gbps = 4 GB/s。

3、 芯片PCIE资源

3.1 硬件介绍

RK3588共有5个PCIe的控制器,硬件IP是⼀样的,配置不⼀样,其中⼀个4Lane DM模式可以⽀持作为EP使⽤,另外⼀个2Lane和3个1Lane控制器均只能作为RC使⽤。RK3588有两种PCIe PHY,其中⼀种为pcie3.0PHY,含2个Port共4个Lane,另⼀种是pcie2.0的PHY有3个,每个都是2.0 1Lane,跟SATAUSB combo使⽤。pcie3.0 PHY的4Lane可以根据实际需求拆分使⽤,拆分后需要合理配置对应的控制器。

wKgaomVC-dmASA5WAAQRx1tW1to846.jpg

3.2 kernel dts解析之PCIe

控制器在DTS对应节点名称:

资源 模式 dts节点 可用phy 内部DMA
PCIe
Gen3 x 4lane
RC/EP pcie3x4:
pcie@fe150000
pcie30phy
PCIe
Gen3 x 2lane
RC only pcie3x2:
pcie@fe160000
pcie30phy
PCIe
Gen3 x 1lane
RC only pcie2x1l0:
pcie@fe170000
pcie30phy,
combphy1_ps
PCIe
Gen3 x 1lane
RC only pcie2x1l1:
pcie@fe180000
pcie30phy,
combphy2_psu
PCIe
Gen3 x 1lane
RC only pcie2x1l2:
pcie@fe190000
combphy0_ps

在kernel/arch/arm64/boot/dts/rockchip/rk3588.dtsi下有具体描述

使用限制

pcie30phy拆分后,pcie30x4控制器,⼯作于2Lane模式时只能固定配合pcie30phy的port0,⼯作于 1Lane模式时,只能固定配合pcie30phy的port0lane0;

pcie30phy拆分后,pcie30x2控制器,⼯作于2Lane模式时只能固定配合pcie30phy的port1,⼯作于 1Lane模式时,只能固定配合pcie30phy的port1lane0;

pcie30phy拆分为4个1Lane,pcie3phy的port0lane1只能固定配合pcie2x1l0控制器,pcie3phy的 port1lane1只能固定配合pcie2x1l1控制器;

pcie30x4控制器⼯作于EP模式,可以使⽤4Lane模式,或者2Lane模式使⽤pcie30phy的port0, pcie30phy的port1中2lane可以作为RC配合其他控制器使⽤。默认使⽤common clock作为reference clock时,⽆法实现pcie30phy port0的lane0⼯作于EP模式,lane1⼯作于RC模式配合其他控制器使 ⽤,因为Port0的两个lane是共⽤⼀个输⼊的reference clock,RC和EP同时使⽤clock可能会有冲突。

RK3588 pcie30phy 如果只使⽤其中⼀个port,另⼀个port也需要供电,refclk等其他信号可接地。

4、PCIe 使用配置

4.1 简介

Armsom-W3开发板上有 1 个 PCIe3.0 x 4 接口和一个PCIe2.0接口,如图

wKgZomVC-dqABZNEAALDdWqbcNw137.jpg

wKgaomVC-dqAdTtWAAX-sF3QebY191.jpg

可以插入对应模组使用, 如图:

wKgZomVC-duAHelsAAEdXxMH7-A198.jpg

4.2 硬件设计

PCIe3.0 x 4 接口:

wKgaomVC-duAJvesAATeXYeTOE4384.jpg

PCIe 2.0接口:

wKgZomVC-dyATeFuAAPfy8T5Y38085.jpg

4.3 软件配置

一般根据原理图在 DTS 中配置供电引脚、复位引脚,选择正确的 pcie 控制器节点和 PHY 节点使能就可以。

kernel/arch/arm64/boot/dts/rockchip/rk3588-armsom-w3.dts中配置如下:

/ {
	vcc12v_dcin: vcc12v-dcin {
		compatible = "regulator-fixed";
		regulator-name = "vcc12v_dcin";
		regulator-always-on;
		regulator-boot-on;
		regulator-min-microvolt = < 12000000 >;
		regulator-max-microvolt = < 12000000 >;
	};

	vcc5v0_sys: vcc5v0-sys {
		compatible = "regulator-fixed";
		regulator-name = "vcc5v0_sys";
		regulator-always-on;
		regulator-boot-on;
		regulator-min-microvolt = < 5000000 >;
		regulator-max-microvolt = < 5000000 >;
		vin-supply = < &vcc12v_dcin >;
	};

	vcc3v3_pcie2x1l0: vcc3v3-pcie2x1l0 {
		compatible = "regulator-fixed";
		regulator-name = "vcc3v3_pcie2x1l0";
		regulator-min-microvolt = < 3300000 >;
		regulator-max-microvolt = < 3300000 >;
		enable-active-high;
		regulator-boot-on;
		regulator-always-on;
		gpios = < &gpio1 RK_PD2 GPIO_ACTIVE_HIGH >;
		startup-delay-us = < 50000 >;
		vin-supply = < &vcc5v0_sys >;
	};

	vcc3v3_pcie30: vcc3v3-pcie30 {
		compatible = "regulator-fixed";
		regulator-name = "vcc3v3_pcie30";
		regulator-min-microvolt = < 3300000 >;
		regulator-max-microvolt = < 3300000 >;
		enable-active-high;
		gpios = < &gpio1 RK_PA4 GPIO_ACTIVE_HIGH >;
		startup-delay-us = < 5000 >;
		vin-supply = < &vcc5v0_sys >;
	};

}

&pcie2x1l0 {
	reset-gpios = < &gpio4 RK_PA5 GPIO_ACTIVE_HIGH >;
	vpcie3v3-supply = < &vcc3v3_pcie2x1l0 >;
	status = "okay";
};

&combphy1_ps {
	status = "okay";
};

&pcie30phy {
	rockchip,pcie30-phymode = < PHY_MODE_PCIE_AGGREGATION >;
	status = "okay";
};

&pcie3x4 {
	reset-gpios = < &gpio4 RK_PB6 GPIO_ACTIVE_HIGH >;
	vpcie3v3-supply = < &vcc3v3_pcie30 >;
	status = "okay";
};

pcie30phy、combphy1_ps:PHY 节点

pcie3x4、pcie2x1l0:pcie3x4 控制器节点

reset-gpios:复位引脚属性

vcc3v3_pcie2x1l0、vcc3v3_pcie30:供电引脚节点

4.4 其他PCIE配置的实例

RK3588的控制器和PHY较多,按配置要点进⾏配置即可,这⾥还有⼏个典型范例供参考:

wKgaomVC-d2AcH1OAARurA6XV7k684.jpg

4.4.1 ⽰例1 pcie3.0phy拆分2个2Lane RC, 3个PCIe 2.0 1Lane

/ {
    vcc3v3_pcie30: vcc3v3-pcie30 {
        compatible = "regulator-fixed";
        regulator-name = "vcc3v3_pcie30";
        regulator-min-microvolt = < 3300000 >;
        regulator-max-microvolt = < 3300000 >;
        enable-active-high;
        gpios = < &gpio3 RK_PC3 GPIO_ACTIVE_HIGH >;
        startup-delay-us = < 5000 >;
        vin-supply = < &vcc12v_dcin >;
    };
};

&combphy0_ps {
	status = "okay";
};
&combphy1_ps {
	status = "okay";
};
&combphy2_psu {
	status = "okay";
};
&pcie2x1l0 {
    phys = < &combphy1_ps PHY_TYPE_PCIE >;
    reset-gpios = < &gpio4 RK_PA5 GPIO_ACTIVE_HIGH >;
    vpcie3v3-supply = < &vcc3v3_pcie30 >;
    status = "okay";
};
&pcie2x1l1 {
    phys = < &combphy2_psu PHY_TYPE_PCIE >;
    reset-gpios = < &gpio4 RK_PA2 GPIO_ACTIVE_HIGH >;
    vpcie3v3-supply = < &vcc3v3_pcie30 >;
    status = "okay";
};
&pcie2x1l2 {
    reset-gpios = < &gpio4 RK_PC1 GPIO_ACTIVE_HIGH >;
    vpcie3v3-supply = < &vcc3v3_pcie30 >;
    status = "okay";
};
&pcie30phy {
	/*pcie30phy的组合使⽤模式:
    PHY_MODE_PCIE_NANBNB  /* P1:PCIe3x2 + P0:PCIe3x2 */
    PHY_MODE_PCIE_NANBBI  /* P1:PCIe3x2 + P0:PCIe3x1*2 */
    PHY_MODE_PCIE_NABINB  /* P1:PCIe3x1*2 + P0:PCIe3x2 */
    PHY_MODE_PCIE_NABIBI  /* P1:PCIe3x1*2 + P0:PCIe3x1*2 */
	*/
    rockchip,pcie30-phymode = < PHY_MODE_PCIE_NANBNB >;
    status = "okay";
};
&pcie3x2 {
    reset-gpios = < &gpio4 RK_PB0 GPIO_ACTIVE_HIGH >;
    vpcie3v3-supply = < &vcc3v3_pcie30 >;
    status = "okay";
};
&pcie3x4 {
    num-lanes = < 2 >;//拆分为2lan使用
    reset-gpios = < &gpio4 RK_PB6 GPIO_ACTIVE_HIGH >;
    vpcie3v3-supply = < &vcc3v3_pcie30 >;
    status = "okay";
};

4.4.2 ⽰例2 pcie3.0phy拆分为4个1Lane, 1个使⽤PCIe 2.0 1 Lane

/ {
    vcc3v3_pcie30: vcc3v3-pcie30 {
        compatible = "regulator-fixed";
        regulator-name = "vcc3v3_pcie30";
        regulator-min-microvolt = < 3300000 >;
        regulator-max-microvolt = < 3300000 >;
        enable-active-high;
        gpios = < &gpio3 RK_PC3 GPIO_ACTIVE_HIGH >;
        startup-delay-us = < 5000 >;
        vin-supply = < &vcc12v_dcin >;
    };
};
&combphy0_ps {
	status = "okay";
};
&pcie2x1l0 {
    phys = < &pcie30phy >;
    reset-gpios = < &gpio4 RK_PA5 GPIO_ACTIVE_HIGH >;
    vpcie3v3-supply = < &vcc3v3_pcie30 >;
    status = "okay";
};
&pcie2x1l1 {
    phys = < &pcie30phy >;
    reset-gpios = < &gpio4 RK_PA2 GPIO_ACTIVE_HIGH >;
    vpcie3v3-supply = < &vcc3v3_pcie30 >;
    status = "okay";
};
&pcie2x1l2 {
    reset-gpios = < &gpio4 RK_PC1 GPIO_ACTIVE_HIGH >;
    vpcie3v3-supply = < &vcc3v3_pcie30 >;
    status = "okay";
};
&pcie30phy {
    rockchip,pcie30-phymode = < PHY_MODE_PCIE_NABIBI >;
    status = "okay";
};
&pcie3x2 {
    num-lanes = < 1 >;
    reset-gpios = < &gpio4 RK_PB0 GPIO_ACTIVE_HIGH >;
    vpcie3v3-supply = < &vcc3v3_pcie30 >;
    status = "okay";
};
&pcie3x4 {
    num-lanes = < 1 >;
    reset-gpios = < &gpio4 RK_PB6 GPIO_ACTIVE_HIGH >;
    vpcie3v3-supply = < &vcc3v3_pcie30 >;
    status = "okay";
};

pcie30phy拆分为4个1Lane时,port0lane0固定配合pcie3x4控制器,pcie3phy的port0lane1固定配合pcie2x1l0控制器,port1lane0固定配合pcie3x2控制器,pcie3phy的port1lane1固定配合pcie2x1l1控制器,加上combphy0_ps固定配合pcie2x1l2。

审核编辑 黄宇

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • PCIe
    +关注

    关注

    16

    文章

    1510

    浏览量

    89292
  • 开源
    +关注

    关注

    3

    文章

    4442

    浏览量

    46664
  • banana pi
    +关注

    关注

    1

    文章

    135

    浏览量

    4392
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    RK3588 PCIe 压测:从崩溃到排障的全流程解析

                在 RK3588 平台上进行 PCIe 设备(如 NVMe SSD )压测时,不少开发者遇到过这样的 “ 噩梦 ” :高负载下系统突然失去响应,日志里满是异常信
    的头像 发表于 02-06 07:11 714次阅读
    <b class='flag-5'>RK3588</b> <b class='flag-5'>PCIe</b> 压测:从崩溃到排障的全流程解析

    RK3588平台USB摄像头调试实战:从报错到稳定运行

    在嵌入式开发中,RK3588 凭借强劲的算力常被用于边缘计算、工业视觉等场景,而 USB 摄像头作为常见外设,调试过程中难免遇到各类 “卡壳” 问题。最近我们在 RK3588
    的头像 发表于 02-04 16:13 968次阅读

    RK3588平台双存储(SPI+PCIE)OTA升级方案教学文档

    在嵌入式设备中,单存储介质可能存在容量限制或可靠性风险。RK3588 平台的双存储 OTA 升级方案支持SPI(如 SPI NAND/NOR)与 PCIE 存储(如
    的头像 发表于 02-01 16:46 1886次阅读
    <b class='flag-5'>RK3588</b><b class='flag-5'>平台</b>双存储(SPI+<b class='flag-5'>PCIE</b>)OTA升级方案教学文档

    RK3588平台串口配置修改指南:切换至串口8

    在嵌入式开发中,串口作为基础调试接口至关重要。本文档针对 RK3588 平台,详细介绍如何将系统默认串口修改为串口 8(UART8),包括 U-Boot 阶段和内核阶段的配置调整。该修
    的头像 发表于 02-01 16:37 1509次阅读

    实战复盘:RK3588 SPI+PCIe3x4方案启动修复,从节点配置到驱动适配全解析

          在 RK3588 嵌入式项目中, “ 接口配置不匹配 ” 是高频踩坑点 —— 近期 基于 linux6.1 内核 调试 SPI 闪存 +PCIe3x4 外设 方案时,就遇到了 “eMMC
    的头像 发表于 01-08 10:24 1010次阅读
    实战复盘:<b class='flag-5'>RK3588</b> SPI+<b class='flag-5'>PCIe3</b>x4方案启动修复,从节点配置到<b class='flag-5'>驱动</b>适配全解析

    【技术分享】RK3588如何搭建xenomai3+ethercat

    说明使用的RK3588的分支版本是linux-6.1-stan-rkr6内核版本是6.1.99把瑞芯微的SDK更新到linux-6.1-stan-rkr6这个版本即可。编译xenomai3的内核请参考上
    的头像 发表于 12-11 17:26 1555次阅读
    【技术分享】<b class='flag-5'>RK3588</b>如何搭建xenomai<b class='flag-5'>3</b>+ethercat

    文搞懂 RK3588 PCIe:从硬件资源到拆分配置 + 避坑指南(含脑图)

    资源解析、 3  大拆分方案实战、关键配置步骤及避坑要点,附带可视化脑图,助力开发者快速落地  PCIe  相关项目。       RK358
    的头像 发表于 11-20 18:18 5336次阅读
    <b class='flag-5'>一</b>文搞懂 <b class='flag-5'>RK3588</b> <b class='flag-5'>PCIe</b>:从硬件资源到拆分配置 + 避坑<b class='flag-5'>指南</b>(含脑图)

    开发者必备,10 分钟搞定 RK3588 PCIE 拆分!

    前言:在嵌入式开发中,PCIe接口的灵活配置直接影响设备扩展能力与性能发挥。RK3588作为旗舰芯片,其PCIe拆分机制更是让硬件设计与软件调试
    的头像 发表于 11-13 08:31 2348次阅读
    <b class='flag-5'>开发</b>者必备,10 分钟搞定 <b class='flag-5'>RK3588</b> <b class='flag-5'>PCIE</b> 拆分!

    BPI-AIM7 RK3588 AI与 Nvidia Jetson Nano 生态系统兼容的低功耗 AI 模块

    Banana Pi BPI-AIM7 RK3588 AI Module7 (AIM7) 配备 64 位八核处理器、6 TOPS NPU、8 GB 内存、
    发表于 10-11 09:08

    BPI-AIM7 RK3588 AI与 Nvidia Jetson Nano 生态系统兼容的低功耗 AI 模块

    Banana Pi BPI-AIM7 RK3588 AI Module7 (AIM7) 配备 64 位八核处理器、6 TOPS NPU、8 GB 内存、
    的头像 发表于 10-11 09:06 1710次阅读
    <b class='flag-5'>BPI</b>-AIM7 <b class='flag-5'>RK3588</b> AI与 Nvidia Jetson Nano 生态系统兼容的低功耗 AI 模块

    【作品合集】玄铁Banana Pi BPI-RV2开发板测评

    测试 作者:chen000000009【Banana Pi BPI-RV2开发板试用体验】开箱+硬件介绍 【Banana
    发表于 09-17 10:58

    RK3588 PCIe设备识别失败?招避坑“非法Class”陷阱

    前言:在RK3588平台开发过程中,你是否遇到过这样的窘境:明明PCIe总线上挂好了网卡模块,lspci能识别到芯片,可驱动就是加载失败,排
    的头像 发表于 08-29 08:32 2307次阅读
    <b class='flag-5'>RK3588</b> <b class='flag-5'>PCIe</b>设备识别失败?<b class='flag-5'>一</b>招避坑“非法Class”陷阱

    Banana Pi BPI-RV2开发板试用体验】开箱上电

    ⼝、板载 512MB DDR3 内存 、128 MiB NAND、16 MiB NOR、M.2接⼝,MINI PCIE和USB 2.0接⼝等。 Banana Pi
    发表于 06-26 19:51

    Banana Pi BPI-RV2开发板试用体验】开发板介绍视频

    . 开发板介绍香蕉派 BPI-RV2 RISC-V 路由器开发板采用矽昌通信 SF21H8898 芯片方案矽昌 SF21H8898 四核64位RISC-V 处理器, 1.25GHz主
    发表于 06-24 23:51

    基于RISC-V处理器,Banana Pi BPI-RV2开发板试用

    Banana Pi BPI-RV2 开源网关是⼀款基于矽昌 SF21H8898 SoC的设备,1 × 2.5 G WAN⽹络接⼝、5  个千兆LAN ⽹络接⼝、板载 512MB DDR3
    的头像 发表于 06-09 14:59 1551次阅读
    基于RISC-V处理器,<b class='flag-5'>Banana</b> <b class='flag-5'>Pi</b> <b class='flag-5'>BPI</b>-RV2<b class='flag-5'>开发</b>板试用