日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

利用 PGO 提升 .NET 程序性能

發布時間:2023/12/4 asp.net 59 豆豆
生活随笔 收集整理的這篇文章主要介紹了 利用 PGO 提升 .NET 程序性能 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

引子

.NET 6 開始初步引入 PGO。PGO 即 Profile Guided Optimization,通過收集運行時信息來指導 JIT 如何優化代碼,相比以前沒有 PGO 時可以做更多以前難以完成的優化。

下面我們用 .NET 6 的 nightly build 版本?6.0.100-rc.1.21377.6?來試試新的 PGO。

PGO 工具

.NET 6 提供了靜態 PGO 和動態 PGO。前者通過工具收集 profile 數據,然后應用到下一次編譯當中指導編譯器如何進行代碼優化;后者則直接在運行時一邊收集 profile 數據一邊進行優化。

另外由于從 .NET 5 開始引入了 OSR(On Stack Replacement),因此可以在運行時替換正在運行的函數,允許將正在運行的低優化代碼遷移到高優化代碼,例如替換一個熱循環中的代碼。

分層編譯和 PGO

.NET 從 Core 3.1 開始正式引入了分層編譯(Tiered Compilation),程序啟動時 JIT 首先快速生成低優化的 tier 0 代碼,由于優化代價小,因此 JIT 吞吐量很高,可以改善整體的延時。

然后隨著程序運行,對多次調用的方法進行再次 JIT 產生高優化的 tier 1 代碼,以提升程序的執行效率。

但是這么做對于程序的性能幾乎沒有提升,只是改善了延時,降低首次 JIT 的時間,卻反而可能由于低優化代碼導致性能倒退。因此我個人通常在開發客戶端類程序的時候會關閉分層編譯,而在開發服務器程序時開啟分層編譯。

然而 .NET 6 引入 PGO 后,分層編譯的機制將變得非常重要。

由于 tier 0 的代碼是低優化代碼,因此更能夠收集到完整的運行時 profile 數據,指導 JIT 做更全面的優化。

為什么這么說?

例如在 tier 1 代碼中,某方法 B 被某方法 A 內聯(inline),運行期間多次調用方法 A 后收集到了 profile 將只包含 A 的信息,而沒有 B 的信息;又例如在 tier 1 代碼中,某循環被 JIT 做了 loop cloning,那此時收集到的 profile 則是不準確的。

因此為了發揮 PGO 的最大效果,我們不僅需要開啟分層編譯,還需要給循環啟用 Quick Jit 在一開始生成低優化代碼。

進行優化

前面說了這么多,那 .NET 6 的 PGO 到底應該如何使用,又會如何對代碼優化產生影響呢?這里舉個例子。

測試代碼

新建一個 .NET 6 控制臺項目?PgoExperiment,考慮有如下代碼:

interface IGenerator {bool ReachEnd { get; }int Current { get; }bool MoveNext(); }abstract class IGeneratorFactory {public abstract IGenerator CreateGenerator(); }class MyGenerator : IGenerator {private int _current;public bool ReachEnd { get; private set; }public int Current { get; private set; }public bool MoveNext(){if (ReachEnd) {return false;}_current++;if (_current > 1000){ReachEnd = true;return false;}Current = _current;return true;} }class MyGeneratorFactory : IGeneratorFactory {public override IGenerator CreateGenerator() {return new MyGenerator();} }

我們利用?IGeneratorFactory?產生?IGenerator,同時分別提供對應的一個實現?MyGeneratorFactory?和?MyGenerator。注意實現類并沒有標注?sealed?因此 JIT 并不知道是否能做去虛擬化(devirtualization),于是生成的代碼會老老實實查虛表。

然后我們編寫測試代碼:

[MethodImpl(MethodImplOptions.NoInlining)] int Test(IGeneratorFactory factory) {var generator = factory.CreateGenerator();var result = 0;while (generator.MoveNext()){result += generator.Current;}return result; }var sw = Stopwatch.StartNew(); var factory = new MyGeneratorFactory();for (var i = 0; i < 10; i++) {sw.Restart();for (int j = 0; j < 1000000; j++){Test(factory);}sw.Stop();Console.WriteLine($"Iteration {i}: {sw.ElapsedMilliseconds} ms."); }

你可能會問為什么不用 BenchmarkDotNet,因為這里要測試出 分層編譯和 PGO 前后的區別,因此不能進行所謂的“預熱”。

進行測試

測試環境:

  • CPU:2vCPU Intel(R) Xeon(R) Platinum 8171M CPU @ 2.60GHz

  • 內存:4G

  • 系統:Ubuntu 20.04.2 LTS

  • 程序運行配置:Release

不使用 PGO

首先采用默認參數運行:

dotnet run -c Release

得到結果:

Iteration 0: 740 ms. Iteration 1: 648 ms. Iteration 2: 687 ms. Iteration 3: 639 ms. Iteration 4: 643 ms. Iteration 5: 641 ms. Iteration 6: 641 ms. Iteration 7: 639 ms. Iteration 8: 644 ms. Iteration 9: 643 ms.

Mean = 656.5ms

你會發現 Iteration 0 用時比其他都要長一點,這符合預期,因為一開始執行的是 tier 0 的低優化代碼,然后隨著調用次數增加,JIT 重新生成 tier 1 的高優化代碼。

然后我們關閉分層編譯看看會怎么樣:

dotnet run -c Release /p:TieredCompilation=false

得到結果:

Iteration 0: 677 ms. Iteration 1: 669 ms. Iteration 2: 677 ms. Iteration 3: 680 ms. Iteration 4: 683 ms. Iteration 5: 689 ms. Iteration 6: 677 ms. Iteration 7: 685 ms. Iteration 8: 676 ms. Iteration 9: 673 ms.

Mean = 678.6ms

這下就沒有區別了,因為一開始生成的就是 tier 1 的高優化代碼。

我們看看 JIT dump:

push rbppush r14push rbxlea rbp,[rsp+10h] ; factory.CreateGenerator()mov rax,[rdi]mov rax,[rax+40h]call qword ptr [rax+20h]mov rbx,rax ; var result = 0xor r14d,r14d ; if (generator.MoveNext())mov rdi,rbxmov r11,7F3357AE0008hmov rax,7F3357AE0008hcall qword ptr [rax]test eax,eaxje short LBL_1LBL_0: ; result += generator.Current;mov rdi,rbxmov r11,7F3357AE0010hmov rax,7F3357AE0010hcall qword ptr [rax]add r14d,eax ; if (generator.MoveNext())mov rdi,rbxmov r11,7F3357AE0008hmov rax,7F3357AE0008hcall qword ptr [rax]test eax,eaxjne short LBL_0LBL_1: ; return result;mov eax,r14dpop rbxpop r14pop rbpret

我用注釋標注出了生成的代碼中關鍵地方對應的 C# 寫法,還原成 C# 代碼大概是這個樣子:

var generator = factory.CreateGenerator(); var result = 0;do {if (generator.MoveNext()){result += generator.Current;}else{return result;} } while(true);

這里有不少有趣的地方:

  • while?循環被優化成了?do-while?循環,做了一次 loop inversion,以此來節省一次循環

  • generator.CreateGenerator、generator.MoveNext?以及?generator.Current?完全沒有去虛擬化

  • 因為沒有去虛擬化因此也無法做內聯優化

這已經是 tier 1 代碼了,也就是目前階段 RyuJIT(.NET 6 的 JIT 編譯器)在不借助任何指示編譯器的?Attribute?以及 PGO 所能生成的最大優化等級的代碼。

使用 PGO

這一次我們先看看啟用動態 PGO 能得到怎樣的結果。

為了使用動態 PGO,現階段需要設置一些環境變量。

export DOTNET_ReadyToRun=0 # 禁用 AOT export DOTNET_TieredPGO=1 # 開啟分層 PGO export DOTNET_TC_QuickJitForLoops=1 # 為循環啟用 Quick Jit

然后運行即可:

dotnet run -c Release

得到如下結果:

Iteration 0: 349 ms. Iteration 1: 190 ms. Iteration 2: 188 ms. Iteration 3: 189 ms. Iteration 4: 190 ms. Iteration 5: 190 ms. Iteration 6: 189 ms. Iteration 7: 188 ms. Iteration 8: 191 ms. Iteration 9: 189 ms.

Mean = 205.3ms

得到了驚人的性能提升,只用了先前的 31% 的時間,相當于性能提升 322%。

然后我們試試靜態 PGO + AOT 編譯,AOT 負責在編譯時預先生成優化后的代碼。

為了使用靜態 PGO,我們需要安裝?dotnet-pgo?工具生成靜態 PGO 數據,由于正式版尚未發布,因此需要添加如下 nuget 源:

<configuration><packageSources><add key="dotnet-public" value="https://pkgs.dev.azure.com/dnceng/public/_packaging/dotnet-public/nuget/v3/index.json" /><add key="dotnet-tools" value="https://pkgs.dev.azure.com/dnceng/public/_packaging/dotnet-tools/nuget/v3/index.json" /><add key="dotnet-eng" value="https://pkgs.dev.azure.com/dnceng/public/_packaging/dotnet-eng/nuget/v3/index.json" /><add key="dotnet6" value="https://pkgs.dev.azure.com/dnceng/public/_packaging/dotnet6/nuget/v3/index.json" /><add key="dotnet6-transport" value="https://pkgs.dev.azure.com/dnceng/public/_packaging/dotnet6-transport/nuget/v3/index.json" /></packageSources> </configuration>

安裝?dotnet-pgo?工具:

dotnet tool install dotnet-pgo --version 6.0.0-* -g

先運行程序采集 profile:

export DOTNET_EnableEventPipe=1 export DOTNET_EventPipeConfig=Microsoft-Windows-DotNETRuntime:0x1F000080018:5 export DOTNET_EventPipeOutputPath=trace.nettrace # 追蹤文件輸出路徑 export DOTNET_ReadyToRun=0 # 禁用 AOT export DOTNET_TieredPGO=1 # 啟用分層 PGO export DOTNET_TC_CallCounting=0 # 永遠不產生 tier 1 代碼 export DOTNET_TC_QuickJitForLoops=1 export DOTNET_JitCollect64BitCounts=1dotnet run -c Release

等待程序運行完成,我們會得到一個?trace.nettrace?文件,里面包含了追蹤數據,然后利用?dotnet-pgo?工具產生 PGO 數據。

dotnet-pgo create-mibc -t trace.nettrace -o pgo.mibc

至此我們就得到了一個?pgo.mibc,里面包含了 PGO 數據。

然后我們使用?crossgen2,在 PGO 數據的指導下對代碼進行 AOT 編譯:

dotnet publish -c Release -r linux-x64 /p:PublishReadyToRun=true /p:PublishReadyToRunComposite=true /p:PublishReadyToRunCrossgen2ExtraArgs=--embed-pgo-data%3b--mibc%3apgo.mibc

你可能會覺得這一系列步驟里面不少參數和環境變量都非常詭異,自然也是因為目前正式版還沒有發布,因此名稱和參數什么的都還沒有規范化。

編譯后我們運行編譯后代碼:

cd bin/Release/net6.0/linux-x64/publish ./PgoExperiment

得到如下結果:

Iteration 0: 278 ms. Iteration 1: 185 ms. Iteration 2: 186 ms. Iteration 3: 187 ms. Iteration 4: 184 ms. Iteration 5: 187 ms. Iteration 6: 185 ms. Iteration 7: 183 ms. Iteration 8: 180 ms. Iteration 9: 186 ms.

Mean = 194.1ms

相比動態 PGO 而言,可以看出第一次用時更小,因為不需要經過 profile 收集后重新 JIT 的過程。

我們看看 PGO 數據指導下產生了怎樣的代碼:

push rbppush r15push r14push r12push rbxlea rbp,[rsp+20h] ; if (factory.GetType() == typeof(MyGeneratorFactory))mov rax,offset methodtable(MyGeneratorFactory)cmp [rdi],raxjne near ptr LBL_11 ; IGenerator generator = new MyGenerator()mov rdi,offset methodtable(MyGenerator)call CORINFO_HELP_NEWSFASTmov rbx,raxLBL_0: ; var result = 0xor r14d,r14djmp short LBL_4LBL_1: ; if (generator.GetType() == typeof(MyGenerator))mov rdi,offset methodtable(MyGenerator)cmp r15,rdijne short LBL_6 ; result += generator.Current LBL_2:mov r12d,[rbx+0Ch]LBL_3:add r14d,r12dLBL_4: ; if (generator.GetType() == typeof(MyGenerator))mov r15,[rbx]mov rax,offset methodtable(MyGenerator)cmp r15,raxjne short LBL_8 ; if (generator.ReachEnd)mov rax,rbxcmp byte ptr [rax+10h],0jne short LBL_7 ; generator._current++mov eax,[rbx+8]inc eaxmov [rbx+8],eax ; if (generator._current > 1000)cmp eax,3E8hjg short LBL_5mov [rbx+0Ch],eaxjmp short LBL_2LBL_5: ; ReachEnd = truemov byte ptr [rbx+10h],1jmp short LBL_10LBL_6: ; result += generator.Currentmov rdi,rbxmov r11,7F5C42A70010hmov rax,7F5C42A70010hcall qword ptr [rax]mov r12d,eaxjmp short LBL_3LBL_7:xor r12d,r12djmp short LBL_9LBL_8: ; if (generator.MoveNext())mov rdi,rbxmov r11,7F5C42A70008hmov rax,7F5C42A70008hcall qword ptr [rax]mov r12d,eaxLBL_9:test r12d,r12djne near ptr LBL_1LBL_10: ; return true/falsemov eax,r14dpop rbxpop r12pop r14pop r15pop rbpretLBL_11: ; factory.CreateGenerator()mov rax,[rdi]mov rax,[rax+40h]call qword ptr [rax+20h]mov rbx,raxjmp near ptr LBL_0

同樣,我用注釋標注出來了關鍵地方對應的 C# 代碼,這里由于稍微有些麻煩因此就不在這里還原回大概的 C# 邏輯了。

同樣,我們發現了不少有趣的地方:

  • 通過類型測試判斷?factory?是否是?MyGeneratorFactory、generator?是否是?MyGenerator

    • 如果是,則跳轉到一個代碼塊,這里面將?IGeneratorFactory.CreateFactory、IGenerator.MoveNext?以及?IGenerator.Current?全部去虛擬化,這也叫做 guarded devirtualization,并且全部進行了內聯

    • 否則跳轉到一個代碼塊,這里面的代碼等同于不開啟 PGO 的 tier 1 代碼

    • 這里做了一次 loop cloning

  • while?循環同樣被優化成了?do-while,做了一次 loop inversion

相比不開啟 PGO 而言,顯然優化幅度就大了很多。

用一張圖來對比首次運行、總體用時(毫秒)和比例(均為越低越好),從上至下分別是默認、關閉分層編譯、動態 PGO、靜態 PGO:

總結

有了 PGO 之后,之前的很多性能經驗就不再有效。最典型的例如在用?List<T>?或者?Array?的時候?IEnumerable<T>.Where(pred).FirstOrDefault()?比?IEnumerable<T>.FirstOrDefault(pred)?快,這是因為?IEnumerable<T>.Where?在代碼層面手動做了針對性的去虛擬化,而?FirstOrDefault<T>?沒有。但是在 PGO 的輔助下,即使不需要手動編寫針對性去虛擬化的代碼也能成功去虛擬化,而且不僅僅局限于?List<T>?和?Array,對所有實現?IEnumerable<T>?的類型都適用。

借助 PGO 我們可以預見大幅度的執行效率提升。例如在 TE-benchmark 非官方測試的 plaintext mvc 中,對比第一次請求時間(毫秒,從運行程序開始計算,越低越好)、RPS(越高越好)和比例(越高越好)結果如下:

另外,PGO 在 .NET 6 中尚處于初步階段,后續版本(.NET 7+)中將會帶來更多基于 PGO 的優化。

至于其他的 JIT 優化方面,.NET 6 同樣做了大量的改進,例如更多的 morphing pass、jump threading、loop inversion、loop alignment、loop cloning 等等,并且優化了 LSRA 和 register heuristic,以及解決了不少導致 struct 出現 stack spilling 的情況,以使其一直保持在寄存器中。但是盡管如此,RyuJIT 在優化方面仍有很長的路要走,例如 loop unrolling、forward subsitituion 以及包含關系條件的 jump threading 之類的優化 .NET 6 目前并不具備,這些優化將會在 .NET 7 或者之后到來。

總結

以上是生活随笔為你收集整理的利用 PGO 提升 .NET 程序性能的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

久久精品久久99精品久久 | 国产精品久久久久久久久久久杏吧 | 国产在线一区二区 | 亚洲 成人 欧美 | 在线观看深夜视频 | 国产成人精品免费在线观看 | 少妇做爰k8经典 | 国产色婷婷精品综合在线手机播放 | 国产成人精品午夜在线播放 | 色狠狠综合 | 国产va精品免费观看 | 婷婷久久一区 | 夜夜看av| 亚洲精选视频免费看 | 久久黄色免费视频 | 国产成人综 | 亚洲五月婷婷 | 999热视频| 日韩久久一区 | 四虎成人精品 | 亚洲一区 av | 在线观看一区 | 国产成人黄色在线 | 日日噜噜噜噜夜夜爽亚洲精品 | 黄在线免费观看 | 欧美久久99 | 91插插视频| 91精品国产91 | 97视频在线观看播放 | 中文字幕国语官网在线视频 | 在线观看黄色免费视频 | 九九视频这里只有精品 | 亚洲三级影院 | 91免费观看视频网站 | 久久久污 | 丁香六月激情婷婷 | 中文字幕一区二区三区乱码在线 | 久久久www成人免费毛片 | 奇米影视8888在线观看大全免费 | 国产精品系列在线 | 美女网色| 男女靠逼app | 91九色porny蝌蚪主页 | 亚洲精品国产拍在线 | av青草 | 成人在线免费视频 | 久久av黄色 | 中国一级片在线 | 曰韩在线 | 天堂av在线网址 | 中文字幕在线观看网 | 欧美怡红院视频 | 91麻豆精品国产91久久久久 | 中文字幕免 | 91av在线看| 在线 国产 日韩 | 国产亚洲精品精品精品 | 国产美女视频免费观看的网站 | 亚洲精品视频在线观看视频 | 97视频亚洲 | 91正在播放| 天天操天天干天天玩 | 成年人免费电影在线观看 | 在线成人一区二区 | 玖操| 在线播放av网址 | 国产精品免费观看国产网曝瓜 | 国产精品尤物视频 | www成人av| 国产69精品久久99不卡的观看体验 | 成人在线一区二区 | 亚洲欧美视频在线观看 | 日本一区二区不卡高清 | 丰满少妇久久久 | 精品国产成人av | 国产不卡精品视频 | 国产区精品 | 久久精品91视频 | 97国产情侣爱久久免费观看 | 中文字幕在线观看视频一区 | 99精品在线观看 | 99精品国产aⅴ | 国产美女精品人人做人人爽 | 91在线播放国产 | 精品婷婷| 色婷婷午夜| 久草久草在线 | 国产在线欧美在线 | 国产精品久久久久久999 | 少妇bbw搡bbbb搡bbb| 欧美成人影音 | 97视频成人 | 美女国产在线 | 午夜视频色 | 国产亚洲精品中文字幕 | 国产精品欧美久久 | 2022中文字幕在线观看 | 91自拍视频在线 | 国产免码va在线观看免费 | 欧美粗又大 | 国产区久久 | 中文字幕国产精品 | 91丨九色丨蝌蚪丨老版 | 四虎成人精品永久免费av | 一本一本久久a久久精品综合 | av免费电影在线 | 久久一区二区免费视频 | 午夜精品一区二区国产 | 亚洲男男gaygay无套同网址 | av看片在线观看 | 久久6精品 | 在线观看国产 | 欧美精品v国产精品 | 婷婷在线综合 | 天天爽夜夜爽人人爽一区二区 | 久久xx视频| 精品999在线观看 | 视频一区二区国产 | 久久精品国产免费看久久精品 | 四虎成人精品永久免费av | 免费av网址在线观看 | 欧美亚洲xxx | 国产亚洲在| 久久久久久久久久免费 | 国产精品18久久久久久首页狼 | 日日干av| 99草视频| 九月婷婷综合网 | 美女视频免费一区二区 | 精品国产综合区久久久久久 | 国产精品久久久毛片 | 999久久国产精品免费观看网站 | 国产精品黄色av | 国产黄色在线网站 | 少妇bbb搡bbbb搡bbbb | 日韩久久一区 | 亚洲美女免费视频 | 亚洲日韩欧美一区二区在线 | 亚洲一区精品二人人爽久久 | 亚洲精品免费播放 | 国内精品久久久久影院一蜜桃 | av成人黄色 | 揉bbb玩bbb少妇bbb | 欧美日韩在线观看视频 | 久草视频资源 | 国产在线观| 人人爽久久涩噜噜噜网站 | 韩国av不卡 | 久久久久久久久影视 | 亚洲精品观看 | 久久精品牌麻豆国产大山 | 不卡的av片 | 成人精品99 | 日韩精品中文字幕av | 久久免费视频一区 | 免费观看mv大片高清 | 久久久久久久久久久久影院 | 久久精品国产精品亚洲 | 91精品视频网站 | 国产精品激情在线观看 | 91黄色成人| 免费a v网站 | 免费观看一区二区三区视频 | 日韩精品一区二区三区三炮视频 | 激情五月伊人 | 国产精品原创视频 | 色.com| 色丁香久久 | 99热手机在线观看 | 最近中文字幕在线播放 | 二区三区精品 | 国内精品美女在线观看 | 99国产在线观看 | 亚洲精品在线二区 | 91av亚洲 | 四虎国产精品免费 | 婷婷激情5月天 | 日韩一级电影在线观看 | 精品夜夜嗨av一区二区三区 | 久久久久中文 | 一区二区精品在线 | 亚洲日韩欧美一区二区在线 | 婷婷丁香激情综合 | 午夜电影久久久 | 国产三级午夜理伦三级 | 欧美影片| 亚洲成a人片77777kkkk1在线观看 | 波多野结衣电影久久 | 精品视频国产一区 | 免费久久网 | 一级黄色片在线免费看 | 91麻豆国产福利在线观看 | 久草视频在线免费 | 欧美综合色在线图区 | 亚洲成人家庭影院 | 91在线观看欧美日韩 | 久久伊人精品一区二区三区 | 996久久国产精品线观看 | 色噜噜在线观看 | www.com久久| 国产又粗又猛又色又黄网站 | 国产高清视频在线免费观看 | 夜夜爽88888免费视频4848 | 国产伦理久久精品久久久久_ | 在线视频一二三 | 亚洲精品三级 | www.午夜| 波多野结衣小视频 | 色婷丁香 | 国产淫片免费看 | 91重口视频 | 国产亚洲综合在线 | 五月婷婷狠狠 | 久久福利小视频 | 欧美精品国产综合久久 | 国产精品一区二区久久国产 | 久草在线最新免费 | 91亚洲精品久久久蜜桃借种 | 射射色 | www久久国产| www.com久久久| 在线视频手机国产 | 99热在线免费观看 | 81精品国产乱码久久久久久 | 美女视频黄的免费的 | 高清一区二区三区 | 九九久久久久久久久激情 | 在线观看成人国产 | 精品久久久网 | 天天综合网天天 | 日韩视频免费观看高清 | 久久国内精品视频 | 成人午夜av电影 | 五月色丁香 | 狠狠躁夜夜av | 亚洲精品乱码久久久久久按摩 | 天堂av网在线 | 亚洲日本三级 | 久久精品一二三区白丝高潮 | 国产精品一区专区欧美日韩 | 日韩欧美一区二区在线 | 狠狠色伊人亚洲综合成人 | 99免费在线播放99久久免费 | 97视频免费观看2区 亚洲视屏 | 午夜国产福利在线 | 丝袜美腿一区 | 国产免费亚洲 | 亚洲精品视频国产 | 国产成人黄色片 | 国产电影黄色av | 久久国产精品一国产精品 | 国产在线精品区 | 国偷自产中文字幕亚洲手机在线 | 人人看黄色 | 久久精品毛片基地 | 97日日 | 美女视频黄是免费的 | 亚洲久草在线视频 | 一区三区在线欧 | 国产一区二区不卡视频 | 久久草草热国产精品直播 | 99热精品视| 日韩欧美精品免费 | 黄色软件网站在线观看 | 中文字幕av在线免费 | 在线a视频 | 国产午夜精品视频 | 国产在线播放一区二区三区 | 国产不卡高清 | 国产精品久久久免费 | 丁香六月婷婷开心 | 色中色综合 | 日韩电影在线一区 | 天天干夜夜操视频 | 亚洲综合丁香 | 最新一区二区三区 | 久久国产精品一区二区三区四区 | www.夜夜骑.com | 国产自制av | 91精品国产欧美一区二区成人 | 91香蕉视频黄色 | 四虎国产精品成人免费影视 | 久久好看 | 精品国产一区二区三区久久 | 国产视频欧美视频 | 四虎影视精品永久在线观看 | 免费www视频| 国产在线高清精品 | 日日夜夜网 | av在线播放观看 | 国产xxxx性hd极品 | 国产精品久久久久久妇 | av永久网址 | 在线视频第一页 | 成人一区不卡 | 国产一级视屏 | 国产成人精品一区二区三区福利 | 色狠狠一区二区 | 在线观看免费成人av | 色网站国产精品 | 亚洲黄网站 | 久久久久国产一区二区三区 | 五月综合网站 | 日日夜夜狠狠干 | 日本久久高清视频 | 玖玖在线看 | 久久久激情网 | 久久se视频 | 91在线视频在线观看 | 精品久久久久久久久久久院品网 | 在线观看精品黄av片免费 | 亚洲成人av影片 | 五月婷婷另类国产 | 国产区免费在线 | 久久久精品高清 | 久久久首页 | 成人小视频在线观看免费 | 亚洲欧美成aⅴ人在线观看 四虎在线观看 | 在线99热| 中文字幕在线看 | 日日碰狠狠躁久久躁综合网 | 久久久综合香蕉尹人综合网 | 久久五月天婷婷 | 激情久久五月天 | 国产精品99久久久久久久久 | 欧美日韩激情视频8区 | 欧美色就是色 | 最新中文字幕在线播放 | 在线影视 一区 二区 三区 | 国产精品午夜久久 | 久久久久激情视频 | 久久久精华网 | 午夜手机电影 | 日韩成人在线一区二区 | 日日碰狠狠添天天爽超碰97久久 | 欧美精品在线视频观看 | 久久久国产一区 | 亚洲精品在线观看视频 | 色吧av色av | 中文字幕超清在线免费 | www178ccom视频在线 | 精品视频成人 | 日韩黄色免费在线观看 | 香蕉视频4aa | 久久福利小视频 | 在线激情电影 | 国产破处在线视频 | 欧美9999| 欧美日韩精品在线播放 | 久久人91精品久久久久久不卡 | 中文字幕精品一区久久久久 | 免费黄色网址网站 | 国产免费不卡 | 丁香在线观看完整电影视频 | 91香蕉视频在线 | 正在播放一区二区 | 亚洲精品国产自产拍在线观看 | 午夜久久影视 | 色婷婷99 | 欧美作爱视频 | 久久国产精品电影 | 99热国产在线中文 | 国产精品亚| 麻豆精品在线视频 | 天天操天天添天天吹 | 91九色porn在线资源 | 成人在线观看免费视频 | 亚洲精品小区久久久久久 | 免费99精品国产自在在线 | 亚洲精品国产综合久久 | 久久综合桃花 | 99久久影视| 美女国产精品 | 中文字幕在线观看完整版 | 97色在线观看 | 五月婷婷丁香在线观看 | 欧美成人在线网站 | 国内精品久久久久久久久久久 | 四虎海外影库www4hu | 色综合中文字幕 | 免费看一级片 | 五月天色丁香 | 日韩精品视频免费在线观看 | www免费网站在线观看 | 久久久精品国产一区二区三区 | 日韩av一区二区三区四区 | 久久视精品 | 免费在线观看视频a | 日韩精品无| 色干综合 | 777久久久 | 久久久久国产成人精品亚洲午夜 | 天天摸天天弄 | 9999精品视频 | 亚洲视频电影在线 | 成人精品视频久久久久 | 97在线视频观看 | 日韩精品专区在线影院重磅 | 一区二区三区高清在线 | 亚洲三级影院 | 欧美精品乱码久久久久久按摩 | 国产视频日本 | 国产精品岛国久久久久久久久红粉 | 国产精品福利久久久 | 成人久久久久久久久久 | 日躁夜躁狠狠躁2001 | 五月天开心| 欧美国产日韩一区二区三区 | 婷婷色综合色 | 在线播放日韩av | 欧美三级高清 | 四虎免费在线观看视频 | 五月天六月色 | 天天草网站 | 少妇bbw揉bbb欧美| 在线国产小视频 | 日韩艹 | 精品国产99 | 欧美一二区视频 | 天天操夜夜逼 | 99一区二区三区 | 色午夜影院| 十八岁以下禁止观看的1000个网站 | 日日爱夜夜爱 | 91精品资源 | 中文字幕在线视频网站 | 久久字幕 | 久久久精华网 | 在线观看精品视频 | 丁香在线观看完整电影视频 | 91九色国产在线 | 中文字幕在线视频一区二区三区 | 性色av一区二区三区在线观看 | 中文电影网 | 久久人人爽爽人人爽人人片av | 中文字幕在线观看的网站 | 色视频在线看 | 精品视频中文字幕 | 日韩va亚洲va欧美va久久 | 亚洲女欲精品久久久久久久18 | 日韩婷婷| 综合网久久 | 日韩91在线 | 又黄又爽的视频在线观看网站 | 黄色a视频 | 福利av在线| 国产精品久久久久久久久免费看 | 久久色视频 | 很黄很污的视频网站 | 99久久精品国产网站 | 国产999精品久久久久久 | 国产手机视频在线观看 | 日韩精品三区四区 | 在线观看中文字幕网站 | 五月婷婷在线综合 | av片子在线观看 | 精品伊人久久久 | 日韩欧美在线视频一区二区三区 | 日韩av电影免费观看 | 不卡的一区二区三区 | 国产99久久久国产 | 国产日产精品久久久久快鸭 | 国产精品观看 | 91人人在线 | 免费看短 | 久久久久国产精品免费网站 | 四虎国产 | 偷拍精偷拍精品欧洲亚洲网站 | 91麻豆免费看 | 天天射天天操天天 | 天天干,天天干 | 9999在线 | 久久久在线| 激情综合婷婷 | 黄色毛片视频免费观看中文 | www.狠狠色.com| 四虎5151久久欧美毛片 | 99国产一区二区三精品乱码 | 国产精品第十页 | 最新黄色av网址 | 国内精品久久久久国产 | 久久久五月天 | 亚洲视频专区在线 | 五月婷婷综合激情 | 不卡的av电影在线观看 | 国产96在线 | 亚洲综合色视频在线观看 | 亚洲91av| 久久黄色免费视频 | 在线观看国产永久免费视频 | 99 色| 日韩精品久久久久久中文字幕8 | 婷婷av在线| 免费看国产曰批40分钟 | 国产精品一区二区三区在线免费观看 | 日韩久久久 | 国产一区在线视频 | 久久久亚洲精华液 | 91日本在线播放 | 丁香六月久久综合狠狠色 | 国产专区一 | 精品久久久久久久久中文字幕 | 日韩毛片久久久 | 免费久久久久久久 | 国产一级二级在线 | 国产成人精品久久久 | 992tv在线| 一区二区三区四区在线免费观看 | 亚洲国产美女精品久久久久∴ | 免费激情在线电影 | 欧美性生活免费 | 美女视频黄,久久 | 天天射狠狠干 | 99婷婷 | 黄色成人小视频 | 午夜精品一区二区三区在线 | 欧美激情综合五月色丁香 | 亚洲国产精久久久久久久 | 亚洲黄色片在线 | 久久激情视频 | 伊人精品在线 | 国产精品久久久久久久99 | 中文字幕免费观看 | 免费观看91视频大全 | 久久99精品久久只有精品 | 在线播放视频一区 | 99精品视频在线看 | 亚洲人成精品久久久久 | 亚洲黄色av | 天天操狠狠操 | 亚洲成av人片在线观看 | 国产精品地址 | 日韩三级不卡 | av在线一| 欧美激情在线网站 | 五月天亚洲综合小说网 | 日本精品中文字幕在线观看 | 操操操av | 美女视频久久 | 最近免费中文字幕mv在线视频3 | 久久网址 | 亚洲午夜久久久久久久久 | 亚洲jizzjizz日本少妇 | 国产美女免费视频 | 国产91精品一区二区麻豆网站 | 伊人天天综合 | 日韩精品一区二区三区在线视频 | 久久深夜福利免费观看 | 伊人成人久久 | 欧美综合色在线图区 | 午夜视频欧美 | 啪啪激情网 | 国产视频精品久久 | 国产精品久久久久久久久免费看 | 超碰在线官网 | 色偷偷88888欧美精品久久 | 精品久久一区 | 精品国产欧美一区二区三区不卡 | 91精品视频网站 | 在线播放视频一区 | 国产精品久久久久久久久久妇女 | 91av色 | 美女视频黄的免费的 | 国产精品1区2区在线观看 | 好看av在线 | 欧美一级日韩免费不卡 | 日本h视频在线观看 | 国产毛片久久 | 久久综合九九 | 人人干人人爽 | 97超碰免费 | 草莓视频在线观看免费观看 | 免费一级片久久 | 婷婷中文字幕综合 | 日本女人的性生活视频 | 成人h电影 | 97视频在线免费 | www.久久色 | 免费高清男女打扑克视频 | 99精品视频一区 | 精品久久久久国产免费第一页 | 国产一区免费视频 | 免费a网址| 深夜国产在线 | 伊人久久国产精品 | 日韩精品一区二区三区不卡 | 久久乐九色婷婷综合色狠狠182 | 高清av在线免费观看 | 欧美国产大片 | www黄在线 | 免费日韩精品 | 久久成人高清视频 | www.黄色在线| 91免费视频黄 | 日韩成人邪恶影片 | 久久欧美在线电影 | 精品资源在线 | 欧美一区二区三区在线 | 亚洲最新av网站 | 国产精品免费一区二区三区在线观看 | 麻豆视频免费在线播放 | 日日操操 | 国产欧美精品一区二区三区四区 | av片免费播放 | 国产精品第二十页 | 精品久久久久久亚洲综合网站 | 亚洲国产精品va在线看 | 色www.| 91亚洲精品久久久 | 蜜臀久久99精品久久久酒店新书 | 999一区二区三区 | 黄色h在线观看 | 日韩电影一区二区在线 | 日本三级久久久 | 一级电影免费在线观看 | 日韩欧美网站 | 国产福利资源 | 欧美一级爽 | 麻豆视频免费入口 | 日韩一区二区三区免费电影 | 国产你懂的在线 | 亚洲3级 | 久久久久国产a免费观看rela | 亚洲美女精品区人人人人 | 国产高清在线观看av | 色香蕉网 | 久久久久国产精品一区二区 | 成人黄色电影在线播放 | 视频在线日韩 | 久草视频在线免费播放 | av网址最新 | 五月综合 | 9在线观看免费 | 免费在线观看国产黄 | 亚洲国内在线 | 久久国产综合视频 | 国产一区在线视频播放 | 国产精品久久精品 | 狠狠综合久久av | 国产午夜在线观看 | 亚洲无吗av | 99久久久国产精品免费99 | 国产中文字幕亚洲 | 狠狠狠狠狠狠 | 在线亚洲小视频 | 中文字幕一区二区三区四区在线视频 | 中文字幕一区二区三区在线视频 | 在线亚洲人成电影网站色www | 亚洲欧美日韩精品一区二区 | 人成在线免费视频 | 久草在线91 | 国产黄色精品视频 | av中文字幕免费在线观看 | 91综合久久一区二区 | 久久精品成人热国产成 | 综合网天天 | 丁香av| 色播五月激情综合网 | 18国产精品福利片久久婷 | 99九九99九九九视频精品 | 免费91在线 | 欧美精品中文字幕亚洲专区 | 91九色视频在线 | 激情黄色一级片 | 人人爽人人做 | 久久激情小说 | 亚洲国产精品成人精品 | 福利视频导航网址 | 在线久热 | 国产精品午夜8888 | 日精品| 91激情视频在线 | 久操综合| 欧美精品一区二区在线观看 | 日韩精品欧美一区 | 久久精品www人人爽人人 | 欧美日韩中文国产 | 欧洲成人av | 97免费视频在线播放 | 国产一区二区三区免费视频 | 久久这里只有精品首页 | 91在线视频观看免费 | 亚洲欧美日韩国产 | 日韩电影在线一区二区 | 精品视频国产 | 精品嫩模福利一区二区蜜臀 | 久久久一本精品99久久精品66 | 99久久久国产精品免费99 | 99在线精品视频观看 | 日本一区二区不卡高清 | 亚洲精品视频在线观看免费视频 | 国产美女精彩久久 | 亚洲日本va午夜在线影院 | 日韩网站中文字幕 | 欧美在线91| 在线观看香蕉视频 | 在线欧美最极品的av | 麻豆91在线播放 | 在线视频观看你懂的 | 久久九九影院 | 视频在线观看亚洲 | 久久久久久久久免费视频 | 国产又粗又硬又爽的视频 | 亚洲电影一区二区 | 超碰97公开 | 国产不卡免费 | 久久久久久久久爱 | 五月天婷婷综合 | 亚洲理论片在线观看 | 国产三级av在线 | 久久99免费| 最近日本字幕mv免费观看在线 | 精品在线观看一区二区 | 精品久久久久久久久久 | 亚洲精品乱码久久久久久按摩 | 国产精品美女免费 | 国产精品九九久久久久久久 | 天天色天天草天天射 | 日韩视频一二三区 | 日韩久久影院 | 97精品国产一二三产区 | 国产日韩av在线 | 亚洲免费成人av电影 | 国产一级二级在线观看 | 久久视频这里只有精品 | 日韩黄色在线电影 | 国产成人av免费在线观看 | 国内外成人在线 | 在线看福利av | 国产精品久久久久免费观看 | 四虎成人免费影院 | 久久久午夜电影 | 国产免费又爽又刺激在线观看 | 国产视频中文字幕 | 国产精品美女久久久网av | 超碰在线中文字幕 | 午夜精品久久久久99热app | 久久国产女人 | 午夜美女wwww | 在线免费高清一区二区三区 | 精品国产一区二区三区在线观看 | 亚洲国产欧洲综合997久久, | 色小说在线 | 又爽又黄又刺激的视频 | 伊人久久影视 | 91精品伦理 | 国产伦精品一区二区三区… | 久草香蕉在线 | 国产视频一区在线播放 | 久久亚洲婷婷 | 操操操日日日干干干 | 久久久精品福利视频 | 欧美人人爱 | 成人xxxx | 欧美日韩国产在线 | 中午字幕在线 | 免费成人短视频 | 色操插| 婷婷丁香色 | 日韩有码专区 | 成人av免费在线 | 中文字幕亚洲欧美日韩2019 | 国产91精品高清一区二区三区 | 五月天中文在线 | 欧美一区二区三区特黄 | 麻豆国产在线播放 | 97成人在线观看 | 9热精品| 久久久久久久久久久久影院 | 日韩av在线小说 | 99人久久精品视频最新地址 | 一区二区三区在线看 | 91视频xxxx| 欧美成人h版 | 91人人射| www.久久视频 | 国产免费不卡 | 国产69熟| 日韩精品一区二区三区免费视频观看 | 深爱五月激情五月 | 伊人成人激情 | 精品一二三四在线 | 欧美整片sss | 免费在线日韩 | 国产不卡在线视频 | 中文字幕制服丝袜av久久 | 久久精品视频在线观看免费 | 国产精品18久久久久久久网站 | 91av片 | av大片免费 | 日韩av中文字幕在线免费观看 | 黄色中文字幕在线 | 国产色视频123区 | 免费在线激情电影 | 久久精品艹 | 最近高清中文字幕在线国语5 | 欧美日韩国产精品一区 | 欧美另类交人妖 | 2018好看的中文在线观看 | 天天干,夜夜操 | 亚洲成人av在线电影 | 国产在线一线 | 蜜桃久久久 | 免费观看性生交大片3 | 欧美动漫一区二区三区 | 国产在线美女 | 亚洲欧美日韩精品久久久 | 黄色片亚洲 | 91大片网站 | www.亚洲激情.com | 亚洲电影自拍 | 五月开心六月伊人色婷婷 | 欧美影院久久 | 国产玖玖精品视频 | 一区二区三区中文字幕在线观看 | 中文字幕黄色 | 国产三级久久久 | 日韩久久精品一区二区 | 日韩精品视频一二三 | 97理论电影| 精品99免费| 久久情网 | 免费看片网站91 | 在线天堂中文www视软件 | 免费污片 | 国产精品激情在线观看 | 免费观看www小视频的软件 | 午夜av免费 | 美女在线国产 | 一区二区三区国产精品 | 久久爽久久爽久久av东京爽 | 国产精品一区久久久久 | 久久久久久久久久久免费av | 亚洲成a人片在线www | 亚州成人av在线 | 激情五月色播五月 | 四虎天堂 | 狠狠狠狠狠狠狠狠干 | 亚洲黑丝少妇 | 伊人久久国产 | а天堂中文最新一区二区三区 | 在线中文字母电影观看 | 精品在线视频一区二区三区 | 国产精品久久99综合免费观看尤物 | 99精品视频在线观看免费 | 色丁香色婷婷 | 午夜美女福利直播 | 超碰九九 | 国产一级二级在线播放 | av网站手机在线观看 | 99精品视频在线免费观看 | 一区二区三区视频在线 | 欧美亚洲精品在线观看 | 天天干天天做 | 婷婷色网 | 久久久久久久久久久久久影院 | 在线 国产一区 | 日韩免费在线视频 | 久一久久 | 亚洲欧美日韩一二三区 | 日韩毛片在线播放 | 色综合久久天天 | 久久久久国产成人免费精品免费 | 欧美极品少妇xbxb性爽爽视频 | 国产91在线播放 | 亚洲一区av | 国产一区二区三区久久久 | 精品成人免费 | 91黄视频在线观看 | 日韩电影中文字幕在线 | 91九色最新地址 | 黄色精品久久 | 婷香五月 | 亚洲成av人影片在线观看 | 首页av在线 | 粉嫩av一区二区三区四区 | 婷婷在线色 | 亚洲国产无 | 人人爽人人射 | 久久婷亚洲五月一区天天躁 | 国产剧情在线一区 | 五月婷婷六月丁香在线观看 | 亚洲三级黄色 | 久久av免费观看 | 波多野结衣在线中文字幕 | 91 中文字幕 | 欧美肥妇free | 成人在线视频在线观看 | 成人97视频 | 日韩视频在线一区 | 婷婷色综合色 | 国产激情电影综合在线看 | 激情久久久久 | 中文字幕丰满人伦在线 | 国产在线看一区 | 四虎影视成人永久免费观看亚洲欧美 | 91黄色视屏 | 成人免费看电影 | 麻豆视频在线看 | 久久66热这里只有精品 | 国产麻豆精品久久一二三 | 十八岁免进欧美 | 久草99| 色播99| 五月婷婷综合在线 | 99热最新在线 | 午夜视频黄| 91禁在线观看 | 国产一区二区三区在线免费观看 | 天天干人人干 | 九色porny真实丨国产18 | 久久视频精品在线 | 亚洲人成在 | 国产一及片 | 中文字幕丰满人伦在线 | 天天爽天天爽 | 色多多视频在线观看 | 高潮毛片无遮挡高清免费 | 超碰在线人人爱 | 亚洲一区二区91 | 美女在线黄 | 97在线视频网站 | 在线黄色免费 | 热久久免费视频 | 亚洲精品99| 亚洲精品在线资源 | 四月婷婷在线观看 | 日日夜夜天天人人 | 亚洲夜夜爽 | 伊人成人久久 | 日韩一级电影在线观看 | 午夜av免费看| 91看片一区二区三区 | 国产一区二区午夜 | 激情av在线资源 | 欧美日韩高清在线观看 | 最近免费中文视频 | 久久亚洲精品国产亚洲老地址 | 国产美女视频免费观看的网站 | 天天操天天操天天操 | www四虎影院 | 久久综合爱 | 亚洲激情av | 女人高潮一级片 | 综合激情| 天天搞天天干天天色 | 精品99在线视频 | 国产精品永久免费在线 | 黄色免费网站下载 | a天堂最新版中文在线地址 久久99久久精品国产 | 国产亚洲在线观看 | 中文国产字幕 | 日韩动漫免费观看高清完整版在线观看 | 亚洲国产精品va在线 | 亚洲精选99 | 国产免费影院 | 亚洲另类xxxx | 美女网站色在线观看 | 日韩网站在线 | 国产中文字幕久久 | 99人成在线观看视频 | 国产福利一区二区在线 | 手机在线黄色网址 | 国产日产精品一区二区三区四区的观看方式 | 国产视频亚洲视频 | 麻豆成人在线观看 | 四虎国产永久在线精品 | 日韩欧美一区二区在线 | 在线观看国产v片 | 午夜精品久久久久久久99 | 天天色天天上天天操 | 国产精品18久久久久久久久久久久 | 日韩欧美在线免费 | 日韩av午夜在线观看 | 国产高清综合 | 国产精品视频在线观看 | 婷婷六月综合网 | 在线观看国产中文字幕 | 日本中文在线播放 | 国产精品久久久久久久久久久久午夜片 | 超碰在线9 | 日韩免 | 91在线影视| 国产专区在线播放 | 8x成人免费视频 | 久草视频国产 | av黄色在线 | 成人小视频免费在线观看 | 一级免费看视频 | 美女视频免费精品 | 香蕉视频亚洲 | 久草精品视频 | 五月激情亚洲 | 国产成人精品午夜在线播放 | 999久久a精品合区久久久 | 日韩久久精品一区二区三区下载 | 色婷婷激情电影 | 国产高清专区 |