在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

如何選擇Embedded Linux的圖形框架

Linux閱碼場 ? 來源:fqj ? 2019-05-27 14:59 ? 次閱讀

對于Android開發者來說,基本不用關心圖形方案這些細節,你只要調用java的class,最后的性能都是有原廠和谷歌驗證過的。 但對Linux開發者來說,情況要復雜的多,沒有一個完美方案。。所以當你決定要在Linux要開發應用的時候,一定要明確你的需求,對比方案間的優劣。

小框圖:

如何選擇Embedded Linux的圖形框架

X11

X11的基礎構架,建議先谷歌一下,太龐大,歷史遺留比較多,到現在我也沒弄清楚一些調用流程。下面主要講講dri2。dri2是xserver用來連接gpu的結構,下面這個鏈接里蠻詳細的。大概理解,dri2自己管理一個window下面的buffers, xserver都不會過問,只有swap front buffer的時候,才會調一些函數來wait page flip來進行畫面的同步。
不過這個front buffer是false的,要注意,最后顯示還要進行compoiste(以rk的xserver為例,這里會用到cpu blit, 而wayland和qt eglfs這步是gpu做的)。dri2全屏和不全屏的性能差距會比較大,因為全屏的情況下,dri2出來的flase front buffer,也就是這個window的drawbuffer, 是直接被作為全局的font buffer,送到ddx顯示的,省去了compoiste。
所以在x11下開發3d應用的時候,一定要全屏,保證沒有多余的compoiste,比如qt的qmlwindow就是一個完整的gl窗口(注:debian上不是)。另外一提,rk平臺上的xserver,還支持了glamor,意味一些compoiste可以被gpu加速到,如果是做多窗口的應用或者desktop類型的產品,這個featrue還是非常有用的,能運行x11上的所有軟件,又有gpu加速合成。

2017.3.10

做了些實驗,x11下egl的lag,在拉高cpu頻率之后,顯著的緩解,所以應該就是cpu參與了合成步驟,導致效率變低。

2017.5.21

在debian看到一些比較慢的現象,要注意不是x11的問題,而是debian的程序編譯選項一般沒帶上gles。

QT EGLFS

QT EGLFS是qt自己實現的一個gui系統,不支持多窗口,但也因此少了window compoiste。QT EGLFS和dri2的方式也差不多,區別就在于,qt eglfs的font buffer在自己用gpu compoiste后,是直接送給drm去顯示,而X里是送Window manager去做compoiste,所以EGLFS在效率上是有優勢的。另外除了QT,常用的UI庫里,SDL也是支持這種DRM+GL的方式的。

2017.3.11

QT EGLFS的流程其實可以通過代碼追蹤一下。根據代碼,一個qmlvideo的顯示過程會是這樣的(非qml的話不一樣,會優先用xvimagesink的subwindow),surface路徑會是QDeclarativeVideoOutput->QDeclarativeVideoRendererBackend,顯示一幀frame的話,會先調用到QDeclarativeVideoRendererBackend::updatePaintNode,然后就是返回一個NV12 to RGB的shader,走正常qtquick程序的顯示顯示,最后QOpenGLCompositor會合成所有的window。Qt EGLFS的流程還是很清晰的,就是先window自己render(qquickwindow是用的GPU)一個buffer, 然后QOpenGLCompositor把所有的window再render到一個buffer上,然后這個buffer送drm顯示(如果就是一個primary window,就直接送drm了)。

Wayland

wayland是Linux上下一代的display server,從結構上來講,也最相近android上的HWC,全部的compoiste都是gpu來做的,不會有xserver那樣cpu合成的場景。wayland除了gpu合成以外,另一個優勢,就是overlay接口的存在,能允許移動平臺上的一些2d加速模塊,display模塊在這個接口上被調用(這些模塊才是移動平臺能跑大分辨率ui的關鍵)。wayland主要的問題是兼容性,比如你用qtmultimedia的話,會發現video sink不能換,因為不兼容wayland的窗口api

應用場景

3d應用

3d應用的瓶頸最主要在計算單元上,拷貝,compoiste一類的開銷,根據具體場景再考慮。建議直接raw的drm api或者qt eglfs。

視頻播放

對視頻播放來說,拷貝,compoiste的開銷是決定性的。Spec上的視頻播放極限,比如rk3399,rk3288播放4k,rk3036播放1080p,基本上是不可能在通用框架,也就是走gpu實現的。 因為達到了芯片bandwidth的上限場景,如果讓gpu去拷貝和轉格式的話速度會很慢,必須要display的部分自己去處理顯示視頻數據。
但想讓display部分去處理的話,軟件上必須有對應的支持——-然而desktop based的gui framework大多缺失了這樣一個東西。之前在rk的系統上,我base X11做了一個“gstreamer sink” 。通過x的api獲取窗口的位置,然后直接drm的api,繞過X系統,overlay畫在窗口的位置。
這樣做確實可以發揮視頻播放的極限,主要的問題就是沒辦法和gui系統融合,沒辦法疊加控件,如果使用的場景都是fullscreen,可以試試這做。上文提了下wayland框架支持overlay,所以最理想的,還是wayland通過overlay的機制直接call的display單元顯示,像android那樣。
總結一下,所以如果視頻性能不是那么高,又需要復雜UI,建議用gpu的框架。qt eglfs,放視頻,按rk3288的性能,可以達到1080p 60fps。x11,gles在rk平臺的軟件上,測試下來,性能比較差;不過已經有rkximagesink的overlay顯示方案。wayland暫時沒有研究,理論上原生支持overlay的wayland是最好的,但是我覺得應該也就類似rkximageisnk的那種效果,不能和正常的窗口兼容。

Tips

libmali

libmali是mali gpu的userspace library,我也看不到代碼,完全是黑盒,只能說根據一些類似的代碼和文檔猜測他的實現方式。libmali有很多編譯選項,我猜的話,除了軟件硬件版本,還有下面兩種。一個是fbdev和gbm,分別對應了fbdev和drm兩種內核驅動的場景。fbdev對比gbm有幾個差異。
1.vblank用fbdev去跑on-screen的glmark,分數一般是要比gbm的高,原因就是這套流程沒有去等待vblank。gbm的實現都會在最后swap front buffer的時候等待vblank,所以on-screen只能跑幾十fps,fbdev的不會去等,因此fbdev的libmali on-screen的fps和off-screen的差不多。
2.zero-copy所謂zero-copy就是不拷貝texture。一段在內存里的texture,要讓gpu去使用,必須先用cpu把數據從這段內存拷到gpu能用的buf(dma-buf)里。如果這個texture數據本來就在一個dma-buf里的話,可以通過特定的api直接讓gpu load,從而避免拷貝。dma-buf在gbm上的實現,搜索EGL_LINUX_DMA_BUF_EXT就可以。在fbdev上的實現,比較麻煩,“fbdev zero-copy” 。還有就是display server的選項,比如xserver,比如wayland。 這個就是支持在display server下運行,沒什么好說的。

libdrm

drm的api分legacy api和新一點的atomic api,如果你直接用drm api開發程序,一定要注意這兩個api的區別。legacy api:drmModeSetCrtc, drmModeSetPlane, drmModePageFlip都是legacy的api,這些函數什么意思,怎么用,可以搜索下網絡資料
大致上,drmModeSetCrtc包括了drmModeSetPlane包括了drmModePageFlip。在rk平臺上,drmModeSetCrtc和drmModeSetPlane都是atomic的,意味著你調用這些api后會一直block到vblank,drmModePageFlip是noneblock的,你調用后就會返回。
一般來說不在一個程序里順序調用會block的api,性能不會有太大問題。atomic api:legacy的api都是atomic的,而且容易重復調用,這就導致有些場景會很沒效率。比如wayland drm的場景下,有3個plane,每個周期內要更新這幾個plane,如果全用drmModeSetPlane的話,就意味著要等待3次vblank,那么一個60hz的屏幕,你的fps最高只會有20fps。
為了解決這種情況,我們就需要有一個api,能在一次調用里,解決掉所有的事情,比如更新所有的plane,然后只用等一次vblank。drmModeAtomicCommit,具體用法請谷歌。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • Linux
    +關注

    關注

    87

    文章

    11314

    瀏覽量

    209783
  • JAVA
    +關注

    關注

    19

    文章

    2970

    瀏覽量

    104838

原文標題:怎么選擇 Embedded Linux 的圖形框架

文章出處:【微信號:LinuxDev,微信公眾號:Linux閱碼場】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    一文讀懂Linux各模塊框架

    Linux各模塊框架整理。
    的頭像 發表于 06-30 11:27 ?8563次閱讀
    一文讀懂<b class='flag-5'>Linux</b>各模塊<b class='flag-5'>框架</b>

    Mentor Graphics新擴展Mentor Embedded Linux功能

    Mentor Graphics公司(納斯達克代碼:MENT)今日宣布,即將推出可兼容 AMD 嵌入式 R 系列處理器的 Mentor? Embedded Linux?運行軟件和開發工具。第二代
    發表于 11-06 11:02 ?1153次閱讀

    嵌入式Linux圖形系統(GUI)快速參考手冊

    安裝Linux時,你通常在很少的幾個"標準"的圖形支持組件中選擇。你很可能使用X Windows系統(XFree86或者Xorg)作為顯示界面的基礎(與Linux
    發表于 02-14 13:40

    基于NXP iMX6Q SoC平臺的Apalis iMX6 ARM核心板的相關資料推薦

    By Toradex秦海1).簡介Qt圖形開發框架作為嵌入式ARM平臺配合Embedded Linux系統最常用的圖形界面開發工具已經被廣泛
    發表于 12-17 06:34

    Embedded SIG | 多 OS 混合部署框架

    Embedded 的角度,混合關鍵性系統的大致架構如圖 1 所示,所面向的硬件是具有同構或異構多核的片上系統,從應用的角度看會同時部署多個 OS /運行時,例如 Linux 負責系統管理與服務、1 個
    發表于 06-29 10:08

    基于Qt/Embedded的嵌入式控制界面開發

    作者通過結合Qt/Embedded的特性和優點,提出用Qt/Embedded實現風力發電控制系統的圖形界面的思路和設計原則,重點介紹了在嵌入式Linux內核基礎上Qt/
    發表于 08-12 10:14 ?49次下載

    基于QT/Embedded的可變情報板應用程序開發

    基于QT/Embedded的可變情報板應用程序開發 QT是奇趣科技推出的一種多平臺的C++圖形用戶界面應用程序框架。它包括QT開發庫QT Library、快速開發工具QT Designer、國際化工
    發表于 03-03 09:36 ?788次閱讀

    Qt/Embedded開發入門

    通過Qt API與Linux I/O設施直接交互,成為嵌入式Linux端口。同Qt/X11相比,Qt/Embedded很省內存,因為它不需要一個X服務器或是Xlib庫,它在底層拋棄了X lib,采用
    發表于 10-18 14:43 ?10次下載
    Qt/<b class='flag-5'>Embedded</b>開發入門

    采用Linux還是Windows Embedded,研華選擇后者

    在IIC-China 2009深圳技術研討會上,工控領域的老大研華科技的副總經理陳培齊一語驚人:基于Windows Embedded OS的開發成本比Linux更低,而且開發周期更短。我們大部分產品
    發表于 12-04 12:55 ?359次閱讀

    Linux DMA Engine框架的介紹

    此會話描述如何從設備驅動程序在Linux中使用DMA。 這包括內存分配,緩存控制和DMA設備控制。 詳細介紹了Linux DMA Engine框架
    的頭像 發表于 11-23 06:29 ?6330次閱讀

    你對Linux總線設備驅動框架是否了解

    Linux的設備驅動模型,或者說,Linux的設備驅動框架,都是同一個意思。應該這樣理解,(Linux的設備)驅動框架,即某類設備對應的驅動
    發表于 05-05 15:13 ?743次閱讀

    Linux內核開發框架學習資料匯總

    Linux內核開發框架學習資料匯總
    發表于 06-17 09:29 ?24次下載

    當前HarmonyOS輕設備圖形框架的總體特性介紹

    HarmonyOS輕設備圖形框架概述 HarmonyOS輕設備圖形框架是一款面向帶屏設備界面開發框架,可運行于LiteOS/
    的頭像 發表于 07-28 14:27 ?1688次閱讀
    當前HarmonyOS輕設備<b class='flag-5'>圖形</b><b class='flag-5'>框架</b>的總體特性介紹

    基于STM32移植UCGUI圖形界面框架(3.9.0源碼版本)

    基于STM32移植UCGUI圖形界面框架(3.9.0源碼版本)
    發表于 11-30 16:06 ?0次下載
    基于STM32移植UCGUI<b class='flag-5'>圖形</b>界面<b class='flag-5'>框架</b>(3.9.0源碼版本)

    ThunderGP:基于HLS的FPGA圖形處理框架

    電子發燒友網站提供《ThunderGP:基于HLS的FPGA圖形處理框架.zip》資料免費下載
    發表于 10-27 16:49 ?0次下載
    ThunderGP:基于HLS的FPGA<b class='flag-5'>圖形</b>處理<b class='flag-5'>框架</b>
    主站蜘蛛池模板: a天堂中文在线官网| 夜夜摸夜夜爽| 猛操女人| 免费观看黄色在线视频| 精品爱爱| video另类蛇交| 天天色天天操综合网| 免费观看成年欧美1314www色| 米奇777四色精品人人爽| 400部大量精品情侣网站| 一区视频免费观看| 伊人久久大香线蕉综合亚洲| 婷婷激情丁香| 免费一级特黄 欧美大片| 国产婷婷高清在线观看免费| 11111日本网站| 久久综合九色| 48pao强力打造免费基地| 狠狠色噜噜狠狠狠狠91| 婷婷丁香综合| 萝l在线精品社区资源| 爱我免费视频观看在线www| 天天干天天射天天爽| 直接看黄的网站| 国产汉服被啪福利在线观看| 网站在线你懂的| 久久黄色精品视频| 一区二区在线观看高清| 男人j进女人j视频| 天堂网在线资源www最新版| 欧美成人天天综合在线视色| 丁香花小说| 免费一级毛片清高播放| 国产最新网站| 伊人久久大香线蕉综合7 | 亚洲成人午夜影院| 久久精品波多野结衣| 一区二区三区视频网站| 兔费看全黄三级| 黄色毛片免费网站| 色综合天天综合网亚洲影院|