《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 嵌入式技術(shù) > 設(shè)計(jì)應(yīng)用 > NIOS下實(shí)現(xiàn)存儲(chǔ)速度可調(diào)的SD卡FAT文件系統(tǒng)
NIOS下實(shí)現(xiàn)存儲(chǔ)速度可調(diào)的SD卡FAT文件系統(tǒng)
2017年微型機(jī)與應(yīng)用第8期
劉人萍,汪濤
重慶大學(xué) 物理學(xué)院,重慶 401331
摘要: 由于NIOS下自帶的SPI控制器,一旦建立,SPI clock(SCLK)的頻率在使用過程中是不允許被修改的,即SPI的讀取速度是不可改變的,這在很大程度上限制了SD卡的使用性能,因?yàn)樵诳ǔ跏蓟臅r(shí)候,SCLK時(shí)鐘最大不能超過400 kHz。使用軟件模擬SPI,通過示波器調(diào)試時(shí)序,并且移植了FATFS文件系統(tǒng)實(shí)現(xiàn)SD的存儲(chǔ)管理。最后通過存儲(chǔ)文件測(cè)試在不同速度下的存儲(chǔ)時(shí)間。
Abstract:
Key words :

  劉人萍,汪濤

  (重慶大學(xué) 物理學(xué)院,重慶 401331)

        摘要:由于NIOS下自帶的SPI控制器,一旦建立,SPI clock(SCLK)的頻率在使用過程中是不允許被修改的,即SPI的讀取速度是不可改變的,這在很大程度上限制了SD卡的使用性能,因?yàn)樵诳ǔ跏蓟臅r(shí)候,SCLK時(shí)鐘最大不能超過400 kHz。使用軟件模擬SPI,通過示波器調(diào)試時(shí)序,并且移植了FATFS文件系統(tǒng)實(shí)現(xiàn)SD的存儲(chǔ)管理。最后通過存儲(chǔ)文件測(cè)試在不同速度下的存儲(chǔ)時(shí)間。

  關(guān)鍵詞: NIOS;軟件SPI;FATFS文件系統(tǒng);SD卡

  中圖分類號(hào):TP274文獻(xiàn)標(biāo)識(shí)碼:ADOI: 10.19358/j.issn.1674-7720.2017.08.027

  引用格式:劉人萍,汪濤.NIOS下實(shí)現(xiàn)存儲(chǔ)速度可調(diào)的SD卡FAT文件系統(tǒng)[J].微型機(jī)與應(yīng)用,2017,36(8):85-87,91.

0引言

  與傳統(tǒng)處理器相比,NIOS II嵌入式系統(tǒng)在設(shè)計(jì)的時(shí)候可以根據(jù)不同的需求來增減外設(shè)的種類和數(shù)量,在FPGA上面快速地搭建硬軟件平臺(tái)。再加上可以根據(jù)需要很方便地把FPGA并行處理的IP核嵌入到NIOS II系統(tǒng)中,而只需要簡(jiǎn)單的Avalon接口總線,所以其靈活的構(gòu)造方式越來越受到開發(fā)人員的青睞。

  嵌入式系統(tǒng)都需要用到大容量存儲(chǔ)設(shè)備,以備數(shù)據(jù)存儲(chǔ)。目前常用的存儲(chǔ)設(shè)備有U盤、Flash芯片、SD卡等,綜合比較,最適合嵌入式系統(tǒng)的可移動(dòng)存儲(chǔ)設(shè)備莫過于SD卡了。SD卡不僅容量可以做到32 GB以上,而且支持SPI,更換方便,編程簡(jiǎn)單,最高通信速度可以達(dá)到18 Mb/s,可滿足于一般的應(yīng)用要求。

  然而在NIOS中使用SPI方式與SD卡通信的時(shí)候,由于在軟核的構(gòu)造過程中,系統(tǒng)已經(jīng)把SPI的時(shí)鐘頻率選定,在軟件編程時(shí)不可以再去修改SPI的速率,再加上SD卡在初始化過程時(shí)鐘最大不超過400 kHz[1],這樣在很大程度上限制了SD卡的使用性能。解決以上問題的方法就是不使用NIOS II自帶的SPI控制器,利用軟件模擬的方式,可以隨時(shí)調(diào)整SPI的時(shí)鐘速率。

  本文將從NIOS II軟核的構(gòu)建開始,利用軟件模擬SPI,接著寫SD的底層驅(qū)動(dòng),最后移植FATFS文件系統(tǒng)來管理SD卡,測(cè)量SD卡在不同的速率下寫文件所需要的時(shí)間。

1NIOS II軟核的構(gòu)建

  1.1SOPC系統(tǒng)結(jié)構(gòu)簡(jiǎn)介[2]

  為了盡可能簡(jiǎn)單地驗(yàn)證本文所述內(nèi)容,在硬件方面只選擇了所必需的硬件,其中包括處理器和支持處理工作的外圍設(shè)備以及4個(gè)通用的IO,具體如下:

  (1)NIOS II 處理器。

  (2)EPCS:FPGA的配置芯片,相當(dāng)于計(jì)算機(jī)的硬盤。由于FPGA掉電后,代碼和配置信息都會(huì)丟失,因此EPCS的功能一方面是保存NIOS II軟核的配置信息,另一方面是保存用戶需要運(yùn)行的程序代碼。

  (3)DDR2 SDRAM: 程序運(yùn)行的地方。上電之后,系統(tǒng)會(huì)把EPCS中的代碼搬移到SDRAM中運(yùn)行。

  (4)JTAG :第一是將編譯好的程序下載到開發(fā)板中;第二是通過JTAG_UART來調(diào)試程序,打印程序的執(zhí)行結(jié)構(gòu)。

  (5)4個(gè)通用IO : 由于用軟件來模擬SPI,因此只要4個(gè)通用IO,其中3個(gè)是輸出方向(SCLK,MOSI,CS),一個(gè)是輸入方向(MISO)。

  1.2NIOS II 軟核構(gòu)建流程[3]

  (1)時(shí)鐘。時(shí)鐘是一個(gè)數(shù)字系統(tǒng)不可缺少的一部分,在嵌入式系統(tǒng)中尤為重要。時(shí)鐘信號(hào)的質(zhì)量也決定著嵌入式系統(tǒng)工作能否穩(wěn)定。在本次NIOS II軟核構(gòu)建中使用PLL來得到所希望的時(shí)鐘頻率。本文中所使用的開發(fā)板的晶振頻率是50 MHz,希望得到的時(shí)鐘頻率也是50 MHz,按理說是不需要PLL的,但是經(jīng)過PLL之后輸出的時(shí)鐘在穩(wěn)定性方面更好一些,所以就用PLL來生成一個(gè)頻率仍為50 MHz的時(shí)鐘。

  (2)軟核及控制器構(gòu)建。這部分以NIOS II CPU為核心,包含了存儲(chǔ)單元的控制器和通用的IO接口。在CPU選擇過程中有三種類型可供選擇,從資源消耗和工作速度的角度出發(fā),本文選擇了NIOSII/s。在選擇SDRAM控制器的時(shí)候,需要根據(jù)自己實(shí)際的硬件來進(jìn)行選擇,一般的數(shù)據(jù)在所使用芯片的DATASHEET中可以查到。然后是添加Flash控制器,這里使用的是EPCS,最后建立system ID和JTAG_UART。

  (3)添加外圍設(shè)備。這里為了盡可能簡(jiǎn)單地驗(yàn)證本文功能,只添加了4個(gè)通用IO來模擬SPI時(shí)序。這里使用了三個(gè)輸出IO(CS,SCLK,MOSI)和一個(gè)輸入IO(MISO)。

2軟件模擬SPI及SD卡底層驅(qū)動(dòng)

  2.1SPI簡(jiǎn)介

  SPI(Serial Peripheral Interface)是Motorola首先在其處理器上面定義的。SPI主要應(yīng)用在EEPROM、Flash、AD轉(zhuǎn)換等。SPI是一種高速的、全雙工、同步的通信總線,并且在芯片的引腳上只占用四跟線,既節(jié)約了芯片的引腳,也方便了PCB的布局布線。SPI接口一般使用四跳線通信:MISO:主設(shè)備輸入,從設(shè)備輸出;MOSI:主設(shè)備輸出,從設(shè)備輸入;SCLK:時(shí)鐘信號(hào),由主設(shè)備產(chǎn)生;CS:從設(shè)備片選信號(hào),由主設(shè)備產(chǎn)生。

  2.2SD卡相關(guān)介紹

  SD卡(Secure Digital Memory Card)是一種基于半導(dǎo)體快閃記憶器的新一代記憶設(shè)備,它被廣泛地應(yīng)用在便攜式設(shè)備中。按容量可以把SD卡分為三類[1]:SDSC(0~2 GB),SDHC(2~32 GB),SDXC(32 GB~2 TB)。

  SD卡和SDHC卡協(xié)議基本兼容,但是同SDXC卡的區(qū)別比較大,本文主要介紹目前比較常用的SDHC卡的操作。SD的操作方式一般支持2種方式:SD卡模式和SPI模式,本文使用SPI模式。

  從DATASHEET中可以知道SD卡每個(gè)命令是由6個(gè)字節(jié)組成的[1],第一個(gè)字節(jié)的最高兩位固定為01,然后緊接著是6個(gè)字節(jié)的命令號(hào),其中第2~5字節(jié)為命令參數(shù),如果有些命令沒有命令參數(shù)就設(shè)為0,第6字節(jié)的高7位是CRC,最低位恒為1。SD卡的通信采用發(fā)送應(yīng)答機(jī)制,每發(fā)送一個(gè)命令,SD卡都會(huì)給出一個(gè)應(yīng)答,以告知主機(jī)該命令的執(zhí)行情況,或者返回給主機(jī)需要獲取的數(shù)據(jù)。后面從示波器中可以看到SD卡具體的發(fā)送命令和接收應(yīng)答的相關(guān)時(shí)序。

  2.3軟件模擬速度可調(diào)的SPI

  根據(jù)SD卡手冊(cè)的Bus Timing可以看出,SD卡底層的讀寫時(shí)序是在時(shí)鐘的上升沿接收數(shù)據(jù),在時(shí)鐘的下降沿發(fā)出數(shù)據(jù)。所以根據(jù)這個(gè)時(shí)序要求,就可以通過軟件來模擬SD卡最底層的數(shù)據(jù)讀寫。圖1右側(cè)是寫一個(gè)字節(jié)的函數(shù),這個(gè)函數(shù)可以通過調(diào)節(jié)usleep(u32 nus)函數(shù)中的參數(shù)來調(diào)整SCLK的速度,從而達(dá)到了SPI寫一個(gè)字節(jié)速度可調(diào)的目的。同理可以寫出讀取一個(gè)字節(jié)的函數(shù),同樣可以根據(jù)usleep(u32 nus)中延時(shí)的參數(shù)不同來控制SPI讀取數(shù)據(jù)的速度。

  

001.jpg

  2.4SD卡的初始化

  有了SD卡底層的讀寫一個(gè)字節(jié)的函數(shù)之后,就可以與SD卡進(jìn)行通信了。根據(jù)SD卡的數(shù)據(jù)手冊(cè)可以總結(jié)出SD卡初始化的大致流程:首先需要給SD卡發(fā)送大于74個(gè)時(shí)鐘,這是因?yàn)镾D卡內(nèi)部有個(gè)供電電壓上升時(shí)間,大概為64個(gè)SCLK,剩下的10個(gè)SCLK用于SD卡同步,然后再發(fā)送CMD0使SD卡進(jìn)入IDLE狀態(tài);接著發(fā)送CMD8,檢查這個(gè)SD卡是否支持2.0協(xié)議;之后根據(jù)不同的應(yīng)答值檢查SD卡;最后初始化結(jié)束之后,需要多發(fā)8個(gè)SCLK使SD卡完成某些操作[4]。在完成初始化之后,就可以進(jìn)入SD卡的讀寫數(shù)據(jù)了。在調(diào)試過程中利用示波器看到的波形圖如圖2所示。然后對(duì)比手冊(cè)給出的發(fā)送命令和返回相應(yīng)的時(shí)序圖,可以驗(yàn)證以上模擬的SPI時(shí)序是否正確可行。

002.jpg

  圖2(a)是SD卡手冊(cè)給出的部分復(fù)位時(shí)序圖,正常情況下在主機(jī)發(fā)送CMD0之后,SD卡會(huì)返回主機(jī)0x01。圖2(b)是實(shí)際在示波器上面看到的時(shí)序,根據(jù)SD卡命令形式可以看出,NIOS II主機(jī)發(fā)送的6個(gè)命令字節(jié)分別是:第1個(gè)字節(jié):0x40(命令第一個(gè)字節(jié)最高兩位必須為01),Command = 0;第2~5個(gè)字節(jié):0x00,0x00,0x00,0x00為命令的參數(shù);第6個(gè)字節(jié):0x95命令CRC校驗(yàn) + 最低位的“1”。

  然后SD卡接收到NIOS II主機(jī)發(fā)送的CMD0命令之后,給出了一個(gè)0x01的應(yīng)答,從而可以看出,上述軟件模擬的SPI時(shí)序是正確的。

  2.5SD卡讀寫功能測(cè)試

  對(duì)SD卡初始化完成之后,就可以正常使用SD卡了。由于SD卡是存儲(chǔ)數(shù)據(jù)的設(shè)備,對(duì)SD的使用無非是讀數(shù)據(jù)和寫數(shù)據(jù)。有了上面寫命令和讀數(shù)據(jù)的基礎(chǔ)之后,就可以通過命令的形式來讀寫SD卡了。

  SD卡手冊(cè)規(guī)定,如果想讀SD卡某個(gè)扇區(qū)數(shù)據(jù),發(fā)送命令CMD17,參數(shù)為扇區(qū)數(shù),就可以讀出扇區(qū)內(nèi)的數(shù)據(jù)。寫扇區(qū)通過發(fā)送CMD24來實(shí)現(xiàn)。這里使用了兩個(gè)函數(shù),分別為讀一個(gè)扇區(qū)和寫一個(gè)扇區(qū)函數(shù):

  SD_ReadDisk(buf,0,1)//把扇區(qū)0的數(shù)據(jù)讀到buf中

  SD_WriteDisk(buf,0,1)//把buf中的數(shù)據(jù)寫到扇區(qū)0中

  由于SD卡是塊設(shè)備,在操作的時(shí)候需要一個(gè)扇區(qū)一個(gè)扇區(qū)地操作。在測(cè)試SD卡讀寫功能的時(shí)候,先對(duì)SD卡初始化,接著讀出原來0號(hào)扇區(qū)的數(shù)據(jù),然后再寫入數(shù)據(jù),最后再次讀出,經(jīng)過JTAG_UART的打印,可以看出是符合預(yù)期目標(biāo)的,所以讀寫函數(shù)功能正常。

3FATFS文件系統(tǒng)移植及SD卡速度測(cè)試

  前面只是對(duì)SD卡一個(gè)扇區(qū)的讀寫,而且讀寫都是數(shù)字。要真正有效地利用SD卡保存文件或者音樂等,必須使用文件系統(tǒng)管理。本文將使用FATFS來管理SD卡,實(shí)現(xiàn)SD卡文件的讀寫。FATFS是一個(gè)完全免費(fèi)并且開源的FAT文件系統(tǒng)模塊,用標(biāo)準(zhǔn)的C語言編寫,移植到各種嵌入式設(shè)備只需要進(jìn)行少量的修改。FATFS支持多個(gè)存儲(chǔ)媒介,有獨(dú)立的緩沖區(qū),可以對(duì)多個(gè)文件進(jìn)行讀寫。使用者無需去關(guān)心FATFS內(nèi)部復(fù)雜的協(xié)議,只需要像調(diào)用其提供的其他一系列應(yīng)用接口函數(shù)那樣就可以了。

  在移植使用的時(shí)候,只需要編寫底層FATFS提供的接口函數(shù),它主要包括存儲(chǔ)設(shè)備的讀函數(shù)、寫函數(shù)、初始化等,之后就可以輕松地使用。

  3.1FATFS移植步驟

  (1)在官網(wǎng)下載源碼,解壓。本文所使用的Eclipse編譯環(huán)境中的數(shù)據(jù)類型和源碼文件夾中integer.h里面的定義是一致的,所以不需要改動(dòng)。如果使用其他編譯器的數(shù)據(jù)類型不和源碼中的相同,就需要根據(jù)編譯器定義好數(shù)據(jù)類型。

  (2)在ffconf.h頭文件中修改相關(guān)配置。這里根據(jù)自己的要求,改變某些變量的值,就可以配置出適合自己需求的文件系統(tǒng)。

  (3)由于文件系統(tǒng)模塊完全與磁盤IO層分開,為了增加通用性,F(xiàn)ATFS的開發(fā)者并不確定用戶所用的存儲(chǔ)設(shè)備是哪一類,所以需要用戶自己提供相應(yīng)的底層操作函數(shù)。在diskio.c文件里面,F(xiàn)ATFS已經(jīng)提供了函數(shù)接口,只需要根據(jù)自己的存儲(chǔ)設(shè)備類型,把這些底層操作函數(shù)添加進(jìn)入即可。這里FATFS留出了6個(gè)函數(shù)接口。僅僅是為了驗(yàn)證本文的功能,本文只添加了三個(gè)函數(shù),其余函數(shù)都返回0。添加的函數(shù)為:disk_initialize,disk_read, disk_write。初始化函數(shù)和讀寫扇區(qū)函數(shù)在前面都已經(jīng)使用和測(cè)試過,只需要把這三個(gè)函數(shù)交給文件系統(tǒng)使用就可以了。

  3.2文件系統(tǒng)測(cè)試

  本文對(duì)文件系統(tǒng)的測(cè)試,首先調(diào)用FATFS提供的接口函數(shù)f_getfree來測(cè)試SD卡的總?cè)萘亢褪S嗳萘浚缓笤赟D卡中創(chuàng)建一個(gè)文件,最后顯示SD卡的容量,判斷FATFS文件系統(tǒng)測(cè)試的結(jié)果和實(shí)際的結(jié)果是否一致,再在PC上查看SD卡中是否有剛才創(chuàng)建的文件。本文所用SD卡容量為4 GB,調(diào)用FATFS文件系統(tǒng)提供的接口f_getfree函數(shù)之后,得到了SD卡的容量為3 716 MB,如圖3所示,與實(shí)際的容量是相符合的。

 

003.jpg

  3.3SD卡寫文件速度測(cè)試

  在移植文件系統(tǒng)之后,就可以輕松地使用SD卡來存儲(chǔ)文件了。這里限于硬件條件比較簡(jiǎn)單,所以只對(duì)SD卡寫文件的速度做一個(gè)大致的測(cè)試和估算。如前所述可以通過改變usleep(u32 nus)這個(gè)函數(shù)的參數(shù)來改變SD卡的讀寫速度。本文測(cè)試的方法是:向SD卡寫入100 KB大小的文件,記錄在不同參數(shù)下所用的時(shí)間。最后通過測(cè)試發(fā)現(xiàn),使用usleep(10)函數(shù)寫入100 KB的文件大致需要18 s;使用usleep(1)函數(shù)寫入100 KB的文件大致需要3 s。通過初略的估算,usleep(10)的情況下,數(shù)據(jù)率約為50 kb/s=6.125 kB/s,寫入100 KB內(nèi)容需要16.3 s,再加上SD卡初始化階段的一些通信命令和讀寫命令的開銷時(shí)間,可以認(rèn)為是在正常范圍。

  4結(jié)論

  本文在NIOS下利用軟件模擬SPI,對(duì)SD卡進(jìn)行了準(zhǔn)確的讀寫,然后移植FATFS文件系統(tǒng)來管理SD卡。提出了可以通過改變SPI SCLK的時(shí)鐘頻率來改變SD卡的讀寫速率,并且測(cè)試了在不同速率下SD卡寫文件的速率,可以解決在NIOS II下使用SPI不可改變SCLK速率的問題。

  參考文獻(xiàn)

  [1] SD Group. SD specifications part1: physical layer simplified specification version 2.0[Z].2006.

  [2] ALTERA. NIOS II processor Reference Handbook[Z].2014.

  [3] 蔡偉剛. NIOS II 軟件架構(gòu)解析[M].西安:西安電子科技大學(xué)出版社,2007.

  [4] 陳續(xù),鄧中亮.基于NIOS II的SD卡驅(qū)動(dòng)程序開發(fā)[J].電子設(shè)計(jì)工程,2010,18(5):107-110.


此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
久久久久综合| 欧美激情五月| 99精品久久久| 亚洲国产岛国毛片在线| 欧美一区二区三区视频在线| 亚洲性感美女99在线| 一本色道久久综合| aⅴ色国产欧美| 9l国产精品久久久久麻豆| 91久久一区二区| 亚洲激情电影在线| 亚洲国产清纯| 亚洲黄色影片| 日韩午夜激情av| 99精品视频免费观看视频| 日韩午夜在线视频| 一本色道综合亚洲| 亚洲婷婷综合久久一本伊一区| 一区二区三区四区在线| 在线视频精品一区| 亚洲一区影音先锋| 亚洲欧美色一区| 欧美一区二区三区视频免费| 欧美一区=区| 亚洲观看高清完整版在线观看| 亚洲电影观看| 亚洲日本中文字幕免费在线不卡| 亚洲另类视频| 亚洲视频1区2区| 亚洲欧美一区二区三区在线| 午夜影院日韩| 久久九九国产精品怡红院| 久久网站免费| 欧美高清不卡在线| 欧美日韩在线精品| 国产精品女主播在线观看| 国产欧美婷婷中文| 在线观看成人一级片| 亚洲精品日韩综合观看成人91| 夜夜嗨av色一区二区不卡| 亚洲欧美不卡| 亚洲国产一二三| 一本久久综合亚洲鲁鲁五月天| 亚洲欧美日韩精品久久| 久久国产精品第一页| 美女脱光内衣内裤视频久久影院| 欧美另类高清视频在线| 国产精品久久久久久久app| 国产综合色一区二区三区| 亚洲国产日韩欧美在线99| 99精品欧美一区二区三区综合在线| 亚洲一区二区三区中文字幕在线| 欧美在线视频免费观看| 99re热这里只有精品视频| 亚洲欧美春色| 玖玖综合伊人| 欧美亚洲第一页| 一区二区三区中文在线观看| 亚洲美女在线一区| 欧美在线视频观看| 一区二区三区国产| 久久久999精品免费| 欧美日韩岛国| 国产在线欧美| 一区二区三区导航| 亚洲大片在线观看| 亚洲欧美久久| 欧美极品影院| 国产亚洲欧洲| 一区二区三区 在线观看视频| 久久精品五月| 午夜电影亚洲| 欧美激情一区二区久久久| 国产精品一区二区你懂的| 亚洲第一区在线| 亚洲欧美日韩在线不卡| 99综合精品| 快射av在线播放一区| 国产精品久久久久一区二区三区共 | 久久理论片午夜琪琪电影网| 欧美午夜精品久久久久久久| 影音先锋亚洲电影| 午夜欧美电影在线观看| 亚洲一区二区高清| 欧美成人中文字幕| 狠狠色丁香久久婷婷综合丁香| 亚洲最黄网站| 亚洲肉体裸体xxxx137| 久久久7777| 国产精品美女| 日韩亚洲一区在线播放| 亚洲破处大片| 久久久久久久一区二区三区| 国产精品久久婷婷六月丁香| 亚洲国产乱码最新视频| 欧美亚洲一区二区在线| 亚洲欧美日韩另类| 欧美人与性禽动交情品| 在线不卡中文字幕| 欧美一区二视频| 亚洲专区在线| 欧美日韩午夜剧场| 最新国产の精品合集bt伙计| 亚洲高清二区| 久久偷窥视频| 一区二区在线视频观看| 欧美一区二区女人| 午夜精品一区二区三区在线播放 | 国产精品人人爽人人做我的可爱| 亚洲国产影院| 亚洲欧洲日本一区二区三区| 久久久久久久久久久一区| 国产日韩精品一区二区三区在线 | 欧美激情亚洲综合一区| 在线不卡免费欧美| 亚洲福利久久| 美女精品一区| 在线不卡中文字幕| 亚洲国产一区二区三区在线播 | 伊人婷婷久久| 亚洲激情av| 欧美第一黄网免费网站| 在线精品视频一区二区三四| 久久精品一区二区三区四区| 久久夜色精品国产亚洲aⅴ | 亚洲国产乱码最新视频| 99riav1国产精品视频| 欧美日韩国产专区| 99香蕉国产精品偷在线观看| 中文一区字幕| 国产精品v日韩精品v欧美精品网站| 一区二区免费在线播放| 亚洲小说区图片区| 国产精品久久国产三级国电话系列| 亚洲图中文字幕| 欧美一站二站| 狠狠色狠色综合曰曰| 亚洲国产精品久久久久秋霞不卡| 久久五月天婷婷| 亚洲激情视频在线| 亚洲视频久久| 国产精品午夜在线| 久久av资源网| 欧美黄色网络| 日韩视频精品在线| 欧美亚洲一区| 国内久久视频| 99精品99| 国产精品爽爽爽| 久久精品国产999大香线蕉| 欧美成黄导航| 夜夜夜久久久| 久久国产一区| 亚洲福利在线视频| 亚洲午夜视频| 国产偷国产偷亚洲高清97cao| 亚洲国产导航| 欧美午夜在线观看| 欧美一区二区三区免费视| 欧美国产日韩免费| 中文在线不卡| 久久这里有精品15一区二区三区| 伊人激情综合| 亚洲午夜精品久久| 国产伊人精品| 一区二区电影免费观看| 国产精品扒开腿做爽爽爽视频| 欧美一级片一区| 欧美激情亚洲激情| 亚洲欧美在线一区| 欧美精品久久一区| 亚洲伊人一本大道中文字幕| 久久综合九色| 在线视频免费在线观看一区二区| 久久九九热re6这里有精品| 亚洲日本激情| 久久久综合网站| av成人老司机| 蜜桃精品久久久久久久免费影院| 在线午夜精品| 欧美成人精品| 香蕉亚洲视频| 欧美午夜激情在线| 亚洲第一精品夜夜躁人人爽 | 亚洲视频专区在线| 久久手机免费观看| 亚洲一区二区伦理| 欧美多人爱爱视频网站| 亚洲综合日韩在线| 欧美区在线观看| 久久gogo国模啪啪人体图| 欧美日韩国产在线播放网站| 久久精品亚洲一区二区| 国产精品美女一区二区在线观看| 亚洲国产视频直播| 国产欧美韩国高清| 中文精品视频| 亚洲国产日韩在线| 久久精品人人爽| 亚洲一级免费视频|