精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

開源神器 MegPeak,讓你更懂你的處理器!

開源
MegPeak 作為一個進行高性能計算的輔助工具,能夠使得開發(fā)人員輕松獲得目標(biāo)處理器的內(nèi)在的詳細信息,輔助進行對代碼的性能評估,以及優(yōu)化方法設(shè)計。

在這個算力需求爆炸的大背景下,如何發(fā)揮出已有硬件的最大算力變得非常重要,直觀一點是:我們需要對現(xiàn)有算法,針對特定處理器,進行極致的性能優(yōu)化,盡量滿足目前 AI 算法對算力高要求。

為了能夠做到極致的性能優(yōu)化,可實現(xiàn)的方向有:

  • 優(yōu)化算法,使得算法能夠在滿足準(zhǔn)確度前提下,訪存和計算量盡量小
  • 優(yōu)化程序,使得實現(xiàn)這些算法的程序最大限度發(fā)揮處理器性能

在優(yōu)化程序的過程中,首先要解決的問題是:如何評估程序發(fā)揮了處理器幾成的算力,以及進一步優(yōu)化空間和優(yōu)化方向。

為了讓我們更懂處理器,MegEngine 團隊開發(fā)了一個處理器調(diào)試工具 MegPeak。

該工具主要用于幫助開發(fā)人員進行性能評估,開發(fā)指導(dǎo)等工作,項目代碼目前已完全開源,大家感興趣的話可以看下。

GitHub:??https://github.com/MegEngine/MegPeak???

下面我們來簡單看下,這款工具所擁有的功能,以及項目的技術(shù)實現(xiàn)細節(jié)。

MegPeak 介紹

通過 MegPeak,用戶可以測試目標(biāo)處理器:

  • 指令的峰值帶寬
  • 指令延遲
  • 內(nèi)存峰值帶寬
  • 任意指令組合峰值帶寬

雖然上面的部分信息可以通過芯片的數(shù)據(jù)手冊查詢相關(guān)數(shù)據(jù),然后結(jié)合理論計算得到,但是很多情況下無法獲取目標(biāo)處理器詳盡的性能文檔,另外通過 MegPeak 進行測量更直接和準(zhǔn)確,并且可以測試特定指令組合的峰值帶寬。

MegPeak 使用方法

使用方法參考 MegPeak 的 Readme 文檔:

??https://github.com/MegEngine/MegPeak#build???

MegPeak 使用示例

測試 ArmV8 上通用指令峰值和延遲,編譯完成之后,在目標(biāo)處理器上執(zhí)行 megpeak,得到:

如上圖所示,MegPeak 可以精確測試出 CPU 上每條指令的計算峰值以及延遲周期。OpenCL 上將測試出不同數(shù)據(jù)類型進行訪存的 Local Memory,Global Memory 的帶寬,以及 int/float 不同數(shù)據(jù)類型進行計算的峰值。

這些數(shù)值,將有效指導(dǎo)我們評估目前程序的性能,并繪制 RoofLine,幫助用戶診斷出阻塞程序主要因素,是訪存或者計算。具體使用分析方法將在后面介紹。

MegPeak 原理

MegPeak 測試的主要參數(shù)是:

  • CPU 不同指令的計算峰值,以及指令延遲,以及內(nèi)存帶寬
  • OpenCL 中不同內(nèi)存的數(shù)據(jù)訪存帶寬,以及不同計算數(shù)據(jù)類型的計算峰值

要了解 MegPeak 是如何測試出上面這些性能數(shù)據(jù),并且做到和數(shù)據(jù)手冊上查詢到盡量一致,因此需要讀者了解下面 CPU 流水線相關(guān)細節(jié)。

處理器流水線

現(xiàn)代處理器為了增加指令的吞吐,引入了指令流水線,指令流水線可以將一條指令的執(zhí)行過程劃分為多個階段,經(jīng)典的 5 級流水線有:取指令,翻譯指令,執(zhí)行指令,訪問寄存器,寫回數(shù)據(jù)。

這 5 個階段,處理器中執(zhí)行每個階段的物理單元獨立,因此理想狀態(tài)下,每個時鐘周期每個階段對應(yīng)的物理單元都能執(zhí)行一次對應(yīng)的操作,這樣就形成了流水線,這樣處理器每個時鐘周期就可以完成執(zhí)行一條指令。

如下表所示,從第 5 個時鐘周期之后,每個時鐘周期都會完成一條指令執(zhí)行:

但是,流水線在實際執(zhí)行時候不可能一直這樣流暢的執(zhí)行下去,會存在以下的冒險,阻塞流水線。

  • 結(jié)構(gòu)冒險 —— 如果硬件無法同時支持指令的所有可能組合方式,就會出現(xiàn)資源沖突,從而導(dǎo)致結(jié)構(gòu)冒險
  • 數(shù)據(jù)冒險 —— 流水線指令存在先后順序,如果一條指令取決于先前指令的結(jié)果,就可能導(dǎo)致數(shù)據(jù)冒險
  • 控制冒險 —— 分支指令及其他改變程序計數(shù)器的指令實現(xiàn)流水化時,可能導(dǎo)致控制冒險

MegPeak 中測量處理器指令的計算峰值和延遲就是通過控制指令間的數(shù)據(jù)冒險,盡可能排除結(jié)構(gòu)冒險和控制冒險來實現(xiàn)的。因為 MegPeak 中需要通過寫 Code 來控制處理器的數(shù)據(jù)冒險,為了排除編譯器編譯 code 時候的優(yōu)化帶來的干擾,所以在 MegPeak 在測試中的核心代碼使用匯編來實現(xiàn)的。

測試指令峰值

為了測量處理器上一條指令的計算峰值,我們需要寫出重復(fù)執(zhí)行這條指令,但是沒有任何冒險的代碼,所以需要代碼控制數(shù)據(jù)冒險和控制冒險。

  •   消除數(shù)據(jù)冒險 ---- 消除重復(fù)指令之間的數(shù)據(jù)依賴,讓前后指令之間沒有下面的數(shù)據(jù)相關(guān),雖然 WAW,WRA 不是真正的數(shù)據(jù)相關(guān),處理器可能會使用寄存器重命名來解決,但是我們還是盡量不要寫出這樣的數(shù)據(jù)相關(guān)。
  •   寫后讀(RAW):上一條指令寫入,下一條指令讀取寫入數(shù)據(jù),這時候后一條指令需要等上一條指令運行結(jié)束之后再運行
  •   寫后寫(WAW):兩條指令前后寫入同一個寄存器,這時候數(shù)據(jù)寫入的先后順序很重要
  •   讀后寫(WRA) :上一條指令讀取一個寄存器,下一條指令將新的數(shù)據(jù)寫入這個寄存器,他們的順序也同樣很重要
  •  盡可能的消除控制冒險 ---- 為了重復(fù)多次執(zhí)行同一條指令,我們可能會用循環(huán)來實現(xiàn),但是循環(huán)里面有分支,可能會造成控制冒險,所以我們需要盡可能的循環(huán)展開,讓一個循環(huán)里面執(zhí)行更多的數(shù)據(jù)無關(guān)的指令,但是這個數(shù)量會被處理器的寄存器數(shù)量限制。

下面是 MegPeak 測試 Arm64 上 fmla 指令計算峰值時候的核心 Code。

static int fmla_throughput() {
asm volatile(
"eor v0.16b, v0.16b, v0.16b\n"
"eor v1.16b, v1.16b, v1.16b\n"
...
"eor v19.16b, v19.16b, v19.16b\n"
"mov x0, #0\n"
"1:\n"
"fmla v0.4s, v0.4s, v0.4s\n"
"fmla v1.4s, v1.4s, v1.4s\n"
...
"fmla v19.4s, v19.4s, v19.4s\n"
"add x0, x0, #1 \n"
"cmp x0, %x[RUNS] \n"
"blt 1b \n"
:
: [RUNS] "r"(megpeak::RUNS)
: "cc", "v0", "v1", "v2", "v3", "v4", "v5", "v6", "v7", "v8", "v9", "v10", "v11", "v12", "v13",
"v14", "v15", "v16", "v17", "v18", "v19", "x0");
return megpeak::RUNS * 20;
}

上面的內(nèi)嵌匯編代碼中,主要做了幾件事情:

  • 初始化 0–19 號 neon 寄存器為零,這一步不是必須的,但可以避免計算過程中出現(xiàn) nan 導(dǎo)致的潛在影響。
  • 創(chuàng)建主循環(huán),主循環(huán)中每條指令執(zhí)行,從對應(yīng)的寄存器讀取數(shù)據(jù),并執(zhí)行 fmla 指令,將計算結(jié)果寫到相同的寄存器中,同一條指令內(nèi)部沒有數(shù)據(jù)相關(guān)。

這里有一個問題需要解釋,為什么選擇 20 個寄存器:

  • 如果寄存器選擇太少,上一次循環(huán)可能還沒有計算完成,下一次循環(huán)讀取相同的寄存器,可能造成數(shù)據(jù)相關(guān),因此循環(huán)里面執(zhí)行的指令條數(shù)需要大于指令延遲和處理器單個周期內(nèi)能夠執(zhí)行的指令數(shù)的乘積,但是我們不知道這條指令延遲,但是可以估計,除了特殊的指令,延遲一般不超過 10 個時鐘周期。
  • Arm64 有 32 個 neon 寄存器,為什么不選擇 32 個寄存器,因為 20 個寄存器已經(jīng)可以避免數(shù)據(jù)和控制相關(guān)了,測試發(fā)現(xiàn)使用更多的寄存器影響很小。

執(zhí)行上面的代碼,可以統(tǒng)計執(zhí)行的時間,加上可以提前通過指令的數(shù)目以及循環(huán)的次數(shù)計算出真正的計算量,因此便可以計算出指令的計算峰值。

測試指令延遲

為了測量處理器上一條指令的執(zhí)行延遲,我們需要寫出重復(fù)執(zhí)行這條指令,并讓這些指令之間存在嚴格的數(shù)據(jù)冒險,盡量排除其他冒險。

  • 制造數(shù)據(jù)冒險 ---- 讓前后兩條指令之間的數(shù)據(jù)存在真正的數(shù)據(jù)依賴(RAW),即上一條指令的輸出為下一條指令的輸入;
  • 盡可能的消除控制冒險 ---- 同上。

下面是 MegPeak 測試 Arm64 上 fmla 指令延遲的核心 Code。

static int fmla_latency() {
asm volatile(
"eor v0.16b, v0.16b, v0.16b\n"
"mov x0, #0\n"
"1:\n"
"fmla v0.4s, v0.4s, v0.4s\n"
//重復(fù) 20
...
"fmla v0.4s, v0.4s, v0.4s\n"
"add x0, x0, #1 \n"
"cmp x0, %x[RUNS] \n"
"blt 1b \n"
:
: [RUNS] "r"(megpeak::RUNS)
: "cc", "v0", "x0"
);
return megpeak::RUNS * 20;
}

上面的內(nèi)嵌匯編代碼中,主要將

fmla v0.4s, v0.4s, v0.4s\n

這條指令重復(fù)了 20 次,這樣每條指令都依賴上一條指令的計算結(jié)果,所以存在嚴格的數(shù)據(jù)相關(guān)。

執(zhí)行代碼,統(tǒng)計執(zhí)行時間,通過執(zhí)行的指令條數(shù),可以計算出這條指令最終的延遲。

上面的代碼在 MegPeak 中實現(xiàn),不是這么直接,而是通過宏來實現(xiàn) code 的生成。

用 MegPeak 測到的數(shù)據(jù),可以用來干什么

MegPeak 可以測試出處理器的內(nèi)存帶寬,指令的理論計算峰值,指令的延遲等信息,因此可以幫助我們:

  • 繪制 Roofline Model 指導(dǎo)我們優(yōu)化模型性能
  • 評估程序的優(yōu)化空間
  • 探索指令組合的理論計算峰值

另外 MegPeak 還可以提供對理論的驗證,如我們通過處理器頻率 單核單周期指令發(fā)射數(shù)量 每條指令執(zhí)行的計算量可以計算出理論計算峰值,然后我們可以通過 MegPeak 進行實際測量進行驗證。

繪制指令相關(guān)的 Roofline Model

Roofline 模型被大量的使用在高性能計算中,是評估算法的可優(yōu)化程度和優(yōu)化方向的重要工具。使用 MegPeak 可以繪制出更加具體的關(guān)于指令對應(yīng)的 Roofline 模型,如:在 CPU 中,不同的數(shù)據(jù)類型,雖然訪存帶寬不會改變,但是計算峰值差距比較大,比如在 arm 上 float 的計算峰值和 int8 的計算峰值差距很大。

評估代碼優(yōu)化空間

在優(yōu)化具體算法的時候,可以通過 MegPeak 測試出 kernel 里面的主要指令的最大峰值,如在 Arm 上優(yōu)化 fp32 Matmul 的時候,主要用到的指令是 fmla 指令,這時候可以測試程序?qū)嶋H運行的峰值,如果指令的峰值和程序的峰值差距越小,說明代碼優(yōu)化得越好。

另外,可以根據(jù)算法實現(xiàn)計算出計算量和訪存量,并使用 MegPeak 繪制出上面的 Roofline,通過計算實際的計算密度,然后再對應(yīng)到 Roofline 中,如果計算密度落在上圖中的綠色區(qū)域,說明程序需要更多考慮優(yōu)化訪存,提供更優(yōu)的訪存模型,如分塊,提前 pack 數(shù)據(jù)等。如果計算強度的點落在灰色區(qū)域說明,代碼已經(jīng)最優(yōu)了,如果還想進一步提速,只能考慮從算法角度進行優(yōu)化了,如:在卷積中使用 FFT,Winograd 等算法進行優(yōu)化。

探索最優(yōu)指令組合

很多 Kernel 的優(yōu)化不是單純的某一條指令就可以衡量,可能需要多條指令的組合才能代表整個 Kernel 的計算,因此我們需要探索如何組織這些指令使其達到處理器最優(yōu)的性能。下面列舉在 A53 小核優(yōu)化 fp32 Matmul 的過程中,由于 Matmul 是計算密集型算子,考慮通過多發(fā)射隱藏訪存指令的開銷,使用 MegPeak 配合進行分析,探索如何組合指令實現(xiàn)盡可能多地多發(fā)射。

因為小核上面資源有限,指令多發(fā)射有很多限制:

  • 首先使用 MegPeak 出測試 A53 上 fp32 的 fmla 指令的計算峰值,將其定義為 100% 峰值計算性能
  • 測試哪些指令組合可以支持雙發(fā)射
  • 在 MegPeak 中添加 vector load 和 fmla 1:1 組合的代碼,然后測試其峰值僅僅為 float 峰值的 36%,表明 Vector load 和 fmla 不能雙發(fā)射
  • 同樣可以測得通用寄存器 load 指令 ldr+fmla 的組合可以達到 float 峰值的 93%,說明 ldr 可以和 fmla 雙發(fā)射
  • 同上可以測得 ins + fmla 能雙發(fā)射,ins + vector load 64 位 可以雙發(fā)射
  • 根據(jù) Matmul 最內(nèi)層 Kernel 的 計算原理,如最內(nèi)層 Kernel 的分塊大小是 8x12,那最內(nèi)層需要讀取:20 個 float 數(shù)據(jù),計算 24 次 fmla 計算
  • 結(jié)合上面的 MegPeak 測試的信息,我們需要找到用最少時鐘完成這:20 個 float 數(shù)據(jù) load,和 24 次 fmla 數(shù)據(jù)計算的指令組合,因此需要將盡可能多的數(shù)據(jù) load 和 fmla 進行雙發(fā)射,隱藏數(shù)據(jù) load 的耗時
  • 最后的指令組合是:
  • 使用 vector load 64 指令 + ldr + ins 組合成為一個 neon 寄存器數(shù)據(jù),因為 ldr 和 ins 都可以和 fmla 雙發(fā)射,把他們和 fmla 放在一起可以隱藏他們的耗時
  • 在這 3 條指令中穿插 fmla 指令,并盡可能解決數(shù)據(jù)依賴

根據(jù)上面的指令組合可以使得 Matmul 在小核上達到計算峰值的 70% 左右。

總結(jié)

MegPeak 作為一個進行高性能計算的輔助工具,能夠使得開發(fā)人員輕松獲得目標(biāo)處理器的內(nèi)在的詳細信息,輔助進行對代碼的性能評估,以及優(yōu)化方法設(shè)計。但是 MegPeak 也有一些需要豐富的方向:

  • 支持獲取更多的處理器性能數(shù)據(jù),如:L1,L2 cache 的大小,自動探索各種指令組合的雙發(fā)射情況,并大概繪制出一個處理器后端的縮略圖。如:en.wikichip.org/w/image
  • 支持測量移動端 OpenCL 的更多細節(jié)信息,如:warp size,local memory 大小等。

如果有同學(xué)對上面的功能感興趣,可以到 GitHub 上提交代碼,或嘗試使用 MegPeak。

責(zé)任編輯:龐桂玉 來源: 良許Linux
相關(guān)推薦

2020-12-31 06:55:37

機器人自然語言人工智能

2016-03-17 17:35:20

浪潮

2023-06-12 15:01:07

縮放神器Web工具

2017-04-27 13:42:56

機智云智能家居機器

2020-09-03 07:27:16

自然語言處理NLP語言

2012-07-10 10:36:45

開發(fā)版Intel

2024-02-19 07:51:52

WebargsPythonWeb

2017-12-19 10:41:29

人工智能UCloudARKie

2019-09-17 14:31:52

JSJavaScript前端

2021-09-30 12:55:44

數(shù)據(jù)處理流處理引擎

2009-02-27 15:15:00

2020-10-14 07:35:43

Linux 5.10

2018-07-16 00:09:30

數(shù)據(jù)科學(xué)大數(shù)據(jù)機器學(xué)習(xí)

2023-11-28 10:17:37

2010-04-22 15:24:36

郵件安全網(wǎng)絡(luò)加密服務(wù)器

2020-01-18 14:59:36

手機AI手機處理器

2024-12-04 08:50:03

2020-05-07 10:18:06

JavaScript前端技術(shù)

2015-09-08 10:44:15

MIAOW圖形處理器開源

2023-05-03 08:58:46

數(shù)據(jù)庫開源
點贊
收藏

51CTO技術(shù)棧公眾號

中文字幕在线一区| 91九色精品国产一区二区| 偷窥少妇高潮呻吟av久久免费| 国产精品久久亚洲7777| 好吊色在线视频| 日本在线电影一区二区三区| 91精品国产综合久久精品app | av动漫在线观看| 韩国福利在线| 国产一区在线看| 91成人在线视频| 污软件在线观看| 日韩高清在线免费观看| 3d动漫精品啪啪1区2区免费 | 啦啦啦中文在线观看日本| av电影在线观看完整版一区二区| 国产精品福利网站| 精品在线视频免费| 久久精品青草| 亚洲欧美资源在线| 老熟女高潮一区二区三区| 成人黄色免费网站| 精品久久久久久国产| 这里只有精品66| 免费在线黄色影片| 成人激情免费电影网址| 91亚洲永久免费精品| 中文字幕一区二区人妻视频| 亚洲第一伊人| 欧美精品情趣视频| 熟女少妇a性色生活片毛片| 国产成人精品免费视| 精品国产伦一区二区三区免费| 久久国产这里只有精品| 亚洲校园激情春色| 午夜精品福利一区二区三区蜜桃| 中国老女人av| 黄色网页网址在线免费| 欧美精品18| 麻豆极品一区二区三区| 久久久久久久久久久成人| 少妇高潮惨叫久久久久| 国产日产精品_国产精品毛片| 亚洲国产成人精品久久| 台湾佬美性中文| 免费观看在线一区二区三区| 欧美精品亚洲二区| 亚洲欧洲日本精品| 国产91亚洲精品久久久| 欧美日韩一区二区三区四区五区| 日本免费一级视频| 成人香蕉视频| 色欧美日韩亚洲| 虎白女粉嫩尤物福利视频| 欧美裸体视频| 一本久久综合亚洲鲁鲁五月天| 精品少妇人妻av免费久久洗澡| eeuss鲁一区二区三区| 亚洲一区二区在线免费看| 日韩一二区视频| 欧美xxxxhdvideosex| 亚洲综合自拍偷拍| 九一国产精品视频| 碰碰在线视频| 日本高清不卡在线观看| 欧美黄色一级片视频| 91国拍精品国产粉嫩亚洲一区| 欧美三级中文字| 亚洲18在线看污www麻豆| 国产成年精品| 亚洲精品一线二线三线| 少妇饥渴放荡91麻豆| 在线亚洲a色| www.久久久久久.com| 亚洲欧美精品aaaaaa片| 国内综合精品午夜久久资源| 97视频人免费观看| 免费一级a毛片| 国产一区二区三区不卡在线观看| 91久久精品一区二区别| 黄色片网站免费| 欧美一级特黄aaaaaa| 国产主播一区二区三区| 国产日韩一区欧美| 免费av在线电影| 中文字幕中文乱码欧美一区二区 | 国产高清视频免费最新在线| 国产精品美日韩| av日韩在线看| 久久久成人av毛片免费观看| 欧美一区永久视频免费观看| 波多野结衣一二三区| 欧美亚洲在线日韩| 欧美激情精品久久久久久久变态| 久草手机在线视频| 久久99热99| 激情伦成人综合小说| 91sp网站在线观看入口| 午夜一区二区三区视频| www.色就是色| 国产成人av毛片| 中文字幕亚洲一区| 天海翼一区二区| 国产真实乱对白精彩久久| 久久精品五月婷婷| 国产乱色在线观看| 在线一区二区三区四区五区| 国产精品欧美性爱| 色135综合网| 51ⅴ精品国产91久久久久久| 国产露脸无套对白在线播放| 久久久国产精品麻豆| 日韩一级特黄毛片| 欧美激情福利| 亚洲美女久久久| 久久久夜色精品| 狠狠色狠狠色综合系列| 日本精品视频一区| 国产粉嫩在线观看| 欧美一二三四在线| 女同久久另类69精品国产| 午夜一级久久| 97人人干人人| 69久久久久久| sese一区| 欧美性色xo影院| 欧美xxxxx少妇| 欧美成人日韩| 91深夜福利视频| 日本亚洲精品| 欧洲另类一二三四区| 国产精品一级黄片| 伊人天天综合| 成人午夜电影在线播放| 国产黄色小视频在线| 欧美人xxxx| 亚洲综合第一区| 日本女人一区二区三区| 蜜桃精品久久久久久久免费影院| 牛牛精品在线| 精品美女在线观看| 久久久无码精品亚洲国产| 国产精品69久久久久水密桃| 欧美h视频在线观看| 四虎国产精品免费久久5151| 少妇精69xxtheporn| 在线观看你懂的网站| 国产三级一区二区三区| 日韩精品无码一区二区三区免费| 亚洲品质自拍| 日本久久久久久久久| 全色精品综合影院| 在线观看三级视频欧美| 亚洲精品一区二区三区影院忠贞| 久久中文在线| 亚洲第一导航| 亚洲成人1区| 欧美成人四级hd版| 肥臀熟女一区二区三区| 午夜精品一区二区三区电影天堂| 亚洲av无码一区二区三区网址| 国产精品资源| 亚洲精品国产精品国自产观看| 99热播精品免费| 久久综合五月天| 亚洲成人第一区| 黑人精品xxx一区| 国产综合精品久久久久成人av| 麻豆一区二区99久久久久| 国产日韩欧美大片| 精品三级在线观看视频| 日韩免费av片在线观看| 翡翠波斯猫1977年美国| 青青青草视频在线| 亚洲激情视频在线| 亚洲va在线观看| 国产精品每日更新在线播放网址| 中文字幕一区二区在线观看视频| 欧美激情在线| 欧洲亚洲一区二区三区四区五区| 国产精品xxx| 久久久久久美女| 九一在线视频| 日韩三级视频在线看| 在线观看黄网站| 一区在线播放视频| 岛国精品资源网站| 麻豆精品蜜桃视频网站| 欧美高清中文字幕| 久久av中文| 99伊人久久| 快播电影网址老女人久久| 超碰97人人做人人爱少妇| 天天操天天操天天操| 欧美唯美清纯偷拍| 欧美福利视频一区二区| 国产精品国产三级国产三级人妇| 日本r级电影在线观看| 亚洲麻豆视频| 亚洲第一精品区| 欧洲精品一区| 亚洲影视九九影院在线观看| 伊人色综合一区二区三区影院视频| 日韩亚洲一区二区| 性高潮久久久久久久久久| 欧美人xxxx| 天堂网一区二区| 午夜影院久久久| 欧美日韩在线观看成人| 欧美国产乱子伦| 青青草视频成人| 国产成人午夜视频| 日本肉体xxxx裸体xxx免费| 国产欧美二区| 日韩精品影音先锋| 美女福利视频网| 91年精品国产| 波多野结衣办公室双飞| 蜜桃视频在线一区| 日韩精品视频久久| 欧美日韩亚洲三区| 永久域名在线精品| 国产欧美日韩在线观看视频| 精品综合在线| 最新精品在线| 亚洲综合中文字幕68页| 天天综合91| 国产精品户外野外| 欧美xnxx| 日韩av电影院| 亚洲欧美韩国| 97视频在线观看视频免费视频| 欧美1—12sexvideos| 日韩有码在线电影| 看电影就来5566av视频在线播放| 亚洲国产精品资源| 好男人在线视频www| 日韩女优电影在线观看| 国产口爆吞精一区二区| 9191国产精品| 国产精品热久久| 欧美欧美欧美欧美首页| 最好看的日本字幕mv视频大全 | 欧美日韩 一区二区三区| 一本在线高清不卡dvd| 久久国产视频精品| 一本久久a久久免费精品不卡| 国产免费av一区| 色菇凉天天综合网| 中文字幕+乱码+中文| 欧美日韩一区 二区 三区 久久精品 | 天天射天天操天天干| 精品不卡在线视频| 人妻中文字幕一区| 日韩精品免费一线在线观看| 香蕉视频成人在线| 亚洲日韩欧美视频一区| av资源在线观看免费高清| 综合久久五月天| 欧美日韩xx| 欧美大片免费看| av伦理在线| 国产不卡av在线| 国内欧美日韩| 成人欧美一区二区三区视频 | 中文字幕av日韩| 麻豆tv免费在线观看| 欧美www在线| 国产99在线观看| 国产精品久久久久9999| avtt久久| 久久99精品久久久水蜜桃| 欧美日韩亚洲在线观看| 少妇高潮流白浆| 91久久中文| www.精品在线| 国产大陆a不卡| 最近中文字幕免费视频| 中文字幕一区二区三区蜜月| 久久免费播放视频| 色综合久久综合网97色综合| 97成人免费视频| 亚洲国产精品一区二区三区| av在线之家电影网站| 欧美激情精品久久久久久久变态 | 国产精品日韩一区二区三区| 亚洲精品一级二级三级| 宅男一区二区三区| 99综合在线| 九九久久久久久| 99精品在线观看视频| 日本免费网站视频| 午夜国产精品一区| 国产乱码久久久| 日韩精品在线观看一区| 国产在线看片| 日韩免费av片在线观看| 91国内精品| 亚洲午夜精品久久久久久浪潮| 亚洲福利一区| 不卡中文字幕在线观看| 久久影院视频免费| 国产一卡二卡在线播放| 欧美日产国产精品| 亚洲aⅴ乱码精品成人区| 久久精品国产久精国产思思| 中文字幕在线视频网站| 超碰97人人在线| 水蜜桃久久夜色精品一区| 777久久久精品一区二区三区| 国产福利不卡视频| 国精产品视频一二二区| 日韩欧美成人精品| 亚洲免费国产视频| 欧美成人合集magnet| 99蜜月精品久久91| 欧洲一区二区在线| 午夜一区不卡| 99re这里只有| 一区二区日韩av| 国产欧美综合视频| 中文字幕日韩有码| 亚洲人免费短视频| 精品一区2区三区| 亚洲第一黄网| 中文字幕第3页| 亚洲一区二区三区三| 国产手机av在线| 久久精品在线视频| 国产精品一区二区免费福利视频| 免费看成人午夜电影| 国产亚洲综合精品| 无码成人精品区在线观看| 洋洋av久久久久久久一区| 国产富婆一级全黄大片| 久久亚洲精品国产亚洲老地址| 欧美在线一级| 一区二区三区免费看| 麻豆精品国产传媒mv男同| 俄罗斯毛片基地| 欧美日韩日本视频| 91社区在线| 国产精品视频午夜| 久久国产精品亚洲人一区二区三区| 亚欧在线免费观看| 国产精品视频线看| 一本大道伊人av久久综合| 色偷偷9999www| 亚洲成a人片777777久久| 亚洲黄色网址在线观看| 国产一区二区免费视频| 91成人福利视频| 精品国产乱码久久久久久老虎| 国精一区二区三区| 久久精品一二三区| 男女激情视频一区| 午夜三级在线观看| 欧美成人一级视频| 2020国产在线| 欧美精品二区三区四区免费看视频| 久久九九99| 一级二级黄色片| 91精品国产黑色紧身裤美女| 羞羞网站在线看| 精品免费视频123区| 日韩精品一二三区| 亚洲欧美精品久久| 精品国产免费一区二区三区四区| 国产v日韩v欧美v| 亚洲国产一区二区三区在线播| 精品一区二区三区免费毛片爱| 久久精品视频免费在线观看| 亚洲精品在线三区| 日韩欧美一区二区三区在线观看| 在线观看国产一区| 本田岬高潮一区二区三区| 中文字幕在线欧美| 日韩在线视频一区| av在线亚洲色图| 最近免费中文字幕中文高清百度| 最新国产の精品合集bt伙计| 亚洲风情第一页| 国产成人精品免费视频| 欧美激情成人在线| 国产aⅴ激情无码久久久无码| 3d动漫精品啪啪一区二区竹菊 | 中文字幕在线视频区| 波多野结衣久草一区| 久久亚洲欧美| 国产探花在线免费观看| 日韩精品在线观| 麻豆国产一区| 草草草在线视频| 亚洲国产精品一区二区www在线| 国产裸舞福利在线视频合集| 成人精品一二区| 久久99这里只有精品| 女人十八岁毛片| 欧美丰满少妇xxxxx| 日本一区二区三区视频|