hotspot/src/os/linux/vm/vmError_linux.cpp
author mgerdin
Thu, 22 Aug 2013 10:50:41 +0200
changeset 19726 c086d352d3f7
parent 13964 01a2b863cc61
child 28943 679546f0cc1f
permissions -rw-r--r--
8016155: SIGBUS when running Kitchensink with ParallelScavenge and ParallelOld Summary: When using NUMA and large pages we need to ease the requirement on which node the memory should be allocated on. To avoid the SIGBUS we now use the memory policy MPOL_PREFERRED, which prefers a certain node, instead of MPOL_BIND, which requires a certain node. Reviewed-by: jmasa, pliden Contributed-by: stefan.johansson@oracle.com
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
/*
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
     2
 * Copyright (c) 2003, 2010, Oracle and/or its affiliates. All rights reserved.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     4
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
489c9b5090e2 Initial load
duke
parents:
diff changeset
     7
 * published by the Free Software Foundation.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     8
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
489c9b5090e2 Initial load
duke
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
489c9b5090e2 Initial load
duke
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
489c9b5090e2 Initial load
duke
parents:
diff changeset
    13
 * accompanied this code).
489c9b5090e2 Initial load
duke
parents:
diff changeset
    14
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
489c9b5090e2 Initial load
duke
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    18
 *
5547
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1
diff changeset
    21
 * questions.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    22
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    23
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
    24
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    25
#include "precompiled.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    26
#include "runtime/arguments.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    27
#include "runtime/os.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    28
#include "runtime/thread.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 5547
diff changeset
    29
#include "utilities/vmError.hpp"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    30
489c9b5090e2 Initial load
duke
parents:
diff changeset
    31
#include <sys/types.h>
489c9b5090e2 Initial load
duke
parents:
diff changeset
    32
#include <sys/wait.h>
489c9b5090e2 Initial load
duke
parents:
diff changeset
    33
#include <sys/syscall.h>
489c9b5090e2 Initial load
duke
parents:
diff changeset
    34
#include <unistd.h>
489c9b5090e2 Initial load
duke
parents:
diff changeset
    35
#include <signal.h>
489c9b5090e2 Initial load
duke
parents:
diff changeset
    36
489c9b5090e2 Initial load
duke
parents:
diff changeset
    37
void VMError::show_message_box(char *buf, int buflen) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    38
  bool yes;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    39
  do {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    40
    error_string(buf, buflen);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    41
    int len = (int)strlen(buf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    42
    char *p = &buf[len];
489c9b5090e2 Initial load
duke
parents:
diff changeset
    43
489c9b5090e2 Initial load
duke
parents:
diff changeset
    44
    jio_snprintf(p, buflen - len,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    45
               "\n\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
    46
               "Do you want to debug the problem?\n\n"
13964
01a2b863cc61 7177003: C1: LogCompilation support
vlivanov
parents: 7433
diff changeset
    47
               "To debug, run 'gdb /proc/%d/exe %d'; then switch to thread " UINTX_FORMAT " (" INTPTR_FORMAT ")\n"
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    48
               "Enter 'yes' to launch gdb automatically (PATH must include gdb)\n"
489c9b5090e2 Initial load
duke
parents:
diff changeset
    49
               "Otherwise, press RETURN to abort...",
489c9b5090e2 Initial load
duke
parents:
diff changeset
    50
               os::current_process_id(), os::current_process_id(),
7433
b418028612ad 6961690: load oops from constant table on SPARC
twisti
parents: 7397
diff changeset
    51
               os::current_thread_id(), os::current_thread_id());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    52
489c9b5090e2 Initial load
duke
parents:
diff changeset
    53
    yes = os::message_box("Unexpected Error", buf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    54
489c9b5090e2 Initial load
duke
parents:
diff changeset
    55
    if (yes) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    56
      // yes, user asked VM to launch debugger
489c9b5090e2 Initial load
duke
parents:
diff changeset
    57
      jio_snprintf(buf, buflen, "gdb /proc/%d/exe %d",
489c9b5090e2 Initial load
duke
parents:
diff changeset
    58
                   os::current_process_id(), os::current_process_id());
489c9b5090e2 Initial load
duke
parents:
diff changeset
    59
489c9b5090e2 Initial load
duke
parents:
diff changeset
    60
      os::fork_and_exec(buf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    61
      yes = false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    62
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    63
  } while (yes);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    64
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
489c9b5090e2 Initial load
duke
parents:
diff changeset
    66
// Space for our "saved" signal flags and handlers
489c9b5090e2 Initial load
duke
parents:
diff changeset
    67
static int resettedSigflags[2];
489c9b5090e2 Initial load
duke
parents:
diff changeset
    68
static address resettedSighandler[2];
489c9b5090e2 Initial load
duke
parents:
diff changeset
    69
489c9b5090e2 Initial load
duke
parents:
diff changeset
    70
static void save_signal(int idx, int sig)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    71
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
    72
  struct sigaction sa;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    73
  sigaction(sig, NULL, &sa);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    74
  resettedSigflags[idx]   = sa.sa_flags;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    75
  resettedSighandler[idx] = (sa.sa_flags & SA_SIGINFO)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    76
                              ? CAST_FROM_FN_PTR(address, sa.sa_sigaction)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    77
                              : CAST_FROM_FN_PTR(address, sa.sa_handler);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    78
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    79
489c9b5090e2 Initial load
duke
parents:
diff changeset
    80
int VMError::get_resetted_sigflags(int sig) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    81
  if(SIGSEGV == sig) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    82
    return resettedSigflags[0];
489c9b5090e2 Initial load
duke
parents:
diff changeset
    83
  } else if(SIGBUS == sig) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    84
    return resettedSigflags[1];
489c9b5090e2 Initial load
duke
parents:
diff changeset
    85
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    86
  return -1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    87
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    88
489c9b5090e2 Initial load
duke
parents:
diff changeset
    89
address VMError::get_resetted_sighandler(int sig) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    90
  if(SIGSEGV == sig) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    91
    return resettedSighandler[0];
489c9b5090e2 Initial load
duke
parents:
diff changeset
    92
  } else if(SIGBUS == sig) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    93
    return resettedSighandler[1];
489c9b5090e2 Initial load
duke
parents:
diff changeset
    94
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    95
  return NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    96
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    97
489c9b5090e2 Initial load
duke
parents:
diff changeset
    98
static void crash_handler(int sig, siginfo_t* info, void* ucVoid) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    99
  // unmask current signal
489c9b5090e2 Initial load
duke
parents:
diff changeset
   100
  sigset_t newset;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   101
  sigemptyset(&newset);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   102
  sigaddset(&newset, sig);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   103
  sigprocmask(SIG_UNBLOCK, &newset, NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   104
489c9b5090e2 Initial load
duke
parents:
diff changeset
   105
  VMError err(NULL, sig, NULL, info, ucVoid);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   106
  err.report_and_die();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   107
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   108
489c9b5090e2 Initial load
duke
parents:
diff changeset
   109
void VMError::reset_signal_handlers() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   110
  // Save sigflags for resetted signals
489c9b5090e2 Initial load
duke
parents:
diff changeset
   111
  save_signal(0, SIGSEGV);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   112
  save_signal(1, SIGBUS);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   113
  os::signal(SIGSEGV, CAST_FROM_FN_PTR(void *, crash_handler));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   114
  os::signal(SIGBUS, CAST_FROM_FN_PTR(void *, crash_handler));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   115
}