故障现象:minigui无法显示界面,消息系统正常。
排查过程:
1.修改V3S初始化代码,把代码中通过读配置文件获取的参数改成固定的320*240,这样就自动会使用320-240配套的配置文件了。发现故障依旧。
void getScreenInfo(int *w, int *h)
{
static int swidth = 0;
static int sheight =0;
if(swidth == 0 ){
char *env = NULL;
char mode[32]={0};
db_msg(" ");
if ((env=getenv("MG_DEFAULTMODE")) != NULL) {
strncpy(mode, env, strlen(env)+1);
}
db_msg(" ");
char *pW = NULL;
char *pH = NULL;
pW = strstr(mode, "x");
*pW = '\0';
swidth = atoi(mode);
*pW = 'x';
pH = strstr(mode, "-");
*pW = '\0';
sheight = atoi(pW+1);
*pW = '-';
}
//swidth = 320;
//sheight = 240;
*w = swidth;
*h = sheight;
printf("\n\n..................width:%d height:%d........................\n\n", swidth, sheight);
}
2.在1的基础上,简化程序,只让程序中运行minigui,且显示一个最简单的窗口,还是不行。
3.单独写了几个测试程序,直接访问fb文件,发现能够正常显示,在pc端做实验时,要用ctrl+alt+F1切换到字符界面才行,测试完后用+F5切换回图形界面。
4.仔细看了调试信息,发现内核驱动打印出“invallid argb format.........”的调试信息,经过查看驱动代码和minigui的源代码,最后定位故障在minigui的初始化函数中,发现初始化函数会读取环境变量:MG_DEFAULTMODE,这个环境变量位于文件root/init.sun8i.rc中,配置为:export MG_DEFAULTMODE "320x480-32bpp",而不是"320x240-32bpp",导致初始化异常。
5.通过手工方式修改MG_DEFAULTMODE为"320x240-32bpp",在命令下执行:export MG_DEFAULTMODE=320x240-32bpp,显示回复正常。
6.正式打包时,把这个文件修改为正确的参数,问题彻底结局。
总结:开始以为只要初始化时使用对应的配置文件就可以了,没想到minigui底层还会调用这个环境变量。