RK3399_PCIe芯片手册解读

本文详细解读了RK3399芯片中PCIe接口的工作原理,重点介绍了AXI总线的连接方式、通道、信号线以及PCIe控制器。文章还探讨了地址空间的划分,包括配置空间和内存/IO空间的访问,并提供了访问示例,阐述了如何通过配置Region0和Region1进行读写操作。

RK3399_PCIe芯片手册解读




参考资料:

AXI相关:

一、 AXI总线

1.1 连接方式

我们一直使用这个图来简化CPU与外设之间的连接:
在这里插入图片描述

实际芯片中,CPU与外设之间的连接更加复杂,高速设备之间通过AXI总线连接。AXI总线总传输数据的双方分为Master和Slave,Master发起传输,Slave回应传输。Master和Slave是多对多的关系,它们之间读、写可以同时进行的,内部结构图如下:

在这里插入图片描述

1.2 五个通道

在AXI总线中,读写可以同时进行,有5个通道:

  • 读:
    • 读地址通道:传输读操作的地址
    • 读数据通道:传输读到的数据
  • 写:
    • 写地址通道:传输写操作的地址
    • 写数据通道:传输要写的数据
    • 写响应通道:传输写操作的结果
      在这里插入图片描述
      在这里插入图片描述
通道名称 通道功能 数据流向
read address 读地址通道 主机->从机
read data
根据你提供的输出,这是在构建 Buildroot 时遇到的一些警告和错误。 首先,警告显示 `/home/clzdh/Desktop/rk3399_linux_release_v2.5.1_20210301/buildroot/output/rockchip_rk3399/.rockchipconfig` 文件中的第 339 行出现了一个警告,指示重新分配了符号 `BR2_PACKAGE_NTFS_3G`。这可能意味着在配置文件中对该符号进行了重复赋值。 然后,输出显示配置已写入 `/home/clzdh/Desktop/rk3399_linux_release_v2.5.1_20210301/buildroot/output/rockchip_rk3399/.config` 文件。 接下来,输出显示离开了 `/home/clzdh/Desktop/rk3399_linux_release_v2.5.1_20210301/buildroot` 目录。 然后,输出显示需要安装 `unbuffer` 工具。它建议你从 `expect` 或 `expect-dev` 包中安装 `unbuffer`。 然后,输出显示日志保存在 `/home/clzdh/Desktop/rk3399_linux_release_v2.5.1_20210301/br.log` 文件中。 最后,输出显示尝试读取 `/home/clzdh/Desktop/rk3399_linux_release_v2.5.1_20210301/br.log` 文件时出现错误,表示该文件不存在。 根据上述警告和错误,你可以尝试做以下几件事情: 1. 检查配置文件中是否对 `BR2_PACKAGE_NTFS_3G` 进行了重复赋值。打开 `/home/clzdh/Desktop/rk3399_linux_release_v2.5.1_20210301/buildroot/output/rockchip_rk3399/.rockchipconfig` 文件,并检查第 339 行的设置。 2. 检查是否已经安装了 `expect` 或 `expect-dev` 包。你可以使用合适的软件包管理器来安装它们。例如,在 Ubuntu 或基于 Debian 的系统上,你可以使用以下命令: ``` sudo apt-get install expect ``` 3. 检查构建日志是否存在。确认 `/home/clzdh/Desktop/rk3399_linux_release_v2.5.1_20210301/br.log` 文件是否存在,如果不存在,可能是由于构建过程中出现问题导致的。 如果问题仍然存在,请提供更多的上下文或详细描述你的构建环境和步骤,以便我们能够更好地帮助你解决问题。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值