0


RK3568开发笔记-EDP显示屏接口调试记录


前言

    RK3568 CPU提供了丰富的外设接口,本文主要介绍通过edp显示接口驱动edp接口显示屏的具体操作方法以及调试记录。

一、edp显示接口介绍

    随着显示分辨率的越来越高,传统的VGA、DVI等接口逐渐不能满足人们的视觉需求。随后就产生了以HDMI、DisplayPort为代表的新型数字接口,外部接口方面HDMI占据了较大市场优势,但是DisplayPort凭借自身优势调整结构,使之差距正在减少。内部接口方面传统用LVDS,LVDS面对高分辨率的显示越来越吃力,DisplayPort内部接口eDP由此诞生,会在将来逐步取代LVDS,本文主要介绍在RK3568平台上使用edp接口显示屏的具体使用方法。

    RK3568 CPU目前支持edp 1.3接口,4对数据线最大支持2.7Gbps/Lane,最大分辨率支持2560x1600(**切记详细看屏幕参数,如果屏幕分辨率大于该参数,RK3568将驱动不了该显示屏**)

二、edp接口部分原理图

    RK3568部分原理图如下图所示。edp接口才用4对数据线和显示屏相连接,没有单独的时钟线,目前最新的edp接口速率可达8.1Gbps/Lane。

三、edp接口显示屏参数介绍

    调试才用京东方NE173QHM edp接口显示屏,支持4对数据连接,分辨率为2560x1440,屏幕简要描述如下图所示,。

    Signal Timing Specification:该表格中典型时钟频率为667.887Mhz,经过计算得知该时钟为最大刷新率为160hz计算出来的时钟,本文才用60h、75hz刷新率分别验证。

edid table参数:edid中主时钟为161Mhz,该时钟为40hz刷新率始终参数。

四、RK3568设备树参数配置

    本小节主要根据edp接口显示屏的参数来配置设备树文件,来实现对edp接口显示屏的时序调试。

a、背光使能:背光使能脚为gpio2 RK_PD6管教,该管脚来实现对pwm背光的使能控制脚。

    edp-panel {
        status = "okay";
        compatible = "simple-panel";
        power-supply = <&vcc3v3_lcd0_n>;
        enable-gpios = <&gpio2 RK_PD6 GPIO_ACTIVE_HIGH>;
        prepare-delay-ms = <200>;
        enable-delay-ms = <200>;
        unprepare-delay-ms = <200>;
        disable-delay-ms = <200>;
        bus-format = <MEDIA_BUS_FMT_RGB888_1X7X4_SPWG>;
        bpc = <8>;
        backlight = <&backlight>;

        ......
}

b、EDP_HPD 使能:配置该管脚为gpio2 RK_PD0来对edp显示屏信号检测。

&edp {
    status = "okay";
    //hpd-gpios = <&gpio4 RK_PC4 GPIO_ACTIVE_HIGH>;
    hpd-gpios = <&gpio2 RK_PD0 GPIO_ACTIVE_HIGH>;
        force-hpd;

        ports {
                edp_out:port@1 {
                        reg = <1>;

                        edp_out_panel: endpoint {
                //reg = <0>;
                                remote-endpoint = <&panel_in_edp>;
                        };
                };
        };
};

c、显示时序配置:根据屏幕参数章节可知参数,具体配置如下图所示:(不同刷新率的时钟频率计算如下所示)

        display-timings {
                native-mode = <&edp_timing>;

                edp_timing: edp_timing {
                        //clock-frequency = <161912000>;    //40Hz
                        //clock-frequency = <242868000>;    //60Hz
                        clock-frequency = <303585000>;        //75Hz
                        hactive = <2560>;
                        vactive = <1440>;
                        
                        hfront-porch = <48>;
                        hsync-len = <32>;
                        hback-porch = <80>;
                        
                        vfront-porch = <2>;
                        vsync-len = <4>;
                        vback-porch = <34>;
                        
                        hsync-active = <0>;
                        vsync-active = <0>;
                        de-active = <0>;
                        pixelclk-active = <0>;
                };
        };

各项参数含义

clock-frequency: 提供给lcd的时钟频率,一般屏的规格书都会给出, 也可以通过计算得到。假如刷帧率是40hz,横向分辨率2560,纵向分辨率1440;那么lcd的时钟频率 dclk = 2560x1440x40 = 161.912MHz。
hactive: 横向分辨率2560。
vactive:纵向分辨率2440。
hsync-len 行同步回扫时间。
hback-porn: 行同步后肩时间。
hfront-porn:行同步前肩时间。
vsync-len: 帧同步回扫时间。
vback-porch: 帧同步后肩时间。
vfront-proch: 帧同步前肩时间。
de-active: DE 信号极性。
hysnc-active: 行同步信号极性。
vsync-active: 帧同步信号极性

根据edid参数表可知hback-porch + hfront-porch + hsync-len = 160,vback-porch + vfront-porch + vsync-len = 40(其中三个参数配置等于总值即可,具体可以细微调整)。

五、完整DTS edp参数

edp-panel {
        status = "okay";
        compatible = "simple-panel";
        power-supply = <&vcc3v3_lcd0_n>;
        enable-gpios = <&gpio2 RK_PD6 GPIO_ACTIVE_HIGH>;
        prepare-delay-ms = <200>;
        enable-delay-ms = <200>;
        unprepare-delay-ms = <200>;
        disable-delay-ms = <200>;
        bus-format = <MEDIA_BUS_FMT_RGB888_1X7X4_SPWG>;
        bpc = <8>;
        backlight = <&backlight>;
                
        display-timings {
                native-mode = <&edp_timing>;

                edp_timing: edp_timing {
        //clock-frequency = <161912000>;            //40
                        //clock-frequency = <242868000>;            //60
        clock-frequency = <303585000>;        //75
                        hactive = <2560>;
                        vactive = <1440>;
                        
                        hfront-porch = <48>;
                        hsync-len = <32>;
                        hback-porch = <80>;
                        
                        vfront-porch = <2>;
                        vsync-len = <4>;
                        vback-porch = <34>;
                        
                        hsync-active = <0>;
                        vsync-active = <0>;
                        de-active = <0>;
                        pixelclk-active = <0>;
                };
        };
        
        ports {
                panel_in_edp: endpoint {
                        remote-endpoint = <&edp_out_panel>;
                };
        };
        };

    &edp {
    status = "okay";
    //hpd-gpios = <&gpio4 RK_PC4 GPIO_ACTIVE_HIGH>;
    hpd-gpios = <&gpio2 RK_PD0 GPIO_ACTIVE_HIGH>;
        force-hpd;

        ports {
                edp_out:port@1 {
                        reg = <1>;

                        edp_out_panel: endpoint {
                //reg = <0>;
                                remote-endpoint = <&panel_in_edp>;
                        };
                };
        };
};

&edp_phy {
        status = "okay";
};

&edp_in_vp0 {
        status = "okay";
};

&edp_in_vp1 {
        status = "disabled";
};

&route_edp {    
        status = "okay";
    logo,uboot = "logo.bmp";
    logo,kernel = "logo.bmp";
    logo,mode = "center";
    charge_logo,mode = "center";
    connect = <&vp0_out_edp>;
};

六、RK3568多屏显示vop选择

    在RK3568如需多屏幕同显,必须为不同的显示接口屏幕配置好vop通道,其中vop0可以用做hdmi、mipi、edp等显示接口使用,vop1可以用作hdmi、mipi、edp、lvds等显示接口使用,vop2可以用作lvds、rgb等显示接口使用。

同时开启三个vop接口配置如下:

&vop {
    status = "okay";
    assigned-clocks = <&cru DCLK_VOP0>,<&cru DCLK_VOP1>,<&cru DCLK_VOP2>;
    assigned-clock-parents = <&pmucru PLL_HPLL>, <&cru PLL_VPLL>;
};

如果edp接口屏幕显示分辨率较大,可以配置vop0显示通道。

七、调试遇到的问题

a、屏幕闪屏

可以加大显示屏时钟频率。

2、多屏显示异常

  • 调整vop显示通道

总结

上述为本人在RK3568平台调试edp接口显示屏的开发记录,希望提供一定的的参考。

标签: c语言 架构 linux

本文转载自: https://blog.csdn.net/qq_18376583/article/details/128995542
版权归原作者 flypig哗啦啦 所有, 如有侵权,请联系我们删除。

“RK3568开发笔记-EDP显示屏接口调试记录”的评论:

还没有评论