首页
|
新闻
|
新品
|
文库
|
方案
|
视频
|
下载
|
商城
|
开发板
|
数据中心
|
座谈新版
|
培训
|
工具
|
博客
|
论坛
|
百科
|
GEC
|
活动
|
主题月
|
电子展
注册
登录
论坛
博客
搜索
帮助
导航
默认风格
uchome
discuz6
GreenM
»
DSP技术
» 基于OMAP5912手持多媒体终端的人机接口实现
返回列表
回复
发帖
发新话题
发布投票
发布悬赏
发布辩论
发布活动
发布视频
发布商品
基于OMAP5912手持多媒体终端的人机接口实现
发短消息
加为好友
520503
当前离线
UID
872339
帖子
13270
精华
0
积分
6635
阅读权限
90
在线时间
361 小时
注册时间
2012-3-2
最后登录
2016-3-10
论坛元老
UID
872339
1
#
打印
字体大小:
t
T
520503
发表于 2016-3-8 16:40
|
只看该作者
基于OMAP5912手持多媒体终端的人机接口实现
多媒体
,
接口
手持多媒体终端以其高渗透力的移动数字媒体方式、全新的业务理念和巨大的市场潜力而倍受关注,已成为世界各国广播和电信产业积极研究和发展的重要领域。手持多媒体终端具有高集成度、低功耗以及使用灵活等优点,故可广泛运用于各种领域。手持多媒体终端对人机接口的设计也越来越人性化、多元化。本系统之所以选用 OMAP5912微处理器,除了它具有低功耗、高性能的特性外,其丰富的外圈接口可提供对各种人机接口的支持,也是其重要因素之一。
1 LCD显示设计
1.1接口框架
本终端设计中包含的人机接口为键盘、触摸屏以及LCD显示屏,图1所示是其接口结构框架。在下面的章节中将对各功能模块分别进行介绍。
1.2 LCD控制器
本设计中的LCD控制器的内部结构如图2所示。图中,VSYNC信号是垂直同步信号(也称帧同步信号),用来指示新的一帧图像的开始;HSYNC信号是水平同步信号(或行同步信号),用来给出新的一行扫描信号的开始:Ac-bias为使能信号。本控制器中每行的点阵数和行数均可编程,并可分别由寄存器 timing 0和timing 1来控制。本系统选用的TFT为samsung的LTV350QV_FOE,它采用320×240像素液晶输出方式。
1.3 LCD的驱动实现
帧缓冲设备属于字符设备,其目的是通过配置寄存器在一段制定的内存与LCD间建立一个自动传输通道。这样,任何程序只要修改这段内存中的数据,就可改变LCD上的显示内容。帧缓冲设备驱动也采用“文件层-驱动层”的接口方式。
framebuffer驱动的最重要结构体就是fb_info,它记录了帧缓冲设备,即当前显卡的全部信息,包括设备的参数、状态以及操作函数指针等。每一个帧缓冲设备都必须对应一个这样的结构体。
帧缓冲设备对应的设备文件为/dev/fb*。如果系统有多个显卡,Linux还可支持多个帧缓冲设备,最多可达32个,分别为/dev/fb0~/dev/fb31,而/dev/fb则为当前缺省的帧缓冲设备,通常指向/dev/fb0。当然,在嵌入式系统中,通常支持一个显示设备就够了。帧缓冲设备为标准字符设备,主设备号为29,次设备号为0到31,分别对应/dev/fb0~/dev/fb31。因此,显示模块加载过程中通常包含以下几个步骤:
(1)分配dma地址;
(2)初始化结构体;
(3)初始化硬件,配置相应寄存器;
(4)申请中断;
(5)注册frame buffer设备。
在文件层次上,Linux为其定义了读操作、写操作、映射操作、打开操作和关闭操作等,其定义代码如下:
file_operations 结构中的open()和release()操作不需底层支持,而read、write接口和普通的字符驱动没什么不同,只是读写的对象变为 framebuffer。是纯粹的内存操作。由于Linux工作在保护模式,每个应用程序都有自己的虚拟地址空间,而在应用程序中不能直接访问物理缓冲区地址,为此,linux在文件操作file_operations结构中提供了mmap函数,通常可将文件的内容映射到用户空间。而对于帧缓冲设备,则可通过映射操作将屏幕缓冲区的物理地址映射到用户空间的一段虚拟地址中,之后,用户就可通过读写这段虚拟地址来访问屏幕缓冲区。实际上,使用帧缓冲设备的应用程序都是通过映射操作来显示图形。
2触摸屏输入设计
2.1触摸屏芯片ADS7843
ADS7843是 TI公司生产的四线电阻触摸屏转换接口芯片。它是一款具有同步串行接口的12位取样模数转换器。其中引脚X+、Y+、X-、Y-是转换器模拟输入端;DCLK是外部时钟输入;CS是片选端;DIN是串行输入,控制数据可通过该引脚输入;DOUT是串行数据输出,可用于输出转换后的触摸位置数据;IN3、IN4是辅助输入
ENIRQ是PEN中断引脚。
本设计主要通过MCSI接口来实现与ADS7843的命令、数据的串行输入输出,并通过KB.C引脚复用成GPIO,然后实现PENIRQ与BUSY信号的中断触发。图3所示是ADS7843连接到OMAP5912的接口电路图。
收藏
分享
评分
回复
引用
订阅
TOP
返回列表
电商论坛
Pine A64
资料下载
方案分享
FAQ
行业应用
消费电子
便携式设备
医疗电子
汽车电子
工业控制
热门技术
智能可穿戴
3D打印
智能家居
综合设计
示波器技术
存储器
电子制造
计算机和外设
软件开发
分立器件
传感器技术
无源元件
资料共享
PCB综合技术
综合技术交流
EDA
MCU 单片机技术
ST MCU
Freescale MCU
NXP MCU
新唐 MCU
MIPS
X86
ARM
PowerPC
DSP技术
嵌入式技术
FPGA/CPLD可编程逻辑
模拟电路
数字电路
富士通半导体FRAM 铁电存储器“免费样片”使用心得
电源与功率管理
LED技术
测试测量
通信技术
3G
无线技术
微波在线
综合交流区
职场驿站
活动专区
在线座谈交流区
紧缺人才培训课程交流区
意见和建议