压缩编码采用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视频记录系统,实现了系统的高度集成。对压缩卡、控制单元和电源部分等分别设计成模块,统一插装在底板上并锁紧,可以方便地拔插和维修。本系统结构紧凑,使用方便,性能出色,耗能低。