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

牽著老婆滿街逛

嚴(yán)以律己,寬以待人. 三思而后行.
GMail/GTalk: yanglinbo#google.com;
MSN/Email: tx7do#yahoo.com.cn;
QQ: 3 0 3 3 9 6 9 2 0 .

內(nèi)核同步機制-優(yōu)化屏障和內(nèi)存屏障

轉(zhuǎn)載自:http://blog.csdn.net/erazy0/article/details/6210569

優(yōu)化屏障

編譯器編譯源代碼時,會將源代碼進(jìn)行優(yōu)化,將源代碼的指令進(jìn)行重排序,以適合于CPU的并行執(zhí)行。然而,內(nèi)核同步必須避免指令重新排序,優(yōu)化屏障(Optimization barrier)避免編譯器的重排序優(yōu)化操作,保證編譯程序時在優(yōu)化屏障之前的指令不會在優(yōu)化屏障之后執(zhí)行。
Linux用宏barrier實現(xiàn)優(yōu)化屏障,gcc編譯器的優(yōu)化屏障宏定義列出如下(在include/linux/compiler-gcc.h中): 

#define barrier() __asm__ __volatile__("": : :"memory")

上述定義中,“__asm__”表示插入了匯編語言程序,“__volatile__”表示阻止編譯器對該值進(jìn)行優(yōu)化,確保變量使用了用戶定義的精確地址,而不是裝有同一信息的一些別名。“memory”表示指令修改了內(nèi)存單元。


內(nèi)存屏障

軟件可通過讀寫屏障強制內(nèi)存訪問次序。讀寫屏障像一堵墻,所有在設(shè)置讀寫屏障之前發(fā)起的內(nèi)存訪問,必須先于在設(shè)置屏障之后發(fā)起的內(nèi)存訪問之前完成,確保內(nèi)存訪問按程序的順序完成。
讀寫屏障通過處理器構(gòu)架的特殊指令mfence(內(nèi)存屏障)、lfence(讀屏障)和sfence(寫屏障)完成,見《x86-64構(gòu)架規(guī)范》一章。另外,在x86-64處理器中,對硬件進(jìn)行操作的匯編語言指令是“串行的”,也具有內(nèi)存屏障的作用,如:對I/O端口進(jìn)行操作的所有指令、帶lock前綴的指令以及寫控制寄存器、系統(tǒng)寄存器或調(diào)試寄存器的所有指令(如:cli和sti)。
Linux內(nèi)核提供的內(nèi)存屏障API函數(shù)說明如表2。內(nèi)存屏障可用于多處理器和單處理器系統(tǒng),如果僅用于多處理器系統(tǒng),就使用smp_xxx函數(shù),在單處理器系統(tǒng)上,它們什么都不要。
表2 內(nèi)存屏障API函數(shù)說明

內(nèi)存屏障的宏定義 功能說明
mb() 適用于多處理器和單處理器的內(nèi)存屏障。
rmb() 適用于多處理器和單處理器的讀內(nèi)存屏障。
wmb() 適用于多處理器和單處理器的寫內(nèi)存屏障。
smp_mb() 適用于多處理器的內(nèi)存屏障。
smp_rmb() 適用于多處理器的讀內(nèi)存屏障。
smp_wmb() 適用于多處理器的寫內(nèi)存屏障。

適合于多處理器和單處理器的內(nèi)存屏障宏定義列出如下(在include/asm-x86/system.h中): 

#ifdef CONFIG_X86_32
/*指令“lock; addl $0,0(%%esp)”表示加鎖,把0加到棧頂?shù)膬?nèi)存單元,該指令操作本身無意義,但這些指令起到內(nèi)存屏障的作用,讓前面的指令執(zhí)行完成。具有XMM2特征的CPU已有內(nèi)存屏障指令,就直接使用該指令*/
    
#define mb() alternative("lock; addl $0,0(%%esp)", "mfence", X86_FEATURE_XMM2)
    
#define rmb() alternative("lock; addl $0,0(%%esp)", "lfence", X86_FEATURE_XMM2)
    
#define wmb() alternative("lock; addl $0,0(%%esp)", "sfence", X86_FEATURE_XMM)
#else
    
#define mb() asm volatile("mfence":::"memory")
    
#define rmb() asm volatile("lfence":::"memory")
    
#define wmb() asm volatile("sfence" ::: "memory")
#endif

/*刷新后面的讀所依賴的所有掛起讀操作,在x86-64構(gòu)架上不需要*/
#define read_barrier_depends() do { } while (0)

宏定義ead_barrier_depends()刷新后面的讀所依賴的所有掛起讀操作,后面的讀操作依賴于正處理的讀操作返回的數(shù)據(jù)。在x86-64構(gòu)架上不需要此宏。它表明:在此屏障之前,沒有來自內(nèi)存區(qū)域數(shù)據(jù)所依賴的讀曾經(jīng)重排序。所有的讀操作處理此原語,保證在跟隨此原語的任何讀操作此原語之前訪問內(nèi)存(但不需要其他CPU的cache)。此原語在大多數(shù)CPU上有比rmb()更輕的份量。
本地CPU和編譯器遵循內(nèi)存屏障的排序限制,僅內(nèi)存屏障原語保證排序,即使數(shù)據(jù)有依賴關(guān)系,也不能保證排序。例如:下面代碼將強迫排序,因為*q的讀操作依賴于p的讀操作,并且這兩個讀操作被read_barrier_depends()分開。在CPU 0和CPU 1上執(zhí)行的程序語句分別列出如下:

CPU 0                                      CPU 1 
= 2;
memory_barrier();
= &b;                                      q = p;
                                                read_barrier_depends();
                                                d 
= *q;


下面的代碼沒有強制排序,因為在a和b的讀操作之間沒有依賴關(guān)系,因此,在一些CPU上,如:Alpha,y將設(shè)置為3,x設(shè)置為0。類似這種沒有數(shù)據(jù)依賴關(guān)系的讀操作,需要排序應(yīng)使用rmb()。

CPU 0                                        CPU 1

= 2;
memory_barrier();
= 3;                                         y = b;
                                                 read_barrier_depends();
                                                 x 
= a;


 

適合于多處理器的內(nèi)存屏障宏定義列出如下(在include/asm-x86/system.h中): 

#ifdef CONFIG_SMP
    
#define smp_mb() mb()


    #ifdef CONFIG_X86_PPRO_FENCE
        # define smp_rmb() rmb()
    
#else
        # define smp_rmb() barrier()
    
#endif


    #ifdef CONFIG_X86_OOSTORE
        # define smp_wmb() wmb()
    
#else
        # define smp_wmb() barrier()
    
#endif


    
#define smp_read_barrier_depends() read_barrier_depends()
    
#define set_mb(var, value) do { (void)xchg(&var, value); } while (0)
#else
    
#define smp_mb() barrier()
    
#define smp_rmb() barrier()
    
#define smp_wmb() barrier()
    
#define smp_read_barrier_depends() do { } while (0)
    
#define set_mb(var, value) do { var = value; barrier(); } while (0)
#endif

 

函數(shù)rdtsc_barrier用于加內(nèi)存屏障阻止RDTSC猜測,當(dāng)在一個定義的代碼區(qū)域使用讀取時間戳計數(shù)器(Read Time-Stamp Counter,RDTSC)函數(shù)(或者函數(shù)get_cycles或vread)時,必須加內(nèi)存屏障阻止RDTSC猜測。其列出如下:

static inline void rdtsc_barrier(void)
{
    alternative(ASM_NOP3, 
"mfence", X86_FEATURE_MFENCE_RDTSC);
    alternative(ASM_NOP3, 
"lfence", X86_FEATURE_LFENCE_RDTSC);
}




 

posted on 2011-08-30 14:17 楊粼波 閱讀(1111) 評論(0)  編輯 收藏 引用 所屬分類: C++

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美中文字幕视频| 久久久精品2019中文字幕神马| 欧美精品1区2区3区| 久久国产成人| 欧美在线观看一二区| 亚洲女性喷水在线观看一区| 午夜视频在线观看一区| 久久精品国产91精品亚洲| 性色av一区二区三区在线观看 | 亚洲国产一区视频| 亚洲九九精品| 亚洲一区免费| 久久成人免费| 久久中文字幕一区| 蜜臀91精品一区二区三区| 美女免费视频一区| 99精品视频一区| 亚洲欧美在线视频观看| 久久亚洲风情| 国产精品扒开腿做爽爽爽软件| 国产精品久久久久三级| 国产有码在线一区二区视频| 亚洲国产日韩欧美综合久久 | 欧美亚洲一区二区在线观看| 欧美一区国产在线| 免费中文日韩| 夜夜嗨一区二区| 欧美亚洲三区| 欧美精品亚洲一区二区在线播放| 欧美系列精品| 最近看过的日韩成人| 亚洲欧美日韩精品久久久| 久久久久久一区二区| 亚洲激情第一区| 99在线精品视频在线观看| 久久精品1区| 国产精品久久午夜夜伦鲁鲁| 亚洲国产精品久久久久秋霞蜜臀| 午夜精品久久久久久久99黑人| 欧美激情一区二区久久久| 午夜宅男欧美| 国产精品免费在线| 9l视频自拍蝌蚪9l视频成人| 男女av一区三区二区色多| 亚洲欧美成人精品| 欧美日韩在线视频一区| 136国产福利精品导航| 久久精品成人一区二区三区| 一区二区三区回区在观看免费视频| 欧美成人69av| 亚洲国产成人精品女人久久久 | 亚洲影视在线| 欧美日一区二区三区在线观看国产免| 尤物精品在线| 老巨人导航500精品| 亚洲女同同性videoxma| 欧美午夜理伦三级在线观看| 艳女tv在线观看国产一区| 欧美成人免费播放| 久久精品视频网| 国产亚洲网站| 久久久久久尹人网香蕉| 亚洲欧美中文日韩v在线观看| 国产精品国产三级国产aⅴ无密码| 男女激情久久| 美女日韩在线中文字幕| 一区二区三区亚洲| 久久精品国产清高在天天线| 亚洲欧美激情在线视频| 国产精品一区二区欧美| 亚洲欧美日本日韩| 亚洲综合视频1区| 国产一区二区精品久久91| 午夜一区二区三区在线观看| 亚洲亚洲精品在线观看| 国产精品区一区| 欧美一区亚洲| 亚洲欧美日韩高清| 国产综合在线看| 久久午夜av| 欧美搞黄网站| 性色av一区二区三区在线观看 | 久久久激情视频| 韩日欧美一区二区| 久久影视精品| 欧美精品日韩综合在线| 亚洲伊人久久综合| 欧美一站二站| 亚洲人成精品久久久久| 夜夜嗨av一区二区三区中文字幕 | 亚洲午夜精品在线| 国产日韩欧美一区二区| 久久亚洲风情| 欧美日本免费| 久久国产综合精品| 欧美va亚洲va香蕉在线| 亚洲一区二区三区高清| 午夜老司机精品| 亚洲欧洲日产国产网站| 一区二区三区成人精品| 欧美精品免费播放| 久久精品国产第一区二区三区最新章节 | 久久中文在线| 欧美激情a∨在线视频播放| 亚洲一二三四久久| 久久青草欧美一区二区三区| 日韩视频免费在线观看| 亚洲欧美中文另类| 日韩一区二区精品在线观看| 亚洲欧美在线一区| 日韩亚洲精品电影| 久久精品国产亚洲一区二区| 一区二区电影免费观看| 欧美中文日韩| 亚洲欧美影院| 欧美在线观看一二区| 免费成人高清视频| 性亚洲最疯狂xxxx高清| 欧美激情精品久久久久| 久久躁狠狠躁夜夜爽| 国产精品久久久久91| 亚洲国产一区二区三区青草影视| 国产一区二区高清视频| 亚洲私拍自拍| 一本一本久久| 欧美激情精品久久久久久蜜臀 | 午夜精品一区二区三区四区| 毛片一区二区三区| 久久久免费av| 国产欧美日韩不卡免费| 艳女tv在线观看国产一区| 亚洲国产一区二区三区a毛片| 欧美一区久久| 欧美在线视频免费播放| 国产精品欧美日韩| 亚洲天堂成人在线观看| 一区二区三区精品| 欧美日韩高清不卡| 亚洲级视频在线观看免费1级| 一区二区三区在线免费视频| 香蕉久久精品日日躁夜夜躁| 亚洲欧美第一页| 国产精品麻豆va在线播放| 亚洲免费观看高清完整版在线观看| 最新国产成人在线观看| 久久婷婷久久一区二区三区| 蜜桃久久精品乱码一区二区| 黄色小说综合网站| 久久夜色撩人精品| 亚洲大胆女人| 亚洲毛片播放| 欧美午夜久久久| 亚洲欧美激情四射在线日 | 午夜视频在线观看一区二区三区| 亚洲一区二区三区四区在线观看| 欧美日韩国产专区| 99成人在线| 欧美在线欧美在线| 国产一区 二区 三区一级| 久久精品国产v日韩v亚洲| 久久夜色撩人精品| 亚洲精品久久久久久久久久久久久| 欧美大片免费| 中文精品一区二区三区 | 亚洲日韩第九十九页| 一本大道久久a久久精品综合 | 亚洲国产欧美日韩另类综合| 欧美大片免费观看| 一区二区三区三区在线| 欧美一级视频一区二区| 国产在线麻豆精品观看| 牛夜精品久久久久久久99黑人| 亚洲激情小视频| 欧美中文字幕久久| 激情成人综合| 亚洲欧洲精品一区二区三区不卡| 国语自产精品视频在线看8查询8| 鲁大师成人一区二区三区| 亚洲理论在线| 久久久久国产精品人| 亚洲三级电影在线观看 | 欧美成人有码| 亚洲色在线视频| 欧美大秀在线观看| 午夜在线播放视频欧美| 亚洲国产精品一区二区www在线| 国产精品二区二区三区| 免费不卡视频| 久久成人国产| 在线一区免费观看| 欧美sm视频| 欧美在线视频导航| 一区二区三区不卡视频在线观看| 国内外成人免费激情在线视频| 欧美片在线观看| 久久综合久久久久88| 亚洲欧美日韩国产中文| 日韩视频中文| 欧美二区乱c少妇| 久久久久免费观看|