helpera64开机bootlogo-BUG

环境:

       HelperA64开发板

       Linux3.10内核

时间:2019.01.12

目标:修改开机bootlogo的BUG

问题:

1.24bit深度的bootlogo.bmp图片会导致Qt5有色差,32位的图片没有色差。

2.将开机bootlogo图片修改为32位图片只有部分图片能够点亮屏就显示,大部分图片没有在开机uboot中显示,只在内核中显示。

方法:修改uboot使其能正常显示

1.查找uboot开机显示图片的地方,寻找源码BUG地方

2.通过bmp格式解析发现没错,调用开机bootlogo解码和显示主要如下

3.BUG原因:helperA64每次开机都会执行下图代码,这代码是lzma解压。部分图片执行解压很快,而大部分bmp图片就在这里卡住了多达四五秒时间等待,这是uboot快速启动所不能接受的。

4.uboot开机时开始时为多线程,导致解析图片产生资源冲突,如下是start.S中先调用sunxi_secendary_cpu_task然后是sunxi_third_cpu_task。

4.修改开机bootlogo调用,禁掉lzma解压,修改如下图使其24位和32位图片能正常显示

5.不足之处:对lzma解压调用还没理清楚,没搞清楚为什么大部分bmp图片会造成多线程资源的抢占,又怎么冲突的。学习内核和UBOOT任重而道远啊~

猜你喜欢

转载自blog.csdn.net/jibei1024/article/details/86351685
bug
64