Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Startup Init Lite
提交
ca44671a
S
Startup Init Lite
项目概览
OpenHarmony
/
Startup Init Lite
1 年多 前同步成功
通知
3
Star
37
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
S
Startup Init Lite
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
ca44671a
编写于
6月 27, 2022
作者:
O
openharmony_ci
提交者:
Gitee
6月 27, 2022
浏览文件
操作
浏览文件
下载
差异文件
!863 optimize bootstage hookmgr with name
Merge pull request !863 from handy/062715
上级
55a59a6f
58b4dd3c
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
30 addition
and
13 deletion
+30
-13
interfaces/innerkits/init_module_engine/include/bootstage.h
interfaces/innerkits/init_module_engine/include/bootstage.h
+8
-6
services/init/standard/init.c
services/init/standard/init.c
+21
-6
services/init/standard/init_cmds.c
services/init/standard/init_cmds.c
+1
-1
未找到文件。
interfaces/innerkits/init_module_engine/include/bootstage.h
浏览文件 @
ca44671a
...
...
@@ -33,34 +33,36 @@ enum INIT_BOOTSTAGE {
INIT_POST_CFG_LOAD
=
50
};
HOOK_MGR
*
GetBootStageHookMgr
();
inline
int
InitAddGlobalInitHook
(
int
prio
,
OhosHook
hook
)
{
return
HookMgrAdd
(
NULL
,
INIT_GLOBAL_INIT
,
prio
,
hook
);
return
HookMgrAdd
(
GetBootStageHookMgr
()
,
INIT_GLOBAL_INIT
,
prio
,
hook
);
}
inline
int
InitAddPreParamServiceHook
(
int
prio
,
OhosHook
hook
)
{
return
HookMgrAdd
(
NULL
,
INIT_PRE_PARAM_SERVICE
,
prio
,
hook
);
return
HookMgrAdd
(
GetBootStageHookMgr
()
,
INIT_PRE_PARAM_SERVICE
,
prio
,
hook
);
}
inline
int
InitAddPreParamLoadHook
(
int
prio
,
OhosHook
hook
)
{
return
HookMgrAdd
(
NULL
,
INIT_PRE_PARAM_LOAD
,
prio
,
hook
);
return
HookMgrAdd
(
GetBootStageHookMgr
()
,
INIT_PRE_PARAM_LOAD
,
prio
,
hook
);
}
inline
int
InitAddPreCfgLoadHook
(
int
prio
,
OhosHook
hook
)
{
return
HookMgrAdd
(
NULL
,
INIT_PRE_CFG_LOAD
,
prio
,
hook
);
return
HookMgrAdd
(
GetBootStageHookMgr
()
,
INIT_PRE_CFG_LOAD
,
prio
,
hook
);
}
inline
int
InitAddPostCfgLoadHook
(
int
prio
,
OhosHook
hook
)
{
return
HookMgrAdd
(
NULL
,
INIT_POST_CFG_LOAD
,
prio
,
hook
);
return
HookMgrAdd
(
GetBootStageHookMgr
()
,
INIT_POST_CFG_LOAD
,
prio
,
hook
);
}
inline
int
InitAddPostPersistParamLoadHook
(
int
prio
,
OhosHook
hook
)
{
return
HookMgrAdd
(
NULL
,
INIT_POST_PERSIST_PARAM_LOAD
,
prio
,
hook
);
return
HookMgrAdd
(
GetBootStageHookMgr
()
,
INIT_POST_PERSIST_PARAM_LOAD
,
prio
,
hook
);
}
#ifdef __cplusplus
#if __cplusplus
...
...
services/init/standard/init.c
浏览文件 @
ca44671a
...
...
@@ -249,6 +249,14 @@ void SystemLoadSelinux(void)
#endif // WITH_SELINUX
}
#define INIT_BOOTSTAGE_HOOK_NAME "bootstage"
static
HOOK_MGR
*
bootStageHookMgr
=
NULL
;
HOOK_MGR
*
GetBootStageHookMgr
()
{
return
bootStageHookMgr
;
}
static
void
BootStateChange
(
const
char
*
content
)
{
INIT_LOGI
(
"boot start %s finish."
,
content
);
...
...
@@ -259,7 +267,8 @@ static void BootStateChange(const char *content)
if
(
strcmp
(
"post-init"
,
content
)
==
0
)
{
StartAllServices
(
START_MODE_NARMAL
);
// Destroy all hooks
HookMgrDestroy
(
NULL
);
HookMgrDestroy
(
bootStageHookMgr
);
bootStageHookMgr
=
NULL
;
return
;
}
}
...
...
@@ -350,10 +359,16 @@ void SystemConfig(void)
options
.
preHook
=
InitPreHook
;
options
.
postHook
=
InitPostHook
;
HookMgrExecute
(
NULL
,
INIT_GLOBAL_INIT
,
(
void
*
)
&
timingStat
,
(
void
*
)
&
options
);
/*
* Create bootstage hook manager for booting only.
* When boot completed, this manager will be destroyed.
*/
bootStageHookMgr
=
HookMgrCreate
(
INIT_BOOTSTAGE_HOOK_NAME
);
HookMgrExecute
(
GetBootStageHookMgr
(),
INIT_GLOBAL_INIT
,
(
void
*
)
&
timingStat
,
(
void
*
)
&
options
);
InitServiceSpace
();
HookMgrExecute
(
NULL
,
INIT_PRE_PARAM_SERVICE
,
(
void
*
)
&
timingStat
,
(
void
*
)
&
options
);
HookMgrExecute
(
GetBootStageHookMgr
()
,
INIT_PRE_PARAM_SERVICE
,
(
void
*
)
&
timingStat
,
(
void
*
)
&
options
);
InitParamService
();
InitParseGroupCfg
();
RegisterBootStateChange
(
BootStateChange
);
...
...
@@ -362,13 +377,13 @@ void SystemConfig(void)
// Do not move position!
SystemLoadSelinux
();
// parse parameters
HookMgrExecute
(
NULL
,
INIT_PRE_PARAM_LOAD
,
(
void
*
)
&
timingStat
,
(
void
*
)
&
options
);
HookMgrExecute
(
GetBootStageHookMgr
()
,
INIT_PRE_PARAM_LOAD
,
(
void
*
)
&
timingStat
,
(
void
*
)
&
options
);
InitLoadParamFiles
();
// read config
HookMgrExecute
(
NULL
,
INIT_PRE_CFG_LOAD
,
(
void
*
)
&
timingStat
,
(
void
*
)
&
options
);
HookMgrExecute
(
GetBootStageHookMgr
()
,
INIT_PRE_CFG_LOAD
,
(
void
*
)
&
timingStat
,
(
void
*
)
&
options
);
ReadConfig
();
INIT_LOGI
(
"Parse init config file done."
);
HookMgrExecute
(
NULL
,
INIT_POST_CFG_LOAD
,
(
void
*
)
&
timingStat
,
(
void
*
)
&
options
);
HookMgrExecute
(
GetBootStageHookMgr
()
,
INIT_POST_CFG_LOAD
,
(
void
*
)
&
timingStat
,
(
void
*
)
&
options
);
// dump config
#if defined(OHOS_SERVICE_DUMP)
...
...
services/init/standard/init_cmds.c
浏览文件 @
ca44671a
...
...
@@ -175,7 +175,7 @@ static void DoLoadPersistParams(const struct CmdArgs *ctx)
{
INIT_LOGV
(
"LoadPersistParams"
);
LoadPersistParams
();
HookMgrExecute
(
NULL
,
INIT_POST_PERSIST_PARAM_LOAD
,
NULL
,
NULL
);
HookMgrExecute
(
GetBootStageHookMgr
()
,
INIT_POST_PERSIST_PARAM_LOAD
,
NULL
,
NULL
);
}
static
void
DoTriggerCmd
(
const
struct
CmdArgs
*
ctx
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录