《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 基于S3C2410的WindowsCE5.0 BSP移植
基于S3C2410的WindowsCE5.0 BSP移植
摘要: 移植基于S3C2410的Windows CE 5.0 BSP,需要分析Windows CE 5.0 及BSP結構。Windows CE 5.0是一款開放的、可升級的32位嵌入式操作系統,具有高可靠性,是一種硬實時嵌入式操作系統,它可以在多種處理器架構(如x86、MIPS、ARM和 SH4)上運行,Windows CE支持ARM體系結構,這是基于S3C2410 處理器進行BSP移植的前提條件。Windows CE 5.0 BSP通常包含以下幾部分:Bootloader,OAL(OEM adaptation layer),設備驅動程序,配置文件等。
Abstract:
Key words :

1 引言

在當今后PC時代,嵌入式系統應用得越來越廣泛,嵌入式產品充斥著許多領域,日常生活的手機,MP4,PDA等都屬于典型的嵌入式系統。在嵌入式系統中,微處理器和操作系統是進行應用開發的基礎。在微處理器方面,S3C2410是Samsung公司推出的一款基于ARM920T內核的16/32位 RISC嵌入式CPU,主要面向手持設備以及高性價比、低功耗的應用。在操作系統方面,Windows CE 5.0是由微軟提供的一款嵌入式操作系統,在Windows CE 4.2基礎上,它又加入了一些新特性以滿足市場需求。板級支持包 (Board Support Package,BSP)是操作系統的一個組成部分,提供對硬件的支持。BSP的開發在整個產品開發時間上占了很大比例,快速的移植滿足產品需求的BSP 在競爭激烈的市場環境里顯得很重要。目前已有許多關于S3C2410、Windows CE以及BSP相關的研究報道,文獻[1]研究基于s3c2410的GPS通信技術及實現,文獻[2]中詳盡分析Windows CE的結構,文獻[3]中歸納了Windows CE 4.2專用操作系統的定制和裁剪方法,文獻[4]則探討基于DSP嵌入式多媒體應用系統板級支持包的開發。目前關于Windows CE的應用主要采用Windows CE 4.2及以下版本,本文研究基于S3C2410的Windows CE 5.0 BSP移植技術。

2 Windows CE 5.0及BSP結構分析

移植基于S3C2410的Windows CE 5.0 BSP,需要分析Windows CE 5.0 及BSP結構。Windows CE 5.0是一款開放的、可升級的32位嵌入式操作系統,具有高可靠性,是一種硬實時嵌入式操作系統,它可以在多種處理器架構(如x86、MIPS、ARM和 SH4)上運行,Windows CE支持ARM體系結構,這是基于S3C2410 處理器進行BSP移植的前提條件。Windows CE 5.0 BSP通常包含以下幾部分:Bootloader,OAL(OEM adaptation layer),設備驅動程序,配置文件等。

BootLoader是加電即運行的一段程序,它初始化硬件,建立系統的內存空間映射,為最終調用系統內核做準備。在Windows CE 5.0系統中,它主要用于下載和啟動鏡像nk.bin,也就是兩種工作模式:啟動加載模式:用戶最終使用的產品即為該模式;下載模式:鏡像首先被 bootloader下載到目標機的RAM中,然后被固化到Flash。

設備驅動程序按照導出的接口不同可分為:本機驅動程序以及流接口驅動程序.本機驅動程序有GEWS.exe加載的鼠標,鍵盤,觸摸屏,顯示驅動等。而流接口驅動程序使用一組流函數來實現,通常由Device.exe加載,如網卡,聲卡,USB等。

OAL是邏輯上駐留在Windows CE內核與目標設備之間的代碼層,在物理上OAL與內核庫連接來產生內核可執行文件。OAL簡化了操作系統與目標代碼之間的通信,OAL代碼用來處理中斷,記時器,電源管理,通用I/O控制等[5]。

Configuration File里面包含的是與生成的鏡像相關的配置信息。

移植Windows CE下S3C2410對應的BSP,就是修改Windows CE自帶的BSP或者修改硬件平臺以前版本的BSP的幾個主要組成部分,使得BSP能有效支持硬件系統。

3  BSP移植

如果從零開始開發Widows CE 5.0 BSP,則需要相當長的時間。通常的做法是:⑴將自己硬件平臺基于Windows CE 4.2及以前版本的BSP移植到Windows CE 5.0系統上;⑵從Windows CE 5.0 BSP中尋找與硬件平臺最接近的作為模板,然后再從自己的硬件平臺上入手做相應的修改,從而得到可以在自己系統上使用的BSP。本文探討的BSP移植屬于第一種情況。

本次移植平臺采用的是深圳英蓓特公司的EdukitIII實驗箱,微處理器是S3C2410,外帶64M NAND Flash芯片等相關硬件資源。軟件資源有:edukit2410包(Windows CE 4.2版本下的BSP)。

3.1 bootloader移植

bootloader的執行流程如下:

⑴ 執行startup.s:對CPU,內存控制器,Cache等做一些基本的初始化。

⑵ 初始化串口:調用函數OEMInitDebugSerial()來完成。

⑶ 初始化平臺:調用函數OEMPlatformInit(),主要對所需硬件資源進行初始化,通常包括:以太網控制器(CS8900A)、系統時鐘、存儲設備以及其他一些外圍設備。

⑷ 調用函數OEMPreDownload():做一些準備工作如獲取IP地址,初始化TFTP連接等。

⑸ 執行函數DownloadImage():下載鏡像到SDRAM中。

⑹ 調用OEMLaunch()函數啟動操作映像。

其中startup.s,OEMInitDebugSerial()可以與OAL共享使用,兩函數的修改在OAL移植過程中敘述。

Bootloader移植主要過程有:

⑴ 修改相應的dir,source文件,下面列出部分庫路徑:

TARGETLIBS=
      $(_TARGETPLATROOT)lib$(_CPUINDPATH)csp_arm.lib    
    $(_COMMONOAKROOT)lib$(_CPUDEPPATH)eboot.lib     
       $(_COMMONOAKROOT)lib$(_CPUINDPATH)cs8900dbg.lib      

其中csp_arm.lib這個庫只存在于Windows CE 4.2的$(_PUBLICOAKROOT),是ARM體系結構鏈接庫之一,在Windows CE 4.2系統下位于PUBLIC目錄,而在Windows CE 5.0系統下存在于PLATFORM,導致編譯系統找不到該庫文件,因此,修改這個庫的鏈接路徑,使得Platform builder這個編譯系統能夠找到這個鏈接庫。

⑵ 修改makefile.inc,因為該文件指定生成eboot.bin(Ethernet bootloader鏡像)所需要的文件以及拷貝eboot.bin到releasedir目錄,其中:

romimage $(_TARGETPLATROOT)ebootboot.bib

為生成生成eboot.bin所需要的配置文件,否則,系統通過編譯卻無法生成eboot.bin.

⑶ 修改boot.bib,使其不與config.bib中的內存分配造成沖突。

⑷ 改進eboot,因為eboot燒寫NK.BIN(OS鏡像)的時候會查找BINFS分區,然后把下載的image燒寫到BINFS分區。如果沒有找到現存的BINFS分區,eboot會低格NAND FLASH,并創建MBR(main boot record),在MBR中有分區表。目前最多支持4個分區,而BINFS分區的大小是以NK.BIN展開的大小按block對齊,所以會出現個問題,當修改過重新生成的NK.BIN比之前寫進NAND FLASH的IMAGE大并且超出block對齊的時候,將會導致燒寫新的NK.BIN失敗,我們可以通過每次下載燒寫NK.BIN前先低格NAND FLASH來解決這個問題,但顯然這不是妥善的解決方法,增加用戶使用復雜度,所以我們可以把BINFS分區的大小固定,而這個固定的大小可以參考生成 NK.BIN的config.bib中定義的ROMSIZE,這樣無論NK怎么修改,BINFS一經創建無需更改,eboot把NK寫進NAND FLASH之后,會把剩余的FREE空間創建一個FAT分區,如果我們要實現HIVE REGISTRY就可以把這個分區mounts成MountAsBootable。

3.2 OAL移植

OAL的移植過程中,OEM主要實現以下幾個函數:Startup.s,調試串口函數,OEMInit函數,系統時鐘函數,中斷處理函數等。

⑴ 修改Startup.s,此函數為OS啟動時第一個要調用的函數,也是OEM要實現的重要函數之一,主要完成的功能是:將CPU初試化到一種已知的狀態;并調用內核初始化函數kernelstart。Startup.s需要修改,修改后的部分代碼如下:
        ……
        ldr     r0, = 0X4A000008           
        ldr     r1, = 0xffffffff                ; 禁止所有中斷
        str     r1, [r0]
        ldr     r0, = 0X4A00001C               
        ldr     r1, = 0x7ff                   ; 禁止所有子中斷
        str     r1, [r0]
        ……..
        add     r0, pc, #g_oalAddressTable - (. + 8)
        bl      KernelStart    //跳轉到KernelStart

⑵ 修改串口調試函數。執行完Startup.s,系統就跳轉到Kernelstart函數,位于private目錄,該函數第一個任務就是初始化串調試口,否則,就無法進行后面的調試工作。其中OEMReadDebugByte, OEMWriteDebugByte, OEMWriteDebugString不用做修改,需要注意的是OEMInitDebugSerial,選UART0,UART1的寄存器配置不一樣,若選用UART0,使用配置:
s2410IOP->rGPHCON &= ~((3 << 4) | (3 << 6));    
s2410IOP->rGPHCON |=  ((2 << 4) | (2 << 6));      

而選擇UART1,則使用配置的是:
s2410IOP->rGPHCON &= ~((3 << 8) | (3 << 10));  
s2410IOP->rGPHCON |=  ((2 << 8) | (2 <<10));     

⑶ 實現OEMInit(),該函數將調用以下函數:OALCacheGlobalsInit(),OALIntrInit(),OALTimerInit(),OALKitlStart()來初始化Cache Global,中斷,時鐘,啟動KITL,實現代碼如下:
void OEMInit()
{
     OALCacheGlobalsInit();// 初試化cache globals
     if (!OALIntrInit()) {
        OALMSG(OAL_ERROR, (
            L"ERROR: OEMInit: failed to initialize interruptsrn"
        ));
    } // 初試化中斷
     OALTimerInit(1, S3C2410X_PCLK/2000, 0); // 初始化時鐘
     OALKitlStart();// 初始化KITL
  }

⑷ 實現OALTimerInit(),該函數用于初始化OS TIMER,設置每毫秒產生一個System tick,為系統計數,觸發進程調度。由CPU的運行主頻和硬件定時器資源來確定,執行過程有:初始化時鐘狀態全局變量,初始化高分辨率時鐘函數指針,使能TIMER。

⑸ 實現中斷處理處理函數:OALIntrInit(),該函數通常先初始化中斷映射表,因為WINCE為了模塊化,把平臺相關物理中斷號和系統中斷號建立映射。然后清除外部中斷,內部中斷等。

3.3  驅動移植

以觸摸屏為例,來探討Windows CE 5.0系統驅動程序移植。這里以三星公司ARM9內核芯片S3C2410觸摸屏接口為基礎,通過外接4線電阻式觸摸屏構成硬件基礎,整個觸摸屏由橫向電阻線和縱向電阻線組成。觸摸屏驅動的主要函數組成有:

TSP_Poweron 該函數將執行觸摸屏的一些初始化,主要是寄存器的配置。

DdsiTouchPanelEnable:使能DDSI接口,使得硬件能將流數據提供給DDSI接口,就可以實現觸摸的操作了。

DdsiTouchPanelSetMode:模式設置函數,設置觸摸屏是高采樣率還是低采樣率

DdsiTouchPanelGetPoint :觸摸屏進行采樣函數

TSP_CalibrationPointGet:坐標轉換函數,該函數實現將從AD采樣植轉換成坐標。

移植主要過程:

⑴ 修改source文件,要添加如下庫文件:
TARGETLIBS=$(_COMMONSDKROOT)lib$(_CPUINDPATH)coredll.lib
SOURCELIBS=
                         $(_COMMONOAKROOT)lib$(_CPUINDPATH)tch_cal.lib
                         $(_COMMONOAKROOT)lib$(_CPUINDPATH)tchmdd.lib 

因為這個驅動在Windows CE 4.2下面是在Public目錄,而這里將該觸摸屏移到了Platform下面,在Windows CE4.2下面是沒有以上三條鏈接庫,但Platform,Public編譯路徑,先決條件都不同。因此引用的庫不一樣。

⑵ 刪除如下庫文件:
           $(_TARGETPLATROOT)lib$(_CPUINDPATH)drvlib.lib

該庫在Windows CE 4.2系統下為觸摸屏與音頻共用庫,但在Windows CE5.0系統下,這個庫已經不是必要的并且已經不存在了,所以刪除掉,否則系統會出編譯錯誤。

⑶修改platform.bib,將我們移植過來的驅動dll包含到nk.bin中

⑷修改platform.reg,其中CalibrationData是觸摸屏的一個參數:
[HKEY_LOCAL_MACHINEHARDWAREDEVICEMAPTOUCH]
 "MaxCalError"=dword:7
 portrait
"CalibrationData"="517,610 897,934 142,936 129,290 891,285 "

其他驅動的過程與觸摸屏類似。

3.4  移植小結

此次移植是升級BSP,而硬件上基本沒有變化,因此很多代碼不需做修改即可使用,通過以上移植,不難發現此類移植BSP過程中所要做的工作主要在以下幾個方面:

⑴  修改dir文件,在dir文件中指定了當前目錄哪些文件夾被系統編譯,編譯器根據dir層層搜索,而移植BSP不可避免的帶來了目錄的變化,通過修改dir來指定新的編譯路徑。

⑵  修改sources文件,在sources文件中,指定了編譯類型有PLATFORM,OAK;編譯的時候引用的庫 sourcelib,targetlib不一樣,移植的時候一定得注意。目標文件類型有Library,Dynlink,program;include 字段包含的則是編譯時候所需要的頭文件目錄。有個比較特殊的sources是位于Platform(例如smdk2410)下的sources.cmn,它包含了該平臺的通用庫,頭文件路徑,這個文件在移植過程中需要修改的,否則,編譯出錯。

⑶ 修改platform.bib,platform.reg等文件,因為這兩個文件決定了鏡像中包含哪些模塊(dll)以及注冊表相關信息,驅動移植的過程中,每個模塊的改動都需要修改這兩個配置文件。

⑷ 驅動源文件中的頭文件的修改以及函數,變量修改等,這些依據編譯時候出現的錯誤來確定。

除此之外,各部分的移植還需特別注意的地方有:

Bootloader部分:因為bootloader下載,燒寫,啟動鏡像過程會涉及到內存地址的問題,各種入口地址不能出錯誤,以及內存超出范圍,沖突都需要特別小心。尤其是g_oalAddressTable這個表,這個表定義了物理地址虛擬地址之間的轉換以及內存的大小,如果設置不正確,將出現校驗錯誤,下載失敗或者鏡像無法啟動等錯誤。

OAL部分:startup.s以及OEMInitDebugSerial兩函數需要特別注意,這兩個主要是初始化硬件及串口,這是系統運行及驅動調試的基礎,如果硬件配置以及調試串口有改變,則需要適當的修改。此次BSP移植,因硬件平臺沒有變化,因此OAL部分很多代碼無須修改即可使用。

驅動部分:Windows CE4.2與Windows CE5.0的結構,庫有了很大的改變,因此需要修改引用庫路徑,以及頭文件的引用路徑,大部分驅動都將會遇到這樣的問題。

4  結束語

本文創新點:通過對BSP結構分析,將具體平臺的Windows CE 4.2 BSP移植到Windows CE 5.0版本,包括移植bootloader,OAL,驅動程序,使之能夠通過編譯并生成鏡像,已經能在平臺上成功運行。通過這次移植,使筆者體會到BSP 移植是一個挺復雜,煩瑣的過程,因Windows CE 5.0跟Windows CE 4.2 BSP包的組織結構不同,導致很多鏈接庫無法找到或者是這些庫已經被替換,刪除,只有耐心的根據這些錯誤提示來定位,有時候也需要去makefile里去找答案。不過移植BSP比重新開發BSP更加節省開發時間,從而縮短產品的研發。 

參考文獻:
[1] 潘永才,魯啟華,田茂.基于s3c2410的GPS通信實現[J].現代電子技術,2006,15,157-159
[2] 林濤.嵌入式操作系統Windows CE的研究[J].微計算機信息,2006,6-2,91-93
[3] 呂秀平,李小民.Windows CE.NET的定制和裁剪[J].科學技術與工程.6卷第21期,2006年11月,p3483-3486
[4] 曹榮,劉峰.一種DSP嵌入式多媒體應用系統板級支持包的研究[J] .第26卷第3期,2006年3月,p746-748
[5] 何宗健.Windows CE嵌入式系統[M].北京:北京航空航天大學出版社,2006.

此內容為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∨| 在线观看欧美精品| 国产精品爱啪在线线免费观看| 国产精品一区二区久激情瑜伽| 国产在线播放一区二区三区| 欧美成人a视频| 亚洲制服少妇| 午夜一区二区三区在线观看| 亚洲精品偷拍| 亚洲国产精品999| 欧美一级视频精品观看| 国产精品永久免费观看| 亚洲欧美视频在线| 国产精品夫妻自拍| 欧美精品v国产精品v日韩精品| 久久精品国产69国产精品亚洲| 亚洲黄色免费网站| 亚洲人成亚洲人成在线观看| 久久久精品视频成人| 影音先锋日韩精品| 卡一卡二国产精品| 一区二区高清| 亚洲精品国产精品国产自| 亚洲一区二区三区久久| av成人免费在线观看| 欧美午夜视频在线观看| 欧美日本国产精品| 好吊一区二区三区| 99精品免费视频| 久久国产日韩| 亚洲免费成人| 在线免费观看日本一区| 欧美一站二站| 久久久久久高潮国产精品视| 国产麻豆视频精品| 99精品热6080yy久久| 亚洲国产视频一区| 欧美人与禽猛交乱配视频| 欧美大片免费观看在线观看网站推荐| 蜜臀av在线播放一区二区三区| 亚洲免费小视频| 韩国一区二区三区在线观看| 国产欧美精品日韩区二区麻豆天美| 国产日韩精品视频一区二区三区| 亚洲日本欧美日韩高观看| 久久青草欧美一区二区三区| 欧美精品在线观看| 欧美日韩亚洲一区| 亚洲综合99| 欧美成人一区二区三区片免费| 一本色道久久99精品综合| 欧美日韩免费高清| 一区二区高清在线观看| 欧美激情性爽国产精品17p| 国产亚洲精品美女| 中文av一区特黄| 亚洲欧洲一区二区三区在线观看| 性感少妇一区| 国产精品国产自产拍高清av| 国产精品草草| 欧美性猛交xxxx乱大交退制版| 精品福利免费观看| 欧美性猛交xxxx乱大交退制版| 欧美有码在线视频| 午夜精品久久一牛影视| 免费在线播放第一区高清av| 亚洲精品欧美| 香蕉视频成人在线观看| 国产精品久久久久天堂| 亚洲无吗在线| 欧美一区2区视频在线观看| 欧美国产专区| 欧美激情1区2区3区| 久久人人爽人人爽| 久久久久久久综合日本| 午夜激情综合网| 国产在线精品二区| 国产精品资源在线观看| 欧美绝品在线观看成人午夜影视| 国产精品亚洲人在线观看| aa日韩免费精品视频一| 欧美大片在线观看一区二区| 久久国产精品99国产精| 国产精品久久久久77777| 国产欧美日韩在线播放| 国产亚洲第一区| 欧美特黄一级大片| 农夫在线精品视频免费观看| 亚洲视频在线观看| 亚洲一区二区在线观看视频| 国产欧美韩国高清| 欧美日韩一区三区四区| 亚洲国产毛片完整版| 亚洲一级特黄| 国产伦精品一区二区三区在线观看| 久热精品视频在线免费观看| 欧美日韩国产在线看| 亚洲视频一区在线观看| 久久成人精品无人区| 国产精品久久久久毛片软件| 国产日韩精品久久久| 亚洲欧美日韩综合aⅴ视频| 新片速递亚洲合集欧美合集| 国内精品**久久毛片app| 午夜精品一区二区在线观看| 欧美美女日韩| 国产一区二区三区高清在线观看| 欧美日韩在线视频观看| 欧美一区二区三区精品电影| 国语自产精品视频在线看一大j8| 亚洲国产网站| 国产精品www994| 一区二区三区视频在线| 欧美午夜美女看片| 欧美性猛交xxxx乱大交退制版| 亚洲国内欧美| 久热精品在线视频| 欧美精品久久久久久久久老牛影院| 韩国在线视频一区| 久久不射2019中文字幕| 亚洲免费观看高清在线观看| 久久人人97超碰人人澡爱香蕉| 国产在线视频不卡二| 欧美日韩一二三四五区| 老司机午夜精品视频| 亚洲国产日韩一区| 午夜在线观看欧美| 亚洲欧美三级伦理| 久久av免费一区| 销魂美女一区二区三区视频在线| 亚洲国产欧美一区二区三区丁香婷| 久久国产一区二区三区| 亚洲精品视频中文字幕| 亚洲人成网站色ww在线| 国产欧美一区二区三区视频| 亚洲一区精品电影| 午夜精品在线观看| 欧美不卡在线| 亚洲国产影院| 国产精品99久久久久久久久久久久| 欧美日韩免费区域视频在线观看| 国产欧美日韩伦理| 国产精品电影网站| 激情久久久久| 亚洲精品在线一区二区| 欧美日韩国产综合在线| 欧美精品www在线观看| 国产精品一区二区你懂的| 久久婷婷成人综合色| 黄页网站一区| 欧美一区二区高清在线观看| 欧美精品一区二区在线播放| 亚洲国产天堂久久综合| 国产精品腿扒开做爽爽爽挤奶网站| 亚洲欧美中文日韩v在线观看| 亚洲精品自在久久| 另类尿喷潮videofree| 亚洲女人av| 欧美88av| 久久色在线观看| 久久精品日韩一区二区三区| 在线播放中文字幕一区| 一区二区高清视频在线观看| 久久精品国产第一区二区三区最新章节| 中文网丁香综合网| 欧美巨乳波霸| 欧美激情 亚洲a∨综合| 亚洲在线网站| 国产精品欧美一区喷水| 亚洲天堂第二页| 亚洲欧美日韩精品综合在线观看| 性做久久久久久久久| 国产性做久久久久久| 欧美日韩在线电影| 国产精品一区二区三区成人| 老司机精品导航| 国模套图日韩精品一区二区| 国内精品久久久久影院色| 日韩亚洲欧美一区| 在线免费一区三区| 麻豆成人在线观看| 久久都是精品| 欧美连裤袜在线视频| 欧美本精品男人aⅴ天堂| 欧美乱人伦中文字幕在线| 国产精品第2页| 欧美日韩另类一区| 亚洲尤物精选| 欧美日韩亚洲网| 欧美精品自拍| 亚洲国产一二三| 欧美午夜精品久久久久久久| 欧美日韩一区二区视频在线观看| 亚洲精选91| 国产一区二区成人久久免费影院| 久久久午夜电影| 美女亚洲精品| 国产日韩在线一区二区三区| 日韩视频免费| 最新成人av在线| 国产亚洲一二三区| 欧美精品播放| 欧美顶级少妇做爰| 国产午夜精品福利| 亚洲欧美美女| 今天的高清视频免费播放成人| 妖精成人www高清在线观看| 亚洲欧洲精品一区二区| 亚洲一区免费在线观看| 欧美激情a∨在线视频播放| 国产精品白丝av嫩草影院| 免费成人在线视频网站| 亚洲小说区图片区| 亚洲人成人77777线观看| 在线日韩中文| 欧美日韩综合不卡| 欧美国产免费| 欧美不卡视频一区发布| 欧美日本不卡高清| 亚洲高清视频的网址| 久久久久国产成人精品亚洲午夜| 久久成人av少妇免费| 久久久五月婷婷| 亚洲一区二区精品在线| 久久久久久久久岛国免费| 欧美一区日韩一区| 欧美一级日韩一级| 亚洲黄色尤物视频| 久久香蕉国产线看观看网| 尤物yw午夜国产精品视频明星| 亚洲一区二区不卡免费| 国产三级欧美三级日产三级99| 久久精品盗摄| 精品不卡在线| 欧美视频中文一区二区三区在线观看| 在线视频国内自拍亚洲视频| 欧美日韩岛国| 久久亚洲美女| 国产亚洲福利| 亚洲伊人第一页| 国产一区二区三区免费观看| 在线观看视频日韩| 亚洲欧美日韩成人| 国产精品成人国产乱一区| 亚洲影院免费| 好吊妞这里只有精品| 亚洲线精品一区二区三区八戒| 国产精品亚洲一区| 国产欧美日韩精品a在线观看| 欧美一区二区久久久| 久久嫩草精品久久久精品一| 欧美专区福利在线| 一本一道久久综合狠狠老精东影业| 国产女人水真多18毛片18精品视频| 韩日欧美一区二区| 午夜精品久久久久久久久| 国产亚洲福利一区| 国产亚洲亚洲| 亚洲精品国产欧美| 亚洲精品国产日韩| 国产精品福利在线| 国产欧美日本一区视频| 国产一区成人| 在线观看欧美成人| 国产欧美一级| 黄色综合网站| 亚洲成人资源| 老司机成人在线视频| 欧美精品在线观看| 国产精品你懂的| 欧美一级在线亚洲天堂| 狠狠色狠狠色综合日日五| 女女同性精品视频| 国产日韩欧美视频| 国产一区二区三区丝袜| 亚洲高清电影| 欧美一区二视频在线免费观看| 久久国产99| 欧美天天视频| 美日韩精品免费| 亚洲最新在线视频| 亚洲欧美另类综合偷拍| 欧美一乱一性一交一视频| 免费不卡在线观看av| 国产精品av久久久久久麻豆网| 午夜精品影院| 狠狠做深爱婷婷久久综合一区| 亚洲精品视频二区| 亚洲人成啪啪网站| 国产综合久久久久久鬼色| 久久精品一本久久99精品| 国产精品视频精品视频| 国产欧美午夜| 欧美成人黄色小视频| 最新精品在线| 欧美成人一区在线| 欧美激情国产精品| 亚洲美女视频在线免费观看| 亚洲精品国精品久久99热| 欧美激情中文字幕在线| 日韩一区二区免费高清| 日韩亚洲精品电影| 国产精品一区二区三区四区五区| 国产视频久久久久| 伊人婷婷久久| 午夜精品一区二区三区在线视| 红桃视频成人| 国产亚洲人成网站在线观看| 欧美日韩在线不卡一区| 欧美精品久久久久久久久老牛影院| 国产精品网站在线| 在线视频一区观看| 午夜亚洲福利| 亚洲午夜激情网页| 99这里只有久久精品视频| 一本大道久久a久久精品综合| 亚洲激情一区| 欧美成人一区二区在线| 亚洲第一中文字幕在线观看| 国产一区二区三区精品久久久| 国产精品进线69影院| 亚洲精品乱码久久久久久按摩观| 在线免费观看成人网| 久久色在线播放| 国产精品揄拍500视频| 国产午夜精品视频免费不卡69堂|