经过一段时间自己学习和理解,个人对于MIPI LCD
接口的调试有了自己的一点心得,当然也收获了Linux DRM显示框架及调试的一些心得,DRM真的很难很难,本文也无法顾及所有的细节,之前也发了一些DRM相关的文章:
以下的这些概念和操作都是本人在实践的过程中觉得对调试有用,所以就记下来了,接下来我们来简单的了解一下:
就是屏幕,比如主控芯片通过HDMI、MIPI DSI,分别接2个屏幕显示,就会有2个对应的Connectors ID;
表示VOP,一个屏幕一般对应一个crtc;
就是图层,比如视频层在plane2,UI在plane1,视频在UI上面;
例如在RV1109的开发板端执行modetest,我们可以看到以下输出信息:
[root@RV1126_RV1109:/oem]# modetest
Encoders:
id crtc type possible crtcs possible clones
55 53 DSI 0x00000001 0x00000000
Connectors:
id encoder status name size (mm) modes encoders
56 55 connected DSI-1 154x86 1 55
modes:
name refresh (Hz) hdisp hss hse htot vdisp vss vse vtot)
1024x600 54 1024 1240 1310 1470 600 612 622 645 51200 flags: nhsync, nvsync;
type: preferred, driver
props:
1 EDID:
flags: immutable blob
blobs:
value:
2 DPMS:
flags: enum
enums: On=0 Standby=1 Suspend=2 Off=3
value: 0
5 link-status:
flags: enum
enums: Good=0 Bad=1
value: 0
6 non-desktop:
flags: immutable range
values: 0 1
value: 0
43 brightness:
flags: range
values: 0 100
value: 50
44 contrast:
flags: range
values: 0 100
value: 50
47 saturation:
flags: range
values: 0 100
value: 50
48 hue:
flags: range
values: 0 100
value: 50
CRTCs:
id fb pos size
53 57 (0,0) (1024x600)
1024x600 54 1024 1240 1310 1470 600 612 622 645 51200 flags: nhsync, nvsync;
type: preferred, driver
props:
38 left margin:
flags: range
values: 0 100
value: 100
39 right margin:
flags: range
values: 0 100
value: 100
40 top margin:
flags: range
values: 0 100
value: 100
41 bottom margin:
flags: range
values: 0 100
value: 100
51 FEATURE:
flags: immutable bitmask
values: afbdc=0x1
value: 0
Planes:
id crtc fb CRTC x,y x,y gamma size possible crtcs
52 53 57 0,0 0,0 0 0x00000001
formats: XR24 AR24 XB24 AB24 RG24 BG24 RG16 BG16
props:
8 type:
flags: immutable enum
enums: Overlay=0 Primary=1 Cursor=2
value: 1
50 FEATURE:
flags: immutable bitmask
values: scale=0x1 alpha=0x2 hdr2sdr=0x4 sdr2hdr=0x8 afbdc=0x10
value: 2
54 0 0 0,0 0,0 0 0x00000001
formats: XR24 AR24 XB24 AB24 RG24 BG24 RG16 BG16 NV12 NV16 NV24
props:
8 type:
flags: immutable enum
enums: Overlay=0 Primary=1 Cursor=2
value: 0
50 FEATURE:
flags: immutable bitmask
values: scale=0x1 alpha=0x2 hdr2sdr=0x4 sdr2hdr=0x8 afbdc=0x10
value: 3
Frame buffers:
id size pitch
从以上信息,我们能够了解到:
观察以上信息,我们可以看到Connectors有1个,代表可以接1个屏幕输出,ID是56。该显示输出的最大分辨率是1024x600,刷新频率54hz;
观察以上信息,我们可以看到CRTCs有1个,ID是53;
观察以上信息,我们可以看到Planes有2个,即代表有2个图层,ID分别是52、54。plane 53当前type值是1,代表是Primary层;plane 55当前type值是0,代表是Overlay层;
2.3.2、Overlay层
我们可以根据以上modetest探测出来的信息,然后发送以下指令让色块显示到LCD显示屏上,在ARM端输入以下命令:
modetest -s 56@53:1024x600@RG24
其中:
执行以后,我们可以看到屏幕上的显示效果:
ls /sys/kernel/debug/dri/0/
可以看到:
cat /sys/kernel/debug/dri/0/state
可以看到:
cat /sys/kernel/debug/dri/0/summary
可以看到:
从以上信息可以看出:
VOP的状态是ACTIVE,表示正在运行中,如果是DISABLED,表示VOP没在运行。
Connector:DSI 表示对应屏幕接口的名称。
Display mode表示的是当前显示的分辨率和频率为,即分辨率为1024*600,频率为54fps。
cat /sys/kernel/debug/clk/clk_summary | grep vop
可以看到:
ls /sys/class/drm
可以看到:
ARM终端输入:
for p in /sys/class/drm/*/status; do con=${p%/status}; echo -n "${con#*/card?-}:"; cat $p; done
可以看到:
当前还有其它的节点可以访问。
以RK平台为例,之前一直调试的是RV1126_RV1109,RK在底层实现了自己的一套DRM显示框架:
MIPI DRM 驱动的加载存在依赖关系,所以可能会多次因为驱动资源暂时获取不到而返回 -517 ,但是只要配置正确,待相关组件驱动能够完整获取到资源后,最终就会 bound 成功,如果没有看到如下:
[ 0.889511] rockchip-drm display-subsystem: bound ffb00000.vop (ops0xb093e180)
[ 0.889613] rockchip-drm display-subsystem: bound ffb30000.dsi (ops0xb09448ac)
则绑定失败,通讯异常。
注意:如果你确定软件上已经没问题了,那么多半是硬件连接的问题,因为 MIPI 排线比较脆弱,很容易导致接触不良。
查看命令如下:
cat /sys/kernel/debug/dri/0/summary
6.3、查看当前连接状态
查看命令:
cat /sys/class/drm/card0-DSI-1/status
cat /sys/class/drm/card0-DSI-1/enabled
查看命令:
cat /sys/class/drm/card0-DSI-1/modes