你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

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

[复制链接]
STMCU-管管 发布时间:2021-6-29 11:17
工程师笔记 | 驱动 8 位 8080 接口 LCD 时的字节序问题
前言7 F& c! Q, m) p; @
在一些图形界面应用中,系统架构会时常考虑使用 FSMC接口来驱动 8080接口的 LCD屏。在 MCU渲染完成,将framebuffer发送到 LCD时,有可能会遇到存儲大小端的问题。STM32MCU都采用 ARMCortex内核,内存使用小端格式。而 intel 8080接口的 LCD在传输 RGB数据时,使用的是大端格式。MCU在传输 RGB数据时,字节序有可能不匹配。
: |& Z9 G' D9 p1 _& x8 _+ Z在图形界面应用中,像素格式一般会使用 RGB888或 RGB565。而在使用 FSMC接口驱动 8bit位宽的 LCD时,很可能会使用 RGB565格式。本文中会介绍两种方法来处理8bit8080接口 RGB565格式图像数据字节序问题。7 t- S. c2 x- b

9 b  n- z. @# Y* m" Q" \1 @图像数据字节序
# i) p) w( z, T( g' _! e8bit8080 LCD在接收 RGB565数据时,会将第一个字节解析为{R4-R0,G5-G3}, 第二个字节解析为{G2-G0,B4-B0},并按这个顺序接收所有数据,如下图:3 a" N% G$ n3 \" K- n. _
11.png
而在 MCU内存中,数据按小端格式存放,RGB565数据存放的字节序如下:1 ~% G2 j) Z7 V& Q( }3 v5 V
12.png
如果不做调整直接将 RGB数据发给 LCD,MCU会先发送 Byte0,再发送 Byte 1,这样 LCD显示的内容就会错乱。对比上面两张图可以看出,只需将内存中 Byte0与 Byte1字节位置对调(Byteswap),就能满足 LCD接口的字节序要求。可以直接使用 CPU进行 Byteswap,但这会消耗过多 CPU算力,同时也会占用更多内存。这里我们将使用硬件进行 Byteswap.+ T! Y, b/ ^, b0 V- _2 K, }* u

  Z; `& ^* I, ]DMA2D 进行Byteswap
7 I/ |  f% e& \0 lDMA2D是 ST为图形应用专门设计并优化的2D加速引擎,拥有丰富的功能。其字节序重排功能包含了Red blueswap以及 Byteswap特性。Red blueswap特性在 L4和 L4+系列 MCU都支持,而 Byteswap仅在L4+系列有支持。在 L4+系列上,通过配置 DMA2D_OPFCCR寄存器的 SB位,即可使能 Byteswap功能,在 DMA2D的outputFIFO中完成字节序调整,如下图:( J0 O1 w/ ^: j
13.png
因此在图形界面应用中,需要 Byteswap时,可以考虑用 DMA2D来传输 RGB数据给 LCD。6 D; L9 m+ E- o* O! Z
: m+ p6 r+ e& {9 b. S# X

# Z7 Y  F% w4 j5 DGPDMA 进行Byteswap
7 l& c# P' W/ [- J2 D  z在新推出的 U5系列芯片上,集成了 GPDMA模块。这是新的通用DMA模块,能在传输数据的同时,还有丰富的数据处理能力。在初始化GPDMA时,通过配置源和目的数据位宽为 DMA_SRC_DATAWIDTH_WORD,在数据处理中配置 DataExchange为 DMA_EXCHANGE_DEST_BYTE,如下面代码,也能实现Byteswap功能。
  l, f6 |# e+ O9 R
14.png
这样,在图形应用中,既能使用 DMA2D加速渲染过程,也能使用 GPDMA的数据处理能力。通过 GPDMA直接向FSMC接口输出 Byteswap后的 RGB565格式的图形数据给LCD。" M0 l6 k8 ?; u
2 a* V# g. X/ _4 [/ _! ?  l
小结
8 B! W1 H$ ]: C0 |9 p! _在驱动 8位 8080接口 LCD时,需要注意图像数据字节序问题。使用 RGB565格式时,可以使用 DMA2D或 GPDMA来传输图像数据,同时对图像数据做 Byteswap调整,满足LCD的字节序要求。
' V, P- j" F  M- C# |3 n2 y6 @
7 W6 s' Y, p1 }8 v8 Q2 t6 x! d/ |' h: H
收藏 1 评论0 发布时间:2021-6-29 11:17

举报

0个回答

所属标签

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版