历史上的今天
返回首页

历史上的今天

今天是:2025年08月20日(星期三)

正在发生

2020年08月20日 | 基于FPGA器件EPXA10实现MPEG-2传输流解复用器的设计

2020-08-20 来源:elecfans

随着芯片技术的发展,FPGA的容量已经达到上百万门级,从而使FPGA成为设计的选择之一。Altera公司的FPGA芯片EPXA10应用SOPC技术,集高密度逻辑(FPGA)、存储器(SRAM)及嵌入式处理器(ARM)于单片可编程逻辑器件上,实现了RISC和FPGA的完美结合。本文使用EPXA10芯片,利用片上的ARM微处理器对MPEG-2传输流进行解码,得到必要的解码参数,实现了将传输流分成视频流和音频流的解复用。


EPAX10器件简要介绍

ALTERA公司的EPXA10器件单片集成了ARM硬核,百万门级的FPGA,以及SDRAM存储器的接口。它将FPGA和ARM处理器完美结合在一起,是一个典型的SOPC结构。


其中ARM处理器是32位的ARM922T,工作频率可以达到200MHz,具有8K的数据缓存和8K的指令缓存。通过板上的JTAG接口,可以实现断点调试功能。


片上的百万门级FPGA可用于实现用户自定义的逻辑。它通过AHB总线和ARM处理器相互连接。为了更加灵活的使用,FPGA用户自定义逻辑可以定义为主模块(master),在总线通信时处于发起端;或是定义为从模块(slave),在总线通信时处于接收端。FPGA器件内部有3M大小的存储器,同时集成了SDRAM控制器。在FPGA开发板上可以外接128M的SDRAM,为了便于内部FPGA和外部SDRAM大数据量的交换,用户还可以定义自己的DMA模块,用于访问外部SDRAM。通过UART、网卡接口、JTAG接口,FPGA可以很方便地同外部计算机通信、下载程序,及调试程序等。


MPEG-2传输流解复用原理

MPEG-2传输流简要介绍

作为数字视频压缩技术的国际通用标准,MPEG-2标准于1994年被运动图像专家组制定出来,分成系统层、视频压缩层和音频压缩层。系统层主要用来描述音、视频的数据复用和音、视频的同步方式。在系统层定义了TS(传输流)和PS(节目流)两种形式的码流。PS通常用于相对无错的环境,例如DVD中,其长度为2048字节;TS通常用于相对有错的环境,例如数字电视的地面广播传输中,分组长度规定为188字节。TS流和PS流都是由编码后的基本数据流(ES)根据一定的格式打包形成PES包,再加入一些系统信息而构成的,码流形成过程如图2所示。根据MPEG-2协议,在发送端,基本流的PES打包由音/视频编码器完成,复用器接收编码端的音、视频数据流以及辅助数据流,按照一定的复用方法将其交织成为单一的TS流。为了实现音、视频同步,在码流中还必须加入各种时间的标志和系统的控制信息。接收端和发送端正好相反。

基于FPGA器件EPXA10实现MPEG-2传输流解复用器的设计

传输流及其PSI表

传输流TS的结构长度为188字节,分成包头和包负荷两部分。包头主要包括同步字节和PID以及其他的信息,同步字节用来指示一个TS包开始(0x47),PID表示TS包的类型。例如一个节目里的音频PES包,在转换成为TS包后会具备同样的PID,这样,接收端只需要接收具有此PID的TS包,就可以将该节目的音频解出来了。包负荷是包的实际内容,根据具体情况,可以放置PES包或PSI包。传输流由一个或者多个节目构成,而每一个节目由视频流、音频流、私有信息流以及其他的数据包构成。


PSI包在传输流解复用中占据重要地位,它通过四个表格来定义码流的结构,分别是节目关联表(PAT)、节目映射表(PMT)、条件接收表(CAT)和网络信息表(NIT)。其中最为关键的部分是PAT表和PMT表。


PAT表是PSI信息的索引表,PID值固定为0。在PAT表中列出了该传输码流中所有节目的PMT表的PID值。如果接收方希望接收其中的一个节目,即可根据这个PID值解出对应于该节目的PMT表,从中可以查询到与该节目相关的所有音频流、视频流,以及私有信息的PID,在接收时就可以只接收具有这些PID值的包。


PAT表的PID值为0,根据PAT表可以得到各个节目对应的PID值,如节目0,PID=122,对应NIT网络信息表;节目1,PID=60;节目20,PID=200等。如果希望看节目20,就根据200这个PID值得到节目20对应的PMT表,再进一步查到节目20的视频、音频及私有信息包对应的PID值,分别为500、510和540。解有这些PID值的传输包就可以解出音频和视频的PES包,最终解出音频流和视频流。CAT表的PID值固定为1,用来传递加密信息,不在本文的讨论范围内。


在MPEG-2系统层解码时,需要由一个解复用器按照上述的原理对PSI表进行处理,同时将各个音、视频基本流从传输流中分离出来,送入对应的解码器中,所以解复用器在MPEG-2解码中占据重要的地位。


解复用系统的具体实现

本文设计的是DVB的SDTV系统集成解码芯片,视频解码最高支持MPEG-2的MP@ML,分辨率为720×576,实时解码;音频解码满足AC-3标准。


从前面的部分可知,解复用器需要承担将数据分流的工作,所以数据处理量相当大,很多解复用器都采用DSP或者专用ASIC进行处理。本文中,有别与以往的结构,利用EPXA10的片上ARM处理器,以及片上内嵌的SDRAM控制器和DMA控制器的特性,来实现对MPEG-2的传输流进行解复用,同时由硬件完成对PID包过滤的任务。所有的数据分解过程都由系统软件来完成,因此在数据处理方面更加灵活,保证了系统对于MPEG-2传输流解码的灵活性,同时避免了语法上的不兼容。

基于FPGA器件EPXA10实现MPEG-2传输流解复用器的设计

系统硬件由PID过滤、片上缓存及DMA等构成;系统软件部分由ARM实现。片外SDRAM用来存放数据。音/视频解码模块使用硬件实现,在本文中不涉及到相关内容。


系统硬件的功能是:当外部的8位传输流数据输入到FPGA上时,根据传输流包头进行同步,并将同步好的数据送入到PID过滤器。如果在传输过程中有错误,也就是包头中有sequence-error-code=1,就丢弃这个包;如果没有,则检查PID码表的数据,如果在码表中有这个PID值,那么就将这个传输流的包送入到FPGA的片上缓存中;否则就丢弃这个包。PID过滤器工作完成后,数据送入FPGA片上缓存部分,为了加快数据处理速度,使用DMA将缓存中的数据传输到片上SDRAM对应的传输流缓冲区。


如果片外SDRAM的传输流缓存中有未处理的包,则取出该包,判断PID的值。如果PID=0,表示当前的包是PAT,那么就对该包进行解析,根据选定的节目号,确定需要解码的PMT包的PID,再更新FPGA上PID码表中PMT的PID,并将PMT的状态位设定为需要解码。


如果PID等于PID码表中PMT包的PID,则判断PMT的状态位。如果不需要解码,就丢弃这个包;如果需要解码,则进入PMT包解析子程序,提取出该解码对应的音、视频传输流包的PID,将提取出的音、视频传输流包的PID值对FPGA片上的PID码表进行更新。


如果PID等于PID码表中的音、视频PID值,那么就进入到音/视频处理程序,对音、视频的传输流包进行解包,将解得的PES包的内容(就是实际的音、视频流)通过DMA发送到片外SDRAM的音/视频缓冲区中,供下一级的音/视频解码器完成解码功能,最终完成MPEG-2码流的解码过程。

基于FPGA器件EPXA10实现MPEG-2传输流解复用器的设计

结语

本文使用了Altera公司的一款具有ARM硬核的FPGA器件EPXA10,提出了一种基于ARM微处理器的对MPEG-2的传输流进行解复用的解复用器设计方案。根据传输流的特点,使用硬件实现了数据量操作比较大的PID包过滤、DMA传输等任务,并利用ARM处理器完成较为复杂的PAT、PMT包的解包工作,同时也将音、视频包解包,并将解出的音、视频发送到片外SDRAM上的音/视频缓冲区中。


最终设计的解复用器能对码率最高为19 Mbps的传输流进行解复用,对系统层的数据和其他辅助数据进行解码。解复用得出的视频流和音频流可供下一级的音/视频模块进行实时解码。

推荐阅读

史海拾趣

HCH Co公司的发展小趣事

背景:面对电子行业的快速变化和多元化需求,HCH Co公司意识到仅凭一己之力难以应对所有挑战。因此,公司积极寻求与其他行业的跨界合作机会,以共同推动电子行业的创新发展。

发展:通过与汽车、医疗、教育等多个行业的领军企业建立合作关系,HCH Co公司成功将自身的电子技术和产品应用于更广泛的领域。例如,与汽车制造商合作开发智能驾驶系统、与医疗机构合作研发远程医疗设备等。跨界合作不仅为公司带来了新的增长点,也促进了不同行业之间的技术交流和资源共享。未来,HCH Co公司将继续秉承开放合作的理念,与更多行业伙伴携手共创美好未来。

请注意,以上五个故事是基于假设构建的,旨在反映电子行业中企业可能的发展路径和趋势。实际情况中,“HCH Co”公司的具体发展故事可能有所不同。

Curtis Industries公司的发展小趣事

为了进一步扩大市场份额,Curtis Industries公司积极拓展市场布局。公司在全球范围内设立了多个生产基地和研发中心,以便更好地满足不同地区客户的需求。同时,公司还加强了与上下游企业的合作,形成了完整的产业链。这些举措不仅提升了公司的产能和研发实力,还为公司带来了更多的商业机会。

Hsuan Mao Technology Co公司的发展小趣事

为了进一步扩大市场份额,Curtis Industries公司积极拓展市场布局。公司在全球范围内设立了多个生产基地和研发中心,以便更好地满足不同地区客户的需求。同时,公司还加强了与上下游企业的合作,形成了完整的产业链。这些举措不仅提升了公司的产能和研发实力,还为公司带来了更多的商业机会。

Advanced Semiconductor, Inc.公司的发展小趣事

Advanced Semiconductor, Inc. (简称ASI) 成立于XXXX年,由一群热衷于半导体技术创新的工程师和科学家创立。在创立初期,ASI专注于研发高性能的半导体芯片,以满足当时市场对更快、更稳定电子产品的需求。公司凭借其独特的技术和创新的理念,很快在半导体行业中崭露头角,吸引了众多投资者的关注。

Exar [Exar Corporation]公司的发展小趣事

Exar始终注重通过收购和合并来增强自身的技术实力和市场竞争力。例如,2012年Exar收购了Integrated Memory Logic Limited(iML),这一举措加强了其在存储和数据管理领域的地位。通过收购iML,Exar获得了更多的技术资源和市场份额,为其后续的发展提供了有力支持。

AMS公司的发展小趣事

Exar公司一直注重全球布局和客户支持。公司在全球设立了多个研发基地和客户服务中心,以确保能够为客户提供及时、高效的技术支持和服务。此外,Exar还积极与全球各地的合作伙伴建立合作关系,共同推动电子行业的发展和进步。这种全球化的战略布局不仅为Exar赢得了更多的市场份额和客户信任,也为其未来的发展奠定了坚实的基础。

以上五个故事简要概述了Exar在电子行业中的重要发展历程。通过这些故事,我们可以看到Exar如何通过不断的技术创新、市场拓展和全球化战略来保持其在行业中的领先地位。

问答坊 | AI 解惑

DSP (数字信号处理) 技术: sysDSP

DSP应用方式持续扩展 随着视频和静态图像使用的增长以及软件无线电(SDR)等可重复配置系统的需求增长,数字信号处理(DSP)的应用持续扩展。许多应用将重要的DSP处理与成本因素结合在一起,产生了对高性能、低成本DSP解决方案的需求。 FPGA及通用D ...…

查看全部问答>

PCB板设计中的接地方法与技巧

PCB板设计中的接地方法与技巧 PCB设计中最重要的就是GND的接法?如何处理GND VSS等各种地 请看这里。。。。。。…

查看全部问答>

各位兄弟姐妹进来看看!

YTE xdata tempBuf2[512* 39 ]; #define        ramFatTab         (tempBuf2 + 512* 0) 我现在在一个C文件里定义上面这些,但是我现在要在一个工程的另外一个C文件里调用ramFatTab,但是如果 ...…

查看全部问答>

请问strrchr()函数如何使用

大家好,我能获取文件的整个路径\"\\\\My Document\\\\1.txt\",现在想获取文件名1.txt,请问该怎么用strrchr()函数来做?我是在win32 application中做的,请不要用mfc。谢谢了…

查看全部问答>

1、假设你需要一个类似于TCP的滑动窗口协议,该协议运行在一个100Mb/s网络上,网络的往返时间是100ms,最大段生命期为60s。请问协议头部的窗口和顺序号字段应该有多少位?为什么? 2、主机A要向主机B传送一个512KB的消息,途中要经过8个路由器。链 ...…

查看全部问答>

如何用cpld实现除法

如何用cpld实现除法…

查看全部问答>

RTC中的ALR寄存器复位时不保存,怎么回事

在RTC调试过程中,出现ALR寄存器数据复位不保存的情况,而CNT可以保存.按手册上讲,这两个寄存器都在后备域中,在未发生后备域复位的情况下,这些数据应该不保存才对啊,而现在ALR不保存,CNT却可以,这是为何??以下先贴初始化程序,后贴图,望有人能解 ...…

查看全部问答>

想了解下stm32f100c才11块,比M0还强啊

                                 f100的引脚和f103的一样是吗?code呢?…

查看全部问答>

求助:有没有SH3单片机的实例程序?

求助:有没有SH3单片机的实例程序?…

查看全部问答>

MSP430串口刚才使用出现的一个小问题

刚才运行程序发现下午明明配置好的串口不能使用,重新上电后有串口数据不稳定的情况,经过仔细排查得出结论:串口使用前,要确定所选的驱动时钟信号已经稳定,否则会产生无法预料的结果…

查看全部问答>