环境:
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。
5、修改开机bootlogo调用,禁掉lzma解压,修改如下图使其32位图片能正常在uboot和内核显示
6、不足之处:对lzma解压调用还没理清楚,没搞清楚为什么大部分bmp图片会造成多线程资源的抢占,又怎么冲突的。学习内核和UBOOT任重而道远啊~