成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

OHOS標準系統的SAMGR代碼解讀(v3.1)--2--Samgr

系統 OpenHarmony
OHOS標準系統的samgr組件位于3.1分支代碼的//foundation/distributedschedule/samgr/目錄下,在最新的master分支代碼則是//foundation/systemabilitymgr/samgr/目錄下。

??想了解更多關于開源的內容,請訪問:??

??51CTO 開源基礎軟件社區??

??https://ost.51cto.com??

OHOS標準系統的samgr組件位于3.1分支代碼的//foundation/distributedschedule/samgr/目錄下,在最新的master分支代碼則是//foundation/systemabilitymgr/samgr/目錄下。

1、samgr 組件的全景圖

先看samgr組件的全景圖(附件有大圖)。

OHOS標準系統的SAMGR代碼解讀(v3.1)--2--samgr-開源基礎軟件社區

從上圖中的代碼目錄結構和編譯腳本部分,可以看到5個編譯目標以及它們各自編譯的代碼:

  • samgr_common:公共部分,提供SA Profile的解析工具、動態鏈接庫的加載和卸載等功能,主要用在上一篇分析的safwk的工作流程中,本文不再贅述。
  • lsamgr:local samgr的客戶端代理,主要用于按需啟動指定的SA;該功能也同時編譯進samgr_proxy模塊中(一并在samgr_proxy中分析)。
  • samgr_proxy:samgr的客戶端代理。SA通過該代理提供的接口與samgr服務進行交互,同時也為samgr服務向SA客戶端反饋SA的加載結果、訂閱的SA的狀態變化等功能提供Stub接口。
  • samgr_init:samgr服務自啟動的配置文件,與samgr可執行程序配套使用。
  • samgr:samgr服務的可執行程序實體,結合samgr_init的配置,在系統啟動的早期自動運行,拉起samgr服務。同時也通過Proxy向SA客戶端反饋SA的加載結果、訂閱的SA的狀態變化事件等消息。

全景圖中雖然畫出了IPC相關的結構,但本文暫不深入IPC/RPC的分析,因此,下文重點看samgr服務的實現和samgr_proxy客戶端的實現。

2、samgr 服務的啟動流程

samgr服務在OHOS系統中幾乎是最早啟動的系統服務,它在OHOS中占據了通信中樞的重要位置(可以參考我分析的samgr_lite系列文章來進行理解)。

samgr服務的啟動流程如全景圖左下角部分所示,看起來還是比較簡單的。

在完成 SystemAbilityManager 類對象manager的創建和Init()之后,就生成了全景圖右下角部分所示的結構;然后通過IPCSkeleton::SetContextObject()將 manager 作為遠程對象注冊到IPC模塊,為以后的IPC/RPC提供IRemoteObject;最后samgr服務的主線程進入loop,開始為整個系統中的SA提供服務。

接下來的內容,請結合samgr組件的全景圖和下面的IPC交互示意圖進行理解。

OHOS標準系統的SAMGR代碼解讀(v3.1)--2--samgr-開源基礎軟件社區

3、samgr 服務端的類結構

samgr 服務端主要的類結構和繼承關系,見全景圖的右下角以ohos_executable(“samgr”)為起點的部分。

(1)SA死亡回調相關的成員和RPC回調相關的成員

在 SystemAbilityManager::Init() 中創建并初始化的與SA死亡回調相關的成員、RPC回調相關的成員,這里先放下不說,請小伙伴先自行閱讀代碼理解。

(2)SystemAbilityLoadCallbackProxy 和 SystemAbilityStatusChangeProxy

在 SystemAbilityManager 類提供的服務中,samgr會根據需要調用相關的接口向samgr_proxy發送IPC消息,以此向Proxy反饋SA的加載狀態、上線離線狀態等信息,見4.2節的簡介。

(3)SystemAbilityManagerStub 和 SystemAbilityManager

samgr服務端的主要工作在這兩個類中。

在samgr進程啟動過程中創建SystemAbilityManager對象時,在SystemAbilityManagerStub的構造函數中就會初始化一個 memberFuncMap_,將Stub要處理的消息代碼與處理函數關聯起來。

SystemAbilityManagerStub在接收到SystemAbilityManagerProxy發過來的IPC消息后,直接在memberFuncMap_中匹配消息代碼,然后轉為調用子類SystemAbilityManager的函數來做具體的服務工作,如有需要也會把處理結果返回給SystemAbilityManagerProxy。

3.1和3.2中的工作,也是由SystemAbilityManager類發起調用或者直接進行處理的。

4、samgr_proxy的類結構

samgr_proxy相關的類結構和繼承關系,見全景圖的中以ohos_shared_library(“samgr_proxy”)為起點的部分。

(1)LocalAbilityManagerProxy

LocalAbilityManagerProxy類提供了向指定進程發送IPC消息拉起按需啟動的SA的Proxy接口,由指定進程中的LocalAbilityManagerStub接收消息,并執行動態拉起SA的具體動作(如上一篇分析4.3節分析所示)。

例如,不管是同設備內的進程還是跨設備的進程,在調用:

sptr<IRemoteObject> SystemAbilityManager::CheckSystemAbility(int32_t systemAbilityId, bool& isExist)

向samgr查詢SA時,samgr會先在已啟動的 abilityMap_ 中查找目標SA,能找到,則表明SA已經啟動了;找不到,則繼續在正在啟動的 startingAbilityMap_ 中查找目標SA,能找到,則表明SA正在啟動中;還找不到,則會嘗試調用StartOnDemandAbility(SAID)來啟動目標SA(即按需啟動SA)。StartOnDemandAbility(SAID)會在登記到onDemandAbilityMap_中的按需啟動的SA列表中查找匹配SAID的記錄,并通過SystemAbilityManager::StartOnDemandAbilityInner()向SAID所在進程發送IPC消息,要求該進程拉起對應的SA,如下代碼片段所示:

void SystemAbilityManager::StartOnDemandAbilityInner(const std::u16string& procName, int32_t systemAbilityId,
AbilityItem& abilityItem)
{
......
//從 systemProcessMap_ 中獲取 LocalAbilityManagerProxy procObject
sptr<ILocalAbilityManager> procObject =
iface_cast<ILocalAbilityManager>(GetSystemProcess(procName));
......
//調用 LocalAbilityManagerProxy::StartAbility
//向 LocalAbilityManagerStub 發送IPC消息拉起參數指定的SA
procObject->StartAbility(systemAbilityId);
......
}

(2)SystemAbilityLoadCallbackStub 和 SystemAbilityStatusChangeStub

當進程A向samgr注冊SA_a時,samgr會調用:

void SystemAbilityManager::SendSystemAbilityAddedMsg(int32_t systemAbilityId, const sptr<IRemoteObject>& remoteObject)
{
......
auto notifyAddedTask = [systemAbilityId, remoteObject, this]() {
FindSystemAbilityNotify(systemAbilityId, ADD_SYSTEM_ABILITY_TRANSACTION);
NotifySystemAbilityLoaded(systemAbilityId, remoteObject);
};
bool ret = workHandler_->PostTask(notifyAddedTask);
......
}

其中的FindSystemAbilityNotify()會在 listenerMap_ 中查找監聽SA_a狀態變化的監聽者,并調用listener的回調函數,通過SystemAbilityStatusChangeProxy向SystemAbilityStatusChangeStub發送SA_a上線或離線的消息。listener所在的進程B、進程C…的SystemAbilityStatusChangeStub就可以收到該消息并做針對性地處理。

其中的NotifySystemAbilityLoaded()也會通過SystemAbilityLoadCallbackProxy向SystemAbilityLoadCallbackStub 發送SA_a加載成功的IPC消息到查詢SA_a的進程B中,這樣進程B中的SystemAbilityLoadCallbackStub 就可以收到該消息并做針對性地處理。

(3)SystemAbilityManagerProxy和 SystemAbilityManagerClient

進程A必須要通過代理才能與samgr進行交互(如注冊SA、查詢SA等)。

如進程A在啟動SA_a時,必須要先通過CheckSystemAbilityManagerReady() 確認samgr可以訪問:

bool LocalAbilityManager::CheckSystemAbilityManagerReady()
{
......
//獲取samgr的代理:SystemAbilityManagerProxy
sptr<ISystemAbilityManager> samgrProxy = SystemAbilityManagerClient::GetInstance().GetSystemAbilityManager();
while (samgrProxy == nullptr) {
HILOGI(TAG, "waiting for SAMGR...get 'samgrProxy'...");
if (timeout > 0) {
usleep(duration);
samgrProxy = SystemAbilityManagerClient::GetInstance().GetSystemAbilityManager();
} else {
HILOGE(TAG, "waiting for SAMGR...timeout[10s]...NGNGNG");
return false;
}
timeout--;
}
......
return true;
}

即能夠成功獲取samgr的代理SystemAbilityManagerProxy,這樣SA_a才能注冊到samgr中,否則表示samgr還沒有能夠正常工作,所有的SA_x都無法注冊,所以可以說samgr進程是最早啟動的系統服務進程了。

類似的,在系統中各個進程需要與samgr進行交互的時候,都是按下面這個流程進行的:

//先獲取samgr的代理:SystemAbilityManagerProxy
sptr<ISystemAbilityManager> samgrProxy = SystemAbilityManagerClient::GetInstance().GetSystemAbilityManager();

//再通過該代理向samgr發送IPC消息,使用samgr提供的服務
samgrProxy->XxxYyy()

5、Proxy與Stub的IPC交互

一圖勝千言,兩圖勝兩千言。

請結合前面兩張圖自行閱讀代碼進行理解。

文章相關附件可以點擊下面的原文鏈接前往下載:

https://ost.51cto.com/resource/2287。

??想了解更多關于開源的內容,請訪問:??

??51CTO 開源基礎軟件社區??

??https://ost.51cto.com??。

責任編輯:jianghua 來源: 51CTO開源基礎軟件社區?
相關推薦

2022-09-08 15:27:11

OHOSSafwk組件

2022-09-27 15:57:20

OHOS代碼倉庫

2022-06-10 14:37:24

鴻蒙操作系統

2022-04-02 20:45:04

Hi3516開發板操作系統鴻蒙

2021-06-10 09:25:39

鴻蒙HarmonyOS應用

2021-06-03 14:21:44

鴻蒙HarmonyOS應用

2021-07-08 16:16:59

鴻蒙HarmonyOS應用

2025-02-20 08:26:28

2014-06-13 19:13:50

Cocos2d-JS

2021-07-05 09:35:36

鴻蒙HarmonyOS應用

2021-11-23 15:35:05

鴻蒙HarmonyOS應用

2009-05-08 09:22:00

Python面向對象編譯

2021-09-26 10:22:41

鴻蒙HarmonyOS應用

2012-05-28 15:25:40

微瘋客棧

2015-04-22 09:41:45

WeX5

2021-06-18 10:02:10

鴻蒙HarmonyOS應用

2022-10-12 15:14:08

開機動畫鴻蒙

2021-09-16 15:04:28

鴻蒙HarmonyOS應用

2021-07-07 09:45:20

鴻蒙HarmonyOS應用

2022-09-15 14:56:12

GDB調試鴻蒙
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 91视频在线观看 | 欧美h视频 | 一本大道久久a久久精二百 国产成人免费在线 | 黑人巨大精品欧美一区二区免费 | 欧美成人a∨高清免费观看 91伊人 | 成人在线视频网 | 国产黄色网 | 国产亚洲精品久久午夜玫瑰园 | 欧美亚洲综合久久 | 亚洲 欧美 日韩在线 | 一区二区三区视频在线 | 亚洲国产欧美日韩 | 久久婷婷色 | 久久99精品久久久久久狂牛 | 岛国av在线免费观看 | 精品久久久久久久久久久 | 国产精品久久久久久久粉嫩 | 精品国产一区二区三区性色av | 亚洲资源在线 | 中文字幕亚洲欧美日韩在线不卡 | 成人福利网站 | 亚洲精品久久久久国产 | 日韩精品一区二区三区在线播放 | 国产精品欧美一区二区三区 | 中文二区 | 亚洲精品一区二区三区蜜桃久 | 国产一区二区三区在线 | 日韩av免费在线电影 | 国产一区二区自拍 | 久久蜜桃资源一区二区老牛 | 亚洲欧洲中文 | 白浆在线 | 日韩一区中文字幕 | 无码日韩精品一区二区免费 | 高清视频一区二区三区 | 国产在线视频一区 | 91亚洲国产成人久久精品网站 | 国产欧美日韩二区 | 天天色图 | 日韩福利 | 狠狠干天天干 |