Merge "Search for subhal .so files in additional directories" into rvc-dev am: 358db3b106
Change-Id: I9394c88b9c8fed821dc8640af75567f0ef20825a
This commit is contained in:
commit
08da8ed673
2 changed files with 30 additions and 1 deletions
|
@ -426,7 +426,7 @@ void HalProxy::initializeSubHalListFromConfigFile(const char* configFileName) {
|
|||
} else {
|
||||
std::string subHalLibraryFile;
|
||||
while (subHalConfigStream >> subHalLibraryFile) {
|
||||
void* handle = dlopen(subHalLibraryFile.c_str(), RTLD_NOW);
|
||||
void* handle = getHandleForSubHalSharedObject(subHalLibraryFile);
|
||||
if (handle == nullptr) {
|
||||
ALOGE("dlopen failed for library: %s", subHalLibraryFile.c_str());
|
||||
} else {
|
||||
|
@ -491,6 +491,25 @@ void HalProxy::initializeSensorList() {
|
|||
}
|
||||
}
|
||||
|
||||
void* HalProxy::getHandleForSubHalSharedObject(const std::string& filename) {
|
||||
static const std::string kSubHalShareObjectLocations[] = {
|
||||
"", // Default locations will be searched
|
||||
#ifdef __LP64__
|
||||
"/vendor/lib64/hw/", "/odm/lib64/hw/"
|
||||
#else
|
||||
"/vendor/lib/hw/", "/odm/lib/hw/"
|
||||
#endif
|
||||
};
|
||||
|
||||
for (const std::string& dir : kSubHalShareObjectLocations) {
|
||||
void* handle = dlopen((dir + filename).c_str(), RTLD_NOW);
|
||||
if (handle != nullptr) {
|
||||
return handle;
|
||||
}
|
||||
}
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
void HalProxy::init() {
|
||||
initializeSensorList();
|
||||
}
|
||||
|
|
|
@ -266,6 +266,16 @@ class HalProxy : public V2_0::implementation::IScopedWakelockRefCounter,
|
|||
*/
|
||||
void initializeSensorList();
|
||||
|
||||
/**
|
||||
* Try using the default include directories as well as the directories defined in
|
||||
* kSubHalShareObjectLocations to get a handle for dlsym for a subhal.
|
||||
*
|
||||
* @param filename The file name to search for.
|
||||
*
|
||||
* @return The handle or nullptr if search failed.
|
||||
*/
|
||||
void* getHandleForSubHalSharedObject(const std::string& filename);
|
||||
|
||||
/**
|
||||
* Calls the helper methods that all ctors use.
|
||||
*/
|
||||
|
|
Loading…
Reference in a new issue