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

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

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

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

基于單片機(jī)和μC/0S-II內(nèi)核實(shí)現(xiàn)串口通信模塊的設(shè)計(jì)

電子設(shè)計(jì) ? 來源:單片機(jī)與嵌入式系統(tǒng)應(yīng)用 ? 作者:姚傳安 ? 2021-06-17 11:54 ? 次閱讀

嵌入式應(yīng)用中,使用RTOS的主要原因是為了提高系統(tǒng)的可靠性,其次是提高開發(fā)效率、縮短開發(fā)周期。μC/OS-II是一個占先式實(shí)時多任務(wù)內(nèi)核,使用對象是嵌入式系統(tǒng),對源代碼適當(dāng)裁減,很容易移植到8~32位不同框架的微處理器上。但μC/OS-II僅是一個實(shí)時內(nèi)核,它不像其他實(shí)時操作系統(tǒng)(如嵌入式Linux)那樣提供給用戶一些API函數(shù)接口。在μC/OS-II實(shí)時內(nèi)核下,對外設(shè)的訪問接口沒有統(tǒng)一完善,有很多工作需要用戶自己去完成。串口通信是單片機(jī)測控系統(tǒng)的重要組成部分,異步串行口是一個比較簡單又很具代表性的中斷驅(qū)動外設(shè)。本文以單片機(jī)中的串口為例,介紹μC/OS—II下編寫中斷服務(wù)程序以及外設(shè)驅(qū)動程序的一般思路。

1 μC/OS-II的中斷處理及51系列單片機(jī)中斷系統(tǒng)分析

μC/OS-II中斷服務(wù)程序(ISR)一般用匯編語言編寫。以下是中斷服務(wù)程序的步驟。

保存全部CPU寄存器

調(diào)用OSIntEnter()或OSIntNesting(全局變量)直接加1;

執(zhí)行用戶代碼做中斷服務(wù);

調(diào)用0SIntExit();

恢復(fù)所有CPU寄存器;

執(zhí)行中斷返回指令。

μC/OS-II提供兩個ISR與內(nèi)核接口函數(shù):OSIntEnter()和OSIntExit()。OSIntEnter()通知μC/OS—II核,中斷服務(wù)程序開始了。事實(shí)上,此函數(shù)做的工作是把一個全局變量OSIntNesting加1,此中斷嵌套計(jì)數(shù)器可以確保所有中斷處理完成后再做任務(wù)調(diào)度。另一個接口函數(shù)OSIntExit()則通知內(nèi)核,中斷服務(wù)已結(jié)束。根據(jù)相應(yīng)情況,退回被中斷點(diǎn)(可能是一個任務(wù)或者是被嵌套的中斷服務(wù)程序)或由內(nèi)核作任務(wù)調(diào)度。

用戶編寫的ISR必須被安裝到某一位置,以便中斷發(fā)生后,CPU根據(jù)相應(yīng)的中斷號運(yùn)行準(zhǔn)確的服務(wù)程序。許多實(shí)時操作系統(tǒng)都提供了安裝和卸載中斷服務(wù)程序的API接口函數(shù),但μC/OS—II內(nèi)核沒有提供類似的接口函數(shù),需要用戶在對CPU的移植中自己實(shí)現(xiàn)。這些接口函數(shù)與具體的硬件環(huán)境有關(guān),接下來以51單片機(jī)下的中斷處理對此詳細(xì)說明。

51單片機(jī)的中斷基本過程如下:CPU在每個機(jī)器周期的S5P2時刻采樣中斷標(biāo)志,而在下一指令周期將對采樣的中斷進(jìn)行查詢。如果有中斷請求,則按照優(yōu)先級高低的原則進(jìn)行處理。響應(yīng)中斷時,先置相應(yīng)的優(yōu)先級激活觸發(fā)器于相應(yīng)位,封鎖同級或低級中斷,然后根據(jù)中斷源類別,在硬件控制下,將中斷地址壓入堆棧,并轉(zhuǎn)向相應(yīng)的中斷向量入口單元。通常在入口單元處放一跳轉(zhuǎn)指令,轉(zhuǎn)向執(zhí)行中斷服務(wù)程序.當(dāng)執(zhí)行中斷返回指令RETI時,把響應(yīng)中斷時所置位的優(yōu)先級激活觸發(fā)器清零后,從堆棧中彈出被保護(hù)的斷點(diǎn)地址,裝入程序計(jì)數(shù)器PC,CPU返回原來被中斷處繼續(xù)執(zhí)行程序。

在移植的過程中,采用Keil C 51作為編譯環(huán)境。KeilC5l集成C編譯和匯編器。中斷子程序用匯編語言編寫,放到移植μC/0S—II后的OS_CPU_A.ASM匯編文件中。下面是以串行口中斷為例的移植中斷服務(wù)子程序代碼

2 串口驅(qū)動程序

已在5l單片機(jī)上成功移植了μC/0S-II內(nèi)核,移植過程在此不再討論。這里重點(diǎn)分析μC/0S—II內(nèi)核下串口驅(qū)動程序編寫。

由于串行設(shè)備存在外設(shè)處理速度和CPU速度不匹配的問題,所以需要一個緩沖區(qū).向串口發(fā)送數(shù)據(jù)時,只要把數(shù)據(jù)寫到緩沖區(qū)中,然后由串口逐個取出往外發(fā)。從串口接收數(shù)據(jù)時,往往等收到若干個字節(jié)后才需要CPU進(jìn)行處理,所以這些預(yù)收的數(shù)據(jù)可以先存于緩沖區(qū)中。實(shí)際上,單片機(jī)的異步串口中只有兩個相互獨(dú)立、地址相同的接收、發(fā)送緩沖寄存器SBUF。在實(shí)際應(yīng)用中,需要從內(nèi)存中開辟兩個緩沖區(qū),分別為接收緩沖區(qū)和發(fā)送緩沖區(qū)。這里把緩沖區(qū)定義為環(huán)形隊(duì)列的數(shù)據(jù)結(jié)構(gòu)。

μC/OS-II內(nèi)核提供了信號量作為通信和同步的機(jī)制,引入數(shù)據(jù)接收信號量、數(shù)據(jù)發(fā)送信號量分別對緩沖區(qū)兩端的操作進(jìn)行同步。串口的操作模式如下:用戶任務(wù)想寫,但緩沖區(qū)滿時,在信號量上睡眠,讓CPU運(yùn)行別的任務(wù),待ISR從緩沖區(qū)讀走數(shù)據(jù)后喚醒此睡眠的任務(wù);同樣,用戶任務(wù)想讀,但緩沖區(qū)空時,也可以在信號量上睡眠,待外部設(shè)備有數(shù)據(jù)來了再喚醒。由于μC/OS-II的信號量提供了超時等待機(jī)制,串口當(dāng)然也具有超時讀寫能力。圖1是帶緩沖區(qū)和信號量的串口接收示意圖。數(shù)據(jù)接收信號量初始化為0,表示在環(huán)形緩沖區(qū)中無數(shù)據(jù)。

接收中斷到來后,ISR從UART的接收緩沖器SBUF中讀入接收的字節(jié)(②),放入接收緩沖區(qū)(③),然后通過接收信號量喚醒用戶任務(wù)端的讀操作(④、①)。在整個過程中,可以查詢記錄緩沖區(qū)中當(dāng)前字節(jié)數(shù)的變量值,此變量表明接收緩沖區(qū)是否已滿。UART收到數(shù)據(jù)并觸發(fā)了接收中斷,但如果此時緩沖區(qū)是滿的,那么放棄收到的字符。緩沖區(qū)的大小應(yīng)合理設(shè)置,降低數(shù)據(jù)丟失的可能性,又要避免存儲空間的浪費(fèi)。

圖2為帶環(huán)形緩沖區(qū)和超時信號量的串口發(fā)送示意圖。發(fā)送信號量初始值設(shè)為發(fā)送緩沖區(qū)的大小,表示緩沖區(qū)已空,并且關(guān)閉發(fā)送中斷。發(fā)送數(shù)據(jù)時,用戶任務(wù)在信號量上等待(①)。如果發(fā)送緩沖區(qū)未滿,用戶任務(wù)向發(fā)送緩沖區(qū)中寫入數(shù)據(jù)(②)。如果寫入的是發(fā)送緩沖區(qū)中的第一個字節(jié),則允許發(fā)送中斷(②)。然后,發(fā)送ISR從發(fā)送緩沖區(qū)中取出最早寫入的字節(jié)輸出至UART(④),這個操作又觸發(fā)了下一次的發(fā)送中斷,如此循環(huán)直到發(fā)送緩沖區(qū)中最后一個字節(jié)被取走,重新關(guān)閉發(fā)送中斷。在ISR向UART輸出的同時,給信號量發(fā)信號(⑤),發(fā)送任務(wù)據(jù)此信號量計(jì)數(shù)值來了解發(fā)送緩沖區(qū)中是否有空間。

3 串口通信模塊的設(shè)計(jì)

每個串行端口有兩個環(huán)狀隊(duì)列緩沖區(qū),同時有兩個信號量:一個用來指示接收字節(jié),另一個用來指示發(fā)送字節(jié)。每個環(huán)狀緩沖區(qū)有以下四個要素:

◇存儲數(shù)據(jù)(INT8U數(shù)組);

◇包含環(huán)狀緩沖區(qū)字節(jié)數(shù)的計(jì)數(shù)器;

◇環(huán)狀緩沖區(qū)中指向?qū)⒈环胖玫南乱蛔止?jié)的指針;

◇環(huán)狀緩沖區(qū)中指向被取出的下一字節(jié)的指針。

圖3是接收數(shù)據(jù)軟件模塊的流程圖。SerialGetehar()用來獲取接收到的數(shù)據(jù),如果緩沖區(qū)已空時將任務(wù)掛起,接收到字節(jié)時,任務(wù)將被喚醒,同時從串行口接收字節(jié)。SerialPutRxChar()用來將接收的字節(jié)放到緩沖區(qū)中,如果接收緩沖區(qū)已滿,則該字節(jié)被丟棄。當(dāng)字節(jié)插入到緩沖區(qū)中,SerialPutRxChar()通知數(shù)據(jù)接收信號量,使之將數(shù)據(jù)己到的消息傳達(dá)給所有等待的任務(wù)。為防止掛起應(yīng)用任務(wù),可以通過調(diào)用SceiallsEmPty()去發(fā)現(xiàn)環(huán)狀隊(duì)列中是否有字節(jié)。

圖4是發(fā)送數(shù)據(jù)模塊的流程圖。當(dāng)需要發(fā)送數(shù)據(jù)給串行端口時,SerialPurChar()等待信號量在初始化發(fā)送信號量時應(yīng)該初始為緩沖區(qū)的大小。因此,當(dāng)緩沖區(qū)中沒有更多空間時,SerialPutChar()就掛起任務(wù),只要UART再次發(fā)送字節(jié),掛起任務(wù)就將恢復(fù)。SerialGctChar()被中斷服務(wù)程序調(diào)用,如果發(fā)送緩沖區(qū)至少還有一個字節(jié),Seri-a1GetChar()就返回一個從緩沖區(qū)發(fā)送的字節(jié)。如果緩沖區(qū)己空,則SerialGetChar()返回Null,這將使調(diào)用停止進(jìn)一步的發(fā)送中斷,一直到有數(shù)據(jù)發(fā)送為止。

4 異步串行通信的接口函數(shù)

應(yīng)用任務(wù)可以通過如下的幾個函數(shù)來控制和訪問UART:SerialCfgPort()、SerialGetChar()、SerialInit()、SerialIsEmpty()、SerialIsFull()和SerialPutChar()。

SerialCfgPort()用于建立串行端口的特征,在為指定端口調(diào)用其他服務(wù)前,必須先調(diào)用該函數(shù),包括確定波特率、比特?cái)?shù)、奇偶校驗(yàn)和停止位等。

SerialGetChar()使應(yīng)用程序從接收數(shù)據(jù)的環(huán)狀title=“緩沖區(qū)” style=“text-decoration:underline;color:blue”》緩沖區(qū)中取出數(shù)據(jù)。

SerialInit()用于初始化整個串口軟件模塊,且必須在該模塊提供的其他任何服務(wù)前調(diào)用。SeriallInit()將環(huán)狀緩沖區(qū)計(jì)數(shù)器的字節(jié)數(shù)清零,并初始化每個環(huán)狀緩沖區(qū)的IN和OUT指針,指向數(shù)據(jù)存儲區(qū)的開始處。數(shù)據(jù)接收信號量初始化為0,表示在環(huán)狀緩沖區(qū)無數(shù)據(jù)。用傳送緩沖區(qū)大小初始化數(shù)據(jù)傳送信號量,表示緩沖區(qū)已空。

SerialIsEmpty()允許應(yīng)用程序確定是否有字節(jié)從串口接收進(jìn)來。本函數(shù)允許在無數(shù)據(jù)時避免將任務(wù)掛起。

SerialIsFull()允許應(yīng)用程序確定傳送環(huán)狀緩沖區(qū)的狀態(tài),本函數(shù)可以在緩沖區(qū)已滿時避免將任務(wù)掛起。

SerialPutChar()允許應(yīng)用程序向一個串行端口發(fā)送數(shù)據(jù)。

結(jié) 語

該串口通信模塊充分利用了實(shí)時內(nèi)核的任務(wù)調(diào)度功能和信號量機(jī)制,系統(tǒng)軟件模塊化,可讀性增強(qiáng),便于修改和移植,其設(shè)計(jì)思路和方法可以很好的應(yīng)用在多種情況下的測控系統(tǒng)中,系統(tǒng)的擴(kuò)展方便,具有一定的借鑒作用。該串口通信模塊已作為某鐵路供水遠(yuǎn)程控制終端的一部分,運(yùn)行穩(wěn)定,提高了整個系統(tǒng)的運(yùn)行效率和實(shí)時性。

------------ 關(guān)于μC/OS-II系列軟件版權(quán)的說明

Micrium 公司產(chǎn)品包括μC/OS-II,μC/GUI,uC/FS,μC/TCP-IP,μC/USB等。Micrium 公司提供嵌入式系統(tǒng)應(yīng)用方面的產(chǎn)品,并對其軟件擁有知識產(chǎn)權(quán)。Micrium花費(fèi)了大量的時間和財(cái)力為嵌入式領(lǐng)域提供高質(zhì)量的軟件產(chǎn)品。所有上述產(chǎn)品都以源代碼的形式提供給客戶,具有極大的適用性。產(chǎn)品不是免費(fèi)軟件,也不是開放源碼的軟件,因此,不能免費(fèi)使用,需要清楚的闡明μC/OS-II和系列的軟件不是開放源碼的免費(fèi)軟件,這是和Linux完全不一樣的。

開發(fā)和研究者可以通過購買Micrium公司的Jean先生的μC/OS-II的書籍,而得到μC/OS-II源代碼,但是僅可以作為個人和學(xué)校學(xué)習(xí)使用,所有和μC/OS-II直接和間接相關(guān)的商業(yè)目的行為,必須購買使用μC/OS-II及系列產(chǎn)品的商業(yè)授權(quán),包括芯片/單板/系統(tǒng)廠家的任何參考設(shè)計(jì),教學(xué)設(shè)備和最終的產(chǎn)品,如果沒有得到Micrium公司Jean先生簽字的合法授權(quán)都是不合法的使用, 這在μC/OS-II的書籍Micrium公司(www.micrium.com)和中國代理商-北京麥克泰軟件公司網(wǎng)站(www.bmrtech.com)上面中有明確規(guī)定。

Micrium公司其它軟件如μC/GUI,μC/FS,μC/TCP-IP,μC/USB 等的銷售模式與μC/OS-II不同,如果沒有購買使用授權(quán),完全不可以擁有該源代碼,也不能將源代碼用于產(chǎn)品的設(shè)計(jì),培訓(xùn),教學(xué)和生產(chǎn)。

μC/OS-II, μC/GUI,μC/FS,μC/TCP-IP,μC/USB 等授權(quán)方式有:單個產(chǎn)品、產(chǎn)品線(系列)、按照CPU 劃分的產(chǎn)品三種形式,μC/OS-KA,μC/OS-VIEW 等工具是按照使用人的數(shù)目收取費(fèi)用的,相對起傳統(tǒng)的RTOS 動輒2-3萬美圓的開發(fā)費(fèi)用和每塊單板的使用費(fèi)(根據(jù)數(shù)量從數(shù)百到幾個美圓),μC/OS-II及系列產(chǎn)品是采用一次性的收費(fèi)方式,應(yīng)該只是大約相當(dāng)于傳統(tǒng)RTOS 的10-20% 的總體費(fèi)用。

責(zé)任編輯:gt

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

    關(guān)注

    6044

    文章

    44627

    瀏覽量

    638975
  • cpu
    cpu
    +關(guān)注

    關(guān)注

    68

    文章

    10911

    瀏覽量

    213144
  • 串口
    +關(guān)注

    關(guān)注

    14

    文章

    1560

    瀏覽量

    77141
收藏 人收藏

    評論

    相關(guān)推薦

    如何開發(fā)基于uC/0S-II的應(yīng)用軟件?

    如何開發(fā)基于uC/0S-II的應(yīng)用軟件?uC/0S-II是如何移植的?
    發(fā)表于 04-27 06:56

    串口/并口基礎(chǔ)上實(shí)現(xiàn)51內(nèi)核單片機(jī)的在線編程

    串口/并口基礎(chǔ)上實(shí)現(xiàn)51內(nèi)核單片機(jī)的在線編程摘要:詳細(xì)說明利用并口模擬I2C總線協(xié)議,實(shí)現(xiàn)My
    發(fā)表于 04-12 14:01 ?34次下載

    利用Keil C51實(shí)現(xiàn)單片機(jī)與PC機(jī)串口通信任務(wù)

    【LabVIEW從入門到精通】5.2.4.1 利用Keil C51實(shí)現(xiàn)單片機(jī)與PC機(jī)串口通信
    發(fā)表于 01-08 15:47 ?0次下載

    利用Keil C51實(shí)現(xiàn)單片機(jī)與PC機(jī)串口通信任務(wù)2

    【LabVIEW從入門到精通】5.2.4.3 利用Keil C51實(shí)現(xiàn)單片機(jī)與PC機(jī)串口通信
    發(fā)表于 01-08 15:47 ?0次下載

    DSP與單片機(jī)串口通信的設(shè)計(jì)與實(shí)現(xiàn)

    DSP與單片機(jī)串口通信的設(shè)計(jì)與實(shí)現(xiàn)
    發(fā)表于 10-20 10:11 ?5次下載
    DSP與<b class='flag-5'>單片機(jī)</b><b class='flag-5'>串口</b><b class='flag-5'>通信</b>的設(shè)計(jì)與<b class='flag-5'>實(shí)現(xiàn)</b>

    什么是單片機(jī)串口通信

    串口通信單片機(jī)一個重要的部分,單片機(jī)和PC,單片機(jī)單片機(jī)之間的
    發(fā)表于 07-25 07:36 ?6.2w次閱讀
    什么是<b class='flag-5'>單片機(jī)</b>的<b class='flag-5'>串口</b><b class='flag-5'>通信</b>?

    單片機(jī)C語言之串口通信協(xié)議

    本文首先介紹了串口的基本結(jié)構(gòu),其次介紹了串口通信方式,最后詳細(xì)介紹了單片機(jī)C語言之串口
    發(fā)表于 05-22 12:37 ?4988次閱讀
    <b class='flag-5'>單片機(jī)</b><b class='flag-5'>C</b>語言之<b class='flag-5'>串口</b><b class='flag-5'>通信</b>協(xié)議

    如何使用51單片機(jī)實(shí)現(xiàn)串口通信

    51單片機(jī)串口引腳為P3.0引腳與P3.1引腳,分別是RXD和TXD引腳。串口通信可以用于單片機(jī)和其它芯片
    發(fā)表于 11-21 15:47 ?3w次閱讀
    如何使用51<b class='flag-5'>單片機(jī)</b><b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>串口</b><b class='flag-5'>通信</b>

    使用51單片機(jī)實(shí)現(xiàn)NRF24L01無線模塊串口通信詳細(xì)資料說明

    基于51單片機(jī)(STC12C5A60S2)和NRF24L01無線模塊串口通信,源碼在附件中,親測用貓貓
    發(fā)表于 03-01 08:00 ?15次下載

    51單片機(jī)串口通信

    串口成本低、容易使用、通信線路簡單,可實(shí)現(xiàn)兩個設(shè)備的互相通信單片機(jī)串口可以使得
    發(fā)表于 11-18 14:06 ?22次下載
    51<b class='flag-5'>單片機(jī)</b><b class='flag-5'>串口</b><b class='flag-5'>通信</b>

    51單片機(jī)串口通信

    串口成本低、容易使用、通信線路簡單,可實(shí)現(xiàn)兩個設(shè)備的互相通信單片機(jī)串口可以使得
    發(fā)表于 11-21 20:36 ?64次下載
    51<b class='flag-5'>單片機(jī)</b><b class='flag-5'>串口</b><b class='flag-5'>通信</b>

    51單片機(jī)——串口通信

    51單片機(jī)——串口通信串口通信串口通信的原理?
    發(fā)表于 11-23 17:36 ?33次下載
    51<b class='flag-5'>單片機(jī)</b>——<b class='flag-5'>串口</b><b class='flag-5'>通信</b>

    單片機(jī)串口通信

    單片機(jī)串口通信:通常的USB串行通信方式為全雙工,即兩條數(shù)據(jù)線:RXD和TXD,一條用于發(fā)送數(shù)據(jù),一條用于接收數(shù)據(jù)。在串行通信前,需要對串行
    發(fā)表于 12-28 19:48 ?7次下載
    <b class='flag-5'>單片機(jī)</b><b class='flag-5'>串口</b><b class='flag-5'>通信</b>

    單片機(jī)通信協(xié)議有哪些 單片機(jī)和wifi模塊間怎么通信

    單片機(jī)和WiFi模塊通信的方法有以下幾種: 1. 串口通信:將單片機(jī)與WiFi
    的頭像 發(fā)表于 06-13 17:56 ?1.7w次閱讀

    基于單片機(jī)串口通信模塊設(shè)計(jì)

    電子發(fā)燒友網(wǎng)站提供《基于單片機(jī)串口通信模塊設(shè)計(jì).doc》資料免費(fèi)下載
    發(fā)表于 10-19 11:29 ?8次下載
    基于<b class='flag-5'>單片機(jī)</b>的<b class='flag-5'>串口</b><b class='flag-5'>通信</b><b class='flag-5'>模塊</b>設(shè)計(jì)
    主站蜘蛛池模板: 国产无遮挡床戏视频免费 | 欧美大片一区 | 激情有码 | 四色成人网 | 天天插天天色 | 丁香婷婷影院 | 国产成人黄网址在线视频 | 欧美性黑人极品hd网站 | 91九色成人 | 性欧美xxxx乳高跟 | 久久亚洲国产成人精品性色 | 国产精品a在线观看香蕉 | 免费h视频在线观看 | 一级片免费在线观看 | 一级一级毛片免费播放 | 美女涩涩网站 | 操国产美女 | 羞涩妩媚玉腿呻吟嗯啊销魂迎合 | 好吊妞视频988在线播放 | 黄色大片免费观看 | 色综合欧美综合天天综合 | 色天天综合色天天碰 | 亚洲午夜视频在线 | 亚洲人成人网毛片在线播放 | 青草99| 狠狠操狠狠搞 | 国产嫩草影院在线观看 | 天天综合在线视频 | 国产亚洲精品久久午夜 | 欧美一区二区三区性 | 日本卡一卡2卡3卡4精品卡无人区 | 久久精品网站免费观看 | 精品国产麻豆免费人成网站 | 黄在线观看网站 | 国产香蕉98碰碰久久人人 | 亚洲酒色1314狠狠做 | 欧美啪啪精品 | 欧美h视频 | 天天网综合 | 上课被同桌强行摸下面小黄文 | 久久精品视频观看 |