当前位置:首页 > EDA > 电子设计自动化
[导读]TS流的CRC译码器设计 潘家顶,杨光杰 (桂林理工大学信息科学与工程学院,广西 桂林 541004) 摘要:TS流是数字电视信号传输的主要方式,由于其采用的是广播方式且信道中存在着许多干扰,因此是不可靠传输。为了保证

摘要:TS流是数字电视信号传输的主要方式,由于其采用的是广播方式且信道中存在着许多干扰,因此是不可靠传输。为了保证数据的正确性,一般需要进行信道编码。在发送端,TS流中通常采用的信道编码方式是CRC校验;在接收端进行译码。由于TS流数据量非常大,通常的软件译码方法不能满足要求。设计了一个基于FPGA的CRC译码器,速度快,并且具有很强的实时性。
关键词:FPGA;TS流;CRC校验;译码器

0 引言
    随着我国数字电视发展的越来越快,集成度越来越高,数据传输的正确性也变得越来越重要。而TS流作为数字电视传输的主要方式,其信号的正确性将直接影响到电视画面的质量以及各种数字电视业务的发展,如互联网等。为了保证传输的可靠性,就要对数据加上CRC校验码,接收的时候对其进行译码。当前的译码大多是在微处理器上用软件来实现的,这样的软件译码方式速度比较慢,无法满足高速大容量的的数字电视信道的要求。本文设计了一个基于FPGA的CRC译码器,通过查找表法进行译码,能够达到很高的速度,具有很强的实时性。

1 TS流的结构
   
传送流(Transport Stream,TS流),它是根据ITU-T Rec.H.222.0 | ISO/IEC 13818-2和ISO/IEC13818-3协议而定义的一种数据流,其目的是为了在有可能发生严重错误的情况下进行一道或多道程序编码数据的传送和存储。传送流由一道或多道节目组成,每道节目由一个或多个原始流和一些其他流复合在一起,包括视频流、音频流、节目特殊信息流(PSI)和其他数据包。TS流是数字电视信号的主要传输形式,TS流由许多的TS包组成,每个TS包的长度为188 B,它由包头、自适应区、数据区三个部分组成,其中,每个TS包的有效信息占184 B,字节后面是4 B的CRC校验码。其结构如图1所示。



2 系统总体设计
   
本系统采用了Altera公司的低成本低功耗的CycloneⅣ系列的EP4CE6E22C8N芯片,此芯片具有6 272个LE,还有270 KB的内部存储器,非常适合用来做CRC校验。本系统采用了Verilog语言在FPGA上实现了UART的收发和CRC校验的功能。
    TS包的数据由串口发送至FPGA,在FPGA内进行CRC校验,当一个section的数据校验完之后,又由UART发送出去。总体框图如图2所示。



3 UART设计
    UART的程序采用了自顶向下的分模块设计方法,其功能模块主要分为波特率产生模块、起始位检测模块、发送模块和接收模块四部分。各个模块分别编写好并且仿真通过之后,再在顶层对其进行例化,使各个模块能够连接起来。
3.1 波特率产生模块
   
设计采用的波特率为9 600 b/s,帧格式为1 b起始位,8 b数据位,无奇偶校验位,1 b停止位。波特率的产生主要是使用累加的方法,当累加到一定值的时候,就给clk_bps一个时钟的高电平,从而产生波特率。产生波特率的部分代码如下:
   
    波特率产生的RTL视图如图3所示。


3.2 起始位检测模块
   
起始位是UART传输数据的开始,因此起始位检测的好坏至关重要,本设计采用了边沿检测技术来检测起始位,当起始位的那个下降沿到来的时候,H2L_sig端口就会产生一个时钟周期的高电平,为下面的接收做好准备,起始位检测的部分代码如下:
   
    起始位的RTL视图如图4所示。


3.3 发送模块
   
发送模块主要功能就是将FIFO里8 b的数据按9 600 b/s波特率一位一位地发送出去,最后再加上停止位,其RTL视图如图5所示。


3.4 接收模块
   
接收模块的主要功能就是检测到起始位后再在每个数据的中央位置进行采样,接收完一帧数据后就放到接收FIFO里供CRC校验模块使用,其RTL视图如图6所示。



4 CRC校验
    CRC校验有两种方法:一种是按位来计算的,一种是按字节来计算的。按位来计算的占用FPGA逻辑资源比较少,但是相对来说速度会比较慢,不能适应高速的TS流的要求。按字节来运算的速度快,但是占用FPGA的逻辑资源多。综合考虑后,这里使用按字节的算法。
    本设计的CRC算法采用直驱动表法,由于一个字节只有8 b,与生成项进行异或后最多有256个结果,先将256个待查表的值生成MIF文件,放入由FPGA的IP核生成的ROM里,然后用查表法可以达到很快的运算速度,具有很强的实时性。其具体算法如下:
    crc_reg<=crctab[crc_reg[31:24]^buffer[7:0]&8'hff]^{crc_reg[23:0],8'h0};
    图7是用model sire对CRC进行仿真的结果使用的是PSI表里的一个section的数据,可以看到,校验到最后的时候,crc_reg的值变为了0,说明数据是正确的。


    只要在接收FIFO里有数据,CRC模块就会将读取数据进行CRC校验。而每个PSI表里都有一个section_length是记录在这个表里面从该字节之后有多个字节是有效数据的。所以,要将这个数据提取出来再加上3就得到了整个表的长度。在CRC校验的时候,也要设置一个计数器,用于记录处理多少个数据,并与section_length比较。若这两个数相同,则判断CRC寄存器里的值;若为0,则说明这个数据段是正确的,通过串口发0x00给上位机;若CRC寄存器不为0,则说明这个数据断是错误的,FPGA发送0x01给上位机。
    CRC校验处理的流程图如图8所示。



5 结论
   
本系统经过实际验证具有很高的准确性和实时性,并且在上位机和FPGA上都进行了校验,可以验证是否数据在串口传输的过程发生了错误,其FPGA部分可以当作一个独立的模块加入到其他系统中,具有很强的实时性。

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

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭