helpera64下开机bootlogo-BUG

环境:

 

 

 

目标:修改开机bootlogo的BUG

问题:

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

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

一、查找bug

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

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

二、BUG原因

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

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

三、修改bug

1、修改开机bootlogo调用,禁掉lzma解压,修改如下图使其32位图片能正常在uboot和内核显示

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

posted @ 2019-01-13 08:29  吉子  阅读(619)  评论(0编辑  收藏  举报