java 进程跑飞_RK3288 st7703 mipi屏指令过长,程序跑飞

  • Post author:
  • Post category:java


CPU:RK3288

系统:Android 5.1

调试 mipi 屏前,先关闭了 uboot 的 logo 显示

rockchip,uboot-logo-on = <0>;

屏调试完成后,打开 uboot 的 logo 显示

rockchip,uboot-logo-on = <1>;

但是开机时,系统竟然进不了 kernel,一直在 uboot 重启,log 如下:

#Boot ver: 2019-07-20#2.30empty serial no.

checkKey

vbus= 1no fuel gauge found

no fuel gauge found

read logo on statefrom dts [1]

pll_src= 0, dclk_hz = 66000000, dclk_div = 6undefined instruction

pc : [<0000009c>] lr : [<05971c18>]

sp :05735938 ip : 0001741c fp : 00019094r10:00000033r9 : 05746a38 r8 : 0000003b

r7 : 0000003c r6 : fa8b95c7 r5 :00000028r4 : 0000000a

r3 : ffffffff r2 :00000004 r1 : 0001741c r0 : 00000000Flags: NzCv IRQs on FIQs off Mode SVC_32

Resetting CPU …

resetting …

原因: mipi 屏的指令太长,超出了定义的范围,程序跑飞了。

解决办法:

1、首先找到定义指令的数组,文件路径如下,打开文件搜索 cmds

path:u-boot/drivers/video/screen/lcd_mipi.c

在 rk_mipi_screen_init_dt 函数中定义的 cmds 数组长度只有 20,但是 mipi 屏最长的指令高达 64。

u32 i,cmds[20];

增大 rk_mipi_screen_init_dt 函数中 cmds 数组的长度,要超过 mipi 屏最长的指令长度。

u32 i,cmds[128];

2、编译 uboot 烧录后,系统虽然没有一直重启,但是卡在 uboot,进不了 kernel,提示内存申请失败,log如下

#Boot ver: 2019-07-20#2.30empty serial no.

checkKey

vbus= 1no fuel gauge found

no fuel gauge found

read logo on statefrom dts [1]

pll_src= 0, dclk_hz = 66000000, dclk_div = 6ERROR: [show_resource_image]: Failed to load image:logo.bmp

no fuel gauge foundmalloc forbl levels fail

Hit any key to stop autoboot:0ERROR : memory not allocated

3、找到定义指令数组的结构体,文件路径如下,打开文件搜索 cmds

path:u-boot/drivers/video/transmitter/mipi_dsi.h

cmds 数组定义在 struct dcs_cmd 结构体中,长度只有 32

int cmds[32];

增大 struct dcs_cmd 结构体中 cmds 数组的长度,要超过 mipi 屏最长的指令长度。

u32 i,cmds[128];

4、此时编译烧录,完美解决问题。

注:如果还没有打开 uboot 显示 logo,处在调试 mipi 阶段,程序还是因为 mipi 屏指令长度跑飞,有两种解决办法,如下:

1、从 rochchip 更新代码,最新的 kernel 代码中已经解决指令长度过长问题。

2、如果不想更新代码或者其他原因没办法更新代码,就需要手动增大指令数组的长度,类似与 uboot

kernel/drivers/video/rockchip/screen/lcd_mipi.c

kernel/drivers/video/rockchip/transmitter/mipi_dsi.h



版权声明:本文为weixin_39830387原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。