www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁(yè) > 智能硬件 > 智能硬件
[導(dǎo)讀]1 引言隨著多核處理器技術(shù)的不斷更新和發(fā)展,傳統(tǒng)的串行程序不論在效率上還是性能上都已經(jīng)跟不上信息高速發(fā)展的腳步了,程序員不得不開發(fā)線程級(jí)并行以提高片上計(jì)算資源的使用效率,但也帶來(lái)了新的挑戰(zhàn)和問(wèn)題。目前不

1  引言

隨著多核處理器技術(shù)的不斷更新和發(fā)展,傳統(tǒng)的串行程序不論在效率上還是性能上都已經(jīng)跟不上信息高速發(fā)展的腳步了,程序員不得不開發(fā)線程級(jí)并行以提高片上計(jì)算資源的使用效率,但也帶來(lái)了新的挑戰(zhàn)和問(wèn)題。目前不同線程間的同步、對(duì)共享資源的訪問(wèn)等都是通過(guò)鎖和信號(hào)量機(jī)制完成的。然而,這種傳統(tǒng)的基于鎖和信號(hào)量的并發(fā)系統(tǒng)存在明顯的局限性。粗粒度的鎖對(duì)大量的共享數(shù)據(jù)做了保護(hù),但是可擴(kuò)展性不好,因?yàn)榧词乖诰€程間不存在對(duì)共享數(shù)據(jù)的訪問(wèn)的情況下也可能會(huì)出現(xiàn)沖突阻塞現(xiàn)象;細(xì)粒度的鎖雖然比粗粒度的鎖擴(kuò)展性能好,但由于算法設(shè)計(jì)的復(fù)雜性,普通程序員很難借助細(xì)力度的鎖實(shí)現(xiàn)高效的應(yīng)用。同時(shí)使用鎖機(jī)制還會(huì)帶來(lái)諸多問(wèn)題,比如:死鎖、優(yōu)先級(jí)反轉(zhuǎn)等,極大地影響了并行應(yīng)用的效率和性能。

事務(wù)存儲(chǔ)(Transactional Memory,TM)的使用是解決上述存在問(wèn)題一個(gè)很好的辦法[1]。通過(guò)將不同并行執(zhí)行的線程事務(wù)化,用事務(wù)操作來(lái)代替鎖機(jī)制能降低編程的復(fù)雜性。事務(wù)是被單線程執(zhí)行的對(duì)內(nèi)存進(jìn)行讀寫的有序操作序列,其特性包括:原子性、隔離性、一致性和持久性。通常事務(wù)的執(zhí)行過(guò)程為:調(diào)用事務(wù)入口函數(shù)(begin_transaction)開始執(zhí)行事務(wù),當(dāng)事務(wù)執(zhí)行完畢后調(diào)用提交函數(shù)(commit_transaction)開始提交工作,提交過(guò)程分為三個(gè)階段(請(qǐng)求提交、開始提交和完成提交),執(zhí)行完提交后此事務(wù)也就執(zhí)行完畢,從而繼續(xù)執(zhí)行下面的事務(wù)。但如果事務(wù)在執(zhí)行或提交過(guò)程中發(fā)生沖突或者錯(cuò)誤,則通過(guò)其特有的回滾機(jī)制 (rollback)返回到此事務(wù)入口繼續(xù)執(zhí)行。事務(wù)的執(zhí)行流程圖如圖 1所示。

圖 1  事務(wù)執(zhí)行流程

為了實(shí)現(xiàn)事務(wù)的這些特性,需有一個(gè)很好的TM系統(tǒng)來(lái)支持事務(wù)數(shù)據(jù)的版本管理(Version Management)和事務(wù)的沖突管理(Contention Management)。版本管理同時(shí)對(duì)新值(事務(wù)提交后可見)和原始的舊值(事務(wù)執(zhí)行過(guò)程中發(fā)生了回滾的恢復(fù)數(shù)據(jù))進(jìn)行管理。根據(jù)數(shù)據(jù)存放方式的不同TM系統(tǒng)區(qū)分版本管理為:積極版本管理(Eager Version Management)和懶惰版本管理(Lazy Version Management)。積極版本管理是將新值置于目標(biāo)存儲(chǔ)區(qū)中,這樣在提交時(shí)新值能夠很快的得到執(zhí)行,極大地降低了提交的時(shí)延;而懶惰版本管理是將原始的舊值置于目標(biāo)存儲(chǔ)區(qū),雖然會(huì)增加提交的延時(shí)但是降低了當(dāng)事務(wù)發(fā)生回滾后執(zhí)行的延時(shí)。沖突管理是不同事務(wù)執(zhí)行過(guò)程中對(duì)共享資源訪問(wèn)引發(fā)沖突而進(jìn)行的沖突檢測(cè)以及管理的機(jī)制。沖突管理有積極的(Eager)和懶惰的(Lazy)兩種策略,如果沖突在讀數(shù)據(jù)或?qū)憯?shù)據(jù)時(shí)立刻被發(fā)現(xiàn)而進(jìn)行仲裁,這種沖突檢測(cè)是積極的;如果沖突是在事務(wù)進(jìn)行提交時(shí)才發(fā)現(xiàn)并仲裁的,這種沖突檢測(cè)則是懶惰的。

目前,基于TM的硬件結(jié)構(gòu)有很多種,圖2中列出了目前幾種流行的硬件結(jié)構(gòu)根據(jù)版本管理和沖突管理而進(jìn)行的分類。本文將介紹其中的一種結(jié)構(gòu)——LogTM(日志事務(wù)存儲(chǔ)),通過(guò)對(duì)其硬件結(jié)構(gòu)(參見圖3)、版本管理、沖突管理的實(shí)現(xiàn),展現(xiàn)了此結(jié)構(gòu)的優(yōu)越性,并給后續(xù)研究提供參考和幫助。

圖2  TM系統(tǒng)分類

2  LogTM的結(jié)構(gòu)

LogTM是建立在多機(jī)系統(tǒng)中基于日志的TM實(shí)現(xiàn),每個(gè)核都有獨(dú)自的私有cache,并通過(guò)目錄協(xié)議來(lái)維持?jǐn)?shù)據(jù)的一致性。它采用的是積極的版本管理策略和積極的沖突管理策略。圖3給出了LogTM的硬件結(jié)構(gòu),它通過(guò)增加一些寄存器和cache中的讀/寫位很好地完成了對(duì)事務(wù)的操作。

圖3  LogTM的硬件結(jié)構(gòu) (圖中黑框中為其特有結(jié)構(gòu))

2.1  版本管理(Version Management)

LogTM使用積極的版本管理,將新的執(zhí)行數(shù)據(jù)存儲(chǔ)在目標(biāo)區(qū)域(目標(biāo)地址)中,而將舊的數(shù)據(jù)存儲(chǔ)在其它緩沖區(qū)。它通過(guò)在內(nèi)存中開辟一塊事務(wù)日志區(qū)域存儲(chǔ)事務(wù)執(zhí)行過(guò)程中被修改的數(shù)據(jù)(上文中提到的原始數(shù)據(jù))和這些數(shù)據(jù)所對(duì)應(yīng)的地址,新的執(zhí)行數(shù)據(jù)則被保存在目標(biāo)存儲(chǔ)區(qū)(目標(biāo)地址),當(dāng)執(zhí)行完成提交時(shí),這些新數(shù)據(jù)將會(huì)立即生效;當(dāng)事務(wù)執(zhí)行過(guò)程中或提交時(shí)發(fā)生沖突或錯(cuò)誤需要回滾時(shí),則通過(guò)事務(wù)日志中記錄的信息恢復(fù)出事務(wù)執(zhí)行前的初始狀態(tài)。

剛開始創(chuàng)建線程時(shí),每一個(gè)線程對(duì)應(yīng)著一個(gè)日志而且為日志分配一塊虛擬存儲(chǔ)區(qū)域,并將該日志基地址寫入Log Base寄存器,當(dāng)舊數(shù)據(jù)需要存儲(chǔ)到日志時(shí),LogTM通過(guò)Log Base寄存器中的值定位到日志的入口然后將舊數(shù)據(jù)的虛擬地址和值一同保存在日志中以便恢復(fù)時(shí)使用。為了減少冗余日志,LogTM為每一個(gè)cache塊添加了對(duì)應(yīng)的寫(W)位,用此來(lái)標(biāo)識(shí)該cache塊在日志中的記錄情況。當(dāng)事務(wù)提交成功后,LogTM將對(duì)應(yīng)cache塊的寫(W)標(biāo)志位清0并將Log Pointer(日志指針)重新指向日志的入口處,以便處理后續(xù)事務(wù)。

LogTM也為每個(gè)cache塊設(shè)置了一個(gè)讀(R)標(biāo)志位,就像上面我們討論的寫(W)標(biāo)志位一樣。在每個(gè)事務(wù)操作過(guò)程中LogTM同樣將讀標(biāo)志位設(shè)置用于表示讀操作的執(zhí)行(如圖4所示),而且在事務(wù)結(jié)束后,讀標(biāo)志位也清0。

這種積極的版本管理模式的缺點(diǎn)就是在事務(wù)發(fā)生沖突或錯(cuò)誤需要回滾時(shí)執(zhí)行比較慢,在回滾時(shí),LogTM為了完成恢復(fù)必須將原始數(shù)據(jù)從日志中讀到合適的目標(biāo)地址中然后重置寫(W)位,同時(shí)因?yàn)橛泻芏鄶?shù)據(jù)記錄在日志中,所以恢復(fù)過(guò)程必須按照由后向前(后進(jìn)先出)的順序進(jìn)行。但在事務(wù)沖突比較少的情況下,這種模式能夠帶來(lái)高效的執(zhí)行效率。

為了能更好的理解LogTM版本管理過(guò)程,圖4通過(guò)一個(gè)例子進(jìn)行了很好的分析。

(1)事務(wù)執(zhí)行開始前的狀態(tài)——cache數(shù)據(jù)塊中存放著原始數(shù)據(jù),每塊的讀(R)、寫(W)位置0,LogBase(日志基址寄存器)指向日志入口地址,LogPtr(日志偏移指針)指向日志入口地址同時(shí)TMcount(事務(wù)計(jì)數(shù)器)置1代表正準(zhǔn)備執(zhí)行一個(gè)事務(wù)。

(2) 讀00地址(十六進(jìn)制地址)中的數(shù)據(jù)到寄存器r1中,00地址對(duì)應(yīng)數(shù)據(jù)塊的讀(R)標(biāo)志位置1表示此數(shù)據(jù)被讀。

(3) 將寄存器r2中數(shù)據(jù)(這里假設(shè)為56)存入c0地址中,由于c0地址中存在原始數(shù)據(jù)34,將c0地址和該原始數(shù)據(jù)一起根據(jù)LogBase中的日志入口地址存入日志中,并將LogPtr指針后移,指向用于存放下個(gè)數(shù)據(jù)的地址位,同時(shí)將c0地址對(duì)應(yīng)塊的寫(W)標(biāo)志位置1,代表一次寫操作的完成,其他的狀態(tài)不變。

(4) 讀取40地址中數(shù)據(jù)到寄存器r3中,然后r3中數(shù)據(jù)加1,并將執(zhí)行后的r3數(shù)據(jù)存回40地址中,該操作對(duì)40地址對(duì)應(yīng)塊執(zhí)行了一次讀操作和一次寫操作,將讀(R)和寫(W)標(biāo)志位置1,然后將原始40地址對(duì)應(yīng)塊中數(shù)據(jù)存入日志中,存入LogPtr指向的地址中,同時(shí)將LogPtr指針后移。

(5) 事務(wù)提交后狀態(tài)——將與本事務(wù)相關(guān)的各個(gè)數(shù)據(jù)塊對(duì)應(yīng)讀寫標(biāo)志位清0,將LogPtr置位到LogBase,TMcount置0。(本例僅針對(duì)單事務(wù)執(zhí)行,如果是嵌套事務(wù)的執(zhí)行,LogTM結(jié)構(gòu)會(huì)更加復(fù)雜,具體支持嵌套事務(wù)的LogTM實(shí)現(xiàn),請(qǐng)參考[2])

(6) 事務(wù)回滾后狀態(tài)——事務(wù)在執(zhí)行或提交過(guò)程中如果出錯(cuò)需要回滾,則將日志中記錄的原始數(shù)據(jù)按照地址映射關(guān)系重新加載到對(duì)應(yīng)cache數(shù)據(jù)塊中,同時(shí)將各個(gè)塊對(duì)應(yīng)讀寫標(biāo)志位清0,LogPtr重置并且TMcount置0。

圖 4 事務(wù)版本管理過(guò)程——成功提交和回滾

2.2  沖突管理(Contention Management)

LogTM采用積極的沖突管理模式,而沖突管理中的一個(gè)重要概念目錄,就是在內(nèi)存中開辟的一片用來(lái)記錄共享數(shù)據(jù)索引和相關(guān)狀態(tài)信息的區(qū)域,也稱為目錄表。此沖突管理以目錄為橋梁,通過(guò)目錄的分析和消息轉(zhuǎn)發(fā)機(jī)制來(lái)完成多處理機(jī)間的沖突檢測(cè)。具體的實(shí)現(xiàn)步驟概括起來(lái)為:①請(qǐng)求操作的處理機(jī)發(fā)出一致性請(qǐng)求到目錄;②目錄響應(yīng)請(qǐng)求并可能將請(qǐng)求轉(zhuǎn)發(fā)到其他一個(gè)或多個(gè)處理機(jī)上;③每個(gè)響應(yīng)請(qǐng)求的處理機(jī)檢查自身狀態(tài)看是否發(fā)生沖突;④每個(gè)響應(yīng)請(qǐng)求的處理機(jī)給出應(yīng)答信號(hào),包括沖突應(yīng)答(nack)和非沖突應(yīng)答(ack);⑤發(fā)出請(qǐng)求的處理機(jī)解決沖突。

事務(wù)發(fā)生沖突后的替換行為須依據(jù)目錄中有效的MOESI狀態(tài)(MOESI 狀態(tài):Modified(M),Owned(O), Exclusive(E),Shared(S) or Invalidate(I))而定。

下面結(jié)合圖5中的沖突檢測(cè)實(shí)例對(duì)沖突管理的具體行為進(jìn)行說(shuō)明。

圖 5  LogTM沖突檢測(cè)實(shí)例

(1)事務(wù)開始——處理機(jī)P開始執(zhí)行事務(wù),TMcount增1;此時(shí)僅目錄中存放的cache塊信息有效。

(2)處理機(jī)P向目錄請(qǐng)求數(shù)據(jù)信息——步驟①:P在自身的cache中找不到某數(shù)據(jù),馬上發(fā)送獨(dú)占請(qǐng)求(GETX)到目錄。步驟②:目錄收到請(qǐng)求后根據(jù)相應(yīng)數(shù)據(jù)的索引找到“老”版本數(shù)據(jù)傳給處理機(jī)P,當(dāng)“老”版本數(shù)據(jù)達(dá)到P時(shí),P將此數(shù)據(jù)更為“新”版本數(shù)據(jù)同時(shí)將本機(jī)此數(shù)據(jù)塊對(duì)應(yīng)讀/寫標(biāo)志位置1。步驟③:P接受數(shù)據(jù)完畢后,發(fā)送應(yīng)答信號(hào)給目錄表示已經(jīng)成功接受數(shù)據(jù)。與此同時(shí)目錄中的狀態(tài)信息為M@P(Modified by P),表示此數(shù)據(jù)正在被處理機(jī)P更改。

(3)檢測(cè)到事務(wù)沖突——步驟①:處理機(jī)Q發(fā)出請(qǐng)求某共享數(shù)據(jù)的信號(hào)(GETS)給目錄。步驟②:由于目錄中此數(shù)據(jù)的狀態(tài)為M@P,目錄則根據(jù)請(qǐng)求轉(zhuǎn)發(fā)給處理機(jī)P。步驟③:P接受到請(qǐng)求后檢查自己的狀態(tài),由于P中相應(yīng)數(shù)據(jù)塊的寫標(biāo)志位已置,表明P正在修改此數(shù)據(jù),不能滿足Q的請(qǐng)求,發(fā)生沖突。這時(shí)處理機(jī)P直接發(fā)送沖突信號(hào)給Q,當(dāng)Q接受到?jīng)_突信號(hào)后進(jìn)行沖突處理。步驟④:處理機(jī)Q同時(shí)將沖突信號(hào)發(fā)送給目錄,表明此次請(qǐng)求失敗。

(4)事務(wù)溢出的處理——處理機(jī)P通知目錄要將修改后的數(shù)據(jù)存到內(nèi)存中(目前,內(nèi)存中存在的是對(duì)應(yīng)數(shù)據(jù)修改前的“臟”數(shù)據(jù))。步驟①:P發(fā)出PUTX請(qǐng)求給目錄。步驟②:目錄認(rèn)可后發(fā)送應(yīng)答信號(hào)給P,通知P可以發(fā)送。步驟③:P接收到此信號(hào)后將數(shù)據(jù)寫回內(nèi)存(WB_XACT)同時(shí)將溢出位置1(表明此數(shù)據(jù)已經(jīng)不在cache中)。這樣在寫回操作完成后,P中相關(guān)數(shù)據(jù)塊信息已置為無(wú)效,但是目錄中仍然保持著原先P持有數(shù)據(jù)時(shí)的狀態(tài),內(nèi)存中對(duì)應(yīng)區(qū)域已為修改后的“干凈”數(shù)據(jù),目錄中該數(shù)據(jù)相應(yīng)的狀態(tài)也由“老”變成了“新”,表明內(nèi)存中此數(shù)據(jù)已為更新后的數(shù)據(jù)。

(5)溢出數(shù)據(jù)的事務(wù)沖突檢測(cè)——步驟①:處理機(jī)Q重新發(fā)出請(qǐng)求數(shù)據(jù)信號(hào)給目錄,由于目錄中的狀態(tài)還沒(méi)有改變。步驟②:目錄根據(jù)當(dāng)前狀態(tài)再次將請(qǐng)求轉(zhuǎn)發(fā)給處理機(jī)P,而此時(shí)Q請(qǐng)求的數(shù)據(jù)塊已經(jīng)寫回內(nèi)存中去了,并不在P的cache中,P收到請(qǐng)求信號(hào)后檢查到自身的溢出位已經(jīng)置位,它認(rèn)為此數(shù)據(jù)可能由于某種原因不在cache中,但是仍然與它相關(guān)。比如:由于此數(shù)據(jù)塊大小大于cache規(guī)定塊大小而不能放下,但仍需操作。步驟③:P發(fā)出沖突信號(hào)(NACK)給Q,但是這個(gè)沖突并不是真正意義上的沖突,而是P假設(shè)的沖突。步驟④:Q收到?jīng)_突信號(hào)后處理沖突同時(shí)發(fā)送信號(hào)給目錄,表明此次請(qǐng)求再次失敗。

(6)目錄中數(shù)據(jù)狀態(tài)的懶惰(Lazy)更新——處理機(jī)P提交事務(wù)后將TMcount減1,將對(duì)應(yīng)cache塊的讀/寫標(biāo)志位和溢出標(biāo)志位清零,但此時(shí)目錄中的狀態(tài)仍然為M@P。步驟①:此時(shí)一旦處理機(jī)Q重新發(fā)出請(qǐng)求此數(shù)據(jù)信號(hào)。步驟②:該信號(hào)會(huì)再一次通過(guò)目錄轉(zhuǎn)發(fā)給處理機(jī)P,但此時(shí)P的溢出位已經(jīng)被清空。步驟③:P通過(guò)發(fā)送清除信息(CLEAN)給目錄通知目錄不必再轉(zhuǎn)發(fā)請(qǐng)求信息,目錄中的數(shù)據(jù)信息有效可以直接發(fā)送給請(qǐng)求的處理機(jī)Q。步驟④:目錄根據(jù)索引關(guān)系找到相關(guān)數(shù)據(jù)發(fā)送給處理機(jī)Q。步驟⑤:Q收到數(shù)據(jù)后進(jìn)行處理同時(shí)將應(yīng)答信號(hào)發(fā)送給目錄,表明請(qǐng)求成功同時(shí)將目錄對(duì)應(yīng)數(shù)據(jù)項(xiàng)狀態(tài)置E@Q,表示此時(shí)處理機(jī)Q獨(dú)占此數(shù)據(jù)資源。

但在執(zhí)行沖突檢測(cè)的過(guò)程中也會(huì)存在錯(cuò)誤的沖突,比如:當(dāng)處理機(jī)Q請(qǐng)求訪問(wèn)一個(gè)數(shù)據(jù)塊,該數(shù)據(jù)塊在目錄中的狀態(tài)為M@P,而處理機(jī)P已經(jīng)執(zhí)行到后續(xù)事務(wù),同時(shí)也置了溢出位。P發(fā)送沖突信號(hào)給Q,但這個(gè)沖突并不是因處理機(jī)Q請(qǐng)求的數(shù)據(jù)正被其他占有而產(chǎn)生的沖突,是一種無(wú)關(guān)的沖突。所以必須采取一種機(jī)制將目錄狀態(tài)及時(shí)更新。

2.3  操作系統(tǒng)對(duì)LogTM的支持

由于事務(wù)的引入,傳統(tǒng)操作系統(tǒng)已經(jīng)不能滿足要求,必須更改或擴(kuò)展操作系統(tǒng)使事務(wù)能穩(wěn)定高效的執(zhí)行。

首先,基于LogTM系統(tǒng),操作系統(tǒng)負(fù)責(zé)對(duì)日志進(jìn)行創(chuàng)建和維護(hù)。它為每一個(gè)執(zhí)行線程開辟一片日志區(qū)域,并將該區(qū)域入口地址寫到Log Base寄存器中,同時(shí)當(dāng)某數(shù)據(jù)存入日志后使Log Pointer指針后移,用來(lái)存放新數(shù)據(jù)。當(dāng)發(fā)生回滾,操作系統(tǒng)根據(jù)目前Log Pointer指針從后向前恢復(fù)數(shù)據(jù)直到Log Pointer與Log Base指向相同為止。

其次,當(dāng)執(zhí)行事務(wù)發(fā)生切換時(shí),操作系統(tǒng)可以通過(guò)擴(kuò)展目前的TCB(線程控制塊)來(lái)對(duì)事務(wù)相關(guān)寄存器內(nèi)容等信息進(jìn)行保存。

再次,當(dāng)發(fā)生事務(wù)級(jí)線程切換時(shí),操作系統(tǒng)判斷切換原因(包括其他線程搶占、時(shí)間片到達(dá)、事務(wù)之間沖突等而執(zhí)行的切換),通知調(diào)度器采取不同的切換策略或沖突策略來(lái)完成切換。

最后,由于中斷內(nèi)新創(chuàng)建的事務(wù)和被中斷事務(wù)沖突而導(dǎo)致活鎖(被中斷事務(wù)掛起得不到執(zhí)行,中斷內(nèi)新創(chuàng)建事務(wù)由于沖突策略一直回滾——重新執(zhí)行——回滾,也得不到執(zhí)行),操作系統(tǒng)必須能夠記錄回滾次數(shù)并設(shè)定一個(gè)門限值,如果同一事務(wù)回滾數(shù)超過(guò)此門限,操作系統(tǒng)可以強(qiáng)行中止該事務(wù)而調(diào)度其他事務(wù)。

3  結(jié)論及展望

本文介紹TM的基本原理,并對(duì)當(dāng)前主流TM系統(tǒng)LogTM進(jìn)行分析實(shí)現(xiàn),得出以下結(jié)論:

⑴要實(shí)現(xiàn)高效的事務(wù)處理必須要有一個(gè)很好的基于事務(wù)模型的硬件結(jié)構(gòu)。比如:LogTM,硬件專門為TM添加了LogBase、LogPointer等寄存器并改變了cache的結(jié)構(gòu),在cache中加入了讀(R)和寫(W)標(biāo)志位;這樣對(duì)事務(wù)版本管理以及沖突管理都帶來(lái)了前所未有的作用,這也是此TM結(jié)構(gòu)優(yōu)越性的體現(xiàn)。

⑵要高效的進(jìn)行事務(wù)處理必須要有TM操作系統(tǒng)的支持,上文中提到了一些操作系統(tǒng)對(duì)LogTM的相關(guān)支持,但如果要完美的支持事務(wù)還需要不斷更改和優(yōu)化已有的操作系統(tǒng),最終的目的是將操作系統(tǒng)事務(wù)化,并能很好的處理事務(wù)化的用戶級(jí)應(yīng)用。

⑶目前TM系統(tǒng)(包括LogTM)雖然通過(guò)一些特有的結(jié)構(gòu)和機(jī)制解決了事務(wù)處理的一些問(wèn)題,但是面對(duì)今后的發(fā)展,像多級(jí)嵌套事務(wù)的復(fù)雜應(yīng)用、中斷事務(wù)化(特別是外部設(shè)備的中斷)、掛起事物與執(zhí)行事務(wù)沖突問(wèn)題、被切換事務(wù)的執(zhí)行選擇(重新調(diào)度后,被切換事務(wù)可能回滾也可能繼續(xù)接著執(zhí)行)等問(wèn)題都需要我們不斷的去研究,去尋找最優(yōu)的解決辦法一一攻克,所以對(duì)TM的研究任重而道遠(yuǎn)。

參考文獻(xiàn)

[1]Yen, L. and J. Bobba, et al. LogTM-SE:Decoupling Hardware Transactional Memory from Caches. In Proc. of Thirteenth Annual International Symp. on High-Performance Computer Architecture.Feb.2007

[2]Moravan, M. J. and J. Bobba, et al. Supporting Nested Transactional Memory in LogTM. In Proc. of the Twelfth International Conference on Architectural Support for Programming Languages and Operating Systems, pages 359-370,Oct.2006

[3]Moore, K. E. and J. Bobba, et al. LogTM: Log_based Transactional Memory. In Proc. of the Twelfth IEEE Symp. on High-Performance Computer Architecture, pages 258–269, Feb. 2006

[4]Herlihy, M. and J. E. B. Moss . Transactional Memory:Architectural Support for Lock-Free Data Structures. In Proc. of the 20th Annual International Symp. on Computer Architecture, pages 289–300, May 1993

[5]Hammond, L. and V. Wong, et al. Transactional Memory Coherence and Consistency. In Proc. of the 31st Annual Intl. Symp. on Computer Architecture, June 2004

[6]Hammond, L. and B. D. Carlstrom, et al. Programming with Transactional Coherence and Consistency(TCC), ASPLOS.04, October 7–13, 2004

更多計(jì)算機(jī)與外設(shè)信息請(qǐng)關(guān)注:21ic計(jì)算機(jī)與外設(shè)頻道

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動(dòng)電源

在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢(shì)抑制與過(guò)流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動(dòng)電源

LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問(wèn)題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗(yàn)。要解決這一問(wèn)題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動(dòng)電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動(dòng)電源的公式,電感內(nèi)電流波動(dòng)大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動(dòng)電源

電動(dòng)汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車的動(dòng)力性能和...

關(guān)鍵字: 電動(dòng)汽車 新能源 驅(qū)動(dòng)電源

在現(xiàn)代城市建設(shè)中,街道及停車場(chǎng)照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢(shì)逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動(dòng)電源 LED

LED通用照明設(shè)計(jì)工程師會(huì)遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動(dòng)電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問(wèn)題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會(huì)影響LED燈具的正常工作,還可能對(duì)周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來(lái)解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動(dòng)電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源

關(guān)鍵字: LED 驅(qū)動(dòng)電源 開關(guān)電源

LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動(dòng)電源
關(guān)閉