aboutsummaryrefslogtreecommitdiffstats
path: root/emulator
diff options
context:
space:
mode:
authorTina Zhang <tina.zhang@intel.com>2014-07-25 10:13:53 +0800
committerVince Harron <vharron@google.com>2014-07-27 19:41:56 -0700
commit1ee821ec62d0adf1fc6132a1cf853d3af0467908 (patch)
tree2f1d08fc297d189ad081026edcd8a096c357c7c4 /emulator
parentec58e2e9626c5f4c5da339a77178d81c32fdb461 (diff)
downloadsdk-1ee821ec62d0adf1fc6132a1cf853d3af0467908.zip
sdk-1ee821ec62d0adf1fc6132a1cf853d3af0467908.tar.gz
sdk-1ee821ec62d0adf1fc6132a1cf853d3af0467908.tar.bz2
Support dynamic lib name without ".dylib" on Mac
On Mac, some of the dynamic libs has name without ".dylib". Like, "System/Library/Frameworks/OpenGL.framework/OpenGL", we need solution to handle it in the dlopen() API. Change-Id: Ie513ace5a0d7d154f73e0f13919005d1498901d7 Signed-off-by: Tina Zhang <tina.zhang@intel.com> Signed-off-by: Chao Qin <chaox.qin@intel.com>
Diffstat (limited to 'emulator')
-rw-r--r--emulator/opengl/shared/emugl/common/shared_library.cpp10
-rw-r--r--emulator/opengl/shared/emugl/common/shared_library.h13
-rw-r--r--emulator/opengl/shared/emugl/common/shared_library_unittest.cpp25
3 files changed, 44 insertions, 4 deletions
diff --git a/emulator/opengl/shared/emugl/common/shared_library.cpp b/emulator/opengl/shared/emugl/common/shared_library.cpp
index db1c75c..e78e36b 100644
--- a/emulator/opengl/shared/emugl/common/shared_library.cpp
+++ b/emulator/opengl/shared/emugl/common/shared_library.cpp
@@ -75,7 +75,17 @@ SharedLibrary* SharedLibrary::open(const char* libraryName) {
libPath = path;
}
+#ifdef __APPLE__
+ // On OSX, some libraries don't include an extension (notably OpenGL)
+ // On OSX we try to open |libraryName| first. If that doesn't exist,
+ // we try |libraryName|.dylib
+ void* lib = dlopen(libraryName, RTLD_NOW);
+ if (lib == NULL) {
+ lib = dlopen(libPath, RTLD_NOW);
+ }
+#else
void* lib = dlopen(libPath, RTLD_NOW);
+#endif
if (path) {
free(path);
diff --git a/emulator/opengl/shared/emugl/common/shared_library.h b/emulator/opengl/shared/emugl/common/shared_library.h
index 38d25bd..f1d82fc 100644
--- a/emulator/opengl/shared/emugl/common/shared_library.h
+++ b/emulator/opengl/shared/emugl/common/shared_library.h
@@ -38,9 +38,16 @@ namespace emugl {
//
class SharedLibrary {
public:
- // Open a given library. |libraryName| can be either a full library
- // path, or a simple name without an extension. On success, returns
- // a new SharedLibrary instance that must be deleted by the caller.
+ // Open a given library. If |libraryName| has no extension, a
+ // platform-appropriate extension is added and that path is opened.
+ // If the |libraryName| has an extension, that form is opened.
+ //
+ // On OSX, some libraries don't include an extension (notably OpenGL)
+ // On OSX we try to open |libraryName| first. If that doesn't exist,
+ // we try |libraryName|.dylib
+ //
+ // On success, returns a new SharedLibrary instance that must be
+ // deleted by the caller.
static SharedLibrary* open(const char* libraryName);
// Closes an existing SharedLibrary instance.
diff --git a/emulator/opengl/shared/emugl/common/shared_library_unittest.cpp b/emulator/opengl/shared/emugl/common/shared_library_unittest.cpp
index cec4c73..cb74efa 100644
--- a/emulator/opengl/shared/emugl/common/shared_library_unittest.cpp
+++ b/emulator/opengl/shared/emugl/common/shared_library_unittest.cpp
@@ -100,6 +100,11 @@ public:
SharedLibrary* operator->() { return mLib; }
+ void release() {
+ delete mLib;
+ mLib = NULL;
+ }
+
private:
SharedLibrary* mLib;
};
@@ -111,19 +116,37 @@ TEST_F(SharedLibraryTest, Open) {
EXPECT_TRUE(lib.get());
}
-TEST_F(SharedLibraryTest, OpenWithExtension) {
+TEST_F(SharedLibraryTest, OpenLibraryWithExtension) {
std::string path = library_path();
+
+ // test extension append
+ ScopedSharedLibrary libNoExtension(SharedLibrary::open(path.c_str()));
+ EXPECT_TRUE(libNoExtension.get());
+ libNoExtension.release();
+
#ifdef _WIN32
path += ".dll";
#elif defined(__APPLE__)
+ // try to open the library without an extension
+
path += ".dylib";
#else
path += ".so";
#endif
+
+ // test open with prepended extension
ScopedSharedLibrary lib(SharedLibrary::open(path.c_str()));
EXPECT_TRUE(lib.get());
}
+#ifdef __APPLE__
+TEST_F(SharedLibraryTest, OpenLibraryWithoutExtension) {
+ const char* library = "/System/Library/Frameworks/OpenGL.framework/OpenGL";
+ ScopedSharedLibrary lib(SharedLibrary::open(library));
+ EXPECT_TRUE(lib.get());
+}
+#endif
+
TEST_F(SharedLibraryTest, FindSymbol) {
ScopedSharedLibrary lib(SharedLibrary::open(library_path()));
EXPECT_TRUE(lib.get());