PCIE集成验证(五)MSI/MSI-X中断

PCI 总线最早采用的中断机制是 INTx,这是基于边带信号的。后续的 PCI/PCI-X版本,为了消除边带信号,降低系统的硬件设计复杂度,逐渐采用了 MSI(Message Signaled Interrupt)/MSI-X(消息信号中断)的中断机制。

MSI/MSI-X 与 PCIe总线中的消息(Message)的概念完全不同! MSI/MSI-X 本质上是一种 Posted Memory Write TLP。

MSI最大支持32个中断向量,MSI-X在 3.0 版本引入,对 MSI 做出了一些升级和改进,最大支持2048个中断向量。

当EP支持MSI/MSI-X时,RC可在枚举阶段对MSI/MSI-X的能力寄存器做相关配置

MSI能力寄存器

MSI的Capability ID = 0x05,DW1为发起中断MEM_WR TLP的地址,DW2的[15:0]为写数据,其中低bit位为对应的中断向量号。

Mask Bits的某一个位置1,则表明对应的中断向量号触发中断时,不会实际发送MEM_WR TLP;但是此时Pending Btis对应位会置1;
软件此时只能通过Polling Pending Bits来得知EP端是否有中断;如果Mask Bits的某一位置0,此时Pending Btis对应位为1,则会触发MEM_WR TLP的中断,然后硬件再clear对应的Pending Btis。

Pending Btis对于HOST是只读的。

根据地址,分为32-bit和64-bit两种格式:

在这里插入图片描述

Message Control格式如下:
[0:0] : MSI使能
[3:1] : EP端可支持的向量数目
[6:4] : 实际软件使能的向量数目
[7:7] : 是否是64-bit格式
[8:8] 是否支持中断mask功能
在这里插入图片描述
所以启用MSI功能之前,需要配置如下寄存器:
注意32-bit相比64-bit少配置一个寄存器,32-bit不支持中断mask功能时,只需配置前三个寄存器。
在这里插入图片描述
所以枚举设备时,驱动软件会判断EP是否支持MSI功能,并配置对应的MSI地址和数据。

MSI-X能力寄存器

MSI-X的Capability ID = 0x11,Message Control [10:0] 表示支持的中断数目,[14]为总的mask开关,[15]为使能开关
Table BIR 表示 MSI-X Table处于哪个BAR上;PBA BIR表示 PBA处于哪个BAR上;
MSI-X Table Offset为相对于BAR地址MSI-X Table的偏移地址,对于HOST是只读的
PBA Offset为为相对于BAR地址PBA的偏移地址,对于HOST是只读的
在这里插入图片描述

因为MSI-X最大支持2048个中断向量,并且中断地址和数据都是可配置的,像MSI那样通过寄存器来实现不太现实;所以MSI-X会分配一段ram空间存放这些信息;本系列中,将MSI-X Table映射在BAR1空间上,相对于BAR1的偏移地址在MSI-X能力寄存器中定义。

每个中断向量为一个Entry,驱动软件可配置每个Entry的地址和数据,DW3 [0:0]为该Entry的mask;
和MSI类似,也有对应的Penging Btis;每一个Penging Btis可覆盖64个中断Entry。

在这里插入图片描述
在这里插入图片描述

所以启用MSI-X功能之前,需要配置如下寄存器以及BAR1空间上的MSI-X Table

在这里插入图片描述

枚举阶段配置完MSI/MSI-X能力寄存器后,EP端的应用可触发MSI/MSI-X中断,两者方式有所不同:

触发MSI中断

MSI中断提供了专门的MSI相关的信号,用户在集成PCIE Controller时,可将响应信号集成到MSIC模块中。相关信号如下:
在这里插入图片描述

逻辑实现如下:

在这里插入图片描述
依次触发终端号为’hc,'h16,'hb,'ha,'h19 :
在这里插入图片描述

Controller接收中断后,生成相应的MEM_WR TLP,写地址为MSI能力寄存器中配置的Message Address,写数据为Message Data和中断向
量号的组合

在这里插入图片描述

触发MSI-X中断

MSI-X中断通过DBI写MSI-X Doorbell Register实现,DOORBELL寄存器如下:
在这里插入图片描述

利用DBI接口向DOORBELL地址’h948写中断向量号 'h16,'h1b,'h9,'h15,'h6

在这里插入图片描述

Controller依据DOORBELL配置,生成相应的MEM_WR TLP,写地址为MSI-X对应Entry中断号的Message Address,写数据为Message Data

在这里插入图片描述

TB中对于如何抓取VIP侧接收的MEM_WR TLP是否符合预期,可以重写callback function post_tlp_framed_in_get 或者使用received_tlp_observed_port

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

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

相关文章

救生圈检测系统源码分享

救生圈检测检测系统源码分享 [一条龙教学YOLOV8标注好的数据集一键训练_70全套改进创新点发刊_Web前端展示] 1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 项目来源AACV Association for the Advancement of Computer Visio…

使用Renesas R7FA8D1BH (Cortex®-M85)和微信小程序App数据传输

目录 概述 1 系统架构 1.1 系统结构 1.2 系统硬件框架结构 1.3 蓝牙模块介绍 2 微信小程序实现 2.1 UI介绍 2.2 代码实现 3 上位机功能实现 3.1 通信协议 3.2 系统测试 4 下位机功能实现 4.1 功能介绍 4.2 代码实现 4.3 源代码文件 5 测试 5.1 编译和下载代码…

微服务基础设施选型

微服务基础设施架构 微服务基础设施架构全貌 微服务 vs SOA (Round 2) 微服务数量越多越复杂 微服务 vs SOA (Round 3) 微服务把服务的粒度变小,进行了标准化拆分。同时也将ESB拆分为了微服务。 微服务基础设施优先级 这里面体现了基础设施的优先级,如…

人工智能之就业方向(The Employment Direction of Artificial Intelligence)

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:Linux运维老纪的首页…

银河麒麟桌面操作系统V10(SP1)离线升级SSH(OpenSSH)服务

目录 前言 准备工作 准备与目标服务器相同版本的操作系统 准备编译依赖包 下载OpenSSL源码包 下载OpenSSH源码包 升级OpenSSH服务 查看当前版本信息 安装编译依赖包 安装OpenSSL 安装OpenSSH 前言 OpenSSH是一个广泛使用的开源SSH(安全壳)协议的实现,它提供了安…

手机自动化测试环境之夜神模拟器inspector部署验证

1、自动化测试环境部署_总览图检查表流程图 Python需要安装Appium-Python-Clicent去定位元素;Appium是一个中间的服务器,它需要依赖node.js,python的脚本通过appium和手机进行交互;手机app的环境都是java环境,先安装jd…

PMBOK® 第六版 排列活动顺序

目录 读后感—PMBOK第六版 目录 职场中有句玩笑话:“工作是永远做不完的,任何时候都不可能做完。”这里所吐槽的要点就在于工作任务繁多以及工作缺乏秩序。工作确实是做不完的,倘若工作都能完成,那也就不需要工作了。 工作中令人…

【服务器第二期】mobaxterm软件下载及连接

【服务器第二期】mobaxterm软件下载及连接 前言什么是SSH什么是FTP/SFTP mobaxterm软件介绍mobaxterm软件下载SSH登录使用方法1-新建ssh连接方法2-打开已有的ssh连接方法3-通过ssh命令建立连接 SFTP数据传输方法1-建立ssh连接后直接拖拽方法2-建立sftp连接再拖拽方法3-直接使用…

SURILL MILL搭配cnc机器的打样(3维导入 使用)

导入STP文件,然后 选择 ,点击 曲面里的 曲面 炸开 (和曲线分开 ) 到处曲面 的面与 面的先分开了 看 实际情况 ,接下来 也可以 曲线炸开 来 分解 组合 然后 ,此时选择面还是没有生产成线 点击文件 那一行的曲面 绘制 ,借助曲面…

华为云centos7.9按装ambari 2.7.5 hostname 踩坑记录

华为云centos7.9按装ambari 2.7.5踩坑记录 前言升华总结 前言 一般都是废话,本人专业写bug业余运维。起初找了三台不废弃的台式机,开始重装centos系统,开始了HDP3.1.5Ambari2.7.5安装。 推荐一波好文,一路长绿。跑了一段时间没啥…

3DMAX乐高积木插件LegoBlocks使用方法

3DMAX乐高积木插件LegoBlocks,用户可以通过控件调整和自定义每个乐高积木的外观和大小。 【适用版本】 3dMax2009或更高版本(不仅限于此范围) 【安装方法】 3DMAX乐高积木插件无需安装,使用时直接拖动插件脚本文件到3dMax视口中…

适用于 Windows 的 7 大数据恢复工具,可靠的数据恢复工具可有效地恢复丢失的文件

数据丢失可能是一种令人沮丧的经历,无论是由于意外删除、磁盘格式化还是系统崩溃。幸运的是,Windows 用户可以使用几种可靠的数据恢复工具来有效地恢复丢失的文件。以下是前七名数据恢复工具的综述,包括奇客数据恢复产品: 适用于 …

大数据新视界 --大数据大厂之 Node.js 与大数据交互:实现高效数据处理

💖💖💖亲爱的朋友们,热烈欢迎你们来到 青云交的博客!能与你们在此邂逅,我满心欢喜,深感无比荣幸。在这个瞬息万变的时代,我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的…

物理学基础精解【7】

文章目录 平面方程直角坐标及基本运算 参考文献 平面方程 直角坐标及基本运算 向量的四则运算 下面由文心一言自动生成 向量的四则运算主要包括加法、减法、数乘(标量乘法)和数量积(点积或内积),但通常不直接称为“除…

CANopen通讯协议笔记

CANopen通讯协议笔记 CANopen 通信对象编号CANopen整体框架网络管理(NMT)主要任务上线报文心跳报文过程数据对象(PDO)SDO服务数据对象对象字典概述 CANopen 通信对象编号 CANopen报文传输采用 CAN 标准帧格式。 这里的CAN-ID也叫…

互联网全景消息(5)之RocketMq快速入门(下)

一、RocketMQ的存储设计 1.1 Domain Model 1.1.1 Message Message是RocketMQ消息引擎中的主体。messageId是全局唯一的。MessageKey是业务系统(生产者)生成的,所以如果要结合业务,可以使用MessageKey作为业务系统的唯一索引。 1.1.2 Topic subTopics==Message Queue,其实…

0基础学习HTML(十)表格

HTML 表格 HTML 表格由 <table> 标签来定义。 HTML 表格是一种用于展示结构化数据的标记语言元素。 每个表格均有若干行&#xff08;由 <tr> 标签定义&#xff09;&#xff0c;每行被分割为若干单元格&#xff08;由 <td> 标签定义&#xff09;&#xff0c…

计算机毕业设计之:基于微信小程序的校园流浪猫收养系统

博主介绍&#xff1a; ✌我是阿龙&#xff0c;一名专注于Java技术领域的程序员&#xff0c;全网拥有10W粉丝。作为CSDN特邀作者、博客专家、新星计划导师&#xff0c;我在计算机毕业设计开发方面积累了丰富的经验。同时&#xff0c;我也是掘金、华为云、阿里云、InfoQ等平台…

YOLOV8 OpenCV + usb 相机 实时识别

1 OpenCV 读相机 import cv2cap cv2.VideoCapture(0) while (1):# get a frameret, frame cap.read()# show a framecv2.imshow("capture", frame)if cv2.waitKey(1) & 0xFF ord(q):# cv2.imwrite("/opt/code/image/fangjian2.jpeg", frame)#passb…

前端-js例子:tab切换

实现效果&#xff1a; 实现步骤&#xff1a; 1. body内容元素 <div class"container"><ul class"top_title"><li class"first" index"1">title1</li><li index"2">title2</li><li …