基于Linux内核的OMAP3530 LCD屏驱动调试小记
背景: 公司要在 OMAP3530平台上做产品,现在处于技术调查阶段。需求点之一是修改现有的3寸LCD屏为7寸屏。 问题: 我们使用 的是瑞泰提供的开发板,开发文档中有关于屏使用的介绍。按照文档中提供的内核编译选项,找到对应的LCD屏驱动文件后,进行参数设定,没有效果,(最明显 的一个参数是时钟频率,修改后,应当花屏,事实上是还正常显示)。 解决过程: 1、把参数都改乱测试,没有效果,怀疑修改错文 件。 2、取消模块向DSS系统的注册动作,屏幕变黑,说明所修改文件还是起作用的。 3、找瑞泰技术支持询问,没有得到有用的 答案,放弃使用询问技术支持的权利。 4、OMAP相关技术群里寻找有这方面经验的人,提供参考意见,有经验的人都说改那文件的参数就起作用 的,见鬼了。 5、联机调内核,跟踪代码试试。结果联机调很麻烦,配了半天环境没配成,放弃此方案。 6、使用最古老的打LOG 方式,在相关地方都打上调试信息的输出,配合SourceInsigh查看代码的调用流程,最终找到了问题所在。 问题原因: 内核启动时,给omapfb模块传入了显示设置的参数470×272MR-16@60,显示子系统(DSS)解析此参数,并对所显示结构体中的 panel->timings成品进行赋值,而此成员的值便是瑞泰文档中所提到的驱动文件中设定的,因此无论在该文件如何修改参数,系统都能正常显 示。 修改方案: 修改解析参数并给display->panel->timings赋值的地方,取消赋值操 作。 方案验证: 修注释掉该调用后,系统直接崩溃。 新问题调查: 定位出问题的代码行后, 发现我们的参数在设置时,超出了合法范围,改小该值,并使用示波器测试时钟频率和相应信号与在驱动文件中设定的值相同。问题最终解决,总共使用时间七个工 作日。
- 分享
- 举报

-
浏览量:426次2020-06-29 10:47:11
-
浏览量:2128次2017-11-30 17:16:20
-
浏览量:415次2020-04-27 16:58:40
-
浏览量:559次2017-12-15 10:43:45
-
浏览量:571次2020-08-06 20:14:59
-
浏览量:367次2020-08-03 11:18:53
-
浏览量:489次2019-06-29 09:33:08
-
浏览量:531次2020-07-31 13:45:09
-
浏览量:766次2017-09-28 11:37:40
-
浏览量:504次2020-07-17 16:50:14
-
浏览量:375次2020-04-15 20:06:48
-
浏览量:437次2017-11-24 11:39:01
-
2020-07-29 18:32:39
-
浏览量:2720次2018-08-28 16:40:09
-
浏览量:411次2020-05-21 19:20:01
-
浏览量:488次2017-12-02 22:05:15
-
浏览量:484次2020-07-13 17:40:25
-
浏览量:502次2020-08-03 11:21:38
-
浏览量:945次2017-11-15 11:07:22
-
广告/SPAM
-
恶意灌水
-
违规内容
-
文不对题
-
重复发帖

yybingyybing







举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明