当前位置:首页 > 嵌入式 > 嵌入式软件
[导读]一种嵌入式视频记录系统的设计与实现

20世纪90年代以来数字多媒体技术取得了飞速的发展和广泛的应用,超大规模集成电路及专用视频压缩处理芯片随之迅速发展,同时随着半导体存储技术的发展,半导体存储器的容量也越来越大,这为研制数字化的音视频记录系统提供了有力的技术基础。同时数字化的记录方法将视频数据经过压缩记录在大容量的半导体存储器上,能有效消除噪声、加快拷贝和复制速度,快速回放和查找,同时还可以通过计算机网络进行传送,与传统的磁带式记录系统相比有着巨大的优势。基于此,作者设计实现了一种基于嵌入式控制模块DIMM-PC/520IU和专用视频处理芯片SZ1510硬件平台的MPEG-1编码标准的数字视频记录系统,该系统集成度高、功耗低、体积小、成本低,适合大量的各类视频监控和记录应用。

1 系统框架及原理说明

本系统选用的主要模块是主控单元DIMM-PC/520IU[1]和视频压缩芯片SZ1510,周围外部设备有视频解码芯片SAA7113H,音频分频器MK2703,音频解码芯片AK4550, RAM芯片,ROM芯片,IDE硬盘和电源模块。系统总体框图如图1所示。系统加电后[2],主控单元DIMM-PC调用程序,对视频压缩芯片SZ1510和视频解码芯片SAA7113H、音频解码芯片AK4550进行初始化配置;模拟视频信号传送给视频解码芯片SAA7113H进行解码,生成CCIR视频信号,AK4550采集输入的模拟音频信号,生成PCM数字音频流,分别送入压缩编码芯片SZ1510,压缩成MPEG-1格式的视频流,主控单元DINMM-PC将其以文件形式存储到IDE硬盘。为解决音视频同步问题,音视频同步采用视频源的同步信号锁定音频编码系统时钟的方式。芯片SAA7713的LLC管脚输出27MHz时钟,经分频器驱动,一路未分频信号校准SZ1510的系统时钟,另一路经过分频器MK2703作为音频编码输出系统时钟。该27MHz信号在SZ1510内部倍频至54MHz对输入的音视频数据进行同步。

2         MPEG-1压缩算法的基本原理

MPEG-1视频压缩技术是针对运动图像的数据压缩技术[3]。为了提高压缩比,帧内图像数据压缩和帧间数据压缩技术必须同时使用。帧内算法与JPEG压缩算法大致相同,采用基于DCT的变换编码技术,用于减少空域冗余信息。帧间压缩算法,采用预测法和插补法,预测法有因果预测器(纯的预测编码),和非因果预测即插补编码。预测误差可再通过DCT变换编码处理,进一步压缩。帧间编码技术可减少时间轴方向的冗余信息。从而在上述几个方面达到了对图像冗余信息的高效压缩。MPEG-1视频压缩的基本原理如图2所示。

图2  MPEG-1压缩的基本原理框图

3 硬件设计

3.1 控制模块设计

系统控制模块我们选择了Kontron公司DIMM-PC/520IU,采用AM5x86TM CPU,具有16KB 片内一级缓存,芯片组是ElanTM SC520集成,运行频率133MHz,工作电压为5V电压,支持DOS、Linux、WinCE、Vxworks等多种操作系统,存储温度为-40℃~80℃,工作温度0℃~60℃。DIMM-PC的所有模板使用了一种通用的DIMM-144内存插座作为连接件,采用144线的金手指连接方式,其CPU模板和扩展模板的插座略有区别,以防插错,几个扩展模板间没有区别,可以随便接插就象ISA插槽一样。CPU模板144接线分为几类ISA总线信号SD[0:15]、SA[0:19]数据地址信号;IOW、IOR、SMEMR等各种读写控制信号,OSC、SYSCLK、DRQ、DACK等特别功能信号,包含了标准ISA总线上的所有数据信号。

3.2 视频音频编解码模块设计

视频解码器采用Philips公司的SAA7113H,是一种从模拟到数字转换的9位视频输入处理器(VIP)[4],它是能与MPEG-1编码芯片SZ1510实现无缝接口的视频解码器之一。它由两通道的模拟预处理电路组成,包括源选择、自动钳位电路与ADC、自动增益控制、时钟产生电路、数字多标准解码器、亮度、对比度、饱和度控制电路和一个色度空间矩阵。解码器是基于行锁定时钟解码原理,能解码PAL和NTSC的色度信号为CCIR-601的颜色分量值。SAA7113H对输入的视频进行采样,解码后生成8 bit/像素的CCIR-601数字视频流,其电路由I2C总线控制[5]。音频解码器采用AK4550,它对模拟音频进行高信噪比16bit数字采样,生成PCM数字音频流。[!--empirenews.page--]

压缩编码采用Zapex公司的视频压缩芯片SZ1510,它是一个实时MPEG-1和运动JPEG图像编码器,内置TI的TMS320C54XDSP,协调完成芯片功能,性能优异。工作频率外部为27MHZ,内部(逻辑)为81MHZ,可配置到94.5MHZ。内核工作电压1.8V,I/O口可以驱动3.3V。采用0.18UM CMOS4LM技术设计,消耗功率仅为0.2W;144IQFP封装。整个芯片内部可以分为6个非常灵活的功能模块,分别是视频接口,视频编码器核心,DSP辅助系统,存储器接口,主设备及串行接口和DMA控制器,相互连接成为一个大的可变的模块化整体。

4 软件设计

由于DOS不支持视频压缩,因而本系统采用Windows操作系统及VC++进行开发。首先在普通PC机上设计程序,再利用U盘将设计程序在DIMM-PC上进行调试。在系统启动时[6],主控计算机首先对压缩卡进行初始化,当设置好MPEG-1压缩格式及数据速率后,压缩卡开始工作,并在主控计算机的控制下将压缩后的图像数据写入硬盘。在工作过程中,主控计算机还将不断监视相关信号,并在图像中加入相应的标志,直到接收到关机信号,系统自动结束压缩卡的工作,并关闭主机。

4.1  系统自检

系统启动后,将依据硬件的器件号与厂商号找到压缩卡,得到总线器件号,由此得到系统BIOS分配给器件的地址。压缩卡自检信息包括卡硬件自检和视频信号源自检,即压缩卡有无故障以及在压缩卡无故障的情况下输入有无视频源。如果自检到该卡无视频信号源则不对该卡的输出数据进行存储。如果压缩卡有故障或未插压缩卡,系统BIOS就不会为压缩卡分配总线器件号,依据事先正常工作条件下得到的总线器件号就可以判断哪一块卡出现故障或该卡没有插入正确。自检信息在地面通电检查时通过串口送至地面检测设备,以便故障定位和维修。

4.2 硬件初始化

4.2.1 SZ1510的初始化

SZ1510共有128个寄存器,每个寄存器有一个索引号。但外界对这些寄存器的访问都是通过IOAR(I/O Adress Register)和IODR(I/O Data Register)来完成的。如果向SZ1510某个寄存器写数据。则首先将这个寄存器的索引号写入IOAR,然后将要写的数据写入IODR,则SZ1510将自动把数据送到某个寄存器。

SZ1510的初始化如下:

(1) 上电后,主机向SZ1510中断使能寄存器写入0x40使能Ready中断。

(2) 主机等候SZ1510的Ready中断。

(3) 等到Ready中断后,主机清除该中断并向SZ1510的0x6E寄存器写入0x0A,配置它内部的DSP时钟为94.5MHZ。

(4) 主机向0x013寄存器写入0x55,对SZ1510进行软复位。

(5) 主机向中断使能寄存器0x0C写入0x40使能Ready中断。

(6) 主机等候RDY中断。

(7) 等到Ready中断,则进行SAA7113的初始化。

(8) SZ1510进行软复位,即向0x0B寄存器写入0x55,0x0C寄存器写0x40。

(9) 等待Ready中断,等到则进行SZ1510的内部DSP二进制代码装载。

(10) 进行SZ1510内部视频压缩核的二进制代码装载。

4.2.2 SAA7113的初始化

SAA7113初始化的步骤如下:

(1) 装载0x280-0x2BF 64个块共16k的二进制代码。

(2) SAA7113寄存器配置,流程如下:

·I2C任务的初始化:分别向寄存器0x2E写0x01,0x0C写0x80,0x11写0x05,0x08写0x04,0x0C写0x80,0x08写0xC2

·I2C写操作:向0x42寄存器写SAA7113设备号0x4A,0x43寄存器写要写的数据索引号(又叫子地址),0x44寄存器写本次I2C写操作要写入数据的长度(一次最多能写11个数据)。

·向0x08命令寄存器写0xC0,等待DSP中断。

·重复以上的操作直到SAA7113的寄存器配置完毕。

4.2.3 SZ1510二进制代码的装载

SZ1510用内部的程序空间来装载二进制代码。这段空间是按块(Blank)为单位,每块的大小是256字节。

用于SAA7113的程序空间是0x280-0x2BF共64块。所以共有16k字节二进制代码要装载。用于DSP的程序空间块是0x10F-0x113,0x13A-0x13B,0x280-0x2BF共71个块,约18k字节代码要装载。其中0x280-0x2BF与SAA7113相重合,所以SAA7113的二进制代码装载要先于SZ1510的DSP装载,且在SAA7113的二进制代码装载后要进行SZ1510的复位。否则SAA7113的代码装载将不起作用。

用于视频编码核的二进制代码的装载空间为0x000-0x004,0x00c-0x00c六个块,共1.5k字节代码

4.2.4 SZ1510视频数据的获取

SZ1510内部有一个256字节的FIFO。一旦这个FIFO达到门限时,即产生一个FIFO Ready中断,通知主机读取FIFO中的数据(通过256次读Data_out寄存器来完成)。所以读取FIFO中视频数据要放到中断的下部去完成。

5 结论

该视频记录系统已经完成了测试工作,已在某型飞机上投入使用,作为某型飞机的机载视频记录系统,运行稳定可靠,取得较好的效果。项目经济效益(200万元)。可长时间实时记录采集到的音视频信号,采用1.5G硬盘,可连续录制3小时,随着半导体存储器容量的不断增长,系统的记录时间还将进一步延长。正常工作情况下,程序启动首先检查磁盘空间,删除最早记录的文件,文件存储方法采用盘满循环存储,当剩余空间不满足条件时,将覆盖最早的文件。

作者的创新:

设计并实现了基于嵌入式控制模块DIMM-PC/520IU和专用视频处理芯片SZ1510硬件平台的MPEG-1视频记录系统,实现了系统的高度集成。对压缩卡、控制单元和电源部分等分别设计成模块,统一插装在底板上并锁紧,可以方便地拔插和维修。本系统结构紧凑,使用方便,性能出色,耗能低。

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

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 信息技术
关闭
关闭