1. spi调试问题:

问题描述:

  1. spi屏幕lk启动的时候正常出现小企鹅,到kernel启动的过程黑屏并且花屏才到开机动画;

2. 黑屏的三个阶段:

参照:黑屏分析

分析开机过程黑屏,首先需要定位黑屏问题发生的时间段,开机过程中涉及到显示logo 或者是播放动画的主要有如下三个阶段:

  • 显示 lk logo ;
  • 显示kernel logo;
  • 开机动画 Bootanimation

    如下这张ENG 版本开机过程显示图,说明了主要的三个过程:

如下解释:

(阶段1)、带有”normal boot“的lk logo,会在lk阶段显示。显示时间一般1s左右。

(阶段2)、启动到kernel的前7s左右,显示的是带”normal boot“字样的lk logo。(这里L/M版本和KK/JB版本很不同,不在此处细说)

(阶段3)、之后显示kernel logo的时间段很短,一般只有2s左右.

(阶段4)、显示bootanimation动画。

3. 调试过程:

如上所示,我们是在(阶段一)(阶段二)之间黑屏,这时候要看一下lk中DEFINES += DISPLAY_SPLASH_SCREEN = 1 的宏有没有打开;(target/xxx/rules.mk),再将qcom,cont-splash-enabled增加到你对应厂商的屏代码的设备树中;

重新烧录软件,开机;

依然出现问题:

我们这时候发现lk到kernel的第二阶段已经完全正常了,但是又出现问题。。。这时候kernel的开机动画出现抖动,并且无法正常显示(第三阶段);关键来了,灭屏后,一切屏幕正常;

这时候,我已经开始怀疑lk和kernel的spi屏初始化代码有区别:

将lk代码修改为kernel中的初始化代码,结果lk也有问题,出现不断的抖动和闪烁;于是,我只能接受spi 屏kernel和lk初始化代码不一样的结论了;但问题是为什么我们第三阶段已经属于我们kernel启动的时候了,但是为什么没有初始化呢?(灭屏后再次开启已经启用了resume了);

读源码吧:

找到我们kernel源码中的qcom,mdss-spi-on-command节点,在解析设备树用到的,最后我们定位在mdss_spi_panel_on函数中初始化:

int mdss_spi_panel_on(struct mdss_panel_data *pdata)
{
struct spi_panel_data *ctrl = NULL;
struct mdss_panel_info *pinfo;
int i; if (pdata == NULL) {
pr_err("%s: Invalid input data\n", __func__);
return -EINVAL;
}
pinfo = &pdata->panel_info;
ctrl = container_of(pdata, struct spi_panel_data,
panel_data); for (i = 0; i < ctrl->on_cmds.cmd_cnt; i++) {
mdss_spi_tx_command(ctrl->on_cmds.cmds[i].command); if (ctrl->on_cmds.cmds[i].dchdr.dlen > 1) {
mdss_spi_tx_parameter(ctrl->on_cmds.cmds[i].parameter,
ctrl->on_cmds.cmds[i].dchdr.dlen-1);
}
if (ctrl->on_cmds.cmds[i].dchdr.wait != 0)
msleep(ctrl->on_cmds.cmds[i].dchdr.wait);
} pinfo->blank_state = MDSS_PANEL_BLANK_UNBLANK;
pr_debug("%s:-\n", __func__); return 0;
}

增加log打印,最后判断在第三阶段中上述函数中并没有被调用到,而是由lk的初始化代码一直维持屏的状态;

mdss_spi_panel_init函数中,注册了相应的回调函数:

int mdss_spi_panel_init(struct device_node *node,
struct spi_panel_data *ctrl_pdata,
bool cmd_cfg_cont_splash)
{
int rc = 0;
static const char *panel_name;
struct mdss_panel_info *pinfo; if (!node || !ctrl_pdata) {
pr_err("%s: Invalid arguments\n", __func__);
return -ENODEV;
} pinfo = &ctrl_pdata->panel_data.panel_info; .......
ctrl_pdata->on = mdss_spi_panel_on;
ctrl_pdata->off = mdss_spi_panel_off;
ctrl_pdata->panel_data.set_backlight = mdss_spi_panel_bl_ctrl; return 0;
}

而这个回调函数是在什么时候作用到的呢?

mdss_spi_panel_unblank函数中:

static int mdss_spi_panel_unblank(struct mdss_panel_data *pdata)
{
int ret = 0;
struct spi_panel_data *ctrl_pdata = NULL; if (pdata == NULL) {
pr_err("%s: Invalid input data\n", __func__);
return -EINVAL;
} ctrl_pdata = container_of(pdata, struct spi_panel_data,
panel_data); // if (!(ctrl_pdata->ctrl_state & CTRL_STATE_PANEL_INIT)) { ret = ctrl_pdata->on(pdata);
if (ret) {
pr_err("%s: unable to initialize the panel\n",
__func__);
return ret;
}
ctrl_pdata->ctrl_state |= CTRL_STATE_PANEL_INIT;
// } return ret;
}

修改后,patch地址: patch地址

开机正常,spi正常,一切正常;

高通调试 SPI 屏的 bug的更多相关文章

  1. 高通APQ8074 spi 接口配置

    高通APQ8074 spi 接口配置 8074 平台含有两个BLSP(BAM Low-Speed Peripheral) , 每一个BLSP含有两个QUP, 每一个QUP可以被配置为I2C, SPI, ...

  2. 高通非adsp 架构下的sensor的bug调试

    高通 sensor 从native到HAL 高通HAL层之Sensor HAL 高通HAL层之bmp18x.cpp 问题现象: 当休眠后,再次打开preesure sensor的时候,会出现隔一段时候 ...

  3. 高通平台 lcd driver 调试小结

    一.概述 1.1 简介 本文档主要包括LCD模块的驱动流程分析.Framebuffer相关知识.Gralloc等相关内容,以及LCD调试的一些经验和相关bug的分析和讲解. 1.2  开发环境 And ...

  4. 高通安卓调试LCD几方面总结

    来公司上班现在已经整整一个月了,蔽人不才,能力有限,学习进度缓慢,不过也是有一点点的收获与心得,在这里写出来与大家分享,养成良好的记录习惯也免得后忘记. 不啰嗦了,开入正题.来公司一个月左右的时间,主 ...

  5. 高通LCD驱动调试

    本文转载自:http://www.itgo.me/a/x6305658852004979994/lcd%20qcom 来自 :http://blog.csdn.net/dacaozuo/article ...

  6. 高通Android平台硬件调试之Camera篇

    之前一段时间有幸在高通android平台上调试2款camera sensor,一款是OV的5M YUV sensor,支持jpeg out,同时也支持AF,调试比较比较简单,因为别的项目已经在使用了, ...

  7. Android 系统自动重启Bug(高通平台)

    点击打开链接 最近客户反馈了一个Bug,我们的系统用着用着会自动重启,尤其是在拨号的时候极容易死机或者进入下载模式.根据老大和高通的支持得到了一个解决方案. 在Android系统中,有这么一个文件夹: ...

  8. 高通spi 屏幕 -lk代码分析

    lk SPI驱动 1. 初始化时钟 在lk中,我们是从kmain开始执行下来的,而执行顺序则是先初始化时钟,也就是在platform_early_init函数中开始执行的: 在这里我们需要修改这个函数 ...

  9. 高通MSM8998 ABL的调试

    高通在MSM8998上引入了UEFI,用来代替LK(Little Kernel).高通UEFI由XBL和ABL两部分组成.XBL负责芯片驱动及充电等核心应用功能.ABL包括芯片无关的应用如fastbo ...

随机推荐

  1. C语言的引用计数与对象树

    引用计数与对象树 cheungmine 2013-12-28 0 引言 我们经常在C语言中,用指针指向一个对象(Object)的结构,也称为句柄(Handle),利用不透明指针的技术把结构数据封装成对 ...

  2. 类模板语法知识体系梳理(包含大量常犯错误demo,尤其滥用友元函数的错误)

    demo 1 #include <iostream> #include <cstdio> using namespace std; //template <typenam ...

  3. 11_Eclipse中演示Git版本的创建,历史版本的修改,创建分支,合并历史版本和当前版本

     1 执行以下案例: 某研发团队2011年初开发了一款名为Apollo的信息系统,目前已发布v1.0版本.此项目初期已有部分基础代码, 研发团队再此基础代码上经过3个月的努力发布了一个功能相对完备 ...

  4. Leetcode_122_Best Time to Buy and Sell Stock II

    本文是在学习中的总结,欢迎转载但请注明出处:http://blog.csdn.net/pistolove/article/details/43155725 Say you have an array ...

  5. SMO

    序列最小优化算法(英语:Sequential minimal optimization, SMO)是一种用于解决支持向量机训练过程中所产生优化问题的算法.SMO由微软研究院的约翰·普莱特(John P ...

  6. 一个 developer 的进化

    作为一名开发者已十年,回顾过往大概经历了这么几个阶段,如下图所示: Develop Code 作为刚走出学校的学生进入公司,在最初的 1-2 年内就处于该阶段. 不停的开发代码,为系统的大厦添砖加瓦, ...

  7. Salesforce 官方扫盲自学导航

    Force.com Platform Fundamentals(新手入门的葵花宝典)www.salesforce.com/us/developer/docs/fundamentals/index_Le ...

  8. 《UNIX网络编程 卷1》之"学习环境搭建"(CentOS 7)

    <UNIX网络编程 卷1>的源码可以从www.unpbook.com下载得到.解压之后的目录为unpv13e. 详细步骤 编译 进入unpv13e目录,按如下步骤编译: ./configu ...

  9. OpenGL Shader Key Points (1)

    1.  Shader起步 1.1.  可编程管线 仅考虑Vertex shader和fragment shader: 1.2.  Shader Object 在编译阶段生成,把shader源代码编译成 ...

  10. Linux文件内容查阅 - cat, tac, nl, more, less, head, tail, od

    cat 由第一行开始显示文件内容 tac 从最后一行开始显示,可以看出 tac 是 cat 的倒著写! nl 显示的时候,顺道输出行号! more 一页一页的显示文件内容 less 与 more 类似 ...