当前位置:首页 > 通信技术 > 通信技术
[导读]摘要:循环冗余(CRC)是USB协议中重要的错误检测措施。在此分析了USB 3.0数据包的基奉格式以及USB 3.0协议中CRC校验的特点,针对USB 3.0数据高速传输的要求,设计实现并行发送端CRC产生和接收端CRC校验电路,功能仿

摘要:循环冗余(CRC)是USB协议中重要的错误检测措施。在此分析了USB 3.0数据包的基奉格式以及USB 3.0协议中CRC校验的特点,针对USB 3.0数据高速传输的要求,设计实现并行发送端CRC产生和接收端CRC校验电路,功能仿真结果证明了其有效性。
关键词:USB 3.0;CRC校验;Verilog HDL代码;仿真结果

    在通用串行总线(USB)的数据传输过程中,数据循环冗余校验(CRC)是为了保证数据传输中数据的正确性而采用的数据保护方法。USB 3.0协议中为了检测和减少这类错误,一方面提供了一系列硬件和软件措施,以保证数据传输的正确性;另一方面在每个包中加入检测位来发现这些瞬时的错误。协议中对每个包的控制位和数据位提供了循环冗余校验,若出现了循环冗余码的错误,则认为该包已经损坏。
    本文介绍了USB 3.0设备控制器中的协议层在数据收发时,如何采用并行电路来完成数据包发送时CRC码的产生和接收时CRC码的校验,并行处理方法与常用的串行处理相比,极大地降低了功耗和电路综合的难度。

1 USB 3.0中的CRC校验
    USB 3.0协议规定了4种类型的包:链路管理包(LMP),传输包(TP),数据包(DP)和同步时间戳包(ITP)。链路管理包(LMP)只遍历直接连接的端口,主要用于管理该连接。传输包遍历主机和设备路径中的所有链路,用来控制数据包流,配置设备和集线器等,传输包没有数据部分。数据包遍历主机和设备路径中的所有连接。同步时间戳包是一个多播数据包,由主机发送到所有激活的连接。
    USB对所有传输数据的保护采用了CRC校验和数据重传的方式。当通过检错码判断错数据包错误时,发送端通过重发来达到纠错的目的。  USB 3.0数据包由数据包头(DPH)和数据包有效载荷(DPP)两部分组成,DPH类似于一个传输包,DPP中有一个32位CRC(CRC-32),可以确保数据的完整性。数据包以16 B的数据包头开始(有的包只有包头没有数据部分),包头含了如何处理该包的信息。一个完整的USB 3.0数据包的格式如图1所示。


    在数据包头(DPH)中,有一个长度为2字节16位的CRC校验码对数据包头的12个字节信息进行保护。在数据部分(DPP)中,包含最大1 024 B的数据,有一个长度为4 B 32 b的CRC校验码对数据部分进行保护。另外,在数据包头中,有2 B的链接控制字(Link Control Word),其中长度为5位的CRC用来对链接控制字中其他的11位信息进行保护,格式如图2所示。


    在USB 3.0协议中,CRC校验有以下特点:
    (1)在发送端,CRC校验在初始状态时将余数寄存器的值置为全1,如果没有这样的预设置,就不能正确地保护数据包开始为0的数据位。在接收端,也同样将移位寄存器预设为全1状态,以保证接收到的被除数加上一个相同的常数,如果数据传输无误,则余数产生器应该得到相同的余数。
    (2)采用了3种类型的CRC校验:5位、16位和32位CRC校验。5位CRC校验采用的生成多项式为;G(X)=X5+X2+1,如果准确无误地接收到数据,接收端的5位余数应该是01100;16位CRC校验采用的生成多项式为:G(X)=X16+X15+X2+1,接收端的16位余数应该是10000000000001101;32位CRC校验采用的生成多项式为:G(X)=X26+X23+X22+X16+X12+X11+X10+X8+X7汁X5+X4+X2+X1+1,接收端中的32位余数应该是32’HC704DD 7B。
    (3)发送端对输入的数据作除法运算后,将所得到的余数按位取反,取反后的余数放在待发送数据的高位,组成了新的数据流。接收端CRC校验采用与CRC产生相同的算法来实现,只是作为输入数据的是原始的被除数数据和对应的CRC校验码组成的新数据流。如果接收端的余数与(2)的要求一致,则说明接收端准确无误地接收到了数据。

2 并行CRC校验的设计
    在USB 3.0协议中,数据最高传输速率高达5 Gb/s,串行方法无法满足实时性要求。本文中,CRC校验采用的是并行设计方法。
    在USB 3.0协议中,数据收发是以字节为单位来传输的,所以在发送端和接收端可以通过一个8位移位寄存器将串行数据转换成字节表示形式,然后再对数据进行并行的CRC码产生和校验。


    以链接控制字中的5位CRC为例,发送端并行CRC产生的设计结构如图3所示。计数器用于产生标志信号,计数值为8时串并转换结束。数据暂存寄存器获取字节数据,经组合逻辑计算后产生新的校验寄存器值。并行CRC5的余数多项式表达式如下:

    在接收端,按照和发送端同样的电路,对发送端产生的CRC校验码和输入的数据一并进行CRC校验,如果接收端成功接收,最后得到的CRC校验码为常数(01100)。

3 仿真结果
    发送端和接收端的并行CRC产生和校验设计用Verilog HDL实现,用ModelSim工具进行仿真,发送端并行CRC产生和接收端CRC校验的仿真波形分别如图4和图5所示。在发送端,每输入8个数进行一个并行的CRC5计算,crc_d寄存器的值随发送的数不断更新,直到最后产生一个余数,在接收端将该余数和发送端的数一并进行CRC5校验,最后CRC得到一个常数值01100。



4 结语
    虽然并行方法在电路规模上比申行算法大,但是能够在单位时间内完成更多位数据的校验,可以有效降低电路的工作频率,硬件实现也较容易。USB 3.0数据的最高传输速率高达5 Gb/s,采用并行CRC校验设计完成USB 3.0数据传输中CRC码的产生和校验。可使高速USB串行接口引擎电路方便地与UTMI接口。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

本文介绍一款小尺寸、功能强大、低噪声的单芯片同步升压转换器。文章重点介绍了该集成电路的多个特性。这些特性能够增强电路性能,并支持定制,以满足各种应用的要求。

关键字: 升压转换器 集成电路 电路

武汉2025年9月9日 /美通社/ -- 7月24日,2025慧聪跨业品牌巡展——湖北•武汉站在武汉中南花园酒店隆重举办!本次巡展由慧聪安防网、慧聪物联网、慧聪音响灯光网、慧聪LED屏网、慧聪教育网联合主办,吸引了安防、...

关键字: AI 希捷 BSP 平板

上海2025年9月9日 /美通社/ -- 9月8日,移远通信宣布,其自研蓝牙协议栈DynaBlue率先通过蓝牙技术联盟(SIG)BQB 6.1标准认证。作为移远深耕短距离通信...

关键字: 蓝牙协议栈 移远通信 COM BSP

上海2025年9月9日 /美通社/ -- 为全面落实党中央、国务院和上海市委、市政府关于加快发展人力资源服务业的决策部署,更好发挥人力资源服务业赋能百业作用,8月29日,以"AI智领 HR智链 静候你来&quo...

关键字: 智能体 AI BSP 人工智能

北京2025年9月8日 /美通社/ -- 近日,易生支付与一汽出行达成合作,为其自主研发的"旗驭车管"车辆运营管理平台提供全流程支付通道及技术支持。此次合作不仅提升了平台对百余家企业客户的运营管理效率...

关键字: 一汽 智能化 BSP SAAS

深圳2025年9月8日 /美通社/ -- 晶泰科技(2228.HK)今日宣布,由其助力智擎生技制药(PharmaEngine, Inc.)发现的新一代PRMT5抑制剂PEP0...

关键字: 泰科 AI MT BSP

上海2025年9月5日 /美通社/ -- 由上海市经济和信息化委员会、上海市发展和改革委员会、上海市商务委员会、上海市教育委员会、上海市科学技术委员会指导,东浩兰生(集团)有限公司主办,东浩兰生会展集团上海工业商务展览有...

关键字: 电子 BSP 芯片 自动驾驶

推进卓越制造,扩大产能并优化布局 苏州2025年9月5日 /美通社/ -- 耐世特汽车系统与苏州工业园区管委会正式签署备忘录,以设立耐世特亚太总部苏州智能制造项目。...

关键字: 智能制造 BSP 汽车系统 线控

慕尼黑和北京2025年9月4日 /美通社/ -- 宝马集团宣布,新世代首款量产车型BMW iX3将于9月5日全球首发,9月8日震撼亮相慕尼黑车展。中国专属版车型也将在年内与大家见面,2026年在国内投产。 宝马集团董事...

关键字: 宝马 慕尼黑 BSP 数字化

北京2025年9月4日 /美通社/ -- 在全球新一轮科技革命与产业变革的澎湃浪潮中,人工智能作为引领创新的核心驱动力,正以前所未有的深度与广度重塑各行业发展格局。体育领域深度融入科技变革浪潮,驶入数字化、智能化转型快车...

关键字: 人工智能 智能体 AI BSP
关闭