本文转载自:http://blog.csdn.net/u014770862/article/details/76274951?locationNum=2&fps=1

RK平台LCD调试说明

原创 2017年07月28日 18:51:00

本篇博文使用Rockchip平台RK3288主控,向大家分享自己总结的Rockchip平台LCD调试的一些经验。不足之处,敬请谅解!

Platform : Rockchip 
Soc : RK3288 
System : Android 5.1


RK3288的LCD调试,根据屏幕规格书对dts作相应的修改基本都可点亮,配置也较为简单,有几个概念容易混淆,单纯的点屏基本上不需要了解相关的LVDS,EDP协议等。本篇博客大致讲述RK平台LVDS、EDP屏的调试经验,协议部分不会涉及,MIPI屏部分暂时还未深入了解。

前言

在fb驱动这块,大致分为了四部分,rk_screen首先会读取dts中screen信息,传给screen_type驱动(本例也就是rk32_lvds.c),这些信息最终都会被fb获取。详细的流程分析请参考博文:RK平台fb源码分析系列

LVDS调试

dts实例

贴一个LVDS屏参的实例,仅供参考:
            disp_timings: display-timings {
native-mode = <&timing0>;
timing0: timing0 {
screen-type = <SCREEN_LVDS>;
lvds-format = <LVDS_8BIT_2>;
out-face = <OUT_P888>;
color-mode = <COLOR_RGB>;
clock-frequency = <43000000>; //43000000
hactive = <1024>;
vactive = <600>;
hback-porch = <100>;
hfront-porch = <60>;
vback-porch = <10>;
vfront-porch = <8>;
hsync-len = <5>;
vsync-len = <2>;
hsync-active = <0>;
vsync-active = <0>;
de-active = <0>;
pixelclk-active = <1>;
swap-rb = <0>;
swap-rg = <0>;
swap-gb = <0>;
}; };

参数看起来挺多的,其实真正需要改的一般不多。那究竟哪些都需要修改呢?这当然是根据不同的LCD参考其规格书修改的,dts中需要重点关注的有以下几个参数: 
screen_type,lvds-format,out-face,clock-frequencyhactivevactive,hbp,hfp,vbp,vfp

screen_type

screen-type表示屏幕类型(RGB,LVDS,EDP,MIPI,HDMI,MCU),如果该屏幕为LVDS屏,则screen-type就
应该取值为SCREEN_LVDS。如果是RGB屏幕,则screen-type取值为SCREEN_RGB。screen-type的值有以下
几种:
SCREEN_RGB,SCREEN_LVDS(SCREEN_DUAL_LVDS,SCREEN_LVDS_10BIT,SCREEN_DUAL_LVDS_10BIT)
,SCREEN_HDMI,SCREEN_MIPI,SCREEN_DUAL_MIPI、SCREEN_EDP
#define SCREEN_NULL        0
#define SCREEN_RGB 1
#define SCREEN_LVDS 2
#define SCREEN_DUAL_LVDS 3
#define SCREEN_MCU 4
#define SCREEN_TVOUT 5
#define SCREEN_HDMI 6
#define SCREEN_MIPI 7
#define SCREEN_DUAL_MIPI 8
#define SCREEN_EDP 9
#define SCREEN_TVOUT_TEST 10
#define SCREEN_LVDS_10BIT 11
#define SCREEN_DUAL_LVDS_10BIT 12

lvds_format

lvds-format表示LVDS的数据方式,只有在该屏幕是LVDS屏的时候该参数才有效。该值需要结合屏幕和LVDS在
硬件上的连接方式来定义。lvds_format的值有以下几种:LVDS_8BIT_1、LVDS_8BIT_2、LVDS_8BIT_3、
LVDS_6BIT。
#define LVDS_8BIT_1     0
#define LVDS_8BIT_2 1
#define LVDS_8BIT_3 2
#define LVDS_6BIT 3
#define LVDS_10BIT_1 4
#define LVDS_10BIT_2 5

LCD的datasheet一般都会说明LVDS信号在各个通道上的分配方式,如下: 

如上图所示,我们将LVDS通道分为Y0、Y1、Y2、Y3,其中Y0对应于上图的Rxin0,Y1对应于上图的Rxin1,Y2和Y3以此类推,一个通道可以传输7bit数据。根据规格书,那么lvds-format我们究竟选择哪一个呢?这几种格式得区别如下: 
 
当然了,事事无绝对,上述判断只能得出大概结论,不能100%保证正确。主要还是由于屏线的原因,开发板底座和屏之间并不是一一对应起来的,也就是说屏的引脚和底座之间排线的选择并不唯一。不过,最为稳妥的方法应该是根据” LVDS Data Input Format”与屏引脚定义来判断lvds-format,因为我们总是要满足”屏”(最起码屏线不要接错)。

LVDS两种format:FORMAT 1、 FORMAT 2 
两者主要区别在于Y3通道上FORMAT 1传输的是颜色的高两位,FORMAT 2传输的是颜色的低两位。通常LCD显示有水彩,就是lvds-format设置错误,调换format即可。

液晶屏中常见的LVDS数据映射标准(将像素的并行数据转化为串行数据)有VESA和JEIDA两种格式,一般情况下均是默认JEIDA格式。有些LVDS屏也会在datasheet中说明: 
 
这款LG的LVDS屏,当第7脚为高电平时,逻辑板工作在JEIDA格式下,为低电平或NC时工作在VESA格式下。两种格式的区别如下: 
 
 
从规格书中可以发现,两种格式的区别主要在于第3通道(D)上,JEIDA格式的第三通道是各种颜色的低两位(R0 R1 G0 G1 B0 B1),而VESA格式的第三通道上传输的是颜色的高两位(R6 R7 G6 G7 B6 B7)。对应于dts中的lvds_format,也就等同于: 
JEIDA —-> LVDS_8BIT_2 
VESA —-> LVDS_8BIT_1

LVDS有多种数据传输模式:单路6bit LVDS、双路6bit LVDS、单路8bit LVDS、双路8bit LVDS 
SoC中,单路还是双路工作方式不同: 
 

因此,单路或是双路处理方式不同而已。事实上,单双路的控制就是通过配置lvds dual cnannel control的开关,配置如下: 

而代码中,也是这样控制来作区分的(可参考博文RK FB源码分析之SCREEN_TYP)

如何从屏幕规格书中来区分是单路还是双路? 
有的规格书会简述,如:LVDS(1 ch,8 bit),表示LVDS接口类型是单通道,8bit的信号带宽(RGB每色有8阶色彩,总色为2^8*2^8*2^8=1677W色)。 
最直观简单的方式就是从屏的引脚定义分析,通常双路LVDS屏都会有odd(or first) input channel和even(or second) input channel,例如: 
 
而单路LVDS通常只有三组或者四组data input和一组clock,例如: 

clock-frequency

双路LVDS时,clocks要取LCD规格书中典型值的2倍
单路LVDS时,clocks取LCD规格书中的典型值即可

out-face

屏幕采用多少位的接线方式。如果是24bit的屏幕,则为OUT_P888;如果是18bit的屏幕, 数据线分别接在每种
单元色的高六位则定义为OUT_D888_P666(就是B0 B1 G0 G1 R0 R1不接),如果数据线接在LCDC的低 18 位
(connect to lcdc D0~D17),则定义为 OUT_P666。这个如果设置的不正确,比如 24bit 的接法,定义成
OUT_D888_P666或者OUT_P666 就有可能出现色阶。

该参数可判断规格书Display Colors的值做参考。

其它参数

hback-porch,hfront-porch,vback-porch ,vfront-porch,hsync-len,vsync-len 
上述六个参数按照规格书来填充(目前大多数屏都是DE mode,DE模式的话一般都会标明DE mode only),DE模式只需要关注两个参数Vertical section blanking和Horizontal section blanking,例如: 
 
上图中,Vertical section blanking=42, Horizontal section blanking=204,在填充6个参数时只需要满足关系:vbp+vfp+vs=42,hbp+hfp+hs=204,各值自行分配(通常hbp和vbp取较大值),例如 
hback-porch = <150>; 
hfront-porch = <50>; 
vback-porch = <30>; 
vfront-porch = <11>; 
hsync-len = <4>; 
vsync-len = <1>;

hsync-active,vsync-active,de-active,pixelclk-active,各参数含义如下: 
hsync-active: hsync pulse is active low/high/ignored 
vsync-active: vsync pulse is active low/high/ignored 
de-active: data-enable pulse is active low/high/ignored 
pixelclk-active:

active high = drive pixel data on rising edge/ sample data on falling edge
active low = drive pixel data on falling edge/ sample data on rising edge
ignored = ignored

其中,需要注意参数pixelclk-active,该参数控制有效的pixel data数据在rising edge还是falling edge显示.LVDS显示有雪花点,噪点等情况时可调整该参数。

EDP调试

待续

RK平台LCD调试说明【转】的更多相关文章

  1. 高通平台 lcd driver 调试小结

    一.概述 1.1 简介 本文档主要包括LCD模块的驱动流程分析.Framebuffer相关知识.Gralloc等相关内容,以及LCD调试的一些经验和相关bug的分析和讲解. 1.2  开发环境 And ...

  2. 高通Android平台硬件调试之Camera篇

    之前一段时间有幸在高通android平台上调试2款camera sensor,一款是OV的5M YUV sensor,支持jpeg out,同时也支持AF,调试比较比较简单,因为别的项目已经在使用了, ...

  3. MTK65XX平台充电调试总结

    MTK平台充电调试总结 摘要:调试电池的充放电管理,首先须要深入了解锂电池的电池原理和特点.充放电特性以及主要的电池安全问题.然后须要对MTK的电池管理驱动程序有深入的了解.理解电池充放电算法的基本原 ...

  4. React Native移动开发实战-5-Android平台的调试技巧

    Android平台的调试和其他平台的调试也很类似,例如:在Android Studio打开的工程中,打开源码MainActivity.java,然后,将鼠标移至代码编辑区的左侧后,单击鼠标即可添加断点 ...

  5. 如何把rtl8188EUS驱动编译生成ko模块并且下载到rk平台Android4.2.2上使用

    下了rtl8188EUS_linux_v4.3.24_16705.20160509.tar.gz,看了里面的数据手册,发现有些看不懂,上网搜了一下,发现大部分博客都在扯淡...后来还是我把Makefi ...

  6. LCD调试1.0

    所谓调lcd timing就是去调lcd时序,一般是6个部分:HFPD(在一行扫描以前需要多少个像素时钟),HBPD(一行扫描结束到下一行扫描开始需要多少个像素时钟),VFPD(一帧开始之前需要多少个 ...

  7. LCD调试

    (1) 液晶显示模式 并行:MCU接口.RGB接口.Vysnc接口 串行:SPI接口.MDDI接口 (2) 屏幕颜色 实质上即为色阶的概念.色阶是表示手机液晶显示屏亮度强弱的指数标准,也就是通常所说的 ...

  8. hud项目lcd调试过程的一些见解

    1.帧缓冲(FrameBuffer)设备驱动帧缓冲设备为标准的字符型设备,在Linux中主设备号29,定义在/include/uapi/linux/major.h中的FB_MAJOR,次设备号定义帧缓 ...

  9. LCD 调试总结

    (1) 液晶显示模式 并行:MCU接口.RGB接口.Vysnc接口 串行:SPI接口.MDDI接口 (2) 屏幕颜色 实质上即为色阶的概念.色阶是表示手机液晶显示屏亮度强弱的指数标准,也就是通常所说的 ...

随机推荐

  1. Cannot delete or update a parent row: a foreign key constraint fails....

    在操作”小弟“这张表时候报错 想在“小弟”上面加入数据或者更新数据,就要听老大的, 这句话后面跟着的表就是“老大”,必须老大有数据索引,“小弟“才可以加入或者更新 查看“小弟”表的外键,会发现有对“老 ...

  2. luogu2485 [SDOI2011]计算器 poj3243 Clever Y BSGS算法

    BSGS 算法,即 Baby Step,Giant Step 算法.拔山盖世算法. 计算 \(a^x \equiv b \pmod p\). \(p\)为质数时 特判掉 \(a,p\) 不互质的情况. ...

  3. jquery怎么获得ul中li的个数

  4. 1284-Primitive Roots,学信安的路过

                                                      Primitive Roots 此题通过率如此之高,料想不会很难,但是再简单小菜还是不会.. 嗯,下 ...

  5. CodeForces 22、23部分题解

    CodeForces 22A 找严格第二小的...注意只有一种情况,可以sort排序然后unique输出. int a[N]; int main() { int n; while(~scanf(&qu ...

  6. [luoguP2704] 炮兵阵地(状压DP)

    传送门 可以事先把每一行的所有状态处理出来,发现每一行的状态数最多不超过60个 f[i][j][k]表示前i行,第i行为状态j,第i-1行为状态k的最优解 #include <vector> ...

  7. 【HDOJ6312】Game(博弈)

    题意: 有一个1到n的序列,两个人轮流取数,取走一个数同时会取走它所有的因子,不能取者为输,两个人都按最优策略取数,问先手是否必胜 思路: #include<cstdio> #includ ...

  8. 【HDOJ6299】Balanced Sequence(贪心)

    题意:给定n个只有左右括号的序列,要求将它们重新排序使得匹配的括号对数最大. n<=1e5 s[i]<=1e5 sum s[i]<=5e6 思路: 先把每个串内部的匹配数量减去,剩下 ...

  9. CF613A:Peter and Snow Blower

    用一个圆心在(x,y)的圆环覆盖一个n边形,顺或逆时针给出n边形所有顶点,求圆环最小面积. 卡了好久,各种傻逼错误.. 题目就是让我们固定一大一小两个边界圆,我们来看看这两个圆满足什么条件. 首先外面 ...

  10. 深入理解计算机操作系统——第11章:CS模型,网络

    网络编程: 11.1 客户端-服务器编程模型 (1)一个应用是由一个服务器进程和一个或多个客户端进程组成. (2)服务器管理某种资源,并且操纵这种资源来为客户端服务. CS模型: CS的基本操作是事务 ...