日韩av色在线_av不卡在线观看_亚洲国产精品第一页_在线看日本不卡_色成人综合网_国产丝袜在线视频_国产精成人品localhost_国产91富婆露脸刺激对白_韩国视频一区_国产精品人成电影

Hi,歡迎來到嵌入式培訓(xùn)高端品牌 - 華清遠(yuǎn)見教育科技集團(tuán)<北京總部官網(wǎng)>,專注嵌入式工程師培養(yǎng)15年!
當(dāng)前位置: > 華清遠(yuǎn)見教育科技集團(tuán) > 嵌入式學(xué)習(xí) > 講師博文 > 如何學(xué)習(xí)linux設(shè)備驅(qū)動(dòng)
如何學(xué)習(xí)linux設(shè)備驅(qū)動(dòng)
時(shí)間:2017-01-05作者:華清遠(yuǎn)見

Linux系統(tǒng)目前主要維護(hù)2.4和2.6兩個(gè)內(nèi)核版本,在//www.kernel.org/ 網(wǎng)站上已經(jīng)可以下載到新的2.6內(nèi)核linux-2.6.38.6,及新的2.4內(nèi)核linux-2.4.37.11。穩(wěn)定版本號(hào)基本上是1~3月更新一次,如:2.6.35至2.6.36,升級(jí)版本號(hào)每1~2周更新一次,如:2.6.35.1至2.6.35.2。 升級(jí)后的高版本內(nèi)核并不完全兼容低版本內(nèi)核,所以內(nèi)核升級(jí)對(duì)于從事linux開發(fā)的技術(shù)人員來說影響很大,特別是對(duì)于那些剛剛從事linux開發(fā)的人員。

通常,內(nèi)核的升級(jí)對(duì)從事linux應(yīng)用程序開發(fā)的人員來說影響較小,因?yàn)橄到y(tǒng)調(diào)用基本保持兼容,影響比較大的是驅(qū)動(dòng)開發(fā)人員。每次內(nèi)核的更新都可能導(dǎo)致許多內(nèi)核函數(shù)原型上的變化,其中既有內(nèi)核本身提供的函數(shù),也有硬件平臺(tái)代碼提供的函數(shù),后者變化的更加頻繁。這一點(diǎn)從許多經(jīng)典書籍就可驗(yàn)證,當(dāng)你按照手里的經(jīng)典著作,如:Alessandro的《linux設(shè)備驅(qū)動(dòng)程序》,編寫驅(qū)動(dòng)時(shí),發(fā)現(xiàn)并不能夠成功的在你的linux平臺(tái)上編譯通過、或不能正常執(zhí)行,原因就在于你用的內(nèi)核和書里的不一致。

本文從兩個(gè)方面去解釋這個(gè)問題,一方面是如何寫好linux設(shè)備驅(qū)動(dòng),另一方面是如何應(yīng)對(duì)不斷升級(jí)的內(nèi)核。

如何寫好Linux設(shè)備驅(qū)動(dòng)

Linux設(shè)備驅(qū)動(dòng)是linux內(nèi)核的一部分,是用來屏蔽硬件細(xì)節(jié),為上層提供標(biāo)準(zhǔn)接口的一種技術(shù)手段。為了能夠編寫出質(zhì)量比較高的驅(qū)動(dòng)程序,要求工程師必須具備以下幾個(gè)方面的知識(shí):

●    熟悉處理器的性能

如:處理器的體系結(jié)構(gòu)、匯編語(yǔ)言、工作模式、異常處理等。對(duì)于初學(xué)者來說,在還不熟悉驅(qū)動(dòng)編寫方法的情況下,可以先不把重心放在這一項(xiàng)上,因?yàn)榭赡芤驗(yàn)樗目菰铩⒊橄蠖绊懙侥銓?duì)設(shè)備驅(qū)動(dòng)的興趣。隨著你不斷地熟悉驅(qū)動(dòng)的編寫,你會(huì)很自然的意識(shí)到此項(xiàng)的重要性。

●    掌握驅(qū)動(dòng)目標(biāo)的硬件工作原理及通訊協(xié)議

如:串口控制器、顯卡控制器、硬件編解碼、存儲(chǔ)卡控制器、I2C通訊、SPI通訊、USB通訊、SDIO通訊、I2S通訊、PCI通訊等。編寫設(shè)備驅(qū)動(dòng)的前提就是需要了解設(shè)備的操作方法,所以這些內(nèi)容的重要程度不言而喻。但不是說要把所有設(shè)備的操作方法都熟悉了以后才可以寫驅(qū)動(dòng),你只需要了解你要驅(qū)動(dòng)的硬件就可以了。

●    掌握硬件的控制方法

如:中斷、輪詢、DMA 等,通常一個(gè)硬件控制器會(huì)有多種控制方法,你需要根據(jù)系統(tǒng)性能的需要合理的選擇操作方法。初學(xué)階段以實(shí)現(xiàn)功能為目的,掌握的順序應(yīng)該是,輪詢->中斷->DMA。隨著學(xué)習(xí)的深入,需要綜合考慮系統(tǒng)的性能需求,采取合適的方法。

●    良好的GNU C語(yǔ)言編程基礎(chǔ)

如:C語(yǔ)言的指針、結(jié)構(gòu)體、內(nèi)存操作、鏈表、隊(duì)列、棧、C和匯編混合編程等。這些編程語(yǔ)法是編寫設(shè)備驅(qū)動(dòng)的基礎(chǔ),無論對(duì)于初學(xué)者還是有經(jīng)驗(yàn)者都非常重要。

●    良好的linux操作系統(tǒng)概念

如:多進(jìn)程、多線程、進(jìn)程調(diào)度、進(jìn)程搶占、進(jìn)程上下文、虛擬內(nèi)存、原子操作、阻塞、睡眠、同步等概念及它們之間的關(guān)系。這些概念及方法在設(shè)備驅(qū)動(dòng)里的使用是linux設(shè)備驅(qū)動(dòng)區(qū)別單片機(jī)編程的大特點(diǎn),只有理解了它們才會(huì)編寫出高質(zhì)量的驅(qū)動(dòng)。

●    掌握l(shuí)inux內(nèi)核中設(shè)備驅(qū)動(dòng)的編寫接口

如:字符設(shè)備的cdev、塊設(shè)備的gendisk、網(wǎng)絡(luò)設(shè)備的net_device,以及基于這些基本接口的framebuffer設(shè)備的fb_info、mtd設(shè)備的mtd_info、tty設(shè)備的tty_driver、usb設(shè)備的usb_driver、mmc設(shè)備的mmc_host等。

Linux內(nèi)核為設(shè)備驅(qū)動(dòng)編寫者提供了標(biāo)準(zhǔn)的接口,驅(qū)動(dòng)編寫者無需精通內(nèi)核的各個(gè)部分,只需要明確內(nèi)核提供給我們的接口,并實(shí)現(xiàn)此接口就可以了。內(nèi)核提供的接口采用的是面向?qū)ο蟮乃悸罚窗涯繕?biāo)設(shè)備抽象成一個(gè)對(duì)象,通常利用一個(gè)結(jié)構(gòu)體來描述這個(gè)對(duì)象。驅(qū)動(dòng)工程師的任務(wù)就是實(shí)現(xiàn)這個(gè)對(duì)象。這個(gè)結(jié)構(gòu)體中會(huì)包含設(shè)備的屬性(用變量表示)和操作方法(用函數(shù)指針表示)。如:字符設(shè)備的cdev

struct cdev {
                struct kobject        kobj;
                struct module        *owner;
                const struct file_operations         *ops;        // 操作方法結(jié)合,其它項(xiàng)都是屬性 
                struct list_head        list;
                dev_t                        dev;
                unsigned int        count;
        };

開始階段可以以模仿為主,即套用一些固定的模板、參考例程。

如何應(yīng)對(duì)不斷升級(jí)的內(nèi)核

內(nèi)核升級(jí)對(duì)驅(qū)動(dòng)的影響主要體現(xiàn)在,(1)驅(qū)動(dòng)接口定義的變化;(2)內(nèi)核的一些功能函數(shù)的名稱、參數(shù)、頭文件、宏定義的變化;(3)平臺(tái)代碼關(guān)于硬件操作方面封裝的一些函數(shù)的變化;(4)設(shè)備模型的影響。

●    驅(qū)動(dòng)接口定義的變化

如:2.4內(nèi)核中字符設(shè)備驅(qū)動(dòng)的注冊(cè)接口是:

int register_chrdev(unsigned int major, const char * name, struct file_operations *fops)

而2.6內(nèi)核中已經(jīng)不建議使用這種方法了,改為:

int cdev_add(struct cdev *p, dev_t dev, unsigned count)

這種接口定義及注冊(cè)方法帶來的變化,發(fā)生的并不頻繁。解決方案是:參考內(nèi)核中的代碼。這種接口定義及注冊(cè)方法在內(nèi)核中非常容易找到,如:字符設(shè)備驅(qū)動(dòng)的注冊(cè)方法及接口定義可以參照內(nèi)核driver/char/目錄下的很多實(shí)例。

●    內(nèi)核的一些功能函數(shù)的名稱、參數(shù)、頭文件、宏定義的變化

如:中斷注冊(cè)函數(shù)的格式及參數(shù)在2.4內(nèi)核、2.6內(nèi)核低版本和高版本之間都存在差別,在2.6.8中,中斷注冊(cè)函數(shù)的定義為:

int request_irq(unsigned int irq, irqreturn_t (*handler)(int, void *, struct pt_regs *),unsigned long irq_flags, const char * devname, void *dev_id)

irq_flags的取值主要為下面的某一種或組合: SA_INTERRUPT、SA_SAMPLE_RANDOM、SA_SHIRQ

在2.6.26中,中斷注冊(cè)函數(shù)的定義為:

int request_irq(unsigned int irq, irq_handler_t handler,unsigned long irqflags, const char *devname, void *dev_id)

typedef irqreturn_t (*irq_handler_t)(int, void *); irq_flags的取值主要為下面的某一種或組合:(功能和2.6.8的對(duì)應(yīng))IRQF_DISABLED、IRQF_SAMPLE_RANDOM、IRQF_SHARED

當(dāng)出現(xiàn)這些問題時(shí),編譯過程中,編譯器會(huì)給我們比較明確的錯(cuò)誤提示,根據(jù)這些提示你可以判斷出是否是缺少頭文件問題、是否是函數(shù)參數(shù)定義有誤等。解決問題的好辦法還是到你的目標(biāo)內(nèi)核中找信息。此時(shí)找問題的方法可以借助于搜索,如:你可以在新的內(nèi)核中搜索request_irq,看新內(nèi)核中的驅(qū)動(dòng)是如何使用它的,這種方法非常有效。

●    平臺(tái)代碼關(guān)于硬件操作方面封裝的一些函數(shù)的變化

內(nèi)核中,硬件平臺(tái)相關(guān)的代碼在內(nèi)核更新過程中變化比較頻繁,和我們的設(shè)備驅(qū)動(dòng)也是息息相關(guān),所以在針對(duì)一個(gè)新內(nèi)核編寫設(shè)備驅(qū)動(dòng)前,一定要熟悉你的平臺(tái)代碼的結(jié)構(gòu)。有時(shí)平臺(tái)雖然提供了內(nèi)核要求的接口函數(shù),但使用起來功能卻并不完善。下面還是先舉個(gè)例子說明平臺(tái)代碼更新對(duì)設(shè)備驅(qū)動(dòng)的影響。

如:在linux-2.6.8內(nèi)核中,調(diào)用set_irq_type(IRQ_EINT0,IRQT_FALLING);去設(shè)置S3C2410的IRQ_EINT0的中斷觸發(fā)信號(hào)類型,你會(huì)發(fā)現(xiàn)不會(huì)有什么效果。跟蹤代碼發(fā)現(xiàn)內(nèi)核的set_irq_type函數(shù)需要平臺(tái)提供一個(gè)針對(duì)硬件平臺(tái)的實(shí)現(xiàn)函數(shù)

static struct irqchip s3c_irqext_chip = {
                .mask = s3c_irqext_mask,
                .unmask = s3c_irqext_unmask,
                .ack = s3c_irqext_ack,
                .type = s3c_irqext_type
        };

s3c_irqext_type就是linux內(nèi)核需要的實(shí)現(xiàn)函數(shù),而s3c_irqext_type在2.6.8中的實(shí)現(xiàn)為: static int s3c_irqext_type(unsigned int irq, unsigned int type)
        {
                irqdbf("s3c_irqext_type: called for irq %d, type %d\n", irq, type);
                return 0;
        }

原來并沒有實(shí)現(xiàn)。而在較高版本的內(nèi)核,如2.6.26內(nèi)核中,這個(gè)函數(shù)是實(shí)現(xiàn)了的。所以你一定要小心。當(dāng)平臺(tái)函數(shù)不好用時(shí),一定要查查原因,或者直接操作硬件寄存器來達(dá)到目的。

●    2.6內(nèi)核設(shè)備模型對(duì)驅(qū)動(dòng)的影響

在2.6內(nèi)核中寫設(shè)備驅(qū)動(dòng)和在2.4內(nèi)核中有著很大的不同,主要就是在設(shè)備驅(qū)動(dòng)中融入了比設(shè)備驅(qū)動(dòng)本身結(jié)構(gòu)還復(fù)雜、還難以理解的設(shè)備模型。初學(xué)驅(qū)動(dòng)時(shí)你可以不理會(huì)設(shè)備模型,但你會(huì)發(fā)現(xiàn)內(nèi)核里的驅(qū)動(dòng)代碼基本上都是融入了設(shè)備模型的了。所以很多時(shí)候你不得不面對(duì)現(xiàn)實(shí),還是要弄懂它,并且它也的注冊(cè)方法也會(huì)隨著內(nèi)核的升級(jí)而發(fā)生變化。解決此類問題的好方法還是參考目標(biāo)內(nèi)核驅(qū)動(dòng)代碼。

總結(jié):

開始學(xué)習(xí)設(shè)備驅(qū)動(dòng)時(shí),選擇一個(gè)當(dāng)前比較流行的內(nèi)核版本和硬件平臺(tái),不急于追趕新潮流。這樣你可以找到的網(wǎng)絡(luò)資源會(huì)比較多,不至于有孤軍奮戰(zhàn)的感覺。我想這個(gè)過程應(yīng)該不低于1年。當(dāng)過了這個(gè)過程后,嘗試將你編寫過的驅(qū)動(dòng)移植到各個(gè)目標(biāo)平臺(tái)上。

(本文參考了一些網(wǎng)上資料,因原出處不詳,特向資料的原作者致謝!)

發(fā)表評(píng)論
評(píng)論列表(網(wǎng)友評(píng)論僅供網(wǎng)友表達(dá)個(gè)人看法,并不表明本站同意其觀點(diǎn)或證實(shí)其描述)
日本一区二区三区免费观看 | 久久久999| 亚洲免费福利| 中国在线观看免费国语版电影| 日韩中文字幕观看| 极品久久久久久久| 男人透女人免费视频| 国产美女精品在线观看| 高清视频欧美一级| 精品国产一区二区三区久久久蜜月 | 欧美成人aaa片一区国产精品| 欧美精品成人网| 日本一区高清不卡| 国产精品99久久久久久久久| 亚洲欧美国产日韩中文字幕| 一本大道久久a久久精二百| 不卡大黄网站免费看| 99国产精品久久久久久久成人热| 久久1电影院| 水蜜桃在线视频| 国产精品毛片一区二区三区四区| 性生活视频网址| 日韩在线观看视频一区| 国产成人无码精品久久久久| 中文字幕在线免费看线人| 亚洲色成人一区二区三区小说| 精品蜜桃一区二区三区| 欧美亚洲另类视频| www.久久久久| 国产午夜精品理论片a级探花| heyzo久久| 在线看片福利| 麻豆视频在线免费观看| 污视频网站免费看| 午夜私人影院在线观看| 久久综合第一页| 国内毛片毛片毛片毛片| 国产精品7777777| 日韩av毛片在线观看| 亚洲精品乱码久久久久久蜜桃欧美| 97超碰青青草| 青草视频在线观看视频| 欧美日韩国产综合视频在线| 91精品国产综合久久香蕉| 久久久久久一区二区三区| 国产亚洲欧美aaaa| 日韩av一区在线观看| 欧美久久久一区| 欧美在线小视频| 色哟哟一区二区三区| 亚洲一区二区三区在线播放| 欧美极品美女视频| 久久精品亚洲精品国产欧美kt∨| 成人午夜视频网站| 老司机精品视频导航| 亚洲一级在线| 亚洲欧美日韩国产一区| 黄色综合网站| 亚洲经典视频在线观看| 午夜精品久久| 影音先锋亚洲精品| 激情文学一区| 99在线精品视频在线观看| 欧美久久影院| 在线观看的日韩av| 国产精品久久国产愉拍| 国产欧美不卡| 日韩精品电影在线观看| 视频一区国产视频| 伊人久久噜噜噜躁狠狠躁| 国产欧美视频在线| 日韩成人18| 欧美一级一片| 四虎成人av| 欧美99在线视频观看| 欧美三级特黄| 影音先锋久久久| 老牛嫩草一区二区三区日本| 美腿丝袜亚洲色图| 国产寡妇亲子伦一区二区| 国产91精品久久久久久久网曝门| 成人av网站免费| 日本一区二区三区视频视频| 中文字幕中文字幕在线一区| 亚洲一区二区中文在线| 福利一区福利二区微拍刺激| 女人天堂亚洲aⅴ在线观看| www.国产毛片| 黄网av在线| 国产女人aaa级久久久级| 91中文字精品一区二区| 中文字幕免费观看视频| 久久精品免费电影| 一区二区精品免费| 黄色精品免费看| 欧美成人精品一级| 都市激情亚洲色图| 亚洲欧美另类动漫| 国产69精品久久久久孕妇| 国产精品一区二区在线观看不卡 | 日韩精品小视频| 制服 丝袜 综合 日韩 欧美| 日韩专区av| 欧美视频免费在线| 少妇伦子伦精品无吗| 国产婷婷视频在线 | 日本视频在线| 国产午夜精品一区二区三区| 欧美深夜福利视频| 中文字幕校园春色| 中文字幕免费在线观看视频一区| 制服国产精品| 中文字幕在线免费播放| 亚洲日本成人在线观看| 浓精h攵女乱爱av| av黄色在线| 精品久久久久99| 亚洲精品www久久久久久| 五月综合久久| 国产精品夫妻激情| 一色屋成人免费精品网| 国产在线视频不卡二| 在线一区亚洲| 黄色大片在线看| 欧美一级理论片| 久草视频中文在线| 日韩欧美不卡| 国内精品二区| 欧美激情图区| 91精品视频网| 日韩美女免费线视频| 国产丰满美女做爰| 国产成人综合在线观看| ww国产内射精品后入国产| 国产日产一区二区三区| 亚洲国产欧美一区| 二区三区在线视频| 99久久精品一区二区| 一个人看的视频www| 日韩中文字幕无砖| 91精品视频在线看| 国产网友自拍电影在线| 欧美片网站yy| 97caocao| 久久久久久久久久久久久夜| 亚洲一区二区三区四区五区六区 | 日本一区二区不卡在线| 九色视频网站入口| 色av成人天堂桃色av| 日韩特黄一级片| 日本人妖一区二区| 亚洲精品无码久久久久久久| 91精品啪在线观看国产手机| 国产成人精品一区二区三区福利| 香蕉影院在线| 亚洲新声在线观看| 国产区卡一卡二卡三乱码免费| 亚洲国产中文字幕| 五月婷婷激情视频| 丁香网亚洲国际| 久久噜噜色综合一区二区| 亚洲在线成人| 亚洲国产日韩在线一区| 久久国产成人精品| 少妇无码av无码专区在线观看| 国产精品蜜月aⅴ在线| 97免费高清电视剧观看| 伊人222成人综合网| 日本精品免费一区二区三区| 最新在线你懂的| 久久99久久99精品中文字幕| 嫩草影院发布页| 欧美男插女视频| 导航福利在线| 午夜精品久久久99热福利| 亚洲精品一区视频| 欧美一区二区三区四区在线| 国产精品99999| 国产在线拍揄自揄视频不卡99| 成人综合av| 精品欧美一区二区三区精品久久| 国产精品一区二区午夜嘿嘿嘿小说| 欧美色涩在线第一页| 无国产精品白浆免费视| 亚洲美女黄色| 在线黄色免费观看| 在线精品一区二区| 久久久久国产精品无码免费看| 日日摸夜夜添夜夜添精品视频 | 欧美另类高清videos| 国产中文字幕在线| 国产乱子伦精品| 一区二区三区四区视频免费观看| 欧美精品一区二区三区三州| 一区二区三区午夜视频| 黄色性生活一级片| 久久精品日韩一区二区三区| 国产男男gay体育生网站| 欧美日本免费一区二区三区| 成年免费网站| 97中文在线观看| 粉嫩的18在线观看极品精品| 五月天视频在线观看| 久久99热狠狠色一区二区| 丁香社区五月天| 欧美日韩二区三区| 免费三级欧美电影| 成人天堂噜噜噜| 加勒比久久高清| 大地资源二中文在线影视观看| 久久久国产精品午夜一区ai换脸| 欧美一级性视频| 日韩视频在线免费观看| 国精产品一区一区三区四川| 欧美激情第3页| 久久精品一区八戒影视| 国产乱视频在线观看播放| 欧美专区中文字幕| 亚洲精品一区二区三区在线| 黄色国产在线视频| 亚洲成人中文在线| 在线免费观看色| 亚洲国产成人精品无码区99| 国产精品一区二区男女羞羞无遮挡| 91无套直看片红桃| 久久成人亚洲精品| 国产精品外围在线观看| 国产在线视频一区二区| 99热这里只有精品2| 9l国产精品久久久久麻豆| 男女啪啪网站| 国产精品电影在线观看| 欧美一区电影| 国产精品久久久久久久久毛片 | 91大片在线观看| 午夜在线播放视频欧美| 风流老熟女一区二区三区| 午夜欧美不卡精品aaaaa| 福利在线一区| 久久久久久亚洲av无码专区| 久久精品中文字幕| 午夜精品福利影院| 中日精品一色哟哟| 国内久久久精品| 国模大胆一区二区三区| 国产特黄一级片| 国产欧美 在线欧美| 国产精品久久久久久久免费软件| 天堂中文在线观看| 久久国产精品免费一区| 成人av在线资源| 久草视频在线播放| 欧美日韩中文不卡| 欧美日韩国产片| 国产精品视频一区二区三区| www.国产一区二区| 国产精品嫩草影院一区二区| 久久久亚洲人| 日本视频一二区| 91丨九色丨蝌蚪| 精品奇米国产一区二区三区| gogo人体一区| 99久久国产综合精品五月天喷水| 91蜜桃视频在线| 大片免费在线看视频| 欧美日韩生活片| 欧美激情videoshd| 99精品国产福利在线观看免费| 夜夜爽视频导航| 男人亚洲天堂网| 欧美精品一区二区三区四区| 视频国产一区| 国产精品在线| 日本xxxxxxx免费视频| 日韩欧美视频一区| 91精品一区国产高清在线gif| 国产精品免费视频二三区 | 亚洲国产欧美久久| 亚洲精品国产偷自在线观看| 免费影视观看网站入口| 密臀av一区二区三区| 欧美精品一区视频| 欧美日韩午夜| 另类图片激情| 性欧美疯狂猛交69hd| 国产欧美日韩91| 亚洲蜜臀av乱码久久精品蜜桃| 亚洲第一二三四区| 无码国产精品96久久久久| 人妻少妇精品久久| 69久久99精品久久久久婷婷| 91九色精品| 一级二级三级在线观看| 日本精品人妻无码77777| 国产伦精品一区二区三区免费视频 | 亚洲综合色婷婷| 在线视频中文字幕久| 农村黄色一级片| 欧美视频小说| 亚洲第一av在线| 日日夜夜精品视频天天综合网| 蜜芽在线免费观看| а√天堂资源在线| 久久精品网站视频| 97香蕉久久超级碰碰高清版| 亚洲永久免费视频| 亚洲精品二区三区| 日韩乱码人妻无码中文字幕| 久久免费看毛片| 欧美日韩国产免费| 永久免费在线| 日本精品一二三区| 国产精品久久久久久久久久久不卡| 亚洲精品乱码久久久久| 色婷婷综合网| 黄色网页在线免费观看| 亚洲网站一区| 2017亚洲天堂| 99亚洲国产精品| 97av在线视频| 欧美日韩国产首页在线观看| 日韩av中文在线观看| 激情综合婷婷| yourporn在线观看中文站| 亚洲免费视频在线| 亚洲国产123| 欧美精品99久久| y111111国产精品久久婷婷| 亚洲黄色成人网| 亚洲精品国产a| 青青草一区二区三区| 第四色在线一区二区| 精品麻豆一区二区三区| 国产精品视频流白浆免费视频| 九九精品视频免费| 99免费视频观看| 久久婷婷人人澡人人喊人人爽| 爽爽爽爽爽爽爽成人免费观看| 精品久久香蕉国产线看观看gif| 日本欧美久久久久免费播放网| 动漫视频在线一区| 欧美理论电影| 性生大片免费观看性| 日本男人天堂网| 波多野结衣二区三区| 中文字幕精品亚洲| 亚洲欧美aaa| 男女激情免费视频| 免费不卡亚洲欧美| 国产精品视频不卡| 色偷偷噜噜噜亚洲男人的天堂| 欧美午夜一区二区三区免费大片| 91啪亚洲精品| 蜜臀国产一区二区三区在线播放 | 欧美日韩a v| 久久9999久久免费精品国产| 丁香花在线影院观看在线播放| 国产精品免费一区二区三区| 99久久精品免费看| 激情欧美丁香| 99热精品久久| heyzo久久| 少妇精品导航| 涩涩屋成人免费视频软件| 午夜影院在线观看国产主播| 免费黄网站在线| 91精品专区| 成人综合影院| 国产三区四区在线观看| 在线观看视频你懂的| 久草一本av| 91美女在线| h色视频在线观看| 伦理电影国产精品| 1024在线视频| 可以直接在线观看的av| 免费在线看v| 在线视频婷婷| yellow91字幕网在线| 羞羞网站在线免费观看| rebdb初裸写真在线观看| gogo高清在线播放免费| 精品欧美一区二区三区在线观看| 欧美色网一区| 岛国成人av| 欧美成人自拍| 99这里有精品| 六月丁香综合| 国产不卡一区视频| 久久精品欧美一区二区三区不卡 | 午夜视频精品| 日本v片在线高清不卡在线观看| 国产乱码精品一区二区三区av | 久久久精品2019中文字幕神马| 日韩在线www| 国产九九精品视频| 蜜桃视频在线观看成人| 免费看日本毛片| 影音先锋资源av| wwwav国产|