1.【需求描述】 动态库开发部分: gcc的sample code。 提供生成暴露接口生成机制,并允许产品新增需要暴露的接口。 提供可以判断库允许资源大小的能力,并提供相关工具辅助开发者确定开发的库要求的资源是否可以满足。 动态库运行部分: 提供elf load的api,可以加载指定路径下的库,并完成符号重映射等运行准备。 提供elf 暴露符号调用的api,用于调用库的api。 elf加载&链接异常时,有明确错误记录,返回明确错误类型。 提供elf 卸载的api。 2.【方案描述】 (1) 通过灌段的形式记录需要导出符号的地址信息,用于暴露内核对外的接口,在加载链接器中通过查询 对应的符号信息获取符号地址。 (2) 加载链接时,解析共享库并将共享库中可加载段通过文件系统读入内存中,并对共享库中未定义的、 需要重定位的符号进行重定位。需要调用符号时,根据符号名通过哈希表即可查询共享库提供的对应符号 的地址。 BREAKING CHANGE: 新增4个对外接口,声明在los_dynlink.h文件中,分别为: (1) LOS_DynlinkInit: 动态加载模块初始化。 (2) LOS_SoLoad: 加载指定路径的共享库。 (3) LOS_FindSym: 根据共享库句柄查找指定符号。 (4) LOS_SoUnload: 卸载共享库。 close #I418HJ Signed-off-by: Haryslee <lihao189@huawei.com> Change-Id: I7669b7ef20096294f9d1094c85ac6602fefad354
39 lines
993 B
Plaintext
39 lines
993 B
Plaintext
# Copyright (c) Huawei Technologies Co., Ltd. 2021. All rights reserved.
|
|
|
|
static_library("test_dynlink") {
|
|
sources = [
|
|
"It_los_dynlink.c",
|
|
"It_los_dynlink_001.c",
|
|
"It_los_dynlink_002.c",
|
|
"It_los_dynlink_003.c",
|
|
"It_los_dynlink_004.c",
|
|
"It_los_dynlink_005.c",
|
|
"It_los_dynlink_006.c",
|
|
"It_los_dynlink_007.c",
|
|
"It_los_dynlink_008.c",
|
|
"It_los_dynlink_009.c",
|
|
"It_los_dynlink_010.c",
|
|
"It_los_dynlink_011.c",
|
|
"It_los_dynlink_012.c",
|
|
"It_los_dynlink_013.c",
|
|
"It_los_dynlink_014.c",
|
|
"It_los_dynlink_015.c",
|
|
"It_los_dynlink_016.c",
|
|
"It_los_dynlink_017.c",
|
|
"It_los_dynlink_018.c",
|
|
"It_los_dynlink_019.c",
|
|
"It_los_dynlink_020.c",
|
|
]
|
|
|
|
include_dirs = [
|
|
"../../../../kernel/include",
|
|
"../../../../kernel/arch/include",
|
|
"../../../include",
|
|
"../../../../utils",
|
|
"../../../../components/dynlink",
|
|
".",
|
|
"../../../../components/cpup",
|
|
"//third_party/bounds_checking_function/include",
|
|
]
|
|
}
|