• <tr id="yyy80"></tr>
  • <sup id="yyy80"></sup>
  • <tfoot id="yyy80"><noscript id="yyy80"></noscript></tfoot>
  • 99热精品在线国产_美女午夜性视频免费_国产精品国产高清国产av_av欧美777_自拍偷自拍亚洲精品老妇_亚洲熟女精品中文字幕_www日本黄色视频网_国产精品野战在线观看 ?

    基于OpenMP編程模型的多線(xiàn)程程序性能分析

    2014-03-26 13:06:48李梅
    電子設(shè)計(jì)工程 2014年23期
    關(guān)鍵詞:線(xiàn)程內(nèi)存處理器

    李梅

    (西安歐亞學(xué)院 陜西 西安 710065)

    多核環(huán)境下軟件開(kāi)發(fā)的核心是多線(xiàn)程開(kāi)發(fā)[1]。采用多線(xiàn)程程序設(shè)計(jì)技術(shù)可以提高系統(tǒng)及 程序的運(yùn)行性能,諸如吞吐量、計(jì)算速度、響應(yīng)時(shí)間等。所以高性能、高效率是多線(xiàn)程程序并行化的目的之一。但是在很多情況下并行化后的程序并不能達(dá)到預(yù)期的執(zhí)行性能。影響執(zhí)行性能的原因是多方面的,比如OpenMP并行化的開(kāi)銷(xiāo)、線(xiàn)程在 CPU核間的動(dòng)態(tài)遷移、負(fù)載平衡、線(xiàn)程同步開(kāi)銷(xiāo)等。

    OpenMP是一種面向共享存儲(chǔ)體系結(jié)構(gòu)的多線(xiàn)程并行編程語(yǔ)言[2],是一種共享內(nèi)存并行的應(yīng)用程序編程接口。所有處理器都被連接到一個(gè)共享的內(nèi)存單元上,處理器在訪(fǎng)問(wèn)內(nèi)存的時(shí)候使用的是相同的內(nèi)存編址空間,由于內(nèi)存共享,因此,某一處理器寫(xiě)入的數(shù)據(jù)會(huì)立刻被其他處理器訪(fǎng)問(wèn)到。OpenMP編程模型通過(guò)提供一組與平臺(tái)無(wú)關(guān)的編譯指導(dǎo)、運(yùn)行時(shí)庫(kù)函數(shù)及環(huán)境變量,指導(dǎo)編譯器何時(shí)以及如何利用程序中的并行性進(jìn)行多線(xiàn)程并行執(zhí)行。OpenMP在并行執(zhí)行程序時(shí),采用Fork/Join方式,它的基本思想是串行區(qū)域由主線(xiàn)程執(zhí)行,并行程序通過(guò)派生多個(gè)線(xiàn)程來(lái)并行執(zhí)行,并行執(zhí)行的程序要全部結(jié)束后才能執(zhí)行后面的非并行執(zhí)行的代碼[3]。

    1 OpenMP并行化的開(kāi)銷(xiāo)

    OpenMP是一個(gè)外部編程模型,而不是自動(dòng)編程模型,它能夠使程序員完全控制并行化[4]。OpenMP并行化本身是有一定開(kāi)銷(xiāo)的,因?yàn)镺penMP獲得應(yīng)用程序多線(xiàn)程并行化能力需要程序庫(kù)的支持,庫(kù)中代碼的運(yùn)行會(huì)帶來(lái)一定的開(kāi)銷(xiāo)。這種開(kāi)銷(xiāo)是不可避免的。但有時(shí)這種開(kāi)銷(xiāo)是沒(méi)有必要的。實(shí)際上,并不是所有的代碼都需要并行化,有些情況下,并行化之后程序的運(yùn)行效率反而比不上串行執(zhí)行的效率。很大一部分原因是由于使用OpenMP進(jìn)行并行化之后引入OpenMP本身的開(kāi)銷(xiāo)過(guò)大。因此,只有并行執(zhí)行代碼段負(fù)擔(dān)足夠大,而引入OpenMP本身的開(kāi)銷(xiāo)又足夠小,此時(shí)引入并行化操作才能加速程序的執(zhí)行。由于并行化會(huì)帶來(lái)額外的開(kāi)銷(xiāo),因此,從效率上考慮,并不是所有的程序都應(yīng)當(dāng)并行化的,特別是對(duì)于小程序,并行化帶來(lái)的效率不足以彌補(bǔ)并行化本身帶來(lái)的運(yùn)行負(fù)擔(dān),勉強(qiáng)進(jìn)行并行化就會(huì)得不償失。應(yīng)當(dāng)盡量使得程序真正工作的負(fù)載超過(guò)并行化的負(fù)擔(dān),每一個(gè)線(xiàn)程負(fù)擔(dān)的工作要足夠多,這樣才能獲得并行化之后的性能提升。例如:

    #include “stdafx.h”

    #include

    #include

    int_tmain(intargc,_TCHAR*argv[])

    {

    clock_tstart,stop;

    unsigned long sum=0;

    start=clock();

    #pragamomp parallel for reduction(+:sum)

    for(int i=0;i<1000;i++)

    sum=sum+i;

    stop=clock();

    printf(“exec with OpenMP:sum=%ul,time=%f seconds ”,sum, ((double)

    (stop-start)/1000.0));

    sum=0;

    start=clock();

    for(int i=0;i<1000;i++)

    sum=sum+i;

    stop=clock();

    printf (“serial exec:sum=%ul,time=%f seconds ”,sum,((double)(stop-start)/1000.0));

    return 0;

    }

    第一個(gè)循環(huán)使用了OpenMP對(duì)循環(huán)進(jìn)行并行化,而第二個(gè)循環(huán)使用了簡(jiǎn)單的串行執(zhí)行方式。下面是程序的一次執(zhí)行結(jié)果:

    exec with OpenMP:sum=499950001,time=0.016000 seconds serial exec:sum=499950001,time=0.000000 seconds

    可以看到串行執(zhí)行的效率要比并行執(zhí)行的效率高,這主要是由于循環(huán)的規(guī)模比較小,使用并行化帶來(lái)的效果無(wú)法抵消并行化的額外負(fù)擔(dān)。但是如果將上述循環(huán)次數(shù)改為1000000000

    exec with openmp:sum=8874597121,timei=0.156000 seconds

    serial exec:sum=8874597121,timei=0.297000 seconds

    加速比為0.297000/0.156000=1.9034。

    從這個(gè)例子中明顯看到在編寫(xiě)并行化程序時(shí),應(yīng)當(dāng)盡量使得程序真正工作的負(fù)載超過(guò)并行化的負(fù)擔(dān),每一個(gè)線(xiàn)程負(fù)擔(dān)的工作要足夠多,這樣才能獲得并行化之后的性能提升。

    2 線(xiàn)程在CPU核間的動(dòng)態(tài)遷移

    OpenMP應(yīng)用程序中,如果過(guò)多的線(xiàn)程集中在一個(gè)CPU上訪(fǎng)問(wèn)不同的內(nèi)存塊,顯然這種對(duì)內(nèi)存總線(xiàn)的競(jìng)爭(zhēng)會(huì)顯著降低訪(fǎng)存的速度。為提高處理器核的使用效率,主流操作系統(tǒng)調(diào)整了其調(diào)度算法,最常用的就是負(fù)載均衡技術(shù),將 CPU的負(fù)荷平均分配到多個(gè) CPU核中,這就意味著,在比較繁忙的CPU核上運(yùn)行的線(xiàn)程可能會(huì)被操作系統(tǒng)自動(dòng)遷移到空閑的CPU核上,這種遷移將導(dǎo)致被遷移的線(xiàn)程的上下文需要遷移到新的CPU核上。如果頻繁遷移會(huì)導(dǎo)致應(yīng)用程序性能下降。為避免線(xiàn)程在CPU核間的動(dòng)態(tài)遷移,可以在不同平臺(tái)下將OpenMP線(xiàn)程綁定到指定的 CPU核上運(yùn)行,從而消除由于遷移原因而導(dǎo)致的性能降低。

    1)windows平臺(tái)下線(xiàn)程和CPU核的綁定

    一個(gè)程序指定到單獨(dú)一個(gè)CPU上運(yùn)行會(huì)比不指定CPU運(yùn)行時(shí)快。這中間主要有兩個(gè)原因:CPU切換時(shí)損耗的性能;Intel的自動(dòng)降頻技術(shù)和windows的機(jī)制沖突:windows有一個(gè)功能是平衡負(fù)載,可以將一個(gè)線(xiàn)程在不同時(shí)間分配到不同CPU,從而使得每一個(gè)CPU不“過(guò)累”。然而,Inter又有一個(gè)技術(shù)叫做SpeedStep,當(dāng)一個(gè)CPU沒(méi)有滿(mǎn)負(fù)荷運(yùn)行時(shí)自動(dòng)降頻從而達(dá)到節(jié)能減排的目的。這兩個(gè)功能實(shí)際是沖突的:一個(gè)程序被分配到多個(gè)CPU協(xié)同工作->每個(gè)CPU都不是滿(mǎn)載->每個(gè)CPU都會(huì)降頻->windows發(fā)現(xiàn)每個(gè)CPU性能都降低了,因此程序執(zhí)行速度也降低了。因此,將線(xiàn)程(進(jìn)程)綁定到指定CPU核心,不讓windows自作主張分散任務(wù),從而提高單線(xiàn)程效率是很有必要的。有兩種方法實(shí)現(xiàn)綁定進(jìn)程到指定CPU:

    手工調(diào)節(jié):在資源管理器的進(jìn)程里面,設(shè)置相關(guān)性,可以設(shè)置進(jìn)程到某個(gè)或者某些指定的CPU核心。

    代碼自動(dòng)調(diào)節(jié):

    DWORD_PTR SetThreadAffinityMask(HANDLE hThread,DWORD_PTR dwThreadAffinityMask);

    第一個(gè)參數(shù)為線(xiàn)程句柄。

    第二個(gè)參數(shù)為 mask,可取值為 0~2^31(32位)和 0~2^63(64位),每一位代表每一個(gè)CPU是否使用。

    2)Linux平臺(tái)下線(xiàn)程和CPU核的綁定

    從 Linux2.6內(nèi)核開(kāi)始,Linux系統(tǒng)提供API函數(shù) sched_setaffinity和sched_getaffinity將線(xiàn)程和CPU核進(jìn)行綁定。

    3 負(fù)載均衡

    對(duì)于OpenMP多線(xiàn)程程序而言,負(fù)載均衡是影響其運(yùn)行性能的重要因素[5]。在多線(xiàn)程程序中,保證線(xiàn)程間的負(fù)載平衡是提高程序性能的方法之一。良好的負(fù)載平衡可以保證執(zhí)行核盡可能的在大部分時(shí)間里保持忙碌的狀態(tài),將調(diào)度開(kāi)銷(xiāo)、上下文切換開(kāi)銷(xiāo)和同步開(kāi)銷(xiāo)降到最低。如果負(fù)載平衡做的很差,那么某些線(xiàn)程可能很早就完成了自己的工作,從而導(dǎo)致處理器資源閑置,降低了程序執(zhí)行的性能。

    通常情況下,循環(huán)并行的負(fù)載平衡差是由循環(huán)迭代計(jì)算時(shí)間的不確定性引起的。一方面,有的循環(huán)通過(guò)檢查源代碼的方法來(lái)確定循環(huán)迭代的計(jì)算時(shí)間是比較容易的。在多數(shù)情況下,循環(huán)迭代總是耗費(fèi)一定數(shù)量的時(shí)間,即便不是這樣,也可以找到耗時(shí)相近的一組迭代。例如,有時(shí)候所有的偶數(shù)迭代集合和所有奇數(shù)迭代集合所耗費(fèi)的時(shí)間幾乎相等,或者循環(huán)前半部分迭代和后半部分迭代所耗費(fèi)的時(shí)間幾乎相等。另一方面,要找出耗時(shí)相同的迭代集合幾乎是不可能的。然而不管怎樣,都可以通過(guò)OpenMP的調(diào)度策略提供循環(huán)調(diào)度信息,使編譯器和運(yùn)行時(shí)庫(kù)能夠更好的劃分迭代,并將迭代分布到各個(gè)線(xiàn)程上,從而實(shí)現(xiàn)更好的負(fù)載平衡。

    在編寫(xiě)OpenMP代碼時(shí),注意保證負(fù)載的均衡,盡量讓每個(gè)線(xiàn)程的工作量相當(dāng),從而保證程序的執(zhí)行效率。在循環(huán)并行化時(shí),采用將循環(huán)次數(shù)平均分配到所有線(xiàn)程中的靜態(tài)分配策略,因此線(xiàn)程的工作量在進(jìn)入循環(huán)并行化之前就已經(jīng)確定了。這種分配策略在每次循環(huán)迭代工作量相仿的時(shí)候可以較好的保證線(xiàn)程間的負(fù)載平衡,獲得良好的執(zhí)行效率。但是,在實(shí)際情況中,每次循環(huán)的工作量并不一定相同,有時(shí)會(huì)差距很大,這時(shí)靜態(tài)分配策略會(huì)引起線(xiàn)程間負(fù)載的不均衡,使得負(fù)載輕的線(xiàn)程無(wú)事可做,負(fù)載重的線(xiàn)程工作繁忙。

    為了解決這個(gè)問(wèn)題,OpenMP提供了動(dòng)態(tài)分配策略,動(dòng)態(tài)策略將循環(huán)迭代劃分為若干個(gè)迭代塊,每個(gè)塊使用一個(gè)內(nèi)部任務(wù)隊(duì)列采用先來(lái)先服務(wù)的方式進(jìn)行調(diào)度。首先為每個(gè)線(xiàn)程各分配一個(gè)循環(huán)塊,當(dāng)一個(gè)線(xiàn)程完成其分配的塊后,它將請(qǐng)求另一個(gè)循環(huán)塊,系統(tǒng)將從任務(wù)隊(duì)列頭部取出下一個(gè)循環(huán)塊分配給該線(xiàn)程。這個(gè)過(guò)程不斷重復(fù),直至所有的迭代塊都被分配執(zhí)行完成。即讓線(xiàn)程根據(jù)自己的執(zhí)行能力向系統(tǒng)申請(qǐng)循環(huán)塊。動(dòng)態(tài)調(diào)度有利于緩解負(fù)載不均衡性[6]。

    #include"stdafx.h"

    #include

    #include

    void smallwork()

    {}

    void bigwork()

    {unsigned long sum=0;

    for(int i=0;i<100000000;i++)sum+=i;

    }

    int_tmain(intargc, _TCHAR*argv[])

    {clock_t start, stop;

    start=clock();

    #pragma omp parallel for

    for(int i=0;i<100;i++){

    if(i<50)smallwork();

    elsebigwork();

    }

    stop=clock();

    printf ("The first:time=%f seconds ",((double)(stopstart)/1000.0));

    start=clock();

    #pragma omp parallel for schedule(dynamic,25)

    for(int i=0;i<100;i++){

    if(i<50)smallwork();

    elsebigwork();

    }

    stop=clock();

    printf ("The second:time=%f seconds ",((double)(stopstart)/1000.0));

    start=clock();

    #pragma omp parallel for

    for(int i=0;i<100;i++){

    if(i%2)smallwork();

    elsebigwork();

    }

    stop=clock();

    printf ("The third:time=%f seconds ",((double)(stopstart)/1000.0));

    return 0;

    }

    下面是某次運(yùn)行結(jié)果:

    The first:time=14.859000 seconds

    The second:time=8.003000 seconds

    The third:time=7.922000 seconds

    通過(guò)這段代碼可以明顯看出負(fù)載均衡對(duì)程序性能的影響。程序中有smallwork()和bigwork()兩個(gè)函數(shù),分別具有不同的負(fù)載,輕載的函數(shù)實(shí)際上就是一個(gè)空函數(shù),而重載的函數(shù)則用來(lái)求和。

    通過(guò)執(zhí)行結(jié)果可以看到,雖然三個(gè)循環(huán)的工作量是一樣的,但是運(yùn)行時(shí)間不盡相同。幾乎相差了一倍。在第一個(gè)循環(huán)中,由于步長(zhǎng)是1,OpenMP運(yùn)行時(shí)采用靜態(tài)調(diào)度策略將前面50個(gè)循環(huán)分配給一個(gè)線(xiàn)程,將后面50個(gè)循環(huán)分配給另一個(gè)線(xiàn)程。后一個(gè)線(xiàn)程需要運(yùn)行的都是負(fù)擔(dān)沉重的函數(shù),而前一個(gè)線(xiàn)程會(huì)很快執(zhí)行完50個(gè)空函數(shù),金繼續(xù)等待另一線(xiàn)程完成工作。在第二個(gè)循環(huán)中采用那個(gè)動(dòng)態(tài)調(diào)度策略將循環(huán)分為4個(gè)迭代塊,根據(jù)線(xiàn)程的執(zhí)行情況動(dòng)態(tài)分配,保證線(xiàn)程的負(fù)載平衡。在第三個(gè)循環(huán)處采用修改代碼的方法將輕重負(fù)載函數(shù)均衡地分配給兩個(gè)線(xiàn)程,從而保證負(fù)載平衡。

    4 線(xiàn)程同步開(kāi)銷(xiāo)

    多個(gè)線(xiàn)程在進(jìn)行同步的時(shí)候必然帶來(lái)一定的同步開(kāi)銷(xiāo)。當(dāng)然,有的同步開(kāi)銷(xiāo)是不可避免的,但是在某些情況下,不合適的同步機(jī)制或者算法會(huì)帶來(lái)運(yùn)行效率的急劇下降。因此在使用多線(xiàn)程進(jìn)行應(yīng)用程序開(kāi)發(fā)時(shí)一定要考慮同步的必要性,消除不必要的同步,或者調(diào)整同步的順序,帶來(lái)性能上的提升。

    5 結(jié) 論

    為提高程序性能,保證程序的執(zhí)行效率,在編寫(xiě)并行化程序時(shí),應(yīng)盡量使程序真正工作的負(fù)載超過(guò)并行化的負(fù)擔(dān),每個(gè)線(xiàn)程負(fù)擔(dān)的工作要足夠多;應(yīng)注意保證負(fù)載的平衡,盡量讓每個(gè)線(xiàn)程的工作量相當(dāng);程序開(kāi)發(fā)時(shí)一定要考慮同步的必要性,消除不必要的同步。

    [1]眭俊華,劉慧娜,王建鑫,等.多核多線(xiàn)程技術(shù)綜述[J].計(jì)算機(jī)應(yīng)用,2013(6):239-242,261.SUIJun-hua,LIUHui-na,WANGJian-xin,etal.Multicore multi-threading technology were reviewed [J].Journal of Computer Applications,2013(6):239-242,261.

    [2]于芳.多核平臺(tái)下的多線(xiàn)程并行編程[J].陰山學(xué)刊,2010(9):33-36.YU Fang.Multi-threads parallel programming method on multi-core PC[J].YinshanAcademIc Journal,2010(9):33-36.

    [3]何濤,李?lèi)?ài)波,黃淵.基于openMP多線(xiàn)程技術(shù)SAR地面處理軟件的并行設(shè)計(jì) [J].計(jì)算機(jī)工程與應(yīng)用,2011,47(8):267-271 HE Tao,LI Ai-bo,HUANG Yuan.Parallel designof SAR-ground processing software based on OPenMP[J].Englneering and APPlications,2011,47(8):267-271.

    [4]游佐勇.openMP并行編程模型與性能優(yōu)化方法的研究與應(yīng)用[D].成都:成都理工大學(xué),2011.

    [5]唐玲.openMP多線(xiàn)程負(fù)載均衡分析方法及調(diào)度策略研究[D].長(zhǎng)沙:湖南大學(xué),2010.

    [6]任小西,唐玲,李仁發(fā),等.OpenMP多線(xiàn)程負(fù)載均衡調(diào)度策略研究與實(shí)現(xiàn)[J].計(jì)算機(jī)科學(xué),2010(11):148-151.REN Xiao-xi,TANG Ling,LI Ren-fa,et al.Study and implementation of OpenMP multi-thread load balance scheduling schema[J].Computer Science,2010(11):148-151.

    猜你喜歡
    線(xiàn)程內(nèi)存處理器
    “春夏秋冬”的內(nèi)存
    淺談linux多線(xiàn)程協(xié)作
    Imagination的ClearCallTM VoIP應(yīng)用現(xiàn)可支持Cavium的OCTEON? Ⅲ多核處理器
    ADI推出新一代SigmaDSP處理器
    呼嚕處理器
    基于內(nèi)存的地理信息訪(fǎng)問(wèn)技術(shù)
    Linux線(xiàn)程實(shí)現(xiàn)技術(shù)研究
    么移動(dòng)中間件線(xiàn)程池并發(fā)機(jī)制優(yōu)化改進(jìn)
    上網(wǎng)本為什么只有1GB?
    電子設(shè)計(jì)應(yīng)用(2004年7期)2004-09-02 08:44:00
    国产精品一区二区三区四区免费观看 | 欧美一区二区精品小视频在线| 人人妻人人看人人澡| aaaaa片日本免费| 亚洲欧美日韩卡通动漫| 欧美bdsm另类| 亚洲av五月六月丁香网| 国内精品久久久久精免费| 国产69精品久久久久777片| 日本 欧美在线| 听说在线观看完整版免费高清| 神马国产精品三级电影在线观看| 国产乱人伦免费视频| 国产伦精品一区二区三区四那| 很黄的视频免费| 精品一区二区三区视频在线| 亚洲片人在线观看| 天天一区二区日本电影三级| 欧美日韩福利视频一区二区| 好男人电影高清在线观看| 日本黄色视频三级网站网址| 赤兔流量卡办理| 直男gayav资源| 欧美黄色淫秽网站| 简卡轻食公司| 在现免费观看毛片| 国产亚洲av嫩草精品影院| 久久久精品欧美日韩精品| 日韩欧美一区二区三区在线观看| av中文乱码字幕在线| 老司机深夜福利视频在线观看| 日日夜夜操网爽| 91久久精品电影网| 国产免费男女视频| 亚洲在线观看片| 亚洲av不卡在线观看| 亚洲五月婷婷丁香| 观看美女的网站| 久久精品国产自在天天线| 亚洲中文字幕一区二区三区有码在线看| 亚洲中文日韩欧美视频| 国产在视频线在精品| 一本久久中文字幕| 最近中文字幕高清免费大全6 | 麻豆成人午夜福利视频| 色播亚洲综合网| 99久久精品热视频| 国产精品影院久久| 不卡一级毛片| 成人高潮视频无遮挡免费网站| 十八禁国产超污无遮挡网站| 欧美色欧美亚洲另类二区| 国产精品嫩草影院av在线观看 | 永久网站在线| 久久久久久久久中文| 丁香六月欧美| 在线播放国产精品三级| 非洲黑人性xxxx精品又粗又长| 一区二区三区免费毛片| 欧美一区二区亚洲| 精品国产三级普通话版| 国产真实伦视频高清在线观看 | 99久久精品一区二区三区| 蜜桃久久精品国产亚洲av| 一级av片app| 两人在一起打扑克的视频| 久久久国产成人免费| 日日干狠狠操夜夜爽| 亚洲av日韩精品久久久久久密| 精品乱码久久久久久99久播| 91久久精品电影网| 三级国产精品欧美在线观看| 免费av不卡在线播放| 国内精品一区二区在线观看| 麻豆一二三区av精品| 国产精品人妻久久久久久| 男女那种视频在线观看| 成人亚洲精品av一区二区| 婷婷丁香在线五月| 两人在一起打扑克的视频| 少妇人妻精品综合一区二区 | 美女黄网站色视频| 亚洲精品成人久久久久久| 婷婷精品国产亚洲av在线| 日韩欧美 国产精品| 麻豆成人av在线观看| 色5月婷婷丁香| 9191精品国产免费久久| 真人做人爱边吃奶动态| 18+在线观看网站| 国产精品一区二区免费欧美| 国产精品一区二区免费欧美| 真实男女啪啪啪动态图| 欧美另类亚洲清纯唯美| 成年免费大片在线观看| 欧美色欧美亚洲另类二区| 一级黄片播放器| 男人和女人高潮做爰伦理| 男女视频在线观看网站免费| 久久天躁狠狠躁夜夜2o2o| www.色视频.com| 中文字幕av成人在线电影| 天天一区二区日本电影三级| 亚洲av五月六月丁香网| 免费无遮挡裸体视频| 国产毛片a区久久久久| 欧美绝顶高潮抽搐喷水| 欧美绝顶高潮抽搐喷水| 91在线观看av| 免费在线观看日本一区| 精品午夜福利视频在线观看一区| 又爽又黄无遮挡网站| 精品无人区乱码1区二区| 99久久精品国产亚洲精品| 十八禁人妻一区二区| 97热精品久久久久久| 十八禁人妻一区二区| 亚洲黑人精品在线| 偷拍熟女少妇极品色| 日韩av在线大香蕉| 综合色av麻豆| 午夜福利免费观看在线| 国产高清视频在线观看网站| 天堂√8在线中文| АⅤ资源中文在线天堂| 女生性感内裤真人,穿戴方法视频| 亚洲18禁久久av| 亚洲av.av天堂| 午夜a级毛片| 久久精品国产清高在天天线| 国产私拍福利视频在线观看| av欧美777| 午夜a级毛片| 国产不卡一卡二| 草草在线视频免费看| 婷婷六月久久综合丁香| 日韩欧美免费精品| 久久久久国内视频| 国产人妻一区二区三区在| 又爽又黄无遮挡网站| 国产又黄又爽又无遮挡在线| 日韩欧美国产在线观看| 国内精品久久久久精免费| 国产在线男女| 天堂av国产一区二区熟女人妻| 欧美日本视频| 亚洲一区二区三区不卡视频| 国产亚洲精品综合一区在线观看| 国产精品人妻久久久久久| 18+在线观看网站| 内射极品少妇av片p| 99久久九九国产精品国产免费| 两性午夜刺激爽爽歪歪视频在线观看| 国产成+人综合+亚洲专区| 搞女人的毛片| 少妇高潮的动态图| 精品福利观看| 99视频精品全部免费 在线| 亚洲一区二区三区色噜噜| 国产极品精品免费视频能看的| 人妻夜夜爽99麻豆av| 我的老师免费观看完整版| 欧美+亚洲+日韩+国产| 99国产极品粉嫩在线观看| 深夜a级毛片| 一区福利在线观看| 久久久成人免费电影| 国产精品久久久久久精品电影| 男女做爰动态图高潮gif福利片| 男女下面进入的视频免费午夜| 国产一区二区在线观看日韩| 草草在线视频免费看| 国产精品一及| 欧美日韩中文字幕国产精品一区二区三区| 欧美色视频一区免费| 欧美极品一区二区三区四区| 91九色精品人成在线观看| 三级国产精品欧美在线观看| av天堂在线播放| 欧美日本亚洲视频在线播放| 国产三级黄色录像| 久久性视频一级片| 十八禁国产超污无遮挡网站| 看黄色毛片网站| 两性午夜刺激爽爽歪歪视频在线观看| 成人国产综合亚洲| 国产精品一区二区性色av| 一进一出抽搐gif免费好疼| 久久欧美精品欧美久久欧美| 亚洲成人精品中文字幕电影| 欧美bdsm另类| 黄片小视频在线播放| 一个人观看的视频www高清免费观看| aaaaa片日本免费| 久久99热6这里只有精品| 中文字幕免费在线视频6| 级片在线观看| 欧美最黄视频在线播放免费| 欧美+日韩+精品| 变态另类成人亚洲欧美熟女| 中文亚洲av片在线观看爽| 国产午夜福利久久久久久| 日韩精品青青久久久久久| 久久99热这里只有精品18| 最近中文字幕高清免费大全6 | 成人精品一区二区免费| 国产精品99久久久久久久久| av福利片在线观看| ponron亚洲| 亚洲美女黄片视频| 精品一区二区免费观看| 99热只有精品国产| 亚洲国产欧美人成| 亚洲七黄色美女视频| 欧美成人一区二区免费高清观看| 亚洲欧美日韩高清专用| 非洲黑人性xxxx精品又粗又长| 99久国产av精品| 国产精品一区二区免费欧美| 国产精品人妻久久久久久| 三级男女做爰猛烈吃奶摸视频| 亚洲中文字幕一区二区三区有码在线看| 天堂影院成人在线观看| 精品久久久久久久久久久久久| 高潮久久久久久久久久久不卡| av在线老鸭窝| 在线观看舔阴道视频| 精品不卡国产一区二区三区| 久久热精品热| av国产免费在线观看| 亚洲av免费在线观看| 18禁裸乳无遮挡免费网站照片| 欧美高清性xxxxhd video| 亚洲中文日韩欧美视频| 日本免费一区二区三区高清不卡| 婷婷六月久久综合丁香| 亚洲国产欧美人成| 日韩欧美精品免费久久 | 成人高潮视频无遮挡免费网站| 91久久精品电影网| www.色视频.com| 性色av乱码一区二区三区2| 午夜精品久久久久久毛片777| 亚洲不卡免费看| 成人美女网站在线观看视频| 国产精品一区二区三区四区免费观看 | 国产精品乱码一区二三区的特点| 亚洲国产高清在线一区二区三| 无遮挡黄片免费观看| 亚洲国产欧洲综合997久久,| 99国产综合亚洲精品| 欧美乱妇无乱码| 亚洲精品乱码久久久v下载方式| 99热精品在线国产| av福利片在线观看| 嫩草影视91久久| 哪里可以看免费的av片| 99国产精品一区二区蜜桃av| 很黄的视频免费| 精品久久久久久久久久免费视频| 国产黄片美女视频| 日韩精品青青久久久久久| 国产精品一区二区三区四区久久| 亚洲av熟女| 久99久视频精品免费| 一本精品99久久精品77| 成人国产综合亚洲| 久久人人精品亚洲av| 天堂√8在线中文| 日韩欧美精品免费久久 | 在线观看免费视频日本深夜| 免费看a级黄色片| 亚洲精品色激情综合| 亚洲av第一区精品v没综合| 国产成人av教育| 亚洲av成人精品一区久久| 欧美精品啪啪一区二区三区| 无遮挡黄片免费观看| 国产精品自产拍在线观看55亚洲| 国模一区二区三区四区视频| 国产精品久久久久久久久免 | 在线十欧美十亚洲十日本专区| 国产爱豆传媒在线观看| 亚洲熟妇中文字幕五十中出| 91久久精品国产一区二区成人| 欧美色欧美亚洲另类二区| 免费在线观看日本一区| av天堂中文字幕网| av中文乱码字幕在线| 亚洲av成人av| 午夜福利在线观看吧| 一级av片app| 啦啦啦韩国在线观看视频| 精品不卡国产一区二区三区| 亚洲乱码一区二区免费版| 日韩欧美免费精品| 在线看三级毛片| 免费人成在线观看视频色| 一个人看的www免费观看视频| 97人妻精品一区二区三区麻豆| 亚洲自偷自拍三级| 男女之事视频高清在线观看| 少妇人妻精品综合一区二区 | 午夜老司机福利剧场| 麻豆av噜噜一区二区三区| 午夜日韩欧美国产| 成年女人看的毛片在线观看| 久久精品影院6| 国产真实乱freesex| 日日夜夜操网爽| 国产高潮美女av| 天美传媒精品一区二区| 成年女人毛片免费观看观看9| 激情在线观看视频在线高清| 国产精品av视频在线免费观看| 性色avwww在线观看| 别揉我奶头 嗯啊视频| 亚洲欧美日韩东京热| 国产精品久久久久久亚洲av鲁大| 色综合站精品国产| 男人和女人高潮做爰伦理| 亚洲男人的天堂狠狠| 搡老熟女国产l中国老女人| 久久热精品热| 亚洲av成人av| 性色avwww在线观看| 老司机福利观看| 欧美日本视频| 国内少妇人妻偷人精品xxx网站| 亚洲国产欧洲综合997久久,| 男女视频在线观看网站免费| 色综合欧美亚洲国产小说| 欧美日韩国产亚洲二区| 村上凉子中文字幕在线| 亚洲无线在线观看| 国产真实乱freesex| 黄色丝袜av网址大全| 黄色配什么色好看| 亚洲真实伦在线观看| 亚洲熟妇中文字幕五十中出| 国产成人影院久久av| 蜜桃久久精品国产亚洲av| 91狼人影院| 2021天堂中文幕一二区在线观| 国产一区二区在线av高清观看| 给我免费播放毛片高清在线观看| 天堂影院成人在线观看| 免费av不卡在线播放| 五月伊人婷婷丁香| 超碰av人人做人人爽久久| 国产中年淑女户外野战色| 精品久久久久久久人妻蜜臀av| 三级国产精品欧美在线观看| 国产成年人精品一区二区| 国产亚洲av嫩草精品影院| 观看免费一级毛片| 亚洲成人免费电影在线观看| 国产欧美日韩一区二区三| 亚洲精品久久国产高清桃花| 国产久久久一区二区三区| 看十八女毛片水多多多| 国产不卡一卡二| 69av精品久久久久久| 极品教师在线视频| 久久精品国产亚洲av涩爱 | 亚洲中文字幕一区二区三区有码在线看| 久久99热这里只有精品18| 欧美zozozo另类| 国产伦人伦偷精品视频| 国产黄色小视频在线观看| 亚洲国产高清在线一区二区三| 亚洲欧美精品综合久久99| 亚洲精品456在线播放app | 91久久精品电影网| www日本黄色视频网| 我要看日韩黄色一级片| 欧美色视频一区免费| 亚洲不卡免费看| av天堂中文字幕网| 少妇人妻一区二区三区视频| 变态另类丝袜制服| 1024手机看黄色片| 91久久精品国产一区二区成人| 久久午夜亚洲精品久久| 黄色丝袜av网址大全| 波野结衣二区三区在线| 国产伦精品一区二区三区视频9| 欧美黑人巨大hd| 如何舔出高潮| 国内精品一区二区在线观看| 波多野结衣高清作品| 欧美成狂野欧美在线观看| 久久国产精品人妻蜜桃| 国产精品久久久久久久电影| 国产91精品成人一区二区三区| 欧美成人a在线观看| 欧美国产日韩亚洲一区| 亚洲最大成人中文| 在线观看一区二区三区| 夜夜爽天天搞| av黄色大香蕉| 久久国产乱子免费精品| 可以在线观看的亚洲视频| 夜夜看夜夜爽夜夜摸| 十八禁网站免费在线| 亚洲久久久久久中文字幕| 国产男靠女视频免费网站| 日韩有码中文字幕| 国产精品一区二区三区四区免费观看 | 免费搜索国产男女视频| 日日摸夜夜添夜夜添av毛片 | 90打野战视频偷拍视频| 亚洲av电影不卡..在线观看| 1000部很黄的大片| 在线观看午夜福利视频| 人人妻人人看人人澡| 亚洲精品一区av在线观看| 国产精品嫩草影院av在线观看 | 亚洲在线观看片| 国产一区二区在线观看日韩| 国产麻豆成人av免费视频| 一区二区三区激情视频| 色播亚洲综合网| 99精品在免费线老司机午夜| 色噜噜av男人的天堂激情| 热99re8久久精品国产| 99视频精品全部免费 在线| 听说在线观看完整版免费高清| 老司机福利观看| 日韩中文字幕欧美一区二区| 国产成年人精品一区二区| 国产欧美日韩一区二区精品| 99久久99久久久精品蜜桃| 久久亚洲真实| 两人在一起打扑克的视频| a级一级毛片免费在线观看| 国产爱豆传媒在线观看| 亚洲av日韩精品久久久久久密| 精品一区二区三区视频在线| 99精品在免费线老司机午夜| 久久精品91蜜桃| 久久中文看片网| 青草久久国产| 欧美最黄视频在线播放免费| 国内精品美女久久久久久| 97超视频在线观看视频| 老司机午夜十八禁免费视频| 好看av亚洲va欧美ⅴa在| 五月伊人婷婷丁香| 男女之事视频高清在线观看| x7x7x7水蜜桃| 免费av观看视频| 亚洲真实伦在线观看| 俄罗斯特黄特色一大片| 国产精品亚洲av一区麻豆| 麻豆一二三区av精品| 免费看a级黄色片| 久久午夜亚洲精品久久| 日韩欧美一区二区三区在线观看| 久久天躁狠狠躁夜夜2o2o| 夜夜躁狠狠躁天天躁| 人妻夜夜爽99麻豆av| 少妇的逼好多水| 简卡轻食公司| 少妇熟女aⅴ在线视频| 男女做爰动态图高潮gif福利片| 高清毛片免费观看视频网站| 欧美最黄视频在线播放免费| 国产av在哪里看| 91久久精品国产一区二区成人| av在线老鸭窝| 神马国产精品三级电影在线观看| 欧美性感艳星| 精品一区二区三区av网在线观看| 亚洲国产精品sss在线观看| 国产欧美日韩一区二区精品| 久久久久久久久久成人| 免费电影在线观看免费观看| 国产成人aa在线观看| 欧美不卡视频在线免费观看| 十八禁网站免费在线| 免费看日本二区| 九九在线视频观看精品| 日韩av在线大香蕉| 久久国产精品人妻蜜桃| ponron亚洲| 亚洲aⅴ乱码一区二区在线播放| av专区在线播放| 欧美xxxx黑人xx丫x性爽| 中文在线观看免费www的网站| 中文字幕人成人乱码亚洲影| 美女高潮的动态| 亚洲av成人不卡在线观看播放网| 俺也久久电影网| 看片在线看免费视频| 男女做爰动态图高潮gif福利片| 99久久精品国产亚洲精品| 成年版毛片免费区| 成人特级av手机在线观看| 国产久久久一区二区三区| 全区人妻精品视频| 日本a在线网址| 99热精品在线国产| 深夜a级毛片| 欧美成狂野欧美在线观看| 欧美绝顶高潮抽搐喷水| 长腿黑丝高跟| 欧美一级a爱片免费观看看| 欧美bdsm另类| 51国产日韩欧美| 三级男女做爰猛烈吃奶摸视频| 露出奶头的视频| 日韩欧美国产在线观看| 亚洲片人在线观看| 国产精品伦人一区二区| 亚洲专区中文字幕在线| 亚洲国产精品成人综合色| 国内精品久久久久精免费| 成人三级黄色视频| 久久性视频一级片| 久久久久久久久久成人| 香蕉av资源在线| 午夜激情福利司机影院| 激情在线观看视频在线高清| 亚洲综合色惰| 少妇人妻精品综合一区二区 | 国产私拍福利视频在线观看| 色视频www国产| 波多野结衣高清无吗| 亚洲国产色片| 免费av不卡在线播放| 国产精品日韩av在线免费观看| 在线播放国产精品三级| 村上凉子中文字幕在线| 麻豆国产av国片精品| 国产精品1区2区在线观看.| 欧美一区二区亚洲| 国产探花在线观看一区二区| eeuss影院久久| 一级av片app| 国产精品久久久久久亚洲av鲁大| 狂野欧美白嫩少妇大欣赏| 国产一区二区三区视频了| 久久九九热精品免费| 精品不卡国产一区二区三区| 99riav亚洲国产免费| 老熟妇乱子伦视频在线观看| 女人十人毛片免费观看3o分钟| 搞女人的毛片| a级毛片免费高清观看在线播放| 99久久99久久久精品蜜桃| 深爱激情五月婷婷| 免费看光身美女| 欧美性感艳星| 亚洲最大成人中文| 午夜亚洲福利在线播放| 国产欧美日韩精品一区二区| 欧美在线黄色| 成人亚洲精品av一区二区| 3wmmmm亚洲av在线观看| 欧美日韩亚洲国产一区二区在线观看| 精品久久久久久,| 99精品久久久久人妻精品| 亚洲一区二区三区色噜噜| 最后的刺客免费高清国语| 全区人妻精品视频| 久久久色成人| 国内精品美女久久久久久| 日韩有码中文字幕| 久久久久亚洲av毛片大全| 日韩 亚洲 欧美在线| 亚洲av成人不卡在线观看播放网| 欧美色欧美亚洲另类二区| 国产高清视频在线播放一区| 久久久久国内视频| 99久久九九国产精品国产免费| 国产精品三级大全| 精品99又大又爽又粗少妇毛片 | 欧美日韩国产亚洲二区| 亚洲熟妇中文字幕五十中出| 国产精品永久免费网站| 国产真实伦视频高清在线观看 | 久久天躁狠狠躁夜夜2o2o| 日韩精品中文字幕看吧| 男女之事视频高清在线观看| 亚洲国产日韩欧美精品在线观看| 十八禁网站免费在线| 久久久久精品国产欧美久久久| 91av网一区二区| 久久99热6这里只有精品| 久久欧美精品欧美久久欧美| 国产淫片久久久久久久久 | 国内精品美女久久久久久| 十八禁人妻一区二区| 在线a可以看的网站| 男女之事视频高清在线观看| 国产精品99久久久久久久久| 久久久久久大精品| 国产激情偷乱视频一区二区| 床上黄色一级片| 国产伦精品一区二区三区四那| 深夜精品福利| 国产 一区 欧美 日韩| 婷婷六月久久综合丁香| 成人亚洲精品av一区二区| 18禁黄网站禁片免费观看直播| 美女 人体艺术 gogo| 欧美一区二区精品小视频在线| 久久久色成人| 精品一区二区三区人妻视频| 国产精华一区二区三区| 成人特级黄色片久久久久久久| a在线观看视频网站| 小说图片视频综合网站| 十八禁人妻一区二区|