summaryrefslogtreecommitdiffstats
path: root/libvndksupport
diff options
context:
space:
mode:
authorJustin Yun <justinyun@google.com>2017-07-11 18:58:51 +0900
committerYifan Hong <elsk@google.com>2017-11-09 18:07:47 -0800
commit090b593a8d65caeafc88f0323698f8f93a986fa5 (patch)
treee15a80bb4cfc3fd5a46027fd2e8acdaa4d95f803 /libvndksupport
parenta34bd0561d40d1d4bd9c5089b62633388852abd9 (diff)
downloadsystem_core-090b593a8d65caeafc88f0323698f8f93a986fa5.tar.gz
system_core-090b593a8d65caeafc88f0323698f8f93a986fa5.tar.bz2
system_core-090b593a8d65caeafc88f0323698f8f93a986fa5.zip
Make libvndksupport look for default namespace as well.
In vendor process, libvndksupport must look for "default" namespace, instead of "sphal" namespace to open hal libraries. Bug: 63411330 Test: Boot the device. Change-Id: I26208b6f47708f83e0679fd72ca7471ade84fff9 Merged-In: I26208b6f47708f83e0679fd72ca7471ade84fff9
Diffstat (limited to 'libvndksupport')
-rw-r--r--libvndksupport/linker.c33
1 files changed, 24 insertions, 9 deletions
diff --git a/libvndksupport/linker.c b/libvndksupport/linker.c
index 703b593fa..d06cafc8e 100644
--- a/libvndksupport/linker.c
+++ b/libvndksupport/linker.c
@@ -23,23 +23,38 @@
extern struct android_namespace_t* android_get_exported_namespace(const char*);
+static const char* namespace_name = NULL;
+
+static struct android_namespace_t* get_vendor_namespace() {
+ const char* namespace_names[] = {"sphal", "default", NULL};
+ static struct android_namespace_t* vendor_namespace = NULL;
+ if (vendor_namespace == NULL) {
+ int name_idx = 0;
+ while (namespace_names[name_idx] != NULL) {
+ vendor_namespace = android_get_exported_namespace(namespace_names[name_idx]);
+ if (vendor_namespace != NULL) {
+ namespace_name = namespace_names[name_idx];
+ break;
+ }
+ name_idx++;
+ }
+ }
+ return vendor_namespace;
+}
+
void* android_load_sphal_library(const char* name, int flag) {
- struct android_namespace_t* sphal_namespace = android_get_exported_namespace("sphal");
- if (sphal_namespace != NULL) {
+ struct android_namespace_t* vendor_namespace = get_vendor_namespace();
+ if (vendor_namespace != NULL) {
const android_dlextinfo dlextinfo = {
- .flags = ANDROID_DLEXT_USE_NAMESPACE, .library_namespace = sphal_namespace,
+ .flags = ANDROID_DLEXT_USE_NAMESPACE, .library_namespace = vendor_namespace,
};
void* handle = android_dlopen_ext(name, flag, &dlextinfo);
if (!handle) {
- ALOGE(
- "Could not load %s from sphal namespace: %s.",
- name, dlerror());
+ ALOGE("Could not load %s from %s namespace: %s.", name, namespace_name, dlerror());
}
return handle;
} else {
- ALOGD(
- "Loading %s from current namespace instead of sphal namespace.",
- name);
+ ALOGD("Loading %s from current namespace instead of sphal namespace.", name);
return dlopen(name, flag);
}
}