Merge "Add getExportedNamespace NB callback"

This commit is contained in:
Treehugger Robot 2019-02-04 17:27:37 +00:00 committed by Gerrit Code Review
commit 3e4b2ec29d
4 changed files with 30 additions and 7 deletions

View File

@ -164,8 +164,9 @@ bool NativeBridgeLinkNamespaces(struct native_bridge_namespace_t* from,
void* NativeBridgeLoadLibraryExt(const char* libpath, int flag,
struct native_bridge_namespace_t* ns);
// Returns vendor namespace if it is enabled for the device and null otherwise
struct native_bridge_namespace_t* NativeBridgeGetVendorNamespace();
// Returns exported namespace by the name. This is a reflection of
// android_get_exported_namespace function. Introduced in v5.
struct native_bridge_namespace_t* NativeBridgeGetExportedNamespace(const char* name);
// Native bridge interfaces to runtime.
struct NativeBridgeCallbacks {
@ -362,7 +363,17 @@ struct NativeBridgeCallbacks {
//
// Returns:
// vendor namespace or null if it was not set up for the device
//
// Starting with v5 (Android Q) this function is no longer used.
// Use getExportedNamespace() below.
struct native_bridge_namespace_t* (*getVendorNamespace)();
// Get native bridge version of exported namespace. Peer of
// android_get_exported_namespace(const char*) function.
//
// Returns:
// exported namespace or null if it was not set up for the device
struct native_bridge_namespace_t* (*getExportedNamespace)(const char* name);
};
// Runtime interfaces to native bridge.

View File

@ -24,7 +24,7 @@ LIBNATIVEBRIDGE_1 {
NativeBridgeGetError;
NativeBridgeIsPathSupported;
NativeBridgeCreateNamespace;
NativeBridgeGetVendorNamespace;
NativeBridgeGetExportedNamespace;
NativeBridgeLinkNamespaces;
NativeBridgeLoadLibraryExt;
NativeBridgeInitAnonymousNamespace;

View File

@ -101,6 +101,8 @@ enum NativeBridgeImplementationVersion {
NAMESPACE_VERSION = 3,
// The version with vendor namespaces
VENDOR_NAMESPACE_VERSION = 4,
// The version with runtime namespaces
RUNTIME_NAMESPACE_VERSION = 5,
};
// Whether we had an error at some point.
@ -610,12 +612,22 @@ bool NativeBridgeLinkNamespaces(native_bridge_namespace_t* from, native_bridge_n
return false;
}
native_bridge_namespace_t* NativeBridgeGetVendorNamespace() {
if (!NativeBridgeInitialized() || !isCompatibleWith(VENDOR_NAMESPACE_VERSION)) {
native_bridge_namespace_t* NativeBridgeGetExportedNamespace(const char* name) {
if (!NativeBridgeInitialized()) {
return nullptr;
}
return callbacks->getVendorNamespace();
if (isCompatibleWith(RUNTIME_NAMESPACE_VERSION)) {
return callbacks->getExportedNamespace(name);
}
// sphal is vendor namespace name -> use v4 callback in the case NB callbacks
// are not compatible with v5
if (isCompatibleWith(VENDOR_NAMESPACE_VERSION) && name != nullptr && strcmp("sphal", name) == 0) {
return callbacks->getVendorNamespace();
}
return nullptr;
}
void* NativeBridgeLoadLibraryExt(const char* libpath, int flag, native_bridge_namespace_t* ns) {

View File

@ -300,7 +300,7 @@ class LibraryNamespaces {
return nullptr;
}
native_bridge_namespace_t* vendor_ns = NativeBridgeGetVendorNamespace();
native_bridge_namespace_t* vendor_ns = NativeBridgeGetExportedNamespace(kVendorNamespaceName);
if (!NativeBridgeLinkNamespaces(ns, nullptr, system_exposed_libraries.c_str())) {
*error_msg = NativeBridgeGetError();