Merge changes from topic "libvndksupport_cp"

* changes:
  Make libvndksupport look for default namespace as well.
  libvndksupport: Change log level and message.
This commit is contained in:
Treehugger Robot 2017-11-10 03:23:02 +00:00 committed by Gerrit Code Review
commit c021b75cfd
1 changed files with 24 additions and 10 deletions

View File

@ -23,24 +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 {
ALOGI(
"sphal namespace is not configured for this process. "
"Loading %s from the current namespace instead.",
name);
ALOGD("Loading %s from current namespace instead of sphal namespace.", name);
return dlopen(name, flag);
}
}