PCIE系统标准体系结构解读(四):体系结构概述之处理层数据包

1.4.1 TLP 的结构

通用 TLP 头的格式:下图展示了一个 3DW 头的格式内容。


头字段头位置字段用途

Lenth[9:0]字节3的7:0

字节2的1:0

TLP 数据有效载荷的传送大小,以DW为单位,最大为 1024 DW。编码:00 0000 0001b = 1DW;00 0000 0010b = 2DW;…;11 1111 1111b = 1023DW;00 0000 0000b = 1024W

Attr字节2的比特5:4bit5:灵活的顺序,设置为1时,对于此TLP,允许使用PCI-X的灵活顺序。设置为0,则使用PCI的严格顺序。

bit4:不侦测,设置为1时,表明请求者对于此TLP不存在主机缓存一致性的问题。引起处理器缓存侦测一致性不需要系统硬件,设置为0时,要求进行PCI类型的缓存侦测保护

EP(中毒数据)字节2的比特6设置为1时,尽管允许正常完成事务,但伴随此数据应该是被认为时无效的

TD(摘要字段存在)字节2的比特7如果设置为1,可选的一个双字的TLP摘要字段要包含在TLP中,而且该TLP包含ECRC值。

TC(流量类别)[2:0]字节1的比特6:4000b=流量类别0(默认)

111b=流量类别7

Tpye[4:0](类型)字节0 的比特4:0编码此TLP使用的事务变体。类型字段和Fmt[1:0]字段用来指定事务的类型、头的大小、数据有效载荷是否存在等。

Fmt[1:0](格式)字节0的比特6:5编码有关头大小以及数据有效载荷是否该TLP的一部分等信息:00b-3DW头,没有数据;01b-4DW,没有数据;10b-3DW头,有数据;11b-4DW头,有数据

第一个DW字节允许字节7的比特3:0这4个比特一对一映射到有效载荷第一个双字中的各字节。

比特3=1:第一个双字中的字节3有效,否则无效;

比特2=1:第一个双字中的字节2有效,否则无效;

比特1=1:第一个双字中的字节1有效,否则无效;

比特0=1:第一个双字中的字节0有效,否则无效。

最后一个DW字节允许字节7的比特7:4这4个比特一对一映射到有效载荷最后一个双字中的各字节。

比特3=1:最后一个双字中的字节3有效,否则无效;

比特2=1:最后一个双字中的字节2有效,否则无效;

比特1=1:最后一个双字中的字节1有效,否则无效;

比特0=1:最后一个双字中的字节0有效,否则无效。

1.4.2 头类型/格式字段的编码


1.4.3 事务描述符字段


1.4.4 IO 请求


字段名头字节/比特用途

Lenth[9:0]字节3的比特7:0

字节2的比特1:0

DW为单位,数据有效载荷的大小。对于IO请求,这个字段总为1。

Attr[1:0]字节2的比特5:4属性1:灵活的顺序比特

属性0:不侦测比特

IO请求中,总为0

EP字节2的比特6为1时表明数据有效载荷中毒

TD字节2的比特7如果为1,表明存在摘要字段(1DW)

TC[2:0]字节2的比特6:4数据包的传送类别。IO请求,TC=0

Type[4:0]字节0的比特4:0TLP数据包的类型字段。对于IO请求总设置为00010b

Fmt[1:0]字节0的比特6:500b-IO读;10b-IO写

Byte count[3:0]字节7的比特3:0第一个双字的字节允许,对于IO请求,任意的比特组合都有效

Byte count[7:4]字节7的比特7:4最后一个双字的字节允许,对于IO请求,这些比特必须为0000b

标记[7:0]字节6的比特7:0这些比特用来标识请求者发出的每一个未完成的请求,如果发送的是非报告请求,则分配下一个连续的标志。默认情况:只使用比特4:0;如果控制寄存器中的扩展标记比特置1,则可以使用全部8个比特

Requester ID[15:0]字节5的比特7:0;字节4的比特7:0识别请求者,以便返回完成数据包等。

字节4-7:0:总线号

字节5-7:3:设备号

字节5-2:0:功能号

Address[31:2]字节8的比特7:2;字节7,6,5,的比特7:0IO传送的32比特起始地址的高30比特。最低两位保留(00b),强制起始地址为DW对齐

1.4.5 存储器请求

PCIe 存储器事务包括两大类:读请求/完成和写请求。当请求存储器数据传送时,决不允许存储器事务跨 4KB 边界。

3DW 和 4DW 头之间的差别在于起始地址字段的位置和大小:对于 3DW 头,地址比特 31:2 在字节 8~11 中,字节 12 ~ 15 没用。对于 4DW 头,地址比特 31:2 在字节12 ~ 15 中,地址比特 63:32 在字节8~11 中。

 4DW 存储器请求头字段

字段名头字节/比特功能

长度[9:0]字节3的比特7:0

字节2的比特1:0

TLP 数据有效载荷传送大小

属性字节2的比特5:4bit5:灵活的顺序

bit4:不侦测

EP字节2的比特6中毒数据

TD(摘要)字节2的比特7设置为1时,一个可选的双字摘要字段包含在此TLP中

TC字节1的比特6:4000b-流量类别0

111b-流量类别7

类型[4:0]字节0的比特4:0类别字段

00000b-存储器读或写

00001b-存储器读锁定

格式[1:0]字节0的比特6:500b-3DW存储器读

10b-3DW存储器写

01b-4DW存储器读

11b-4DW存储器写

第一个DW BE[3:0]字节7的比特3:0 

最后一个DW BE[3:0]字节7的比特7:4 

标记7:0字节6的比特7:0 

请求者ID[15:0]字节5的比特7:0

字节4的比特7:0

字节4-7:0:总线号

字节5-7:3:设备号

字节5-2:0:功能号

地址[31:2]字节15的比特7:2

字节14的比特7:0

字节13的比特7:0


地址[63:32]字节11的比特7:2

字节10的比特7:0

字节9的比特7:0

字节8的比特7:0



1.4.6 配置请求

字段名头字节/比特功能

长度[9:0]字节3的比特7:0

字节2的比特1:0

这一字段总为1

属性[1:0]字节2的比特5:4bit5:灵活的顺序

bit4:不侦测

EP字节2的比特6中毒数据

TD(摘要)字节2的比特7设置为1时,一个可选的双字摘要字段包含在此TLP中

TC字节1的比特6:4TC=0

类型[4:0]字节0的比特4:0类别字段

00100b-类型0配置请求

00101b-类型1配置请求

格式[1:0]字节0的比特6:500b-3DW配置读

10b-3DW配置写

第一个DW BE[3:0]字节7的比特3:0 

最后一个DW BE[3:0]字节7的比特7:40000b

标记7:0字节6的比特7:0 

请求者ID[15:0]字节5的比特7:0

字节4的比特7:0

字节4-7:0:总线号

字节5-7:3:设备号

字节5-2:0:功能号

寄存器数号字节11的比特7:2配置空间偏移量的低6比特

扩展寄存器数号字节10比特3:0配置空间偏移量的高端4比特

完成者ID[15:0]字节9的比特7:0

字节8的比特7:0

字节8-7:0:总线号

字节9-7:3:设备号

字节9-2:0:功能号


1.4.7 完成

完成在以下每个非报告事务请求后返回:存储器读请求可能导致带数据的完成;IO读请求可能导致带或不带数据的完成;IO写请求可能导致没有数据的完成;配置读请求可能导致带数据的完成;配置写请求可能到时没有数据的完成。

字段名头字节/比特功能

长度[9:0]字节3的比特7:0

字节2的比特1:0

这一字段总为1

属性[1:0]字节2的比特5:4bit5:灵活的顺序

bit4:不侦测

EP字节2的比特6中毒数据

TD(摘要)字节2的比特7设置为1时,一个可选的双字摘要字段包含在此TLP中

TC字节1的比特6:4TC=0

类型[4:0]字节0的比特4:0类别字段

00100b-类型0配置请求

00101b-类型1配置请求

格式[1:0]字节0的比特6:500b-3DW配置读

10b-3DW配置写

字节计数字节7的比特7:0

字节6的比特3:0

读请求结束之前的剩余字节数。

BCM(修改的字节计数)字节6的比特4只能由PCI-X完成者设置为1。表示字节数字段能够反映第一次传输的有效载荷,而不是剩余的总有效载荷。

CS[2:0](完成者状况代码)字节6的比特7:5由完成者对这些比特编码表示成功实现请求。

000b-成功完成SC

001b-不支持的请求UR

010b-配置请求重试状态CR,S

100b-完成者终止CA

完成者ID[15:0]字节5比特7:0

字节4比特7:0

标识完成者。尽管路由完成数据包不需要这一信息,但在调试总线流量时,这一信息可能非常有用。

字节4-7:0:完成者总线号

字节5-7:3:完成者设备号

字节5-2:0:完成者的功能号

低地址[6:0]字节11比特6:0一次读操作返回数据的第一个允许字节的地址的地段7比特。可以由请求数据包中的长度和字节允许来计算,常用来确定下以合法读完成的边界。

标记[7:0]字节10波特7:0设置这些比特以反映接收的请求标记,请求者使用这一字段将入站的完成数据包与未完成的请求关联起来。

请求者ID[15:0]字节9的比特7:0

字节8的比特7:0

从请求中复制此字段,用来路由完成数据包返回原请求者。

字节4-7:0:请求者总线号

字节5-7:3:请求者设备号

字节5-2:0:请求者功能号


1.4.8 消息请求

消息请求可以代替早期总线协议使用的中断、错误和电源管理等边带信号。所有消息请求都使用 4DW 头格式,并且处理消息请求的过程与处理存储器写事务基本相同。消息可以使用地址、ID或隐式路由方法来路由。数据包头中的路由子字段表示应用的路由方法,以及另外在使用哪些头寄存器。


字段名头字节/比特功能

长度[9:0]字节3的比特7:0

字节2的比特1:0

这一字段总为0或1

属性[1:0]字节2的比特5:4bit5:灵活的顺序

bit4:不侦测

EP字节2的比特6中毒数据

TD(摘要)字节2的比特7设置为1时,一个可选的双字摘要字段包含在此TLP中

TC字节1的比特6:4TC=0

类型[4:0]字节0的比特4:0类别字段

bit4:3-10b=Msg

bit2:0(消息路由子字段)

000b-路由至根联合体

001b-根据地址路由

010b-根据ID路由

011b-根联合体广播Msg

100b-本地,终止于接收器

101b-收集/路由至根联合体

其它-保留

格式[1:0]字节0的比特6:501b-没有数据的消息请求

11b-带数据的消息请求

消息代码[7:0]字节7的比特7:0这一字段含有表明要发送的消息类型的编码

0000 0000b-解除锁定消息

0001 xxxb-电源管理消息

0010 0xxxb-INTx消息

0011 00xxb-出错消息

0100 0000b-热插拔消息

0101 0000b-插槽电源消息

0111 111xb-厂商类型0消息

0111 1111b-厂商类型1消息

标记7:0字节6的比特7:0所有消息请求都是非报告请求,没有分配表肌比特,这些比特都是0

请求者ID[15:0]字节5的比特7:0

字节4的比特7:0

标识发送消息的请求者。

字节4-7:0:请求者总线号

字节5-7:3:请求者设备号

字节5-2:0:请求者功能号

地址[31:2]字节11的比特7:2

字节10的比特7:0

字节9的比特7:0

字节8的比特7:0

如果选择地址路由,则此字段含有起始地址的低32比特,否则不使用此字段

地址[63:32]字节15的比特7:0

字节14的比特7:0

字节13的比特7:0

字节12的比特7:0

如果选择地址路由,则此字段含有起始地址的高32比特,否则不使用此字段

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,335评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,895评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,766评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,918评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,042评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,169评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,219评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,976评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,393评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,711评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,876评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,562评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,193评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,903评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,699评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,764评论 2 351

推荐阅读更多精彩内容