linux中基于DRM的圖形顯示系統(tǒng)概述
1FBDEVFramebuffer device社區(qū)參與度不高,基本轉(zhuǎn)移到了DRM。
DRM/KMSDirect Rendering Manager / KernelMode Setting主流的圖形顯示方法,社區(qū)參與度高,支持圖形系統(tǒng)精細(xì)化操作,基本形成了一套圖顯系統(tǒng)開發(fā)的生態(tài)標(biāo)準(zhǔn)。
V4L2Video For Linux 2主要用于視頻捕獲的應(yīng)用場(chǎng)景,并且需要特定輸出設(shè)備,對(duì)復(fù)雜圖顯控制器的支持不佳
DRM系統(tǒng)組成
2kernel層面的DRM系統(tǒng)包含兩大部分,一部分是圖顯設(shè)備的DRM抽象,另外一部分是圖顯設(shè)備的顯存控制。
圖片來源于網(wǎng)絡(luò)
========================
圖片來源于網(wǎng)絡(luò)
========================
上圖涵蓋了linux系統(tǒng)中DRM系統(tǒng)組成,kernel為用戶層提供標(biāo)準(zhǔn)的DRM接口,在用戶層依據(jù)DRM庫構(gòu)建各種圖顯協(xié)議,圖顯應(yīng)用層基于這些中間件完成應(yīng)用程序的開發(fā)。
##顯存Framebuffer申請(qǐng)的一塊用于存儲(chǔ)顯示數(shù)據(jù)的內(nèi)存區(qū)域,主要包括:
1)內(nèi)存區(qū)域大小范圍
2)內(nèi)存中待顯示數(shù)據(jù)的幀格式
3)內(nèi)存中有效的區(qū)域,該部分是待顯示數(shù)據(jù)
其實(shí)現(xiàn)方法主要有3種:
1)基于CMA的
drivers/gpu/drm/drm_fb_cma_helper.c
2)基于Scatter Gather
drivers/gpu/drm/tegra/
3)基于IOMMU
drivers/gpu/drm/exynos/exynos_drm_iommu.c
顯存區(qū)域定義
幀格式定義支持的幀格式以FOURCC格式來呈現(xiàn),其定義形式如下:
1/*?24?bpp?RGB?*/
2#define?DRM_FORMAT_RGB888????fourcc_code('R',?'G',?'2',?'4')
3#define?DRM_FORMAT_BGR888????fourcc_code('B',?'G',?'2',?'4')
4
5/*?32?bpp?RGB?*/
6#define?DRM_FORMAT_XRGB8888????fourcc_code('X',?'R',?'2',?'4')
7#define?DRM_FORMAT_XBGR8888????fourcc_code('X',?'B',?'2',?'4')
8#define?DRM_FORMAT_RGBX8888????fourcc_code('R',?'X',?'2',?'4')
9#define?DRM_FORMAT_BGRX8888????fourcc_code('B',?'X',?'2',?'4')
創(chuàng)建FRAME BUFFER
創(chuàng)建成功可在dev下看見fb設(shè)備
##CRTC
CRT Controller, 陰極射線管控制,對(duì)顯示buffer進(jìn)行掃描,并產(chǎn)生時(shí)序信號(hào)。
CRTC funcs
1static?const?struct?drm_crtc_funcs?ade_crtc_funcs?=?{
2????.destroy????=?drm_crtc_cleanup,
3????.set_config?=?drm_atomic_helper_set_config,
4????.page_flip??=?drm_atomic_helper_page_flip,
5????.reset??????=?drm_atomic_helper_crtc_reset,
6 .atomic_duplicate_state?=?drm_atomic_helper_crtc_duplicate_state,
7????.atomic_destroy_state???=?drm_atomic_helper_crtc_destroy_state,
8????.enable_vblank??=?ade_crtc_enable_vblank,
9????.disable_vblank?=?ade_crtc_disable_vblank,
10};
CRTC helper funcs
1static?const?struct?drm_crtc_helper_funcs?ade_crtc_helper_funcs?=?{
2????.mode_fixup?=?ade_crtc_mode_fixup,
3????.mode_set_nofb??=?ade_crtc_mode_set_nofb,
4????.atomic_begin???=?ade_crtc_atomic_begin,
5????.atomic_flush???=?ade_crtc_atomic_flush,
6????.atomic_enable??=?ade_crtc_atomic_enable,
7????.atomic_disable?=?ade_crtc_atomic_disable,
8};
##PLANE
圖片來源于網(wǎng)絡(luò)
========================
PLANE funcs
1static?struct?drm_plane_funcs?ade_plane_funcs?=?{
2????.update_plane???=?drm_atomic_helper_update_plane,
3????.disable_plane??=?drm_atomic_helper_disable_plane,
4????.destroy?=?drm_plane_cleanup,
5????.reset?=?drm_atomic_helper_plane_reset,
6????.atomic_duplicate_state?=?drm_atomic_helper_plane_duplicate_state,
7????.atomic_destroy_state?=?drm_atomic_helper_plane_destroy_state,
8};
PLANE helper funcs
1static?const?struct?drm_plane_helper_funcs?ade_plane_helper_funcs?=?{
2????.atomic_check?=?ade_plane_atomic_check,
3????.atomic_update?=?ade_plane_atomic_update,
4????.atomic_disable?=?ade_plane_atomic_disable,
5};
##ENCODER/CONNECTORENCODER負(fù)責(zé)將CRTC輸出的timing時(shí)序轉(zhuǎn)換成外部設(shè)備所需要的信號(hào)的模塊,如HDMI轉(zhuǎn)換器。CONNECTOR ? 連接物理顯示設(shè)備的連接器,如HDMI、DisplayPort、DSI總線,通常和Encoder驅(qū)動(dòng)綁定在一起。
圖片來源于網(wǎng)絡(luò)
========================
ENCODER/helper funcs
1static?const?struct?drm_encoder_helper_funcs?dw_encoder_helper_funcs?=?{
2????.atomic_check???=?dsi_encoder_atomic_check,
3????.mode_valid?=?dsi_encoder_mode_valid,
4????.mode_set???=?dsi_encoder_mode_set,
5????.enable?????=?dsi_encoder_enable,
6????.disable????=?dsi_encoder_disable
7};
8
9static?const?struct?drm_encoder_funcs?dw_encoder_funcs?=?{
10????.destroy?=?drm_encoder_cleanup,
11};
CONNECTOR/helper funcs
1static?const?struct?drm_connector_helper_funcs
2panel_bridge_connector_helper_funcs?=?{
3????.get_modes?=?panel_bridge_connector_get_modes,
4};
5
6static?const?struct?drm_connector_funcs?panel_bridge_connector_funcs?=?{
7????.reset?=?drm_atomic_helper_connector_reset,
8????.fill_modes?=?drm_helper_probe_single_connector_modes,
9????.destroy?=?drm_connector_cleanup,
10????.atomic_duplicate_state?=?drm_atomic_helper_connector_duplicate_state,
11????.atomic_destroy_state?=?drm_atomic_helper_connector_destroy_state,
12};
##ioctl注冊(cè)
component組件系統(tǒng)
3kernel中的component框架是為了subsystem能夠按照一定的順序初始化設(shè)備而提出的架構(gòu)。
subsystem中由較多設(shè)備模塊組成,而內(nèi)核加載每個(gè)模塊時(shí)間不定。則需要component框架來保證需最后初始化的設(shè)備加載前,所需設(shè)備全部加載完畢。?在component中,包含兩個(gè)基本概念,master和component。master是設(shè)備樹中的“超級(jí)設(shè)備(superdevice)”,負(fù)責(zé)管理該超級(jí)設(shè)備下的普通設(shè)備。component是由master管理的普通設(shè)備,要先初始化。?#初始化分為兩部分master即超級(jí)設(shè)備,執(zhí)行probe使用component_master_add_with_match函數(shù)注冊(cè)自己到component框架中。component即普通設(shè)備,執(zhí)行probe使用component_add函數(shù)注冊(cè)自己到component框架中。
##Master初始化
1static?int?kirin_drm_platform_probe(struct?platform_device?*pdev)
2{
3????struct?device?*dev?=?