《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > UEFI驅動程序的研究與開發
UEFI驅動程序的研究與開發
來源:電子技術應用2014年第5期
韓德強,馬 駿,張 強
(北京工業大學 計算機學院,北京100124)
摘要: UEFI是Intel推出的新一代BIOS技術。在分析UEFI基本結構和驅動程序模型的基礎上,詳細論述了基于USB協議棧的CC2531 ZigBee模塊的設備驅動程序設計與開發過程,實現了在操作系統啟動之前主機與USB設備間的信息交互,擴展了UEFI的功能。
中圖分類號: TP393
文獻標識碼: A
文章編號: 0258-7998(2014)05-0010-04
Research and development of UEFI driver
Han Deqiang,Ma Jun,Zhang Qiang
College of Computer,Beijing University of Technology,Beijing 100124,China
Abstract: UEFI sponsored by Intel is the new generation of BIOS technology. Based on the analysis of the basic structures of UEFI and driver model, the paper describes the detailed development process of CC2531 ZigBee module driver based on USB stack. This driver will implement the information interaction between host and USB devices in pre-OS, and expand the function of UEFI.
Key words : UEFI BIOS;CC2531;device driver

    統一可擴展固件接口UEFI(Unified Extensible Firmware Interface)是Intel推出的新一代BIOS技術,旨在定義一套操作系統與平臺固件之間完整的接口規范,為操作系統的引導提供標準環境[1]。相比于使用匯編語言編寫的傳統BIOS,UEFI采用模塊化的設計、C語言風格的參數堆棧傳遞方式,借由動態鏈接的形式所構建出來的系統,更易于實現[2]。同時,UEFI是以32 bit或64 bit CPU保護模式運行,突破了傳統16 bit實模式代碼的尋址能力,可達到CPU的最大尋址空間。得益于這些優點,UEFI經過近10年的推廣,已經成為主流,將使用傳統BIOS的微型計算機系統逐漸淘汰出市場[3]。
    UEFI中引入了UEFI驅動程序模型的概念,采用驅動/協議的結構開發驅動程序,驅動程序和硬件完全獨立,具有很強的擴展性,從而使得UEFI平臺下添加新的特性變得簡單[4]。
1 UEFI基本結構分析
    UEFI主要由引導管理器、固件內核、協議、驅動模型等組件構成[4]。其中固件內核為UEFI的基礎,它將底層硬件功能抽象化,為上層的引導管理器提供兩種服務:引導服務和運行時服務。引導管理器是一個策略引擎,它使用固件內核提供的服務加載UEFI驅動程序和應用程序,并最終加載操作系統。
    圖1所示為UEFI的系統框架圖。固件內核運行在PEI和DXE階段,UEFI在PEI階段直接與硬件層打交道,啟動必需的硬件資源,譬如完成CPU和芯片組的初始化,進而滿足DXE的執行啟動條件;其后,系統在DXE階段完成其他所有硬件的初始化,并為上層接口實現引導服務和運行時服務。引導管理器運行在DXE和BDS階段,它通過加載框架驅動和平臺驅動向上層提供UEFI服務和接口,通過加載應用程序擴展系統功能,并在BDS階段提供一個引導菜單,供用戶選擇引導設備。最終引導加載器在ROM上加載操作系統加載器,將控制權移交給操作系統,完成操作系統的引導。

2 CC2531 ZigBee模塊的設備驅動程序開發
    CC2531是TI公司推出的一款用于IEEE 802.15.4或ZigBee應用的片上系統解決方案,它能夠以非常低的成本建立網絡節點,支持低功耗的無線通信,主要用于遠程控制、家庭控制等領域[5]。CC2531集成了USB2.0功能模塊,可以更加方便地與主機進行通信。
    本文將CC2531 ZigBee模塊(以下簡稱CC2531模塊)通過USB接口與無線POS機的主機相連,CC2531模塊通過ZigBee無線網絡與POS機的外設(如打印機、客顯、鍵盤等)進行信息交互。此方案實現了在啟動操作系統之前對POS機及其外設進行相應遠程檢測和診斷的功能。圖2為無線POS機系統的結構框圖。
2.1 UEFI驅動程序模型分析
2.1.1 句柄和協議

    UEFI驅動程序模型使用句柄代表設備,每個設備對應有自己的句柄,句柄由一個或多個協議組成。協議是一個以128 bit的全局唯一標識符GUID(Globally Unique Identifier)命名的結構體,是一些指針和數據結構體或者規范定義的接口函數指針的集合,協議代表設備提供的一類服務,服務的具體功能在設備驅動程序(以下簡稱驅動)中實現。開發者首先找到指定設備句柄上掛載的指定協議,再通過協議提供的接口訪問設備驅動中實現服務的功能函數,對設備進行操作。圖3所示為設備句柄和協議的結構圖。

2.1.2 驅動程序模型執行流程
    UEFI驅動程序模型是一種用于簡化設備驅動設計和執行的機制,遵循驅動程序模型規范的UEFI驅動的可執行鏡像大小會得到有效的減小[6]。UEFI驅動程序模型的執行流程圖如圖4所示。

    驅動程序模型采用UEFI 驅動載入、連接的形式來進行硬件的辨識、控制及系統資源掌控。在DXE階段,系統調用引導服務的LoadImage()函數將驅動鏡像文件加載到內存中,調用StartImage()函數執行驅動的入口函數來啟動驅動。遵循模型規范的設備驅動在入口函數的初始化中不涉及任何硬件操作,僅僅實現驅動綁定協議(Driver Binding Protocol),協議包含3個接口函數:Support()、Start()和Stop()。Support()函數用來驗證驅動程序與給定的設備句柄是否匹配;Start()函數負責驅動與句柄的連接,即將抽象 I/O 功能的協議安裝到設備句柄上;相對應的,Stop()函數則會強制停止驅動對一個設備句柄的管理和控制,并卸載設備句柄在Start()中安裝的所有協議。
    DXE階段執行完成后,雖然加載和啟動了驅動,但還在等待著連接設備句柄。因此,在BDS階段引導管理器將會調用引導服務的ConnectController()函數執行驅動的連接過程。該函數執行所有驅動綁定協議的Support()進行設備句柄的驗證,若驗證正確,則會繼續調用Start()連接驅動和設備句柄,并在設備句柄上安裝抽象I/O功能的協議。
2.2 CC2531模塊USB驅動協議棧
    圖5所示是由一系列驅動組成的多層次的、完整的 USB 驅動協議棧。處于上層的驅動會使用下層驅動提供的服務,并為更高層的驅動提供服務。首先,PCI總線驅動枚舉設備時發現USB主機控制器,并在控制器句柄上安裝EFI_PCI_IO_PROTOCOL協議,USB主機控制器驅動則使用EFI_PCI_IO_PROTOCOL協議提供的接口實現EFI_USB_HC_PROTOCOL協議。然后,USB總線驅動使用EFI_USB_HC_PROTOCOL協議服務實現對USB設備的枚舉,生成CC2531設備句柄,并在設備句柄上安裝 EFI_USB_IO_PROTOCOL協議。最后,CC2531模塊設備驅動使用EFI_USB_IO_PROTOCOL協議服務,在CC2531模塊設備句柄上安裝EFI_USB_CCCONTROL_PROTOCOL協議,完成CC2531模塊驅動協議棧的加載。

2.3 CC2531模塊驅動程序設計
    CC2531模塊驅動作為設備驅動,遵循UEFI驅動程序模型規范,使用驅動綁定協議的方式實現設備驅動的加載和連接。同時,驅動還提供通信協議EFI_USB_CCCONTROL_PROTOCOL用于系統與CC2531模塊間的通信,并通過ZigBee網絡與無線POS機外設進行通信。
2.3.1 綁定協議接口函數的實現

 


    (1)Support():圖6所示為Support函數實現流程圖,函數首先檢查給定的目標設備句柄是否安裝有 EFI_USB_IO_PROTOCOL協議,若有,則說明USB總線驅動已經辨認出該USB設備。其次,使用EFI_USB_IO_PROTOCOL協議提供的功能接口函數獲取目標USB設備的設備描述符,描述符中的接口號、接口類型、子類型和協議等字段指定了的USB設備的類型,檢查這些字段就可得知驅動是否為CC2531模塊設備驅動,如果匹配則說明加載的驅動正確,就會執行Start()函數。以下是部分實現代碼:

    EFI_STATUS USBCC2531DriverBindingSupported(…)
    {…
    //檢查目標設備句柄是否安裝有USB_IO協議
        Status = gBS->OpenProtocol (Controller,
&gEfiUsbIoProtocolGuid,
    (VOID **) &UsbIo, This->DriverBindingHandle,
    Controller, EFI_OPEN_PROTOCOL_BY_DRIVER );
    …
    //讀出目標USB設備的設備描述符
    Status = UsbIo->UsbGetInterfaceDescriptor (
            UsbIo, &InterfaceDescriptor);
    //檢查是否為USB-CC2531的驅動
    if(InterfaceDescriptor.InterfaceNumber==1
    &&InterfaceDescriptor.InterfaceClass ==0x0a
    && InterfaceDescriptor.InterfaceSubClass==0
    && InterfaceDescriptor.InterfaceProtocol == 0 ) { … }
    //關閉USB_IO協議
        gBS->CloseProtocol (…);
        return Status;
    }
    (2)Start():Start()函數的目標是使用USB總線驅動提供的協議服務在CC2531模塊設備驅動中安裝通信協議EFI_USB_CCCONTROL_PROTOCOL。函數首先打開設備句柄上掛載的EFI_USB_IO_PROTOCOL協議,使用該協議提供的接口函數UsbGetInterfaceDescriptor()和UsbGetEndpointDescriptor()得到USB設備的接口描述符和端點描述符,分析設備描述符中的字段以確定USB設備信息和接口類型等參數。其次,為驅動私有數據結構體分配內存,并使用設備描述符中的字段信息進行初始化。最后,安裝EFI_USB_CCCONTROL_PROTOCOL協議,完成驅動與設備的連接。圖7所示為Start()函數實現流程圖。
    (3)Stop():Stop()是Start執行流程的逆過程,該函數用于卸載EFI_USB_CCCONTROL_PROTOCOL協議,釋放驅動私有數據結構體占用的內存資源,關閉EFI_USB_IO_PROTOCOL協議,斷開CC2531模塊驅動與設備句柄的連接。

2.3.2 設備通信協議結構體
    為了實現UEFI系統與CC2531模塊之間的數據通信,本文設計了EFI_USB_CCCONTROL_PROTOCOL作為驅動的通信協議。該協議中包括了UEFI系統與CC2531模塊間數據發送和接收的接口函數,還有部分與POS機系統外設交互的命令函數,如系統外設啟動和復位命令的接口函數。協議的部分成員函數定義如下:
struct _EFI_USB_CCCONTROL_PROTOCOL {…
    EFI_USB_CONTROLL_RESET Reset;//復位設備
    EFI_USB_TEXTOUTPUT_STRING OutputString;
//數據發送
    EFI_USBINPUT_STRING    ReadInput;  //數據讀取
    EFI_USB_DETECTDEVICE    DetectDevice;
//設備啟動命令
    EFI_EVENT WaitForInputString;//等待讀入事件
    };
2.3.3 設備通信協議接口函數的實現
    CC2531 模塊的USB接口固件代碼是基于USB通信設備類CDC(Communication Device Class)協議實現的。CDC由通信接口類和數據接口類組成,通信接口類主要負責設備的管理和控制,數據接口類則負責數據的傳輸。CC2531模塊的USB接口采用端點0作為通信接口類中的控制端點來管理設備的枚舉和命令控制,數據接口類使用塊傳輸輸入(IN)端點和塊傳輸輸出(OUT)端點實現數據的雙向傳輸。因此,UEFI系統對CC2531模塊的枚舉和識別采用控制傳輸方式,數據通信則采用批量傳輸方式。
    協議的發送接口函數為UsbCCDataTransmit(),該函數調用EFI_USB_IO_PROTOCOL協議提供的服務函數UsbBulkTransfer(),通過將數據寫入輸出端口完成數據從主機到CC2531模塊的批量傳輸。設備驅動發送數據接口函數的部分代碼實現如下所示:
    EFI_STATUS UsbCCDataTransmit (…)
    { …
    //選擇發送數據的輸出端口
    Endpoint=UsbCC2531Device->BulkOutEndpointDescriptor;
    //等待發送或接收的超時時間
    Timeout = Timeout / USB_MASS_1_MILLISECOND;
        //發送數據
        Status=UsbCC2531Device->UsbIo->UsbBulkTransfer (
        UsbCC2531Device->UsbIo, Endpoint.EndpointAddress,
Data, TransLen, Timeout, &Result);
        if (EFI_ERROR (Status)) { …}
        return Status;
    }
    CC2531模塊設備驅動的數據接收操作亦通過調用函數UsbBulkTransfer()檢測輸入端口的緩沖隊列完成。由于數據接收操作的被動性,驅動需要建立一套讀操作的響應觸發機制。本方案使用UEFI的事件(EVENT)機制實現對數據接收操作的響應:首先在驅動的Start()創建一個定時器事件,并在定時器的響應函數USBCC2531Timer-
Handler()中周期性調用UsbCCDataRecevice()執行對輸入端口緩沖隊列的讀操作,如果成功讀到數據,則將讀回的數據存入私有數據結構體的循環隊列UsbDataQueue中。其次,創建一個等待事件WaitForInputString,并在等待事件的觸發函數中檢查循環隊列,如有數據則讀取,否則循環等待。部分數據讀取操作的代碼如下:
    EFI_STATUS UsbCCDataRecevice ( …)
    { …
        Status=UsbCC2531Device->UsbIo->UsbBulkTransfer (…);
        if (EFI_ERROR (Status)) {  …  }
        else {
            //將讀取的數據存入鏈表
            Enqueue (UsbCC2531Device->UsbDataQueue,
Data,MaxItemSize);
                }
        return Status;
    }
    UEFI采用的模塊化設計和驅動程序模型都為整體系統提供了良好的兼容性和擴展性,簡化了UEFI驅動和應用程序的開發難度,提高了可維護性,有助于計算機固件的進一步發展。相對于傳統BIOS,UEFI具有明顯的優越性,越來越得到業界和市場的認可。本文從UEFI功能擴展的角度考慮,分析了UEFI的架構和驅動程序模型,設計并實現了CC2531模塊的設備驅動程序,最終實現了在啟動操作系統之前通過CC2531模塊與無線POS機外設進行通信的目標。本方案的下一目標是擴展UEFI下的網絡應用,實現對POS機系統的遠程管理和診斷。
參考文獻
[1] Unified EFI,Inc.Unified extensible firmware interface specification[S].Version2.3.1 Errata C.2012:1-22.
[2] 朱賀新.基于UEFI的可信BIOS平臺研究與應用[D].西安:西安科技大學,2008:11-15.
[3] 萬象.基于UEFI系統的LINUX通用應用平臺的設計與實現[D].上海:上海交通大學,2012.
[4] 潘登,劉光明.EFI結構分析及Driver開發[J].計算機工程與科學,2006,28(2):115-117.
[5] Texas Instruments.CC2531 SOC solution for IEEE 802.15.4 and ZigBee applications(Rev.A)[Z].2011.
[6] ZIMMER V,ROTHMAN M,MARISETTY S.Beyond BIOS:developing with the unified extensible firmware interface(2  Edition)[M].Intel Press,2010.

此內容為AET網站原創,未經授權禁止轉載。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          亚洲欧美成aⅴ人在线观看| 欧美日韩福利在线观看| 欧美日韩国产综合一区二区| 国产精品海角社区在线观看| 99视频在线精品国自产拍免费观看| 久久午夜色播影院免费高清| 欧美日韩ab片| 亚洲乱码国产乱码精品精可以看| 激情小说另类小说亚洲欧美| 国产一区二区激情| 久久三级福利| 欧美不卡一卡二卡免费版| 欧美日韩精品欧美日韩精品一| 欧美二区在线| 亚洲小说欧美另类社区| 欧美日韩亚洲一区二区三区四区| 欧美日韩dvd在线观看| 91久久精品www人人做人人爽| 日韩一区二区精品在线观看| 亚洲一品av免费观看| 国产精品毛片在线看| 久久久999精品| 日韩午夜电影av| 亚洲国产一二三| 美日韩精品免费观看视频| 欧美在线视频不卡| 欧美日韩国产影片| 国产综合在线视频| 韩国av一区二区三区在线观看| 99国产精品国产精品久久| 久久久久久久久久久久久女国产乱| 国产视频一区在线观看一区免费| 国产精品国产成人国产三级| 激情婷婷欧美| 一区二区亚洲欧洲国产日韩| 欧美深夜福利| 欧美刺激午夜性久久久久久久| 欧美日韩免费一区二区三区视频| 国产午夜久久久久| 伊人成人在线视频| 一区二区三区久久网| 国产一区二区在线观看免费播放| 亚洲影院污污.| 亚洲欧美国产视频| 麻豆精品一区二区av白丝在线| 亚洲精品乱码久久久久久久久| 久久久久久久一区| 国产亚洲欧洲997久久综合| 一本大道久久a久久综合婷婷| 亚洲性感美女99在线| 亚洲国产日韩欧美| 久久久国产成人精品| 在线观看成人一级片| 中文无字幕一区二区三区| 亚洲欧洲免费视频| 欧美v国产在线一区二区三区| 香蕉免费一区二区三区在线观看| 国产精品三级视频| 欧美视频日韩视频| 1000精品久久久久久久久| 狠狠色伊人亚洲综合网站色| 国外成人性视频| 国产亚洲精品v| 欧美日韩专区| 国产一区二区丝袜高跟鞋图片| 国产美女精品人人做人人爽| 欧美三级第一页| 在线视频你懂得一区二区三区| 日韩一区二区精品葵司在线| 香蕉成人久久| 国产视频精品va久久久久久| 欧美精品久久99久久在免费线| 国产精品素人视频| 欧美一区二区在线视频| 9国产精品视频| 久久久久国产一区二区三区| 欧美大片专区| 久久视频国产精品免费视频在线| 欧美香蕉大胸在线视频观看| 亚洲男人的天堂在线观看| 国产精品白丝黑袜喷水久久久| 欧美日韩免费观看一区| 欧美成人午夜剧场免费观看| 欧美日韩综合视频网址| 亚洲国产精品一区二区第四页av| 一本大道av伊人久久综合| 午夜免费电影一区在线观看| 国产一区二区三区四区在线观看| 国产精品久久久久aaaa樱花| 香蕉久久一区二区不卡无毒影院| 午夜免费日韩视频| 久久亚洲欧美| 亚洲欧洲一区二区在线播放| 国产精品丝袜xxxxxxx| 国内成+人亚洲+欧美+综合在线| 久久精品一级爱片| 欧美视频在线观看视频极品| 国产精品一二| 欧美精品午夜视频| 伊人伊人伊人久久| 国产欧美日韩三区| 日韩一区二区精品| 亚洲每日在线| 欧美日韩在线不卡| 欧美成人在线免费观看| 国产精品日产欧美久久久久| 欧美三日本三级少妇三2023| 黑人巨大精品欧美一区二区| 国产亚洲一区二区精品| 亚欧美中日韩视频| 国产欧美一区在线| 亚洲特黄一级片| 国产精品第2页| 亚洲黄网站在线观看| 亚洲人线精品午夜| 国产欧美一区二区精品忘忧草| 欧美电影免费观看大全| 午夜精品一区二区在线观看| 亚洲精品自在久久| 91久久一区二区| 亚洲视频福利| 久热精品视频在线观看一区| 欧美另类变人与禽xxxxx| 国语自产精品视频在线看一大j8| 一色屋精品视频在线观看网站| 国产亚洲激情视频在线| 欧美高清不卡| 亚洲一区二区三区乱码aⅴ蜜桃女| 老司机午夜精品视频在线观看| 午夜精品视频在线观看| 欧美日韩国产综合新一区| 国产精品v欧美精品v日本精品动漫| 在线观看国产精品网站| 欧美经典一区二区| 狠狠88综合久久久久综合网| 久久人人九九| 性欧美大战久久久久久久免费观看| 精品电影一区| 欧美一区二区三区视频| 国产日产精品一区二区三区四区的观看方式| 欧美一区二区三区播放老司机| 欧美一区二区成人| 一区二区三区久久精品| 国产欧美日韩专区发布| 欧美一区视频在线| 久久精品国产99国产精品澳门| 一区二区三区欧美视频| 男人插女人欧美| 在线国产精品播放| 亚洲精品久久久久中文字幕欢迎你| 亚洲三级国产| 国产欧美视频一区二区三区| 国产色婷婷国产综合在线理论片a| 一区二区亚洲| 亚洲国产成人tv| 国产精品日韩在线| 国产午夜亚洲精品不卡| 久久黄金**| 亚洲乱码国产乱码精品精| 国产日韩专区| 国产婷婷色综合av蜜臀av| 国产精品爽爽ⅴa在线观看| 国产日韩亚洲欧美精品| 国内精品一区二区三区| 国产精品视频| 亚洲大胆人体视频| 国产色综合网| 激情亚洲一区二区三区四区| 在线视频日本亚洲性| 欧美午夜a级限制福利片| 在线观看视频一区二区欧美日韩| 最新国产乱人伦偷精品免费网站| 黄网动漫久久久| 女女同性女同一区二区三区91| 国产婷婷97碰碰久久人人蜜臀| 亚洲福利视频一区| 欧美三级日韩三级国产三级| 久久成人综合视频| 亚洲高清不卡一区| 欧美系列一区| 亚洲综合日韩| 欧美一区二区大片| 国产又爽又黄的激情精品视频| 老司机免费视频一区二区三区| 久久国产欧美日韩精品| 免费久久精品视频| 亚洲欧洲视频在线| 久久综合色天天久久综合图片| 免费观看欧美在线视频的网站| 欧美日韩1区2区3区| 欧美国产1区2区| 久久亚洲一区二区| 亚洲欧洲精品一区二区精品久久久| 欧美国产成人在线| 欧美在线免费观看视频| 欧美在线观看视频一区二区三区| 一本一本久久a久久精品综合妖精| 一区二区三区国产精华| 亚洲免费福利视频| 一级日韩一区在线观看| 欧美日韩在线另类| 免费视频一区二区三区在线观看| 国产一区二区三区久久悠悠色av| 久久久人成影片一区二区三区观看| 亚洲黄网站黄| 欧美日韩中文精品| av成人老司机| 欧美日韩视频| 欧美顶级大胆免费视频| 欧美激情中文字幕乱码免费| 新狼窝色av性久久久久久| 99re8这里有精品热视频免费| 久久不见久久见免费视频1| 亚洲欧美日本伦理| 亚洲一区不卡| 99精品国产在热久久婷婷| 免费成人美女女| 欧美一区二区视频网站| 精品动漫一区| 欧美丰满高潮xxxx喷水动漫| 国产精品porn| 欧美性猛交99久久久久99按摩| 欧美午夜一区二区福利视频| 久久久国产午夜精品| 国产中文一区| 国产精品播放| 国产麻豆成人精品| 亚洲黄色片网站| 亚洲一区二区视频在线观看| 亚洲一区中文字幕在线观看| 国产精品成人va在线观看| 韩国一区二区三区美女美女秀| 欧美1区2区| 亚洲影视九九影院在线观看| 欧美日韩国产影片| 国产日韩在线播放| 欧美日韩综合在线免费观看| 免费高清在线视频一区·| 久久亚洲综合色一区二区三区| 亚洲电影免费观看高清完整版| 亚洲国产女人aaa毛片在线| 精品成人一区二区三区四区| 在线日韩中文| 亚洲成人直播| 欧美一区午夜视频在线观看| 欧美天堂亚洲电影院在线播放| 亚洲午夜电影在线观看| 欧美在线视频免费观看| 亚洲日本电影| 国产欧美日韩综合一区在线观看| 在线观看欧美视频| 韩国v欧美v日本v亚洲v| 欧美日韩国产成人在线观看| 欧美日韩p片| 欧美视频免费| 国产精品美女久久久| 久久精品国产2020观看福利| 欧美美女福利视频| 国产老肥熟一区二区三区| 久久国产加勒比精品无码| 亚洲精品孕妇| 久久网站热最新地址| 欧美日韩精品久久| 亚洲一区二区三区四区五区午夜| 久久亚洲综合色一区二区三区| 亚洲国产日韩欧美在线99| 亚洲精品视频在线观看免费| 99国产一区二区三精品乱码| 亚洲成色777777女色窝| 亚洲第一页自拍| 国产精品第13页| 国产在线播精品第三| 欧美激情成人在线视频| 在线观看91精品国产麻豆| 国产老肥熟一区二区三区| 国产精品女同互慰在线看| 亚洲性视频网址| 国产日韩欧美精品综合| 欧美成人官网二区| 亚洲最快最全在线视频| 国内免费精品永久在线视频| 亚洲一区二区三区国产| 国产农村妇女精品一二区| 国产日韩精品入口| 欧美人与性动交a欧美精品| 在线播放国产一区中文字幕剧情欧美| 欧美日韩国产成人精品| 亚洲丰满少妇videoshd| 亚洲欧美日韩国产一区二区| 欧美一级久久久久久久大片| 午夜一区不卡| 欧美一区二区三区成人| 欧美国产日本高清在线| 午夜在线成人av| 亚洲视频欧美视频| 欧美伊人久久久久久久久影院| 美女啪啪无遮挡免费久久网站| 精品成人国产在线观看男人呻吟| 国产欧美日韩精品丝袜高跟鞋| 国产在线视频欧美一区二区三区| 国产精品久久久久久久第一福利| 一区二区三区在线免费观看| 狠狠综合久久av一区二区老牛| 国自产拍偷拍福利精品免费一| 国产精品国产精品国产专区不蜜| 久久久精品一区二区三区| 久久亚洲综合网| 国产欧美一级| 亚洲国产精品视频一区| 欧美日韩综合视频网址| 亚洲欧美日韩一区| 男女激情视频一区| 狠狠色伊人亚洲综合网站色| 欧美精品高清视频| 久久久久青草大香线综合精品| 亚洲一二三区精品| 国产精品99免视看9| 久久综合中文色婷婷| 一区二区三区精品视频在线观看| 一本色道久久综合一区| 久热国产精品视频| 欧美一区二区三区四区在线观看| 狠久久av成人天堂| 日韩视频不卡| 欧美日韩视频一区二区| 红桃视频一区| 国产精品免费网站在线观看| 国内精品亚洲|