PCIE协议-2-事务层规范-MEM/IO/CFG request rules

2.2.7 内存、I/O和配置请求规则

以下规则适用于所有内存、I/O和配置请求。每种类型的请求还有特定的额外规则。

  • 所有内存、I/O和配置请求除了常见的头标字段外,还包括以下字段:
  • requester ID[15:0]和Tag[9:0],形成事务ID。
  • Last DW BE[3:0] and First DW BE[3:0]。对于设置了TH位的内存读取请求和原子操作请求,头标中Last DW BE[3:0] and First DW BE[3:0]的字节位置被重新用于携带ST[7.0]字段。对于设置了TH位的原子操作请求,DW字节使能位的值被认为是保留的。对于清除了TH位的原子操作请求,DW字节使能位是保留的。

对于内存请求,以下规则适用:

  • 内存请求通过地址进行路由,使用64位或32位寻址(见图2-17和图2-18)。

  • 对于内存读取请求,长度不得超过Max_Read_Request_Size指定的值。

  • 对于原子操作请求,表2-12中指定了架构操作数大小及其关联的长度字段值。如果完成器支持原子操作,以下规则适用:完成器必须检查长度字段值,如果该值与架构值不匹配,完成器必须将TLP视为畸形TLP。否则,如果该值与完成器支持的操作数大小不匹配,完成器必须将TLP视为不支持的请求(UR)。这是一个与接收端口相关联的报告错误。

  • 一个FetchAdd请求包含一个操作数,即"add"值。

  • 一个Swap请求包含一个操作数,即"swap"值”。

  • 一个CAS请求包含两个操作数。数据区域中的第一个是“compare”值,第二个是“swap”值。

  • 对于原子操作请求,地址必须与操作数大小自然对齐。完成器必须检查此规则的违规情况,如果TLP违反此规则,则该TLP是一个畸形TLP。这是一个与接收端口相关联的报告错误。

  • 请求不能指定会导致内存空间访问跨越4-KB边界的地址/长度组合。

  1. 接收器可以可选地检查此规则的违规情况。如果实现此检查的接收器确定TLP违反此规则,则该TLP是一个畸形TLP。

    • 如果进行了检查,这是与接收端口相关联的报告错误。
  2. 对于原子操作请求,完成器必须强制检查地址的自然对齐(见上文),已经保证了访问不会跨越4-KB边界,因此不需要单独的4-KB边界检查。
  3. 如果对原子操作CAS请求执行了4-KB边界检查,此检查必须理解TLP长度值是基于两个操作数的大小,而对内存空间的访问是基于一个操作数的大小。

对于I/O(输入/输出)请求,适用以下规则:

  • I/O请求通过地址路由,使用32位寻址(见图2-19)。
  • I/O请求有以下限制:
    • TC[2:0] 必须是 000b(二进制)
    • LN 对于I/O请求不适用,该位是保留的
    • TH 对于I/O请求不适用,该位是保留的
    • Attr[2] 是保留的
    • Attr[1:0] 必须是 00b(二进制)
    • AT[1:0] 必须是 00b(二进制)。接收方不要求或鼓励检查这一点。
    • Length[9:0] 必须是 00 0000 0001b(二进制)
    • Last DW BE[3.0] 必须是 0000b(二进制)

接收方可以选择性检查这些规则的违规情况(但不得检查保留位)。这些检查是独立可选的。如果执行这些检查的接收方确定事务层包(TLP)违反了这些规则,该TLP就是畸形TLP。

  • 如果进行了检查,这是一个与接收端口相关联的报告错误。

对于配置请求,适用以下规则:

  • 配置请求通过ID路由,并使用3个DW的头标。
  • 除了所有内存、I/O和配置请求中包含的头标字段以及ID路由字段,配置请求还包含以下额外字段(见图2-20):
    • register number[5:0]
    • extended register number[3:0]
  • 配置请求有以下限制:
    • TC[2:0] 必须是 000b(二进制)
    • LN 对于配置请求不适用,该位是保留的
    • TH 对于配置请求不适用,该位是保留的
    • Attr[2] 是保留的
    • Attr[1:0] 必须是 00b(二进制)
    • AT[1:0] 必须是 00b(二进制)。接收方不需要或鼓励检查这一点。
    • Length[9:0] 必须是 00 0000 0001b(二进制)
    • Last DW BE[3:0] 必须是 0000b(二进制)
  • 接收方可以选择性检查这些规则的违规情况(但不得检查保留位)。这些检查是独立可选的。如果执行这些检查的接收方确定事务层包(TLP)违反了这些规则,该TLP就是畸形TLP。
  • 如果进行了检查,这是一个与接收端口相关联的报告错误。

 MSI/MSI-X 机制使用内存写请求来表示中断消息。用于 MSI/MSI-X 事务的请求格式与上面定义的内存写请求格式相同,并且就排序、流量控制和数据完整性而言,MSI/MSIX 请求与内存写入无法区分。

2.2.7.1 TPH 规则

为 TPH 指定了两种格式。所有提供 TPH 的请求都必须使用基准 TPH 格式(见图 2-22 和图 2-23)。带有可选 TPH TLP 前缀的格式扩展了 TPH 字段(见图 2-21),以提供 Steering Tag (ST) 字段的额外位。

可选的 TPH TLP 前缀用于扩展 TPH 字段。 通过decode byte0 来确定是否存在 TPH TLP 前缀。

对于目标为内存空间的请求,TH 位为 1b 表示 TLP 头标和可选的 TPH TLP 前缀(如果存在)中存在 TPH。

  • 对于提供 TPH 的请求,必须设置 TH 位。
  • 针对具有 TPH TLP 前缀的请求,必须设置 TH 位。 
  • 当 TH 位清零时,PH(处理提示)字段是保留的。
  • 对于所有其他请求,TH 位和 PH 字段都不适用,并且是保留的。
  • 处理提示(PH)字段的映射在图 2-22、图 2-23 和表 2-14 中显示。

PH[1:0] 字段提供了有关数据访问模式的信息,并如表 2-15 中所述所定义。 

转向标签(ST)字段映射到 TLP 头标,如图 2-24、图 2-25 和表 2-16 所示。 

  • ST[7:0] 字段携带转向标签值
    • 所有位都是零的值表示没有转向标签偏好
    • 提供了总共255个唯一的转向标签值

对于不支持 TPH(Translation Process Hierarchy)完成或路由能力的功能,如果接收到设置了 TH 位的事务,则必须忽略 TH 位,并以与未设置 TH 位的相同事务类型的请求相同的方式处理该请求。

 

 

 

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

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

相关文章

ICode国际青少年编程竞赛- Python-2级训练场-列表遍历

ICode国际青少年编程竞赛- Python-2级训练场-列表遍历 1、 for i in range(3):Flyer[i].step(2) Dev.step(6)2、 for i in range(7):Flyer[i].step() Dev.step(Item.x - Dev.x)3、 for i in range(3):Flyer[i].step(1) Dev.step(4) Dev.turnLeft() Dev.step(2) Dev.turnL…

【APM】在Kubernetes中搭建OpenTelemetry+Loki+Tempo+Grafana链路追踪(一)

文章目录 1、最终效果2、前提准备2、环境信息3、服务集成(Opentelemetry ->Tempo)3.1 上报链路数据3.1.1 下载opentelemetry-agent3.1.2 启动配置业务app3.1.3 配置opentelemetry输入输出3.1.4 配置grafana datasource3.1.4.1 配置tempo3.1.4.2 配置l…

快速判断出485从站设备是否支持MODBUS RTU无线通讯

对于变频器和仪表设备,都支持485串口通讯,那么怎么判断从站设备支持那种协议呢?通常分为两种方式去判断:1.从设备参数参看2.从设备通讯报文查看。本次文章以以台达MH300系列变频器为例。 1.从设备通讯参数查看 使用设备之前一定…

资料如何打印更省钱

在日常工作和学习中,我们经常需要打印各种资料。然而,随着打印成本的不断提高,如何更省钱地打印资料成为了大家关注的焦点。今天,就为大家分享一些资料打印的省钱技巧,并推荐一个省钱又省心的打印平台。 首先&#xff…

【话题】软件开发的航海图:程序员的实用神器探秘

大家好,我是全栈小5,欢迎阅读小5的系列文章,这是《话题》系列文章 目录 背景一、代码编写二、版本控制三、测试与调试四、部署与运维五、总结文章推荐 背景 在软件开发的广阔海洋中,每一位程序员都是一位勇敢的航海家&#xff0c…

数据结构-栈的讲解

栈的概念及结构 栈:一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。 进行数据插入和删除操作的一端称为栈顶,另一端称为栈底(因为先进后出)。栈中的数据元素遵守后进先出LIFO(Last In Firs…

学习注意力机制并将其应用到网络中

什么是注意力机制 注意力机制的核心重点就是让网络关注到它更需要关注的地方。 当我们使用卷积神经网络去处理图片的时候,我们会更希望卷积神经网络去注意应该注意的地方,而不是什么都关注,我们不可能手动去调节需要注意的地方,…

证明力引导算法forceatlas2为什么不是启发式算法

一、基本概念 吸引力 F a ( n i ) ∑ n j ∈ N c t d ( n i ) ω i , j d E ( n i , n j ) V i , j \displaystyle \bm{F}_a(n_i) \sum_{n_j \in \mathcal{N}_{ctd}(n_i)} \omega_{i,j} \; d_E(n_i,n_j) \bm{V}_{i,j} Fa​(ni​)nj​∈Nctd​(ni​)∑​ωi,j​dE​(ni​,nj​…

class常量池、运行时常量池和字符串常量池的关系

类常量池、运行时常量池和字符串常量池这三种常量池,在Java中扮演着不同但又相互关联的角色。理解它们之间的关系,有助于深入理解Java虚拟机(JVM)的内部工作机制,尤其是在类加载、内存分配和字符串处理方面。 类常量池…

NeurIPS‘24 截稿日期逼近 加拿大温哥华邀你共赴盛会

会议之眼 快讯 第38届NeurIPS24(Conference and Workshop on Neural Information Processing Systems)即神经信息处理系统研讨会将于 2024 年 12月9日-15日在加拿大温哥华会议中心举行! NeurIPS 每一年都是全球AI领域的一场盛宴,吸引着来自世界各地的顶…

5.10.8 Transformer in Transformer

Transformer iN Transformer (TNT)。具体来说,我们将局部补丁(例如,1616)视为“视觉句子”,并将它们进一步划分为更小的补丁(例如,44)作为“视觉单词”。每个单词的注意力将与给定视…

信号和槽基本概念

🐌博主主页:🐌​倔强的大蜗牛🐌​ 📚专栏分类:QT❤️感谢大家点赞👍收藏⭐评论✍️ 目录 一、概述 二、信号的本质 三、槽的本质 一、概述 在 Qt 中,用户和控件的每次交互过程称…

Bootloader+升级方案

随着设备的功能越来越强大,系统也越来越复杂,产品升级也成为了开发过程不可或缺的一道程序。在工程应用中,如何在不更改硬件的前提下通过软件的方式实现产品升级。通过Bootloader来实现固件的升级是一种极好的方式,Bootloader是单…

I2CKD : INTRA- AND INTER-CLASS KNOWLEDGE DISTILLATION FOR SEMANTIC SEGMENTATION

摘要 本文提出了一种新的针对图像语义分割的知识蒸馏方法,称为类内和类间知识蒸馏(I2CKD)。该方法的重点是在教师(繁琐模型)和学生(紧凑模型)的中间层之间捕获和传递知识。对于知识提取&#x…

12个乒乓球,有一个次品,不知轻重,用一台无砝码天平称三次,找出次品,告知轻重?

前言 B站上看到个视频:为什么有人不认可清北的学生大多是智商高的? 然后试了下,发现我真菜 自己的思路(失败) 三次称重要获取到12个乒乓球中那个是次品,我想着将12个小球编号,分为四组,每组…

yo!这里是socket网络编程相关介绍

目录 前言 基本概念 源ip&&目的ip 源端口号&&目的端口号 udp&&tcp初识 socket编程 网络字节序 socket常见接口 socket bind listen accept connect 地址转换函数 字符串转in_addr in_addr转字符串 套接字读写函数 recvfrom&&a…

Java入门基础学习笔记2——JDK的选择下载安装

搭建Java的开发环境: Java的产品叫JDK(Java Development Kit: Java开发者工具包),必须安装JDK才能使用Java。 JDK的发展史: LTS:Long-term Support:长期支持版。指的Java会对这些版…

pycharm报错Process finished with exit code -1073740791 (0xC0000409)

pycharm报错Process finished with exit code -1073740791 (0xC0000409) 各种垃圾文章(包括chatgpt产生的垃圾文章),没有给出具体的解决办法。 解决办法就是把具体报错信息显示出来,然后再去查。 勾选 然后再运行就能把错误显示…

MetaRTC-play拉流客户端代码分析

渲染使用opengl,音频播放使用alsa。 当点击播放按钮后,以此调用的类如下,开始建立rtc连接,AV解码,音频渲染,视频渲染。 如果想去除QT,改为cmake工程管理,去掉渲染部分即可。 下方是…

Linux---vim编辑器(续写)

5. vim正常模式命令集 插入模式 按「i」切换进入插入模式「insert mode」, 按“i”进入插入模式后是从光标当前位置开始输入文件; 按「a」进入插入模式后,是从目前光标所在位置的下一个位置开始输入文字; 按「o」进入插入模式…