国产剧情视频在线观看-国产剧情麻豆女教师在线观看-国产剧情精品在线观看-国产剧情精品-国产剧情91-国产玖玖在线观看


曙海教育集團(tuán)論壇Linux專區(qū)Linux驅(qū)動(dòng)開(kāi)發(fā) → 嵌入式Linux系統(tǒng)中MMC卡驅(qū)動(dòng)管理技術(shù)研究


  共有12246人關(guān)注過(guò)本帖樹(shù)形打印

主題:嵌入式Linux系統(tǒng)中MMC卡驅(qū)動(dòng)管理技術(shù)研究

美女呀,離線,留言給我吧!
wangxinxin
  1樓 個(gè)性首頁(yè) | 博客 | 信息 | 搜索 | 郵箱 | 主頁(yè) | UC


加好友 發(fā)短信
等級(jí):青蜂俠 帖子:1393 積分:14038 威望:0 精華:0 注冊(cè):2010-11-12 11:08:23
嵌入式Linux系統(tǒng)中MMC卡驅(qū)動(dòng)管理技術(shù)研究  發(fā)帖心情 Post By:2010-11-24 11:25:39

摘要  簡(jiǎn)明介紹MMC卡驅(qū)動(dòng)程序的體系結(jié)構(gòu),設(shè)計(jì)并實(shí)現(xiàn)MMC卡的底層驅(qū)動(dòng);對(duì)傳統(tǒng)的塊設(shè)備驅(qū)動(dòng)程序中的單塊讀寫(xiě)進(jìn)行改進(jìn),實(shí)現(xiàn)MMC卡的集群讀寫(xiě),同時(shí)實(shí)現(xiàn)了卡的電源管理和即插即用功能。
關(guān)鍵詞 Linux MMC卡 底層驅(qū)動(dòng) 集群讀寫(xiě) 熱拔插

引 言
    MMC(Multitmedia Card)是一種體積小巧、容量大、使用方便的存儲(chǔ)器,目前在手機(jī)等嵌入式系統(tǒng)中有著廣泛的應(yīng)用。MMC通過(guò)卡內(nèi)的一個(gè)集成片內(nèi)控制器對(duì)MMC卡進(jìn)行控制和管理,當(dāng)主機(jī)正確地驅(qū)動(dòng)MMC卡后,就可以像磁盤(pán)一樣方便地存取數(shù)據(jù)。本文所研究與實(shí)現(xiàn)的Linux驅(qū)動(dòng)程序,以Intel XScale的PXA250為硬件平臺(tái),在遵循MMC卡通信協(xié)議規(guī)范的基礎(chǔ)上,實(shí)現(xiàn)了卡的底層讀寫(xiě)。然后對(duì)傳統(tǒng)的塊設(shè)備驅(qū)動(dòng)程序中的單塊讀寫(xiě)進(jìn)行了改進(jìn),實(shí)現(xiàn)了集群讀寫(xiě)技術(shù),提高了卡的讀寫(xiě)速度;同時(shí)增加了電源管理功能,滿足了嵌入式系統(tǒng)低功耗的需求;增加了即插即用功能,方便了用戶的使用。

1 MMC卡驅(qū)動(dòng)程序的體系結(jié)構(gòu)
    MMC卡僅通過(guò)5個(gè)引腳與主機(jī)的控制器相連,通過(guò)串行協(xié)議與主機(jī)通信。MMC卡在硬件上的簡(jiǎn)單構(gòu)造必然導(dǎo)致在實(shí)現(xiàn)驅(qū)動(dòng)程序上的復(fù)雜。依據(jù)MMC卡的通信擲議規(guī)范和Linux驅(qū)動(dòng)程序的結(jié)構(gòu),把驅(qū)動(dòng)程序原有的底層驅(qū)動(dòng)、守護(hù)線程、單塊讀寫(xiě)進(jìn)行改進(jìn)和擴(kuò)展,其結(jié)構(gòu)層次再劃分為底層驅(qū)動(dòng)、守護(hù)線程、集群讀寫(xiě)、電源管理及熱拔插管理5個(gè)部分,如圖l所示。

圖片點(diǎn)擊可在新窗口打開(kāi)查看

    圖1中各部分的功能為:
    ①底層驅(qū)動(dòng)——處理直接涉及與MMC卡硬件寄存器端口的操作,包括:命令的發(fā)布和響應(yīng)、中斷響應(yīng)和處理、PIO或者DMA通道數(shù)據(jù)傳輸?shù)取?br/>    ②集群讀寫(xiě)——將磁盤(pán)相鄰數(shù)據(jù)塊的讀寫(xiě)請(qǐng)求合并起來(lái)一起發(fā)布讀寫(xiě)命令,以加快數(shù)據(jù)讀寫(xiě),并在讀寫(xiě)中實(shí)現(xiàn)并發(fā)控制。
    ③電源管理——實(shí)現(xiàn)MMC卡的低功耗管理。 
    ④熱拔插管理——實(shí)現(xiàn)MMC卡的即插即用功能。
    ⑤守護(hù)線程——響應(yīng)文件系統(tǒng)的讀寫(xiě)請(qǐng)求并啟動(dòng)對(duì)卡的1/O。

2 MMC卡驅(qū)動(dòng)程序的實(shí)現(xiàn)
2.1 底層驅(qū)動(dòng)
   
底層驅(qū)動(dòng)指的是直接對(duì)MMC卡進(jìn)行操作。MMC卡采用串行的數(shù)據(jù)傳輸方式;是一種比較“精細(xì)”的卡,對(duì)它的操作比較復(fù)雜而且必須有準(zhǔn)確的時(shí)序安排。以下從命令的發(fā)布和響應(yīng)、中斷響應(yīng)和處理、DMA數(shù)據(jù)傳輸3個(gè)方面講述如何進(jìn)行底層讀寫(xiě)驅(qū)動(dòng)。

(1)命令發(fā)布和響應(yīng)

    MMC卡的操作是通過(guò)對(duì)其18個(gè)控制寄存器的讀寫(xiě)實(shí)現(xiàn)的。首先,設(shè)置時(shí)鐘起停寄存器MMC_STRCPL的最低兩位為01.關(guān)閉MMC卡內(nèi)部時(shí)鐘。然后,設(shè)置中斷屏蔽寄存器MMC_LMASK的最低7位都為1,屏蔽所有對(duì)MMC控制器的中斷,再向指定的MMC控制寄存器中寫(xiě)入命令參數(shù),如時(shí)鐘頻率設(shè)置寄存器MMC_CLKRT,讀寫(xiě)塊數(shù)寄存器MMC_NOB,命令寄存器MMC_CMD等。最后,打開(kāi)內(nèi)部時(shí)鐘,解除屏蔽的中斷。這時(shí),當(dāng)前讀寫(xiě)進(jìn)程進(jìn)入睡眠狀態(tài),等待中斷處理程序的喚醒。

(2)中斷響應(yīng)和處理
    MMC卡在數(shù)據(jù)傳輸請(qǐng)求、內(nèi)部時(shí)鐘關(guān)閉、命令發(fā)布完畢、數(shù)據(jù)傳輸完畢的情況下都會(huì)產(chǎn)生中斷,但足MMC卡的控制器只通過(guò)1裉GPIO23的引腳與CPU相連,用于中斷信號(hào)線的復(fù)用;因此在中斷處理程序中,必須首先判斷到底是哪種原因產(chǎn)生的中斷,然后再進(jìn)行相應(yīng)的處理。這里,MMC卡在正確發(fā)布讀寫(xiě)命令以后,系統(tǒng)會(huì)產(chǎn)生1次中斷,中斷處理程序中讀取MMC_IREG的值,判斷命令已經(jīng)發(fā)布成功,同時(shí)喚醒等待命令完成的進(jìn)程。

    讀寫(xiě)進(jìn)程被中斷喚醒后,首先讀取MMC卡響應(yīng)寄存器MMC_RES中的狀態(tài)信息,再根據(jù)這些狀態(tài)信息判斷命令是否發(fā)布成功和卡的當(dāng)前狀態(tài)。如果這些狀態(tài)信息表示命令執(zhí)行成功,則通過(guò)讀寫(xiě)緩沖寄存器MMC_RXFIFO和MMC_TXFIFO進(jìn)行數(shù)據(jù)的讀寫(xiě)(這里使用DMA進(jìn)行數(shù)據(jù)傳輸,提高了數(shù)據(jù)的傳輸速度);如果返回的狀態(tài)信息表明命令執(zhí)行不成功,則根據(jù)狀念信息進(jìn)行相應(yīng)的出錯(cuò)處理。

(3)DMA數(shù)據(jù)傳輸

    驅(qū)動(dòng)程序中對(duì)MMC卡的數(shù)據(jù)讀寫(xiě)是通過(guò)DMA通道進(jìn)行傳輸?shù)摹榱吮M舨僮鞯倪B續(xù)性,驅(qū)動(dòng)程序?qū)MC卡的輸入和輸出緩沖各設(shè)置1個(gè)DMA通道,在進(jìn)行實(shí)際數(shù)據(jù)傳輸時(shí),讀寫(xiě)進(jìn)程也進(jìn)入睡眠狀態(tài),等待DMA數(shù)據(jù)傳輸完畢后,被DMA中斷喚醒。實(shí)現(xiàn)一次讀操作的偽代碼如下:
Pxa_read_mmc(){

    關(guān)閉時(shí)鐘,屏蔽中斷;
    設(shè)置讀寫(xiě)寄存器的內(nèi)容; /*讀寫(xiě)塊數(shù),起始?jí)K數(shù),讀寫(xiě)速度等*/
    打開(kāi)時(shí)鐘,發(fā)布讀寫(xiě)命令;
    Interruptible_sleep_on(); /*進(jìn)入可打斷睡眠狀態(tài),等待中斷程序的喚醒*/
    被中斷程序喚醒,打開(kāi)DMA通道,進(jìn)行數(shù)據(jù)傳輸,再次進(jìn)入可打斷睡眠狀態(tài);
    被DMA傳輸完畢中斷喚醒,發(fā)布結(jié)束傳輸命令,結(jié)束數(shù)據(jù)傳輸;

2.2 集群(clustering)讀寫(xiě)和并發(fā)控制
2.2.1 傳統(tǒng)的塊設(shè)備驅(qū)動(dòng)程序結(jié)構(gòu)和不足
   
塊沒(méi)備驅(qū)動(dòng)程序是Linux系統(tǒng)中最復(fù)雜的驅(qū)動(dòng)程序之一,參閱文獻(xiàn)[3,4]可以詳細(xì)了解Linux塊設(shè)備驅(qū)動(dòng)程序。這里簡(jiǎn)單介紹與集群讀寫(xiě)相關(guān)的數(shù)據(jù)結(jié)構(gòu)和操作。扇區(qū)(seetor)是塊設(shè)備硬件傳輸數(shù)據(jù)的基本單位,而塊(block)是塊設(shè)備請(qǐng)求1次I/O操作所涉及的一組相鄰扇區(qū),每個(gè)塊都需要有自己的內(nèi)存緩沖區(qū)。緩沖區(qū)首部(buffer_head)是與每個(gè)緩沖區(qū)相關(guān)的數(shù)據(jù)結(jié)構(gòu),每次對(duì)塊沒(méi)備的I/O傳輸都必須經(jīng)過(guò)塊的緩沖區(qū)。

    Linux塊沒(méi)備驅(qū)動(dòng)程序采取一種延遲I/O策略。當(dāng)進(jìn)程有I/O請(qǐng)求時(shí),驅(qū)動(dòng)程序延遲一段時(shí)間,把塊設(shè)備上相連續(xù)的buffer_head結(jié)構(gòu)關(guān)聯(lián)在一起形成一個(gè)I/O請(qǐng)求描述符(struct request),再把request結(jié)構(gòu)按照電梯算法排隊(duì)到設(shè)備的請(qǐng)求隊(duì)列(request_queue_t)。這樣實(shí)際執(zhí)行I/O傳輸時(shí),順次處理對(duì)應(yīng)塊設(shè)備的請(qǐng)求隊(duì)列。
    對(duì)于request結(jié)構(gòu)的電梯排隊(duì)算法,避免由于頻繁的移動(dòng)磁頭而導(dǎo)致塊設(shè)備性能下降;然而,目前在Linux塊設(shè)備驅(qū)動(dòng)程序中,對(duì)一個(gè)request結(jié)構(gòu)中的各個(gè)buffer_head結(jié)構(gòu)分別發(fā)布I/O讀寫(xiě)命令,會(huì)導(dǎo)致每次對(duì)一個(gè)buffer_head的輸入/輸出時(shí),磁頭都會(huì)停頓一段時(shí)間,進(jìn)行DMA數(shù)據(jù)讀寫(xiě)。這樣頻繁的磁頭啟停會(huì)導(dǎo)致磁盤(pán)性能下降。

2.2.2 集群讀寫(xiě)的實(shí)現(xiàn)

    傳統(tǒng)的塊設(shè)備驅(qū)動(dòng)程序中每次發(fā)布讀寫(xiě)命令都只對(duì)一個(gè)buffer_head緩沖而導(dǎo)致塊設(shè)備性能下降。針對(duì)這一問(wèn)題,我們對(duì)傳統(tǒng)塊設(shè)備進(jìn)行改進(jìn),實(shí)現(xiàn)了集群讀寫(xiě)。由于每一個(gè)request結(jié)構(gòu)的buffer_head結(jié)構(gòu)鏈對(duì)應(yīng)的物理塊都是相鄰的,因此為進(jìn)行集群讀寫(xiě)創(chuàng)造了條件。request結(jié)構(gòu)中的nr_sectors表示該request結(jié)構(gòu)需要讀寫(xiě)的塊數(shù)。進(jìn)行讀寫(xiě)時(shí),一次性發(fā)布讀寫(xiě)塊數(shù)為nr_seetors,讀入塊設(shè)備內(nèi)容到requem結(jié)構(gòu)指向的第一個(gè)buffer_head結(jié)構(gòu)對(duì)應(yīng)的內(nèi)存區(qū)域。在一個(gè)buffer_head結(jié)構(gòu)的緩沖區(qū)讀寫(xiě)滿了以后,就調(diào)整讀寫(xiě)緩沖區(qū)地址為下一個(gè)buffer_head所指向的緩沖區(qū),同時(shí)配合DMA進(jìn)行數(shù)據(jù)傳輸,提高了讀寫(xiě)速度。對(duì)一個(gè)request結(jié)構(gòu)操作完成以后,釋放request結(jié)構(gòu)資源。實(shí)現(xiàn)集群讀操作偽碼如下:
Read_mmc(){

    發(fā)布讀寫(xiě)命令,讀入的數(shù)據(jù)塊數(shù)為一個(gè)rcquest一>nr_sectors的塊數(shù);
    緩沖區(qū)的指針指向第1個(gè)bh結(jié)構(gòu)所指的緩沖區(qū);
    while(數(shù)據(jù)還沒(méi)有讀完){
    讀入數(shù)據(jù)到buffer_head結(jié)構(gòu)所指定的緩沖區(qū);/*調(diào)用Pxa_read_mmc()*/
    調(diào)整緩沖區(qū)的指針到下一個(gè)buffer_head結(jié)構(gòu)所指向的緩沖區(qū);
    }

}

2.2.3集群讀寫(xiě)中的并發(fā)控制
   
如果I/O請(qǐng)求隊(duì)列request_queue_t是在內(nèi)核中的許多地方都被訪問(wèn)的,則該隊(duì)列就成為了臨界資源。為了對(duì)該隊(duì)列進(jìn)行互斥保護(hù),Linux2.4中所有的請(qǐng)求隊(duì)列都受一個(gè)單獨(dú)的全局自旋鎖io_request_lock的保護(hù)。所有對(duì)清求隊(duì)列的操作必須要求擁有該鎖并禁止中斷,然而,在驅(qū)動(dòng)程序擁有這個(gè)鎖的同時(shí),其他任何讀寫(xiě)請(qǐng)求不能排隊(duì)到系統(tǒng)的任何塊設(shè)備上,其他讀寫(xiě)處理函數(shù)也不能運(yùn)行。為了盡量減輕由于驅(qū)動(dòng)程序長(zhǎng)期的擁有該鎖而導(dǎo)致系統(tǒng)性能下降的問(wèn)題,在實(shí)現(xiàn)集群讀寫(xiě)時(shí)必須遵循以下原則:

    ①對(duì)請(qǐng)求隊(duì)列進(jìn)行讀寫(xiě)操作時(shí)要獲得鎖;
    ②對(duì)請(qǐng)求隊(duì)列操作完畢后釋放請(qǐng)求鎖;
    ③為了減少占用鎖的時(shí)間,可先把隊(duì)列中的request結(jié)構(gòu)從隊(duì)列中取下來(lái),再打開(kāi)鎖,然后在開(kāi)鎖的情況下對(duì)取下的request結(jié)構(gòu)進(jìn)行操作。

    基于以上原則,讀/寫(xiě)處理函數(shù)的偽碼如下所示:
mmc_request_fn()
    whilc(1){
    加鎖io_request_lock;
    讀取當(dāng)前mmc卡請(qǐng)求隊(duì)列的第一個(gè)請(qǐng)求結(jié)構(gòu)request;
    釋放鎖io_request_lock;
    if(request為空)
    cxit(O); /*沒(méi)有可以處理的隊(duì)列,返回*/
    read_mmc(); /*調(diào)用集群讀寫(xiě)函數(shù)*/
    加鎖io_request_lock;
    在queue結(jié)構(gòu)中取處理完畢的request結(jié)構(gòu),釋放request資源;
    釋放鎖io_request_lock;
    }

}

2.3 守護(hù)線程
   
在MMC卡驅(qū)動(dòng)程序初始化的時(shí)候,啟動(dòng)守護(hù)線程mme_block_thread。它平時(shí)處于睡眠狀態(tài),當(dāng)有對(duì)MMC卡的讀/寫(xiě)請(qǐng)求時(shí),mmc_blok_thread被喚醒。該線程調(diào)用上述讀/寫(xiě)處理函數(shù)mmc_request_fn(),處理完畢后再進(jìn)入睡眠狀態(tài)。

2.4 電源管理
   
嵌入式系統(tǒng)一般有低功耗要求,當(dāng)某設(shè)備長(zhǎng)期沒(méi)有運(yùn)行時(shí),就應(yīng)該停止給該設(shè)備供電,以減少電能消耗。在內(nèi)核中有一個(gè)需要注冊(cè)的電源管理設(shè)備的隊(duì)列pm_list,同時(shí)也有電源管理線程kpowered,它的優(yōu)先級(jí)是所有運(yùn)行進(jìn)程中最低的。當(dāng)系統(tǒng)長(zhǎng)時(shí)間沒(méi)有進(jìn)程運(yùn)行時(shí),kpowered被喚醒,掃描pm_list隊(duì)列各個(gè)注冊(cè)的設(shè)備。如果發(fā)現(xiàn)該設(shè)備長(zhǎng)期沒(méi)有運(yùn)行,則向該設(shè)備發(fā)出PM_SUSPEND事件;而當(dāng)設(shè)備重新開(kāi)始使用時(shí),則向pm_list隊(duì)列發(fā)出:PM_RESUME事件。

    在MMC卡驅(qū)動(dòng)模塊中注冊(cè)了電源管理的回調(diào)函數(shù)mme_block_callback,即pm_register(PM_UNKNOWN_DEV,0,mme_pm_callback)。這樣MMC卡就注冊(cè)到了pm_list隊(duì)列中去了。當(dāng)有電源事件時(shí),就觸發(fā)mmc_pm_callback函數(shù)。該函數(shù)處理各種電源事件。

    程序中的電源事件有兩種:
    ①PM_SUSPEND事件。該事件使MMC卡進(jìn)入省電模式。這時(shí)驅(qū)動(dòng)程序保存MMC卡的當(dāng)前狀態(tài)和重要寄存器的內(nèi)容,如時(shí)鐘寄存器MMC_CLKRT和狀態(tài)寄存器MMC_STAT等。然后,設(shè)置MMC卡的供電GPIO為高電平,關(guān)閉MMC卡的電源供應(yīng),沒(méi)置MMC卡在時(shí)鐘使能寄存器CKEN的相應(yīng)位為O,關(guān)閉MMC卡的時(shí)鐘脈沖。這時(shí),MMC卡就進(jìn)入了省電模式。
    ②PM_RESUME事件。該事件使MMC卡進(jìn)入正常工作模式。這時(shí)程序恢復(fù)在進(jìn)入省電模式前保存的寄存器,打開(kāi)電源供應(yīng)和時(shí)鐘脈沖,MMC卡恢復(fù)到正常的工作模式。
    當(dāng)然電源事件也可以由用戶進(jìn)程自愿觸發(fā)。在文件系統(tǒng)的接口file_operaion io_control中留有電源理管理接口,用戶可以通過(guò)io_contol向卡發(fā)送電源事件請(qǐng)求。

2.5 熱插拔管理

    在手機(jī)、PDA等嵌入式系統(tǒng)中,都要求提供對(duì)設(shè)備的即插即用功能,使用戶無(wú)須安裝驅(qū)動(dòng)程序就可以即時(shí)使用設(shè)備。Linux在系統(tǒng)層和應(yīng)用層都要對(duì)熱插拔事件進(jìn)行處理。在系統(tǒng)層,一方面要探測(cè)MMC卡的熱插拔事件,分配或釋放系統(tǒng)資源,并驅(qū)動(dòng)MMC卡;另一方面,要將此事件準(zhǔn)確及時(shí)地通知給應(yīng)用層,應(yīng)用層則根據(jù)熱插拔事件作相應(yīng)的處理。

    在操作系統(tǒng)層,需要注冊(cè)一個(gè)字符型設(shè)備mmc_plug文件,用于應(yīng)用層探測(cè)MMC卡的熱插拔事什。CPU通過(guò)GPIO12引腳與MMC卡相連,用于卡插拔的中斷探測(cè)。同時(shí)驅(qū)動(dòng)程序巾設(shè)置一個(gè)信號(hào)量MMC_EVENT,它取MMC_INSERT和MMC_REMOVAL兩個(gè)值。當(dāng)卡插入和或者拔出時(shí),在中斷處理程序中被分別設(shè)置為MMC_INSERT和MMC_REMCOVAL;并同時(shí)傳給字符設(shè)備mmc_plug,供上層的應(yīng)用程序使用。為了讓?xiě)?yīng)用層能夠知曉卡的拔插事件,在字符設(shè)備mmc_plug使用異步I/O機(jī)制poll,需要接收內(nèi)核拔插事件的進(jìn)程通過(guò)poll在一個(gè)等待隊(duì)列上睡眠,當(dāng)有卡拔插事件時(shí)產(chǎn)生中斷,中斷處理程序喚醒在隊(duì)列上等待的進(jìn)程。上層進(jìn)程在被喚醒后就讀取字符設(shè)備,獲取所發(fā)生的事件。

    在應(yīng)用層,進(jìn)程通過(guò)select機(jī)制監(jiān)聽(tīng)MMC卡所發(fā)生的熱插拔事件,在沒(méi)有拔插事件的時(shí)候,進(jìn)程進(jìn)入阻塞狀態(tài),讓出CPU資源;當(dāng)發(fā)生熱拔插事件時(shí),系統(tǒng)喚醒通過(guò)poll加入到等待隊(duì)列中的進(jìn)程,然后應(yīng)用層通過(guò)read函數(shù)得到MMC卡的熱插拔事件,進(jìn)行相應(yīng)的應(yīng)用層處理。當(dāng)然,應(yīng)用層也可以通過(guò)write方法通知系統(tǒng)層對(duì)卡進(jìn)行處理。

結(jié)語(yǔ)
   
本文研究實(shí)現(xiàn)的MMC卡驅(qū)動(dòng)程序,其實(shí)現(xiàn)的集群讀寫(xiě)證明有穩(wěn)定而較高的讀/寫(xiě)速度;增加了電源管理功能,降低了電源的功耗,滿足了嵌入式系統(tǒng)低功耗的要求;增加的即插即用功能,大大方便了用戶的使用。驅(qū)動(dòng)程序的體系結(jié)構(gòu)是實(shí)現(xiàn)嵌入式系統(tǒng)塊設(shè)備驅(qū)動(dòng)的一種好方法。


支持(0中立(0反對(duì)(0單帖管理 | 引用 | 回復(fù) 回到頂部

返回版面帖子列表

嵌入式Linux系統(tǒng)中MMC卡驅(qū)動(dòng)管理技術(shù)研究








簽名
国产剧情视频在线观看-国产剧情麻豆女教师在线观看-国产剧情精品在线观看-国产剧情精品-国产剧情91-国产玖玖在线观看
<dfn id="is4kg"></dfn>
  • <ul id="is4kg"></ul>
  • <abbr id="is4kg"></abbr>
  • <ul id="is4kg"></ul>
    <bdo id="is4kg"></bdo>
    992tv在线成人免费观看| 日本视频精品一区| 国产精品一区免费观看| 欧美风情在线观看| 91久久久久久久久| 亚洲天堂电影网| 国产这里只有精品| 亚洲永久一区二区三区在线| 成人精品久久久| 亚洲国产精品www| 国产精品网红福利| 一区二区精品免费视频| 亚洲最大成人在线| 久久久噜噜噜久噜久久| 国产精华一区二区三区| 热草久综合在线| 日本精品二区| 成人深夜直播免费观看| 国产69精品久久久久99| 欧美亚州在线观看| 日本一区二区不卡| 97国产在线视频| 国产精品香蕉视屏| 欧美一区二区色| 欧美伦理一区二区| 国产美女久久精品香蕉69| 午夜精品一区二区三区在线视频| 97在线观看免费| 5566中文字幕一区二区| 日韩在线第一区| 成人精品视频在线| 午夜免费日韩视频| 青青草成人网| 国产伦精品一区二区三区视频黑人| 日本不卡高字幕在线2019| 亚洲欧洲免费无码| 精品不卡在线| 91在线免费观看网站| 久久久噜噜噜久久| 日韩欧美三级电影| 国产精品一区二区av| 国产精选久久久久久| 久久久久中文字幕| 亚洲.欧美.日本.国产综合在线| 99伊人久久| 国产精品免费小视频| 午夜欧美大片免费观看| 亚洲一二三区精品| 欧美理论一区二区| 精品乱码一区| 成人资源视频网站免费| 91精品啪aⅴ在线观看国产| 国产91在线播放| 欧美国产日韩中文字幕在线| 天堂精品一区二区三区| 久久精品成人一区二区三区蜜臀 | 国产精品白嫩美女在线观看| 久久久久久久久亚洲| 先锋在线资源一区二区三区| 欧美大香线蕉线伊人久久| wwwxx欧美| 亚洲综合在线小说| 91午夜理伦私人影院| 国产美女久久精品香蕉69| 国产成一区二区| 欧美在线一级视频| 欧美中文字幕精品| 欧美在线视频网| 欧美一级片在线播放| 97久久精品国产| 午夜精品免费视频| 国语自产精品视频在线看抢先版图片| 在线成人性视频| 亚洲欧洲一区二区在线观看| 亚洲一区二区三区午夜| 亚洲图片小说在线| 欧美肥婆姓交大片| 欧美精品videosex极品1| 在线不卡日本| 久久免费视频观看| 久久久久久网址| 国产成人精品一区二区在线| 欧美在线性爱视频 | 国产精品极品美女粉嫩高清在线| 538国产精品一区二区免费视频| 久久理论片午夜琪琪电影网| 性色av香蕉一区二区| 午夜免费在线观看精品视频| 欧美亚洲国产日韩2020| 国产成人精品视频在线| 国产精品h在线观看| 国产成人综合一区二区三区| 国产精品丝袜久久久久久高清| 国产精品久久中文| 国产中文日韩欧美| 亚洲最大的成人网| 国产欧美一区二区在线播放| 欧美激情论坛| 亚洲bbw性色大片| 久久久久一本一区二区青青蜜月| 97欧美精品一区二区三区| 日本欧美精品在线| 国产欧美日韩中文字幕在线| av一本久道久久波多野结衣| 六十路精品视频| 天堂精品视频| 国语自产在线不卡| 国产精品美女在线观看| 97神马电影| 欧美性大战久久久久| 亚洲三区在线| 欧美亚洲激情视频| 成人有码视频在线播放| 精品国产免费一区二区三区| 日本成人三级| 97国产真实伦对白精彩视频8| 国产精品国产三级国产aⅴ浪潮 | 奇门遁甲1982国语版免费观看高清| 国产成人97精品免费看片| 国产日韩精品在线播放| 国产精品9999久久久久仙踪林| 美日韩免费视频| 欧美极品少妇xxxxx| 国产mv久久久| caoporn国产精品免费公开| 欧美不卡在线一区二区三区| 久久久久久久久久久人体| 国产成人极品视频| 国产高清一区视频| 亚洲欧洲在线一区| 国产成人久久久精品一区| 99精品国产高清一区二区| 日本黄网免费一区二区精品| 97精品久久久| 999日本视频| 日韩免费三级| 国产精品色视频| 九色91在线视频| 午夜精品视频在线| 99三级在线| 色中色综合影院手机版在线观看| 国产精品久久久久久久久久三级| 久久99九九| 国内精品久久久久伊人av| 91影院在线免费观看视频| 日韩欧美在线一区二区| 国产成人欧美在线观看| 久久国产精品亚洲va麻豆| 国产91精品久| 国产伦精品一区二区三区四区免费| 亚洲国产欧美日韩| 国产一区二区色| 亚洲精品9999| 91在线看www| 在线观看日韩羞羞视频| 亚洲在线第一页| 一区二区视频在线播放| 91免费在线视频网站| 亚洲一区免费看| 国产欧亚日韩视频| 亚洲乱码国产乱码精品天美传媒| 国产精品自拍网| 亚洲欧美日产图| 亚洲一区二区三区久久 | 成人网在线观看| 视频一区视频二区视频三区高| 国产精品三级网站| 小说区图片区图片区另类灬| 成人妇女淫片aaaa视频| 一区二区三区国产福利| 91青青草免费在线看| 国内外成人免费激情在线视频| 国产欧美日韩综合一区在线观看 | 91精品国产色综合久久不卡98口| 91情侣在线视频| 97超碰蝌蚪网人人做人人爽| 欧美精品久久久| 国产精品永久免费在线| 欧美激情乱人伦一区| 国产精选一区二区| 国产精品入口日韩视频大尺度| 亚洲激情一区二区三区| 超碰国产精品久久国产精品99| 欧美亚洲成人免费| 台湾成人av| 国产精品视频在线免费观看| 国产精品稀缺呦系列在线| 久久久久久国产免费 | 97国产suv精品一区二区62| 国产精品免费视频一区二区| 国产精品96久久久久久又黄又硬| 宅男噜噜99国产精品观看免费| 国产精品久久亚洲| 国产精品久久久久久网站| 中文字幕欧美日韩一区二区三区| 精品蜜桃一区二区三区| 成人在线小视频| 国产成人精品日本亚洲| 久久久视频精品| 台湾成人av| 麻豆传媒一区| 国产二区不卡| 成人高清视频观看www| 97国产在线视频| 日韩一本精品| 久久综合中文色婷婷| 亚洲影视九九影院在线观看| 国产成人免费av| 97在线观看视频| 亚洲一区三区在线观看| 欧美激情导航| 精品一区二区国产| 粉嫩av一区二区三区免费观看 | 国产欧美日韩精品在线观看| 2023亚洲男人天堂| 欧美国产日韩精品| 亚洲综合第一| 先锋影音一区二区三区| 欧美一区二区三区四区五区六区| 国产精品播放| 官网99热精品| 成人国产一区二区| 91久久极品少妇xxxxⅹ软件| 成人网中文字幕| 国产精品视频免费在线| 国产精品成人av在线| 2019亚洲男人天堂| 2020欧美日韩在线视频| 91精品国产乱码久久久久久蜜臀| 久久久久亚洲精品| 国外成人在线直播| 97热在线精品视频在线观看| 国内精品免费午夜毛片| 性欧美激情精品| 国模视频一区二区| 午夜精品视频在线| 性色av一区二区咪爱| 97视频在线观看网址| 97久久精品人搡人人玩| 66m—66摸成人免费视频| 午夜精品久久久99热福利| 久久久久久国产三级电影| 中日韩在线视频| 尤物国产精品| 亚洲91精品在线观看| 91av在线播放| 日韩免费在线免费观看| 国产精品视频内| 91在线免费看网站| 高清av免费一区中文字幕| 国产精品一区二区三区免费观看| 国产乱码精品一区二区三区日韩精品| 国产98在线|日韩| 精品产品国产在线不卡| 欧美日韩亚洲免费| 午夜欧美性电影| 欧美激情a在线| 538国产精品一区二区在线| 日本aⅴ大伊香蕉精品视频| 国产成人综合亚洲| 91久久在线播放| 成人黄视频免费| 免费99视频| 一级做a爰片久久| 欧美一级黑人aaaaaaa做受| 国产精品白丝jk喷水视频一区 | 97视频在线免费观看| 青青a在线精品免费观看| 国产精品久久久久免费a∨| 国产日产久久高清欧美一区| 成人自拍网站| 日韩电影天堂视频一区二区| 日韩av免费看| 国产高清精品一区二区三区| 久久国产精品精品国产色婷婷| 蜜桃欧美视频| 欧美贵妇videos办公室| 日韩69视频在线观看| 国产精品视频中文字幕91| 成人av在线网址| 国产伦一区二区三区色一情| 日韩.欧美.亚洲| 久久久这里只有精品视频| 日本中文字幕成人| 亚洲aa在线观看| 国产精品入口免费| 亚洲视频精品一区| 日韩免费不卡av| 91在线观看网站| 欧美一级日本a级v片| 久久久久久久av| 国产精品亚洲精品| 国产综合第一页| 欧美激情亚洲另类| 国产区精品视频| 久久一区免费| 国精产品一区一区三区有限在线| 国产精品一区久久| 久久人人九九| 97视频在线观看播放| 成人亚洲欧美一区二区三区| 日本一区二区三区免费观看| 欧美专区在线播放| 国产精品久久国产精品| 欧美精品久久久久久久| 成人黄色在线播放| 日产精品久久久一区二区| 奇米四色中文综合久久| 国产伦视频一区二区三区| 亚洲精品第一区二区三区| 日韩av免费在线观看| 国产精品日韩高清| 最近看过的日韩成人| 国产精品美女主播| 久久综合九色综合久99| 日本久久精品视频| 久久爱av电影| 国产91在线视频| 麻豆成人小视频| 国产成人亚洲综合青青| 免费试看一区| 国产精品久久一| 欧美一区国产一区| 国产精品福利观看| 日本免费高清一区| 国产日韩欧美视频在线| 亚洲欧洲久久| 91蜜桃网站免费观看| 久久久久久久成人| 国产精品中出一区二区三区| 欧美一级大片视频| 欧美一二三区| 成人精品一区二区三区电影免费| 亚洲欧美国产一区二区| 91丝袜脚交足在线播放| 91精品国产91久久久久久不卡| 国内一区二区三区在线视频| 日韩美女主播视频| 亚洲欧洲另类精品久久综合| 操一操视频一区| 91大神福利视频在线| 美女主播视频一区| 成人av番号网| 91精品国产高清| 日韩动漫在线观看| 91国产在线免费观看| 7m精品福利视频导航| 欧美一区二区三区四区在线观看地址 | 99在线高清视频在线播放| 久久久久久午夜| 欧美12av| 97人人澡人人爽| 国产精品成人一区二区| 亚洲一区三区在线观看| 精品国产乱码久久久久久郑州公司| 国产精品黄色av| 欧美激情免费观看| 欧美大陆一区二区| 2020国产精品久久精品不卡| 国产v综合v亚洲欧美久久| 一本一道久久久a久久久精品91| 国产精品免费一区二区三区在线观看| 国产成人精品综合| 欧美高清在线观看| 欧美精品一区二区三区在线四季 | 亚洲一二区在线| 黄色91av| av在线亚洲男人的天堂| 国产精品爽黄69天堂a| 97人人做人人爱| 中文一区一区三区免费| 欧美性bbwbbwbbwhd| 国产精品入口免费| 91精品国产一区二区三区动漫| 国产精品草莓在线免费观看| 午夜精品视频在线| 在线国产精品网| 日产精品久久久一区二区| 国产精品xxx在线观看www| 国产欧美日韩高清| 国产成人avxxxxx在线看| 97精品久久久| 色综合久久精品亚洲国产| 日本最新一区二区三区视频观看| 国产精品午夜av在线| 91色视频在线导航| 国产专区欧美专区| 国产精品无av码在线观看| 日韩美女视频免费看| 91国产视频在线播放| 久久久久久国产精品三级玉女聊斋 | 秋霞av国产精品一区| 久久人人爽人人| 欧美大片欧美激情性色a∨久久| 欧美亚洲另类久久综合| 欧美精品二区三区四区免费看视频| 国模精品娜娜一二三区| 成人自拍偷拍| 国产精品一国产精品最新章节| 91免费在线观看网站| 亚洲在线观看视频| 91香蕉国产在线观看| 91久久中文字幕| 91夜夜未满十八勿入爽爽影院| 91精品国产自产在线| 国产在线视频不卡| 成人在线视频福利| 91天堂在线视频| 99久久久久国产精品免费| 91久色国产| 国产视色精品亚洲一区二区| 国产精品视频免费观看| 国产亚洲精品美女久久久m| 精品欧美国产| 日本一区二区三区www| 午夜欧美一区二区三区免费观看| 视频一区亚洲| 欧美激情videoshd| 91av在线免费观看视频| 国产97在线亚洲| 国产精品户外野外| 午夜精品一区二区三区在线| 国产精品你懂得| 成人免费在线看片| yy111111少妇影院日韩夜片| 国产精品久久久久久久天堂第1集 国产精品久久久久久久免费大片 国产精品久久久久久久久婷婷 | 国产精品一二三在线| 国产欧美一区二区白浆黑人| 91精品综合久久久久久五月天| 亚洲字幕一区二区| 国产亚洲第一区| 蜜桃传媒一区二区| 涩涩涩999| 国内揄拍国内精品| 国产激情999| 亚洲最大激情中文字幕| 好吊妞www.84com只有这里才有精品| 欧美日韩另类丝袜其他| 在线不卡视频一区二区| 欧美性受xxxx黑人猛交| 国产精品久久国产精品99gif| 91欧美精品午夜性色福利在线| 国产精品视频免费观看| 日本欧美色综合网站免费| 亚洲伊人婷婷| 日本国产精品视频| 成人动漫网站在线观看| 国产免费高清一区| 亚洲人体一区| 欧美中文字幕视频| 亚洲va欧美va国产综合久久| 久久精品五月婷婷| 欧美俄罗斯乱妇| 国产精品第一第二| 国产精品手机视频| 在线观看欧美激情| 国产精品久久久久久久久久久不卡| 亚洲一区二区三区成人在线视频精品 | 欧美高清视频一区| 欧美精品videosex极品1| 国产精品高潮呻吟久久av野狼| 91成人在线看| 亚洲mv在线看| 国产成人在线亚洲欧美| 99九九视频| 亚洲欧美日韩国产成人综合一二三区| 青草青草久热精品视频在线观看| 亚洲最大av网| 亚洲精品二区| 国产精品久在线观看| 国产一区二区视频在线免费观看| 色综合天天综合网国产成人网| 国产精品国模在线| 久久精品日产第一区二区三区 | 粉嫩精品一区二区三区在线观看| 亚洲aⅴ天堂av在线电影软件| 日韩av电影中文字幕| 精品综合在线| 91av国产在线| 国产欧美日韩一区二区三区| 国语自产精品视频在线看一大j8| 亚洲一区精品电影| 亚洲日本精品国产第一区| 国产精品丝袜久久久久久高清| 久久99精品久久久久久久久久| 2023亚洲男人天堂| 国模精品娜娜一二三区| 97人人做人人爱| 国产一区二区三区高清| 8x拔播拔播x8国产精品| 激情视频一区二区| 欧美在线影院在线视频| 久久久久九九九| 国产激情综合五月久久| 麻豆av一区| 国产精品一区二区三| 国产精品高清在线观看| 水蜜桃亚洲精品| 欧美在线观看一区二区三区| 国产伦精品一区二区三区照片| 中文字幕一区二区三区有限公司| 国产精品夜间视频香蕉| 日日夜夜精品网站| 成人免费视频a| 在线视频不卡一区二区三区| 亚洲专区中文字幕| 久久久久亚洲精品| 国产精品一级久久久| 欧美亚洲伦理www| 欧美极品日韩| 国产一区二区色| 欧美国产日韩中文字幕在线| 丁香婷婷久久久综合精品国产 | 国产一区二区三区黄| 亚洲91精品在线| 久草一区二区| 色综合色综合网色综合| 国产精品对白刺激| 日韩精品大片| 92福利视频午夜1000合集在线观看| 欧美激情在线视频二区| 成人影片在线播放| 国产成人一区三区| 欧美激情奇米色| 国模精品系列视频| 成人妇女免费播放久久久| 久久久久久97| 欧美动漫一区二区| 亚洲a∨日韩av高清在线观看| 久久久久久久成人| 欧美日韩精品不卡| 91情侣偷在线精品国产| 7777免费精品视频| 日韩一区免费观看| 国产午夜精品一区| 国产在线不卡精品| 国产91精品不卡视频| 亚洲成色www久久网站| 国产高清在线一区二区| 国产精品欧美激情| 欧美激情一级精品国产| 久久亚洲综合网| 7777精品久久久大香线蕉小说| 国产成人精品av在线| 欧美激情亚洲自拍| 日韩欧美手机在线| 激情久久av| 91入口在线观看| 国产精品亚洲第一区| 欧美专区中文字幕| 最近看过的日韩成人| 美女视频久久| 国产精品美女黄网| 91精品一区二区| 国产精品免费久久久久影院| 91精品国产亚洲| 欧美激情视频一区二区三区不卡 | 欧美精品www| 日韩在线电影一区| 久久精品二区| 精品欧美日韩在线| 国产伦精品一区二区三区照片| 亚洲free性xxxx护士hd| 国产精品一区二区三区久久| 国产黑人绿帽在线第一区| 97婷婷涩涩精品一区| 欧美激情按摩在线| 一区二区三区av| 午夜老司机精品| 日本高清不卡一区二区三| 久久亚洲精品欧美| 久久青青草原| 麻豆传媒一区二区| 久久久久久国产精品mv| 精品高清视频| 狠狠色综合一区二区| 精品国产乱码久久久久| 国产日韩欧美一区二区| 国产精品一区二区三区在线观 | 欧美极品少妇与黑人| 中文字幕一区二区三区最新| 亚洲日本精品国产第一区| 亚洲 国产 日韩 综合一区| 无码免费一区二区三区免费播放 | 日韩美女视频中文字幕| 欧洲成人免费视频| 日本成人精品在线| 国产精品wwwwww| 国产成人精品在线| 国产精品欧美激情在线播放| 国产精品视频大全| 成人激情视频在线| 亚洲一区中文字幕在线观看| 豆国产97在线| 精品国产一区二区三区免费| 精品视频一区二区三区四区| 欧洲在线视频一区| 亚洲欧美日韩精品综合在线观看 | 青青久久av北条麻妃黑人| 日韩av色在线|