author | chegar |
Fri, 27 Feb 2015 11:45:07 +0000 | |
changeset 29220 | b07abc731618 |
parent 22734 | 41757c1f3946 |
child 32575 | 059965be379b |
permissions | -rw-r--r-- |
#!/bin/sh # Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved. # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. # # This code is free software; you can redistribute it and/or modify it # under the terms of the GNU General Public License version 2 only, as # published by the Free Software Foundation. # # This code is distributed in the hope that it will be useful, but WITHOUT # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or # FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License # version 2 for more details (a copy is included in the LICENSE file that # accompanied this code). # # You should have received a copy of the GNU General Public License version # 2 along with this work; if not, write to the Free Software Foundation, # Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. # # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA # or visit www.oracle.com if you need additional information or have any # questions. # This script launches HotSpot. # # If the first parameter is either "-gdb" or "-gud", HotSpot will be # launched inside gdb. "-gud" means "open an Emacs window and run gdb # inside Emacs". # # If the first parameter is "-dbx", HotSpot will be launched inside dbx. # # If the first parameter is "-valgrind", HotSpot will be launched # inside Valgrind (http://valgrind.kde.org) using the Memcheck skin, # and with memory leak detection enabled. This currently (2005jan19) # requires at least Valgrind 2.3.0. -Xmx16m will also be passed as # the first parameter to HotSpot, since lowering HotSpot's memory # consumption makes execution inside of Valgrind *a lot* faster. # # # User changeable parameters ------------------------------------------------ # # This is the name of the gdb binary to use if [ ! "$GDB" ] then GDB=gdb fi # This is the name of the dbx binary to use if [ ! "$DBX" ] then DBX=dbx fi # This is the name of the Valgrind binary to use if [ ! "$VALGRIND" ] then VALGRIND=valgrind fi # This is the name of Emacs for running GUD EMACS=emacs # # End of user changeable parameters ----------------------------------------- # OS=`uname -s` # Make sure the paths are fully specified, i.e. they must begin with /. REL_MYDIR=`dirname $0` MYDIR=`cd $REL_MYDIR && pwd` case "$OS" in CYGWIN*) MYDIR=`cygpath -m "$MYDIR"` ;; esac # # Look whether the user wants to run inside gdb case "$1" in -gdb) MODE=gdb shift ;; -gud) MODE=gud shift ;; -dbx) MODE=dbx shift ;; -valgrind) MODE=valgrind shift ;; *) MODE=run ;; esac if [ "${ALT_JAVA_HOME}" != "" ]; then JDK=${ALT_JAVA_HOME%%/jre} else JDK=@@JDK_IMPORT_PATH@@ fi if [ "${JDK}" != "" ]; then case "$OS" in CYGWIN*) JDK=`cygpath -m "$JDK"` ;; esac else echo "Failed to find JDK." \ "Either ALT_JAVA_HOME is not set or JDK_IMPORT_PATH is empty." exit 1 fi # We will set the LD_LIBRARY_PATH as follows: # o $JVMPATH (directory portion only) # o $JRE/lib/$ARCH # followed by the user's previous effective LD_LIBRARY_PATH, if # any. JRE=$JDK/jre JAVA_HOME=$JDK export JAVA_HOME ARCH=@@LIBARCH@@ SBP=${MYDIR}:${JRE}/lib/${ARCH} # Set up a suitable LD_LIBRARY_PATH or DYLD_LIBRARY_PATH if [ "${OS}" = "Darwin" ] then if [ -z "$DYLD_LIBRARY_PATH" ] then DYLD_LIBRARY_PATH="$SBP" else DYLD_LIBRARY_PATH="$SBP:$DYLD_LIBRARY_PATH" fi export DYLD_LIBRARY_PATH else # not 'Darwin' if [ -z "$LD_LIBRARY_PATH" ] then LD_LIBRARY_PATH="$SBP" else LD_LIBRARY_PATH="$SBP:$LD_LIBRARY_PATH" fi export LD_LIBRARY_PATH fi JPARMS="-XXaltjvm=$MYDIR -Dsun.java.launcher.is_altjvm=true $@ $JAVA_ARGS"; # Locate the java launcher LAUNCHER=$JDK/bin/java if [ ! -x $LAUNCHER ] ; then echo Error: Cannot find the java launcher \"$LAUNCHER\" exit 1 fi GDBSRCDIR=$MYDIR BASEDIR=`cd $MYDIR/../../.. && pwd` case "$OS" in CYGWIN*) BASEDIR=`cygpath -m "$BASEDIR"` ;; esac init_gdb() { # Create a gdb script in case we should run inside gdb GDBSCR=/tmp/hsl.$$ rm -f $GDBSCR cat >>$GDBSCR <<EOF cd `pwd` handle SIGUSR1 nostop noprint handle SIGUSR2 nostop noprint set args $JPARMS file $LAUNCHER directory $GDBSRCDIR # Get us to a point where we can set breakpoints in libjvm.so set breakpoint pending on break JNI_CreateJavaVM run # Stop in JNI_CreateJavaVM delete 1 # We can now set breakpoints wherever we like EOF } case "$MODE" in gdb) init_gdb $GDB -x $GDBSCR rm -f $GDBSCR ;; gud) init_gdb # First find out what emacs version we're using, so that we can # use the new pretty GDB mode if emacs -version >= 22.1 case `$EMACS -version 2> /dev/null` in *GNU\ Emacs\ 2[23]*) emacs_gud_cmd="gdba" emacs_gud_args="--annotate=3" ;; *) emacs_gud_cmd="gdb" emacs_gud_args= ;; esac $EMACS --eval "($emacs_gud_cmd \"$GDB $emacs_gud_args -x $GDBSCR\")"; rm -f $GDBSCR ;; dbx) $DBX -s $HOME/.dbxrc -c "loadobject -load libjvm.so; stop in JNI_CreateJavaVM; run $JPARMS; delete all" $LAUNCHER ;; valgrind) echo Warning: Defaulting to 16Mb heap to make Valgrind run faster, use -Xmx for larger heap echo $VALGRIND --tool=memcheck --leak-check=yes --num-callers=50 $LAUNCHER -Xmx16m $JPARMS ;; run) LD_PRELOAD=$PRELOADING exec $LAUNCHER $JPARMS ;; *) echo Error: Internal error, unknown launch mode \"$MODE\" exit 1 ;; esac RETVAL=$? exit $RETVAL