Rockchi之RK3288解决MIPI屏黑屏问题

2023-12-12 20:32

本文主要是介绍Rockchi之RK3288解决MIPI屏黑屏问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Rockchi之RK3288解决MIPI屏黑屏问题

继上一次解决液晶屏出现花屏现象之后,在公司4台测试机上测试可用,但不久便传来工厂测试时液晶屏出现黑屏现象,紧接着上次任务,我又继续了无尽头的调试,同样,拿到液晶屏,打开液晶屏的配置文件dts文件.

打开查看参数,想起上次修改的是rockchip,dsi_hs_clk这个参数,上次改的值是450,然后在不断开机的时候就会出现黑屏现象或者开机动画不正常现象,但是当我把这个参数改大,液晶屏经过连续的开关机并不会出现黑屏或者开机动画不正常现象,但是致命的就是液晶屏左侧会出现一条竖线,继续增大rockchip,dsi_hs_clk这个值,就会出现花屏,然后我的第一想法就是改一个刚好合适的值,让它既不会黑屏又不会有水纹,但是最后结果我错了.
  查看lcd屏的数据手册,看到rockchip,dsi_hs_clk的值最大为500,但是dts上rockchip,dsi_hs_clk写的是600,然后我就没有参考这个,就是在510—520之间调节,但最后发现都是无济于事,调高液晶屏左端会有一条竖线,调低会出现液晶屏开机黑屏或者开机动画不正常现象,紧接着我又想到了行场信号,查看LCD的时序图
  在这里插入图片描述
  在这里插入图片描述
由图中可以看到,Hsync水平同步信号和Vsync垂直同步信号的时序,其中tvw和thw为无效时间,tvbp和thbp为等待时间tvd为垂直像素,thd为水平同步信号,tvfp和thfp为结束时间,根据这张图我去调节dts里的参数,但是这些参数又有限制,LCD的数据手册上写了很清楚.
在这里插入图片描述
tHW+tHBP+tHFP的典型值为241,tvW+tvBP+tvFP的典型值为33,根据这个,调节参数
在这里插入图片描述
但是最后发现,无论我怎么调节行场信号都不能解决问题,甚至对液晶屏显示都没有一点影响,很沮丧,就这样调节clock-frequency像素时钟和各行场信号,虽然有时候测试十多二十次正常,但是经不起次数更多的测试,这也花费了我不少时间,但是有一天我看到了网友们的调试经验,我发现我之前的想法错了,不多说上图
在这里插入图片描述

其中bpp为像素位宽,在本LCD屏中,设置的是24位像素
在这里插入图片描述
我之前对这个rockchip,dsi_hs_clk参数很模糊,不知到他到底怎么来的,直到今天明白,他是由行场信号、刷新率、像素位宽以及数据data线的数量有关,只有rockchip,dsi_hs_clk和刷新率两者匹配液晶屏才能正常显示,然而液晶屏的刷新率又是
在这里插入图片描述
根据计算,LCD数据手册给出的典型值算下来的fps刷新率正好为60,虽然是59.9多,但是可以认为是60,但是这个60在android系统中是最大的刷新率了,所以我就把这些参数都设置成典型值,根据上面rockchip,dsi_hs_clk公式可以计算出来每条MIPI data lane传输速率为456.

填入456后,测试30次正常,很开心很激动,继续测试到45次开机动画不正常,卡了一下,瞬间奔溃,但是还是很开心的,因为找到了突破点,之后我把参数改成450,发现液晶屏显示发生偏移,改成460发现液晶屏显示出现波纹,简直就是完美,然后我从560往下降,一个个测试,最终当参数改为458的时候,液晶屏测试100次无误,这也就符合了网友说的
在这里插入图片描述
好了,液晶屏一切正常了,是不是要手工领盒饭了呢,并不能,因为作为一个严谨好学的孩子,是不能停止脚步的,根据公式我算了一下数据手册上的DSI Clock frequency(HS)参数,当像素时钟clock-frequency最大为82.4MHz其他行场信号最小HW+tHBP+tHFP的值为136,tvW+tvBP+tvFP的为21时,刷新率fps为70.8多,最终算下来rockchip,dsi_hs_clk的值为494多,和数据手册上的MAX值为500相符,所以数据手册上的参数是正确的。

除此之外对公式进行解析:

 dsi_hs_clk = ((h_active + hfp + hbp + h_sync) * (v_active + vfp + vbp + v_sync) * fps * bpp) / lane_number

一帧画面需要的数据量为(单位bit)

FRAME_BIT = (屏幕有效显示宽度+hsync+hfp+hbp) x ( 屏幕有效显示高度+vsync+vfp+vbp) x(RGB显示数据宽度24)

一秒钟内需要传输的数据量为(单位bps)

FRAME_BIT  x  fps(帧率)。

那为何要除以lane_num----因为mipi通讯协议中,一个CLOCK几个lane是可以同时传输数据的.

但是有些还要再除2,因为根据mipi通讯协议,CLK_N、CLK_P这两根时钟线的上升沿/下降沿可以获取到数据,但是我们这个mipi屏好像没有上升下降都获取数据,所以暂且不除2。

因此我们可以得出如下结论

  1. 在相同的时钟频率下,lane数越多,则单位时间内可以传输的数据越多。若显示帧率固定不变,则可以支持的更大的分辨率;而分辨率固定不变的情况下,则我们可以考虑支持更高的帧率显示。
  2. 在lane数固定的情况下,提高传输的时钟频率,则单位时间内也可以传输更多的显示数据。进而我们可以考虑是提高帧率还是提高分辨率,或两者做出平衡。

那么我们是否可以任意无限制的提高mipi的传输时钟频率及lane数目呢?mipi通讯协议对此进行了限制,一组CLOCK最高只能支持4组lane,一组lane的传输速度最高只能支持到1 Gbps。也就是说一组CLOCK最高只能支持到4 Gbps速度传输。

此时就引出了一个新问题:4Gbps速度传输,是满足不了现在市场上推出的4K电视的带宽要求的,怎么办?答案是使用8组lane,使用两组clock来传输。

这篇关于Rockchi之RK3288解决MIPI屏黑屏问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/485844

相关文章

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

504 Gateway Timeout网关超时的根源及完美解决方法

《504GatewayTimeout网关超时的根源及完美解决方法》在日常开发和运维过程中,504GatewayTimeout错误是常见的网络问题之一,尤其是在使用反向代理(如Nginx)或... 目录引言为什么会出现 504 错误?1. 探索 504 Gateway Timeout 错误的根源 1.1 后端

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

深度剖析SpringBoot日志性能提升的原因与解决

《深度剖析SpringBoot日志性能提升的原因与解决》日志记录本该是辅助工具,却为何成了性能瓶颈,SpringBoot如何用代码彻底破解日志导致的高延迟问题,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言第一章:日志性能陷阱的底层原理1.1 日志级别的“双刃剑”效应1.2 同步日志的“吞吐量杀手”

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

解决Nginx启动报错Job for nginx.service failed because the control process exited with error code问题

《解决Nginx启动报错Jobfornginx.servicefailedbecausethecontrolprocessexitedwitherrorcode问题》Nginx启... 目录一、报错如下二、解决原因三、解决方式总结一、报错如下Job for nginx.service failed bec

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

MySQ中出现幻读问题的解决过程

《MySQ中出现幻读问题的解决过程》文章解析MySQLInnoDB通过MVCC与间隙锁机制在可重复读隔离级别下解决幻读,确保事务一致性,同时指出性能影响及乐观锁等替代方案,帮助开发者优化数据库应用... 目录一、幻读的准确定义与核心特征幻读 vs 不可重复读二、mysql隔离级别深度解析各隔离级别的实现差异

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基