diff options
author | 2021-03-30 22:35:24 +0100 | |
---|---|---|
committer | 2021-06-09 13:33:03 +0000 | |
commit | 19d1feb0fe57963e4e0931b953aa9e61b26b72c7 (patch) | |
tree | 684944929a39a0b6fcd644db6e340bdb7c71036a /libnativebridge/native_bridge_lazy.cc | |
parent | 094b1cfc9fa9e1c02238a2352c190be1746f5622 (diff) |
Avoid internal APEX stubs in libnative{bridge,loader} and clean up
exported symbols.
The APEX stubs don't have any practical effect on the lazy loading
library wrappers. Add notes about that and update the function wrappers
to keep them in sync.
Also add tests for the lazy libraries. That necessitated some
reshuffling in libnativeloader tests to reuse the mocks.
Test: art/libnativebridge/tests/runtests.sh
Test: atest libnativebridge-lazy-tests
Test: atest libnativeloader_test libnativeloader_lazy_test
Bug: 122710865
Change-Id: I7e291f2e84d8e35731dfb1114c9b19978ff87969
Diffstat (limited to 'libnativebridge/native_bridge_lazy.cc')
-rw-r--r-- | libnativebridge/native_bridge_lazy.cc | 93 |
1 files changed, 0 insertions, 93 deletions
diff --git a/libnativebridge/native_bridge_lazy.cc b/libnativebridge/native_bridge_lazy.cc index b3f4ada9bc..dd8a8068b4 100644 --- a/libnativebridge/native_bridge_lazy.cc +++ b/libnativebridge/native_bridge_lazy.cc @@ -44,12 +44,6 @@ FuncPtr GetFuncPtr(const char* function_name) { } // namespace -bool LoadNativeBridge(const char* native_bridge_library_filename, - const struct NativeBridgeRuntimeCallbacks* runtime_callbacks) { - static auto f = GET_FUNC_PTR(LoadNativeBridge); - return f(native_bridge_library_filename, runtime_callbacks); -} - bool NeedsNativeBridge(const char* instruction_set) { static auto f = GET_FUNC_PTR(NeedsNativeBridge); return f(instruction_set); @@ -60,21 +54,6 @@ bool PreInitializeNativeBridge(const char* app_data_dir, const char* instruction return f(app_data_dir, instruction_set); } -void PreZygoteForkNativeBridge() { - static auto f = GET_FUNC_PTR(PreZygoteForkNativeBridge); - return f(); -} - -bool InitializeNativeBridge(JNIEnv* env, const char* instruction_set) { - static auto f = GET_FUNC_PTR(InitializeNativeBridge); - return f(env, instruction_set); -} - -void UnloadNativeBridge() { - static auto f = GET_FUNC_PTR(UnloadNativeBridge); - return f(); -} - bool NativeBridgeAvailable() { static auto f = GET_FUNC_PTR(NativeBridgeAvailable); return f(); @@ -85,88 +64,16 @@ bool NativeBridgeInitialized() { return f(); } -void* NativeBridgeLoadLibrary(const char* libpath, int flag) { - static auto f = GET_FUNC_PTR(NativeBridgeLoadLibrary); - return f(libpath, flag); -} - void* NativeBridgeGetTrampoline(void* handle, const char* name, const char* shorty, uint32_t len) { static auto f = GET_FUNC_PTR(NativeBridgeGetTrampoline); return f(handle, name, shorty, len); } -bool NativeBridgeIsSupported(const char* libpath) { - static auto f = GET_FUNC_PTR(NativeBridgeIsSupported); - return f(libpath); -} - -uint32_t NativeBridgeGetVersion() { - static auto f = GET_FUNC_PTR(NativeBridgeGetVersion); - return f(); -} - -NativeBridgeSignalHandlerFn NativeBridgeGetSignalHandler(int signal) { - static auto f = GET_FUNC_PTR(NativeBridgeGetSignalHandler); - return f(signal); -} - -bool NativeBridgeError() { - static auto f = GET_FUNC_PTR(NativeBridgeError); - return f(); -} - -bool NativeBridgeNameAcceptable(const char* native_bridge_library_filename) { - static auto f = GET_FUNC_PTR(NativeBridgeNameAcceptable); - return f(native_bridge_library_filename); -} - -int NativeBridgeUnloadLibrary(void* handle) { - static auto f = GET_FUNC_PTR(NativeBridgeUnloadLibrary); - return f(handle); -} - const char* NativeBridgeGetError() { static auto f = GET_FUNC_PTR(NativeBridgeGetError); return f(); } -bool NativeBridgeIsPathSupported(const char* path) { - static auto f = GET_FUNC_PTR(NativeBridgeIsPathSupported); - return f(path); -} - -bool NativeBridgeInitAnonymousNamespace(const char* public_ns_sonames, - const char* anon_ns_library_path) { - static auto f = GET_FUNC_PTR(NativeBridgeInitAnonymousNamespace); - return f(public_ns_sonames, anon_ns_library_path); -} - -struct native_bridge_namespace_t* NativeBridgeCreateNamespace( - const char* name, const char* ld_library_path, const char* default_library_path, uint64_t type, - const char* permitted_when_isolated_path, struct native_bridge_namespace_t* parent_ns) { - static auto f = GET_FUNC_PTR(NativeBridgeCreateNamespace); - return f(name, ld_library_path, default_library_path, type, permitted_when_isolated_path, - parent_ns); -} - -bool NativeBridgeLinkNamespaces(struct native_bridge_namespace_t* from, - struct native_bridge_namespace_t* to, - const char* shared_libs_sonames) { - static auto f = GET_FUNC_PTR(NativeBridgeLinkNamespaces); - return f(from, to, shared_libs_sonames); -} - -void* NativeBridgeLoadLibraryExt(const char* libpath, int flag, - struct native_bridge_namespace_t* ns) { - static auto f = GET_FUNC_PTR(NativeBridgeLoadLibraryExt); - return f(libpath, flag, ns); -} - -struct native_bridge_namespace_t* NativeBridgeGetVendorNamespace() { - static auto f = GET_FUNC_PTR(NativeBridgeGetVendorNamespace); - return f(); -} - #undef GET_FUNC_PTR } // namespace android |