新闻中心

EEPW首页 > 嵌入式系统 > 设计应用 > 基于Linux的虚拟试妆系统设计

基于Linux的虚拟试妆系统设计

作者:时间:2011-09-01来源:网络收藏

随着社会的进步,人们对自身形象愈加重视,化妆成为女性一门必修课。如何选择合适的化妆品对于不少女性来说是一项难题。近几年针对该问题提出了多种试妆解决方案。包括通过浏览器进行本地与远程服务器交互方案及使用Visual C++开发上位机软件[1]等。
以Altera公司的SoPC技术和操作为基础,了一款嵌入式试妆。该在SD卡中存储信息,通过摄像头采集用户面部图像,用户可通过触摸屏浏览、选择商品对影像进行上妆,并查看试妆效果,最终达到选购化妆品的目的。系统具有体积小巧、方便易用等特点,适合于各种商场的化妆品柜台。
1 系统总体结构
系统以DE2-70为核心板,外接PS2键盘录入信息,通过扩展口分别接入LTM触摸屏和D5M 500万像素摄像头。为使用操作系统,构建了带MMU的Nios II处理器的SoPC。通过SDRAM运行内核和RAM文件系统,使用SSRAM作为显示缓存,将硬件编程代码烧入EPCS,而将压缩的内核、文件系统与引导代码一起烧入Flash。系统采用Altera大学计划IP中的PS2 Controller和Video IPs分别管理PS2接口和触摸屏的显示部分,自行编写硬件模块实现触摸屏的配置、摄像头采集和SSRAM多路复用。此外,系统还使用SPI模式管理SD/MMC卡以及第三方IP管理网络物理芯片。系统结构框图如图1所示。
2 系统硬件
2.1 运行的最小系统搭建

Linux操作系统对SoPC系统的构建有特殊要求,包括带MMU处理器设置、全功能定时器启用、通信终端设定等。表1总结了Linux系统所需要添加的SoPC组件以及关键设置[2]。
2.2 影像采集和存储方案设计
图2所示为本系统使用的影像采集和存储方案。在SoPC系统外,通过Cam_CFG_CAP模块配置和采集摄像头数据,经由SSRAM_WRITE模块合成指定格式数据并生成SSRAM写时序送入SSRAM_2PORT进行仲裁;SSRAM_2PORT既接收SSRAM_WRITE的数据写入SSRAM的指定区域,又允许SSRAM Controller访问SSRAM获取相应数据。

本文引用地址:http://www.eepw.com.cn/article/150272.htm

(1)SSRAM_WRITE
该模块分别提取Cam_CFG_CAP传入RGB分量的高5、6、5 bit数据,拼接成16 bit数据,读入两个像素合成32 bit,同时生成对应的21 bit SSRAM地址,将其传递给SSRAM_2PORT。
(2)SSRAM_2PORT
该模块对来自SoPC系统的SSRAM控制器和SSRAM_WRITE的读写请求做出仲裁。在CPU读请求有效期间,SSRAM_2PORT模块读取SSRAM中的数据发送给Avalon总线;超出读请求有效期则接收SSRAM_WRITE模块图像数据写入SSRAM。在该模块中添加两个DCFIFO分别作为实时图像数据及其对应地址的缓冲空间,实现不同时钟域的数据同步。
3 系统软件设计
3.1 开发包修改及内核配置

系统采用NiosWiki社区发布的nios2-linux-20090929.tar内核开发包作为软件开发基础。SoPC系统构建好后,通过“sopc-create-header-files --single custom_fpga.h”生成自定义硬件对应的C语言头文件,将该文件拷贝到“nios-linux/linux-2.6/arch/nios/include/asm/”路径中。开发包通过custom_fpga.h和nios.h两个文件中的宏定义管理SoPC组件与Linux内核驱动代码对设备的映射,同时通过config.c文件内置了大量设备的驱动支持,由内核配置生成的config.h文件和nios.h以及custom_fpga.h共同控制。图3所示为这三个文件之间的关系。

linux操作系统文章专题:linux操作系统详解(linux不再难懂)

上一页 1 2 下一页

评论


相关推荐

技术专区

关闭