日本强伦姧人妻一区二区,久久精品中文字幕一区,国产欧美日韩一区二区三区在线,亚洲午夜精品第一区二区8050

LonWorks節點驅動程序編寫簡介

(海思LonWorks技術粉絲供稿)

引言

   在現場總線產品開發及系統建設中,各類新設備及新的接口規范等,使得操作系統的設備驅動程序的開發工作層出不窮。在基于嵌入現場總線控制器的開發中,將遇到LonWorks設備的驅動程序問題。對驅動程序實現機制進行研究,對開發LonWorks現場總線設備的驅動程序十分必要。

一、LonWorks技術簡介

    現場總線是一類工業數據總線,是連接智能現場設備和自動化系統的高可靠的數字式、雙向傳輸的通信技術,可方便地構成全數字化的分布式現場控制網絡。在各種現場總線中,LonWorks總線技術以其在技術先進性、可靠性、開放性、拓撲結構靈活性等方面獨特的優勢,為分布式監控系統提供了理想的實現手段。特別適合于建筑的樓宇自動化系統。

    LON網絡接口卡是上位機與LonWorks網絡的接口適配器,使上位機能夠完成與LonWorks節點之間的數據通信。

(一) LonWorks網卡的硬件構成

了解LonWorks網卡的工作原理,對編寫驅動程序是必要的。

1LonWorks網卡的硬件原理框圖。

    在LonWorks網卡的設計中,使用可編程邏輯陣列(CPLD)來實現與ISA總線的接口邏輯,只用一個芯片就完成了所有功能,大大簡化了網卡的電路。

(二)LonWorks網卡的工作原理

    計算機與微控制器之間數據交互的流程圖如圖23所示,完成計算機與微控制器之間讀寫數據、置標志位和清除標志位的功能。CPLD為內部實現了存儲數據和標志位的寄存器。

 

 

二、LonWorks網卡設備驅動實現

Linux平臺上開發和設計LonWorks網卡的軟件包含應用程序和設備驅動程序兩部分。本文主要討論的是設備驅動程序部分。

Linux平臺上實現對硬件的驅動支持采用了如下工作方式:使用Linux內核中提供的機制來實現。 

(一) Linux的可加載模塊機制

    Linux內核提供了兩種機制來開發設備驅動程序:一種是直接把驅動程序鏈接到內核中;另一種則是通過稱為Linux可加載模塊的機制來開發可動態加載和卸載的驅動模塊。而第一種方式可以在后一種方式成功后,采用與內核一起提供的配置工具和接口來完成。

    Linux作為單核結構其效率比較高,但是系統靈活性不足,為了平衡這兩者的關系,它提供了可動態加載機制。利用這種機制我們可以開發Linux內核模塊,并且可以動態的對它加載和卸載。Linux下的設備驅動程序一般都支持這種方式,且模塊被加載到內核后,它就可以任意的利用核心提供的各種資源和服務了。為了讓模塊利用核心提供的資源,Linux內核維護了一張所有內核資源的符號表(在接下來的部分我們稱它為內核資源符號表),用于在模塊載入時解決對相應資源的引用問題。并且,Linux允許模塊的堆棧操作,由此一個模塊可以使用其他模塊所提供的資源。也就是說:一個模塊對另一個模塊的資源的使用與其對內核資源的使用非常相似,不同的只是這些服務的資源從屬于另一個模塊而已。每當一個模塊被加載Linux就會有一個修改內核資源符號表的過程,將該模塊所提供的服務和資源加入進去,這樣另一個模塊載入時,如果需要就可以引用這個模塊的資源了。而卸載一個模塊時,就要知道當前模塊是否正在被使用。如果沒有被使用,在卸載時要能夠通知該模塊它將被卸載,以便由它自己釋放已被它占用的系統資源。然后,Linux還要從內核資源符號表中刪除所有該模塊提供的資源和服務。 

    從上面的原理分析可知,內核模塊編寫時應該具有兩個主要的接口函數:init_module()用于在模塊加載時由加載模塊的工具調用,以便于注冊一些必要的服務和申請一些資源。cleanup_module()用于在模塊卸載時由刪除模塊的工具來調用,清除掉由init_module()所做的工作,從而使內核模塊可以安全的卸載。其中對init_module()調用的一種工具是在根用戶執行insmod命令來加載模塊時執行。而對于cleanup_module()的調用是在根用戶使用rmmod命令來卸載模塊時執行。

(二) Linux下設備驅動程序

    系統調用是操作系統內核和應用程序之間的接口, .aspx" title="設備" style="text-decoration:underline;color:blue">設備驅動程序是操作系統內核和機器硬件之間的接口。設備驅動程序為應用程序屏蔽了硬件的細節,這樣在應用程序看來,硬件設備只是一個設備文件,可以通過相應的系統調用象操作普通文件一樣對硬件設備進行操作。

(1) Linux設備分類

    Linux系統的設備分為字符設備(char device),塊設備(block device)和網絡設備(network device)三種。字符設備是指存取時沒有緩存的設備,如系統的串口設備/dev/cua0, /dev/cual。塊設備的讀寫則都有緩存來支持,只能以塊為單位進行讀寫,并且塊設備必須能夠隨機存取(random access),即不管塊處于設備的什么地方都可以對它進行讀寫,字符設備則沒有這個要求。塊設備主要包括硬盤軟盤設備,CD-ROM等。網絡設備在Linux里做專門的處理。Linux的網絡系統主要是基于BSD unixsocket機制。

(2) 設備標識方式

    Linux設備由一個主設備號和一個次設備號標識。主設備號唯一標識了設備類型,即設備驅動程序類型,它是塊設備表或字符設備表中相應表項的索引。次設備號僅由設備驅動程序解釋,一般用于識別在若干可能的硬件設備中,I/O請求所涉及到的那個設備。值得一提的是次設備號還可以被分成幾個部分用來區分子設備驅動程序和具體的設備。

(3) Linux設備驅動程序組成部分

    Linux設備驅動程序可以分為三個主要組成部分:

●自動配置和初始化子程序。負責檢測所要驅動的硬件設備是否存在和是否能正常工作。如果該設備正常,則對這個設備及其相關的、設備驅動程序需要的軟硬件進行初始化。

●服務于I/O請求的子程序。它們主要是對file_operations結構的各個入口點的實現。這部分的實現支持了文件系統的調用(openclose,

read等等)

●中斷服務子程序。在Linux系統中,并不是直接從中斷向量表中調用設備驅動程序的中斷服務子程序,而是由Linux系統來接收硬件中斷,再由系統來調用中斷服務子程序。

但是,這三個部分不是必須在每個驅動程序中必須具有的。

(三)  LonWorks網卡驅動程序 

    根據Linux的設備管理以及設備驅動程序實現方法,LonWorks節點設備驅動程序即可進行編寫實現,并對實現中的一些關鍵問題進行探討。

(1) LonWorks現場總線網卡驅動程序

    在驅動程序設計和開發中,一定要注意機制(Mechanism)與策略(Policy)的分離。所謂的機制是指驅動程序提供的接口應該忠實地反映設備的原始功能,而與應用無關。而策略是指一旦這個設備驅動程序為設備機制提供了相應的軟件接口,應用程序開發人員就能按照特定的方式使用機制接口。可以說,在內核驅動程序開發過程中,所設計的數據結構,以及確定的接口命令都是為以后的應用策略提供的一種機制。而如前所述,這種機制在Unix類系統內部是通過一組固定的入口點來提供的。由于我們要開發的設備驅動程序是一個字符型的設備,所以接下來我們首先分析字符型設備驅動程序中常用的入口點:

● open入口點

    打開設備準備I/O操作。對字符設備文件進行打開操作,都會調用設備的open入口點。open子程序必須對將要進行的I/O操作做好必要的準備工作,如清除緩沖區等。如果設備是獨占的,即同一時刻只能有一個程序訪問此設備,則open子程序必須設置一些標志以表示設備處于忙狀態。 

release入口點

關閉一個設備。當最后一次使用設備終結后,調用release子程序。獨占設備必須改變前由open子程序設置的標志,以便設備可再次被使用。

read入口點

從設備上讀數據。對于有緩沖區的I/O操作,一般是從緩沖區里讀數據。對字符設備文件進行讀操作將調用read子程序。

write入口點

往設備上寫數據。對于有緩沖區的I/O操作,一般是把數據寫入緩沖區里。對字符設備文件進行寫操作將調用write子程序。

● ioctl入口點

執行讀、寫之外的一些硬件控制操作。

poll入口點

    把對許多非阻塞操作的設備描述符集合起來,等待事件的發生,以便于集中檢查,看數據是否可從設備讀取或設備是否可用于寫數據,這樣就做到了所謂的多路復用。

    以上入口點構成了設備驅動程序的三大組成部分中I/O請求的部分,在Linux中它們由file_operations結構來封裝,并不是所有的字符設備驅動程序都必須提供以上每一個入口點的實現,如果設備驅動程序沒有提供上述入口點中的某幾個,系統會用缺省的子程序來代替。

    由上面的描述可見,在內核設備驅動程序的設計中,相應的機制的提供主要是對設備入口點的選擇和設計。

    針對LonWorks網卡的特點,選擇并實現了五個入口點,即open, release,readwrite, ioctl。對于openrelease入口點由于設備特點,只需要控制設備驅動模塊在使用時,不被異常釋放即可。接下來將描述以上設計實現中與Linux內核相關的一些調用和問題。

(2) file_operations結構的初始化file_operations結構是Linux操作系統中用于實現驅動程序的最重要的數據結構,前面提到過,它對Linux提供I/O請求的子程序的一系列入口點進行了封裝。該結構貫穿在整個驅動程序中,故在文件作用域內定義了它的一個變量,并對本程序中用到的入口點做了初始化,其代碼如下:

struct file_operations lmdev_fops= {

NULL

lmdev_read,

//把實現的lmdev_read函數指針賦給read入口點。 

lmdev_write

//把實現的lmdev_write函數指針賦給write入口點。

NULL

NULL

lmdev_ioctl

//把實現的lmdev_ioctl函數指針賦給ioctl入口點。

NULL

lmdev_open

//把實現的lmdev_ open函數指針賦給open入口點。

lmdev_release

//把實現的lmdev_release函數指針賦給release入口點。

NULL

NULL

NULL

NULL,

};

對于lmdev-*函數的實現方法,我們將在后面做詳細的討論。

(3) 模塊初始化與模塊卸載

● 9;color:blue">LonWorks網卡驅動模塊初始化,通過對init_module的實現來完成以下幾個任務。以字符設備類型向系統注冊LonWorks現場總線設備卡,同時動態獲得其設備號。通過調用下面這個函數int

register_ chrdev(unsigned int major, const char*name,struct file_operations

*fops)來實現。

    這里我們使major參數為0,這樣系統就會動態的分配并返回主設備號。name參數是用于標識設備的字符串。file_operatons傳入的是如前所述的lmdev_fops。然后,向系統申請LonWorks網卡的I/O端口地址。根據該卡上的跳線得到的I/O地址,調用系統提供的宏:check_region(start,n)//檢查端口地址范圍startstart+n-1是否可用,是則返回0,否則返回1request_region(start,n,name)//用于申請通過以上函數檢查的地址范圍。接下來,做一些必要的系統日志,根據各種條件用printk向系統日志緩沖區寫入不同級別的信息。最后,控制對內核資源提供的符號表輸出的符號信息(即在可加載模塊機制部分提到的模塊要注冊的服務)。這里使用EX-PORT_NO_SYMBOLS使得該模塊不輸出任何符號信息。

LonWorks現場總線網卡模塊卸載需要完成以下幾個任務:

調用release_region(start,n)宏釋放模塊初始化時申請的I/O端口資源。

調用int unregister_chrdev(unsigned int major, const char*name);

    向系統注銷該字符設備,本程序中major參數即前面注冊時動態獲得的主設備號,name與注冊時提供的name字符串相同。調用printk函數,做一些必要的系統日志。 

(4) file operations結構中入口點的實現

openrelease入口點。

    這兩個入口點在本模塊中被賦予的就是前面在介紹file_operations結構時給出的lmdev_openlmdev_close函數指針,它們主要通過調用MOD_INC_USE_COUNTMOD_DEC_USE_COUNT來進行模塊計數。用計數來對LonWorks現場總線設備驅動模塊是否正在被使用進行控制,防止模塊正在使用時被意外卸載而導致核心對設備操作出現異常。

●對read/write入口點的實現

    這個入口點在本模塊中被賦予的就是前面在介紹file_operations結構時給出的lmdev_read函數指針,它是對設備操作的核心部分,根據前面描述的算法,它實現了如下幾個功能:

    用inb_p宏,訪問硬件的狀態和數據端口,以讀取相應的狀態和數據信息。

    調用long_sleep_on_timeout(wait_queue_head_t *q, long timeout)函數把當前進程加入時鐘等待隊列q中,使它等待timeout時間。根據LonWorks現場總線卡的工作方式來看,這樣做可以減少輪詢時間,大大的提高了效率。

    Linux分為核心空間和用戶空間,用戶空間的代碼不能直接訪問核心空間,故需調用Linux核心提供的copy_to_user(to,from,n)宏,把數據從內核空間地址from拷貝到用戶空間地址to中。這樣,系統調用返回后,用戶空間的代碼就可以通過to指針來訪問相應的數據并進行處理了。這樣核心驅動模塊部分的程序就完成了。

(5) 編譯內核模塊

    在程序完成后,用gcc編譯成目標文件(不鏈接,生成*.o文件),要做到這一點只需在gcc命令行里加上-c參數。另外,還要加上-D_KERNEL_ -DMODULE參數。上述程序可以這么編譯。

root# gcc -c -D-KERNEL_-DMODULE -Wall -02

    lmdev.c。其中參數-Wall的功能是打印附加的警告信息。由于頭文件中的函數都是聲明為inline的,還必須給編譯器指定-O選項。gcc只有打開優化選項后才能擴展內嵌函數,不過它能同時接受-g-O選項,這樣就可以調試那些內嵌函數的代碼了。優化參數-O有三個級別:Ol,02, 03,它們的優化程度不同,優化效果03大于02大于Ol。編譯好模塊后的如何加載模塊,在前面已經有所描述,這里就不再敘述了。

(四)  應用程序開發

    在對以上模塊編譯并加載后,Linux根據用戶可用mknod命令,利用動態分配的主設備號(該設備號在用戶空間可以從/proc/devices文件中用設備名獲得)建立相應的設備文件,并對它設置恰當讀寫權限后,就可以在應用程序中,使用Linux的文件系統調用通過這個設備文件來操作LonWorks現場總線卡了。這樣做不僅使得應用程序編程風格更加統一,代碼更具魯棒性,應用系統更加安全更易于維護。而且可在核心級來保證關鍵部分的實時響應,從而降低了用戶程序開發的難度。  

(本文僅供對LonWorks技術開發有興趣者學習、參考,不代表本網站同意其觀點及方法)

返回頂部

    版權所有:南京海思自動化系統有限公司    網站地圖:Sitemap        蘇ICP備13027346號-1
電話:025-52804590 52804690 地址:南京市秦淮區白下高新技術產業園區光華路162號研發孵化綜合樓2樓 網址: m.sglcjfs.com
版權所有:南京海思自動化系統有限公司
總機:025-52804590 / 52804690
市場部:8008分機  售后部:8006分機
手機:18905184663(市場)  郵箱:highsys@163.com
南京市秦淮區白下高新技術產業園區光華路162號研發孵化綜合樓2樓
日本强伦姧人妻一区二区,久久精品中文字幕一区,国产欧美日韩一区二区三区在线,亚洲午夜精品第一区二区8050
<code id="ea2gy"><pre id="ea2gy"></pre></code>
  • <acronym id="ea2gy"><th id="ea2gy"></th></acronym><fieldset id="ea2gy"><dd id="ea2gy"></dd></fieldset>
  • <noscript id="ea2gy"></noscript>
    <td id="ea2gy"><dd id="ea2gy"></dd></td>
    美女视频网站久久| 美腿丝袜亚洲一区| 视频一区视频二区中文字幕| 日韩高清欧美激情| 国产精品一色哟哟哟| 北条麻妃国产九九精品视频| 久久成人免费网| 成人av网站在线观看免费| 另类调教123区| 成人小视频免费观看| 麻豆专区一区二区三区四区五区| 懂色av一区二区三区免费观看| 蜜臀久久久久久久| www.一区二区| 国产成人精品免费在线| 蜜桃av噜噜一区| 91在线码无精品| 国产精品1024久久| 精品亚洲免费视频| 免费成人在线网站| 97精品视频在线观看自产线路二| 国内精品久久久久影院薰衣草| 三级成人在线视频| 99久久99精品久久久久久| 国产精品影视网| 国产在线精品免费| 99久久精品国产网站| 久久99国产乱子伦精品免费| 日韩一区精品视频| 99久久精品免费看| 国产成人av一区二区三区在线| 久久99精品国产麻豆婷婷洗澡| 天堂一区二区在线| 91亚洲精华国产精华精华液| 成人美女视频在线看| 国产成人高清在线| 国产成人一级电影| 国产在线视频不卡二| 精品午夜久久福利影院| 久久国产精品99久久久久久老狼 | 强制捆绑调教一区二区| jiyouzz国产精品久久| 丰满亚洲少妇av| 国产成人啪免费观看软件| 国产麻豆视频精品| 国产一区二区精品久久99| 久久99精品国产麻豆婷婷| 热久久免费视频| 日本不卡一区二区三区高清视频| 日韩电影免费一区| 美洲天堂一区二卡三卡四卡视频| 麻豆一区二区三| 经典一区二区三区| 国产精品18久久久久| 成人久久视频在线观看| av一本久道久久综合久久鬼色| av综合在线播放| 视频一区视频二区在线观看| 男女男精品视频| 精品影院一区二区久久久| 国产一区二区看久久| 成人美女视频在线看| 日韩成人午夜电影| 国产一区二区不卡老阿姨| 国产成人免费av在线| 成人h动漫精品一区二| 91社区在线播放| 麻豆成人在线观看| 国产成人精品综合在线观看 | 成人av在线播放网站| 97se亚洲国产综合在线| 日本不卡免费在线视频| 国产真实乱偷精品视频免| 粉嫩13p一区二区三区| 91蜜桃婷婷狠狠久久综合9色| 美洲天堂一区二卡三卡四卡视频| 国产精品一二三在| 视频一区欧美日韩| 国产激情视频一区二区三区欧美 | 免费在线一区观看| 国产盗摄视频一区二区三区| 99国产精品99久久久久久| 免费观看在线综合色| 国产成人精品亚洲日本在线桃色 | 日本不卡123| 国产精品91xxx| 91视频com| 国产91露脸合集magnet| 视频一区国产视频| 国产成人在线色| 奇米精品一区二区三区四区| 国产suv精品一区二区6| 美国欧美日韩国产在线播放 | 播五月开心婷婷综合| 久久99蜜桃精品| av午夜一区麻豆| 国产麻豆精品久久一二三| 91丨porny丨国产| 成人精品视频一区二区三区| 蜜臀av性久久久久蜜臀aⅴ流畅| 成人妖精视频yjsp地址| 精品制服美女丁香| 青青草一区二区三区| 成人性视频网站| 日本va欧美va精品| 99re成人精品视频| 国产精品99久久久久久有的能看| 男男视频亚洲欧美| 视频一区视频二区在线观看| proumb性欧美在线观看| 粉嫩aⅴ一区二区三区四区五区| 狠狠色丁香久久婷婷综合丁香| 91视频com| 91免费观看视频在线| 国产成人午夜电影网| 九九九久久久精品| 美国三级日本三级久久99| 日韩精品一级二级| 天堂在线亚洲视频| 91美女片黄在线观看| 97se亚洲国产综合自在线观| www.av精品| 91网址在线看| 99国产精品一区| 天堂在线一区二区| 成人av电影免费观看| 成人精品gif动图一区| 成人中文字幕合集| 成人av电影在线网| 91在线视频免费观看| 白白色亚洲国产精品| 国产精品88av| 懂色一区二区三区免费观看| 成人精品高清在线| 91麻豆.com| 日韩av不卡在线观看| 青草av.久久免费一区| 久久精品av麻豆的观看方式| 韩国女主播成人在线| 国产一区二区不卡老阿姨| 成人综合婷婷国产精品久久蜜臀| 成人av资源网站| 日韩精品色哟哟| 久久国产欧美日韩精品| 国产一区不卡在线| av欧美精品.com| 青青草国产成人99久久| 国产一区二区三区在线观看精品 | 丁香六月综合激情| 成人动漫一区二区三区| 91碰在线视频| 国产一区二区中文字幕| 成+人+亚洲+综合天堂| 91啪亚洲精品| 激情久久五月天| 成人动漫在线一区| 美女性感视频久久| 国产成人亚洲综合a∨猫咪| 成人av在线网| 美女网站在线免费欧美精品| 国产99久久久久久免费看农村| 99久久精品免费看| 久久99精品一区二区三区| 国产精品99久久久久久有的能看| 91在线观看免费视频| 久久国产精品免费| 99re8在线精品视频免费播放| 看国产成人h片视频| 粉嫩欧美一区二区三区高清影视 | 91免费国产在线观看| 激情综合色播五月| 99精品黄色片免费大全| 蜜臀av性久久久久蜜臀aⅴ四虎| 国产精品一区二区三区乱码 | 日韩高清欧美激情| 国产99久久久国产精品潘金| 91美女精品福利| 国产精品1024久久| 久久爱另类一区二区小说| a美女胸又www黄视频久久| 狠狠久久亚洲欧美| 91丝袜美腿高跟国产极品老师| 国产一区不卡在线| 麻豆专区一区二区三区四区五区| av一二三不卡影片| 国产91色综合久久免费分享| 看电视剧不卡顿的网站| 91免费精品国自产拍在线不卡| 国产盗摄女厕一区二区三区| 激情深爱一区二区| 麻豆freexxxx性91精品| 91一区二区在线| 福利一区二区在线观看| 激情综合色播五月| 国产综合久久久久影院| caoporen国产精品视频| 高清日韩电视剧大全免费| 狠狠色丁香久久婷婷综合_中| 三级一区在线视频先锋| caoporm超碰国产精品| 成人深夜视频在线观看| 国产精品影音先锋| 国产成人综合亚洲网站| 国产一区二区调教| 国产美女在线观看一区| 国产一区三区三区| 国产一二三精品| 韩国女主播成人在线| 九九精品视频在线看| 国模少妇一区二区三区| 韩国精品一区二区| 国产成人综合亚洲网站| 成人午夜视频免费看| 国产精品 欧美精品| 懂色av中文字幕一区二区三区| 成人网在线播放| 成人美女在线视频| 99国产精品国产精品毛片| 91丝袜呻吟高潮美腿白嫩在线观看| www.欧美精品一二区| 99久久夜色精品国产网站| 不卡的看片网站| 石原莉奈在线亚洲二区| 蜜桃视频免费观看一区| 精品亚洲国内自在自线福利| 国产精品一区二区黑丝| 成人蜜臀av电影| 91蜜桃在线免费视频| 美女国产一区二区三区| 国产剧情一区二区| 成人黄页毛片网站| 91免费视频网| 韩国av一区二区| 成人免费不卡视频| 日本欧美大码aⅴ在线播放| 国产自产v一区二区三区c| 粉嫩13p一区二区三区| 日日欢夜夜爽一区| 狠狠色丁香久久婷婷综| 成人av网址在线观看| 免费观看成人av| 国产91高潮流白浆在线麻豆| 99久久精品费精品国产一区二区| 91麻豆国产福利精品| 精品在线播放免费| av电影一区二区| 精品一区二区精品| 北岛玲一区二区三区四区| 捆绑变态av一区二区三区| 福利一区二区在线观看| 蜜臀精品久久久久久蜜臀| 国产成人精品一区二区三区四区| 97久久超碰精品国产| 韩国v欧美v日本v亚洲v| 91在线看国产| 国产激情一区二区三区四区| 青青草精品视频| 波多野结衣视频一区| 国产综合色视频| 日本在线观看不卡视频| 国产精品77777竹菊影视小说| 日韩成人av影视| 岛国一区二区三区| 老司机免费视频一区二区三区| 99热精品国产| 国产成人av福利| 免费不卡在线观看| 不卡在线观看av| 国产成人亚洲精品青草天美| 久久成人免费网| 欧美aaa在线| av日韩在线网站| 成人小视频免费在线观看| 精品一区二区影视| 日韩精品视频网| 99精品视频在线免费观看| 国产麻豆视频一区| 精久久久久久久久久久| 免费欧美在线视频| 日韩精品一二三区| 91美女在线视频| av电影在线观看不卡| 国产成人精品免费在线| 国产精品亚洲视频| 国内成+人亚洲+欧美+综合在线| 热久久国产精品| 欧美aaaaa成人免费观看视频| 99精品一区二区三区| 成人av综合在线| 成人免费视频视频在线观看免费| 国产一区二区三区免费观看| 九九九久久久精品| 精品一区二区三区在线播放| 青青草成人在线观看| 日韩va欧美va亚洲va久久| 日一区二区三区| 99国产精品国产精品毛片| 91在线porny国产在线看| 99re这里都是精品| 91免费国产在线| 人妖欧美一区二区| 久久aⅴ国产欧美74aaa| 国产专区欧美精品| 国产成人自拍网| 粉嫩绯色av一区二区在线观看| www.视频一区| 日韩av电影一区| 粉嫩13p一区二区三区| 国产精品伊人色| 成人小视频免费在线观看| 成人av在线资源网站| 91亚洲国产成人精品一区二三| 99久久久久久| 日本人妖一区二区| 美国十次了思思久久精品导航 | 精油按摩中文字幕久久| 国产在线一区二区综合免费视频| 国产精品亚洲午夜一区二区三区 | 丁香一区二区三区| 不卡一区二区三区四区| 91看片淫黄大片一级在线观看| 奇米一区二区三区| 国产成人精品一区二区三区网站观看| av午夜精品一区二区三区| 日本欧美一区二区三区乱码| 精品在线你懂的| 99在线热播精品免费| 蜜臀精品一区二区三区在线观看 | 老司机免费视频一区二区三区| 国产一区二区不卡| 99精品国产一区二区三区不卡| 久久超碰97人人做人人爱| 成人性生交大片免费看中文| 免费观看日韩av| 成人avav在线| 久久爱另类一区二区小说| 不卡一二三区首页| 九色综合狠狠综合久久| 国产成人精品免费| 麻豆国产精品视频| 国产成人综合在线播放| 日韩国产精品久久久| 国产精品综合二区| 日韩精品乱码免费| 国产成人精品免费网站| 蜜臀av性久久久久蜜臀av麻豆 | 成人一级黄色片| 久久精品国产77777蜜臀| 99久久综合狠狠综合久久| 精品一区在线看| 日本 国产 欧美色综合| av爱爱亚洲一区| 国产乱对白刺激视频不卡| 日本少妇一区二区| av激情亚洲男人天堂| 国产精品123区| 国产一区二区三区四区在线观看| 91亚洲精品一区二区乱码| 国产成人精品亚洲777人妖| 免费在线成人网| 91丨九色丨蝌蚪丨老版| 成人av网站免费观看| 国产成人免费在线观看| 激情五月婷婷综合网| 麻豆91小视频| 日韩和欧美的一区| youjizz久久| a级高清视频欧美日韩| 处破女av一区二区| 国产高清在线观看免费不卡| 久草中文综合在线| 激情综合色综合久久| 裸体一区二区三区| 成人午夜激情片| 国产成人免费在线| 麻豆一区二区三区| 成人天堂资源www在线| 99国产精品视频免费观看| 精品一二线国产| 丝袜脚交一区二区| 99久久免费国产| 国产成人亚洲综合a∨猫咪| 久久超碰97中文字幕| 轻轻草成人在线| 日本麻豆一区二区三区视频| 91首页免费视频| 日韩精彩视频在线观看| 97久久超碰精品国产| 不卡一区在线观看| 99精品热视频| 日韩精品久久久久久| 全部av―极品视觉盛宴亚洲| 日韩vs国产vs欧美| 麻豆久久久久久久| 精品一区二区三区在线观看| 国产精品自在在线| 成人亚洲一区二区一| 91丨九色丨黑人外教| 奇米亚洲午夜久久精品| 精品一二线国产|