PCIE中TLP prefix的疑问

转载自http://hi.baidu.com/aihenry2980/item/02c2e1ef8b17c9265a2d64fd

这两天看PCI Expressspec有点疑问。实在很不解。

话说TLP里面含有TLP Prefix和TLP Header等等,顺序是TLPPrefix在前。

问题就是,TLP Prefix的长度和有无都是在Header中定义的,但是Header在后面,那我上哪儿找去啊。

不知道还有没有别的协议这么搞,把至高无上的Header放到中间去。

已经给PCISIG写信了,看下周能不能回复。


下班前跟崔责任讨论了一下,她找了点别的资料,然后俺对照着一看,就明白了。这个spec写的太误导了。

一开始spec说header里面如果前三位(fmt field)是100的话,那么前面有prefix的存在。那么prefix到底有几个不知道。

后来看了另一个pdf,才发现,原来prefix本身也有fmt field,而且里面写着100,所以寻找header的方法就是如果某个DW的第一个byte的最高三位不是100,那么这个就是header了。太坑爹了。害的我看了这么久spec不知所云。


另外我比较好奇的是,干嘛搞这么多需要判断的长度,固定下来多好,跟数据相比也就千分之一的浪费,但是电路可以简单一些,而且我看的大部分协议都是留出空位节省判断的逻辑。
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PCI Express (PCIe) TLP (Transaction Layer Packet) 是 PCI Express 协议的一个重要部分,它用于在不同的 PCIe 设备之间传输数据。PCIe TLP 由四个部分组成:头部、有效载荷、可选的可扩展有效载荷和 FCS(帧校验序列)。 具体来说,PCIe TLP 的格式如下: |---------------------------| | PCIe TLP 头部 (12 字节) | |---------------------------| | 有效载荷 (0 - 1024 字节) | |---------------------------| | 可扩展有效载荷 (0 - 1024 字节) | |---------------------------| | FCS(帧校验序列)(4 字节) | |---------------------------| PCIe TLP 头部包括以下字段: - TC(传输类别):指定 TLP 的类型,比如请求(Memory Read/Write)、Completion 等。 - TD(传输方向):指定 TLP 的传输方向,是从上游设备到下游设备还是相反。 - EP(端点):指定 TLP 的目标设备端口号。 - Length(长度):指定有效载荷的长度。 - First DW BE(第一个双字节字节 Enable):指定有效载荷的第一个双字节的哪些字节是有效的。 - Last DW BE(最后一个双字节字节 Enable):指定有效载荷的最后一个双字节的哪些字节是有效的。 - Tag(标签):可选字段,用于匹配请求和 Completion TLP。 - Requester ID(请求者 ID):可选字段,用于标识发起 TLP 的设备。 - Completer ID(完成者 ID):可选字段,用于标识处理 TLP 的设备。 PCIe TLP 的有效载荷可以是数据、地址或控制信息。可扩展有效载荷在某些情况下用于传输额外的数据或信息。FCS 是一个校验序列,用于检测传输的错误。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值