青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 297,  comments - 15,  trackbacks - 0
關于單CPU,多CPU上的原子操作  轉自http://software.intel.com/zh-cn/blogs/2010/01/14/cpucpu/?cid=sw:prccsdn956

    所謂原子操作,就是"不可中斷的一個或一系列操作" 。

硬件級的原子操作:
    在單處理器系統(UniProcessor)中,能夠在單條指令中完成的操作都可以認為是" 原子操作",因為中斷只能發生于指令之間。這也是某些CPU指令系統中引入了test_and_set、test_and_clear等指令用于臨界資源互斥的原因。

    在對稱多處理器(Symmetric Multi-Processor)結構中就不同了,由于系統中有多個處理器在獨立地運行,即使能在單條指令中完成的操作也有可能受到干擾。

    在x86 平臺上,CPU提供了在指令執行期間對總線加鎖的手段。CPU芯片上有一條引線#HLOCK pin,如果匯編語言的程序中在一條指令前面加上前綴"LOCK",經過匯編以后的機器代碼就使CPU在執行這條指令的時候把#HLOCK pin的電位拉低,持續到這條指令結束時放開,從而把總線鎖住,這樣同一總線上別的CPU就暫時不能通過總線訪問內存了,保證了這條指令在多處理器環境中 的原子性。
軟件級的原子操作:
    軟件級的原子操作實現依賴于硬件原子操作的支持。
    對于linux而言,內核提供了兩組原子操作接口:一組是針對整數進行操作;另一組是針對單獨的位進行操作。
2.1. 原子整數操作
    針對整數的原子操作只能對atomic_t類型的數據處理。這里沒有使用C語言的int類型,主要是因為:

    1) 讓原子函數只接受atomic_t類型操作數,可以確保原子操作只與這種特殊類型數據一起使用

    2) 使用atomic_t類型確保編譯器不對相應的值進行訪問優化

    3) 使用atomic_t類型可以屏蔽不同體系結構上的數據類型的差異。盡管Linux支持的所有機器上的整型數據都是32位,但是使用atomic_t的代 碼只能將該類型的數據當作24位來使用。這個限制完全是因為在SPARC體系結構上,原子操作的實現不同于其它體系結構:32位int類型的低8位嵌入了 一個鎖,因為SPARC體系結構對原子操作缺乏指令級的支持,所以只能利用該鎖來避免對原子類型數據的并發訪問。

    原子整數操作最常見的用途就是實現計數器。原子整數操作列表在中定義。原子操作通常是內斂函數,往往通過內嵌匯編指令來實現。如果某個函數本來就是原子的,那么它往往會被定義成一個宏。

在編寫內核時,操作也簡單:

    atomic_t use_cnt;

    atomic_set(&use_cnt, 2);

    atomic_add(4, &use_cnt);

    atomic_inc(use_cnt);

2.2. 原子性與順序性

    原子性確保指令執行期間不被打斷,要么全部執行,要么根本不執行。而順序性確保即使兩條或多條指令出現在獨立的執行線程中,甚至獨立的處理器上,它們本該執行的順序依然要保持。

2.3. 原子位操作

    原子位操作定義在文件中。令人感到奇怪的是位操作函數是對普通的內存地址進行操作的。原子位操作在多數情況下是對一個字長的內存訪問,因而位號該位于0-31之間(在64位機器上是0-63之間),但是對位號的范圍沒有限制。

編寫內核代碼,只要把指向了你希望的數據的指針給操作函數,就可以進行位操作了:

    unsigned long word = 0;

    set_bit(0, &word); /*第0位被設置*/

    set_bit(1, &word); /*第1位被設置*/

    clear_bit(1, &word); /*第1位被清空*/

    change_bit(0, &word); /*翻轉第0位*/

為什么關注原子操作?
    1)在確認一個操作是原子的情況下,多線程環境里面,我們可以避免僅僅為保護這個操作在外圍加上性能開銷昂貴的鎖。
    2)借助于原子操作,我們可以實現互斥鎖。
    3)借助于互斥鎖,我們可以把一些列操作變為原子操作。

GNU C中x++是原子操作嗎?
    答案不是。x++由3條指令完成。x++在單CPU下不是原子操作。
    對應3條匯編指令
    movl x, %eax
    addl $1, %eax
    movl %eax, x
    在vc2005下對應
    ++x;
    004232FA mov eax,dword ptr [x]
    004232FD add eax,1
    00423300 mov dword ptr [x],eax
    仍然是3條指令。
    所以++x,x++等都不是原子操作。因其步驟包括了從內存中取x值放入寄存器,加寄存器,把值寫入內存三個指令。

如何實現x++的原子性?
    在單處理器上,如果執行x++時,禁止多線程調度,就可以實現原子。因為單處理的多線程并發是偽并發。
    在多處理器上,需要借助cpu提供的Lock功能。鎖總線。讀取內存值,修改,寫回內存三步期間禁止別的CPU訪問總線。同時我估計使用Lock指令鎖總線的時候,OS也不會把當前線程調度走了。要是調走了,那就麻煩了。

    在多處理器系統中存在潛在問題的原因是:
    不使用LOCK指令前綴鎖定總線的話,在一次內存訪問周期中有可能其他處理器會產生異常或中斷,而在異常處理中有可能會修改尚未寫入的地址,這樣當INC操作完成后會產生無效數據(覆蓋了前面的修改)。

    spinlock 用于CPU同步, 它的實現是基于CPU鎖定數據總線的指令.
    當某個CPU鎖住數據總線后, 它讀一個內存單元(spinlock_t)來判斷這個spinlock 是否已經被別的CPU鎖住. 如果否, 它寫進一個特定值, 表示鎖定成功, 然后返回. 如果是, 它會重復以上操作直到成功, 或者spin次數超過一個設定值. 鎖定數據總線的指令只能保證一個機器指令內, CPU獨占數據總線.
    單CPU當然能用spinlock, 但實現上無需鎖定數據總線.

    spinlock在鎖定的時候,如果不成功,不會睡眠,會持續的嘗試,單cpu的時候spinlock會讓其它process動不了.

from:
http://blog.csdn.net/microtong/archive/2010/01/20/5211750.aspx


posted on 2010-04-03 21:05 chatler 閱讀(1324) 評論(0)  編輯 收藏 引用 所屬分類: C++_BASIS
<2009年11月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
293012345

常用鏈接

留言簿(10)

隨筆分類(307)

隨筆檔案(297)

algorithm

Books_Free_Online

C++

database

Linux

Linux shell

linux socket

misce

  • cloudward
  • 感覺這個博客還是不錯,雖然做的東西和我不大相關,覺得看看還是有好處的

network

OSS

  • Google Android
  • Android is a software stack for mobile devices that includes an operating system, middleware and key applications. This early look at the Android SDK provides the tools and APIs necessary to begin developing applications on the Android platform using the Java programming language.
  • os161 file list

overall

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美激情91| av成人激情| 久久se精品一区精品二区| 国产精品午夜av在线| 亚洲一区二区三区三| 亚洲视频免费| 国产精品一区二区你懂得 | 亚洲小说欧美另类社区| 亚洲激情图片小说视频| 麻豆av一区二区三区| 亚洲久久成人| 宅男噜噜噜66一区二区| 国产精品一国产精品k频道56| 午夜日韩在线观看| 久久精品国产2020观看福利| 亚洲成人中文| 亚洲精品一级| 国产日韩欧美91| 美女成人午夜| 欧美三区视频| 久久免费99精品久久久久久| 免费在线亚洲欧美| 亚洲无毛电影| 久久久久天天天天| 亚洲午夜精品一区二区| 欧美一区在线视频| 日韩视频精品在线观看| 亚洲永久免费av| 在线精品一区二区| 一本一本久久a久久精品综合妖精| 国产精品久久久久久久久久免费看 | 欧美日本一区二区三区| 久久精品国产免费| 欧美激情导航| 久久亚洲免费| 欧美视频一区二区三区四区| 久久一区二区精品| 欧美视频你懂的| 欧美a级片网| 国产精品一二三视频| 亚洲高清在线观看| 国内一区二区在线视频观看| 亚洲另类一区二区| 揄拍成人国产精品视频| 亚洲伊人网站| 99这里只有久久精品视频| 久久精品国产91精品亚洲| 亚洲一区三区电影在线观看| 免费在线播放第一区高清av| 欧美中文字幕精品| 欧美午夜精品一区| 91久久精品国产91性色tv| 亚洲福利视频三区| 久久国产精品高清| 久久国产精彩视频| 国产精品hd| 一区二区三区产品免费精品久久75 | 午夜精品视频| 亚洲欧美日韩视频二区| 欧美日韩中文字幕| 亚洲精品一区二区网址 | 欧美日韩在线播放三区| 亚洲国产精品一区二区第四页av| 永久555www成人免费| 性色av香蕉一区二区| 欧美一区二区日韩一区二区| 欧美视频中文一区二区三区在线观看| 亚洲福利视频网站| 亚洲国产高清一区二区三区| 久久久久久久波多野高潮日日| 久久久精品动漫| 国产日韩精品视频一区| 亚洲欧美日韩系列| 午夜在线电影亚洲一区| 国产精品亚洲一区| 亚洲免费小视频| 欧美一区二区三区日韩视频| 国产精品青草久久久久福利99| 亚洲一区二区在| 久久国产精品99国产| 狠狠干综合网| 久久婷婷国产综合国色天香| 欧美国产激情二区三区| 亚洲精品国产精品国自产在线| 欧美激情小视频| 99一区二区| 久久国产精品一区二区| 一区二区在线视频播放| 男女精品网站| 99国内精品| 久久精品夜夜夜夜久久| 在线观看精品| 欧美人与禽性xxxxx杂性| 夜夜嗨av一区二区三区四区| 欧美一区二区三区播放老司机| 国产一区自拍视频| 欧美成人一品| 亚洲欧美欧美一区二区三区| 久久影院午夜片一区| 亚洲美洲欧洲综合国产一区| 欧美午夜激情在线| 久久久精品网| 亚洲人成亚洲人成在线观看图片| 亚洲欧美一区二区三区在线| 国内精品视频久久| 欧美日韩三级在线| 久久成人资源| 一本一道久久综合狠狠老精东影业 | 亚洲毛片av| 国产精品网站在线观看| 嫩草国产精品入口| 亚洲伊人观看| 亚洲看片网站| 美女精品在线观看| 欧美一级播放| 99精品国产一区二区青青牛奶| 国产日韩欧美一区二区| 欧美激情第一页xxx| 欧美一级二区| aa级大片欧美| 亚洲黄色av一区| 乱码第一页成人| 销魂美女一区二区三区视频在线| 亚洲国产裸拍裸体视频在线观看乱了 | 亚洲在线黄色| 亚洲精品乱码久久久久久按摩观| 久久在线免费| 午夜精品久久久久久久久久久久| 亚洲日本中文字幕| 精品成人一区二区| 国产午夜精品在线| 国产精品入口麻豆原神| 欧美区在线观看| 欧美xart系列在线观看| 久久免费视频观看| 久久精品亚洲一区二区| 亚洲愉拍自拍另类高清精品| 亚洲卡通欧美制服中文| 亚洲国产精品日韩| 亚洲国产精品黑人久久久| 久色婷婷小香蕉久久| 久久久久国产一区二区三区四区| 亚洲欧美精品在线| 亚洲午夜视频在线| 亚洲视频狠狠| 亚洲一二三区视频在线观看| 日韩西西人体444www| 亚洲精品一区在线观看香蕉| 亚洲激情电影在线| 亚洲国产一区在线| 亚洲国产婷婷综合在线精品| 在线成人免费观看| 亚洲国产精品免费| 亚洲黄色一区二区三区| 亚洲高清视频中文字幕| 亚洲欧洲日本专区| 亚洲毛片在线观看.| 日韩香蕉视频| 午夜视频一区在线观看| 先锋影音一区二区三区| 欧美一区二区三区精品电影| 午夜精品久久| 久久免费少妇高潮久久精品99| 久久午夜国产精品| 欧美激情视频一区二区三区不卡| 亚洲国产精品久久| 亚洲日本欧美日韩高观看| 宅男在线国产精品| 亚洲综合三区| 久久手机精品视频| 欧美激情精品久久久| 国产精品成人一区二区艾草| 国产女同一区二区| 亚洲第一主播视频| 一本大道久久精品懂色aⅴ| 亚洲一区二区三区三| 久久本道综合色狠狠五月| 欧美xxxx在线观看| 亚洲免费激情| 欧美一区二区在线免费播放| 老巨人导航500精品| 欧美色视频日本高清在线观看| 国产伦精品一区二区三区高清版| 精品88久久久久88久久久| 亚洲精品国产精品国自产观看| 亚洲嫩草精品久久| 欧美不卡高清| 亚洲网站在线播放| 久久久免费精品视频| 欧美视频在线观看免费网址| 激情久久综艺| 亚洲欧美精品suv| 欧美成年视频| 亚洲一区二区三区精品在线| 麻豆国产精品一区二区三区| 国产精品毛片a∨一区二区三区|国| 亚洲国产毛片完整版| 久久gogo国模裸体人体| 91久久极品少妇xxxxⅹ软件| 欧美一级精品大片|