PCIE总线

news2024/11/25 12:40:19

PCIE总线记录

    • 描述
    • PCI分类与速度
    • PCIE连接拓扑与角色
    • PCIE接口定义
    • PCIE数据传输方式与中断
        • 在PCIE中有两种数据传输方式:
        • PCIE中断:
    • PCIE协议栈与工作流程
    • PCIE地址空间分类
    • 实例分析
    • PCIE两种访问方式

描述

PCI-Express(peripheral component interconnect express)是一种高速串行计算机扩展总线标准,它原来的名称为“3GIO”,是由英特尔在2001年提出的,旨在替代旧的PCI,PCI-X和AGP总线标准。PCIe属于高速串行点对点双通道高带宽传输,所连接的设备分配独享通道带宽,不共享总线带宽,主要支持主动电源管理,错误报告,端对端的可靠性传输,热插拔以及服务质量(QOS)等功能。PCIe交由PCI-SIG(PCI特殊兴趣组织)认证发布后才改名为“PCI-Express”,简称“PCI-e”。它的主要优势就是数据传输速率高,目前最高的16X 2.0版本可达到10GB/s,而且还有相当大的发展潜力。PCI Express也有多种规格,从PCI Express x1到PCI Express x32,能满足将来一定时间内出现的低速设备和高速设备的需求。PCI-Express最新的接口是PCIe 3.0接口,其比特率为8Gbps,约为上一代产品带宽的两倍,并且包含发射器和接收器均衡、PLL改善以及时钟数据恢复等一系列重要的新功能,用以改善数据传输和数据保护性能。

PCI分类与速度

在这里插入图片描述

PCIE连接拓扑与角色

在这里插入图片描述
EP设备:终端设备。
RC设备:根总线设备,总线控制器。
BG设备:桥设备。将pcie总线转换成其他总线的设备,或者反之。类似于网关。
SW设备:连接多个pci终端设备在同一总线域的设备。类似于交换机。

PCIE接口定义

在这里插入图片描述
PRSNT1/2#:热插拔信号引脚
SMCLK+SMDAT:SMBUS信号接口,用于管理pcie设备。
TCK+TDI+TDO+TMS+TRST#:jtag接口,用于调试pcie设备。
WAKE#:唤醒引脚。
PERST#:复位引脚。
CLKREQ#:时钟请求引脚。
REFCLK+/-:差分时钟引脚。
HS O/I p/n (0):差分IO引脚。

Tips:实际使用中可以根据需求删减引脚。

PCIE数据传输方式与中断

在PCIE中有两种数据传输方式:

DMA(Direct Memory Access),直接内存访问,在该模式下,数据传送不是由CPU负责处理,而是由一个特殊的处理器DMA控制器来完成,因此占用极少的CPU资源。
PIO(Programmed Input-Output),可编程输入输出,在该模式下,数据传送由CPU执行I/O端口指令来按照字节或更大的数据单位来处理,占用大量的CPU资源,数据传输速度也大大低于DMA模式。举例老说,在DMA方式下,如果copy文件的同时在播放mp3音乐,则不受丝毫影响;如果在PIO模式下,则会发现音乐声时断时续,这是因为大部分CPU资源被文件传输占用。

PCIE中断:

在PCIE总线中没有中断引脚,所以中断信号通过MSI的方式传输。也就是中断信号与数据信号一起传输。

PCIE协议栈与工作流程

在这里插入图片描述

  1. pcie设备上电或者复位,并且电源与pll变稳定后。pcie就会开始尝试建立连接。当链路处于有效状态,终端设备就会告诉总线设备自己已经准备好建立连接了。两者状态同步后,总线设备LTSSM开始检测可用的通道数,并且开始链路训练,用来确认该状态下的链路最佳的通信参数。
  2. 物理层的linkup建立后,数据链路模块开始工作,并且初始化控制流。
  3. 控制流初始化完毕后。数据链路模块发信号给传输层模块,告诉他准备好允许发送/接收TLP流量。

Tips:在正常操作期间,LTSSM和数据链路模块继续管理底层链路完整性。 4、pcie枚举发现新设备。

PCIE地址空间分类

pcie的空间分为io、mem与配置空间。配置空间是每一个PCI设备都要提供的一个寄存器,位于硬件设备中,它的作用是:

  1. 告诉系统本硬件的名称、生产厂商、设备类型、版本、是否支持背靠背传输等信息;
  2. 告诉系统本硬件需要的IO、中断、MEMORY等资源的数量;
  3. 接受系统赋予以上资源的基地址;
    在这里插入图片描述
    EP设备配置空间
    在这里插入图片描述

实例分析

在这里插入图片描述
bar中的地址,就是linux kernel map中的物理地址(linux kernel如果是32位,那么虚拟内存大小是一块4G的空间,各个外设比如pci,ddr等通过映射的方式可以将物理地址映射上来)。另外这个bar地址是上电后系统根据实际配置情况与bar信息经过映射的地址,保存在pci设备中的配置信息记录的是设备在pci空间中的地址与长度等信息。
在这里插入图片描述
拿到bar中的地址信息了。我们就等于拿到了pcie设备的寄存器起始地址了。接下来就可以正式编写设备驱动了。

PCIE两种访问方式

在这里插入图片描述
默认情况下,RC outbound的方式访问PCIE设备。如果需要RC inbound,那么需要额外配置。

(参考来源组内大佬的分享文档)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/336724.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python调用API接口,实现人脸识别

人生苦短,我用Python 在开始之前,先问问大家: 什么是百度Aip模块? 百度AI平台提供了很多的API接口供开发者快速的调用运用在项目中 本文写的是使用百度AI的**在线接口SDK模块(baidu-aip)**进行实现人脸识…

K100多功能嵌入吞吐式电动发卡读写一体机|读卡器技术选型问答

K100多功能嵌入吞吐式电动发卡读写一体机|读卡器技术是一款带卡槽,支持150张标准卡存放,电动式发卡、读写一体,支持磁条卡读卡,发卡;支持符合ISO7816协议的接触式芯片卡发卡,读写卡;支持符合ISO…

【C++详解】——vector类

📖 前言:本期介绍vector类。 目录🕒 1. vector的介绍🕒 2. vector的使用🕘 2.1 定义🕘 2.2 iterator🕘 2.3 空间增长🕘 2.4 增删查改🕒 2. vector的模拟实现&#x1f558…

Springboot+ssm微空间私人定向共享文件资料系统java

目 录 1绪论 1 1.1项目研究的背景 1 1.2开发意义 1 1.3项目研究现状及内容 5 1.4论文结构 5 2开发技术介绍 7 2.1 B/S架构 7 2.2 MySQL 介绍 7 2.3 MySQL环境配置 7 2.4 Java语言简介 8 2.5Jsp技术 8 3系统分析 9 3.1可行性分析 9 3.1…

Android Studio 编译C/C++生成.so文件

前期准备:下载NDK、CMake方法一:使用AndroidStudio自动创建NativeC/C 项目创建新项目创建项目后,会默认生成两个文件和相关默认配置.若创建好C项目后报错,则需要配置一下NDK路径如果上图配置页面显示无法配置,则需要手…

【疑难解决】EasyCVR集成宇视SDK关闭“按需直播”,一直未拉流是什么原因?

EasyCVR平台不仅能提供丰富的视频能力,还可提供云、边、端分布式海量视频资源的统一管理与运维,从而实现数据采集、处理、汇聚、分析、存储、管理等全环节的视频能力。借助智能分析网关的AI智能检测能力,可实现人脸、人体、车辆、烟火、物体、…

LeetCode-191-位1的个数

1、位运算 我们可以使用位运算来计算二进制串中1的个数。由于异或的性质,0与0异或为0,0与1异或为1,我们可以将n与0进行异或操作,而后逐位判断是否为1,最终将结果进行累加即可。 class Solution { public:int hamming…

Mybatis 基础1

Mybatis基础什么是Mybatis什么是框架ORM介绍快速入门环境搭建MyBatis的相关apiResources构建器SqlSessionFactoryBuilder工厂对象SqlSessionFactorySqlSession会话对象MyBatis 映射配置文件映射配置文件介绍查询功能新增功能修改功能删除功能小结Mybatis核心配置文件介绍核心配…

创建百度百科词条要交费吗?百度百科词条花钱吗?

互联网时代,百度逐渐成为了人们了解信息、搜集信息的主要渠道,越来越多的用户通过百度百科词条认识到了很多知名的人物、产品、品牌或是作品等等,百度百科词条在人们心中的信赖度也是越来越高。 百度百科词条具有权威性,百度百科…

Spring中Bean的生命周期(包含Spring执行流程)

文章目录一、Spring(Bean)执行流程二、Bean生命周期Bean的生命周期演示总结一、Spring(Bean)执行流程 启动容器(启动项目)读取配置文件(初始化) a) 使用xml注册bean b) 配置bean根(扫描)路径将bean存储到Spring中(存操作): 通过类注解进行扫描和装配将bean从Spring读取出来(取…

想要协同办公,企业云盘该怎么选?

信息数字时代,数字资产迎来爆发的同时,资产管理需求也在不断增加。在面对资源容量过大、素材无法大量共享等问题时,怎么让内容生产者和团队管理者更高效进行内容存储,满足项目在多元场景下分发、协作需求?赞奇超级云盘…

MySQL相关面试题

文章目录union 和 unionAll 的区别?drop、delete与truncate的区别 ?sql 语句如何优化 ?什么是事务 ?事务的四个特性(ACID) ?事务的隔离级别?索引主要有哪几种分类 ?什么时候适合添加索引&#x…

ClickHouse 单机安装及基础知识与 Spark 应用

什么是 ClickHouse? ClickHouse 是一个用于联机分析(OLAP)的列式数据库管理系统(DBMS)。 在传统的行式数据库系统中,数据按如下顺序存储: 处于同一行中的数据总是被物理的存储在一起。 常见的行式数据库系统有:MySQL、Postgres等。 在列式数据库系统中,数据按如下的顺…

ansible的常用模块介绍

ansible 常用命令/usr/bin/ansible  #Ansibe AD-Hoc 临时命令执行工具,常用于临时命令的执行/usr/bin/ansible-doc #Ansible 模块功能查看工具/usr/bin/ansible-galaxy  #下载/上传优秀代码或Roles模块 的官网平台,基于网络的/usr/bin/ansible-playbo…

第八章 Flink集成Iceberg的DataStreamAPI、TableSQLAPI详解

1、概述 ​ 目前Flink支持使用DataStream API 和SQL API方式实时读取和写入Iceberg表,建议使用SQL API方式实时读取和写入Iceberg表。 Iceberg支持的Flink版本为1.11.x版本以上,以下为版本匹配关系: Flink版本Iceberg版本备注Flink1.11.XI…

Windows 安装 Docker

一、Docker 官网 Dockerhttps://hub.docker.com/下载地址 window Docker 下载地址https://desktop.docker.com/win/main/amd64/Docker%20Desktop%20Installer.exe 二、安装 检测是否已经安装了docker docker -v 如下图 : 如果没有安装,则在第一点下…

【Spark分布式内存计算框架——Spark Core】5. RDD 函数补充:关联函数与练习

关联函数 当两个RDD的数据类型为二元组Key/Value对时,可以依据Key进行关联Join。 首先回顾一下SQL JOIN,用Venn图表示如下: RDD中关联JOIN函数都在PairRDDFunctions中,具体截图如下: 具体看一下join(等…

1624_MIT 6.828 stabs文档信息整理_上

全部学习汇总: GreyZhang/g_unix: some basic learning about unix operating system. (github.com) 前面为了完成MIT 6.828的堆栈信息解析大概看了一下这个文档,现在把看过的信息简单整理一下。 1. stabs主要是为调试器提供调试信息用的描述数据&#x…

11.XMLHttpRequest的进阶用法

目录 1 设置HTTP的请求时限 2 Formdata对象 2.1 简单使用 2.2 Formdata直接获取表单数据 2.3 上传文件 2.4 上传文件的进度 3 定义API根路径 4 请求出错 上面我们用的都是旧版的XMLHttpRequest,旧版有两个缺点 无法上传文件没有传送数据的进度信息…

Docker部署ddns-go,动态域名解析公网IPv6地址

Docker部署ddns-go,动态域名解析公网IPv6地址 ddns-go,自动获得你的公网 IPv4 或 IPv6 地址,并解析到对应的域名服务。 嫌IPv6地址太难记?ddns来解决,将家里的公网IPv6地址用起来吧! 前言 为什么需要DDNS …