九九99在线视频-九九99香蕉在线视频美国毛片-九九99热久久精品在线9-九九99热-九九99久久精品在免费线bt-九九99久久

以文本方式查看主題

-  曙海教育集團(tuán)論壇  (http://m.adgdgn.cn/bbs/index.asp)
--  Linux驅(qū)動(dòng)開(kāi)發(fā)  (http://m.adgdgn.cn/bbs/list.asp?boardid=33)
----  嵌入式Linux系統(tǒng)中MMC卡驅(qū)動(dòng)管理技術(shù)研究  (http://m.adgdgn.cn/bbs/dispbbs.asp?boardid=33&id=1730)

--  作者:wangxinxin
--  發(fā)布時(shí)間:2010-11-24 11:25:39
--  嵌入式Linux系統(tǒng)中MMC卡驅(qū)動(dòng)管理技術(shù)研究
摘要  簡(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)程序中的單塊讀寫進(jìn)行改進(jìn),實(shí)現(xiàn)MMC卡的集群讀寫,同時(shí)實(shí)現(xiàn)了卡的電源管理和即插即用功能。
關(guān)鍵詞 Linux MMC卡 底層驅(qū)動(dòng) 集群讀寫 熱拔插

引 言
    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卡后,就可以像磁盤一樣方便地存取數(shù)據(jù)。本文所研究與實(shí)現(xiàn)的Linux驅(qū)動(dòng)程序,以Intel XScale的PXA250為硬件平臺(tái),在遵循MMC卡通信協(xié)議規(guī)范的基礎(chǔ)上,實(shí)現(xiàn)了卡的底層讀寫。然后對(duì)傳統(tǒng)的塊設(shè)備驅(qū)動(dòng)程序中的單塊讀寫進(jìn)行了改進(jìn),實(shí)現(xiàn)了集群讀寫技術(shù),提高了卡的讀寫速度;同時(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ù)線程、單塊讀寫進(jìn)行改進(jìn)和擴(kuò)展,其結(jié)構(gòu)層次再劃分為底層驅(qū)動(dòng)、守護(hù)線程、集群讀寫、電源管理及熱拔插管理5個(gè)部分,如圖l所示。

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

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

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

    MMC卡的操作是通過(guò)對(duì)其18個(gè)控制寄存器的讀寫實(shí)現(xiàn)的。首先,設(shè)置時(shí)鐘起停寄存器MMC_STRCPL的最低兩位為01.關(guān)閉MMC卡內(nèi)部時(shí)鐘。然后,設(shè)置中斷屏蔽寄存器MMC_LMASK的最低7位都為1,屏蔽所有對(duì)MMC控制器的中斷,再向指定的MMC控制寄存器中寫入命令參數(shù),如時(shí)鐘頻率設(shè)置寄存器MMC_CLKRT,讀寫塊數(shù)寄存器MMC_NOB,命令寄存器MMC_CMD等。最后,打開(kāi)內(nèi)部時(shí)鐘,解除屏蔽的中斷。這時(shí),當(dāng)前讀寫進(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ā)布讀寫命令以后,系統(tǒng)會(huì)產(chǎn)生1次中斷,中斷處理程序中讀取MMC_IREG的值,判斷命令已經(jīng)發(fā)布成功,同時(shí)喚醒等待命令完成的進(jìn)程。

    讀寫進(jìn)程被中斷喚醒后,首先讀取MMC卡響應(yīng)寄存器MMC_RES中的狀態(tài)信息,再根據(jù)這些狀態(tài)信息判斷命令是否發(fā)布成功和卡的當(dāng)前狀態(tài)。如果這些狀態(tài)信息表示命令執(zhí)行成功,則通過(guò)讀寫緩沖寄存器MMC_RXFIFO和MMC_TXFIFO進(jìn)行數(shù)據(jù)的讀寫(這里使用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ù)讀寫是通過(guò)DMA通道進(jìn)行傳輸?shù)摹榱吮M舨僮鞯倪B續(xù)性,驅(qū)動(dòng)程序?qū)MC卡的輸入和輸出緩沖各設(shè)置1個(gè)DMA通道,在進(jìn)行實(shí)際數(shù)據(jù)傳輸時(shí),讀寫進(jìn)程也進(jìn)入睡眠狀態(tài),等待DMA數(shù)據(jù)傳輸完畢后,被DMA中斷喚醒。實(shí)現(xiàn)一次讀操作的偽代碼如下:
Pxa_read_mmc(){

    關(guān)閉時(shí)鐘,屏蔽中斷;
    設(shè)置讀寫寄存器的內(nèi)容; /*讀寫塊數(shù),起始?jí)K數(shù),讀寫速度等*/
    打開(kāi)時(shí)鐘,發(fā)布讀寫命令;
    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)讀寫和并發(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)單介紹與集群讀寫相關(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讀寫命令,會(huì)導(dǎo)致每次對(duì)一個(gè)buffer_head的輸入/輸出時(shí),磁頭都會(huì)停頓一段時(shí)間,進(jìn)行DMA數(shù)據(jù)讀寫。這樣頻繁的磁頭啟停會(huì)導(dǎo)致磁盤性能下降。

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

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

    發(fā)布讀寫命令,讀入的數(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集群讀寫中的并發(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í),其他任何讀寫請(qǐng)求不能排隊(duì)到系統(tǒng)的任何塊設(shè)備上,其他讀寫處理函數(shù)也不能運(yùn)行。為了盡量減輕由于驅(qū)動(dòng)程序長(zhǎng)期的擁有該鎖而導(dǎo)致系統(tǒng)性能下降的問(wèn)題,在實(shí)現(xiàn)集群讀寫時(shí)必須遵循以下原則:

    ①對(duì)請(qǐng)求隊(duì)列進(jìn)行讀寫操作時(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)行操作。

    基于以上原則,讀/寫處理函數(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)用集群讀寫函數(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卡的讀/寫請(qǐng)求時(shí),mmc_blok_thread被喚醒。該線程調(diào)用上述讀/寫處理函數(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)用程序使用。為了讓應(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)的集群讀寫證明有穩(wěn)定而較高的讀/寫速度;增加了電源管理功能,降低了電源的功耗,滿足了嵌入式系統(tǒng)低功耗的要求;增加的即插即用功能,大大方便了用戶的使用。驅(qū)動(dòng)程序的體系結(jié)構(gòu)是實(shí)現(xiàn)嵌入式系統(tǒng)塊設(shè)備驅(qū)動(dòng)的一種好方法。


主站蜘蛛池模板: 婷婷五月情 | 欧美性天天 | 无码精品国产一区二区三区免费 | 全部av―极品视觉盛宴 | 国产精品成人免费视频网站 | 亚洲综合小说 | 亚洲男女一区二区三区 | 少妇裸体淫交视频免费看 | 91亚洲国产成人 | 国模裸体无码xxxx视频 | 亚洲日本一区二区三区在线 | 男人天堂2014 | 人人妻人人爽人人澡av | 精品蜜桃一区二区三区 | 69xxx中国| 日日干夜夜撸 | 屁股夹体温计调教play | 欧美图片一区 | 一级三级毛片 | 国语自产免费精品视频在 | 亚洲国产欧美日韩在线观看第一页 | 少妇人妻系列无码专区视频 | 欧产日产国产69 | 色老板精品凹凸在线视频观看 | 国产午夜三级 | 亚洲天堂日本 | 国产一级视频在线观看 | 色一情一乱一伦一区二区三区日本 | 国产精品美女乱子伦高 | 日韩免费播放 | 日本国产三级xxxxxx | 国模冰莲自慰肥美胞极品人体图 | 欧洲一区二区三区 | 亚洲精品一区二区三区香蕉 | 麻豆一区二区三区蜜桃免费 | 欧美视频在线一区二区三区 | 免费看高清毛片 | 国产丰满精品伦一区二区三级视频 | 午夜国产精品成人 | 伊人精品久久久大香线蕉 | av人摸人人人澡人人超碰妓女 | 国产成人av在线影院 | 精品欧洲av无码一区二区 | 天海翼激烈高潮到腰振不止 | 中国女人内谢69xxxx | 精品国产一区二区三区久久 | 香蕉网伊 | 欧美国产日韩另类 | 精品一区二区三区免费观看 | 国产高清视频在线观看97 | 再深点灬舒服灬大了添片在线 | 国产欧美成人一区二区a片 又大又长粗又爽又黄少妇视频 | 神马九九 | 日本国产一区 | 最近更新中文字幕 | 天堂在线中文 | 日本人妖xxxx | 国产精品呻吟 | 18处破外女出血在线 | 干干干操操操 | 免费淫片 | 911色| 精品日韩欧美一区二区在线播放 | 亚洲精品国产视频 | 高清一级片 | 白浆影院 | av免费在线观看网址 | 亚洲精品久久久狠狠狠爱 | 999精品视频在线 | 9九色桋品熟女内射 | 日韩在线视频不卡 | 欧美日韩国产在线一区 | 少妇脚交调教玩男人的视频 | 欧美日韩另类一区二区 | 欧美黑粗硬 | 亚洲高清在线视频 | 香蕉精品在线 | 亚洲 欧美 中文 在线 视频 | 免费看黄色大片 | 福利逼站 | 蜜桃狠狠色伊人亚洲综合网站 | 中文字幕日产乱码一二三区 | 国产欧美精品区一区二区三区 | 日韩的一区二区 | 久久99精品久久久久久噜噜 | eeuss鲁一区二区三区 | 亚洲蜜芽在线精品一区 | 最新中文字幕av | 十八禁毛片 | 黄色777| av片观看| 国产av久久久久精东av | 欧美日韩久久 | 99中文字幕在线观看 | 国产成人a v | 成人黄色在线观看视频 | 69国产成人精品二区 | 国产激情精品 | 2019自拍偷拍 | 天堂在线www中文 | 免费国产黄 | 亚洲精品成人网 | 精品少妇一区二区三区免费观 | 丝袜在线视频 | 日本一级免费视频 | 99精品偷拍视频一区二区三区 | 91pron在线| 国产一区二区三区精品在线观看 | 亚洲中文字幕久久久一区 | 国产精品久久久久久久久久久久午夜 | 又大又黄又粗又爽的免费视频 | 免费成人小视频 | 午夜激情视频网站 | 夜先锋av资源网站 | 日日夜夜爽爽 | 国产精品第一页在线观看 | 富婆性猛交xxxx | 国产免费a∨片同性同志 | 色香蕉视频 | 丰满人妻翻云覆雨呻吟视频 | 911精品美国片911久久久 | 色女仆影院 | 免费的很黄很污的视频 | 黄色一级免费视频 | 国产精品原创巨作av | 亚洲综合小说 | 一级aaa级毛片午夜在线播放 | 国产乱码一区二区三区在线观看 | 91亚洲国产成人精品性色 | 日韩顶级毛片 | 亚洲摸丰满大乳奶水 | 99福利| 欧美视频三区 | 免费黄色一级视频 | 四虎影视永久免费观看在线 | 天堂а√在线最新版中文在线 | 日本韩国欧美在线 | 久久精品国产亚洲a∨蜜臀 久久精品国产亚洲沈樵 | 99免费在线 | 欧美videos另类极品 | 国产精品内射后入合集 | 久热中文字幕在线精品观 | 一本色道无码道dvd在线观看 | 女人大荫蒂毛茸茸视频 | 国产成人av三级在线观看 | 在线观看的黄网 | 亚洲午夜精品久久久久久人妖 | 在线中文字幕网站 | 后宫一级淫片免费放 | 自拍偷拍第5页 | 国内精品福利视频 | 国产乱子夫妻xx黑人xyx真爽 | 欧美日韩国产精品自在自线 | 日韩黄色一级 | 国产人妖视频一区二区 | 高中生粉嫩无套第一次 | 西西人体www44rt大胆高清 | 四虎影库在线永久影院免费观看 | 成人影视网址 | 欧美日韩国产传媒 | 国产黑丝av | 国产69精品久久久久app下载 | 久久爽精品区穿丝袜 | 精品国产乱码久久久 | 隔壁人妻偷人bd中字 | 性欧美videos另类hd | 日韩av在线网址 | 久久99精品久久久久久久青青日本 | 精品国偷自产在线视频 | 国产卡一卡二卡三无线乱码新区 | 婷婷色中文字幕综合在线 | 人妻毛片网站 | 亚洲va在线 | 性做久久久久久 | 操人视频免费看 | 国产女优在线播放 | 精品国产麻豆免费人成网站 | 亚洲国产欧洲 | 国产精品高潮呻吟av久久4虎 | 嫩草视频91 | 国产九一视频 | 亚洲国产成人a精品不卡在线 | 教师夫妇交换刺激做爰小说 | 国产精品亚洲一区二区在线观看 | 国产午夜成人av在线播放 | 丰满少妇被猛烈进av毛片 | 亚洲国产欧美国产综合一区 | 国产三a级三级日产三级野外 | 麻豆天美传媒毛片av88 | 四虎国产精品成人免费4hu | 亚欧在线播放 | 97超碰97 | yy1111111少妇影院乱码 | 极品美女扒开粉嫩小泬图片 | 久久羞羞视频 | 午夜精品久久久久久久四虎美女版 | 国产下药迷倒白嫩丰满美女j8 | 91 高清 在线 制服 偷拍 | 青青草成人在线观看 | 欧美疯狂xxxx乱大交 | 亚洲精品一区二三区不卡 | 以色列最猛性xxxxx视频 | 一区二区久久精品66国产精品 | 国产呻吟久久久久久久92 | 国产精品99精品久久免费 | 中文字幕日韩精品亚洲七区 | 国产成年人网站 | 成人国产片女人爽到高潮 | 与黑人做爰的日本人 | 大陆熟妇丰满多毛xxxx | 神马午夜dy888 | 华人在线| 欧美日日夜夜 | 西西人体www44rt大胆高清 | 美女午夜影院 | 精品久久久久久一区二区 | 噜妇插内射精品 | 欧美成人一区二免费视频软件 | 蜜桃久久久久久久 | a√天堂中文 | 欧美一区二区高清视频 | 美女视频黄是免费 | 僵尸叔叔在线观看国语高清免费观看 | 在线观看免费av网址 | 国产综合第一页 | 国产午夜成人免费看片 | 国产人与zoxxxx另类一一 | 一本一道久久久a久久久精品91 | 一边捏奶头一边高潮视频 | 久久国产精品无码网站 | 成人涩涩软件 | 日韩少妇白浆无码系列 | 乐播av一区二区三区 | 亚洲v无码一区二区三区四区观看 | 情人伊人久久综合亚洲 | 国产又粗又爽又猛又大的动漫片 | 中国少妇xxxx做受视频 | 岛国av一区 | 尤物videos另类xxxx | av大片网 | 性插动态视频 | 日本三级全黄少妇三2023 | 国产精品久久久久久久久免费看 | 亚洲福利网 | 少妇专区 | 亚洲国产无 | 成人动漫视频在线 | 亚洲黄色网址大全 | 国产一区二区三区四区五区精品 | 国产精品极品白嫩在线 | 国产精品久久久亚洲 | 久久人人爽人人爽人人片av高请 | 欧美熟妇另类久久久久久不卡 | 日韩欧美一区二区三区四区 | 欧美~大家屁股网站 | 美女内射毛片在线看免费人动物 | 精品久久久一区 | 美日韩三级| a级片久久久 | 精品在线二区 | 日本夫妻性生活视频 | 不良网站在线免费观看 | 浴室里强摁做开腿呻吟男男 | 亚洲国产精品久久久久久久 | 久久99久久99精品蜜柚传媒 | 91久久精品日日躁夜夜躁国产 | 亚洲欧美日韩久久一区二区 | av剧情在线观看 | 一本一道波多野结衣中文av字幕 | 超碰99在线观看 | 国产又粗又猛又爽又黄的视频9 | a在线视频v视频 | 亚洲伊人久久综合 | 国产成人综合在线观看不卡 | 99亚洲精品在线 | 182tv成人福利视频免费看 | 天天操天天摸天天爽 | 干欧美少妇| 狠狠色狠狠色综合日日小说 | 亚洲精品99久久久久久 | 小说区 图片区色 综合区 | 免费精品久久 | 黄色毛片儿 | 93精品国产乱码久久久 | 好吊妞人成视频在线观看27du | 媚药一区二区三区四区 | 日本aaaa大片免费观看入口 | 亚洲精品午夜一区人人爽 | 天天看片中文字幕 | 亚洲日本欧美日韩高观看 | 天天狠天天干 | 久久久久久99av无码免费网站 | 最近2019中文字幕大全第二页 | 国产边摸边吃奶边做爽视频 | 不戴套各种姿势啪啪高素质 | 欧美乱妇高清无乱码在线观看 | 亚洲精品成人福利网站 | 国产三级av片 | 18禁真人抽搐一进一出在线 | 北条麻妃一区二区免费播放 | 九九爱精品 | 久久爱www久久做 | 色之综合天天综合色天天棕色 | 国内精品久久久久影视老司机 | 午夜视频精品 | 91精品日产一二三区乱码 | 欧美黄一区 | 精品久久久久久人妻无码中文字幕 | 成人免费乱码大片a毛片软件 | 国产精品原创av | 黄色av观看 | 精品国产一区二区三区av 性色 | 水中色av综合 | 国产精品原创巨作av | 国产精品一区二区毛片 | 欧美精品少妇 | 亚洲永久精品视频 | 色婷婷av一区二区三区软件 | 在线成人毛片 | 亚洲女同在线观看 | 黄色片网址在线观看 | 日韩国产大片 | 国产老头和老太xxxxx视频 | 国产精品欧美在线 | 色屁屁ts人妖系列二区 | 九色porny丨天天更新 | 中文字幕免费视频 | 性插视频在线观看 | 亚洲日韩中文第一精品 | 日韩中文字幕一区 | 亚洲成av人片在线观看无 | 日韩免费在线视频 | 成人精品视频在线 | 免费av成人 | 55夜色66夜色国产精品视频 | 国产精品一级片 | 免费看一级黄色片 | 国产在线精品成人欧美 | 久久精品—区二区三区 | 日本成人动漫在线观看 | 日韩黄色免费 | 成人三级网址 | 成人免费性视频 | 欧美不卡一区二区 | 日本视频一区二区三区 | 暖暖日本在线 | 日韩天天干 | 特级毛片全部免费播放器 | 热久久精品 | 一本大道久久卡一卡二卡三乱码 | 色综合社区 | 日本久久高清一区二区三区毛片 | 国产一级αⅴ片免费看 | 97夜夜澡人人爽人人喊中国片 | 男女做爰全过程免费视频播放 | 天天躁日日躁狠狠躁欧美老牛 | a级特黄一级一大片多人 | 免费观看黄色一级片 | 精品黄网站 | 人妻有码av中文字幕久久琪 | 免费草逼视频 | 国产精品美女一区二区三区 | 久久精品噜噜噜成人av | 国内久久精品视频 | 一级特黄特色的免费大片视频 | 无限资源日本好片 | 娇喘顶撞深初h1v1 | 在线三级av| www一起操| 国产公开免费人成视频 | 国产精品丝袜一区二区 | 啪啪激情网 | 日本精品久久久久中文字幕乱中年 | 国产在线视频一区二区董小宛性色 | 素人一区| 精品国产免费人成网站 | 波多野结衣影院 | 在线看亚洲十八禁网站 | 国产综合婷婷 | 国产高清无密码一区二区三区 | 欧美日韩国产成人在线观看 | 午夜丰满寂寞少妇精品 | 少妇欧美激情一区二区三区 | 国产精品奇米一区二区三区小说 | 国产 字幕 制服 中文 在线 | 人妻 日韩精品 中文字幕 | 免费一级做a爰片久久毛片潮喷 | 久热中文字幕无码视频 | 欧美性生活视频免费看 | 伊人青青久久 | 欧美性猛交乱大交xxxxx | 丝袜五月天 | 久久久噜噜噜久久久 | 亚洲视频在线免费播放 | 国产china男男激情 | 亚洲小视频网站 | 最新免费中文字幕 | 精品国产乱码 | 亚洲综合在线播放 | 国产日产欧美a级毛片 | 少妇下蹲露大唇无遮挡图片 | 欧美人与物videos另类 | 日本黄网站 | 中出视频在线观看 | 国产h自拍 | 中国黄色录像一级片 | 污污视频在线观看网站 | 亚洲日韩第一页 | 激情二区 | 久久久免费高清视频 | 超碰在线资源 | www.精品国产 | 一区二区三区四区在线播放 | 国产av一区二区三区无码野战 | 国产原创视频在线 | 日本人与黑人做爰视频网站 | 色翁荡息又大又硬又粗视频 | 精品人伦一区二区三区潘金莲 | av在线播放器 | 激情婷婷色 | 国产亚洲美女精品久久久2020 | 毛片基地在线观看 | 九九九九九依人 | 少妇人妻av无码专区 | 欧美人与动性xxxxx杂 | 另类国产ts人妖高潮系列视频 | 一区二区在线观看免费 | 亚洲国产理论片在线播放 | 精品欧美日韩 | 国语对白少妇×××bbb | 欧美性猛交xxxⅹ乱大交小说一 | 国产精品成人在线观看 | 阿v视频在线免费观看 | 国产大片网站 | 人妻无码久久精品人妻 | 国产中文字幕一区二区三区 | www.天天综合 | 欧美成人第一页 | 少妇做爰免费视频网站图片 | 国产乱码精品一区二区三区不卡 | 久久8| 福利视频一区二区三区 | 国产伦理片在线观看 | 好吊色国产欧美日韩免费观看 | 亚洲日韩视频免费观看 | 天天爽夜夜爽视频 | 欧美熟妇xxxxx欧美老妇不卡 | 精品在线一区 | 玖玖爱在线观看 | 国产免费又硬又黄又爽的视频喷水 | 十八女人水多三级 | 免费看a视频 | 国产精品免费无遮挡无码永久视频 | 欧美激情成人在线 | 国产精品极品美女自在线观看免费 | 久久午夜色播影院 | 精品少妇一区二区三区免费观看 | 亚洲中文字幕不卡无码 | 肮脏的交易在线观看 | 狠狠色综合网站久久久久久久 | 蜜臀av亚洲一区二区 | 色女人网站 | 亚洲人成欧美中文字幕 | 国产在线一区二区三区四区五区 | 久久天堂综合亚洲伊人hd妓女 | 99草草国产熟女视频在线 | 天天综合在线视频 | 一边捏奶头一边高潮视频 | 国产精品区一区二区三含羞草 | 久久精品国内一区二区三区 | 天下第一社区视频www日本 | 日韩专区一区 | 成人黄色三级 | 国产精品三级三级三级 | 日本中文字幕网站 | 精品一区二区三区免费播放 | 欧美性猛交xxxxx按摩欧美 | 劲爆欧美第一页 | 成人av在线一区二区三区 | 日噜噜夜噜噜 | 不卡中文字幕 | 免费在线观看成人 | 亚洲男人第一av网站 | 国产精成人品 | 欧美图片一区二区 | 黑人巨大精品欧美一区二区三区 | 成人免费观看a | 狠狠久久亚洲欧美专区 | 男人天堂免费视频 | 亚洲欧美另类视频 | 欧美一区二区三区在线播放 | 91国偷自产一区二区三区女王 | 九色porny视频黑人 | 国产97久久| 亚洲精品成a人 | 亚洲国产aⅴ综合网 | 午夜精品在线 | 久久www香蕉免费人成 | 亚洲最新网址 | 亚l州综合另中文字幕 | 国产人与禽zoz0性伦免费 | 18禁止看的免费污网站 | 特级特黄aaaa免费看 | 国产在线视欧美亚综合 | 91天天| 成人av网站在线播放 | 成人性生活大片免费看ⅰ软件 | 成人字幕网zmw | 精品国产乱码一区二区三区99 | 91福利一区二区 | 久久精品人人做人人综合 | 成人免费视频在线播放 | 成人做爰视频www网站小优视频 | 99精品国产丝袜在线拍国语 | 黑人粗大猛烈进出高潮视频 | 日韩一二三区视频 | 亚洲天堂导航 | 国产做a爰片久久毛片a片 | 97超级碰碰碰 | 午夜dj在线观看免费视频 | 成年人黄色大片 | 国产精品一区在线播放 | 人妻熟妇乱又伦精品视频 | 精品国产乱码久久久久 | 亚洲图片一区二区三区 | 国产原创麻豆 | 免费啪视频 | 狠狠色噜噜狠狠米奇777 | 色播亚洲视频在线观看 | 51国产偷自视频区视频 | 精品国产一区二区三区国产馆杂枝 | 日韩精品一| 国产成人精品亚洲一区 | 国内精品久久久久久久久电影网 | 日本一卡二卡四卡无卡乱码视频免费 | 久久精品水蜜桃av综合天堂 | 久久久国产精品视频 | 狠狠干2022 | 肉体暴力强伦轩在线播放 | 穿越异世荒淫h啪肉np文 | 日韩精品乱码 | 国产aaaaaa| 日韩欧美aaaa羞羞影院 | 成人免费看黄 | 国产伦精品一区二区三区四区 | 免费看欧美大片 | 农村老熟妇乱子伦视频 | 富婆按摩av国产hd | 精品国产一区二区三区色欲 | 欧美黑人狂野猛交老妇 | 国产超碰人人模人人爽人人喊 | 国产成人艳妇aa视频在线 | 国产美a三级三级看三级 | 成人国产在线视频 | 一女两夫做爰3p高h文 | 全球色影院 | 少妇愉情理伦片丰满丰满午夜 | 欧美精品免费一区二区三区 | 一二三区国产 | 欧洲中文字幕 | 天天干夜夜爽 | 国产精品久久久久久久裸模 | 麻豆tv入口在线看 | 中文字幕日韩精品一区 | 国产欧美视频一区二区 | 久久婷婷国产综合 | 性做久久久久久久久 | 欧美色久 | 成人含羞草tv免费入口 | 女同互舔互慰dv毛片 | 99热国产| 亚洲伦理自拍 | 日韩一欧美内射在线观看 | 精品一区二区在线播放 | 日韩欧美在线视频 | 久久99精品国产.久久久久 | 国产精品一区二区av不卡 | 免费看成人av | 视频在线不卡 | 玩弄少妇肉体到高潮动态图 | 欧美破处女 | 亚洲精品字幕在线观看 | 激情宗合网 | 玩弄白嫩少妇xxxxx性 | 亚洲涩网| 成人自拍视频在线观看 | 国产黄色一级网站 | 久久久久久一区二区三区四区别墅 | 三级全黄做爰龚玥菲在线 | 国产在线精品一区二区 | 国精产品一区一区三区有限在线 | 色婷婷综合久色aⅴ五区最新 | 国产一区二区三区四区三区 | 国产精品久久久久7777 | 岛国一区二区 | 国产www性 | 美女视频黄频a美女大全 | 无码无套少妇毛多18p | 极品尤物被啪到呻吟喷水 | 精品伦精品一区二区三区视频 | 你懂的网址在线播放 | 黄色三级生活片 | 91啪视频在线观看 | 国产精品成人av性教育 | 一区二区免费在线播放 | 久久一级免费视频 | 欧美一区二区日韩国产 | 一区二区免费在线观看 | 欧美 亚洲 另类 偷偷 自拍 | 国产情侣在线播放 | 一区国产精品 | 亚洲19禁大尺度做爰无遮挡 | 激情区| 日韩视频在线观看免费 | 日韩少妇内射免费播放 |