Search for subhal .so files in additional directories am: b42bde95cb

Change-Id: I1fb0ce977406e07a26278a2be0e2380ee7d677f4
This commit is contained in:
Stan Rokita
2020-05-06 23:00:18 +00:00
committed by Automerger Merge Worker
2 changed files with 30 additions and 1 deletions

View File

@@ -360,7 +360,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 {
@@ -415,6 +415,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/", "/odm/lib64/hw/"
#else
"/vendor/lib/hw/", "/odm/lib/", "/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() {
initializeSubHalCallbacks();
initializeSensorList();

View File

@@ -261,6 +261,16 @@ class HalProxy : public ISensors, public 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.
*/