PCIE总线的分层协议介绍

上传人:d**** 文档编号:100602929 上传时间:2022-06-03 格式:DOCX 页数:5 大小:35.97KB
返回 下载 相关 举报
PCIE总线的分层协议介绍_第1页
第1页 / 共5页
PCIE总线的分层协议介绍_第2页
第2页 / 共5页
PCIE总线的分层协议介绍_第3页
第3页 / 共5页
亲,该文档总共5页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述
在PCIE总线中信息是以封包的形式传输的,下面为大家介绍一下数据在PCIE设备中是如何封包以及怎样传输的,这里我们将省去路由寻址、流量控制等一些细节,只介绍数据在设备中的传输过程。PCIE总线采用了串行连接方式,并使用数据包(Packet)进行数据传输,采用这种结构有效去除了在PCI总线中存在的一些边带信号,如INTx和PME等信号。在PCIE总线中,数据报文在接收和发送过程中,需要通过多个层次,包括事务层、数据链路层和物理层,才能完成数据的传输。PCIE总线的层次结构如图1所示。PCItDrvtADtvvtEDviiaCmcDtvittCettTrafisLiWITDafaLsttLave5FFt芋alLi料LdiciLSub-rtkckLl.cal$i诫曲ockEkcekiZSub-blKkEkeHialSub-NocltRXTXrxrx1c丁图1PCIE总线的层次结构在PCIE体系结构中,数据报文首先在设备的核心层(DeviceCore)中产生,然后再经过该设备的事务层仃ransactionLayer)、数据链路层(DataLinkLayer)和物理层(PhysicalLayer),最终发送出去。而接收端的数据也需要通过物理层、数据链路和事务层,并最终到达DeviceCore。下面将介绍各个层次的功能以及该层数据的封包形态,每个层次从发送端和接收端两个方面来讲:1、事务层(TransactionLayer)事务层是三层协议结构的最高层,数据在这一层组成最基本的数据包,即事务层数据包仃ransactionLayerPacket,TLP)。在发送端,当处理器或者其他PCIE设备访问PCIE设备时,事务层接收来自PCIE设备核心层的数据,并将其封装为TLP后,发向数据链路层。在接收端,事务层可以从数据链路层中接收数据报文,然后转发至PCIE设备的核心层。接收部分将入站的TLP保存在虚拟通道缓冲区中,根据TLP中的ECRC字段检查CRCt误。若无误,则删去ECRC字段,将在TLPHeader中得到的信息及数据有效载荷(DataPayload)发送给用户接口。事务层数据包(TLP)主要由一个或多个可选的TLPPrefixes、一个TLPHeader、一个DataPayload和一个可选的TLPDigest组成。TLP的组成如图2所示,每一部分的功能会在下面做简单介绍。TLPoIi|zb-TIPHeaderH-ataPayload旻(includedwtierappiicab时50J”应1-TLPOigcGt(op-liariai)图2TLP的组成TLPPrefix由PCIEV2.1总线规范引入,分为LocalTLPPrefix和EP-EPTLPPrefix两类。其中LocalTLPPrefix的主要作用是在PCIE链路的两端传递消息,而EP-EPTLPPrefix的主要作用是在发送范的一些新的功能。由于TLPPrefix是可选的,如果我们用不到,TLP中可以省去该字段。TLPHeader是TLP中最重要的标志,不同的TLP其头的定义并不相同。TLP头的大小为3个或4个DW(双字),其中的信息包含了地址、TLP类型、传送数据的长度、请求者/应答者ID、标记、流量类别、字节允许、完成代码和属性等字段。TLPHeader的通用格式(以4DW长度为例)如下图所示。S*1I321Dw-53-2FtrtF.TC玄gK弍AtrAT寸IS电鹽图3TLPHeader通用格式其中第一个DW(ByteOByte3)中的各个字段在所有的TLPHeader中定义是一样的,而后面的2-3个DW则因TLP的类型不同而有所差异。至于TLPHeader中每个字段代表的具体意义,以及不同事务类型的TLP中Header的具体形式,大家有兴趣的话可以参考附件文件,里面有详细的介绍。DataPayload,即我们要传输的数据。在一个TLP中,DataPayload的长度视数据长度而定,最小为0,最大为1024DWDataPayload也可以看做一个可选项,有些TLP并不需要DataPayload,如存储器读请求、配置和I/O写完成TLP并不需要DataPayload;而在存储器写请求、I/O写请求、配置写请求和消息请求的TLP中是带数据的,DataPayload字段要有。TLPDigest是一个可选项,长度为1DW一个TLP是否需要TLPDigest由TLPHeader中TD字段决定。如果接收设备支持ECRC校验的功能的话,贝UTLPDigest字段用来放置TLP中的数据校验码ECRC2、数据链路层(DataLinkLayer)数据链路层(DataLinkLayer)连接事务层和物理层,其主要功能是保证在各链路上发送和接受数据包时的数据完整性。数据链路层使用ACK/NAK协议保证报文的可靠传递(ACK/NAK协议:ACK(Acknowledgement)为确认应答字符,在数据通信中,当接收站确认接收的数据无误后,会发给发送站该类字符;NAK(NegativeAcknowledge)为否定应答字符,当接收站确认数据收到,但是有错误的信息,便会发送该字符,接收站收到NAK字符后,便会重发数据,直到接收站返回ACK字符,即数据传输无误)。在发送设备中,数据链路层从事务层接收TLP,接收时必须遵循流量控制机制。数据链路层接收到TLP后,生成链路CRC(LCRC和一个SequenceNumber(序列ID)并附加到TLP上。之后在该层中的重放缓冲区中保留该TLP的一个副本并将TLP发往接收设备。接收设备的数据链路层对收到的TLP进行CRC校验;如果校验无误,则向发送设备返回一个带有序列ID的ACKDLLP,发送设备在接收到ACK后,确认该TLP已成功到达接收设备,同时清空重放缓冲区中与该序列ID有关的TLP;如果校验有误,接收设备会返回一个带序列ID的NAKDLLP发送设备将重发缓冲区中与此ID相关的TLP。数据链路层在TLP上添加的序列ID和LCRC勺字段长度分别为12bit和32bit。序列ID用于将重放缓冲区中保存的出站TLP副本与入站ACK/NAKDLLF联系起来,LCRC则是根据TLP的所有字节和序列ID计算的,用于检测数据包的传输是否正确。在数据链路层中的数据封包如下所示。序列IDTLPPrefixesTLPHeaderDatapayloadECRCLCRC2BytenDW(11:Obit(n为0,1)3或4DW0一1024DW1DW1DW有效)图4数据链路层中的数据封包格式这里简单介绍一下ACK/NAKDLLPDLLP(DataLinkLayerPacket)产生于数据链路层,终止于数据链路层,并不会传递到事务层。DLLP总长度为6Byte,其类型主要由第一个字节DLLPType字段决定,最后两个字节为CRC校验码。DLLP的各种类型在PCIE3.0规范中DataLinkLayerSpecification章节中也有详细的介绍,这里只介绍一下ACK/NAKDLLP的格式,如下所示:DLLPTypeReservedAckNak_Seq_NumCRC00000000-Ack12bit12bit(同TLP序列ID)16bit00010000-Nak图5ACK/NAKDLLP3、物理层(PhysicalLayer)物理层作为PCIE总线的最底层,负责直接连接PCIE设备,它为设备的数据通信提供传送介质。物理层又可分为两部分:逻辑物理层和电气物理层。逻辑物理层包括对数据包(从数据链路层接收的TLP、DLLP以及从链路上接收的物理层数据包)进行相关的数字逻辑,电气物理层是连接物理层和链路的模拟接口,由各通道的差分驱动器和差分接收器组成。在发送设备中,来自数据链路层的TLP和DLLP被定时输入到逻辑物理层的发送缓冲区中,物理层在TLP和DLLP的前后分别添加一个帧开始和帧结尾字符。接收设备利用这两个字符检测数据包的开始和结束。此时,在物理层中TLP的数据封包格式如下。STP序列IDTLPPrefixesTLPHeaderDatapayloadECRCLCRCEND帧开始2BytenDW帧结尾1Byte(11:0bit有效)(n为0,1)3或4DW0一1024DW1DW1DW1Byte图6物理层中的TLP封包格式在发送端,待数据包处理完成后,物理层通过串/并转换器将数据转换成串行比特流,通过差分驱动器发送岀去;在接收端,物理层通过并/串转换器将串行数据转换成字节。在这里我们需要知道的是在每个Byte的传输是以低位(LSB)开始,高位(MSB结束的。下面介绍一下PCIE总线中的数据编码方式:在PCIE总线V1.x和V2.0规范中物理层中使用8/10b编码,即在PCIE链路上的10bit中含有8bit的有效数据。在8/10bit编码中,将每个Byte看成由3bits(高3位,如下图中的HGF和5bits(低5位,如图中的EDCBA两部分组成,编码后这个Byte数据则变成jhgfiedcba(需要注意的是,这里的hgfedcba已经和原字节中的HGFEDCB不一样了,在附件PCIExpressBaser3.0的附录B(SymbolEncoding)中枚举了一个字节的所有值,及其对应的10bit编码),j和i则是给每部分添加的起始位,其随Byte的值而有所不同。TransmitIMSBjTLSBV|EI5卜3|订10|Z|和bb+coMKiH.G.F.E.D.C.BA2+A1SB;IL5Bh|十卜|十|T|*3n1心HrG.F.EJaCJB.Zfill10CEncodeTOO*ciccmk|lOblhin.T.j.eacua图78/10b10WIB编码方式而在PCIEV3.0规范中使用128/130b编码方式,即在PCIE链路上的130bit中含有128bit的有效数据。在128/130b编码方式中,在128bit的开头添加了H0H1两个同步起始头,H0H1有两种有效的编码:10和01,其定义了传输的数据负载的类型。下图是128bit数据从发送端到接收端的编码及接收顺序。旳唧旳罔M5SLsa缶|亦use*LSB、卜-b十.岂訂品wseL99銅rrboWSynrtdi1,SyTI-d!5TranfltL9l+l比电创剣:LSG|勿|打|*|3.|纠刎別MSBLS8羽5订.辰号冋野區Symbdi15Ti-neOUITans-2UVTito:10uiTrw?WUIH(j旳SflS3s3厲|訂釦SDSiS2|S3SsSs|ST/1-SflSi弱创创焉兔SjLJiJn1rT*rUrtt图8128bit数据编码方式上图中的数据传输只是在x1Link的情况下,在多Link传输中,数据的传输会有所不同,简单理解的话,可以看成每个Byte里的bit是串行传输的,而DataPayload(数据负载)里的Byte是并行传输的。对于PCIE总线的分层协议介绍就到这里,由于自己只学习了其中的一小部分,所以在上面的内容写的不是很全面,如果有看不明白的地方,可以找我交流,共同学习,或者参考PCIE的规范(附件)。若有错误,还请大家指正
展开阅读全文
相关资源
相关搜索

最新文档


当前位置:首页 > 办公文档 > 活动策划


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!