MX6Q-MIPIDSI - himax8394f驱动driver加载

2024-03-16 15:10

本文主要是介绍MX6Q-MIPIDSI - himax8394f驱动driver加载,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

mipi-dsi在mx6q上只有两条lane,因此用的人比较少。加载过程中网上的资源不多,遇到一些困难,因此做一些总结。
首先linux内核是linux4.0,基于设备树。因此在修改硬件配置时首先要修改设备树。我拿到的内核源码是别人配的差不多的,设备书部分是基于mx6q-sabresd系列的。其中的mipi-dsi部分已经配置完成的,只是其中的channel要修改为你所需要的名字,与driver中的部分匹配上。
驱动中的部分:
static struct mipi_dsi_match_lcd mipi_dsi_lcd_db[] = {
#ifdef CONFIG_FB_MXC_TRULY_WVGA_SYNC_PANEL
 {
  "TRULY-WVGA",    //此处的channel 名字
  {mipid_hx8369_get_lcd_videomode, mipid_hx8369_lcd_setup}
 },
#endif
 {
 "", {NULL, NULL}
 }
};
设备树部分:
其中的mipi节点
&mipi_dsi {
 dev_id = <0>;
 disp_id = <1>;
 lcd_panel = "TRULY-WVGA";//此处的channel名字。
 disp-power-on-supply = <&reg_mipi_dsi_pwr_on>;
 resets = <&mipi_dsi_reset>;
 status = "okay";
};
mxcfb节点
mxcfb1: fb@0 {                                                                                                                                 
182         compatible = "fsl,mxc_sdc_fb";
183         disp_dev = "mipi_dsi";
184         interface_pix_fmt = "RGB24";
185         mode_str = "TRULY-WVGA";//此处的名字也要匹配上。显示时才会有图像。
186         default_bpp = <24>;
187         int_clk = <0>;
188         late_init = <0>;
189         status = "okay";
190     };
在mipi-dsi的probe函数中:
ret = of_property_read_string(np, "lcd_panel", &lcd_panel);
这句就会将设备树中的lcd_panel字符串取出来,用于在lcd_init函数中对字符串进行匹配。
这样做的意义在于,你可以在内核中加载多款的lcd驱动,比如himax-8394,或者联泳的,等等,而当你换屏的时候只要修改设备树就可以实现驱动的变换,而不需要修改内核代码了。
匹配成功后内核会调用
mipi_dsi_enable指针指向的函数,此函数中就会包含lcd的set_up回调函数指针的调用了。
以上只是一个大概的流程。set_up函数中会调用mipi-dsi的DCS命令,对himax-8394F芯片进行初始化。初始化之前一定要进行reset,要么初始化有可能会不成功。
himax8394的datasheet中,写到支持的命令如下:


其中我们发现它下载长命令字用的是39H,而我一开始一直用的是29H,所以一直不成功,搞了很久。也不明白原因,因为没有明确写不支持29H,所以我也百分百确定不支持,但是39H绝对没错。
mx6q的D-PHY是飞思卡尔自己做好的,我们不用关心,我们所需要做的工作就是给LCD芯片初始化以及一下系统参数的配置。在初始化过程中,加一些log,可以查看读取的ID是否成功,如果成功说明通信是没有问题的。如果可以LCD上的电容,上面有10多V的电压,说明初始化就成功了。我说了什么啊,感觉自己表达就不清楚……

























这篇关于MX6Q-MIPIDSI - himax8394f驱动driver加载的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

Flutter 进阶:绘制加载动画

绘制加载动画:由小圆组成的大圆 1. 定义 LoadingScreen 类2. 实现 _LoadingScreenState 类3. 定义 LoadingPainter 类4. 总结 实现加载动画 我们需要定义两个类:LoadingScreen 和 LoadingPainter。LoadingScreen 负责控制动画的状态,而 LoadingPainter 则负责绘制动画。

驱动(RK3588S)第七课时:单节点设备树

目录 需求一、设备树的概念1、设备树的后缀名:2、设备树的语法格式3、设备树的属性(重要)4、设备树格式举例 二、设备树所用函数1、如何在内核层种获取设备树节点:2、从设备树上获取 gpio 口的属性3、获取节点上的属性只针对于字符串属性的4、函数读取 np 结点中的 propname 属性的值,并将读取到的 u32 类型的值保存在 out_value 指向的内存中,函数的返回值表示读取到的

使用WebP解决网站加载速度问题,这些细节你需要了解

说到网页的图片格式,大家最常想到的可能是JPEG、PNG,毕竟这些老牌格式陪伴我们这么多年。然而,近几年,有一个格式悄悄崭露头角,那就是WebP。很多人可能听说过,但到底它好在哪?你的网站或者项目是不是也应该用WebP呢?别着急,今天咱们就来好好聊聊WebP这个图片格式的前世今生,以及它值不值得你花时间去用。 为什么会有WebP? 你有没有遇到过这样的情况?网页加载特别慢,尤其是那

驱动安装注册表指令

HKCR: HKEY_CLASSES_ROOT HKCU: HKEY_CURRENT_USER HKLM: HKEY_LOCAL_MACHINE HKU: HEKY_USER HER: 相对根键

UMDF驱动安装

VS2013 + WDF8.1,UMDF驱动选择User Mode Driver,不要选User Mode Driver 2.0,否则Win7安装有问题,如图 另外,在驱动安装时不要忘记WUDFUpdate_<主版本号><次版本号>.dll文件,具体文件名在INF中查找。此文件可在WDF的安装目录中找到。注意:在WDF的安装目录中会有3个WUDFUpdate_xxx.dll文件,x86,x6

gazebo 已加载模型但无法显示

目录 写在前面的话问题一:robot_state_publisher 发布机器人信息失败报错一 Error: Error document empty.报错二 .xcaro 文件中有多行注释成功启动 问题二:通过 ros2 启动 gazebo 失败成功启动 问题三:gazebo 崩溃和无法显示模型问题四: 缺少 robot_description 等话题正确的输出 写在前面的话

电脑驱动分类

电脑驱动程序(驱动程序)是操作系统与硬件设备之间的桥梁,用于使操作系统能够识别并与硬件设备进行通信。以下是常见的驱动分类: 1. 设备驱动程序 显示驱动程序:控制显卡和显示器的显示功能,负责图形渲染和屏幕显示。 示例:NVIDIA、AMD 显示驱动程序。打印机驱动程序:允许操作系统与打印机通信,控制打印任务。 示例:HP、Canon 打印机驱动程序。声卡驱动程序:管理音频输入和输出,与声卡硬件

JVM类的加载器及加载过程

类的加载器及加载过程 文章目录 类的加载器及加载过程类的加载过程加载:链接(验证、准备、解析):初始化: 类加载器的分类引导类加载器:BootstrapClassLoader 启动类加载器( C/C++实现,嵌套在JVM内部)自定义类加载器(所有派生于抽象类ClassLoader的类加载器)获取ClassLoader的途径 双亲委派机制(重点)判断两个Class对象是否为同一个类

Unity Adressables 使用说明(六)加载(Load) Addressable Assets

【概述】Load Addressable Assets Addressables类提供了加载 Addressable assets 的方法。你可以一次加载一个资源或批量加载资源。为了识别要加载的资源,你需要向加载方法传递一个键或键列表。键可以是以下对象之一: Address:包含你分配给资源的地址的字符串。Label:包含分配给一个或多个资源的标签的字符串。AssetReference Obj