LCM兼容

1、project-1998-trunk-bootable-bootloader-lk-project:   复制zaw1998aa_platform.mk为zaw2000aa_platform.mk
里面修改:
CONFIG_CUSTOM_LK_LCM="hx8394d_dsi_vdo_zaw1998 zx_dsi_vdo_zaw2000"

2、project-1998-trunk-bootable-bootloader-lk-dev-lcm:   ...._lcm_list.c里面加extern
#if defined(ZX_DSI_VDO_ZAW2000)                               //自定义
extern LCM_DRIVER zx_dsi_vdo_zaw2000_lcm_drv;
#endif
LCM_DRIVER* lcm_driver_list[] =
{
#if defined(ZX_DSI_VDO_ZAW2000)
        &zx_dsi_vdo_zaw2000_lcm_drv,
        #endif
....
}
3、project-1998-trunk-bootable-bootloader-lk-dev-lcm:   3.1在添加的屏的文件夹zx_dsi_vdo_zaw2000里面的makefile文件里修改
obj-y += hx8394d_dsi_vdo_zaw1998.o zx_dsi_vdo_zaw2000.o
在驱动文件zx_dsi_vdo_zaw2000里面修改
LCM_DRIVER zx_dsi_vdo_zaw2000_lcm_drv =  
{
    .name            = "zx_dsi_vdo_zaw2000"
    ....
}

4、trunk-kernal-3.10-arch-arm-configs:                  platform_debug_defconfig
zaw1998aa_platform_debug_defconfig和zaw1998aa_platform_defconfig的区别:带debug是eng版本的,不带是user版本的
在1166行原来:
CONFIG_CUSTOM_KERNEL_LCM="hx8394d_dsi_vdo_zaw1998"
修改后:CONFIG_CUSTOM_KERNEL_LCM="hx8394d_dsi_vdo_zaw1998 zx_dsi_vdo_zaw2000"

5、trunk-kernal-3.10-drivers-misc-mediatek-lcm—:       .._lcm_list.c里面加extern

kernal\  Mtkfb.c:___mtkfb_probe(struct device *dev)___disp_drv_.c\DISP_SelectDevice(NULL)___disp_hal_.c\LCM_DRIVER  *disphal_get_lcm_driver___lcm = lcm_driver_list[0]____Mt65xx_lcm_list.c\LCM_DRIVER* lcm_driver_list[]=

bootloader\lk\platform\mt6735\platform.c
mt_disp_Init((void)*g_fb_base)
 DISP_CHECK_RET(DISP_Init((UINT32)lcdbase, (UINT32)lcdbase, FALSE));
disp_drv_init_context()
 DISP_DetectDevice()
lcm_drv = disp_drv_get_lcm_driver(NULL);

kernal-3.10-drivers-misc-mediatek-video-mt6582:  disp_hal_.c   *disphal_get_lcm_driver(const char *lcm_name)

platform总线注册:kernal/init :Main.c    asmlinkage void __init start_kernel(void)(内核的初始化过程由start_kernel函数开始,它完成了内核的大部分初始化工作)——>rest_init——>kernel_thread(这个线程创建很重要)——>kernel_init——>kernel_init_freeable——>do_basic_setup——>void __init driver_init(void)(kernal/driver/base/Init.c)——>platform_bus_init(kernal/driver/base/platform.c)

kernal\drivers\base
platform_driver_registe:向系统注册设备——>driver_register——>bus_add_driver——>void driver_attach(struct device_driver * drv):——>  bus_for_each_dev(drv->bus, NULL, drv, __driver_attach):遍历总线上的设备,执行一次__driver_attach(),看能不能将驱动关联(attach)到某个设备上去——>__driver_attach——>driver_match_device——>drv->bus->match——>(*match)(struct device *dev, struct device_driver *drv)==0;——>driver_probe_device(drv, dev)——>driver_probe_device(drv, dev)——>really_probe——>dev->bus->probe(dev)
这里找到总线类型中的match函数,这里只是个函数指针,很明显platform_bus_type结构下有具体match的实现,匹配后会自动调用驱动下的probe函数:platform_drv_prober(在platform_driver_registe函数中定义了指针函数,使probe指向platform_drv_probe:drv->driver.probe = platform_drv_probe)

而每当我们向一根bus添加一个硬件时时,套路是这样

kernal\drivers\base:platform.c
plateform_device_register
platform_device_add
kernal\drivers\base:core.c
device_add()
\\ device_add 中有很多操作kobject,注册sysfs,形成硬件hiberarchy结构的代码。
如果您忘记了,先回头去参考参考"我是sysfs"
-> bus_probe_device(struct device *dev) -> device_attach() (driver/base:dd.c)->bus_for_each_drv()
bus_for_each_drv与bus_for_each_dev类似,遍历该总线上所有的driver,执行一次__device_attach(),看能不能将设备关联(attach)到某个已登记的驱动上去。
__device_attach()
->driver_probe_device() //后面与上面一样

platform_driver结构体:platform_device.h
static struct platform_device mt6575_device_fb  :Mt_devs.c(定义设备与资源的地方)

时间: 2024-08-06 14:44:55

LCM兼容的相关文章

高通平台MSM8916LCM模块移植(一)-bootloader部分【转】

本文转载自:http://www.mobile-open.com/2016/970947.html 高通平台中的bootloader叫做LK(Little Kernel,对于LCM来说LK部分相当重要,它不仅要负责开机部分的LCD显示任务,还要负责传参给kernel的LCM驱动,指导kernel选择合适的LCM参数. 1.LK中LCM启动流程 注:read_panel_id()和read_panel_id_ddr3()为私有添加,非高通库上代码. 在这个流程图中,需要着重了解的有oem_pane

android 不同分辨率的LCM进行兼容

1. 关于时序 JB版本中,接口disp_drv_get_lcm_driver实现compare id并获取到lcm driver以及lcm param的动作,对于DSI,每次尝试读取id之前都会根据lcm driver中的设置重新设置时序,所以担心时序不同无法读取id的担心就显得多余了 2. 关于开机logo 我们默认的做法,在ProjectConfig.mk中会定义Macro BOOT_LOGO方便在目录\mediatek\custom\common\lk\logo中读取到相应的资源,作为开

mtk lcm驱动加载流程 (转载)

平台:mt6582 + Android 4.4 前面就说过,在mtk代码中支持屏是可兼容的,通过调用驱动中的compare_id函数来匹配驱动和屏,这里来细看一下代码. 1. LK部分(mediatek/platform/mt6582/lk/disp_drv.c) [cpp] view plaincopy OOL DISP_DetectDevice(void) { //LCD_STATUS ret; DISP_LOG("shi=>%s, %d\n", __func__, __LI

mtk设备模型之LCM

1.Linux设备模型 站在BSP的角度来看,整个系统可以由三部分组成:设备.总线.驱动. Linux kernel有一些总线,比如USB.I2C等.对于每一个总线都会有一些设备和驱动挂在上面.驱动服务于匹配的设备,使Linux正确的操作硬件设备.当一个设备或者驱动注册到特定的总线上的时候就会触发总线匹配函数,比如一个设备注册到了总线,所有的该总线的驱动都会被枚举,判断是不是可以服务于新添加的设备(一般通过name来匹配),反之亦然. 如果总线匹配成功,就会调用驱动的probe函数,检查指定的硬

MSM8909中LK阶段LCM屏适配与显示流程分析

1.前言 在驱动开发中,我们往往需要适配一些新的屏幕或者调试一些屏幕的参数等,对于Qualcomm的MSM8909这款SoC,当启动Android系统时,会有一个LK阶段,该阶段用来启动Linux内核系统,本文,将简单介绍如何在MSM8909的LK阶段中如何进行LCM屏的兼容和适配流程,并对LK阶段中,LCD屏幕的初始化和显示流程进行简要分析. 2.适配LCM屏幕 3.显示流程分析 4.小结 原文地址:https://www.cnblogs.com/Cqlismy/p/12019317.html

IE6 浏览器常见兼容问题 共23个

1.<!DOCTYPE HTML>文档类型的声明. 产生条件:IE6浏览器,当我们没有书写这个文档声明的时候,会触发IE6浏览器的怪异解析现象: 解决办法:书写文档声明. 2.不同浏览器当中,很多的标签的默认样式不同,如默认的外部丁内补丁. 产生条件:不同浏览器: 解决办法:利用CSS reset文件进行样式的清除,然后再根据需要进行设置. 3.横向双倍外边距 产生条件:在IE6中块元素浮动后,会出现横向双倍margin现象. 解决办法: 在float标签的样式控制中加入display:inl

前端浏览器JavaScript及CSS兼容总结

一. getElementById [标准参考] getElementById 是 Document 接口提供的方法,用于获取一个元素,该方法传入的参数应该是目标元素的 id 属性的值,目标元素的 id 是一个大小写敏感的字符串,并且该 id 在文档内应该是唯一的. [问题描述] 但是在 IE6 IE7 IE8(Q) 中,支持以 document.getElementById(elementName) 的方式获取 name 属性值为 elementName 的 A APPLET BUTTON F

SQL-GROUP BY语句在MySQL中的一个错误使用被兼容的情况

首先创建数据库hncu,建立stud表格. 添加数据: create table stud( sno varchar(30) not null primary key, sname varchar(30) not null, age int, saddress varchar(30) ); INSERT INTO stud VALUES('1001','Tom',22,'湖南益阳'); INSERT INTO stud VALUES('1002','Jack',23,'益阳'); INSERT

【好用的小技巧】win8兼容、网页不让复制

1.今天下了个matlab7,我用的是win8系统,不兼容. 解决:鼠标右键matlab7的快捷键,点击属性,选择兼容性,选择window vista即可运行 2.在一个 网页上看到一个对自己很有帮助的代码,想下.结果发现代码可以预览,可以选择代码中的文字,但是一复制就弹出窗口说积分不够. 解决:存储网页到本地,用word打开网页.然后文字就都可以复制了.