Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(265)

Side by Side Diff: base/android/linker/linker_jni.cc

Issue 1218493004: crazy linker: Add a Breakpad "guard region" to reserved space. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Tweak for review feedback. Created 5 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | third_party/android_crazy_linker/README.chromium » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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
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
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 }
OLDNEW
« no previous file with comments | « no previous file | third_party/android_crazy_linker/README.chromium » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698