学习
实践
活动
专区
工具
TVP
写文章

PCIe中MSIMSI-X中断机制

MSIMSI-X中断机制 在PCI总线中,所有需要提交中断请求的设备,必须能够通过INTx引脚提交中断请求,而MSI机制是一个可选机制。 在PCIe总线中,MSIMSI-X中断机制使用存储器写请求TLP向处理器提交中断请求,下文为简便起见将传递MSI/MSI-X中断消息的存储器写报文简称为MSI/MSI-X报文。 与MSI中断机制相比,MSI-X中断机制更为合理。本章将首先介绍MSI/MSI-X Capability结构,之后分别以PowerPC处理器和x86处理器为例介绍MSIMSI-X中断机制。 MSI/MSI-X Capability结构 PCIe设备可以使用MSI或者MSI-X报文向处理器提交中断请求,但是对于某个具体的PCIe设备,可能仅支持一种报文。 MSI中断机制最多只能使用32个中断向量,而MSI-X可以使用更多的中断向量。目前Intel的许多PCIe设备支持MSI-X中断机制。与MSI中断机制相比,MSI-X机制更为合理。

64330
  • 广告
    关闭

    热门业务场景教学

    个人网站、项目部署、开发环境、游戏服务器、图床、渲染训练等免费搭建教程,多款云服务器20元起。

  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MSI-X的介绍(1)

    本文将更偏向于具体编程实现的角度来介绍MSI-X,阅读本文需要有PCI总线以及MSI的基本前置知识。 MSI-X是PCI总线设备的一种中断方式,直接将中断投递到处理器核心的Local APIC。 它与MSI的区别在于,MSI-X属于是对MSI中断的扩展,他们的区别在于,MSI的话,只有32个中断向量,且必须连续,MSI-X可以有2048个,可以不连续。 并且,MSIMSI-X是互斥的,也就是说,对于某个pci设备而言,它要么启用MSI,要么启用MSI-X,不能同时启用二者。并且,有的PCI设备同时支持了二者,你可以选择启用其中的任意一种。 Message Control 图片 Message Control部分的bit分布 MSI-X Enable 若当前位为1,且MSI Enable为0,那么,当前function将被允许使用MSI-X Pending bit Offset 这部分与上面的Table Offset类似,只不过涉及到的是MSI-X PBA MSI-X Table MSI-X Table中描述了该function的MSI-X

    14940

    PCI Express 系列连载篇(二十四)MSIMSI-X中断机制 I

    中断机制,包括MSI/MSI-X Capability结构(MSI Capability结构、MSI-X Capability结构)等内容。 在PCIe总线中,MSIMSI-X中断机制使用存储器写请求TLP向处理器提交中断请求,下文为简便起见将传递MSI/MSI-X中断消息的存储器写报文简称为MSI/MSI-X报文。 与MSI中断机制相比,MSI-X中断机制更为合理。本章将首先介绍MSI/MSI-X Capability结构,之后分别以PowerPC处理器和x86处理器为例介绍MSIMSI-X中断机制。 MSI/MSI-X Capability结构 PCIe设备可以使用MSI或者MSI-X报文向处理器提交中断请求,但是对于某个具体的PCIe设备,可能仅支持一种报文。 MSI中断机制最多只能使用32个中断向量,而MSI-X可以使用更多的中断向量。目前Intel的许多PCIe设备支持MSI-X中断机制。与MSI中断机制相比,MSI-X机制更为合理。

    1.3K20

    PCI Express 系列连载篇(二十五)MSIMSI-X中断机制 II

    中断机制,包括PowerPC处理器如何处理MSI中断请求(MSI中断机制使用的寄存器、系统软件如何初始化PCIe设备的MSI Capability结构)相关内容。 MSIMSI-X中断机制 + ? PowerPC处理器如何处理MSI中断请求 PowerPC处理器使用OpenPIC中断控制器或者MPIC中断控制器,处理外部中断请求。 本节将MPC8572处理器为例说明MSI机制的处理过程,在第二十六篇介绍x86处理器如何实现MSI机制。 使用MPIC中断控制器处理MSI中断时,PCIe设备的MSI报文,其目的地址为MPIC中断控制器的MSIIR寄存器。 系统软件完成这些设置后,将置MSI Cabalibities结构的MSI Enable位有效,使能该PCIe设备的MSI机制。

    66520

    PCI Express 系列连载篇(二十七)MSIMSI-X中断机制小结及系列完结篇

    最近有很多大侠在交流群里讨论PCI总线,PCI作为高速接口之一,在当下的FPGA产品设计研发中,地位举足轻重,应用广泛,今天给大侠带来PCI Express 系列连载第二十七篇,也是本系列的最后一篇,包括MSIMSI-X中断机制章节小结以及本系列心得等相关内容。 MSIMSI-X中断机制章节小结 本章详细描述了MSI/MSI-X中断机制的原理,并以PowerPC和x86两个处理器系统为例说明这两种中断机制实现机制。 而理解这些中断控制器的实现机制是进一步理解MSI/MSI-X中断机制的要点。 对此部分有兴趣的读者可以继续阅读MPIC中断控制器和APIC中断控制器的实现机制,以加深对MSI/MSI-X中断机制的理解。

    46140

    绝对干货:自定义msi安装包的执行过程

    有时候我们需要在程序中执行另一个程序的安装,这就需要我们去自定义msi安装包的执行过程。 比如我要做一个安装管理程序,可以根据用户的选择安装不同的子产品。 通过下面的调用就可以去掉msi中自带的UI: NativeMethods.MsiSetInternalUI(2, IntPtr.Zero) [DllImport("msi.dll", CharSet = 或者通过它传递我们的消息给msi,比如说告诉msi,停止安装,执行cancel操作。使用这个方法需要注意的是,当你完成安装后一定要把原来的handler设回去。否则以后执行msi安装包可能会出问题。 在安装进行的过程中可以把cancel信息传递给MsiProgressHandler,当MsiProgressHandler检测到cancel信息后通过返回值告诉msi的执行引擎,执行cancel操作(msi 如果要安装多个msi只需在Install方法中循环就可以了。  总结一下,通过调用几个windows API,我们可以实现对msi安装过程的控制。

    1.1K90

    常用软件打包类型及静默安装参数(nsis|msi|InstallShield|Inno)

    其它格式的文件参考下面的内容: 现在常用的制作安装程序的软件有:Microsoft Windows Installer,Windows 补丁包,InstallShield,InstallShield with MSI 一、Microsoft Windows Installer 如果软件是用 Windows Installer 打包的,可以在文件夹中看到 *.msi 后缀的文件。 例如:安装虚拟光驱 DaemonTools:msiexec /i dtools.msi /qb REBOOT=SUPPRESS 二、Windows 补丁包 有两种情况,一种是类似 IE 增量补丁包,要使之静默安装 四、InstallShield with MSI InstallShield with MSI 制作的安装文件,请使用类似:setup.exe /s /v "/qb" 来安装。 声明:本文由w3h5原创,转载请注明出处:《常用软件打包类型及静默安装参数(nsis|msi|InstallShield|Inno)》 https://www.w3h5.com/post/429.html

    6.7K10

    关注

    腾讯云开发者公众号
    10元无门槛代金券
    洞察腾讯核心技术
    剖析业界实践案例
    腾讯云开发者公众号二维码

    相关产品

    • 代码签名证书

      代码签名证书

      腾讯云代码签名证书(CSC)提供各平台程序的签名服务,标识软件或代码的来源以及软件开发者的真实身份,同时保证软件不被恶意篡改。签名后的软件,在下载安装时不会弹出安全警告,用户能够有效的辨别该软件的可信度,从而建立良好的软件品牌信誉度。

    相关资讯

    热门标签

    活动推荐

    扫码关注腾讯云开发者

    领取腾讯云代金券