当前位置:首页 > 嵌入式 > 嵌入式硬件
[导读]  摘要:许多嵌入式系统需要支持高分辨率的LCD显示器。SM501是用来提高嵌入式系统显示能力的一款芯片。文中介绍SM501的基本架构,以及一个基于 SM501的系统设计。关键词

  摘要:许多嵌入式系统需要支持高分辨率的LCD显示器。SM501是用来提高嵌入式系统显示能力的一款芯片。文中介绍SM501的基本架构,以及一个基于 SM501的系统设计。关键词:嵌入式系统 TFT LCD 多媒体协处理器 SM501 [b]引言 [/b]近年来,从手持消费电子到工业控制系统,嵌入式处理器的应用已经深入到人们工作和生活的方方面面。在某些应用领域,系统需要提供如1 280%26;#215;1 024这类高分辨率的显示界面,而多数嵌入式处理器不能支持,或者在高分辨率下提供的显示效果不好。   通常,一个带有LCD显示器的ARM系统如图1所示。

图1 带有LCD显示器的ARM系统框图   在该系统中,ARM处理器将LCD显示器的数据存放于SDRAM中的LCD帧缓冲区中,由处理器中的LCD控制器提取LCD帧缓冲区中的数据并输送给 LCD显示器。一个LCD控制器的时钟信号有3种:FRAMESYNC (场同步)、LINESYNC(行同步)和LCD_DCLK(数据时钟)。在LCD_DCLK的作用下,LCD控制器将LCD数据信号并行输出到LCD显示器。显然,一个LCD_DCLK时钟只能输送一个像素点的数据。根据文献,TFT LCD的刷新频率一般在60 Hz,因此,一个具有M%26;#215;N像素点的LCD显示器,在1 s的时间中,要求LCD控制器传送像素点总数为(M%26;#215;N%26;#215;60),即LCD控制器的LCD_DCLK的频率必须大于(M%26;#215;N%26;#215;60) Hz,以便保证LCD显示器的正常显示。因此,嵌入式处理器芯片LCD控制器支持的最大分辨率与LCD_DCLK时钟频率有关;然而LCD_DCLK是从处理器系统的AHB总线时钟HCLK通过分频计算得出的,所以,LCD控制器支持的最大分辨率与系统HCLK有关。为确保嵌入式处理器系统处在良好的工作状态,一般不使用最大分辨率进行显示。以Samsung公司的S3C2410为例,在TFT LCD模式下,典型的实际支持的最大分辨率为640%26;#215;480。另外,受到ARM处理器LCD帧缓冲区大小的影响,在达到最大分辨率时,LCD数据的位宽度降低,这使得显示效果变差。   如何才能使嵌入式处理器应用在高分辨率的场合呢?SM501图形加速芯片的出现很好地解决了这个问题。 1 SM501图形加速芯片简介   SM501是一款便携式多媒体协处理器芯片,专门为嵌入式工业提供补充功能,具有视频和2D能力。为了降低系统的成本,它支持多种输入/输出接口,包括模拟RGB、数字LCD屏接口、8位并行接口、USB、 UART、 IrDA、 Zoom Video、 AC97或I2S、 SSP、PWM和I2C,同时它还带有GPIO,便于与外部器件连接。SM501的2D引擎包括一个前端色彩空间转换器,支持4∶1和1∶8的比例。视频引擎支持在每个像素点8位、16位或32位数据宽度时2个不同的视频输出(双显示屏),为每个视频输出提供三色硬件指针。LCD视频流水线支持一个黑点 YUV色彩空间转换,比例为4∶1和1∶212。放大视频(Zoom Video)接口包括MPEG解码或TV输入的外部电路接口。   SM501的系统框图如图2所示。

图2 SM501系统框图 2 SM501的2D图形引擎   通过将优化的128位的2D图形引擎和一个与本地帧存储器连接的高带宽链接相结合,SM501提供面向工业的2D图形加速功能。2D图形引擎也包含一个命令翻译器(一个增强型的DMA引擎),对于工作在150 MHz的32位数据宽度的SDRAM,SM501的DMA引擎读取2D操作数的带宽可达600 MB/s。这么高的存储器带宽使得2D引擎在无须等待和流水线停止工作的情况下高速运行。当它在读取和翻译命令时,命令翻译器也可以有条件地转到存储器空间的另一个地址上,等待由其他模块发送过来的状态信息。2D图形引擎同时还包含一个色彩空间转换单元。该单元允许从许多的YUV模式直接翻译到RGB模式。2D图形引擎还带有一个双线性标量器,它可以支持4∶1的压缩和1∶216的拉伸。SM501支持存储器工作在UMA和本地32位模式下。 3 SM501的LCD接口   SM501的LCD逻辑模块可以直接驱动一个18位或24位的TFT LCD显示屏;同时也支持12位的CSTN屏,通过一个颤抖引擎(dithering engine)可以得到有效的18位显示效果。支持的最大屏的大小为1 280%26;#215;1 024。通过硬件和软件可控制LCD显示屏的上电顺序。SM501与一个24位 TFT LCD显示屏的接口电路如图3所示。由图3可知,该接口电路的设计与一个嵌入式处理器和TFT LCD的接口电路的设计是相同的,因此,设计起来很方便。

图3 SM501与TFT LCD显示器的接口电路 4 具有SM501的嵌入式系统设计   一个具有SM501的嵌入式系统如图4所示。系统中ARM处理器将LCD的数据放入SDRAM的帧缓冲区中,然后将显示工作交给SM501处理。通过 2D图形引擎,SM501从SDRAM的帧缓冲区中读取数据,并将这些数据输送到LCD显示器。这样一来,LCD的数据没有经过ARM处理器的LCD控制器,因此,LCD数据的传输不受ARM处理器的HCLK时钟的影响,达到了支持高分辨率的设计要求。

图4具有SM501的嵌入式系统框图   综上所述,SM501为ARM处理器支持高分辨率显示提供了良好的解决方案。同时它还带有模拟RGB等丰富的在片资源,为ARM系统功能的进一步扩展,提供了方便. [b] 参考文献 [/b][1] Samsung公司.S3C2410数据手册. [2] Silicon motion公司. SM501数据手册. 2004.

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

在工业物联网设备部署中,Modbus通信故障是导致系统停机的首要原因之一。据统计,超过60%的现场问题源于通信配置错误或数据解析异常。本文从嵌入式系统开发视角,系统阐述Modbus通信调试的方法论,结合实际案例解析如何高...

关键字: 嵌入式系统 Modbus通信

在嵌入式系统开发中,看门狗(Watchdog Timer, WDT)是保障系统可靠性的核心组件,其初始化时机的选择直接影响系统抗干扰能力和稳定性。本文从硬件架构、软件流程、安全规范三个维度,系统分析看门狗初始化的最佳实践...

关键字: 单片机 看门狗 嵌入式系统

人工智能(AI)和机器学习(ML)是使系统能够从数据中学习、进行推理并随着时间的推移提高性能的关键技术。这些技术通常用于大型数据中心和功能强大的GPU,但在微控制器(MCU)等资源受限的器件上部署这些技术的需求也在不断增...

关键字: 嵌入式系统 人工智能 机器学习

Zephyr开源项目由Linux基金会维护,是一个针对资源受限的嵌入式设备优化的小型、可缩放、多体系结构实时操作系统(RTOS)。近年来,Zephyr RTOS在嵌入式开发中的采用度逐步增加,支持的开发板和传感器不断增加...

关键字: 嵌入式系统 软件开发 实时操作系统 Zephyr项目

在资源受限的嵌入式系统中,代码执行效率和内存占用始终是开发者需要权衡的核心问题。内联函数(inline functions)和宏(macros)作为两种常见的代码展开技术,在性能、可维护性和安全性方面表现出显著差异。本文...

关键字: 内联函数 嵌入式系统

在嵌入式系统和服务器开发中,日志系统是故障排查和运行监控的核心组件。本文基于Linux环境实现一个轻量级C语言日志库,支持DEBUG/INFO/WARN/ERROR四级日志分级,并实现按大小滚动的文件轮转机制。该设计在某...

关键字: C语言 嵌入式系统

在嵌入式系统和底层驱动开发中,C语言因其高效性和可控性成为主流选择,但缺乏原生单元测试支持成为开发痛点。本文提出一种基于宏定义和测试用例管理的轻量级单元测试框架方案,通过自定义断言宏和测试注册机制,实现无需外部依赖的嵌入...

关键字: C语言 嵌入式系统 驱动开发

在嵌入式系统与驱动开发中,内存映射I/O(Memory-Mapped I/O, MMIO)是一种将硬件寄存器映射到处理器地址空间的技术,允许开发者通过指针直接读写寄存器,实现高效、低延迟的硬件控制。本文通过C语言实战案例...

关键字: 内存映射 I/O操作 嵌入式系统

在嵌入式系统开发和多线程编程中,程序崩溃、内存越界等复杂问题常令开发者困扰。GDB作为强大的调试工具,其条件断点和内存查看功能可精准定位隐蔽缺陷。本文通过实际案例演示这些高级功能的应用,帮助开发者提升调试效率。

关键字: GDB 嵌入式系统
关闭