当前位置:首页 > 消费电子 > 消费电子
[导读]本文介绍了一种基于嵌入式微处理器S3C2410和MPEG-4专用视频压缩芯片IME6400及大容量电子硬盘的数字录像机。讨论了系统总体设计,介绍了各功能模块及关键接口电路设计,介绍了linux下驱动程序及应用程序的设计与实现。

【摘 要】 本文介绍了一种基于嵌入式微处理器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

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

摘要:给出了基于物联网技术设计的一种智能家居系统。该系统通过ZigBee技术将各种安防设备和家用电器组建成无线通信网络,以实现无线数据采集和命令控制;同时使用ARM9高性能处理器S3C2410作为嵌入式网关和网络服务器,...

关键字: Zigbee S3C2410 GPRS 物联网 智能家居

Android11系统原定于今年6月发布,但已被Google推迟。 9月9日凌晨,Android11正式发布,它还具有很多新功能,可以为用户添加一些新功能和游戏玩法。 让我们看一下Android 11中的新功能。

关键字: android11 录像机 airdrop

录像机添加摄像机提示‘网络不可达’问题形成原因分析

关键字: 录像机

导读:本文介绍的一种S3C2410路由器的整体结构及工作原理,后详细地介绍了其i/o和UART及存储介质三部分功能的具体实现,达到设计S3C2410路由器的目的.在ARM技术不断发展成熟

关键字: 路由器 S3C2410 端口 GP

还记得小鬼当家中萌萌的主角,笨笨的贼吗?那个时代录像机曾非常流行—将电视节目录制下来,以后再想看就拿出录像带细细回味。就在最近,索尼终于宣告这种录像机的“死刑”。上世纪70年代,索尼推...

关键字: 录像机 索尼 BETA 亚马逊

1 引言SD卡( Secure DigitalMemory Card)是一种基于Flash的新一代存储器,它着重数据存储的安全、容量和性能,是许多便携式电子产品如数码相机、手提电话, PDA 等理想的

关键字: S3C2410 SD存储 SD卡 控器

数字内容的爆炸式增长大大推动了数字家庭对于以磁盘为基础的存储需求。个人录像机(PVR)或者个人计算机(PC)随机内置的单个驱动器已经不能满足消费者的要求。因此,这就刺激了

关键字: 存储空间 数字存储 录像机 数字家庭

对于一个显示设备,数据的更新率正比于画面的像素数和色彩深度的乘积。在嵌入式Linux系统中,受处理器资源配置和运算能力的制约,当使用大分辨率显示时(如在一些屏幕尺寸较

关键字: 调色板 S3C2410 嵌入式LINUX RGB

介绍了一种嵌入式高图像质量的MPEC-4视频流解码系统。该系统以嵌入式Linux作为操作系统,采用硬解码方式,把IDE接口设备或网络端口输入的MPEC-4视频码流(ES、PS和TS)转换成

关键字: 嵌入式 解码系统 MPEG-4 Flash
关闭
关闭