summaryrefslogtreecommitdiffstats
path: root/runtime/fault_handler.cc
diff options
context:
space:
mode:
authorOleksiy Vyalov <ovyalov@google.com>2015-06-14 15:17:26 -0700
committerNarayan Kamath <narayan@google.com>2015-06-17 17:04:03 +0100
commitafe9e134a773242b142b0740383f085f08ec1cba (patch)
treeba63c358e457984807cc36780fa738c364115773 /runtime/fault_handler.cc
parent61e4ec36e8f3435a63c45ad91858ecb5ce50ad72 (diff)
downloadart-afe9e134a773242b142b0740383f085f08ec1cba.zip
art-afe9e134a773242b142b0740383f085f08ec1cba.tar.gz
art-afe9e134a773242b142b0740383f085f08ec1cba.tar.bz2
Set default visibility on art_sigsegv_fault.
libart.so is built with flag -fvisibility=protected which complicates setting breakpoints on art_sigsegv_fault. According to the GCC manual "Protected visibility indicates that the symbol will be placed in the dynamic symbol table, but that references within the defining module will bind to the local symbol.". This implies that a breakpoint on a protected symbol will not be hit. Without this change gdbclient with ART debugging enabled doesn't break at art_sigsegv_fault as expected. Bonus build fix included (commit c37769b6) : Fix lint error. Blank line at the start of a code block. (cherry picked from commit f775bab533cd385c00ee30b56bdcb6f962fc5239) (cherry picked from commit c37769b63faf7b120a6ed80f5cfb92667f5090c4) bug: 21893559 Change-Id: Ie388f027f717a7bd2351a0163a38e50d3acbba8f
Diffstat (limited to 'runtime/fault_handler.cc')
-rw-r--r--runtime/fault_handler.cc4
1 files changed, 1 insertions, 3 deletions
diff --git a/runtime/fault_handler.cc b/runtime/fault_handler.cc
index 4a352dd..762f061 100644
--- a/runtime/fault_handler.cc
+++ b/runtime/fault_handler.cc
@@ -72,12 +72,10 @@ namespace art {
// Static fault manger object accessed by signal handler.
FaultManager fault_manager;
-extern "C" {
-void art_sigsegv_fault() {
+extern "C" __attribute__((visibility("default"))) void art_sigsegv_fault() {
// Set a breakpoint here to be informed when a SIGSEGV is unhandled by ART.
VLOG(signals)<< "Caught unknown SIGSEGV in ART fault handler - chaining to next handler.";
}
-}
// Signal handler called on SIGSEGV.
static void art_fault_handler(int sig, siginfo_t* info, void* context) {