博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
被LCD调戏睡不着了
阅读量:1980 次
发布时间:2019-04-27

本文共 3792 字,大约阅读时间需要 12 分钟。

好吧,我承认我不是因为被调戏睡不着的,我是因为今天晚上喝了一杯该死的咖啡,然后就睡不着了,这个点[3:40]在床上翻来覆去,刚开始我摸着楠哥的小腿,过了一会,觉得没意思了,然后再摸楠哥的大腿,我想跟他说几句话,接着是,啪的一个声音,精神小伙给了我一巴掌。

因为睡不着,于是我就坐起来写点奇怪的东西,就有了这篇文章。

我们今天在调试屏幕,已经在LK阶段让屏幕亮起来了,但是在kernel阶段屏幕还是不能亮,排查了很久不知道问题在哪里。

1、测量了复位脚上电时序,可以看到按下power键休眠唤醒的时候可以看到reset脚的电平变化,也就是说这个脚是可以控制的,不过话说回来,如果这个脚不可以控制,在lk阶段怎么可能亮屏呢?

2、测量mipi的lane脚,也可以看到休眠的时候没有波形,唤醒的时候有波形,所以平台端的视频输出是正确的。

3、发现上电时候复位引脚拉高后的延迟时间不够,芯片手册上要求是 10ms以上,但是我们代码实际上写的是5ms,但是实际修改后也没有亮屏。

4、在kernel阶段,我们写入BIST模式的时候不能进入测试模式。这个可以猜测没有写成功是因为上电时序有问题,IC没有进入正常的上电状态。

明天准备排查方向

1、还是从上电时序入手,VDD 和RESET之间的时间,还有RESET和LANE数据的时间,都需要严格遵守,并且要用示波器测量正确。

这一点跟模组厂确认,电源开机后一直打开是没有问题的,所以排除这一点。但是有的屏幕如果复位时序不正确,寄存器是写不进去的。

2、去掉LK的控制,让屏幕在Kernel阶段初始化,因为从没有电到上电有一个过程,这也是为什么LK阶段上电不严格也可以初始化的原因,因为它总是从没有电到有电的冷启动。

3、叫模组厂的FAE过来,我们没有调通,大家应该都有责任把这个事情做好,先把锅甩出去再说。


题外话

在知乎上看到一个问题,如果当时关羽不出手,刘备不出手,张飞不出手,谁能斩华雄。

这里只讨论演义,我看了很多人的答案,我觉得有两个人可以,一个是孙坚,一个是曹洪,孙坚前期打架是很厉害的,当然也还有其他人选,比如典韦,赵云之类的,但是他们当时还没有出现,赵云那时候年纪也还比较小,我选的这两个人也都出现在当时的联合军队中。不过不管是孙坚和曹洪,战斗力应该都打不过华雄,即使能不被反杀,想拿下华雄人头应该还是很难的。


时间来到今天

今天还是一样,我把我熬夜思考出来的秘籍都测试了,开机后可以亮屏幕,但是suspend后再resume,该死的屏幕还是亮不了。

其中还跟模组厂沟通如下:

这个时候,我发现我的背光亮不了。于是我就跟着背光在resume的时候不能亮的思路去寻找。我还想起来,我昨天发了文章,有一个大牛给我回复了,我跟他聊了下。

就是这个该死的宏,在唤醒的时候进行了判断跑了不同的逻辑。

我按照这样修改后,这个该死的屏幕就亮起来了。

void mt_mt65xx_led_set(struct led_classdev *led_cdev, enum led_brightness level){  struct mt65xx_led_data *led_data =      container_of(led_cdev, struct mt65xx_led_data, cdev);  /* unsigned long flags; */  /* spin_lock_irqsave(&leds_lock, flags); */  output_met_backlight_tag(level);    printk("=== weiqifa === %s-%d\n",__FUNCTION__,__LINE__);#ifdef CONFIG_MTK_AAL_SUPPORT  if (led_data->level != level) {    led_data->level = level;    if (strcmp(led_data->cust.name, "lcd-backlight") != 0) {      LEDS_DEBUG("Set NLED directly %d at time %lu\n",           led_data->level, jiffies);      schedule_work(&led_data->work);    } else {      if (level != 0          && level * CONFIG_LIGHTNESS_MAPPING_VALUE < 255) {        level = 1;      } else {        level =            (level * CONFIG_LIGHTNESS_MAPPING_VALUE) /            255;      }      LEDS_DEBUG          ("Set Backlight directly %d at time %lu, mapping level is %d\n",           led_data->level, jiffies, level);      /* mt_mt65xx_led_set_cust(&led_data->cust, led_data->level); */      disp_aal_notify_backlight_changed((((1 <<                   MT_LED_INTERNAL_LEVEL_BIT_CNT)                  - 1) * level +                 127) / 255);    }  }#else  /* do something only when level is changed */  if (led_data->level != level) {    led_data->level = level;    if (strcmp(led_data->cust.name, "lcd-backlight") != 0) {      LEDS_DEBUG("Set NLED directly %d at time %lu\n",           led_data->level, jiffies);      schedule_work(&led_data->work);    } else {      if (level != 0          && level * CONFIG_LIGHTNESS_MAPPING_VALUE < 255) {        level = 1;      } else {        level =            (level * CONFIG_LIGHTNESS_MAPPING_VALUE) /            255;      }      LEDS_DEBUG          ("Set Backlight directly %d at time %lu, mapping level is %d\n",           led_data->level, jiffies, level);      if (led_data->cust.mode == MT65XX_LED_MODE_CUST_BLS_PWM) {        mt_mt65xx_led_set_cust(&led_data->cust,                   ((((1 <<                 MT_LED_INTERNAL_LEVEL_BIT_CNT)                - 1) * level +               127) / 255));      } else {        mt_mt65xx_led_set_cust(&led_data->cust, level);      }    }  }  /* spin_unlock_irqrestore(&leds_lock, flags); */#endif

但是这个背光控制没有在DTS里面设置的,这个真的是一个大坑,我们的背光控制硬件GPIO口是

但是代码中,这里直接通过PWM寄存器控制了,所以就脱离了GPIO口了。也就是我们想在DTS里面找GPIO口配置是不对的。

还有这个宏的作用

CONFIG_MTK_AAL_SUPPORT

这个是自动背光的作用,可以用来节省电量,但是我们不需要这个功能,而且前期调试的时候,光感还没有起来,开了这个就有影响了。

把这个功能关闭后需要全编译一次,要不然功能还没有完全关闭。

MTK8167S的LCD软件流程框架我就不说了,驱动调试的话可以按照原有的驱动来参考编写,也有MTK的调试文档,先不花篇幅在这里了。有需要的可以私聊我。

最后~

感谢这位小哥哥~


  回复「 篮球的大肚子」进入技术群聊

回复「1024」获取1000G学习资料

转载地址:http://icepf.baihongyu.com/

你可能感兴趣的文章
redis api
查看>>
flink physical partition
查看>>
java 解析json
查看>>
java http请求
查看>>
tensorflow 数据格式
查看>>
tf rnn layer
查看>>
常用中间件
查看>>
tf input layer
查看>>
tf model create
查看>>
tf dense layer两种创建方式的对比和numpy实现
查看>>
tf initializer
查看>>
tf 从RNN到BERT
查看>>
tf keras SimpleRNN源码解析
查看>>
tf keras Dense源码解析
查看>>
tf rnn输入输出的维度和权重的维度
查看>>
检验是否服从同一分布
查看>>
tf callbacks
查看>>
keras、tf、numpy实现logloss对比
查看>>
Ubuntu20.04安装微信
查看>>
Restful风格的使用
查看>>