精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Hi3516的SAMGR--系統(tǒng)服務(wù)框架子系統(tǒng)-6-系統(tǒng)服務(wù)的啟動

系統(tǒng)
系統(tǒng)服務(wù)和特性(service/feature)的Init函數(shù),都會用SYS_SERVICE_INIT /SYS_FEATURE_INIT或者SYSEX_SERVICE_INIT/APP_SERVICE_INIT/SYSEX_FEATURE_INIT/APP_FEATURE_INIT等一組宏來做標(biāo)記,這組宏定義在 //utils/native/lite/include/ohos_init.h文件內(nèi)。

[[408903]]

想了解更多內(nèi)容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術(shù)社區(qū)

https://harmonyos.51cto.com

在進(jìn)入正題之前,我們先來簡單了解一下在系統(tǒng)服務(wù)的啟動方式上,輕量系統(tǒng)和小型系統(tǒng)(包括了標(biāo)準(zhǔn)系統(tǒng),后面一樣)的差別。

不管是輕量系統(tǒng)還是小型系統(tǒng),系統(tǒng)服務(wù)和特性(service/feature)的Init函數(shù),都會用SYS_SERVICE_INIT /SYS_FEATURE_INIT或者SYSEX_SERVICE_INIT/APP_SERVICE_INIT/SYSEX_FEATURE_INIT/APP_FEATURE_INIT等一組宏來做標(biāo)記,這組宏定義在 //utils/native/lite/include/ohos_init.h文件內(nèi)。

打開這個文件,可以看到:

Hi3516的SAMGR--系統(tǒng)服務(wù)框架子系統(tǒng)-6-系統(tǒng)服務(wù)的啟動-鴻蒙HarmonyOS技術(shù)社區(qū)

在對“LAYER_INITCALL”這個宏的展開上,輕量系統(tǒng)和小型系統(tǒng)的差別就開始了。

命令行進(jìn)入B_LTS項目代碼根目錄,執(zhí)行$find ./ -name *.gn | xargs grep -in "LAYER_INIT_SHARED_LIB" 指令,可以查到"LAYER_INIT_SHARED_LIB"定義的地方,在 //foundation/distributedschedule/samgr_lite/samgr/BUILD.gn:14。

打開看一下:

  1. config("external_settings_shared") { 
  2.  
  3.   defines = [ "LAYER_INIT_SHARED_LIB" ] 
  4.  
  5.  
  6. if (ohos_kernel_type == "liteos_m") { 
  7.  
  8.   static_library("samgr") { 
  9.  
  10. ...... 
  11.  
  12.  
  13.  
  14. if (ohos_kernel_type == "liteos_a" || ohos_kernel_type == "linux") { 
  15.  
  16.   shared_library("samgr") { 
  17.  
  18. ...... 
  19.  
  20.     public_configs += [ ":external_settings_shared" ] 
  21.  
  22.   } 
  23.  

也就是說輕量系統(tǒng)沒有定義"LAYER_INIT_SHARED_LIB",而小型系統(tǒng)則是包含這個宏的定義的,為什么要將"LAYER_INIT_SHARED_LIB"的定義要放在samgr_lite/samgr組件上,這個稍后會講到。

輕量系統(tǒng):

輕量系統(tǒng)上,LAYER_INITCALL使用__attribute __((section(“section_name”)))來展開, 其作用是在編譯階段,將函數(shù)或數(shù)據(jù)鏈接到指定的名為"section_name"對應(yīng)的段中。在系統(tǒng)啟動時,再通過MODULE_INIT/SYS_INIT宏引導(dǎo)去"section_name"對應(yīng)的段中找到記錄的入口函數(shù),并依次執(zhí)行它們。

注意,這種啟動方式是串行的,前一個服務(wù)的入口函數(shù)沒有執(zhí)行完,并不會執(zhí)行后一個服務(wù)的入口函數(shù),這就是不能在SYS_SERVICE_INIT /SYS_FEATURE_INIT等宏標(biāo)記的入口函數(shù)做太多事情、特別是不能做阻塞式的事情的原因。

更具體的啟動細(xì)節(jié),請去《Hi3861_WiFiIoT工程的一點(diǎn)理解》進(jìn)行閱讀理解。

小型系統(tǒng):

小型系統(tǒng)上,LAYER_INITCALL使用__attribute __((constructor))來展開,對應(yīng)還有一個__attribute __((destructor)),它們就類似于C++的類中的構(gòu)造函數(shù)和析構(gòu)函數(shù)的作用。

  • 如果函數(shù)被設(shè)定為constructor屬性,則該函數(shù)會在main()函數(shù)開始執(zhí)行之前被自動地先執(zhí)行;
  • 如果函數(shù)被設(shè)定為destructor屬性,則該函數(shù)會在main()函數(shù)執(zhí)行結(jié)束之后或者exit()被調(diào)用后,被自動地執(zhí)行。

這在小型系統(tǒng)中非常有用,比如某個進(jìn)程的運(yùn)行依賴ServiceA和FeatureAa,ServiceA和FeatureAa的Init函數(shù)都用SYS_SERVICE_INIT /SYS_FEATURE_INIT標(biāo)記了,那在這個進(jìn)程啟動時的main函數(shù)執(zhí)行之前,ServiceA和FeatureAa的Init函數(shù)就會先于main被執(zhí)行。所以,小型系統(tǒng)中,梳理清楚關(guān)鍵進(jìn)程的服務(wù)依賴關(guān)系就顯得非常重要了。

下面我們就進(jìn)入正題,小型系統(tǒng)的系統(tǒng)服務(wù)的整體的啟動流程。

我們知道,鴻蒙系統(tǒng)從內(nèi)核態(tài)切換到用戶態(tài),跑的第一個進(jìn)程Init,也叫用戶態(tài)根進(jìn)程,它讀取并分析/etc/init.cfg配置文件(//vendor/hisilicon/hispark_taurus/init_configs/init_liteos_a_3516dv300.cfg的副本),根據(jù)上面的記錄,按順序啟動幾個關(guān)鍵的系統(tǒng)進(jìn)程:

  1.  
  2.             "name" : "init"
  3.  
  4.             "cmds" : [ 
  5.  
  6.                 "start shell"
  7.  
  8.                 "start apphilogcat"
  9.  
  10.                 "start foundation"
  11.  
  12.                 "start bundle_daemon"
  13.  
  14.                 "start appspawn"
  15.  
  16.                 "start media_server"
  17.  
  18.                 "start wms_server"
  19.  
  20.                 "start hiview"
  21.  
  22.                 "start sensor_service"
  23.  
  24.                 "start ai_server" 
  25.  
  26.             ] 
  27.  
  28. }, 

系統(tǒng)啟動的log如下:

Hi3516的SAMGR--系統(tǒng)服務(wù)框架子系統(tǒng)-6-系統(tǒng)服務(wù)的啟動-鴻蒙HarmonyOS技術(shù)社區(qū)

這里的“[init_service] ServiceStart:[[xxxx]]:OK, pid[x].”僅僅表明用戶態(tài)根進(jìn)程已經(jīng)為服務(wù)進(jìn)程創(chuàng)建好了運(yùn)行的基礎(chǔ)環(huán)境并拿到了服務(wù)進(jìn)程的Pid,并不代表服務(wù)進(jìn)程已經(jīng)完全可以正常工作了。服務(wù)進(jìn)程需要去執(zhí)行自己的main()函數(shù)跑起來,而在這之前,又需要先去跑完它依賴的所有的“ServiceA和FeatureAa”的__attribute __((constructor))函數(shù),然后main()的最后一步,一般是進(jìn)入while (1) { pause() }狀態(tài),也就是服務(wù)進(jìn)程進(jìn)入后臺,默默守護(hù)著本進(jìn)程以及它的所有子進(jìn)程/子線程,有點(diǎn)像蜂王/蟻后一樣,進(jìn)程對內(nèi)/外提供的服務(wù)、功能、接口等具體工作,由它的子子孫孫來完成。

上面提到,一個服務(wù)進(jìn)程對別人的依賴關(guān)系非常重要,下表是我對上面init OK的9個進(jìn)程的依賴關(guān)系所做的一些梳理,把每一個進(jìn)程的依賴關(guān)系一層層找到列了出來,從上到下,把對三方庫的依賴、重復(fù)出現(xiàn)的依賴,都灰化掉了,這樣看起來就清爽多了。【每次重洗整理都發(fā)現(xiàn)會有一些小小的疏漏,所以這個表格還不算完美】 

Hi3516的SAMGR--系統(tǒng)服務(wù)框架子系統(tǒng)-6-系統(tǒng)服務(wù)的啟動-鴻蒙HarmonyOS技術(shù)社區(qū)

從系統(tǒng)啟動完整過程的log看這9個進(jìn)程的實(shí)際啟動順序與上面/etc/init.cfg給出的順序并不一一對應(yīng):

  1. Line 167: {Process:shell} 
  2.  
  3. Line 170: {Process:apphilogcat} 
  4.  
  5. Line 182: {Process:sensor_service} 
  6.  
  7. Line 195: {Process:bundle_daemon} 
  8.  
  9. Line 284: {Process:ai_server} 
  10.  
  11. Line 345: {Process:wms_server} 
  12.  
  13. Line 347: {Process:media_server} 
  14.  
  15. Line 573: {Process:foundation} 
  16.  
  17. Line 1678: {Process:appspawn} 

這是因?yàn)橛行┻M(jìn)程依賴關(guān)系很少,就啟動得快一些,而foundation進(jìn)程,依賴非常多的東西,所以啟動得非常慢。

前面說到“為什么要將 LAYER_INIT_SHARED_LIB 的定義要放在samgr_lite/samgr組件上”,因?yàn)檩p量系統(tǒng)不用__attribute __((constructor))這個機(jī)制,LAYER_INIT_SHARED_LIB的定義放在哪里,對輕量系統(tǒng)來說無所謂;而小型系統(tǒng),看看上面的依賴關(guān)系表,shell/apphilogcat/media_server三個進(jìn)程不依賴其他的ServiceA和FeatureAa,也不依賴samgr組件,所以對它們來說,LAYER_INIT_SHARED_LIB的定義放在哪里,也無所謂;而其他進(jìn)程都需要依賴samgr,并且是由samgr來管理和啟動該進(jìn)程所依賴的所有ServiceA和FeatureAa,所以LAYER_INIT_SHARED_LIB的定義,最低層次放在samgr是非常合適的,可以把系統(tǒng)組件的耦合程度降到最低。

3號進(jìn)程shell由內(nèi)核提供,直接啟動,這是full shell,代碼在//kernel/liteos_a/shell/full/目錄下。

4號進(jìn)程apphilogcat,依賴關(guān)系非常簡單,僅僅依賴一個三方庫和由 //base/hiviewdfx/hilog_lite/frameworks/featured/ 目錄下的代碼編譯生成的動態(tài)鏈接庫hilog_shared,所以也是直接啟動了。

5號進(jìn)程foundation,依賴的東西非常多,需要到很后面才會跑到main函數(shù),這個后面詳細(xì)講。

反倒是依賴關(guān)系相對簡單的10號進(jìn)程sensor_service、6號進(jìn)程bundle_daemon、11號進(jìn)程ai_server首先跑完依賴關(guān)系,進(jìn)入main的while (1) { pause() } 狀態(tài)。

9號進(jìn)程wms_server,啟動起來之后,它的子線程就無休止地監(jiān)測按鍵/屏幕觸控等輸入性質(zhì)或者窗口顯示性質(zhì)的事件,并做出響應(yīng)。

8號進(jìn)程media_server,媒體服務(wù)進(jìn)程看上去是最干凈的,只由//device/hisilicon/hardware/multimedia:libhdi_media提供支持,最終由liteos_a:kernel提供支持。

7號進(jìn)程appspawn,是最后啟動的系統(tǒng)進(jìn)程,它起來之后,就可以通過它孵化出第一個應(yīng)用進(jìn)程launcher,以及后面其他的應(yīng)用進(jìn)程。

上面shell/apphilogcat/media_server三個進(jìn)程不依賴于samgr,也不依賴于其他的Service/Feature,我們這里就先不說了。

其他6個系統(tǒng)進(jìn)程,每個進(jìn)程都有自己獨(dú)立的地址空間,互相之間不能直接訪問,需要通過進(jìn)程間通信來進(jìn)行交互。

獨(dú)立的系統(tǒng)進(jìn)程,在自己獨(dú)立的地址空間內(nèi),啟動自己所依賴的Service/Feature,由自己空間內(nèi)的SamgrLiteImpl g_samgrImpl來管理,完全就是一個獨(dú)立的輕量系統(tǒng),這里可以去看看我前面的文章《Hi3861的SAMGR--系統(tǒng)服務(wù)框架子系統(tǒng)-3》,但注意還是會有一些較大的差異。

下面以不算簡單,但又不復(fù)雜的wms_server進(jìn)程為例,進(jìn)行分析。

打開 //foundation/graphic/wms/BUILD.gn 文件,查看它的依賴關(guān)系,簡化整理如下:

Hi3516的SAMGR--系統(tǒng)服務(wù)框架子系統(tǒng)-6-系統(tǒng)服務(wù)的啟動-鴻蒙HarmonyOS技術(shù)社區(qū)

hdi_input/lite_graphic_hals,需要外圍硬件設(shè)備的支持,硬件驅(qū)動啟動的時候就會加載運(yùn)行了。

samgr和lite_ipc_adapter,都沒有__attribute __((constructor))修飾,這是兩個獨(dú)立的動態(tài)鏈接庫,裝載進(jìn)來就直接用,注意,是samgr自己而已,并不包含"samgr_server:server"和"samgr_client:client"。

Broadcast服務(wù),包含了“Provider and subscriber”feature,不過好像實(shí)際上并沒有使用到。

wms_server進(jìn)程還依賴本進(jìn)程代碼中提供的WMS/IMS服務(wù),都沒有feature。

整理的表格如下:

Hi3516的SAMGR--系統(tǒng)服務(wù)框架子系統(tǒng)-6-系統(tǒng)服務(wù)的啟動-鴻蒙HarmonyOS技術(shù)社區(qū)

從上表的依賴關(guān)系來看,它就依賴一個broadcast 組件提供的Service/Feature,以及它自己wms_server組件所提供的Service:WMS/IMS,所以從實(shí)際跑起來的log可以驗(yàn)證,在main()跑起來之前,__attribute __((constructor))修飾的Servic/Feature的Init函數(shù)先跑起來:

Hi3516的SAMGR--系統(tǒng)服務(wù)框架子系統(tǒng)-6-系統(tǒng)服務(wù)的啟動-鴻蒙HarmonyOS技術(shù)社區(qū)

在main函數(shù)跑起來之前,wms_server進(jìn)程地址空間內(nèi),已經(jīng)有一張由本進(jìn)程的SamgrLiteImpl g_samgrImpl控制的靜態(tài)展開圖了(這里就不放展開圖了,可以參考《Hi3861的SAMGR--系統(tǒng)服務(wù)框架子系統(tǒng)-2》的展開圖進(jìn)行理解)。

main( )中,跑完HiFbdevInit()/InitDriver()后,會通過HOS_SystemInit()來調(diào)用SAMGR_Bootstrap()函數(shù),為上面三個service:Broadcast/WMS/IMS 創(chuàng)建各自的 TaskPool、Task、Queue,其中WMS/IMS是同級別的SHARED_TASK,所以它們共用一個Task/Queue,在收發(fā)消息時將會通過ServiceID來做區(qū)分。Task運(yùn)行起來之后,立即監(jiān)聽自己的消息隊列,處理消息。

Hi3516的SAMGR--系統(tǒng)服務(wù)框架子系統(tǒng)-6-系統(tǒng)服務(wù)的啟動-鴻蒙HarmonyOS技術(shù)社區(qū)

三個service:Broadcast/WMS/IMS的消息隊列,各自會首先收到一個MSG_DIRECT消息,由HandleInitRequest()來處理,這個HandleInitRequest() 內(nèi),會調(diào)用DEFAULT_Initialize(serviceImpl)來初始化Service/Feature。

DEFAULT_Initialize(serviceImpl) 函數(shù)內(nèi)的行為,對于輕量系統(tǒng)來說,就是調(diào)用Service/Feature的生命周期函數(shù)Initialize()/OnInitialize()來完成初始化工作,就OK了,SAMGR_RegisterServiceApi() 函數(shù)是空的樁函數(shù)。但是對于小型系統(tǒng)來說,SAMGR_RegisterServiceApi()有另外的實(shí)現(xiàn),它是進(jìn)入一個新世界的入口,這里先點(diǎn)到為止,后面我們會詳細(xì)講。

至此,系統(tǒng)服務(wù)進(jìn)程wms_server就可以開始工作了。

“[wms.cpp] main[5-4]: GetInstance()->Run()”這一步,InputManagerService instance對象就開始無休止地監(jiān)測按鍵/屏幕觸控等輸入性質(zhì)的事件,并做出響應(yīng)。

“[wms.cpp] main[5-5]: while(1)”這一步,也通過“OHOS::LiteWM::GetInstance()->MainTaskHandler();”開始無休止地根據(jù)需要重繪窗口顯示內(nèi)容。

其他五個進(jìn)程,啟動情況類似,或更簡單一些,或更復(fù)雜一些,但都會跑類似的流程,各個進(jìn)程內(nèi)部,都由自己的SamgrLiteImpl g_samgrImpl來管理本進(jìn)程內(nèi)的Service/Feature,進(jìn)程內(nèi)部的Service線程,直接通過消息隊列機(jī)制來進(jìn)行通信即可,要想跨進(jìn)程進(jìn)行交互,那就需要更復(fù)雜的機(jī)制了。

想了解更多內(nèi)容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術(shù)社區(qū)

https://harmonyos.51cto.com

 

責(zé)任編輯:jianghua 來源: 鴻蒙社區(qū)
相關(guān)推薦

2021-07-07 09:45:20

鴻蒙HarmonyOS應(yīng)用

2021-07-08 16:16:59

鴻蒙HarmonyOS應(yīng)用

2021-06-10 09:25:39

鴻蒙HarmonyOS應(yīng)用

2021-06-03 14:21:44

鴻蒙HarmonyOS應(yīng)用

2021-07-12 09:50:39

鴻蒙HarmonyOS應(yīng)用

2021-06-18 10:02:10

鴻蒙HarmonyOS應(yīng)用

2021-06-18 15:23:59

鴻蒙HarmonyOS應(yīng)用

2022-04-15 14:45:49

Hi3516系統(tǒng)類型燒錄鴻蒙

2022-02-16 16:01:02

Hi3516開發(fā)板鴻蒙

2021-07-21 09:58:50

鴻蒙HarmonyOS應(yīng)用

2021-10-09 10:12:39

鴻蒙HarmonyOS應(yīng)用

2021-03-29 15:36:46

鴻蒙HarmonyOS應(yīng)用

2021-04-09 09:45:21

鴻蒙HarmonyOS應(yīng)用

2021-07-19 15:34:05

鴻蒙HarmonyOS應(yīng)用

2021-07-09 14:20:23

鴻蒙HarmonyOS應(yīng)用

2021-11-09 15:28:41

鴻蒙HarmonyOS應(yīng)用

2021-03-16 09:49:16

鴻蒙HarmonyOS應(yīng)用

2021-05-25 14:47:43

鴻蒙HarmonyOS應(yīng)用

2023-04-12 15:31:11

系統(tǒng)服務(wù)管理鴻蒙

2022-03-14 15:26:59

Hi3516Ark子系統(tǒng)鴻蒙
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

欧美一区二区三区播放老司机| 日本一区二区三区四区在线视频| 欧美国产日韩精品| 黄色在线观看av| 亚洲天堂av影院| 国产精品久久看| 国产美女精品在线观看| 99精品人妻国产毛片| 欧美国产一级| 亚洲国产精品成人va在线观看| 日韩福利视频在线| 视频在线观看入口黄最新永久免费国产 | 国产伦精品一区二区三区视频青涩 | 桃花岛成人影院| 亚洲色图制服丝袜| 久中文字幕一区| 99久久国产免费| 久久xxxx精品视频| 九九精品在线观看| japanese中文字幕| 亚洲精品影片| 欧美日韩高清一区二区三区| 免费看一级大黄情大片| 麻豆网站在线免费观看| 97国产一区二区| 亚洲专区国产精品| 涩涩视频在线观看| 亚洲美女少妇无套啪啪呻吟| 日韩亚洲精品视频| 香蕉视频久久久| 美日韩黄色大片| 欧美一区二区三区四区视频 | 国产又黄又爽又无遮挡| 国产成人精品免费视| 亚洲第一福利网站| 韩国三级hd中文字幕有哪些| 国产精品久久久久久吹潮| 狠狠久久亚洲欧美专区| 黄色免费高清视频| 北岛玲一区二区三区| 久久人人爽爽爽人久久久| 粉嫩精品一区二区三区在线观看| 久久久国产免费| 国产视频欧美| 69av在线播放| 日韩精品一区二区三| 欧美日韩国产免费观看| 久久精品国产亚洲| 免费黄色国产视频| 色乱码一区二区三区网站| 亚洲人成网站免费播放| 大地资源二中文在线影视观看 | 久久电影网电视剧免费观看| 国产成一区二区| 亚洲GV成人无码久久精品| 亚洲欧洲视频| 98精品在线视频| 国产特黄大片aaaa毛片| 91久久视频| 97久久国产精品| 97免费在线观看视频| 一级成人国产| 欧美一级视频免费在线观看| √资源天堂中文在线| 99riav1国产精品视频| 久久久久久中文字幕| 国产极品美女高潮无套嗷嗷叫酒店| 午夜精品999| 国内精品久久久久| 国产精品suv一区二区三区| 国产婷婷精品| 国产精品福利网站| 在线观看色网站| 激情成人午夜视频| 高清视频一区| 麻豆av电影在线观看| 国产区在线观看成人精品 | 色丁香久综合在线久综合在线观看| 久久久久久久久久久久久国产精品| 成人性生活av| 欧美日韩不卡在线| 在线成人精品视频| 免费欧美一区| www.久久色.com| 国产一级黄色av| 久久婷婷麻豆| 成人精品视频99在线观看免费 | 亚洲人成网站在线播| 亚洲色图日韩精品| 黄色成人在线网站| 国产国语videosex另类| 国产尤物视频在线观看| 丁香桃色午夜亚洲一区二区三区| 国内精品视频免费| 国产高清一区在线观看| 亚洲美女视频在线| 亚洲乱码中文字幕久久孕妇黑人| 成人四虎影院| 亚洲国产精品久久久| 91麻豆精品国产91久久综合| 欧美在线高清| 国产精品1区2区在线观看| 国产免费黄色录像| 久久精品人人做人人爽人人| 亚洲啊啊啊啊啊| 原纱央莉成人av片| 日韩无一区二区| 无码少妇精品一区二区免费动态| 在线免费观看日本欧美爱情大片| 欧美在线视频一区二区| 99视频免费看| 中文在线一区二区| 成人在线免费观看av| 91国产一区| 亚洲欧洲高清在线| 国产污片在线观看| 国产一二精品视频| 日韩av高清| 麻豆视频在线观看免费网站黄| 777亚洲妇女| aa一级黄色片| 一区二区自拍| 亚洲一区二区三区视频| 国产一区二区三区福利| 欧美日韩国产中文精品字幕自在自线 | av中文字幕电影在线看| 欧美情侣在线播放| 欧美18—19性高清hd4k| 亚洲一区二区三区四区五区午夜| 成人黄色片视频网站| 免费在线观看黄色网| 欧洲精品在线观看| 国产精品三级在线观看无码| 亚洲精品123区| 国产精品亚洲不卡a| 日本在线视频中文有码| 91精品国产91久久综合桃花| 九一在线免费观看| 老司机午夜精品视频| 精品欧美日韩| 女人让男人操自己视频在线观看 | 亚洲一区二区三区香蕉 | 美国一区二区| 国语自产精品视频在线看一大j8| www.久久久久久| 亚洲精品免费在线观看| 天天色综合天天色| 欧美一区二区三| 国产精品96久久久久久又黄又硬| 亚洲色图欧美视频| 精品色蜜蜜精品视频在线观看| 午夜影院福利社| 精品1区2区3区4区| 精品国产乱码久久久久久108| 美足av综合网| 亚洲电影免费观看高清| 精品欧美一区二区三区免费观看| 91最新地址在线播放| 欧美污视频网站| 久久99国产精品视频| 国产成人啪精品视频免费网| 三级视频在线| 欧洲精品一区二区三区在线观看| 欧日韩不卡视频| 狠狠色综合色综合网络| 黄色网zhan| 成人在线视频中文字幕| 2021久久精品国产99国产精品| 人妻精品无码一区二区| 午夜a成v人精品| 中文字幕av久久爽一区| 男男成人高潮片免费网站| 人人妻人人澡人人爽精品欧美一区| gogo大尺度成人免费视频| 欧美乱妇高清无乱码| 人妻va精品va欧美va| 在线这里只有精品| 肉色超薄丝袜脚交69xx图片| 国产成人啪免费观看软件| 天天夜碰日日摸日日澡性色av| 久久不见久久见中文字幕免费| 国产欧美日韩最新| 国产在线xxx| 国产一区二区三区在线看| 一本色道久久综合无码人妻| 一区二区三区**美女毛片| 亚洲制服丝袜在线播放| 全国精品久久少妇| 成人在线观看毛片| 偷拍一区二区| 成人在线视频网| 日韩影院在线| 久久影院资源网| 三级在线电影| 日韩免费看网站| 进去里视频在线观看| 一卡二卡欧美日韩| 妺妺窝人体色WWW精品| 国产一区二区成人久久免费影院| 国产淫片免费看| 91久久夜色精品国产按摩| 国产一级二级三级精品| 欧洲午夜精品| 77777亚洲午夜久久多人| 国产淫片在线观看| 亚洲免费视频在线观看| a级片免费观看| 欧美影视一区在线| 日韩欧美a级片| 亚洲精品视频在线观看网站| 免费网站在线高清观看| 不卡免费追剧大全电视剧网站| 亚洲天堂2018av| 久久不射中文字幕| 91免费黄视频| 欧美欧美全黄| 亚洲一区二区三区加勒比| 天海翼精品一区二区三区| 亚洲一区二区三区xxx视频| 中文另类视频| 欧洲美女免费图片一区| 欧美精品videosex| 久久精品中文字幕免费mv| 久久久久久久久亚洲精品| 精品剧情在线观看| 国产欧美日韩成人| 欧美午夜电影网| 无码人妻精品一区二区三区不卡| 亚洲高清免费视频| 精国产品一区二区三区a片| 国产精品人妖ts系列视频| 在线国产视频一区| 99re视频精品| 欧美大喷水吹潮合集在线观看| 国产精品香蕉一区二区三区| 亚洲人视频在线| 看片网站欧美日韩| 高清一区在线观看| 日本成人超碰在线观看| 国产女女做受ⅹxx高潮| 亚洲中字在线| 亚洲 高清 成人 动漫| 亚洲美女网站| 日本wwww视频| 久久先锋资源| 999在线免费视频| 久久精品主播| 狠狠热免费视频| 免费欧美在线视频| 日本高清久久久| 韩国av一区二区三区在线观看| 天堂av8在线| 国产一区高清在线| 在线观看免费看片| 国产传媒一区在线| 亚洲图片欧美另类| 93久久精品日日躁夜夜躁欧美| 成人精品在线观看视频| 91丨porny丨中文| 熟女俱乐部一区二区| 久久久久88色偷偷免费| 人与嘼交av免费| 国产精品伦一区二区三级视频| 麻豆网址在线观看| 樱花草国产18久久久久| 精品深夜av无码一区二区老年| 亚洲午夜私人影院| 天天操天天摸天天干| 色婷婷综合久久久久中文 | 免费黄网站欧美| 99日在线视频| 成人午夜av影视| 国产福利短视频| 亚洲国产精品传媒在线观看| 人与动物性xxxx| 一级女性全黄久久生活片免费| 五月天婷婷丁香| 欧美性视频一区二区三区| 艳妇乳肉豪妇荡乳av| 欧美精品一区二| 国产在线一二三| 久久成年人免费电影| 2018av在线| 国产精品一久久香蕉国产线看观看| 国产日韩在线观看视频| 国产一区视频观看| 日韩国产一区二区| 东北少妇不带套对白| 久久综合图片| 永久看看免费大片| 久久精品一区二区三区av| 日韩在线中文字幕视频| 粉嫩老牛aⅴ一区二区三区| 久久午夜鲁丝片| 337p日本欧洲亚洲大胆精品 | 国产精品久久久久久久久毛片| 精品少妇一区二区三区| 精品视频一二三| 久久99精品视频一区97| 日韩精选视频| 国产精品一区二| 日韩亚洲一区在线| 免费成人在线视频网站| 国产综合色在线| 成人国产精品久久久网站| 亚洲综合免费观看高清完整版| 国产真人无遮挡作爱免费视频| 日韩欧美在线网站| 国产二区视频在线观看| 午夜精品蜜臀一区二区三区免费| 精品三级在线| 快播亚洲色图| 在线成人h网| 国产黑丝在线视频| 国产精品欧美一区喷水| 国产成人亚洲欧洲在线| 日韩精品一区二区三区在线| 色三级在线观看| 欧美与黑人午夜性猛交久久久| 亚洲精品一区二区三区在线| 亚洲精品成人a8198a| 久久久久久久欧美精品| 国产日韩视频一区| 亚洲欧美激情小说另类| 亚洲特级黄色片| 国产小视频91| 一区二区乱码| 国产一区免费| 亚洲全部视频| jjzz黄色片| 伊人色综合久久天天| 国产精品久久777777换脸| 色久欧美在线视频观看| 欧美电影免费观看| 美女黄毛**国产精品啪啪| 亚洲高清成人| 国模无码视频一区| 亚洲在线免费播放| 亚洲不卡免费视频| 欧美国产亚洲精品久久久8v| 国产乱码精品一区二区三区亚洲人| 色综合电影网| 免费不卡在线观看| wwwww黄色| 欧美日韩一区高清| 夜级特黄日本大片_在线| 国产精品高清免费在线观看| 精品盗摄女厕tp美女嘘嘘| 丁香婷婷激情网| 日本一区二区三级电影在线观看| 波多野结衣一区二区在线| 国产亚洲欧美日韩美女| 亚洲第一影院| 一区二区成人国产精品| 国产在线一区二区| 99久久婷婷国产综合| 日韩精品在线看片z| 日本无删减在线| 国产精品一区二区在线观看| 亚洲经典在线| 加勒比一区二区| 91黄色免费看| 精精国产xxxx视频在线| 亚洲伊人一本大道中文字幕| 欧美精品午夜| 久久久久国产精品无码免费看| 欧美日韩人人澡狠狠躁视频| 激情小说 在线视频| 国产精品久久久久久久一区探花| 国产精品国产一区| 最好看的中文字幕| 天天做天天摸天天爽国产一区| 性xxxx视频| 国产女精品视频网站免费| 中文字幕av亚洲精品一部二部| 丰满少妇xbxb毛片日本| 色综合天天在线| 午夜免费视频在线国产| 成人欧美一区二区三区视频xxx| 国产麻豆综合| 99成人在线观看| 亚洲第一区在线| 久久久人成影片一区二区三区在哪下载| 在线不卡视频一区二区| 成人中文字幕合集| 久久人人爽人人爽人人片av免费| 久久伊人免费视频| 日韩高清一级| 国产aⅴ爽av久久久久| 亚洲成人7777| 午夜激情在线观看| 国产伦精品一区二区三区高清| 日韩黄色免费网站| 激情视频在线播放| 国产一区二区激情| 北条麻妃一区二区三区在线| 一级黄色香蕉视频| 午夜久久久影院| 久操视频在线免费播放| 久久www免费人成精品|