在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于Visual C++程序與C++語(yǔ)言的FPGA可重配置設(shè)計(jì)方案

電子設(shè)計(jì) ? 來(lái)源:郭婷 ? 作者:電子設(shè)計(jì) ? 2018-12-30 09:26 ? 次閱讀

引言

隨著大規(guī)模集成電路的快速發(fā)展,系統(tǒng)設(shè)計(jì)已從傳統(tǒng)的追求大規(guī)模、高密度逐漸轉(zhuǎn)向提高資源利用率,使有限的資源可以實(shí)現(xiàn)更大規(guī)模的邏輯設(shè)計(jì)。利用現(xiàn)場(chǎng)可編程邏輯器件FPGA的多次可編程配置特點(diǎn),通過(guò)重新下載存儲(chǔ)于存儲(chǔ)器的不同系統(tǒng)數(shù)據(jù),從而實(shí)現(xiàn)不同的芯片邏輯功能,可以在很大程度上提高資源利用率。原始配置FPGA的方法是硬件設(shè)計(jì)者根據(jù)需求設(shè)計(jì)生成配置數(shù)據(jù)流,然后通過(guò)專用配置芯片對(duì)FPGA進(jìn)行配置,例如通過(guò)下載電纜將配置數(shù)據(jù)流存儲(chǔ)到FPGA配置存儲(chǔ)芯片中,該方法的整個(gè)過(guò)程需要芯片廠商的專用軟件參與。因此,該配置方法對(duì)依賴下載電纜,適合于產(chǎn)品研制過(guò)程中下載配置操作,且有一定的局限性,不適用對(duì)產(chǎn)品應(yīng)用中的系統(tǒng)升級(jí)或系統(tǒng)重構(gòu)。

結(jié)合對(duì)FPGA重配置方案的軟硬件設(shè)計(jì),本文通過(guò)PC機(jī)并通過(guò)總線(如PCI總線)將配置數(shù)據(jù)流下載到硬件功能模塊的有關(guān)配置芯片,從而完成配置FPGA的全過(guò)程。該方法的軟件部分基于Visual C++的開發(fā)環(huán)境,并用C++語(yǔ)言開發(fā)動(dòng)態(tài)連接庫(kù),以用于軟件設(shè)計(jì)應(yīng)用程序部分的調(diào)用。文中詳述了上層用戶對(duì)配置文件的處理、調(diào)用動(dòng)態(tài)連接庫(kù)中的發(fā)送函數(shù)、將配置數(shù)據(jù)流發(fā)送給硬件的軟件設(shè)計(jì)過(guò)程,并通過(guò)建立用戶與硬件的握手聯(lián)系,來(lái)提高配置數(shù)據(jù)的傳輸率。

1 FPGA的可重配置硬件方案

本文給出的設(shè)計(jì)方案將FPGA的配置程序文件看作一個(gè)“對(duì)象”,邏輯設(shè)計(jì)者先將所要完成的工作程序生成這樣的一個(gè)“對(duì)象”,然后由上位機(jī)通過(guò)某種通訊接口模塊及邏輯控制模塊,將其下傳到FPGA的配置芯片中來(lái)完成FPGA器件的重新配置,即通過(guò)對(duì)FPGA邏輯的重配置來(lái)完成系統(tǒng)的重構(gòu)或升級(jí)。邏輯設(shè)計(jì)者最終通過(guò)上位機(jī)用戶界面的簡(jiǎn)單操作,即可完成硬件功能模塊的工作方式重構(gòu),其可重配置的系統(tǒng)硬件結(jié)構(gòu)框圖如圖1所示。

圖1中借用原系統(tǒng)DSP處理器的控制功能來(lái)完成上位機(jī)控制命令及下載數(shù)據(jù)的接收,上位機(jī)與系統(tǒng)之間采用PCI總線接口。上位機(jī)命令由DSP處理器進(jìn)行解析,并隨后發(fā)送到配置芯片控制器中,配置芯片控制器可由CPLD器件構(gòu)成,它的編程采用EEPROM或FLASH技術(shù),且無(wú)需外部存儲(chǔ)器芯片。

基于Visual C++程序與C++語(yǔ)言的FPGA可重配置設(shè)計(jì)方案

在設(shè)計(jì)中,上位機(jī)通過(guò)PCI總線建立通信并發(fā)送配置命令及數(shù)據(jù)至DSP,DSP以串行方式通知配置芯片控制器發(fā)送控制命令以及要進(jìn)行配置的數(shù)據(jù)包,同時(shí),配置芯片控制器在解析命令后,還應(yīng)執(zhí)行相應(yīng)的操作,并完成FPGA配置芯片所需的下載時(shí)序及配置數(shù)據(jù)。配置芯片的數(shù)據(jù)下載過(guò)程稱為編程操作,編程完成后,再啟動(dòng)配置操作,即可進(jìn)行FPGA從配置芯片讀取新的系統(tǒng)配置程序過(guò)程。與常用的FPGA配置方法相比較,本文所采用的FPGA可重構(gòu)設(shè)計(jì)的硬件結(jié)構(gòu)更加簡(jiǎn)單,用戶操作也更加方便,而且在對(duì)FPGA的配置芯片寫入配置程序數(shù)據(jù)的時(shí)候,并不會(huì)影響到FPGA的繼續(xù)工作,系統(tǒng)重構(gòu)的時(shí)隙也更小。

DSP控制程序一般采用中斷等待的設(shè)計(jì)思想,處理器上電啟動(dòng)后,首先對(duì)自身的工作方式進(jìn)行設(shè)置,然后對(duì)系統(tǒng)各個(gè)功能模塊進(jìn)行初始化操作,使其工作在一個(gè)確定的已知狀態(tài)下。之后,在完成系統(tǒng)的初始化以后,DSP程序進(jìn)入空閑等待狀態(tài),直到標(biāo)志著上層命令已送達(dá)控制邏輯的中斷信號(hào)有效,程序再?gòu)目臻e等待狀態(tài)進(jìn)入中斷服務(wù)程序,然后判斷是系統(tǒng)配置命令,還是其他工作命令。若接收到配置命令,則進(jìn)入串口中斷服務(wù)程序,隨后判斷配置命令的類別,并進(jìn)入相應(yīng)的子函數(shù)程序,包括配置模式、用戶模式、擦除、擦除延時(shí)、寫數(shù)據(jù)等多個(gè)子函數(shù)。配置模式是指系統(tǒng)通過(guò)發(fā)送控制命令來(lái)獲取FPGA配置芯片的數(shù)據(jù)信號(hào)線、時(shí)鐘信號(hào)線以及片選信號(hào)線的控制權(quán),從而進(jìn)行讀寫操作。調(diào)用配置模式子函數(shù)后,發(fā)送不同的命令控制字,便可以選擇配置不同的配置器件。

本系統(tǒng)中的邏輯電路平臺(tái)由2片Altra公司FPGA芯片構(gòu)成,其對(duì)應(yīng)的配置芯片分別為EPCS16和EPCS1器件,設(shè)計(jì)中,可以分別為這兩片配置芯片設(shè)置各自的32位控制字。用戶模式子函數(shù)可在系統(tǒng)對(duì)EPCS配置芯片的寫數(shù)據(jù)操作完成后,通過(guò)系統(tǒng)發(fā)送控制命令來(lái)釋放配置芯片EPCS的數(shù)據(jù)信號(hào)線、時(shí)鐘信號(hào)線以及片選信號(hào)線的控制權(quán),這樣,F(xiàn)PGA將恢復(fù)到用戶所設(shè)置的工作模式。

2 可重配置軟件方案

用戶發(fā)送配置數(shù)據(jù)流到EPCS對(duì)FPGA進(jìn)行配置的結(jié)構(gòu)圖如圖2所示,其中PC機(jī)部分為上位機(jī)配置控制的用戶軟件宿主。配置控制軟件主要包括用戶應(yīng)用程序(Win32應(yīng)用程序)、儀器驅(qū)動(dòng)程序、總線驅(qū)動(dòng)程序三部分,總線驅(qū)動(dòng)位于整個(gè)軟件系統(tǒng)的最底層,可通過(guò)硬件抽象層(HAL)直接與硬件進(jìn)行交流。儀器驅(qū)動(dòng)位于總線驅(qū)動(dòng)和用戶應(yīng)用程序之間。它對(duì)上可為屏蔽底層工作細(xì)節(jié)提供應(yīng)用程序調(diào)用的接口函數(shù),對(duì)下則可發(fā)送命令或接收數(shù)據(jù)。用戶應(yīng)用程序則位于軟件結(jié)構(gòu)的最上層,可通過(guò)調(diào)用儀器驅(qū)動(dòng)程序,間接地與底層進(jìn)行交互。其結(jié)構(gòu)圖如圖3所示。

基于Visual C++程序與C++語(yǔ)言的FPGA可重配置設(shè)計(jì)方案

Windows XP操作系統(tǒng)中的驅(qū)動(dòng)程序開發(fā)主要是基于Win32模式驅(qū)動(dòng)程序,即基于WDM(Win32 Driver Model)。在WDM驅(qū)動(dòng)模型中,每個(gè)硬件設(shè)備至少有兩個(gè)驅(qū)動(dòng)程序:總線驅(qū)動(dòng)程序和功能驅(qū)動(dòng)程序。其中總線驅(qū)動(dòng)程序由Windows提供,需要考慮的是負(fù)責(zé)實(shí)現(xiàn)PCI設(shè)備邏輯功能的功能驅(qū)動(dòng)程序。所以,驅(qū)動(dòng)程序分為以動(dòng)態(tài)鏈接庫(kù)形式的儀器驅(qū)動(dòng)程序和以WDM格式的底層的接口驅(qū)動(dòng)程序。前者用于實(shí)現(xiàn)對(duì)目標(biāo)硬件的操作,即下載配置數(shù)據(jù)流對(duì)FPGA的配置;后者則可實(shí)現(xiàn)資源分配、接口管理及數(shù)據(jù)的控制傳輸。

3配置數(shù)據(jù)分析

本設(shè)計(jì)中的應(yīng)用軟件所要下載的配置數(shù)據(jù)流是由硬件設(shè)計(jì)者根據(jù)需求提供的,是以二進(jìn)制形式存儲(chǔ)的.rpd文件??梢愿鶕?jù)不同的FPGA來(lái)選擇不同的外圍存儲(chǔ)芯片(如EPCS1,EPCS16),從而生成不同大小的配置數(shù)據(jù)流。由于軟件設(shè)計(jì)中,每次下發(fā)的數(shù)據(jù)一定,所以,由數(shù)據(jù)流的大小就能決定循環(huán)發(fā)送數(shù)據(jù)的次數(shù)。

由于硬件設(shè)計(jì)者提供的.rod文件中的數(shù)據(jù)并不是原始的配置數(shù)據(jù),而是所要配置的數(shù)據(jù)經(jīng)過(guò)反轉(zhuǎn)生成的新的配置數(shù)據(jù)流,所以,要先將.rpd中的數(shù)據(jù)反轉(zhuǎn)處理后再發(fā)送給硬件。通過(guò)用戶界面可以二進(jìn)制的形式打開.rod文件并讀數(shù),將配置數(shù)據(jù)流以單字節(jié)的形式暫存在一數(shù)組中,然后對(duì)數(shù)據(jù)進(jìn)行反轉(zhuǎn)處理。數(shù)組中每個(gè)單字節(jié)數(shù)據(jù)的反轉(zhuǎn)過(guò)程為:unsigned char strl=DE,反轉(zhuǎn)后為strl=7B,定義無(wú)符號(hào)char型變量bi(i為小于8的整數(shù)),可由下面的轉(zhuǎn)換完成:

由此可以得到:strl=7B。對(duì)反轉(zhuǎn)處理生成的單字節(jié)數(shù)據(jù)經(jīng)過(guò)組合處理后,最終便可得到對(duì)FPGA進(jìn)行配置所需要的數(shù)據(jù)流。

4儀器驅(qū)動(dòng)函數(shù)的設(shè)計(jì)

根據(jù)硬件設(shè)計(jì),儀器驅(qū)動(dòng)需將配置數(shù)據(jù)以長(zhǎng)整型的形式發(fā)送,即32位。因?yàn)榕渲脭?shù)據(jù)的長(zhǎng)度為16位,所以發(fā)送數(shù)據(jù)時(shí),每次要傳兩個(gè)數(shù),高16位和低16位分別放一個(gè)數(shù)。當(dāng)應(yīng)用程序打開.rpd文件時(shí),應(yīng)將其中配置數(shù)據(jù)流保存在數(shù)組ww[f]中,而反轉(zhuǎn)處理后得到的數(shù)據(jù)依然放在數(shù)組ww[f]中并覆蓋原來(lái)的數(shù)據(jù),然后根據(jù)公式(1)進(jìn)行組合處理,以得到最終要發(fā)送的32位數(shù)據(jù)并保存在長(zhǎng)整型數(shù)組comdata[f]中。數(shù)組comdata[j]中的每個(gè)數(shù)據(jù)實(shí)際上包含兩個(gè)配置數(shù)據(jù),第一個(gè)數(shù)放在高16位,第二個(gè)數(shù)放在低16位,依次類推。確定好數(shù)據(jù)后,便可以調(diào)用動(dòng)態(tài)連接庫(kù)中的發(fā)送數(shù)據(jù)函數(shù)并發(fā)送給硬件。

comdata[j]=(ww[i]<<24)∣(ww[i+1]<<16)∣(ww[i+2]<<8)∣ww[i+3](1)

應(yīng)用程序可以通過(guò)DeviceI/OControl ( )函數(shù)和WDM進(jìn)行通信,DeviceI/OControl ( )既可以讀數(shù)據(jù),也可以寫數(shù)據(jù),常用于數(shù)據(jù)量較小的情況下。在軟件設(shè)計(jì)中,發(fā)送配置數(shù)據(jù)可通過(guò)調(diào)用DeviceI/OControl()完成。根據(jù)硬件要求,每次可下發(fā)1022個(gè)配置數(shù)據(jù)到cyclone (即循環(huán)發(fā)LONG型數(shù)據(jù)511次),然后由cyclone給DSP一個(gè)中斷信號(hào),DSP接到中斷信號(hào)后,即進(jìn)入中斷程序,開始接收配置數(shù)據(jù)。當(dāng)應(yīng)用程序調(diào)用發(fā)送數(shù)據(jù)函數(shù)時(shí),可先確定要發(fā)送的配置數(shù)據(jù)大小,再計(jì)算發(fā)送的次數(shù)。為了盡可能的減小發(fā)送時(shí)間,有效完成數(shù)據(jù)的發(fā)送與配置,應(yīng)在軟件設(shè)計(jì)中建立與底層硬件的握手聯(lián)系。用戶每發(fā)送1022個(gè)數(shù)據(jù)便進(jìn)入等待狀態(tài),在等待期間,DSP可把接收到的數(shù)據(jù)轉(zhuǎn)化為EPCS所需要的配置數(shù)據(jù)流。當(dāng)DSP處理完這段數(shù)據(jù)后,就給上層用戶發(fā)送一個(gè)握手信號(hào),用戶接收到握手信號(hào),便進(jìn)入下一個(gè)1022的發(fā)送,如果最后一次發(fā)送的數(shù)據(jù)不夠1022個(gè),則用0xFFFF補(bǔ)足1022個(gè)數(shù)據(jù),如此循環(huán)處理,直到數(shù)據(jù)發(fā)送完畢。發(fā)送完畢后,再給硬件繼續(xù)發(fā)送一個(gè)配置命令,DSP接到該命令后,又開始對(duì)cyclone進(jìn)行配置,從而完成整個(gè)配置過(guò)程。圖4和圖5分別是配置數(shù)據(jù)和發(fā)送數(shù)據(jù)的軟件工作流程。

基于Visual C++程序與C++語(yǔ)言的FPGA可重配置設(shè)計(jì)方案

圖6為上位機(jī)配置控制界面,圖中給出了2片配置芯片的配置過(guò)程,這是采用Visual C++和NIMeasurement Studio聯(lián)合編程方式的標(biāo)準(zhǔn)用戶界面。其中Visual C++提供了友好的界面及用戶熟悉的Windows風(fēng)格界面,并可以調(diào)用CVI中提供的控件庫(kù)和庫(kù)函數(shù)。

5 結(jié)束語(yǔ)

本文給出了一種基于VC++程序的FPGA可重配置的實(shí)現(xiàn)方案,該方案在配置過(guò)程中,用戶可以通過(guò)調(diào)用自己的邏輯配置文件和程序來(lái)完成處理轉(zhuǎn)換,并控制下載,從而實(shí)現(xiàn)用戶系統(tǒng)的FPGA在系統(tǒng)編程。該方法可有效提高系統(tǒng)配置的效率,并為產(chǎn)品的升級(jí)、重構(gòu),以及用戶產(chǎn)品二次開發(fā)提供了良好手段。此外,借助互聯(lián)網(wǎng)技術(shù),本設(shè)計(jì)還可以支持遠(yuǎn)程下載功能。(王方,王志剛 電子科技大學(xué)自動(dòng)化工程學(xué)院)

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • FPGA
    +關(guān)注

    關(guān)注

    1629

    文章

    21748

    瀏覽量

    603912
  • 集成電路
    +關(guān)注

    關(guān)注

    5388

    文章

    11562

    瀏覽量

    362018
  • C++
    C++
    +關(guān)注

    關(guān)注

    22

    文章

    2110

    瀏覽量

    73688
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    c++程序設(shè)計(jì)教程

    C++是一種高效應(yīng)用的程序設(shè)計(jì)語(yǔ)言,它即可進(jìn)行過(guò)程化程序設(shè)計(jì),也可進(jìn)行面向?qū)ο?b class='flag-5'>程序設(shè)計(jì),因而成了編程人員最廣泛使用的工具。學(xué)好C++,很容易
    發(fā)表于 04-08 00:36 ?124次下載
    <b class='flag-5'>c++</b><b class='flag-5'>程序</b>設(shè)計(jì)教程

    c++程序設(shè)計(jì)語(yǔ)言(特別版)

    c++程序設(shè)計(jì)語(yǔ)言介紹了標(biāo)準(zhǔn)C++以及由C++所支持的關(guān)鍵性編程技術(shù)和設(shè)計(jì)技術(shù)。標(biāo)準(zhǔn)C++較以前的版本功能更
    發(fā)表于 09-05 15:28 ?0次下載

    c++程序設(shè)計(jì)語(yǔ)言題解

    c++程序設(shè)計(jì)語(yǔ)言題解是與Bjarne Stroustrup的《C++程序設(shè)計(jì)語(yǔ)言》一書配套使用的習(xí)題解答,為從《C++
    發(fā)表于 09-05 16:00 ?121次下載
    <b class='flag-5'>c++</b><b class='flag-5'>程序設(shè)計(jì)語(yǔ)言</b>題解

    C++程序設(shè)計(jì)語(yǔ)言實(shí)驗(yàn)指導(dǎo)書

    C++程序設(shè)計(jì)語(yǔ)言實(shí)驗(yàn)指導(dǎo)書書說(shuō)明:第一章 C++實(shí)驗(yàn)基礎(chǔ)知識(shí)...61.1 C++語(yǔ)言實(shí)驗(yàn)環(huán)境配置
    發(fā)表于 09-20 22:20 ?45次下載

    Visual C++ 6 24學(xué)時(shí)學(xué)習(xí)教程

    Visual C++ 6 24學(xué)時(shí)學(xué)習(xí)教程:Visual C++ 6.0是當(dāng)今最前沿的軟件開發(fā)工具,本書以精煉的語(yǔ)言、簡(jiǎn)潔的例子向讀者介紹了
    發(fā)表于 11-27 23:37 ?113次下載
    <b class='flag-5'>Visual</b> <b class='flag-5'>C++</b> 6 24學(xué)時(shí)學(xué)習(xí)教程

    程序設(shè)計(jì)及C++語(yǔ)言課程設(shè)計(jì)教學(xué)大鋼

    程序設(shè)計(jì)及C++語(yǔ)言課程設(shè)計(jì)教學(xué)大鋼:程序設(shè)計(jì)及C++語(yǔ)言》課程設(shè)計(jì)教學(xué)大鋼(課程設(shè)計(jì)類) 課
    發(fā)表于 06-25 23:29 ?15次下載

    VISUAL C++ MFC編程實(shí)例

    VISUAL C++ MFC編程實(shí)例:用Visual C++ 和M F C創(chuàng)建的應(yīng)用程序大多會(huì)自
    發(fā)表于 07-12 15:20 ?0次下載

    Visual C++ 6.0 高級(jí)編程 -下載

    Visual C++ 6.0 高級(jí)編程,免費(fèi)下載:全面介紹了Visual C++ 6.0的中高級(jí)編程技術(shù),其內(nèi)容主要有:內(nèi)存管理、高級(jí)圖形處理、使用Internet、創(chuàng)建多線程
    發(fā)表于 07-12 15:25 ?0次下載
    <b class='flag-5'>Visual</b> <b class='flag-5'>C++</b> 6.0 高級(jí)編程 -下載

    Visual C++ 6.0 二級(jí)C語(yǔ)言專用版(7M)英文

    電子發(fā)燒友網(wǎng)站提供《Visual C++ 6.0 二級(jí)C語(yǔ)言專用版(7M)英文.txt》資料免費(fèi)下載
    發(fā)表于 10-14 21:42 ?0次下載

    C++程序Visual_C++6.0編譯系統(tǒng)中的實(shí)現(xiàn)

    C++程序Visual_C++6.0編譯系統(tǒng)中的實(shí)現(xiàn)。
    發(fā)表于 05-04 11:09 ?1次下載

    Visual C++ 6.0上機(jī)指導(dǎo)

    Visual C++ 6.0軟件基本指導(dǎo)
    發(fā)表于 12-17 16:09 ?0次下載

    VISUAL C++教程之VISUAL C++的安裝和使用方法

    本文檔的主要內(nèi)容詳細(xì)介紹的是VISUAL C++教程之VISUAL C++的安裝和使用方法資料免費(fèi)下載。
    發(fā)表于 12-27 16:32 ?19次下載
    <b class='flag-5'>VISUAL</b> <b class='flag-5'>C++</b>教程之<b class='flag-5'>VISUAL</b> <b class='flag-5'>C++</b>的安裝和使用方法

    Visual C++教程之C++的基礎(chǔ)知識(shí)介紹

    本文檔的主要內(nèi)容詳細(xì)介紹的是Visual C++教程之C++的基礎(chǔ)知識(shí)介紹主要內(nèi)容包括了:1 類和對(duì)象,2 類的成員及特性,3 繼承和派生類
    發(fā)表于 02-15 15:59 ?9次下載
    <b class='flag-5'>Visual</b> <b class='flag-5'>C++</b>教程之<b class='flag-5'>C++</b>的基礎(chǔ)知識(shí)介紹

    Visual C++教程之C++語(yǔ)言資料概述免費(fèi)下載

    本文檔詳細(xì)介紹的是Visual C++教程之C++語(yǔ)言資料概述免費(fèi)下載主要內(nèi)容包括了:1 從CC++
    發(fā)表于 02-15 15:59 ?3次下載
    <b class='flag-5'>Visual</b> <b class='flag-5'>C++</b>教程之<b class='flag-5'>C++</b>的<b class='flag-5'>語(yǔ)言</b>資料概述免費(fèi)下載

    visual C++編程詞典應(yīng)用程序免費(fèi)下載

    本文檔的主要內(nèi)容詳細(xì)介紹的是visual C++編程詞典應(yīng)用程序免費(fèi)下載。
    發(fā)表于 05-17 17:10 ?27次下載
    <b class='flag-5'>visual</b> <b class='flag-5'>C++</b>編程詞典應(yīng)用<b class='flag-5'>程序</b>免費(fèi)下載
    主站蜘蛛池模板: 色偷偷88欧美精品久久久| 精品国产污网站在线观看15| 不卡视频一区| 欧美一区二区三区不卡视频| 女性私密部位扒开的视频| 最新毛片网| 91视频色| 欧美色惰| 老子影院午夜精品欧美视频| 激情综合亚洲| 高清国产一区二区三区| 久久久噜噜噜久久| 国产成人教育视频在线观看| free欧美| 手机视频在线播放| 国产精品www夜色影视| 成人午夜啪啪免费网站| 国产特黄一级一片免费| 天天爽天天爽天天片a久久网| 国产三级在线观看播放| 永久视频免费| 理论片免费午夜| 天天摸天天看天天爽| 久热精品视频| 国产男人搡女人免费视频| www.一区二区三区| 色老太视频| 国产一区二区三区在线观看视频| 夜夜夜久久久| 九九热精品国产| 华人黄网站大全| 久久久免费观看| 综合免费一区二区三区| 在线成人免费| 免费人成网站| 亚洲va国产日韩欧美精品色婷婷| 免费观看片| 操您啦| 成人黄色免费网站| 日本欧洲亚洲一区在线观看| 视频二区中文字幕|