基于LLVM的異構編譯優(yōu)化方法研究.pdf_第1頁
已閱讀1頁,還剩63頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、2009年Khronos Group ISO提出了OpenCL(Open Computing Language)標準,它是一個為異構平臺編寫并行程序的框架。相對于CUDA等GPGPU(General-purpose computing on graphics processing units)“方言”,它有著標準化、跨平臺等特點,適合用于在異構計算系統(tǒng)中開發(fā)可移植的并行應用程序。標準化高性能應用開發(fā)平臺的需求推動了OpenCL的發(fā)展。O

2、penCL解決了復雜的存儲器層次結構、數(shù)據(jù)并行執(zhí)行問題,特別是解決了異構并行計算系統(tǒng)先前編程模型中存在的嚴重局限性。
   相對CPU每個核擁有大量的緩存及復雜的控制邏輯,善于單線程可執(zhí)行程序的復雜執(zhí)行。GPU更側重于執(zhí)行并行應用程序時的吞吐量,由大量較小的核組成,每個核的主頻較低,但存在較大量的寄存器文件、內存帶寬和擁有較小的緩存。同時期的頂級CPU與GPU相比,整體浮點運算的執(zhí)行速度是CPU的10倍左右,顯存的帶寬也是內存的

3、10倍左右;單一核CPU與GPU相比,運算速度和平均擁有的帶寬剛好相反,為十分之一。
   本文針對OpenCL編譯時期的特有模式,提出了一種新的針對異構計算平臺的編譯期優(yōu)化方法,該方法根據(jù)設備端和主機端的各自特點將設備端的一些冗余操作提到主機端或者新的設備端kernel中去執(zhí)行,以達到降低存儲器讀寫的目的。這種方法充分利用了異構計算平臺的特點,較傳統(tǒng)優(yōu)化方法相對靈活,在一定程度上降低了異構平臺程序開發(fā)對硬件的依賴,可以產生良好

4、的代碼并提高程序運行的效率。
   本文整體實現(xiàn)主要包含兩個模塊,分別是運行時檢測模塊與編譯期代碼優(yōu)化模塊。作者主要工作如下:擴展了循環(huán)不變代碼外提算法,通過數(shù)據(jù)依賴分析,使得算法可以較細致的分析那些load,store指令是可以外提到循環(huán)前置塊的。另外設計了一個針對OpenCL的歸納變量分析器,分析每條指令依賴get_global_id和get_local_id函數(shù)的維度。并且證明了在kernel中進行依賴分析時不需要考慮Op

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論