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

将 framebuffer 保存为图片来检查内容

[复制链接]
STMCU小助手 发布时间:2022-8-7 18:34
1. 前言
客户在做 GUI 项目开发时,会碰到许多显示相关的问题。而屏幕花屏是比较严重的问题,如果产品出现花屏,会严重影响使用体验。正常的 UI 显示,包括画图和将帧缓冲传输到屏幕两个过程。如果画图过程出错,那帧缓冲的内容就不对了,传输到屏幕后显示也不对。而如果画图过程正确,而传输过程出错,虽然帧缓冲的内容是对的,而屏幕接收到的数据出错了,那屏幕显示的内容自然也是错误的。因此在定位显示错乱、花屏等问题时,需要先判断是画图出错还是传输过程出错。本文会介绍一种方法,将帧缓冲内容导出并保存为图片,来判断帧缓冲内容是否正确。
由于帧缓冲的内容为全部像素的 RGB 数据,在导出后需要借助其它工具将 RGB 数据转换为图片,方便在 PC 上直接查看。这里可以使用 python 的 pillow 包,将 RGB 转换为JPG 图片。而读取帧缓冲的过程可以借助 python 的 pyswd 包来实现。
2. 环境安装
本机环境:Windows10 64bit安装 python 3.9.0 (测试过 3.9.6 正常),检查系统环境变量,将 python 添加到 Path中。

图1. 设置环境变量
B`WY2`D4]IFD8_@8~F9BXXD.png


2.1. 安装 libusb
解压 libusb-1.0.24.7z,将 VS2019/MS64/dll/libusb-1.0.dll 拷贝到 python 安装目录,与 python.exe 相同目录
2.2. 安装 pyusb
打开 powershell,输入 pip install pyusb-1.2.1-py3-none-any.whl
2.3. 安装 Pillow
打开 powershell,输入 pip install Pillow-8.3.1-cp39-cp39-win_amd64.whl
2.4. 安装 pyswd
解压 pyswd-1.0.0.zip,打开 powershell,进入 pyswd-1.0.0 目录,输入 python setup.py install

3. 将帧缓冲保存为图片
3.1. 读取帧缓冲
通过 pyswd,可以创建 stlink 对象连接到目标板,用 read_mem 函数来读取目标板内存。
3.2. 保存图片
从 Pillow 包导入 Image 类,创建图片对象,将 pyswd 读取的 framebuffer 数据填充到 image 对象中并保存实现代码如下,保存为 pyswd_rgb2jpg.py 文件。
  1. #!/usr/bin/env python
  2. # pyswd_rgb2jpg.py fb_addr width hight bpp output_name
  3. # pyswd_rgb2jpg.py 0x20000090 390 390 3 abc.jpg
  4. import swd
  5. from PIL import Image
  6. #from io import BytesIO
  7. import sys
  8. w = int(sys.argv[2]) #390
  9. h = int(sys.argv[3]) #390
  10. bpp = int(sys.argv[4])
  11. size = w * h * bpp #RGB565/RGB888
  12. fb_addr = int(sys.argv[1], 16) #hex
  13. dev = swd.Stlink(swd_frequency=1800000, logger=None)
  14. im_data = dev.read_mem(fb_addr, size)
  15. im_list = list(im_data)
  16. ## test rgb565.dta file, RGB offset = 16
  17. ## pyswd_rgb2jpg.py rgb565.dta 100 100 2 rgb565.jpg
  18. #with open(sys.argv[1], 'rb') as f:
  19. # f.seek(16)
  20. # data = f.read()
  21. # #print(data)
  22. #im_list = list(data)
  23. im = Image.new("RGB", (w, h))
  24. if bpp == 3:
  25. for j in range(0, h):
  26. for i in range(0, w):
  27. im.putpixel((i, j), (im_list[(w*j + i)*bpp + 2], im_list[(w*j + i)*bpp + 1], im_list[(w*j + i)*bpp]))
  28. elif bpp == 2:
  29. for j in range(0, h):
  30. for i in range(0, w):
  31. r = im_list[(w*j + i)*bpp + 1] >> 3
  32. g = ((im_list[(w*j + i)*bpp + 1] & 0x07) << 3) | (im_list[(w*j + i)*bpp] >> 5)
  33. b = im_list[(w*j + i)*bpp] & 0x1f
  34. r = round((r * 255) / 31.0)
  35. g = round((g * 255) / 63.0)
  36. b = round((b * 255) / 31.0)
  37. im.putpixel((i, j), (r, g, b))
  38. #print("%02x %02x %02x" %(r, g, b))
  39. else:
  40. print("bpp error")
  41. im.save(sys.argv[5])
复制代码


4. 测试及小结
在 L4R9-DK 板上进行了测试
(1) 无 GFXMMU 时,传给脚本的参数,宽和高为实际 LCD 的宽和高将 GUI 固件烧录到开发板后,屏幕正常显示。在工程 map 文件中,找到 framebuffer 地址。打开 powershell,执行 pyswd_rgb2jpg.py:


F`)6UW4Z3V)_YL)S0$P{Y@I.png

(2)开启 GFXMMU 时,framebuffer 对应为虚拟地址,传给脚本的参数中,图像的宽度要用GFXMMU 像素宽度
图4. L4R9-DK 开启 GFXMMU 测试



UEMC]VSX[13FK}J~7GK~3.png


完整版请查看:附件


LAT1033 将framebuffer保存成图片来检查其内容是否正常_v1.0.pdf

下载

450.27 KB, 下载次数: 1

收藏 评论0 发布时间:2022-8-7 18:34

举报

0个回答

所属标签

相似分享

官网相关资源

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