| OLD | NEW | 
|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be | 
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. | 
| 4 | 4 | 
| 5 // This is the Android-specific Chromium linker, a tiny shared library | 5 // This is the Android-specific Chromium linker, a tiny shared library | 
| 6 // implementing a custom dynamic linker that can be used to load the | 6 // implementing a custom dynamic linker that can be used to load the | 
| 7 // real Chromium libraries (e.g. libcontentshell.so). | 7 // real Chromium libraries (e.g. libcontentshell.so). | 
| 8 | 8 | 
| 9 // The main point of this linker is to be able to share the RELRO | 9 // The main point of this linker is to be able to share the RELRO | 
| 10 // section of libcontentshell.so (or equivalent) between the browser and | 10 // section of libcontentshell.so (or equivalent) between the browser and | 
| 11 // renderer process. | 11 // renderer process. | 
| 12 | 12 | 
| 13 // This source code *cannot* depend on anything from base/ or the C++ | 13 // This source code *cannot* depend on anything from base/ or the C++ | 
| 14 // STL, to keep the final library small, and avoid ugly dependency issues. | 14 // STL, to keep the final library small, and avoid ugly dependency issues. | 
| 15 | 15 | 
| 16 #include <android/log.h> | 16 #include <android/log.h> | 
| 17 #include <crazy_linker.h> | 17 #include <crazy_linker.h> | 
| 18 #include <fcntl.h> | 18 #include <fcntl.h> | 
| 19 #include <jni.h> | 19 #include <jni.h> | 
| 20 #include <limits.h> | 20 #include <limits.h> | 
| 21 #include <stdlib.h> | 21 #include <stdlib.h> | 
| 22 #include <sys/mman.h> | 22 #include <sys/mman.h> | 
| 23 #include <unistd.h> | 23 #include <unistd.h> | 
| 24 | 24 | 
|  | 25 // See commentary in crazy_linker_elf_loader.cpp for the effect of setting | 
|  | 26 // this.  If changing there, change here also. | 
|  | 27 // | 
|  | 28 // For more, see: | 
|  | 29 //   https://crbug.com/504410 | 
|  | 30 #define RESERVE_BREAKPAD_GUARD_REGION 1 | 
|  | 31 | 
| 25 // Set this to 1 to enable debug traces to the Android log. | 32 // Set this to 1 to enable debug traces to the Android log. | 
| 26 // Note that LOG() from "base/logging.h" cannot be used, since it is | 33 // Note that LOG() from "base/logging.h" cannot be used, since it is | 
| 27 // in base/ which hasn't been loaded yet. | 34 // in base/ which hasn't been loaded yet. | 
| 28 #define DEBUG 0 | 35 #define DEBUG 0 | 
| 29 | 36 | 
| 30 #define TAG "chromium_android_linker" | 37 #define TAG "chromium_android_linker" | 
| 31 | 38 | 
| 32 #if DEBUG | 39 #if DEBUG | 
| 33 #define LOG_INFO(...) __android_log_print(ANDROID_LOG_INFO, TAG, __VA_ARGS__) | 40 #define LOG_INFO(...) __android_log_print(ANDROID_LOG_INFO, TAG, __VA_ARGS__) | 
| 34 #else | 41 #else | 
| (...skipping 584 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 619            lib_name.c_str()); | 626            lib_name.c_str()); | 
| 620 | 627 | 
| 621   return true; | 628   return true; | 
| 622 } | 629 } | 
| 623 | 630 | 
| 624 jboolean CanUseSharedRelro(JNIEnv* env, jclass clazz) { | 631 jboolean CanUseSharedRelro(JNIEnv* env, jclass clazz) { | 
| 625   return crazy_system_can_share_relro(); | 632   return crazy_system_can_share_relro(); | 
| 626 } | 633 } | 
| 627 | 634 | 
| 628 jlong GetRandomBaseLoadAddress(JNIEnv* env, jclass clazz, jlong bytes) { | 635 jlong GetRandomBaseLoadAddress(JNIEnv* env, jclass clazz, jlong bytes) { | 
|  | 636 #if RESERVE_BREAKPAD_GUARD_REGION | 
|  | 637   // Add a Breakpad guard region.  16Mb should be comfortably larger than | 
|  | 638   // the largest relocation packer saving we expect to encounter. | 
|  | 639   static const size_t kBreakpadGuardRegionBytes = 16 * 1024 * 1024; | 
|  | 640   bytes += kBreakpadGuardRegionBytes; | 
|  | 641 #endif | 
|  | 642 | 
| 629   void* address = | 643   void* address = | 
| 630       mmap(NULL, bytes, PROT_NONE, MAP_PRIVATE | MAP_ANONYMOUS, -1, 0); | 644       mmap(NULL, bytes, PROT_NONE, MAP_PRIVATE | MAP_ANONYMOUS, -1, 0); | 
| 631   if (address == MAP_FAILED) { | 645   if (address == MAP_FAILED) { | 
| 632     LOG_INFO("%s: Random base load address not determinable\n", __FUNCTION__); | 646     LOG_INFO("%s: Random base load address not determinable\n", __FUNCTION__); | 
| 633     return 0; | 647     return 0; | 
| 634   } | 648   } | 
| 635   munmap(address, bytes); | 649   munmap(address, bytes); | 
|  | 650 | 
|  | 651 #if RESERVE_BREAKPAD_GUARD_REGION | 
|  | 652   // Allow for a Breakpad guard region ahead of the returned address. | 
|  | 653   address = reinterpret_cast<void*>( | 
|  | 654       reinterpret_cast<uintptr_t>(address) + kBreakpadGuardRegionBytes); | 
|  | 655 #endif | 
|  | 656 | 
| 636   LOG_INFO("%s: Random base load address is %p\n", __FUNCTION__, address); | 657   LOG_INFO("%s: Random base load address is %p\n", __FUNCTION__, address); | 
| 637   return static_cast<jlong>(reinterpret_cast<uintptr_t>(address)); | 658   return static_cast<jlong>(reinterpret_cast<uintptr_t>(address)); | 
| 638 } | 659 } | 
| 639 | 660 | 
| 640 // Get the full path of a library in the zip file | 661 // Get the full path of a library in the zip file | 
| 641 // (lib/<abi>/crazy.<lib_name>). | 662 // (lib/<abi>/crazy.<lib_name>). | 
| 642 // | 663 // | 
| 643 // |env| is the current JNI environment handle. | 664 // |env| is the current JNI environment handle. | 
| 644 // |clazz| is the static class handle which is not used here. | 665 // |clazz| is the static class handle which is not used here. | 
| 645 // |lib_name| is the library base name. | 666 // |lib_name| is the library base name. | 
| (...skipping 148 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 794   crazy_context_t* context = GetCrazyContext(); | 815   crazy_context_t* context = GetCrazyContext(); | 
| 795   crazy_context_set_java_vm(context, vm, JNI_VERSION_1_4); | 816   crazy_context_set_java_vm(context, vm, JNI_VERSION_1_4); | 
| 796 | 817 | 
| 797   // Register the function that the crazy linker can call to post code | 818   // Register the function that the crazy linker can call to post code | 
| 798   // for later execution. | 819   // for later execution. | 
| 799   crazy_context_set_callback_poster(context, &PostForLaterExecution, NULL); | 820   crazy_context_set_callback_poster(context, &PostForLaterExecution, NULL); | 
| 800 | 821 | 
| 801   LOG_INFO("%s: Done", __FUNCTION__); | 822   LOG_INFO("%s: Done", __FUNCTION__); | 
| 802   return JNI_VERSION_1_4; | 823   return JNI_VERSION_1_4; | 
| 803 } | 824 } | 
| OLD | NEW | 
|---|