当前位置:首页 > 嵌入式 > 嵌入式软件
[导读]基于S3C2410的MPEG-4数字录像机的设计与实现

【摘 要】 本文介绍了一种基于嵌入式微处理器S3C2410MPEG-4专用视频压缩芯片IME6400及大容量电子硬盘的数字录像机。讨论了系统总体设计,介绍了各功能模块及关键接口电路设计,介绍了linux下驱动程序及应用程序的设计与实现。
【关键词】 S3C2410  IME6400  MPEG-4  Linux   设备驱动

视频信息在现代信息化战争发挥日益重要的作用,在视频监控、侦察、机载或车载视频记录等方面都得到了越来越广泛应用,这种形势对数字视频监控记录设备的研制提出了新的要求:大批量的应用要求降低监控记录设备成本,多样的应用环境、分散、孤立的监控点要求监控记录设备尽可能一体化、小型化、独立、便携、低功耗、供电方便、性能可靠。针对这些新问题和新要求,笔者设计实现了一种基于嵌入式系统和MPEG-4编码标准的数字录像机,系统集成度高、体积小、功耗低、独立、便携,适合大量的各类视频监控和记录应用。

1         系统总体设计及原理

图 1

本系统选择嵌入式微处理器加专用压缩编码芯片的方案,系统电路主体框图如图1所示,主要由视音频解码芯片、视音频压缩编码芯片、核心微处理器控制模块、电源模块以及各种外部接口等组成。系统采用单一5V电源供电,正常启动后,视频、音频解码芯片SAA7114和PCM1800分别对对输入的模拟视频、音频信号进行解码,并分别送入压缩编码芯片IME6400进行压缩生成MPEG-4复合流,控制芯片S3C2410从IME6400的HOST接口接收数据并以文件的形式存储至硬盘,并完成系统的总体控制。

硬件设计

2.1  视频音频解码及压缩编码部分设计

视频A/D芯片选用Philips公司的SAA7114,该芯片支持多种输入模式,具有抗混叠滤波、自动增益变换、亮度、对比度调整等功能。通过设定SAA7114的内部的配置寄存器93H[6]为1使能其HOST端口,实现与IME6400的无缝连接。音频A/D芯片采用BURR-BROWN公司的PCM1800,它对模拟音频进行高信噪比20bit数字采样,生成PCM数字音频流。

压缩编码采用INTIME公司的MPEG-4编码芯片IME6400。该芯片是一款高性能的单片多通道MPEG-4数字压缩编码芯片,它支持多种编码模式和比特率控制,并提供了丰富的外围硬件接口。其外部HOST接口有四种模式,由MODE引脚来决定,本系统选用异步模式:MODE[1:0] pin = 11。在此模式下,IME6400对输入的视频音频流进行压缩和复合,产生MPEG-4的系统流,然后经过输出端口大小为1K的FIFO缓冲进行数据的输出,当FIFO满,其GPIO0脚就产生一个下降沿的中断通知主机读取FIFO中的数据,主机通过512次(16bit主机)读IME6400 HOST端口的EncodedStream寄存器完成数据的读取,外部主机通过写一个不同的值到USER4寄存器来通知IME6400数据传输已完成[1]

2.2  控制、接口及存储部分设计

系统控制模块选用三星的S3C2410微处理器,这是一个采用ARM920T内核,高性能、低功耗、低成本的32位微处理器[2]。为了提高设计和应用的灵活性,硬件设计上采用核心板加底板的模块化设计方法,在核心板上集成了基于S3C2410的最小系统,通过底板来扩展外部功能。在核心板上主要配置了64MB的NANDFlash 和64MB的SDRAM及提供RTC时钟和工作时钟的晶体,并将其丰富的外设接口资源引出。在底板上扩展出USB主机接口、以太网口、UART接口、IDE接口等,以实现与外部设备间的数据传输和通信。

S3C2410并不带有IDE控制模块,接口电路需另行设计,图2是IDE接口电路示意图。电路利用S3C2410的第5个BANK的片选信号nGCS4和地址信号ADD4和ADD5相或后形成IDE接口的两个片选信号nIDE_CS0、nIDE_CS1,S3C2410的读写信号nOE、nWE 则直接用于IDE接口读写信号nIOR、nIOW。该方法将IDE接口映射到了S3C2410的第5个Memory Bank中, S3C2410将IDE设备视为普通的存储器,以相同的方式访问,这大大降低了系统软件开发的复杂度[3]

  

     采用类似IDE接口的方式将IME6400的HOST接口映射到处理器的第6个Memory Bank中。系统存储部分采用体积小、抗震性好、温度范围宽的电子硬盘作为存储器。

3        软件设计

由于Linux系统具有稳定、高效、易定制、易裁减、开放源码等优点,本系统选用嵌入式Linux作为操作系统,在此系统下实现IME6400驱动程序设计和相关应用程序设计。

Linux 将设备当作文件处理,编写linux驱动程序的最主要工作就是file_operations结构中各入口点的实现,即对应于open()、release()、read()、write()、ioctrl()等系统调用子函数的编写[4]。同时本系统的设备驱动程序采用灵活性较好的动态加载方式,驱动程序还应包括模块初始化函数和模块注销函数。下面介绍几个主要函数及其功能:

l         模块初始化函数在驱动程序被加载的时候被调用,主要完成以下功能:

申请挂载总线上的视频编码芯片的实际物理地址空间并且将它映射到虚拟地址空间:

       request_region(BASE_ADDR,0x100,"IME6400")

       vbase = ioremap_nocache(BASE_ADDR,0x100)           

注册设备并获取主设备号[4]

       ret=register_chrdev(IME6400_MAJOR,"ime6400",&ime6400_fops)

设置并且申请中断及注册中断处理函数:

       set_external_irq(IRQ_EINT19, EXT_FALLING_EDGE, GPIO_PULLUP_DIS) request_irq(IRQ_EINT19, &ime6400_irq, SA_INTERRUPT,"ime6400", NULL)

注册设备文件系统:

       ime6400_devfs_dir= devfs_register(NULL,"ime6400",DEVFS_FL_DEFAULT,IME6400_MAJOR,0, S_IFCHR |S_IRUSR |S_IWUSR |S_IRGRP |S_IWGRP,&ime6400_fops, NULL)

l         OPEN函数递增模块使用计数,防止没有释放设备就把模块卸载了。

l         READ函数阻塞等待数据缓冲区满,然后把数据从内核空间复制到用户空间。

l         IOCTRL函数实现从用户空间向内核空间传递参数,用于设置IME6400工作模式。

l         中断处理函数读取IME6400输出的MPEG-4码流数据存入内核缓冲区,并通知IME6400数据读取完毕。Linux将中断处理函数分为两部分:顶半部(top half)是实际响应中断的例程,底半部(bottom half)是一个被顶半部调用在稍后安全的时间内运行的例程[5]。Linux采用Tasklet机制实现底半部处理,通过宏DECLARE_TASKLET可以声明Tasklet:

static DECLARE_TASKLET(ime_tasklet,do_tasklet,NULL),其中do_tasklet函数实际处理中断,从IME6400读取数据至内核缓冲区。通过函数tasklet_schedule()可以调度一个Tasklet运行:tasklet_schedule(&ime_tasklet) 。

本系统应用程序主要实现从驱动层接收MPEG-4码流数据并存储至硬盘,主要采用多线程编程的方式,主程序创建了读和写线程两个线程:首先,用户程序读线程调用read(),此时编码尚未开始,驱动进行ime6400_read()无数据可读,进入睡眠态,用户进程被阻塞。此后中断到来,中断处理程序从IME6400读取数据存入内核缓冲区,若缓冲区满则唤醒睡眠的ime6400_read(),并往IME6400的USER4寄存器写入一个新值,通知IME6400数据已读取完毕,启动新一轮的编码。ime6400_read()被唤醒后,将内核缓冲区数据拷贝到用户缓冲区,然后返回并等待用户进程的下一次调用。ime6400_read()返回后,用户空间读到编码数据退出阻塞状态,然后读线程以信号量通知写线程,由写线程完成将缓冲区数据存储至硬盘。

4         结束语

系统目前已完成了初步调试,可实时压缩存储最大分辨率为720x576全帧率的4:2:2的彩色视频,采用2G的电子硬盘,在720x576分辨率下可记录2小时以上,且图像质量较好。同时系统还具有较好的灵活性,可以通过设置视频图像分辨率大小、量化系数、帧率等参数,来达到对图像大小、图像质量及码率等方面的不同要求,以满足不同场合应用的需要。

本文作者创新点:设计并实现了基于ARM及嵌入式Linux平台的MPEG-4压缩记录,实现了系统的一体化、小型化、高性能、低功耗,在硬件设计上采用核心板加底板的模块化设计方法,在软件上完成了Linux系统下驱动程序的开发。

参考文献:

【1】         IME6400 firmware manual. Intime Corporation. 2003
【2】         S3C2410X 32-BIT RISC MICROPROCESSOR USER’S MANUAL. Samsung Electronics.2001
【3】         孟柯 李凤亭 马惠敏,用于视频监控的便携式数字录像机设计,电视技术,2002.7
【4】         钱晨 徐荣华 王钦若,基于linux操作系统的设备驱动程序开发,微计算机信息,2004.09, 131-133
【5】         魏永明 耿岳 钟书毅 译,Linux设备驱动程序(第三版),中国电力出版社,2006.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 信息技术
关闭
关闭