0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

使用FSMC接口来驱动8080接口LCD屏的问题

STM32单片机 来源:STM32单片机 作者:STM32单片机 2021-06-29 09:59 次阅读

前言

在一些图形界面应用中,系统架构会时常考虑使用 FSMC接口来驱动 8080接口的 LCD屏。在 MCU渲染完成,将framebuffer发送到 LCD时,有可能会遇到存儲大小端的问题。STM32MCU都采用 ARMCortex内核,内存使用小端格式。而 intel 8080接口的 LCD在传输 RGB数据时,使用的是大端格式。MCU在传输 RGB数据时,字节序有可能不匹配。在图形界面应用中,像素格式一般会使用 RGB888或 RGB565。而在使用 FSMC接口驱动 8bit位宽的 LCD时,很可能会使用 RGB565格式。本文中会介绍两种方法来处理8bit8080接口 RGB565格式图像数据字节序问题。

图像数据字节序

8bit8080 LCD在接收 RGB565数据时,会将第一个字节解析为{R4-R0,G5-G3}, 第二个字节解析为{G2-G0,B4-B0},并按这个顺序接收所有数据,如下图:

a210c732-d86f-11eb-9e57-12bb97331649.png

而在 MCU内存中,数据按小端格式存放,RGB565数据存放的字节序如下:

a26017c4-d86f-11eb-9e57-12bb97331649.png

如果不做调整直接将 RGB数据发给 LCD,MCU会先发送 Byte0,再发送 Byte 1,这样 LCD显示的内容就会错乱。对比上面两张图可以看出,只需将内存中 Byte0与 Byte1字节位置对调(Byteswap),就能满足 LCD接口的字节序要求。可以直接使用 CPU进行 Byteswap,但这会消耗过多 CPU算力,同时也会占用更多内存。这里我们将使用硬件进行 Byteswap.

DMA2D 进行Byteswap

DMA2D是 ST为图形应用专门设计并优化的2D加速引擎,拥有丰富的功能。其字节序重排功能包含了Red blueswap以及 Byteswap特性。Red blueswap特性在 L4和 L4+系列 MCU都支持,而 Byteswap仅在L4+系列有支持。在 L4+系列上,通过配置 DMA2D_OPFCCR寄存器的 SB位,即可使能 Byteswap功能,在 DMA2D的outputFIFO中完成字节序调整,如下图:

a26c2b5e-d86f-11eb-9e57-12bb97331649.png

因此在图形界面应用中,需要 Byteswap时,可以考虑用 DMA2D来传输 RGB数据给 LCD。

GPDMA 进行Byteswap

在新推出的 U5系列芯片上,集成了 GPDMA模块。这是新的通用DMA模块,能在传输数据的同时,还有丰富的数据处理能力。在初始化GPDMA时,通过配置源和目的数据位宽为 DMA_SRC_DATAWIDTH_WORD,在数据处理中配置 DataExchange为 DMA_EXCHANGE_DEST_BYTE,如下面代码,也能实现Byteswap功能。

a2754d74-d86f-11eb-9e57-12bb97331649.png

这样,在图形应用中,既能使用 DMA2D加速渲染过程,也能使用 GPDMA的数据处理能力。通过 GPDMA直接向FSMC接口输出 Byteswap后的 RGB565格式的图形数据给LCD。

小结

在驱动 8位 8080接口 LCD时,需要注意图像数据字节序问题。使用 RGB565格式时,可以使用 DMA2D或 GPDMA来传输图像数据,同时对图像数据做 Byteswap调整,满足LCD的字节序要求。

责任编辑:haq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • lcd
    lcd
    +关注

    关注

    34

    文章

    4276

    浏览量

    164050
  • 驱动
    +关注

    关注

    11

    文章

    1717

    浏览量

    84338

原文标题:工程师笔记 | 驱动 8 位 8080 接口 LCD 时的字节序问题

文章出处:【微信号:STM32_STM8_MCU,微信公众号:STM32单片机】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    如何提高SPI接口LCD的刷新频率?

    怎么样提高SPI接口LCD的刷新频率
    发表于 03-28 06:24

    具有PWM和SMBus控制接口LCD背光WLED驱动器TPS61195数据表

    电子发烧友网站提供《具有PWM和SMBus控制接口LCD背光WLED驱动器TPS61195数据表.pdf》资料免费下载
    发表于 03-13 09:14 0次下载
    具有PWM和SMBus控制<b class='flag-5'>接口</b>的<b class='flag-5'>LCD</b>背光WLED<b class='flag-5'>驱动</b>器TPS61195数据表

    【ElfBoard】硬件显示接口第1期

    ,屏幕就扫描一行。扫描480行后,又从第一行扫描开始。(这个规律由显示驱动IC所决定的)。 HV模式:需要LCD_CLK时钟信号,行同步信号LCD_HSYNC和场同步信号
    发表于 02-19 13:50

    如何在i.MXRT1170上快速点亮一款全新LCD屏?

    我们知道 LCD 屏的接口有很多:DPI-RGB、MIPI DSI、DBI/MCU(I8080)、LVDS、SPI 等等,接口不同,对应的软件驱动
    的头像 发表于 01-05 15:49 577次阅读
    如何在i.MXRT1170上快速点亮一款全新<b class='flag-5'>LCD</b>屏?

    Arduino如何连接和驱动8080 MCU

    Arduino如何连接和驱动8080 MCU
    发表于 11-10 07:09

    MCU接口LCD花屏问题如何解决?

    之前用 19264这种单色,偶尔会出现花屏现象,后来把所有显示数据全缓存在单片机RAM中,然后不断刷屏才解决。 现在要换彩色LCD,同样是MCU接口的,320*240的如果用RAM缓存要160k ram,成本就上去了,这个通常
    发表于 11-01 07:47

    使用MM32F3270 FSMC驱动TFT-LCD

    使用MM32F3270 FSMC驱动TFT-LCD
    的头像 发表于 09-27 15:34 470次阅读
    使用MM32F3270 <b class='flag-5'>FSMC</b><b class='flag-5'>驱动</b>TFT-<b class='flag-5'>LCD</b>

    使用MM32F3270 FSMC驱动OLED

    使用MM32F3270 FSMC驱动OLED
    的头像 发表于 09-27 15:30 581次阅读
    使用MM32F3270 <b class='flag-5'>FSMC</b><b class='flag-5'>驱动</b>OLED

    STM32的FSMC是如何驱动8080总线的液晶的?

    STM32de FSMC是如何驱动8080总线的液晶的?看了半天数据手册也不知道如何接线了,液晶有16位的数据总线,而FSMC的有20多位。
    发表于 09-26 07:38

    QVGA TFT-LCD直接驱动使用STM32F10xx FSMC外设

    电子发烧友网站提供《QVGA TFT-LCD直接驱动使用STM32F10xx FSMC外设.pdf》资料免费下载
    发表于 09-21 14:36 2次下载
    QVGA TFT-<b class='flag-5'>LCD</b>直接<b class='flag-5'>驱动</b>使用STM32F10xx <b class='flag-5'>FSMC</b>外设

    TFT LCDFSMC的硬件连接大容量STM32F10xxx FSMC接口

    电子发烧友网站提供《TFT LCDFSMC的硬件连接大容量STM32F10xxx FSMC接口.pdf》资料免费下载
    发表于 09-21 11:42 0次下载
    TFT <b class='flag-5'>LCD</b>与<b class='flag-5'>FSMC</b>的硬件连接大容量STM32F10xxx <b class='flag-5'>FSMC</b><b class='flag-5'>接口</b>

    使用STM32设计HMI_综述

    频率可达216MHz/2(fCLK = HCLK /2)• 支持的存储器类型• 静态存储支持• SRAM• PSRAM• NOR/ONENAND• ROM• LCD接口• 支持8080和6800模式
    发表于 09-11 06:58

    嵌入式LCD接口分类

    LCD接口有多种,分类很细。主要看LCD驱动方式和控制方式,目前手机上的彩色LCD的连接方式一般有这么几种:MCU模式,RGB模式,SP
    的头像 发表于 08-03 15:15 416次阅读
    嵌入式<b class='flag-5'>LCD</b>的<b class='flag-5'>接口</b>分类

    浅析STM32 FSMC操作LCD的过程

    FSMC称为灵活的静态存储器,它能够与同步或异步存储器和16位PC存储器卡连接,STM32F4的FSMC接口支持包括SRAM、NAND FLASH、NOR FLASH和PSRAM等存储器。
    发表于 07-22 14:46 2339次阅读
    浅析STM32 <b class='flag-5'>FSMC</b>操作<b class='flag-5'>LCD</b>的过程

    如何驱动I2C接口的OLED

    前面我们介绍了驱动SPI接口LCD5110显示的方法,这次介绍一下如何驱动I2C接口的OLED
    发表于 06-27 06:37