<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 基于GTK+和X-window的GUI在嵌入式Linux中的應用

          基于GTK+和X-window的GUI在嵌入式Linux中的應用

          作者: 時間:2012-04-05 來源:網(wǎng)絡 收藏

            整體尺寸大小

            經(jīng)過一系列的改進后,我們就得到了一個穩(wěn)定的,功能和性能都能滿足嵌入系統(tǒng)要求的了。在ARM系統(tǒng)下,得到的尺寸大小為:

          圖1

            其中 + 里面仍然還有不需要的代碼,可以將其再去除。如果再簡化一下的話,+ 可以做到850KB,總體大小可以到 2.8M。

            運行性能

            將修改過的 運行在一個 ARM7 的系統(tǒng)上,CPU 為 100MHZ,運行時的效果還不錯,窗口響應用戶操作的速度很迅速,新的畫面創(chuàng)建與顯示的速度都能接受。

           但是,啟動時的時間卻有些問題,比較慢。在這個 CPU 上,應用程序畫面加載與顯示的時間需要 2.4秒,其中 1.5 秒是花在了建立與顯示 UI 上。

            在較慢的 CPU 上,這樣的啟動速度是 + 運行在 X,X 再寫到 framebuffer 上導致的。我們需要分析具體的瓶頸在什么地方。在深入的調(diào)試中,當使用PC機來運行我們的應用,而在ARM設備上顯示時,初始化和顯示的時間幾乎可以忽略不計。同樣,將應用運行在ARM設備上,而在PC機上顯示時,性能也很好。所以數(shù)據(jù)包的傳輸,framebuffer上的顯示及GTK+的運算速度都不是問題所在。速度慢的原因可能是這幾個因素的先后順序引起的。而且內(nèi)存的占用上也存在問題。在初始階段,GTK+構造了大量的對象,GTK+和X是使用共享內(nèi)存來通訊的,X寫到framebuffer,framebuffer也是不變地寫到顯存上。這些都是發(fā)生在一個較窄總線上相同的內(nèi)存空間里,這個就會引起速度慢。

            現(xiàn)在知道了X在啟動時比較花費時間。在客戶模式下的GTK+的應用,需要連接到X server,通過了認證,得到位深及其他資源。當然,使用X系統(tǒng)的好處要遠大于它的不足。X系統(tǒng)提供了一個靈活的client/server模型,這樣更有利于應用的靈活加入。你可以在同一時間顯示不用的應用窗口,而像GTK+/Fb等其他的方式無法做到這一點,當然QPE是個例外。

            2.4秒的延時,也并不能完全否定一切。在一個700MHZ的windows系統(tǒng)的PC上,Microsoft Word, Excel and IE幾乎都需要2秒的時間來啟動。KEdit, 一個KDE的應用程序,在500MHZ的PIII上,加載的時間也需要1.37秒。

            對于啟動時間,需要采用其他的辦法來加以改善。一個策略就是在用戶等待的時候,顯示一些東西來表示系統(tǒng)正在工作,這樣會使用戶忽略掉啟動時間的緩慢。另一個策略就是可以預先在背后啟動一些通用的程序,來有效減少集中啟動的時間。這也是通常嵌入系統(tǒng)所慣用的做法。

            優(yōu)化

            在ARM7的系統(tǒng)上,由于沒有浮點運算FPU,所以GTK+中的浮點運算部分最好是去掉,否則會大大影響性能。GTK+使用到的浮點變量只分布在少數(shù)的幾個窗口中,并且去掉它們會帶來3%到12%的性能提高。

            高像素的應用會導致速度較慢,這大多是由于GTK+與X中對高像素的效率低下的處理有關。如涉及到的XPM,XPM (X pixmap)格式是被設計來做到較好的兼容性,而不是更加快速。X系統(tǒng)是一個像素一個像素地畫到server的pixmap的。GTK+的像素處理也很低效,它是使用fgetc()來讀取XPM文件的,這就會帶來大量的上下文切換開銷。

            X窗口系統(tǒng)的結構也導致了像素的加載變慢。GTK+客戶端需要加載,分析XPM文件,將像素值通過傳輸協(xié)議發(fā)送給server,然后server才將像素值放入framebuffer。如果客戶端直接將數(shù)據(jù)寫到framebuffer server那將會有效很多。

            處理的GTK+像素的辦法就是,寫一個臨時的中間過程,取得render過的像素,使用這個原始數(shù)據(jù)來替換XPM數(shù)據(jù),這個原始數(shù)據(jù)就可以直接強制寫到X server上。從結構上來看,這雖然不是一個很好的處理辦法,但在效率上卻要比使用XPM要快上80%。

            總結

            現(xiàn)在的消費電子大多需要一個美觀,實用的圖形界面系統(tǒng)GUI。在嵌入系統(tǒng)linux下,有很多種GUI可供選擇。使用開放代碼的GUI的優(yōu)點就是你可以將其裁剪得滿足你的各種各樣的特殊需求。GTK+就是一個很好的選擇,而系統(tǒng)提供了一個穩(wěn)定可靠的client/server模型。當你得到一個只有2.9M大小的定制過的GUI時,對大多數(shù)的嵌入系統(tǒng)還是很有參考價值的。

            關于作者

            余濤,高級軟件工程師,現(xiàn)從事 linux 嵌入式系統(tǒng)的開發(fā)工作,主要研究方向嵌入系統(tǒng),UPNP 多媒體播放系統(tǒng)。您可以通過電子郵件 yut616@21cn.com 和他聯(lián)系。希望能與更多的朋友交流關于 Linux 方面的知識。


          上一頁 1 2 3 下一頁

          評論


          相關推薦

          技術專區(qū)

          關閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();