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

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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

嵌入式軟件優(yōu)先級的重要性

strongerHuang ? 來源:博客園 ? 作者:博客園 ? 2020-09-04 15:29 ? 次閱讀

嵌入式軟件開發(fā)中,我們不可避免的需要接觸優(yōu)先級的概念,掌握優(yōu)先級的概念對于設計一個好的軟件系統(tǒng)尤為重要。

本篇筆記的主要內容有以下幾個方面:

1、中斷優(yōu)先級

2、操作系統(tǒng)中的任務優(yōu)先級

3、同等優(yōu)先級處理

4、中斷嵌套

今天借助大家熟悉的 STM32F103 平臺和各位聊聊其中的密事。

首先,我們從一個裸機系統(tǒng)的變量自加開始說起。

這里有三個變量,A、B、C,其中 B 變量除了在 main 函數中自加外,還會在中斷處理函數中進行自加。

這里面考慮了B的兩種情況,一是先執(zhí)行 main 中的自加再執(zhí)行中斷的自加,二是先執(zhí)行中斷的自加再進行 main 的自加。

不管發(fā)生哪種情況,當程序執(zhí)行到 C 位置時,B 的值都是一樣的。

當然,以上分析是從 C 語言的角度進行分析的,如果以匯編的視角進行分析(自加操作在匯編中分為三個步驟),你會發(fā)現,這里面其實還有第三種情況:

這里面的 B’ 可以認為是寄存器,即變量的 B 的副本。

正因為副本的存在,在main 函數的寫入過程中導致丟失了中斷中 B 的自加操作。

對于程序而言,就好像根本沒有進入中斷一樣!

這就是全局變量的使用隱患。

但是善于分析的道友可能會提出這樣一個疑問,為什么上面只考慮了main 函數中的B++被打斷的可能,卻沒有考慮中斷(橙色部分)的B++被打斷的可能,是魚鷹忽略了嗎?

不不,其實這里面就涉及到了今天的主題,優(yōu)先級。

在裸機系統(tǒng)中,中斷優(yōu)先級高于main函數的處理,也就是說,一且中斷來臨, 不管main函數執(zhí)行到哪個位置,都會優(yōu)先處理中斷程序,只有中斷程序執(zhí)行完成后,才會繼續(xù)執(zhí)行main函數,所以中斷的 B++ 不可能被main 函數打斷!

這里插兩個問題:

怎么進入中斷函數的?

當中斷請求(中斷請求可以認為是種電平信號,在寄存器中就表現為某一位的標志位)來臨時,硬件負責把部分寄存器存儲到棧(一種特殊的數據結構)中,這里面就包含了PC寄存器(用于指示下一條指令執(zhí)行的位置),之后從向量表中找到中斷處理函數的入口地址,開始進入中斷處理函數中執(zhí)行。

怎么回到原來的位置?

因為在進入中斷前已經保存了PC等其他寄存器的值,所以只要在執(zhí)行完中斷處理函數后,將之前的保存到棧中的值恢復回來,那么CPU就可以繼續(xù)從被打斷的指令開始繼續(xù)執(zhí)行。

更多相關的中斷行為請查看《權威指南》,魚鷹不再細說。

回到剛才的優(yōu)先級話題,正因為中斷的執(zhí)行優(yōu)先級比main高,所以中斷中的 B++ 不會被打斷,這也是為什么有些時候,我們不需要對中斷中的變量進行臨界保護的原因所在。

在 Cortex-M3 內核中,中斷分為可屏蔽和不可屏蔽中斷,同時又有可編程優(yōu)先級和不可編程優(yōu)先級之分。

所謂可屏蔽,就是說這個中斷是可以屏蔽掉的,即使發(fā)生了中斷,也不會讓CPU執(zhí)行中斷里面的程序。

比如我們的定時器中斷,如果我們沒有開啟相應的中斷的話,即使定時器溢出中斷來了,那也不會進入中斷處理函數處理的。

而不可屏蔽,就是說這個中斷是不可以屏蔽的,比如復位中斷(是不是不可思議,代碼執(zhí)行的第一條指令竟然是中斷處理函數里面的),如果復位中斷都被屏蔽了,那么系統(tǒng)也就別想運行了。

可編程,意味著這個中斷的優(yōu)先級可以由軟件修改(不可編程,即優(yōu)先級固定死了,不能修改)。

中斷的優(yōu)先級在設置時又有搶占式優(yōu)先級和非搶占式優(yōu)先級兩種設置(根據單片機不同,搶占式和非搶占式可設置的位數不同,并且可以分配各自的位數,即所謂的中斷分組,如STM32F103 共有四位,通過設置中斷分組來決定搶占式和非搶占的位數)。

搶占優(yōu)先級,即如果中斷 1 的優(yōu)先級比中斷 2 的搶占優(yōu)先級高的話,一旦中斷1發(fā)出中斷請求,即使已經在中斷 2 執(zhí)行了,也會強制進入中斷 1 執(zhí)行,這個類似于 main 函數與中斷的關系,只不過這里兩個都是中斷而已。

在搶占優(yōu)先級相同情況下,非搶占優(yōu)先級就會開始起作用了。

如果中斷 1 和中斷 2 的搶占優(yōu)先級設置成一樣,而非搶占優(yōu)先級不一樣,此時如果兩個中斷同時發(fā)出請求,那么優(yōu)先處理非搶占優(yōu)先級高的中斷。

但是如果不是同時發(fā)生呢?那么就會依次處理中斷請求,在其中一個中斷處理過程中,是不可以被另一個中斷打斷的,同時如果本中斷再來一個請求,也不會重新進入中斷函數處理。

即中斷本身不可打斷自身的處理,換句話說中斷不會執(zhí)行到一半時又因為自身新的中斷請求來臨而重新再次進入本中斷處理函數執(zhí)行。

如果搶占優(yōu)先級和非搶占優(yōu)先級都設置成一樣呢,此時如果兩個中斷同時發(fā)生,又該選擇哪個先執(zhí)行,隨機嗎?

這里就涉及到硬件優(yōu)先級了。

在上圖中,每一個中斷其實都是有固定的默認優(yōu)先級的,這個優(yōu)先級肯定不同,所以當搶占優(yōu)先級和非搶占優(yōu)先級一樣的情況下,在中斷同時發(fā)生時,先執(zhí)行默認優(yōu)先級高的。

看圖:

講到了中斷,就不可不說如何禁止中斷的問題了。

在常規(guī)操作中,我們會使用禁止全局中斷來禁止中斷的處理,一旦禁止了全局中斷,那么除了不可屏蔽中斷外,所有的中斷都會被屏蔽掉,即如果在禁止中斷后發(fā)生了中斷,也不會再執(zhí)行。

但是一旦中斷打開了,那么之前被屏蔽的中斷就會立刻開始執(zhí)行(有一個中斷掛起位,代表中斷的發(fā)生,只有CPU執(zhí)行了中斷處理函數,并清零相應標志位,該掛起位才會清除)。

如果在關閉中斷的過程中發(fā)送了兩次中斷,比如外部中斷發(fā)生了兩次,那么在開啟中斷后,也只會響應一次中斷,因為掛起位就只有那么一位(不像隊列一樣可以保留多個標志位)。

對于一般功能而言,禁止全局中斷確實有用,對于保護全局變量也非常有效,但是對于整個系統(tǒng)而言會有一定的影響。

如果禁止中斷的時間很短,那么確實無關緊要,但是一旦需要禁止較長的時間(毫秒級別),對于那些需要及時處理的中斷而言,就是一個不可忽視的延遲。

而在操作系統(tǒng)中,為了保護那些全局變量,禁止中斷的操作時有發(fā)生,那么是否有一種方法可以屏蔽部分中斷,而讓高優(yōu)先級的中斷不被屏蔽呢?

有的,在 Cortex-M3 內核中,有一個寄存器專門干這事,即 BASEPRI。

當設置該寄存器時,將屏蔽所有優(yōu)先級不高于某個具體值的中斷。

比如設置該寄存器為 3,那么優(yōu)先級0~ 2的中斷不會被屏蔽。

所以在操作系統(tǒng)中,我們可以修改禁止中斷的代碼,使其不會屏蔽高優(yōu)先級的中斷,對于高優(yōu)先級中斷來說,可增加實時性。

uCOS II 中默認是直接全局禁止中斷的(可以修改它),但是 FreeRTOS 是可以禁止部分中斷的,使用的就是上述寄存器,當然這個功能需要單片機本身支持才行。

以上就是中斷優(yōu)先級的內容,如果只會裸機的話,那么以上內容就差不多了,但是如果是操作系統(tǒng),那么需要再增加一個任務優(yōu)先級的概念。

所謂任務,你也可以認為是一種中斷,只不過,這種特殊的中斷優(yōu)先級低于所有的硬件觸發(fā)的中斷。

中斷的優(yōu)先級凌駕于所有任務之上。

也就是說,一旦中斷來臨,不管CPU正在執(zhí)行哪個任務,在全局中斷開啟的情況下,都會立刻執(zhí)行中斷里的程序。

在中斷中,可以進行中斷嵌套,所謂的中斷嵌套即當前中斷被另一個更高優(yōu)先級的中斷所打斷(即搶占),被打斷的中斷必須在高優(yōu)先級任務執(zhí)行完成后才會繼續(xù)執(zhí)行。而在嵌入式實時操作系統(tǒng)中,為了更好的處理實時任務,一般而言也會設置成可搶占的任務(亦稱可剝奪)。

中斷的優(yōu)先級處理是由內核進行管理的,這里的內核是指單片機內核,比如STM32F103的內核是Cortex-M3(更準確的說是由 NVIC 管理)。

一旦設置好相應的寄存器之后,只要中斷來了,那么就會自動處理中斷程序,這些工作由硬件完成,它會在多個中斷同時來臨時選擇最高的優(yōu)先處理;也會在中斷執(zhí)行時,如果有一個更高優(yōu)先級的中斷來臨時,打斷當前中斷的執(zhí)行而先執(zhí)行更高優(yōu)先級的中斷。

但是操作系統(tǒng)是純軟件行為,那么操作系統(tǒng)的任務優(yōu)先級又是誰管理的?又是如何管理的呢?

答案就在Systick中斷。

既然要管理所有任務的優(yōu)先級,即在合適時選擇運行優(yōu)先級最高的任務,那么操作系統(tǒng)本身必然需要有能剝奪所有任務執(zhí)行的能力,而中斷是凌駕于任務之上的,可以在任何時候剝奪任務的執(zhí)行,從而獲得CPU的使用權,所以選擇中斷作為操作系統(tǒng)的核心是合適的。

但是中斷那么多,選擇什么中斷比較合適呢?沒有比 Systick 中斷更合適的了,因為它就是為此而生的。

Systick說白了就是一個定時器,但是和普通定時器不同的是,功能比較單一,就是一個計數器而已,所以使用它管理任務是合適的,不會占用其他定時器。

那么Systick又是如何管理任務的呢?

一般而言,Systick 會設置成幾毫秒中斷一次,在每次中斷時,Systick處理程序(即操作系統(tǒng)內核)都會從所有的任務中選擇最高優(yōu)先級的任務執(zhí)行,也就是說,系統(tǒng)總是運行最高的任務。

而這個特性也就導致你的高優(yōu)先級任務不可以無限執(zhí)行而不主動釋放CPU,因為一旦高優(yōu)先級任務無限執(zhí)行了,那么低優(yōu)先級任務將永遠得不到執(zhí)行機會,這就給人一種死機的假象。

可能有道友會疑惑,為什么空閑任務不需要調用系統(tǒng)延時函數去主動釋放CPU的使用權呢?

那是因為空閑任務本身優(yōu)先級就是所有任務中最低的,如果它主動釋放 CPU 了,而其他任務都處于掛起狀態(tài),那么操作系統(tǒng)又該讓誰去執(zhí)行呢?

所以,空閑任務需要永遠處于運行狀態(tài)。

從這個角度來說,操作系統(tǒng)主要的功能就是定時從所有任務中尋找最高優(yōu)先級的任務,然后讓該任務得到運行機會(使用PendSV 中斷切換到任務中,模擬中斷切換過程),功能類似于中斷管理器。

而正因為操作系統(tǒng)只會尋找最高優(yōu)先級的任務來執(zhí)行(對于實時操作系統(tǒng)是這樣,有些操作系統(tǒng)可能先來先處理的策略),所以任務本身主動釋放 CPU 就顯得尤為重要了。

最常用的主動釋放 CPU 的函數就是系統(tǒng)延時函數了,調用這個函數后,任務將延時一段時候才回來繼續(xù)執(zhí)行,而在延時過程中,操作系統(tǒng)就可以調用其他任務執(zhí)行了,正因為如此,操作系統(tǒng)才顯得高效。

雖然操作系統(tǒng)需要中斷來剝奪所有任務的執(zhí)行,從而擁有 CPU 的控制權,但是一般而言,它的優(yōu)先級卻是所有中斷中最低的,因為它的優(yōu)先級只需要高于任務即可,如果設置的更高,那么就會影響到真正需要高優(yōu)先處理的中斷,因為Systick中斷的處理還是比較頻繁和繁重的,如果設置的太高,那么在Systick處理時,更低優(yōu)先級的中斷將無法處理,這可不是我們想看到的結果。

而如果設置成中斷優(yōu)先級最低的話,既可以剝奪任務的執(zhí)行,又可以在高優(yōu)先級中斷來臨時及時處理中斷,讓系統(tǒng)的實時得到提高。

與 Systick 配套的中斷,還有一個 PendSV 中斷,這個優(yōu)先級一般和 Systick 設置成一樣,一般而言該中斷的觸發(fā)是由操作系統(tǒng)內核主動觸發(fā)的(在切換任務時軟件觸發(fā)該中斷),而不像 Systick 一樣,定時被動觸發(fā),關于兩個中斷更具體描述可參考《Cortex-M3 權威指南》。

既然中斷可以設置成優(yōu)先級一樣的,那么任務應該也可以才對,確實一般的操作系統(tǒng)都可以設置相同優(yōu)先級的任務(uCOS II 不可以, uCOS III 和 FreeRTOS 、RT-Thread可以),那么操作系統(tǒng)又是如何處理同等優(yōu)先級的任務?

一般而言,在任務初始化時,會設置任務的時間片,這個時間片就是在任務優(yōu)先級相同的情況下才會發(fā)生作用。

比如,任務 1 設置 5 個時間片(即Systick中斷時間),任務 2 設置 10 個時間片,如果兩個任務的優(yōu)先級一樣,那么在 15 個時間片內,任務 1 將執(zhí)行 5 個時間片,之后切換到任務 2 執(zhí)行10個時間片,來回往復。

那么比任務1 和任務 2 優(yōu)先級更高的任務該什么時候執(zhí)行呢?答案是隨時,即只要高優(yōu)先級任務有需要,那么不管任務 1 和 任務 2 是否主動釋放 CPU,都會被操作系統(tǒng)強制切換到高優(yōu)先級任務中執(zhí)行(由 Systick完成,所以可能會有一點延時)。

那么優(yōu)先級比它們低的任務呢?這個就靠它們的自覺了,如果它們自覺的主動釋放CPU(比如調用系統(tǒng)延時函數),那么低優(yōu)先級任務就有執(zhí)行機會,否則,低優(yōu)先級任務將不會執(zhí)行!

該用一張圖來說明整個系統(tǒng)的優(yōu)先級關系了:

最后魚鷹再聊聊該如何設置任務優(yōu)先級。

很多人設計任務優(yōu)先級時都會從 0、1、2、3 這樣的順序來設置,實際上,這種設置是不合理的,因為一旦后面需求變化了,要從中加入一個中間的優(yōu)先級,那么很可能在加入后程序出現問題了。

其實我們可以從 Cortex-M3 的中斷優(yōu)先級得到啟發(fā),即空開部分優(yōu)先級不使用,留待后面擴展用,比如設計優(yōu)先級時可以設置成 3、5、7、9、11,留出最高的0~2用于可能的高優(yōu)先級任務,中間空出一個或兩個優(yōu)先級用于擴展,這樣一旦后面需要增加其他優(yōu)先級的任務,會顯得異常簡單(可能會有額外的一點內存損耗,但卻是值得的)。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯系本站處理。 舉報投訴
  • 嵌入式
    +關注

    關注

    5094

    文章

    19178

    瀏覽量

    307732
  • 嵌入式系統(tǒng)

    關注

    41

    文章

    3625

    瀏覽量

    129764

原文標題:嵌入式系統(tǒng)優(yōu)先級詳解

文章出處:【微信號:strongerHuang,微信公眾號:strongerHuang】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    【「嵌入式Hypervisor:架構、原理與應用」閱讀體驗】+第7-8章學習心得

    這是一本很好的學習嵌入式的書籍。 在深入學習《嵌入式Hypervisor:架構、原理與應用》的第7-8章后,我對嵌入式Hypervisor的架構、原理及其在實際應用中的重要性有了更為深
    發(fā)表于 10-09 18:50

    freertos中斷優(yōu)先級在哪設置

    FreeRTOS是一個流行的實時操作系統(tǒng),它廣泛應用于嵌入式系統(tǒng)開發(fā)。在FreeRTOS中,中斷優(yōu)先級是一個重要的概念,因為它決定了中斷處理的順序和響應時間。 1. 理解中斷優(yōu)先級
    的頭像 發(fā)表于 09-02 14:17 ?780次閱讀

    APS智能優(yōu)化排產軟件優(yōu)先級應用

    資源、訂單需求和約束條件,自動計算出最優(yōu)的生產計劃。在這個過程中,訂單排產的優(yōu)先規(guī)則起著至關重要的作用。1.交期優(yōu)先級交期優(yōu)先級是訂單排產中最基本的
    的頭像 發(fā)表于 06-26 17:43 ?444次閱讀
    APS智能優(yōu)化排產<b class='flag-5'>軟件</b>的<b class='flag-5'>優(yōu)先級</b>應用

    請問有什么方法降低WIFI中斷的優(yōu)先級?

    因為項目對時序輸出要求比較嚴格,WIFI中斷優(yōu)先級比硬件定時器中斷優(yōu)先級要高,在定時器中斷里面對GPIO管腳控制被延長執(zhí)行,請問有什么方法降低WIFI中斷的優(yōu)先級?
    發(fā)表于 06-19 07:37

    從事嵌入式方向,一定要軟硬件通吃?

    嵌入式系統(tǒng)開發(fā)領域,軟件和硬件的界限常常模糊不清。一個常見的問題是,嵌入式軟件工程師是否需要了解硬件。本文將探討這一問題的重要性,并分析
    的頭像 發(fā)表于 06-05 08:10 ?1290次閱讀
    從事<b class='flag-5'>嵌入式</b>方向,一定要軟硬件通吃?

    systick的中斷優(yōu)先級是否應該設置為最高優(yōu)先級的嵌套中斷?

    最近在學習ucosii有這樣一個疑問,關于stm32的systick作為ucosii的基準時鐘,systick的中斷優(yōu)先級是否應該設置為最高優(yōu)先級的嵌套中斷。理由是什么?各位大俠求指教!??!
    發(fā)表于 05-16 06:44

    創(chuàng)建了兩個task如果一個優(yōu)先級高 一個優(yōu)先級低,高優(yōu)先級的那個一直在做,什么時候會調度到低優(yōu)先級的呢?

    創(chuàng)建了兩個task如果一個優(yōu)先級高一個優(yōu)先級低, 我看到任務的函數都是用死循環(huán)做的,那個高優(yōu)先級的那個一直在做,什么時候會調度到低優(yōu)先級的呢?
    發(fā)表于 05-13 07:13

    嵌入式實時操作系統(tǒng)中的優(yōu)先級反轉問題

    死鎖預防是實時系統(tǒng)設計中的一個重要因素。不幸的是,即使使用安全排除技術,這可能也不是困難的終點。在解決資源爭用問題時,可能引入新的優(yōu)先級翻轉問題。
    發(fā)表于 04-26 15:47 ?525次閱讀
    <b class='flag-5'>嵌入式</b>實時操作系統(tǒng)中的<b class='flag-5'>優(yōu)先級</b>反轉問題

    嵌入式環(huán)境的中斷調試步驟操作

    確保問題中斷的優(yōu)先級設置正確。它應該高于正常工作的中斷的優(yōu)先級,但低于任何應該優(yōu)先于它的中斷的優(yōu)先級
    發(fā)表于 04-09 10:41 ?400次閱讀

    嵌入式實時操作系統(tǒng)優(yōu)先級搶占調度機制解析

    當搶占發(fā)生時,任務即使沒有完成也會被迫放棄處理器,此時任務并沒有被掛起,而是會返回就緒隊列。任務在隊列中的位置是由優(yōu)先級決定的,它會在隊列中等待到下一次被調度。
    的頭像 發(fā)表于 04-05 05:22 ?2917次閱讀
    <b class='flag-5'>嵌入式</b>實時操作系統(tǒng)<b class='flag-5'>優(yōu)先級</b>搶占<b class='flag-5'>式</b>調度機制解析

    STM32F103的寄存器NVIC_IPRx搶占優(yōu)先級和子優(yōu)先級是怎么設置的?

    STM32F103的寄存器NVIC_IPRx有些不明白,搶占優(yōu)先級和子優(yōu)先級是怎么設置的? 如果,中斷分組2,搶占優(yōu)先級3,子優(yōu)先級3 那下面這樣寫對嗎? SCB->AIR
    發(fā)表于 03-27 07:48

    嵌入式C語言中斷調試步驟

    確保問題中斷的優(yōu)先級設置正確。它應該高于正常工作的中斷的優(yōu)先級,但低于任何應該優(yōu)先于它的中斷的優(yōu)先級。
    的頭像 發(fā)表于 03-26 12:20 ?763次閱讀

    Hightec對芯片中斷優(yōu)先級分配時,中斷號越高中斷優(yōu)先級越高嗎?

    請問大佬,Hightec對芯片中斷優(yōu)先級分配時,中斷號越高中斷優(yōu)先級越高嗎?看網上的帖子說中斷號越低優(yōu)先級越高。
    發(fā)表于 02-27 06:13

    RTTnano的用戶main函數中的優(yōu)先級是多少?

    RTTnano 的用戶main函數中的優(yōu)先級是多少?為什么會出現創(chuàng)建新的task之后,main函數會搶占掉低優(yōu)先級的task,例如RT_THREAD_PRIORITY_MAX設置為8 ,低于3
    發(fā)表于 02-26 08:01

    嵌入式軟件設計的原則分享

    嵌入式軟件開發(fā)如果具有更好的閱讀、擴展性以及維護,就需要考慮很多因素。今天給大家分享幾個嵌入式軟件
    發(fā)表于 02-25 10:54 ?751次閱讀
    <b class='flag-5'>嵌入式</b><b class='flag-5'>軟件</b>設計的原則分享
    主站蜘蛛池模板: 在线视频亚洲色图 | 亚洲美国avcom| 国产aaa级一级毛片 国产ar高清视频+视频 | 久久国产免费福利永久 | 大香伊人网 | 天天综合天天添夜夜添狠狠添 | 99色视频在线 | 亚洲日本一区二区三区在线不卡 | 欧美一级黄色录相 | 国产国产人免费人成成免视频 | 天天操天天操天天射 | 国产色啪午夜免费视频 | 中文一级黄色片 | 噜噜噜色噜噜噜久久 | 狠狠色丁香久久婷婷综合丁香 | 99久精品| dvd碟片色爱 | 好紧好湿好黄的视频 | 国产在线播放成人免费 | 奇米影视五月天 | 日韩美女拍拍免费视频网站 | 欧美成人午夜毛片免费影院 | 色视频在线观看网站 | 高清成年美女黄网站色大 | 欧美激情啪啪 | 欧美性猛交xxxx乱大交中文 | 免费一级毛片私人影院a行 免费一级毛片无毒不卡 | 成人窝窝午夜看片 | 网站在线观看视频 | 免费的黄色大片 | 色男人网 | 天天摸日日舔 | 天天躁夜夜躁狠狠躁2021西西 | 久久免费看视频 | 日本啪啪小视频 | 色五月天天 | 九九国产在线观看 | 天天干天天谢 | 色多多视频在线观看免费大全 | 欧美精品videosex性欧美 | 国产性色视频 |