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

Android硬件加速原理與實現簡介

移動開發 Android
在手機客戶端尤其是Android應用的開發過程中,我們經常會接觸到“硬件加速”這個詞。由于操作系統對底層軟硬件封裝非常完善,上層軟件開發者往往對硬件加速的底層原理了解很少,也不清楚了解底層原理的意義,因此常會有一些誤解,如硬件加速是不是通過特殊算法實現頁面渲染加速,或是通過硬件提高CPU/GPU運算速率實現渲染加速。

在手機客戶端尤其是Android應用的開發過程中,我們經常會接觸到“硬件加速”這個詞。由于操作系統對底層軟硬件封裝非常完善,上層軟件開發者往往對硬件加速的底層原理了解很少,也不清楚了解底層原理的意義,因此常會有一些誤解,如硬件加速是不是通過特殊算法實現頁面渲染加速,或是通過硬件提高CPU/GPU運算速率實現渲染加速。

本文嘗試從底層硬件原理,一直到上層代碼實現,對硬件加速技術進行簡單介紹,其中上層實現基于Android 6.0。

了解硬件加速對App開發的意義

對于App開發者,簡單了解硬件加速原理及上層API實現,開發時就可以充分利用硬件加速提高頁面的性能。以Android舉例,實現一個圓角矩形按鈕通常有兩種方案:使用PNG圖片;使用代碼(XML/Java)實現。簡單對比兩種方案如下。 

 

 

 

頁面渲染背景知識

  • 頁面渲染時,被繪制的元素最終要轉換成矩陣像素點(即多維數組形式,類似安卓中的Bitmap),才能被顯示器顯示。
  • 頁面由各種基本元素組成,例如圓形、圓角矩形、線段、文字、矢量圖(常用貝塞爾曲線組成)、Bitmap等。
  • 元素繪制時尤其是動畫繪制過程中,經常涉及插值、縮放、旋轉、透明度變化、動畫過渡、毛玻璃模糊,甚至包括3D變換、物理運動(例如游戲中常見的拋物線運動)、多媒體文件解碼(主要在桌面機中有應用,移動設備一般不用GPU做解碼)等運算。
  • 繪制過程經常需要進行邏輯較簡單、但數據量龐大的浮點運算。

CPU與GPU結構對比

CPU(Central Processing Unit,中央處理器)是計算機設備核心器件,用于執行程序代碼,軟件開發者對此都很熟悉;GPU(Graphics Processing Unit,圖形處理器)主要用于處理圖形運算,通常所說“顯卡”的核心部件就是GPU。

下面是CPU和GPU的結構對比圖。其中:

  • 黃色的Control為控制器,用于協調控制整個CPU的運行,包括取出指令、控制其他模塊的運行等;
  • 綠色的ALU(Arithmetic Logic Unit)是算術邏輯單元,用于進行數學、邏輯運算;
  • 橙色的Cache和DRAM分別為緩存和RAM,用于存儲信息。 

 

 

 

  • 從結構圖可以看出,CPU的控制器較為復雜,而ALU數量較少。因此CPU擅長各種復雜的邏輯運算,但不擅長數學尤其是浮點運算。
    • 以8086為例,一百多條匯編指令大部分都是邏輯指令,數學計算相關的主要是16位加減乘除和移位運算。一次整型和邏輯運算一般需要1~3個機器周期,而浮點運算要轉換成整數計算,一次運算可能消耗上百個機器周期。
    • 更簡單的CPU甚至只有加法指令,減法用補碼加法實現,乘法用累加實現,除法用減法循環實現。
    • 現代CPU一般都帶有硬件浮點運算器(FPU),但主要適用于數據量不大的情況。
  • CPU是串行結構。以計算100個數字為例,對于CPU的一個核,每次只能計算兩個數的和,結果逐步累加。
  • 和CPU不同的是,GPU就是為實現大量數學運算設計的。從結構圖中可以看到,GPU的控制器比較簡單,但包含了大量ALU。GPU中的ALU使用了并行設計,且具有較多浮點運算單元。
  • 硬件加速的主要原理,就是通過底層軟件代碼,將CPU不擅長的圖形計算轉換成GPU專用指令,由GPU完成。

擴展:很多計算機中的GPU有自己獨立的顯存;沒有獨立顯存則使用共享內存的形式,從內存中劃分一塊區域作為顯存。顯存可以保存GPU指令等信息。

并行結構舉例:級聯加法器

為了方便理解,這里先從底層電路結構的角度舉一個例子。如下圖為一個加法器,對應實際的數字電路結構。

  • A、B為輸入,C為輸出,且A、B、C均為總線,以32位CPU為例,則每根總線實際由32根導線組成,每根導線用不同的電壓表示一個二進制的0或1。
  • Clock為時鐘信號線,每個固定的時鐘周期可向其輸入一個特定的電壓信號,每當一個時鐘信號到來時,A和B的和就會輸出到C。 

 

 

 

現在我們要計算8個整數的和。

對于CPU這種串行結構,代碼編寫很簡單,用for循環把所有數字逐個相加即可。串行結構只有一個加法器,需要7次求和運算;每次計算完部分和,還要將其再轉移到加法器的輸入端,做下一次計算。整個過程至少要消耗十幾個機器周期。

而對于并行結構,一種常見的設計是級聯加法器,如下圖,其中所有的clock連在一起。當需要相加的8個數據在輸入端A1~B4準備好后,經過三個時鐘周期,求和操作就完成了。如果數據量更大、級聯的層級更大,則并行結構的優勢更明顯。

由于電路的限制,不容易通過提高時鐘頻率、減小時鐘周期的方式提高運算速度。并行結構通過增加電路規模、并行處理,來實現更快的運算。但并行結構不容易實現復雜邏輯,因為同時考慮多個支路的輸出結果,并協調同步處理的過程很復雜(有點像多線程編程)。 

 

 

 

GPU并行計算舉例

假設我們有如下圖像處理任務,給每個像素值加1。GPU并行計算的方式簡單粗暴,在資源允許的情況下,可以為每個像素開一個GPU線程,由其進行加1操作。數學運算量越大,這種并行方式性能優勢越明顯。 

 

 

 

Android中的硬件加速

在Android中,大多數應用的界面都是利用常規的View來構建的(除了游戲、視頻、圖像等應用可能直接使用OpenGL ES)。下面根據Android 6.0原生系統的Java層代碼,對View的軟件和硬件加速渲染做一些分析和對比。

DisplayList

DisplayList是一個基本繪制元素,包含元素原始屬性(位置、尺寸、角度、透明度等),對應Canvas的drawXxx()方法(如下圖)。

信息傳遞流程:Canvas(Java API) —> OpenGL(C/C++ Lib) —> 驅動程序 —> GPU。

在Android 4.1及以上版本,DisplayList支持屬性,如果View的一些屬性發生變化(比如Scale、Alpha、Translate),只需把屬性更新給GPU,不需要生成新的DisplayList。

RenderNode

一個RenderNode包含若干個DisplayList,通常一個RenderNode對應一個View,包含View自身及其子View的所有DisplayList。 

 

 

 

Android繪制流程(Android 6.0)

下面是安卓View完整的繪制流程圖,主要通過閱讀源碼和調試得出,虛線箭頭表示遞歸調用。

  • 從ViewRootImpl.performTraversals到PhoneWindow.DecroView.drawChild是每次遍歷View樹的固定流程,首先根據標志位判斷是否需要重新布局并執行布局;然后進行Canvas的創建等操作開始繪制。
    • 如果硬件加速不支持或者被關閉,則使用軟件繪制,生成的Canvas即Canvas.class的對象;
    • 如果支持硬件加速,則生成的是DisplayListCanvas.class的對象;
    • 兩者的isHardwareAccelerated()方法返回的值分別為false、true,View根據這個值判斷是否使用硬件加速。
  • View中的draw(canvas,parent,drawingTime) - draw(canvas) - onDraw - dispachDraw - drawChild這條遞歸路徑(下文簡稱Draw路徑),調用了Canvas.drawXxx()方法,在軟件渲染時用于實際繪制;在硬件加速時,用于構建DisplayList。
  • View中的updateDisplayListIfDirty - dispatchGetDisplayList - recreateChildDisplayList這條遞歸路徑(下文簡稱DisplayList路徑),僅在硬件加速時會經過,用于在遍歷View樹繪制的過程中更新DisplayList屬性,并快速跳過不需要重建DisplayList的View。

Android 6.0中,和DisplayList相關的API目前仍被標記為“@hide”不可訪問,表示還不成熟,后續版本可能開放。

  • 硬件加速情況下,draw流程執行結束后DisplayList構建完成,然后通過ThreadedRenderer.nSyncAndDrawFrame()利用GPU繪制DisplayList到屏幕上。 

 

 

 

 

 

 

 

純軟件繪制 VS 硬件加速(Android 6.0)

下面根據具體的幾種場景,具體分析一下硬件加速前后的流程與加速效果。 

 

 

 

  • 場景1中,無論是否加速,遍歷View樹并都會走Draw路徑。硬件加速后Draw路徑不做實際繪制工作,只是構建DisplayList,復雜的繪制計算任務被GPU分擔,已經有了較大的加速效果。
  • 場景2中,TextView設置前后尺寸位置不變,不會觸發重新Layout。
    • 軟件繪制時,TextView所在區域即為臟區。由于TextView有透明區域,遍歷View樹的過程中,和臟區重疊的多數View都要重繪,包括與之重疊的兄弟節點和他們的父節點(詳見后面的介紹),不需要繪制的View在draw(canvas,parent,drawingTime)方法中判斷直接返回。
    • 硬件加速后,也需要遍歷View樹,但只有TextView及其每一層父節點需要重建DisplayList,走的是Draw路徑,其他View直接走了DisplayList路徑,剩下的工作都交給GPU處理。頁面越復雜,兩者性能差距越明顯。
  • 場景3中,軟件繪制每一幀都要做大量繪制工作,很容易導致動畫卡頓。硬件加速后,動畫過程直接走DisplayList路徑更新DisplayList的屬性,動畫流暢度能得到極大提高。
  • 場景4中,兩者的性能差距更明顯。簡單修改透明度,軟件繪制仍然要做很多工作;硬件加速后一般直接更新RenderNode的屬性,不需要觸發invalidate,也不會遍歷View樹(除了少數View可能要對Alpha做特殊響應并在onSetAlpha()返回true,代碼如下)。
  1. public class View {    // ... 
  2.     public void setAlpha(@FloatRange(from=0.0, to=1.0) float alpha) { 
  3.         ensureTransformationInfo();        if (mTransformationInfo.mAlpha != alpha) { 
  4.             mTransformationInfo.mAlpha = alpha;            if (onSetAlpha((int) (alpha * 255))) {                // ... 
  5.                 invalidate(true); 
  6.             } else {                // ... 
  7.                 mRenderNode.setAlpha(getFinalAlpha());                // ... 
  8.             } 
  9.         } 
  10.     }    protected boolean onSetAlpha(int alpha) {        return false
  11.     }    // ...} 

軟件繪制刷新邏輯簡介

實際閱讀源碼并實驗,得出通常情況下的軟件繪制刷新邏輯:

  • 默認情況下,View的clipChildren屬性為true,即每個View繪制區域不能超出其父View的范圍。如果設置一個頁面根布局的clipChildren屬性為false,則子View可以超出父View的繪制區域。
  • 當一個View觸發invalidate,且沒有播放動畫、沒有觸發layout的情況下:
    • clipChildren為true時,臟區會被轉換成ViewRoot中的Rect,刷新時層層向下判斷,當View與臟區有重疊則重繪。如果一個View超出父View范圍且與臟區重疊,但其父View不與臟區重疊,這個子View不會重繪。
    • clipChildren為false時,ViewGroup.invalidateChildInParent()中會把臟區擴大到自身整個區域,于是與這個區域重疊的所有View都會重繪。
    • 對于全不透明的View,其自身會設置標志位PFLAG_DIRTY,其父View會設置標志位PFLAG_DIRTY_OPAQUE。在draw(canvas)方法中,只有這個View自身重繪。
    • 對于可能有透明區域的View,其自身和父View都會設置標志位PFLAG_DIRTY。

總結

至此,硬件加速相關的內容就介紹完了,這里做個簡單總結:

  • CPU更擅長復雜邏輯控制,而GPU得益于大量ALU和并行結構設計,更擅長數學運算。
  • 頁面由各種基礎元素(DisplayList)構成,渲染時需要進行大量浮點運算。
  • 硬件加速條件下,CPU用于控制復雜繪制邏輯、構建或更新DisplayList;GPU用于完成圖形計算、渲染DisplayList。
  • 硬件加速條件下,刷新界面尤其是播放動畫時,CPU只重建或更新必要的DisplayList,進一步提高渲染效率。
  • 實現同樣效果,應盡量使用更簡單的DisplayList,從而達到更好的性能(Shape代替Bitmap等)。

參考資料與擴展閱讀

責任編輯:龐桂玉 來源: Android技術之家
相關推薦

2009-12-23 13:55:44

WPF硬件加速

2011-11-16 10:35:28

Android 4.0圖形硬件加速繪制技巧

2017-12-25 14:29:31

NFV硬加速運營商

2010-06-24 10:59:11

Bzip2算法

2010-07-20 16:01:44

GPU硬件加速瀏覽器

2010-10-08 09:18:06

Ubuntu 10.1GPU硬件加速

2010-01-27 09:17:43

Office 2010GUP加速

2017-08-07 18:20:14

Windows 7WindowsCPU

2011-05-04 09:23:19

Android 3.1硬件加速FlashPlayer

2020-07-08 08:30:28

Windows操作系統功能

2011-07-14 09:30:47

HTML 5Windows PhoMango

2021-01-12 09:00:17

FirefoxLinux開發者

2010-05-19 11:17:24

Office 2010

2010-09-16 11:09:34

IE 9 Beta評測

2020-07-08 17:24:10

Windows 10GPU硬件

2011-03-16 17:12:46

IE9GPU

2012-07-24 14:30:58

Windows 8操作系統

2023-05-10 14:57:13

UbuntuChromium

2022-08-03 08:00:00

機器人硬件開發

2022-06-15 16:06:29

LZ4 算法硬件加速
點贊
收藏

51CTO技術棧公眾號

99国产精品久久久久久久久久 | 欧美一卡2卡3卡4卡| 一区二区三区av| 性猛交xxxx乱大交孕妇印度| 午夜影院日韩| 欧美成人中文字幕| 国产色视频一区二区三区qq号| 欧美一级免费| 欧美日韩在线视频一区二区| 黄色网址在线免费看| 午夜视频免费在线| 韩国理伦片一区二区三区在线播放 | 中文字幕视频观看| 国产精品毛片久久久久久久久久99999999 | 香蕉久久国产| 欧美精品少妇videofree| 四虎永久免费在线观看| 日韩精品一区二区三区中文字幕 | 一区二区三区日韩在线观看| 欧洲久久久久久| 免费看日韩av| 激情久久五月天| 日本最新高清不卡中文字幕| wwwav国产| 日韩精品二区| 国产丝袜一区视频在线观看| 亚洲国产精品第一页| 在线观看亚洲精品福利片| 色先锋aa成人| 国产视频一视频二| 国产白丝在线观看| 亚洲欧美日韩中文字幕一区二区三区 | 伊人国产精品视频| 国产一区二区主播在线| 高跟丝袜一区二区三区| 国产九色porny| av网站网址在线观看| 亚洲欧洲一区二区三区| 视频一区二区在线| 久久久久国产精品嫩草影院| 99热精品一区二区| 国产欧美日韩亚洲| 高清毛片aaaaaaaaa片| 国产乱码一区二区三区| 91在线视频一区| 97人妻一区二区精品免费视频 | 国产欧美婷婷中文| 久久久久久久亚洲| 蜜臀久久99精品久久久久宅男| 啪一啪鲁一鲁2019在线视频| 黄色片免费观看视频| 999在线观看精品免费不卡网站| 欧美激情国产高清| 国产午夜精品无码| 亚洲麻豆av| 2019亚洲男人天堂| 六月丁香激情综合| 丝袜诱惑制服诱惑色一区在线观看| 日本一本a高清免费不卡| 久久久精品视频网站| 天堂久久一区二区三区| 国产精品xxx视频| 自拍偷拍精品视频| 美腿丝袜亚洲综合| 91色p视频在线| 亚洲AV无码国产精品午夜字幕| 成人免费三级在线| 鲁丝片一区二区三区| 免费动漫网站在线观看| 国产精品女主播在线观看| 黄瓜视频免费观看在线观看www| 国产精品扒开做爽爽爽的视频| 亚洲乱码中文字幕| 2018国产在线| 免费在线观看一区| www.桃色av嫩草.com| 91蜜臀精品国产自偷在线 | 99精品全国免费观看| 91欧美国产| 欧美激情视频网站| 一级成人黄色片| 另类人妖一区二区av| 99免费在线视频观看| 青青青手机在线视频观看| 中文字幕免费观看一区| 特级黄色录像片| 美女视频在线免费| 欧美日韩久久一区二区| 日本wwww色| 欧美码中文字幕在线| 欧美老少做受xxxx高潮| 精品欧美一区二区三区免费观看 | 熟妇高潮一区二区| 国产一区二区欧美| 九色精品免费永久在线| 日本视频在线观看免费| 国产精品综合一区二区| 欧美三级网色| 男插女视频久久久| 在线观看亚洲成人| 岛国av免费观看| 色狮一区二区三区四区视频| 久久久亚洲影院| 一个人看的www日本高清视频| 成人av电影在线播放| 亚洲一二三区在线| 依依综合在线| 亚洲第一视频网站| 亚洲 欧美 国产 另类| 国产精品亚洲欧美| 亚洲永久在线观看| √天堂资源地址在线官网| 亚洲成人午夜电影| 在线一区二区不卡| 国内精品久久久久久久久电影网| 欧美激情第6页| 97人妻精品一区二区三区视频 | 麻豆中文字幕在线观看| 欧美aa免费在线| 欧美成人综合网站| 久久久久麻豆v国产| 国产模特精品视频久久久久| 国产成人精品免费视频大全最热 | 亚洲视频分类| 久久久久这里只有精品| www.黄色av| 亚洲蜜臀av乱码久久精品蜜桃| 欧美两根一起进3p做受视频| 高潮久久久久久久久久久久久久 | 在线不卡视频一区二区| 日韩在线影院| 亚洲欧美激情一区| 国产无人区码熟妇毛片多| 成人爱爱电影网址| 日韩欧美国产综合在线| 白嫩白嫩国产精品| 欧美激情在线狂野欧美精品| 亚洲老妇色熟女老太| 亚洲精品一二三四区| 亚洲天堂网站在线| 亚洲精品国产偷自在线观看| 国产一区二区丝袜高跟鞋图片| 成人18在线| 欧洲av在线精品| 国产精品无码无卡无需播放器| 久久午夜精品一区二区| 欧美日韩亚洲在线| 日韩精品麻豆| 色综合伊人色综合网站| 一区二区视频播放| 综合在线观看色| 在线观看免费视频污| 亚洲激情五月| 国产精品一区二区三区在线| 人在线成免费视频| 亚洲欧美制服第一页| 日韩一级片中文字幕| 欧美激情一区二区三区不卡| 天天操狠狠操夜夜操| 91麻豆国产自产在线观看亚洲| 成人性生交大片免费观看嘿嘿视频 | 2020国产精品| 能在线观看的av网站| 久久大综合网| 91一区二区三区| 成人在线黄色电影| 亚洲欧美成人网| 影音先锋国产资源| 亚洲女同ⅹxx女同tv| 国产伦精品一区二区三区精品| 亚洲在线一区| 亚洲 国产 日韩 综合一区| 国产亚洲精彩久久| 欧美日本亚洲视频| 青青免费在线视频| 91麻豆精品91久久久久久清纯| 久久久精品视频在线 | 欧美特黄一级片| 粉嫩绯色av一区二区在线观看| 自慰无码一区二区三区| 精品久久久久久久久久久aⅴ| 91情侣偷在线精品国产| 国产社区精品视频| 少妇高潮久久77777| www.久久综合| 日韩欧美国产网站| 婷婷伊人五月天| 91免费观看在线| 亚洲综合激情视频| 中日韩视频在线观看| 亚洲a∨一区二区三区| 一区二区三区在线资源| 国产精品国产福利国产秒拍 | 欧洲亚洲妇女av| www视频在线免费观看 | 毛片av在线| 亚洲国产日韩欧美在线99| 樱花视频在线免费观看| 亚洲国产精品一区二区www在线 | 天天干天天操av| 欧美日韩黄色一区二区| 永久免费看片在线播放| 亚洲色图在线看| 无码人妻精品一区二区中文| 国产电影一区在线| 亚洲一二三区av| 亚洲美女黄色| 老汉色影院首页| 禁断一区二区三区在线| 国产精品视频免费观看| 欧美视频在线视频精品| 日本午夜在线亚洲.国产| 日本孕妇大胆孕交无码| 精品国产一区二区三区在线观看| 午夜在线视频观看| 日韩欧美一级二级三级| 中文字幕一二区| 色婷婷国产精品综合在线观看| 国产主播在线观看| 亚洲蜜桃精久久久久久久| 欧洲性xxxx| 欧美极品少妇xxxxⅹ高跟鞋 | 亚洲综合999| 日韩精品一区二区亚洲av性色| 国产欧美一区二区在线观看| 午夜一区二区三区免费| 成人免费黄色在线| 91av免费观看| 国产精品一区二区久久不卡 | 哺乳挤奶一区二区三区免费看| 国产色综合天天综合网| 成人影院在线免费观看| 日本老师69xxx| 性欧美又大又长又硬| 久久免费精品日本久久中文字幕| av理论在线观看| 欧美成人午夜剧场免费观看| 久久久久久久久免费视频| 丝袜亚洲另类欧美重口| 自拍视频在线| 精品国产一区二区三区久久狼5月| 在线激情小视频| 在线观看国产成人av片| av网站在线免费播放| 一区二区欧美在线| av网站无病毒在线| 日韩最新av在线| 在线视频三区| 久久精品国产久精国产一老狼| 九七电影韩国女主播在线观看| 久久这里有精品| av片在线观看网站| 久久久久久亚洲| 午夜欧美激情| 国产精品福利小视频| 99久久综合国产精品二区| 国产欧美一区二区三区视频 | 极品日韩久久| 美女亚洲一区| 新呦u视频一区二区| 91精品精品| 精品人妻少妇一区二区| 久久精品日韩欧美| 天堂社区在线视频| 精品一区二区三区在线播放| 北条麻妃亚洲一区| 99久久伊人精品| 90岁老太婆乱淫| 综合在线观看色| 日本一区二区免费在线观看| 日韩欧美在线免费| 11024精品一区二区三区日韩| 91精品国产色综合久久不卡电影| 亚洲精品97久久中文字幕无码| 日韩成人在线视频网站| 在线播放麻豆| 久久久这里只有精品视频| 深夜成人影院| 97人人干人人| 国产一区二区三区电影在线观看| 最新不卡av| 国产精品久久777777毛茸茸 | 国产91精品露脸国语对白| 国产麻豆天美果冻无码视频| 欧美激情中文不卡| 久久网中文字幕| 在线精品视频一区二区三四 | 成人精品在线视频观看| 波多野吉衣中文字幕| 亚洲人亚洲人成电影网站色| 日本午夜视频在线观看| 欧美日韩久久一区| 性高潮久久久久久久久久| 日韩在线观看免费av| 国产乱码午夜在线视频 | 在线免费观看av片| 亚洲高清久久久久久| 老司机免费在线视频| 4438全国亚洲精品在线观看视频| 色999久久久精品人人澡69| 精品国产一区二区三区麻豆免费观看完整版| 国内黄色精品| 好吊妞无缓冲视频观看| 国产精品综合二区| 欧美三级视频网站| 精品国产成人av| 国产a级免费视频| 中文日韩在线视频| 午夜裸体女人视频网站在线观看| 亚洲sss综合天堂久久| 成人免费在线播放| 女人天堂av手机在线| 国产传媒欧美日韩成人| 老司机精品免费视频| 色综合色狠狠综合色| 成人毛片视频免费看| 欧美成年人在线观看| 欧美a视频在线| 日韩中文字幕一区| 久久高清一区| 午夜一区二区三区免费| 亚洲成人自拍一区| 丰满肉嫩西川结衣av| 久久国产精品电影| 777午夜精品电影免费看| 你懂的网址一区二区三区| 亚洲精品乱码| 亚洲熟女一区二区| 亚洲最新在线观看| 亚洲经典一区二区三区| 欧美激情国内偷拍| 77成人影视| 精品国产一区二区三区无码| 国产成人精品免费一区二区| 农村妇女精品一区二区| 日韩一二三区视频| av电影高清在线观看| 亚洲已满18点击进入在线看片| 亚洲精品97| 欧美成人精品一区二区综合免费| 亚洲精品成人少妇| 亚洲AV无码精品自拍| 欧美激情综合色综合啪啪五月| 日韩欧美中文在线观看| 国产成人亚洲综合无码| 成人免费视频app| 日日夜夜综合网| 亚洲欧美精品一区二区| 欧美人与性动交xxⅹxx| 欧洲亚洲一区二区| 蜜桃av噜噜一区| 久久嫩草捆绑紧缚| 日韩一级成人av| 岛国av在线播放| 免费中文日韩| 蜜桃av一区二区在线观看| 制服丨自拍丨欧美丨动漫丨| 欧美一区二区视频在线观看| 天堂成人av| 久久久久久草| 奇米影视一区二区三区| h色网站在线观看| 精品久久久久一区| 在线人成日本视频| 图片区小说区区亚洲五月| 激情成人午夜视频| 久久草视频在线| 国产亚洲欧洲在线| 久久视频免费| 免费无码不卡视频在线观看| 中文字幕va一区二区三区| 国产又粗又猛又爽又黄的| 欧美精品国产精品日韩精品| 中国av一区| 黄色a级三级三级三级| 精品久久久精品| 婷婷视频在线| 精品一区二区三区视频日产| 国产亚洲天堂网| 中文字幕久久精品一区二区| 日韩精品一区二区免费| 国产亚洲精品久| 性一交一乱一乱一视频| 情事1991在线| 91精品国产成人观看| 男女黄床上色视频| 欧美精品国产精品| 国产高清自产拍av在线| 亚洲一区三区视频在线观看 | 久久大逼视频| 国产美女免费网站| 日韩一区二区三区视频| 中文av在线全新| 蜜臀av.com| 久久久久久一级片| www.xxxx国产| 国产精品视频资源| 亚洲福利一区| 91香蕉视频网| 国产婷婷成人久久av免费高清 |