8dba7fefb0
When libbase is built for an APEX, it uses dlsym to reflectively access
liblog symbols that are added in R. This is because the APEX where
libbasse is packaged into might be running in pre-R devices where the
symbols don't exist in liblog.so.
This however causes a problem for a static executable in an APEX. Since
it is in an APEX, the dlsym is used. But libdl.so which provides dlsym
is not available to static executable. Currently, the dynamic linker is
the only executable in an APEX that all of its dependencies are
statically linked. Fixing the issue by providing fake dlsym by
statically linking to libdl.a.
Exempt-From-Owner-Approval: cherry-pick rvc-dev
Bug: 149569129
Test: m
Merged-In: I2e9e45d9876c2d6c878e541715389e6d1ef56996
(cherry picked from commit ec829ed4ea
)
Change-Id: I2e9e45d9876c2d6c878e541715389e6d1ef56996
249 lines
6.2 KiB
Text
249 lines
6.2 KiB
Text
//
|
|
// libdl
|
|
//
|
|
cc_library_static {
|
|
name: "libdl_static",
|
|
defaults: ["linux_bionic_supported"],
|
|
ramdisk_available: true,
|
|
recovery_available: true,
|
|
native_bridge_supported: true,
|
|
|
|
srcs: [
|
|
"libdl.cpp",
|
|
"libdl_cfi.cpp",
|
|
],
|
|
|
|
cflags: [
|
|
"-Wall",
|
|
"-Wextra",
|
|
"-Wunused",
|
|
"-Werror",
|
|
],
|
|
|
|
// For private/CFIShadow.h.
|
|
include_dirs: ["bionic/libc"],
|
|
|
|
stl: "none",
|
|
system_shared_libs: [],
|
|
|
|
sanitize: {
|
|
never: true,
|
|
},
|
|
|
|
apex_available: [
|
|
"//apex_available:platform",
|
|
"com.android.runtime",
|
|
],
|
|
}
|
|
|
|
cc_library {
|
|
name: "libdl",
|
|
ramdisk_available: true,
|
|
recovery_available: true,
|
|
native_bridge_supported: true,
|
|
static_ndk_lib: true,
|
|
|
|
defaults: ["linux_bionic_supported"],
|
|
|
|
// NOTE: --exclude-libs=libgcc.a makes sure that any symbols libdl.so pulls from
|
|
// libgcc.a are made static to libdl.so. This in turn ensures that libraries that
|
|
// a) pull symbols from libgcc.a and b) depend on libdl.so will not rely on libdl.so
|
|
// to provide those symbols, but will instead pull them from libgcc.a. Specifically,
|
|
// we use this property to make sure libc.so has its own copy of the code from
|
|
// libgcc.a it uses.
|
|
//
|
|
// DO NOT REMOVE --exclude-libs!
|
|
|
|
ldflags: [
|
|
"-Wl,--exclude-libs=libgcc.a",
|
|
"-Wl,--exclude-libs=libgcc_stripped.a",
|
|
"-Wl,--exclude-libs=libclang_rt.builtins-arm-android.a",
|
|
"-Wl,--exclude-libs=libclang_rt.builtins-aarch64-android.a",
|
|
"-Wl,--exclude-libs=libclang_rt.builtins-x86-android.a",
|
|
"-Wl,--exclude-libs=libclang_rt.builtins-x86_64-android.a",
|
|
],
|
|
|
|
// for x86, exclude libgcc_eh.a for the same reasons as above
|
|
arch: {
|
|
arm: {
|
|
version_script: ":libdl.arm.map",
|
|
pack_relocations: false,
|
|
ldflags: ["-Wl,--hash-style=both"],
|
|
},
|
|
arm64: {
|
|
version_script: ":libdl.arm64.map",
|
|
},
|
|
x86: {
|
|
pack_relocations: false,
|
|
ldflags: [
|
|
"-Wl,--exclude-libs=libgcc_eh.a",
|
|
"-Wl,--hash-style=both",
|
|
],
|
|
version_script: ":libdl.x86.map",
|
|
},
|
|
x86_64: {
|
|
ldflags: ["-Wl,--exclude-libs=libgcc_eh.a"],
|
|
version_script: ":libdl.x86_64.map",
|
|
},
|
|
},
|
|
shared: {
|
|
whole_static_libs: ["libdl_static"],
|
|
},
|
|
static: {
|
|
srcs: ["libdl_static.cpp"],
|
|
},
|
|
cflags: [
|
|
"-Wall",
|
|
"-Wextra",
|
|
"-Wunused",
|
|
"-Werror",
|
|
],
|
|
stl: "none",
|
|
|
|
nocrt: true,
|
|
system_shared_libs: [],
|
|
|
|
// Opt out of native_coverage when opting out of system_shared_libs
|
|
native_coverage: false,
|
|
|
|
// This is placeholder library the actual implementation is (currently)
|
|
// provided by the linker.
|
|
shared_libs: ["ld-android"],
|
|
|
|
sanitize: {
|
|
never: true,
|
|
},
|
|
|
|
stubs: {
|
|
symbol_file: "libdl.map.txt",
|
|
versions: [
|
|
"29",
|
|
"10000",
|
|
],
|
|
},
|
|
|
|
apex_available: [
|
|
"//apex_available:platform",
|
|
"com.android.runtime",
|
|
],
|
|
}
|
|
|
|
cc_library {
|
|
name: "libdl_android",
|
|
|
|
defaults: ["linux_bionic_supported"],
|
|
ramdisk_available: true,
|
|
recovery_available: true,
|
|
native_bridge_supported: true,
|
|
|
|
// NOTE: --exclude-libs=libgcc.a makes sure that any symbols libdl.so pulls from
|
|
// libgcc.a are made static to libdl.so. This in turn ensures that libraries that
|
|
// a) pull symbols from libgcc.a and b) depend on libdl.so will not rely on libdl.so
|
|
// to provide those symbols, but will instead pull them from libgcc.a. Specifically,
|
|
// we use this property to make sure libc.so has its own copy of the code from
|
|
// libgcc.a it uses.
|
|
//
|
|
// DO NOT REMOVE --exclude-libs!
|
|
|
|
ldflags: [
|
|
"-Wl,--exclude-libs=libgcc.a",
|
|
"-Wl,--exclude-libs=libgcc_stripped.a",
|
|
"-Wl,--exclude-libs=libclang_rt.builtins-arm-android.a",
|
|
"-Wl,--exclude-libs=libclang_rt.builtins-aarch64-android.a",
|
|
"-Wl,--exclude-libs=libclang_rt.builtins-x86-android.a",
|
|
"-Wl,--exclude-libs=libclang_rt.builtins-x86_64-android.a",
|
|
],
|
|
|
|
// for x86, exclude libgcc_eh.a for the same reasons as above
|
|
arch: {
|
|
x86: {
|
|
ldflags: [
|
|
"-Wl,--exclude-libs=libgcc_eh.a",
|
|
],
|
|
},
|
|
x86_64: {
|
|
ldflags: ["-Wl,--exclude-libs=libgcc_eh.a"],
|
|
},
|
|
},
|
|
|
|
srcs: [ "libdl_android.cpp" ],
|
|
version_script: "libdl_android.map.txt",
|
|
|
|
cflags: [
|
|
"-Wall",
|
|
"-Wextra",
|
|
"-Wunused",
|
|
"-Werror",
|
|
],
|
|
|
|
stl: "none",
|
|
|
|
nocrt: true,
|
|
system_shared_libs: [],
|
|
|
|
// Opt out of native_coverage when opting out of system_shared_libs
|
|
native_coverage: false,
|
|
|
|
// This is placeholder library the actual implementation is (currently)
|
|
// provided by the linker.
|
|
shared_libs: ["ld-android"],
|
|
|
|
sanitize: {
|
|
never: true,
|
|
},
|
|
|
|
stubs: {
|
|
symbol_file: "libdl_android.map.txt",
|
|
versions: ["10000"],
|
|
},
|
|
|
|
apex_available: [
|
|
"//apex_available:platform",
|
|
"com.android.runtime",
|
|
],
|
|
}
|
|
|
|
ndk_library {
|
|
name: "libdl",
|
|
native_bridge_supported: true,
|
|
symbol_file: "libdl.map.txt",
|
|
first_version: "9",
|
|
}
|
|
|
|
llndk_library {
|
|
name: "libdl",
|
|
native_bridge_supported: true,
|
|
symbol_file: "libdl.map.txt",
|
|
}
|
|
|
|
genrule {
|
|
name: "libdl.arm.map",
|
|
out: ["libdl.arm.map"],
|
|
srcs: ["libdl.map.txt"],
|
|
tool_files: [":bionic-generate-version-script"],
|
|
cmd: "$(location :bionic-generate-version-script) arm $(in) $(out)",
|
|
}
|
|
|
|
genrule {
|
|
name: "libdl.arm64.map",
|
|
out: ["libdl.arm64.map"],
|
|
srcs: ["libdl.map.txt"],
|
|
tool_files: [":bionic-generate-version-script"],
|
|
cmd: "$(location :bionic-generate-version-script) arm64 $(in) $(out)",
|
|
}
|
|
|
|
genrule {
|
|
name: "libdl.x86.map",
|
|
out: ["libdl.x86.map"],
|
|
srcs: ["libdl.map.txt"],
|
|
tool_files: [":bionic-generate-version-script"],
|
|
cmd: "$(location :bionic-generate-version-script) x86 $(in) $(out)",
|
|
}
|
|
|
|
genrule {
|
|
name: "libdl.x86_64.map",
|
|
out: ["libdl.x86_64.map"],
|
|
srcs: ["libdl.map.txt"],
|
|
tool_files: [":bionic-generate-version-script"],
|
|
cmd: "$(location :bionic-generate-version-script) x86_64 $(in) $(out)",
|
|
}
|