《電子技術(shù)應(yīng)用》
您所在的位置:首頁(yè) > 測(cè)試測(cè)量 > 設(shè)計(jì)應(yīng)用 > 基于LABVIEW平臺(tái)的數(shù)據(jù)采集卡軟件設(shè)計(jì)
基于LABVIEW平臺(tái)的數(shù)據(jù)采集卡軟件設(shè)計(jì)
摘要: 由于采用數(shù)據(jù)流模型,LABVIEW可以自動(dòng)規(guī)劃多線程任務(wù),可充分利用PC系統(tǒng)處理器的處理能力,從而提高模塊的采集效率。本文基于LABVIEW開(kāi)發(fā)環(huán)境,以庫(kù)函數(shù)節(jié)點(diǎn)的調(diào)用方式及結(jié)構(gòu),實(shí)現(xiàn)了一種中頻數(shù)據(jù)采集與處理卡軟件的設(shè)計(jì)。
Abstract:
Key words :

  引言

  作為專業(yè)測(cè)控領(lǐng)域的軟件開(kāi)發(fā)平臺(tái),LABVIEW內(nèi)含豐富的數(shù)據(jù)采集、數(shù)據(jù)信號(hào)分析以及功能強(qiáng)大的DAQ助手,搭建數(shù)據(jù)采集系統(tǒng)更為輕松,便于硬件設(shè)計(jì)人員直接對(duì)硬件的操控展開(kāi)設(shè)計(jì)。此外,它可通過(guò)DLL、CIN節(jié)點(diǎn)、ActiveX、.NET或MATLAB腳本節(jié)點(diǎn)等技術(shù),實(shí)現(xiàn)與其它編程語(yǔ)言混合編程,通過(guò)調(diào)用外部驅(qū)動(dòng)代碼使它與設(shè)備的連接變得非常容易。由于采用數(shù)據(jù)流模型,LABVIEW可以自動(dòng)規(guī)劃多線程任務(wù),可充分利用PC系統(tǒng)處理器的處理能力,從而提高模塊的采集效率。本文基于LABVIEW開(kāi)發(fā)環(huán)境,以庫(kù)函數(shù)節(jié)點(diǎn)的調(diào)用方式及結(jié)構(gòu),實(shí)現(xiàn)了一種中頻數(shù)據(jù)采集與處理卡軟件的設(shè)計(jì)。

  數(shù)據(jù)采集卡軟件結(jié)構(gòu)

  采集卡軟件是基于PC的數(shù)據(jù)采集系統(tǒng)重要組成部分,它與硬件形成一個(gè)完整的數(shù)據(jù)采集、分析和顯示系統(tǒng),軟件分為上層應(yīng)用程序和驅(qū)動(dòng)程序。上層應(yīng)用程序用以完成數(shù)據(jù)的分析、存儲(chǔ)和顯示等。驅(qū)動(dòng)程序則可直接對(duì)數(shù)據(jù)采集硬件的寄存器編程,管理數(shù)據(jù)采集硬件的操作并把它和處理器中斷、DMA和內(nèi)存這些計(jì)算機(jī)資源結(jié)合在一起。

  驅(qū)動(dòng)程序隱藏了復(fù)雜的硬件底層編程細(xì)節(jié),為用戶提供容易理解的接口。NI公司為基于NI數(shù)據(jù)采集設(shè)備的數(shù)據(jù)采集系統(tǒng)提供了相應(yīng)的接口驅(qū)動(dòng)及VI函數(shù) (VI,Virtual Instrument)。對(duì)于一些不常見(jiàn)的硬件設(shè)備或用戶研發(fā)的硬件設(shè)備,NI沒(méi)有提供合適的驅(qū)動(dòng)。但是,如前所述,LABVIEW還提供了很多其它的通信接口,包括調(diào)用庫(kù)函數(shù)節(jié)點(diǎn)(Call Library Function Node, CLF)、代碼接口節(jié)點(diǎn)(Code Interface Node, CIN)、TCP/IP、Data Socket、OPC、共享變量、DDE和.NET等。通過(guò)這些通信接口,LABVIEW能夠?qū)崿F(xiàn)與任何設(shè)備的通信。值得留意的是LABVIEW具有調(diào)用庫(kù)函數(shù)節(jié)點(diǎn)和代碼接口節(jié)點(diǎn)兩種方法,可以結(jié)合C語(yǔ)言的編程靈活性和LABVIEW G語(yǔ)言的直觀便捷特點(diǎn),大幅提高LABVIEW對(duì)用戶數(shù)據(jù)采集卡的軟件設(shè)計(jì)支持。可進(jìn)一步利用LABVIEW豐富的數(shù)據(jù)分析資源,節(jié)約系統(tǒng)開(kāi)發(fā)成本。

  LABVIEW提供的數(shù)據(jù)采集卡的常用驅(qū)動(dòng)方式有兩種,調(diào)用C語(yǔ)言源代碼方式(CIN方式),以及調(diào)用動(dòng)態(tài)鏈接庫(kù)方式(CLF方式)。

  CIN方式是實(shí)現(xiàn)LABVIEW與C語(yǔ)言混合編程的一種媒介,CIN通過(guò)輸入、輸出端口實(shí)現(xiàn)兩種語(yǔ)言之間的數(shù)據(jù)傳遞。輸入、輸出端口的個(gè)數(shù)可由設(shè)計(jì)者根據(jù)實(shí)際需要確定,當(dāng)LABVIEW的程序運(yùn)行到CIN節(jié)點(diǎn)時(shí),數(shù)據(jù)由CIN的輸入端口傳遞給C源代碼圖標(biāo),程序轉(zhuǎn)去執(zhí)行C源代碼,代碼執(zhí)行完后,執(zhí)行的數(shù)據(jù)結(jié)果由CIN輸出端口返回至LABVIEW。

  CLF是一種動(dòng)態(tài)鏈接庫(kù)(DLL)的調(diào)用方式。DLL是一種應(yīng)用程序在運(yùn)行時(shí)與庫(kù)文件連接起來(lái)的技術(shù),在WINDOWS的管理下,應(yīng)用程序與對(duì)應(yīng)DLL之間建立鏈接關(guān)系,根據(jù)鏈接產(chǎn)生的重定位信息,轉(zhuǎn)去執(zhí)行DLL中相應(yīng)的代碼。LABVIEW中,可通過(guò)CLF(調(diào)用路徑為Function>>Advanced>>Call Library Function)功能模塊實(shí)現(xiàn)調(diào)用。

  調(diào)用CIN節(jié)點(diǎn)需要有C語(yǔ)言編程的支持,它能夠?qū)⒋a集成在VI中作為單獨(dú)的一個(gè)VI發(fā)布,CIN 支持的參數(shù)類型比DLL 函數(shù)多,可使用LABVIEW 定義的任何參數(shù)類型,但制作CIN的過(guò)程復(fù)雜得多。使用這種方法的缺點(diǎn)是在數(shù)據(jù)采集過(guò)程中不能實(shí)時(shí)地進(jìn)行數(shù)據(jù)的顯示,只能在數(shù)據(jù)全部采集結(jié)束后再一起顯示所采集的全部數(shù)據(jù),這樣在需要較高執(zhí)行效率的場(chǎng)合就不適用。其次由于CIN節(jié)點(diǎn)在制作數(shù)據(jù)采集卡的驅(qū)動(dòng)時(shí),需要提供采集卡的硬件參數(shù),需編制對(duì)硬件設(shè)備進(jìn)行底層操作的庫(kù)函數(shù),對(duì)于不清楚函數(shù)內(nèi)核的程序員不適用。相比CIN方式,CLF方式更加簡(jiǎn)單易學(xué),開(kāi)發(fā)者只需要熟悉DLL中的各個(gè)函數(shù)功能以及函數(shù)的參數(shù)及類型,在本文設(shè)計(jì)中,擬采用CLF方式實(shí)現(xiàn)驅(qū)動(dòng)程序的調(diào)用。

  基于CLF方式的采集卡軟件設(shè)計(jì)

  本文所涉及的軟件控制對(duì)象是一款中頻數(shù)據(jù)采集與處理卡,具有14位A/D精度,最高采樣頻率為105MHz,4路模擬量輸入,提供高精度中頻信號(hào)數(shù)字化、多通道、多模式數(shù)字下變頻(DDC)等數(shù)字處理,軟件結(jié)構(gòu)詳見(jiàn)圖1。

采集卡的軟件結(jié)構(gòu)

圖1 采集卡的軟件結(jié)構(gòu)

  LABVIEW應(yīng)用程序分為用戶界面和圖標(biāo)代碼,通過(guò)搭建和調(diào)用子VI編寫(xiě)主體程序,各VI利用LABVIEW的CLF技術(shù)調(diào)用動(dòng)態(tài)鏈接庫(kù)中的驅(qū)動(dòng)函數(shù),實(shí)現(xiàn)與硬件設(shè)備的數(shù)據(jù)交換。子VI將基本的驅(qū)動(dòng)函數(shù)進(jìn)行功能封裝。一個(gè)完整的LABVIEW應(yīng)用程序通常由若干個(gè)子VI及其外部編程連線構(gòu)成,VI的層級(jí)結(jié)構(gòu)設(shè)計(jì)是設(shè)計(jì)虛擬儀器驅(qū)動(dòng)程序的核心,各VI分別為組成驅(qū)動(dòng)程序的模塊化子程序。設(shè)計(jì)中,動(dòng)態(tài)鏈接庫(kù)由VC編寫(xiě),調(diào)用底層的驅(qū)動(dòng)函數(shù)與設(shè)備通信。軟件包括兩類子VI函數(shù)集合,一類是低層組件VI集合,分為若干個(gè)獨(dú)立的軟件功能模塊,每個(gè)模塊負(fù)責(zé)控制儀器的某項(xiàng)特殊功能,這類VI是儀器驅(qū)動(dòng)程序的基礎(chǔ);另一類為高層應(yīng)用VI集合,應(yīng)用VI通過(guò)調(diào)用合適的組件VI以實(shí)現(xiàn)最通常的儀器設(shè)置和測(cè)量任務(wù)。顯然,就驅(qū)動(dòng)程序開(kāi)發(fā)而言,能否根據(jù)硬件特性成功構(gòu)建組件VI集合是關(guān)鍵所在。VI層次結(jié)構(gòu)如圖2所示。

 

VI的層級(jí)結(jié)構(gòu)

圖2 VI的層級(jí)結(jié)構(gòu)

  如圖所示,按功能有兩個(gè)高層應(yīng)用子VI集合:Config.vi,Config DDC.vi,這兩個(gè)子VI又分別調(diào)用低層組件子VI來(lái)完成特定的設(shè)置、配置任務(wù)。Config.vi完成采集卡的常規(guī)配置,例如對(duì)采集卡單次采集數(shù)量、FIFO滿深度、寄存器(硬件通道、時(shí)鐘、觸發(fā)、采集方式、采集模式等的控制)設(shè)置、采集卡的狀態(tài)查詢等;Config DDC.vi完成DDC的所有配置工作,包括對(duì)DDC的模式、抽取率、輸出格式、本振頻率、本振相位、增益、CFIR濾波參數(shù)、PFIR濾波參數(shù)等的設(shè)置,從而實(shí)現(xiàn)DDC的數(shù)字IQ分離、抽取、數(shù)字濾波、重采樣、多級(jí)增益調(diào)節(jié)、多種調(diào)制方式的解調(diào)等功能。其余低層組件VI實(shí)現(xiàn)設(shè)備的打開(kāi)關(guān)閉、數(shù)據(jù)從數(shù)據(jù)采集卡到主機(jī)內(nèi)存的傳送、數(shù)據(jù)保存等。無(wú)論應(yīng)用子VI或組件子VI均為獨(dú)立可執(zhí)行程序,實(shí)現(xiàn)特定功能,各VI函數(shù)作為提供給用戶進(jìn)行系統(tǒng)應(yīng)用開(kāi)發(fā)所需的各類操作。采用該結(jié)構(gòu),能夠使用戶在運(yùn)行時(shí)修改虛擬儀器系統(tǒng)的運(yùn)行邏輯與人機(jī)界面,可立即執(zhí)行,因此在用戶需要改變需求的情況下能迅速適配,數(shù)據(jù)采集卡具有可重構(gòu)的特點(diǎn),用戶也不必去關(guān)心硬件的實(shí)現(xiàn)細(xì)節(jié)。

  DLL的調(diào)用

  在LABVIEW 中調(diào)用DLL時(shí),把編寫(xiě)好的DLL放在當(dāng)前目錄或特定目錄下,然后根據(jù)應(yīng)用程序的需要,確定參數(shù)個(gè)數(shù)和參數(shù)類型及調(diào)用規(guī)則,在LABVIEW中正確地配置DLL 。首先從函數(shù)模板Function 中調(diào)用CLF 節(jié)點(diǎn),雙擊彈出設(shè)置對(duì)話框,如圖2所示。對(duì)話框中,第一個(gè)參數(shù)Library Name Path 填入需要調(diào)用的動(dòng)態(tài)鏈接庫(kù)文件的名字和路徑。第二個(gè)參數(shù)Function Name 是鏈接庫(kù)中要調(diào)用的函數(shù)名稱。第三個(gè)參數(shù)為線程調(diào)用方式,在DLL只被一個(gè)線程調(diào)用的情況下,兩種調(diào)用方式都可選擇,但在多線程調(diào)用情況下,需注意選擇。Run in UI Thread 表示在用戶接口線路中調(diào)用,DLL 的執(zhí)行期將等到用戶接口線程(即LABVIEW環(huán)境下的VI 應(yīng)用程序) 執(zhí)行DLL 的導(dǎo)出函數(shù)調(diào)用時(shí)才開(kāi)始;Run in any Thread 表示允許多個(gè)線程同時(shí)調(diào)用這個(gè)DLL。在編制DLL 過(guò)程中,充分考慮了線程保護(hù)的同步機(jī)制,如使用臨界區(qū)、互斥、信號(hào)量等,線程安全較為確定,那么可以選用Run in any Thread方式,這將有助于提高DLL調(diào)用的性能;反之,可選Run in UI Thread。第四個(gè)參數(shù)是對(duì)DLL的調(diào)用規(guī)則,可選擇C或stdcall,在此選擇stdcall。LABVIEW調(diào)用庫(kù)函數(shù)設(shè)置界面如圖3所示,其中Parameters項(xiàng)是對(duì)參數(shù)選項(xiàng)的設(shè)置,根據(jù)調(diào)用的函數(shù),添加和設(shè)置相應(yīng)的參數(shù),參數(shù)名稱、類型和數(shù)據(jù)類型,且要與被調(diào)用函數(shù)中的參數(shù)名相同。需要注意的是,當(dāng)調(diào)用多個(gè)函數(shù)時(shí)要分別填寫(xiě)參數(shù)的個(gè)數(shù)和對(duì)應(yīng)的類型,而且在調(diào)用過(guò)程中應(yīng)保持?jǐn)?shù)據(jù)位的一致。由于LABVIEW中的數(shù)據(jù)類型和不同編程語(yǔ)言對(duì)應(yīng)的數(shù)據(jù)類型在形式上有些不一致,因此需要知道它們是如何對(duì)應(yīng)的。如:LABVIEW中I16表示有符號(hào)16位整型,對(duì)應(yīng)C語(yǔ)言中的short型。

LABVIEW調(diào)用庫(kù)函數(shù)設(shè)置界面

圖3 LABVIEW調(diào)用庫(kù)函數(shù)設(shè)置界面

  設(shè)置后,LABVIEW將自動(dòng)生成各參數(shù)的入口及出口狀態(tài),完成調(diào)用庫(kù)函數(shù)節(jié)點(diǎn)的配置。對(duì)于外部的編程和連線,如Trigger.vi,如圖4所示。

Trigger子VI程序框圖

圖4 Trigger子VI程序框圖

  DLL調(diào)用中的參數(shù)類型匹配

  在LABVIEW中調(diào)用動(dòng)態(tài)鏈接庫(kù),難點(diǎn)在于參數(shù)類型匹配。最常用的三種數(shù)據(jù)類型是:數(shù)值類型、字符串、數(shù)值型數(shù)組。設(shè)計(jì)中,將采集數(shù)據(jù)傳送到內(nèi)存塊過(guò)程涉及到帶數(shù)組參數(shù)的函數(shù)調(diào)用,值得注意的是,LABVIEW 只支持 C 數(shù)據(jù)類型中的數(shù)值型數(shù)組,調(diào)用含有數(shù)組參數(shù)函數(shù)時(shí),傳遞數(shù)組類型“Array Format”要選擇“Array Data Pointer”。這個(gè)設(shè)置中還有其他兩個(gè)選項(xiàng)(Array Handle,Array Handle Pointer),這種帶有“Handle”的參數(shù)類型都是表示LABVIEW定義的特殊類型的,在第三方的DLL中不會(huì)使用到。按前述步驟設(shè)置好CLF節(jié)點(diǎn),連接外部輸入(采集數(shù)量size)和輸出(存放采集數(shù)據(jù)的數(shù)組)后,輸出沒(méi)有反應(yīng),檢查分析得知,數(shù)組參數(shù)作為輸出值時(shí),要為輸出的數(shù)組數(shù)據(jù)開(kāi)辟空間,將輸入數(shù)據(jù)的指針復(fù)制給輸出數(shù)組數(shù)據(jù)指針并傳給驅(qū)動(dòng)函數(shù)。在LABVIEW中開(kāi)辟數(shù)據(jù)空間的方法有兩種:

 

  1.創(chuàng)建一個(gè)長(zhǎng)度滿足要求的數(shù)組,作為初始值傳遞給輸入?yún)?shù),輸出數(shù)據(jù)就會(huì)被放置在輸入數(shù)組所在的內(nèi)存空間內(nèi)。

  2.直接在參數(shù)配置面板上進(jìn)行設(shè)置。在 Minimum size 中寫(xiě)入一個(gè)固定的數(shù)值或選擇函數(shù)的其它數(shù)據(jù)參數(shù),LABVIEW 就會(huì)按此大小為輸出數(shù)組開(kāi)辟空間。

  詳細(xì)設(shè)置如表1所示。字符串的使用與數(shù)組非常類似,實(shí)際上在C語(yǔ)言中字符串就是一個(gè)I8數(shù)組。

表1 調(diào)用含有數(shù)組參數(shù)函數(shù)舉例

調(diào)用含有數(shù)組參數(shù)函數(shù)舉例

  此外,布爾類型在DLL函數(shù)和LABVIEW VI之間傳遞沒(méi)有專有的數(shù)據(jù)類型,需利用數(shù)值類型來(lái)傳遞。輸入時(shí)先把布爾值轉(zhuǎn)變?yōu)閿?shù)值,傳遞給DLL函數(shù);輸出時(shí)把數(shù)值轉(zhuǎn)為布爾值。對(duì)于所調(diào)用的DLL 庫(kù)函數(shù)的參數(shù)類型,如果在配置框中找不到匹配的類型,可以在Type 框中選Adapt to Type,表示編程時(shí)指定的LABVIEW數(shù)據(jù)類型與DLL中參數(shù)類型進(jìn)行自動(dòng)匹配。LABVIEW也定義了一些特有的數(shù)據(jù)類型,例如復(fù)數(shù)類型、LV布爾類型。為了在動(dòng)態(tài)鏈接庫(kù)中能對(duì)這些類型的數(shù)據(jù)進(jìn)行操作,在LABVIEW目錄中的extcode.h文件對(duì)LABVIEW的各種數(shù)據(jù)類型進(jìn)行了定義。在編寫(xiě)動(dòng)態(tài)鏈接庫(kù)時(shí),通過(guò)引用該文件就可以在C代碼中對(duì)LABVIEW的這些獨(dú)有數(shù)據(jù)類型進(jìn)行操作。

  實(shí)驗(yàn)與結(jié)論

  程序設(shè)計(jì)采用循環(huán)順序執(zhí)行結(jié)構(gòu),主要設(shè)置三個(gè)調(diào)用動(dòng)態(tài)鏈接庫(kù)節(jié)點(diǎn)。循環(huán)順序執(zhí)行結(jié)構(gòu)中包括三幀,第一幀調(diào)用Config函數(shù)進(jìn)行數(shù)據(jù)采集卡的初始化;第二幀循環(huán)調(diào)用datatrans函數(shù)采集數(shù)據(jù)至內(nèi)存,并用波形圖顯示出來(lái);第三幀調(diào)用deviceshut函數(shù)釋放采集卡所占資源,程序結(jié)束。圖5是設(shè)計(jì)完成的采集卡軟件工作界面,圖中顯示了對(duì)系統(tǒng)采集參數(shù)、處理參數(shù)配置以及采集波形的顯示等,波形顯示了對(duì)正弦信號(hào)采集4096個(gè)有效數(shù)據(jù)點(diǎn)。

采集波形顯示圖

圖5 采集波形顯示圖

  結(jié)果表明,數(shù)據(jù)卡的接口工作穩(wěn)定,數(shù)據(jù)正確無(wú)誤,達(dá)到了設(shè)計(jì)的目標(biāo)。上述方法成功實(shí)現(xiàn)了LABVIEW與采集卡驅(qū)動(dòng)程序的數(shù)據(jù)交換,進(jìn)而利用LABVIEW豐富的函數(shù)庫(kù),能方便地實(shí)現(xiàn)采集卡的所有功能,搭建了以LABVIEW為應(yīng)用程序的數(shù)字采集處理系統(tǒng)。很明顯這種集成了VC++和LABVIEW圖形化編程語(yǔ)言各自優(yōu)勢(shì)的采集處理系統(tǒng)不僅性價(jià)比高、通用性強(qiáng)、易于開(kāi)發(fā)、數(shù)據(jù)處理簡(jiǎn)單,且可以大大縮短開(kāi)發(fā)時(shí)間。采用CLF 技術(shù),充分利用已有的動(dòng)態(tài)鏈接程序庫(kù),可大大增強(qiáng)LABVIEW 和底層硬件的通信能力。

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
国产综合久久久久久鬼色| 亚洲精品中文字幕在线| 欧美日韩免费高清| 欧美国产大片| 久久婷婷国产麻豆91天堂| 久久aⅴ国产紧身牛仔裤| 午夜视频精品| 亚洲免费影视第一页| 亚洲一区二区三区精品在线| 一区二区精品国产| 一区二区三区视频观看| 在线视频中文亚洲| 一区二区三区蜜桃网| 宅男精品导航| 亚洲欧美精品中文字幕在线| 亚洲欧美日韩综合国产aⅴ| 亚洲欧美日韩在线一区| 欧美一区二区三区免费观看视频 | 亚洲精品一区二区三区樱花| 亚洲区一区二| 99re8这里有精品热视频免费| 99伊人成综合| 亚洲一区二区三区在线| 性欧美xxxx视频在线观看| 欧美中文在线观看国产| 久久久久www| 免费在线播放第一区高清av| 欧美精品在线观看一区二区| 欧美日韩国产综合新一区| 欧美日韩爆操| 国产精品成人午夜| 国产日韩精品一区二区三区| 国模一区二区三区| 亚洲电影免费观看高清完整版 | 亚洲精品综合| 一区二区三区日韩欧美精品| 亚洲一区欧美二区| 久久都是精品| 亚洲毛片在线看| 亚洲欧美一区二区三区极速播放| 欧美一区日本一区韩国一区| 久久艳片www.17c.com| 欧美美女bb生活片| 国产精品美女www爽爽爽| 红桃视频一区| 99re视频这里只有精品| 亚洲欧美一区二区原创| 亚洲高清视频在线| 亚洲视频一二| 久久久久久91香蕉国产| 欧美精品一区二区在线观看 | 国产欧美一区二区三区另类精品 | 亚洲高清不卡| 亚洲一区二区伦理| 久久精品国产免费| 欧美成人精品激情在线观看| 欧美性色综合| 伊人精品成人久久综合软件| 日韩天堂av| 欧美在线亚洲| 亚洲一区二区av电影| 久久婷婷蜜乳一本欲蜜臀| 欧美日韩免费视频| 国产综合色产在线精品| 亚洲久久在线| 久久精品欧洲| 亚洲欧美另类在线| 欧美91大片| 国产欧美精品日韩精品| 91久久久久久| 欧美一区二区三区久久精品| 日韩天堂在线观看| 久久精品在线| 欧美日韩美女一区二区| 国内视频一区| 亚洲一区二区三区久久| 日韩视频国产视频| 久久亚洲精品中文字幕冲田杏梨| 欧美新色视频| 在线播放精品| 亚洲欧美日韩国产另类专区| 日韩视频免费看| 久久久亚洲影院你懂的| 国产精品毛片大码女人| 日韩视频一区二区三区| 久久精品成人欧美大片古装| 亚洲欧美日韩中文在线制服| 欧美区一区二区三区| 在线播放中文字幕一区| 午夜伦理片一区| 亚洲男女自偷自拍图片另类| 欧美久久九九| 在线观看日韩欧美| 欧美一区二区精品| 午夜国产不卡在线观看视频| 久久精品免费观看| 久久精品国产亚洲a| 国产精品久久久久婷婷| 日韩亚洲欧美成人一区| 日韩一级不卡| 欧美激情精品久久久久久大尺度| 狠狠色丁香婷婷综合久久片| 午夜精品www| 午夜视频一区| 国产精品久久网站| 亚洲视频二区| 亚洲在线一区二区三区| 欧美美女bbbb| 亚洲精品视频一区| 亚洲欧洲美洲综合色网| 另类尿喷潮videofree| 狠狠色2019综合网| 亚洲国产91| 久久综合九色| 伊人精品在线| 亚洲欧洲精品成人久久奇米网| 久久琪琪电影院| 伊人久久大香线| 亚洲电影第三页| 久久综合伊人| 在线观看一区二区视频| 亚洲国产小视频在线观看| 久久亚洲精选| 亚洲国产激情| 99riav国产精品| 欧美日韩系列| 在线亚洲自拍| 亚洲欧美综合一区| 国产区在线观看成人精品| 午夜精品理论片| 久久精品亚洲| 精品成人一区二区| 亚洲国产日日夜夜| 欧美另类69精品久久久久9999| 日韩网站在线观看| 亚洲午夜视频在线| 国产精品人成在线观看免费| 亚洲影音先锋| 久久精品一区四区| 1024成人网色www| 艳妇臀荡乳欲伦亚洲一区| 欧美网站在线| 香蕉乱码成人久久天堂爱免费| 久久夜色精品亚洲噜噜国产mv| 尤物九九久久国产精品的特点| 亚洲精选91| 国产精品成人aaaaa网站 | 在线一区二区视频| 国产精品久久久久久户外露出| 亚洲欧美成人综合| 久久综合久久综合久久| 亚洲国产综合在线看不卡| 国产精品99久久99久久久二8| 国产精品入口| 亚洲国产精品视频| 欧美日韩在线精品一区二区三区| 亚洲欧美日韩中文在线制服| 老司机午夜精品视频| 亚洲最新色图| 久久久久久久激情视频| 亚洲国产婷婷综合在线精品 | 国产午夜亚洲精品理论片色戒| 久久精品午夜| 欧美日韩亚洲在线| 欧美在线看片| 欧美日韩日本网| 久久精品国产99国产精品| 欧美日韩1234| 欧美一级久久| 欧美岛国激情| 亚洲影视中文字幕| 欧美成人性网| 亚洲欧美日韩一区在线| 久久综合中文字幕| 在线天堂一区av电影| 久久天天躁夜夜躁狠狠躁2022| 日韩午夜电影在线观看| 久久久噜噜噜久久人人看| 亚洲免费电影在线| 久久久青草青青国产亚洲免观| 日韩视频在线一区二区| 久久久免费精品视频| 一本色道久久88综合亚洲精品ⅰ | 亚洲国产精品悠悠久久琪琪| 亚洲免费影视| 亚洲第一成人在线| 欧美一区二区视频免费观看 | av成人福利| 麻豆精品91| 亚洲少妇中出一区| 免费亚洲电影| 亚洲欧美国产日韩天堂区| 欧美激情精品久久久久久| 午夜亚洲福利| 国产精品久99| 日韩一级在线| 狠狠综合久久av一区二区小说| 亚洲男女自偷自拍| 亚洲蜜桃精久久久久久久| 嫩草影视亚洲|