OSDN Git Service

Log dlopen failures caused by text relocations
authorDmitriy Ivanov <dimitry@google.com>
Tue, 13 Oct 2015 18:07:56 +0000 (11:07 -0700)
committerDmitriy Ivanov <dimitry@google.com>
Tue, 13 Oct 2015 18:13:19 +0000 (11:13 -0700)
Some apps will fail to load native libraries with
text relocations when switching target sdk version to M.
It could be hard to diagnose because some of them
suppress dlerror and/or UnsatisfiedLinkError.

This change unconditionally logs the error message making
the cause of the failure more visible to developers.

Bug: http://b/24876001
Change-Id: I0477a0d1307d0879000f3a3a43b974b4cf34bdb2

linker/linker.cpp

index faacd49..c99042f 100644 (file)
@@ -2937,6 +2937,7 @@ bool soinfo::link_image(const soinfo_list_t& global_group, const soinfo_list_t&
     // TODO (dimitry): remove != __ANDROID_API__ check once http://b/20020312 is fixed
     if (get_application_target_sdk_version() != __ANDROID_API__
         && get_application_target_sdk_version() > 22) {
+      PRINT("%s: has text relocations", get_realpath());
       DL_ERR("%s: has text relocations", get_realpath());
       return false;
     }