《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 基于ARM嵌入式系統的SPI驅動程序設計
基于ARM嵌入式系統的SPI驅動程序設計
來源:微型機與應用2011年第5期
李 琦,賀 明,董利民,董 健
(北京工業大學 集成電路與系統集成實驗室,北京 100124)
摘要: 以微處理器S3C2440和嵌入式Linux操作系統組成的嵌入式系統作為主要開發平臺,根據SPI通信原理和S3C2440電路接口的特點,設計了一款基于ARM嵌入式系統的SPI驅動程序。討論了SPI驅動程序的基本開發方法和實現過程,通過編寫簡單的測試程序進行仿真驗證。驗證結果表明該驅動程序穩定可靠,可實現嵌入式系統的數據通信。
Abstract:
Key words :

摘  要: 以微處理器S3C2440嵌入式Linux操作系統組成的嵌入式系統作為主要開發平臺,根據SPI通信原理和S3C2440電路接口的特點,設計了一款基于ARM嵌入式系統的SPI驅動程序。討論了SPI驅動程序的基本開發方法和實現過程,通過編寫簡單的測試程序進行仿真驗證。驗證結果表明該驅動程序穩定可靠,可實現嵌入式系統的數據通信。
關鍵詞: S3C2440;嵌入式Linux;SPI;驅動程序

 嵌入式系統已被廣泛應用于國防電子、數字家庭、工業自動化、汽車電子等多種領域[1]。在嵌入式開發過程中,許多系統通常使用串口驅動來滿足通信要求,但在實際應用中,使用SPI通信方式會更加高效和快捷[2]。SPI接口是一種高速、高效的串行接口技術,因而SPI設備在數據通信應用中十分方便[3]。本文基于ARM9芯片的S3C2440和Linux操作系統,設計了一種SPI驅動程序,該驅動程序功能可靠靈活、易于移植,可應用于多種嵌入式平臺,實現ARM與設備之間的通信。
1 硬件說明
1.1 S3C2440開發平臺

 采用三星公司的SoC芯片S3C2440[4]作為核心處理器,主頻為400 MHz,并與64 MB SDRAM和64 MB NAND Flash共同組成核心部分。此外,該平臺也為用戶提供了大量的通信、顯示、調試以及I/O接口。為滿足設計需要,將Linux2.6.21版內核移植于該平臺上。
1.2 SPI硬件模塊
 S3C2440具有兩個SPI,每個SPI具有兩個8位移位寄存器用于獨立地發送和接收數據,并兼容SPI ver.2.11協議,支持8位邏輯預分頻,系統可用polling、中斷、DMA三種方式判斷SPI發送及接收狀態。此SPI模塊共包含以下信號線[5]:
 (1)SCK:數據同步時鐘信號,由主設備驅動,向從設備輸出,使得從設備按照同步時鐘的步調來接收或發送數據。
    (2)nCS(由用戶指定GPIO):從設備選擇信號線(Slave Select,SS)由主設備發出,用來選擇激活某個從設備,低電平有效。
 (3)MISO(SPIMISO0):主入從出信號線,表示該信號在主設備中作為輸入,在從設備中作為輸出。
 (4)MOSI(SPIMOSI0):主出從入信號線,表示該信號在主設備中作為輸出,在從設備中作為輸入。
 (5)/SS(nSS):多主錯誤檢測。
2 Linux下的SPI設備驅動程序設計
 Linux設備驅動在Linux內核中扮演著重要的角色。它可使某些特定硬件響應一個定義良好的內部編程接口,這些接口完全隱藏了設備工作的細節。用戶操作可通過一組標準化的調用來執行,這些調用在形式上完全獨立于特定的驅動程序,而將這些調用映射到實際硬件設備的特有操作上,則是驅動程序的任務[6]。本設計的SPI驅動主要定義了初始化、讀和寫三個操作。其中初始化操作用于驅動程序第一次加載到內核運行時,對一些內核機制及存儲器進行初始化。寫操作負責將用戶數據拷貝至內核緩沖區,控制本地主SPI發送數據至從SPI寄存器中。讀操作將按照用戶要求讀取的字節數,連續讀取本地主SPI中接收到的數據,并將其拷貝至用戶空間。驅動程序將采用中斷的方式通知系統SPI數據是否發送完畢,即當SPI硬件模塊每發送完畢一個數據,都會通過中斷線向系統發起中斷,系統響應中斷后,驅動程序將調用中斷處理例程。
2.1 SPI初始化
 (1)申請中斷。此驅動設計通過中斷判斷數據是否發送完畢,所以需要申請SPI0相關的中斷,并注冊相應的中斷處理函數。此驅動程序的中斷處理函數聲明如下:
 static irqreturn_t s3c2440_isr_spi(int irq,void*dev_id,struct pt_regs*reg)
 利用request_irq向內核申請中斷號并注冊中斷處理函數:
 request_irq(IRQ_SPI0,s3c2440_isr_spi,SA_INTERRUPT,DEVICE_NAME,s3c2440_isr_spi);
 (2)虛擬地址映射。驅動程序可以直接通過訪問內核中的虛擬地址來訪問設備物理地址所對應的寄存器,對其進行操作。SPI設備的地址映射過程如下:
 request_mem_region(S3C2440_PA_SPI,0x30,"s3c2440-spi");
base_addr = ioremap(S3C2440_PA_SPI,0x30);
 其中S3C2440_PA_SPI為SPI的物理地址(在/asm-arch/arch-s3c2440/map.h中定義),從S3C2440_PA_SPI開始分配0x30大小的內存區域,此后將其移至內核空間。
 (3)相關寄存器的設置。通過配置SPI功能寄存器設置SPI工作模式。以ioremap返回的虛擬地址為基址,通過增加不同偏移量訪問相應寄存器。本次設計將本地SPI設為主設備,開啟SCK信號使能,設定CPOL和CPHA均為0,SPI工作在普通模式下。設置波特率預分頻寄存器(SPPRE)中的分頻比為8。具體設計如下:
 __raw_writel((S3C2440_SPCON_SMOD_INT|S3C2440_SPCON_ENSCK|S3C2440_SPCON_MSTR), s3c2440_SPCON);
 DPRINTK(DEVICE_NAME"SPCON initialize\n");
 __raw_writel((S3C2440_SPPIN_ENMUL | S3C2440_SPPIN_KEEP),s3c2440_SPPIN);
 DPRINTK(DEVICE_NAME"SPPIN initialize\n");
 __raw_writel(0x07,s3c2440_SPPRE);
 DPRINTK(DEVICE_NAME"SPPRE initialize\n");
 (4)初始化發送和接收數據緩沖區。數據緩沖區使用環形緩沖區結構,通過頭尾指針的循環移動,實現對緩沖區的動態管理。其定義如下:
 typedef struct
    {
        spi_buf buf[MAX_SPI_BUF];
        unsigned int head, tail;
        wait_queue_head_t wq;
    } SPI_BUF;  static SPI_BUF spi_Tx_buf;static                SPI_BUF spi_Rec_buf;
 其中spi_buf表示char型,MAX_SPI_BUF為緩沖區大小,設為1 024 B。head、tail分別表示頭尾數組下標,wq為等待隊列頭。此結構依靠以下宏進行管理:
 #define SPI_Tx_BUF_HEAD(spi_Tx_buf.buf[spi_Tx_buf.head])
 #define SPI_Tx_BUF_TAIL(spi_Tx_buf.buf[spi_Tx_buf.tail])
 #define INCBUF(x,mod)((++(x))&((mod)-1))
 前兩個宏用于引用緩沖區中的元素,最后一個宏用于對頭尾下標進行前移,并保證頭尾下標數值可循環變化,不發生溢出。
 在初始化時,分別對接收和發送緩沖區的頭尾指針進行清零操作,具體如下:
spi_Tx_buf.head=spi_Tx_buf.tail=0;spi_Rec_buf.head=spi_Rec_buf.tail = 0;
 (5)內核機制相關的數據結構初始化。本設計所使用的內核機制包括了中斷上下半部的操作和睡眠等待機制,因此需要對發送、接收等待隊列以及tasklet結構進行初始化,并注冊tasklet處理函數。初始化過程如下:
 init_waitqueue_head(&(spi_Tx_buf.wq));   
 init_waitqueue_head(&(spi_Rec_buf.wq));
 tasklet_init(&spi_tasklet,spi_tasklet_handler,data);
 (6)初始化相應端口。根據S3C2440外部管腳配置,將與SPI功能引腳復用的GPIO設定為SPI相應功能。具體操作如下:
 s3c2440_gpio_cfgpin
 (S3C2440_GPE11,S3C2440_GPE11_SPIMISO0);
 s3c2440_gpio_cfgpin
 (S3C2440_GPE12,S3C2440_GPE12_SPIMOSI0);
 s3c2440_gpio_cfgpin
 (S3C2440_GPE13,S3C2440_GPE13_SPICLK0);
 s3c2440_gpio_cfgpin
 (S3C2440_GPG2,S3C2440_GPG2_INP);//設置nSS
 s3c2440_gpio_cfgpin(S3C2440_GPB10,
 S3C2440_GPB10_OUTP);    //設置片選信號
 s3c2440_gpio_setpin(S3C2440_GPB10,1);
2.2 SPI寫操作
 寫操作主要是將上層應用部分的用戶空間中的數據拷貝到內核空間中的環形緩沖區中,此后將緩沖區的數據送到SPI發送寄存器中,在SPI發送完一個數據后,系統產生中斷,中斷例程中的下半部將調用tasklet判斷緩沖區狀態。若緩沖區中有相應的空間,可以將下一數據填入SPI發送寄存器中,直至將緩沖區數據全部發送完畢。
 本設計的寫操作實現了環形緩沖區的動態管理,即在緩沖區刪除數據、尾指針前移的情況下,允許向緩沖區添加數據,頭指針前移。此設計可以使用戶空間任務與內核空間的數據發送同時進行,提高了用戶空間任務執行效率,并且當利用copy_from_user函數將數據從用戶空間拷貝至內核空間時,數據發送仍在進行,即數據從用戶空間至內核空間拷貝過程與數據發送過程并發,提高了驅動程序效率。
 為了實現環形緩沖區動態管理,定義了copy_to_Tx_buf_init和copy_to_Tx_buf兩個函數完成數據向緩沖區的復制操作。
 (1)copy_to_Tx_buf_init函數。本函數主要用于兩種情況:
?、偃绻彌_區為空,當有一組數據到來且此數據的大小小于緩沖區的空間大小時,直接將此數據放到緩沖區中。
?、谌绻l送數據的大小大于剩余緩沖區的空間,則只復制緩沖區大小的數據到緩沖區。
緩沖區滿,該進程進行睡眠操作,直到緩沖區所有數據發送完畢,緩沖區再次為空,當前進程被喚醒,將此組用戶數據的未發送部分復制到緩沖區,繼續發送。
 (2)copy_to_Tx_buf函數。此函數主要用于緩沖區正在發送且未發送完畢的情況,將新一組用戶數據copy至緩沖區。首先計算緩沖區剩余空間,若剩余空間大于本組用戶數據大小,則直接將用戶數據全部copy至緩沖區;若剩余空間小于本組數據大小,則copy與剩余空間大小相同的用戶數據至緩沖區。
 寫操作的具體流程如圖1所示,首先用戶數據從空間態轉換到內核態,并設置相應的接收標志位。此后判斷數據大小。若數據大于緩沖區空間,數據發生溢出,寫操作結束;若沒有溢出,為了保證進程間的數據,使得該進程獲得自旋鎖,此時判斷緩沖區是否為空。根據上面兩個函數的介紹,在不同情況下分別調用不同的函數,在數據寫入環形緩沖區后,將數據發送到SPI的發送寄存器。當SPI發送寄存器發送數據時,環形緩沖區依舊接收數據,如果此時緩沖區為滿,則釋放自旋鎖,并設置進程等待標志位(wait_Tx_done),將此進程休眠,直到發送寄存器中的數據發送完畢,再喚醒進程,判斷數據是否全部發送完畢。若仍有數據等待發送,則調用copy_to_Tx_buf_int;若數據已全部發送完畢,則寫操作結束。若緩沖區不為滿,則判斷數據是否發送完畢。數據全部發送完畢,發送操作結束。

2.3 SPI讀操作
 讀操作是連續讀取主SPI發送到從SPI的接收緩沖區中的數據,并將其傳送給用戶空間。具體流程如圖2所示。首先判斷操作標志位spi_Rec_en,若此位為0,說明此時驅動正處于發送狀態,則將發送進程等待標志位(wait_Tx_done)置1,讀進程進入休眠狀態即放入等待隊列中,等待中斷處理函數中相關發送程序喚醒。若操作標志位不為1,讀進程首先獲得自旋鎖,判斷數據大小。若數據大小不為0且不超過緩沖區大小,則按照S3C2440接收數據的要求,向SPI發送寄存器寫入第一個dummy數據(0xff)。此后,將接收進程等待標志位(wait_Rec_done)置1,釋放自旋鎖,并將此進程加入等待隊列進行休眠,直到用戶要求的所有數據已發送至接收緩沖區后,由中斷處理函數喚醒該進程,最后將接收區中的數據放到臨時接收緩存中,以便于其他操作讀取。

3 SPI驅動程序測試
 SPI驅動程序主要通過調用寫操作,使SPI連續發送數據0x55,此后再調用SPI讀操作,將MISO上的串行數據讀入用戶緩沖區,并與實際數據進行比較。圖3為示波器測試MOSI引腳波形。圖中波形1為SCK信號,ARM系統時鐘為40 MHz,SPI的SCK信號為系統時鐘的256分頻,約為156 kHz;波形2為MOSI信號,SPI從低位向高位串行移位。通過波形可以看出,SPI驅動能夠準確地完成讀寫操作,驗證了其正確性。

 本文以S3C2440為硬件開發平臺,采用嵌入式Linux操作系統驅動設計方法,設計了一款通用的SPI驅動程序,并通過編寫簡單測試程序,觀察示波器輸出波形驗證。該驅動程序可以使微處理器和外設之間進行穩定可靠的數據傳輸,具有功能靈活、可移植性強、可靠性高等特點,有一定的使用價值和借鑒意義。
參考文獻
[1] 孫天澤,袁文菊.嵌入式設計及Linux驅動開發指南—基于ARM9處理器(第3版)[M].北京:電子工業出版社,2009.
[2] 張曉雷,陳曉寧,郭劍.嵌入式Linux下基于SPI總線的網絡設備驅動設計與實現[J].計算機工程與設計,2008,29(23).
[3] 沃爾瓦諾.嵌入式微機算機系統:實時接口技術[M].李森譯.北京:機械工業出版社,2008.
[4] S3C2440A 32-Bit CMOS Microcontroller User’s Manual, Revision 2. Samsung Electronics. 2008.
[5] 徐英慧.ARM9嵌入式系統設計—基于S3C2440與Linux[M].北京:北京航空航天大學出版社,2008.
[6] CORBET J, RUBINI A, KROAH-HARTMAN G. LINUX設備驅動程序(第三版)[M].魏永明,耿岳,鐘書毅,譯.北京:中國電力出版社,2009.

此內容為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>
          久久久久欧美精品| 午夜亚洲性色福利视频| 久久免费视频在线观看| 欧美日韩你懂的| 亚洲欧美精品在线| 日韩午夜激情电影| 欧美大学生性色视频| 亚洲视频精品在线| 欧美日韩精品高清| 韩日午夜在线资源一区二区| 欧美大片在线看| 欧美激情综合亚洲一二区| 中日韩高清电影网| 亚洲第一在线| 久久久久久久久久久久久女国产乱| 亚洲一区影院| 狠狠色综合网| 亚洲欧美日本视频在线观看| 欧美一区二区三区视频| 亚洲女人av| 久久久久久久成人| 亚洲欧洲99久久| 亚洲欧洲一区二区在线播放| 亚洲高清免费在线| 麻豆成人综合网| 欧美性事免费在线观看| 久久青青草综合| 亚洲一区二区三区乱码aⅴ蜜桃女| 免费成人网www| 亚洲欧美日韩精品久久| 久久精品在线视频| 亚洲日本国产| 亚洲欧美日韩国产综合| 久久国产欧美| 欧美激情中文字幕在线| 久久久久久久久久看片| 尤物九九久久国产精品的分类| 亚洲欧洲日本mm| 欧美激情一区二区三级高清视频| 亚洲一区二区在线免费观看视频| 夜夜嗨av一区二区三区免费区| 中文亚洲视频在线| 久久精品一区二区| 亚洲一二三区视频在线观看| 欧美激情影院| 国产精品久久久久一区二区三区| 欧美激情第六页| 久久女同互慰一区二区三区| 亚洲国产精品日韩| 亚洲欧美日韩综合aⅴ视频| 国产精品99久久久久久宅男| 欧美日韩国产一中文字不卡| av成人激情| 亚洲人成在线免费观看| 亚洲婷婷综合久久一本伊一区| 久久九九精品| 狠久久av成人天堂| 亚洲精品一区在线| 亚洲免费在线观看视频| 欧美日韩午夜在线视频| 欧美色区777第一页| 精品成人一区| 悠悠资源网久久精品| 国产在线视频欧美一区二区三区| 99伊人成综合| 亚洲免费在线| 欧美日韩国内自拍| 欧美日产一区二区三区在线观看| 欧美成人激情视频免费观看| 欧美视频官网| 欧美日韩国产91| 国产日韩精品入口| 国产一二精品视频| 欧美精品激情在线观看| 久久久精品国产99久久精品芒果| 狠狠色狠色综合曰曰| 亚洲精品乱码久久久久久日本蜜臀| 欧美大片在线影院| 久久免费一区| 狠狠色伊人亚洲综合网站色| 久久精品国产99国产精品澳门| 欧美精品久久久久久久久老牛影院| 亚洲欧美激情一区| 最新日韩精品| 国内欧美视频一区二区| 国产亚洲欧美日韩美女| 国产一区免费视频| 免费在线观看一区二区| 久久一二三国产| 欧美亚洲成人免费| 亚洲国产精品成人va在线观看| 国产精品99久久99久久久二8| 亚洲国产精品va在线看黑人动漫| 久久精品女人| 亚洲国产精品视频一区| 在线播放亚洲一区| 亚洲美女淫视频| 亚洲欧美久久久| 一区二区三区在线免费观看| 日韩一区二区久久| 欧美三级电影大全| 欧美一区在线直播| 久久久久久日产精品| 久久精品论坛| 欧美日韩精品在线视频| 夜夜狂射影院欧美极品| 久久欧美肥婆一二区| 久久久91精品国产一区二区三区| 欧美一级理论性理论a| 欧美14一18处毛片| 亚洲国产经典视频| 伊人成人在线| 午夜精品一区二区三区电影天堂| 亚洲品质自拍| 国产精品久久99| 在线免费观看欧美| 亚洲激情电影中文字幕| 久久久精品999| 亚洲夜间福利| 亚洲精品一区在线观看| 国产精品国产自产拍高清av王其| 国产精品综合av一区二区国产馆| 亚洲乱码国产乱码精品精天堂| 国产日产欧美a一级在线| 国产一二三精品| 老牛影视一区二区三区| 久久爱另类一区二区小说| 亚洲午夜免费视频| 在线观看国产精品网站| 亚洲一区二区三区在线| 亚洲国产精品小视频| 国产精品一页| 一色屋精品视频在线观看网站| 亚洲精品资源| 欧美日韩系列| 欧美日韩国产在线播放网站| 午夜精品久久99蜜桃的功能介绍| 欧美激情一区二区三区在线视频观看| 欧美一区二区在线播放| 欧美jizzhd精品欧美巨大免费| 国产一区二区观看| 国语自产精品视频在线看抢先版结局| 一区二区视频在线观看| 女同性一区二区三区人了人一| 久久疯狂做爰流白浆xx| 激情五月综合色婷婷一区二区| 国产日韩视频| 亚洲日本中文字幕免费在线不卡| 一本在线高清不卡dvd| 在线播放一区| 亚洲成人在线网站| 你懂的视频一区二区| 韩国精品久久久999| 国产日韩欧美中文在线播放| 国产日韩欧美综合精品| 欧美日韩精品一区视频| 亚洲欧美制服另类日韩| 一区二区三区欧美日韩| 国产精品一区三区| 国产欧美婷婷中文| 激情视频一区二区| 男女av一区三区二区色多| 欧美日韩一区二区视频在线| 午夜在线不卡| 久久精品国产清自在天天线| 欧美亚洲综合网| 亚洲美女毛片| 欧美精品电影在线| 蜜桃av一区二区三区| 亚洲国产精品尤物yw在线观看| 国产精品乱码久久久久久| 国产精品r级在线| 亚洲国产精品成人精品| 久久亚洲图片| 亚洲国产欧美在线| 在线亚洲+欧美+日本专区| 久久久久久久91| 亚洲第一精品在线| 欧美成年人网| 午夜精品偷拍| 国产精品国产a| 国产精品久久久久一区| 激情久久久久久久久久久久久久久久| 国产精品揄拍一区二区| 欧美激情第9页| 国产精品va在线播放我和闺蜜| 日韩视频永久免费| 夜夜嗨av一区二区三区四区| 亚洲福利视频一区| 亚洲国产精品久久久| 亚洲三级性片| 久久婷婷综合激情| 久久国产免费看| 国产一区二区福利| 国产精品专区一| 欧美午夜精品电影| 亚洲电影免费观看高清| 久久在精品线影院精品国产| 精品999久久久| 国产伦精品一区二区三区高清版| 91久久久亚洲精品| 久久久久久久尹人综合网亚洲| 欧美成人自拍视频| 亚洲视频在线观看三级| 欧美色精品天天在线观看视频| 久久综合色天天久久综合图片| 国产精品视频成人| 久久这里只有精品视频首页| 欧美一区日本一区韩国一区| 亚洲综合色激情五月| 欧美日韩一二三区| 激情一区二区| 久久青草福利网站| 国产一区香蕉久久| 美日韩精品视频免费看| 亚洲人成亚洲人成在线观看| 日韩亚洲精品视频| 老色鬼精品视频在线观看播放| 午夜在线电影亚洲一区| 欧美日本精品一区二区三区| 久久久91精品国产一区二区三区| 在线一区二区三区四区五区| 久久精品国产免费看久久精品| 久久精品女人天堂| 久久精品国产99精品国产亚洲性色| 欧美日韩免费观看一区二区三区| 国产精品久久午夜夜伦鲁鲁| 亚洲精品国产视频| 欧美网站大全在线观看| 欧美午夜剧场| 国产精品vvv| 久久综合色天天久久综合图片| 亚洲一区二区三区视频| 国产精品家教| 亚洲免费不卡| 影视先锋久久| 亚洲电影中文字幕| 在线亚洲电影| 一区二区电影免费在线观看| 亚洲欧洲精品一区二区精品久久久| 欧美大片国产精品| 国产精品视频yy9299一区| 亚洲综合电影一区二区三区| 国产精品高清一区二区三区| 99国产欧美久久久精品| 亚洲精品视频在线看| 尤物精品国产第一福利三区| 欧美中文字幕不卡| 亚洲一区二区免费在线| 亚洲福利视频网站| 一本一本久久| 国产精品腿扒开做爽爽爽挤奶网站| 午夜精品剧场| 国产日韩欧美综合在线| 国产色综合网| 亚洲成人在线网站| 老司机精品视频网站| 亚洲欧美日韩一区在线观看| 国产精品一区二区三区成人| 久久久亚洲国产美女国产盗摄| 久久亚洲国产精品日日av夜夜| 欧美日韩在线播放| 欧美精品一区在线| 免费成年人欧美视频| 一区二区日韩欧美| 嫩草伊人久久精品少妇av杨幂| 亚洲午夜视频在线| 欧美福利电影在线观看| 巨胸喷奶水www久久久免费动漫| 在线精品一区二区| 欧美伦理影院| 欧美日本免费一区二区三区| 国产精品国产三级国产专播品爱网| 国产综合精品| 亚洲影视在线播放| 亚洲国产视频一区| 欧美一区二区日韩| 一区二区三区欧美成人| 国产乱码精品一区二区三区不卡| 亚洲国产精品v| 国产主播一区二区三区四区| 亚洲国产精品99久久久久久久久| 久久久久成人精品免费播放动漫| 欧美日韩国产成人在线免费| 亚洲国产精品一区二区第一页| 欧美第一黄网免费网站| 久久成人一区二区| 久久精品最新地址| 国产精品高潮呻吟久久av无限| 欧美+亚洲+精品+三区| 黑丝一区二区三区| 99综合在线| 亚洲欧洲午夜| 免费日韩视频| 国产欧美日本一区视频| 亚洲精一区二区三区| 国产一区日韩二区欧美三区| 性色av一区二区三区在线观看| 亚洲欧洲日本在线| 日韩视频在线永久播放| 亚洲综合色激情五月| 久久综合久久久| 你懂的视频一区二区| 欧美在线播放一区| 六月婷婷一区| 国产麻豆精品久久一二三| 亚洲啪啪91| 久久久久国产一区二区三区四区| 亚洲私人影院在线观看| 欧美日韩一区二区在线视频| 国产精品在线看| 91久久精品国产91久久| 美女主播视频一区| 国产精品99久久久久久有的能看| 欧美国产日韩一区| 国产乱码精品一区二区三区忘忧草| 国产欧美在线看| 国产农村妇女毛片精品久久莱园子| 欧美jizzhd精品欧美巨大免费| 亚洲国产成人精品久久久国产成人一区| 欧美激情综合在线| 国产精品视频午夜| 亚洲小少妇裸体bbw| 韩日欧美一区| 国产精品理论片| 欧美在线一级视频| 免费视频一区| 有码中文亚洲精品|