RK平台LCD调试说明

本文分享了Rockchip平台RK3288主控的LCD调试经验,重点介绍了LVDS屏的dts配置方法及注意事项,包括screen_type、lvds_format、out-face等关键参数的理解与设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本篇博文使用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调试

待续

### 回答1: PSPICE 17.2 是一种用于电子电路仿真和分析的软件工具。下面是一份简单的 PSpice 17.2 使用初级教程: 1. 安装和启动:首先,你需要下载并安装 PSpice 17.2 软件。安装完成后,双击图标启动软件。 2. 创建电路:在软件界面上,选择“文件”>“新建”,然后在电路编辑器中创建你的电路。你可以从元件库中选择组件,并将其拖放到画布上。连接元件的引脚以构建电路。 3. 设置元件参数:双击元件以打开元件参数设置对话框。在对话框中,设置元件的值、名称和其他参数。对于电阻、电容等基本元件,可以直接输入数值。 4. 设置仿真配置:选择“仿真”>“设置和校验”,然后在仿真设置对话框中选择仿真的类型和参数。你可以选择直流分析、交流分析、暂态分析等。设置仿真参数后,点击“确定”。 5. 运行仿真:选择“仿真”>“运行”来启动仿真。在仿真过程中,软件将模拟电路的响应,并将结果输出到仿真波形窗口中。 6. 查看仿真结果:在仿真波形窗口中,你可以查看各个元件的电流、电压等参数随时间变化的波形。你还可以对波形进行放大、缩小、平移等操作,以更详细地分析电路的性能。 7. 保存和导出结果:在仿真过程中,你可以选择将结果保存为文件或导出为其他格式,如图像文件或数据文件。 以上是 PSpice 17.2 使用初级教程的基本步骤。随着实践的深入,你可以进一步了解复杂电路的建模和分析方法,并尝试更高级的功能和技术。 ### 回答2: PSPICE 17.2是一款电子电路仿真软件,用于对电路进行分析和验证。以下是PSPICE 17.2的使用初级教程: 1. 下载和安装:在官方网站上下载PSPICE 17.2并进行安装。 2. 组件库:打开PSPICE软件后,点击“Capture CIS”图标,进入组件库界面。选择适当的电子元件,如电阻、电容、二极管等,将它们拖放到画布上。 3. 电路连接:在画布上拖放所需元件后,使用导线工具连接它们。点击导线图标,选择合适的连接方式,并将其拖动到适当的端口上。 4. 参数设定:双击元件,弹出元件属性对话框。在这里设置元件的数值,例如电阻的阻值、电容的电容值等。 5. 电源设置:在画布上点击右键,选择“Power Sources”,然后选择适当的电源,如直流电源或交流电源。设置电源的电压或电流数值。 6. 仿真设置:点击画布上方的“PSpice”选项,选择“Edit Simulation Profile”打开仿真配置对话框。在仿真配置中,设置仿真参数,如仿真类型(直流、交流、脉冲等)、仿真时间等。 7. 仿真运行:在仿真配置对话框中点击“Run”按钮,开始进行电路仿真运行。仿真完成后,可以查看并分析仿真结果,如电流、电压、功率等。 8. 结果分析:通过菜单栏中的“PSpice>Probe”选项,打开特定信号的仿真结果。通过选择信号节点,可以显示该信号的波形、幅值和频谱等信息。 9. 数据输出:仿真结束后,可以通过“PSpice>Results”菜单栏选项,导出仿真结果到文本文件,以供后续分析。 10. 误差调整:如果仿真结果与预期不符,可以检查电路连接、元件参数等以找出问题。根据需要进行调整,重新运行仿真以验证改进效果。 以上就是PSPICE 17.2使用初级教程的简要介绍。在使用过程中,请参考软件的帮助文件和官方文档,以获取更详细的指导和解决方法。任何新的软件都需要不断的实践和尝试,希望这个教程能对你有所帮助。 ### 回答3: PSPICE 17.2是一款常用的电路仿真软件,用于电路设计和分析。下面是一个简要的PSPICE 17.2的初级教程: 1. 下载和安装:首先,从官方网站下载PSPICE 17.2,并按照安装向导进行安装。安装完成后,打开软件。 2. 创建新工程:在PSPICE 主界面上,点击“File”菜单,然后选择“New Project”来创建一个新的工程。给工程起一个适当的名字,并选择工程的存储位置。 3. 添加电路元件:在工程界面上,点击“Place”图标,然后选择不同的元件来构建你的电路。你可以从库中选择各种电子元件,如电阻、电容、电感等,并将它们拖放到工程界面上。 4. 连接元件:选择“Wire”图标,然后点击元件的引脚来连接它们。确保连接顺序正确,以保证电路的正确性。 5. 设置元件参数:对于每个添加的元件,你需要设置它们的参数。右键点击元件,选择“Edit Propertiess”,然后在弹出的窗口中输入适当的参数值。 6. 添加电源:在电路中添加电源,以提供电路所需的电能。选择“Place”图标,然后选择合适的电源元件并将其拖放到电路中。同样,设置电源的参数值。 7. 设置仿真配置:在工程界面上,点击“PSpice”菜单,然后选择“Edit Simulation Profile”来设置仿真配置参数。你可以选择仿真类型、仿真时间和仿真步长等。 8. 运行仿真:点击“PSpice”菜单,选择“Run”来运行仿真。PSPICE将自动运行仿真并显示结果。 9. 分析和优化:根据仿真结果,可以分析和优化电路的性能。你可以观察电流、电压和功率等参数,以评估电路的性能,并根据需要进行调整。 10. 保存和导出结果:在分析和优化完成后,可以保存你的工程并导出结果。点击“File”菜单,选择“Save Project”来保存工程,然后选择“Outut”菜单,选择“Export”来导出结果。 以上是PSPICE 17.2的初级教程的简要介绍。通过以上步骤,你可以开始使用PSPICE 17.2进行电路设计和仿真。在实践中不断探索和学习,你将成为一个熟练的PSPICE用户。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值