基于內存隔離的確定性多線程系統(tǒng)研究.pdf_第1頁
已閱讀1頁,還剩59頁未讀 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、隨著多核眾核體系結構的普及,多線程程序的需求越來越大。由于多線程程序的非確定性特征,導致程序的測試、調試復雜化,即多線程編寫過程產生大量并發(fā)性錯誤,如死鎖、數(shù)據(jù)競爭。現(xiàn)有的解決方案或基于先前生成的日志文件再現(xiàn)程序調度過程實現(xiàn),需要高昂的存儲開銷及性能開銷;或基于修改源代碼的確定性系統(tǒng)實現(xiàn),不具有通用性和可擴展性。
  基于內存隔離的確定性多線程系統(tǒng)(libthread),采用內存隔離與內存提交技術來保證源碼的確定性執(zhí)行,并且具有高

2、效性、通用性和可擴展性等特點。Libthread系統(tǒng)通過將共享內存映射到每個線程中,隔離線程的并發(fā)執(zhí)行過程,避免數(shù)據(jù)競爭,消除了假共享;使用標準的虛擬內存保護機制跟蹤每個線程的讀寫操作,在同步原語處采用串行執(zhí)行,按照確定的順序提交私有內存到共享內存,保證多線程程序執(zhí)行的確定性。Libthread系統(tǒng)使用性能計數(shù)器跟蹤每個線程執(zhí)行進度來建立確定性邏輯時間,利用確定性邏輯時間建立內存提交的順序,保證共享內存數(shù)據(jù)訪問的準確性,同時提供良好的均

3、衡性。Libthread系統(tǒng)利用封裝的同步原語作為并行階段和串行階段的邊界,即使程序調試過程中加入調試語句也不改變并串行邊界,從而降低了調試難度。
  通過并行程序測試集PARSEC BenchmarkSuite進行模擬實驗,將基于libthread的編譯策略與基于pthread的編譯策略進行比較,實驗結果表明,libthread系統(tǒng)解決了多線程程序非確定性問題,保證同一程序每次執(zhí)行的結果是相同的;libthread系統(tǒng)執(zhí)行效率和

溫馨提示

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

評論

0/150

提交評論