src/os/posix/launcher/launcher.script

Thu, 02 Dec 2010 05:45:54 -0800

author
sla
date
Thu, 02 Dec 2010 05:45:54 -0800
changeset 2327
cb2d0a362639
child 2369
aa6e219afbf1
permissions
-rw-r--r--

6981484: Update development launcher
Summary: Add new development launcher called hotspot(.exe)
Reviewed-by: coleenp

     1 #!/bin/bash
     3 # Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved.
     4 # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
     5 #
     6 # This code is free software; you can redistribute it and/or modify it
     7 # under the terms of the GNU General Public License version 2 only, as
     8 # published by the Free Software Foundation.
     9 #
    10 # This code is distributed in the hope that it will be useful, but WITHOUT
    11 # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
    12 # FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
    13 # version 2 for more details (a copy is included in the LICENSE file that
    14 # accompanied this code).
    15 #
    16 # You should have received a copy of the GNU General Public License version
    17 # 2 along with this work; if not, write to the Free Software Foundation,
    18 # Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
    19 #
    20 # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
    21 # or visit www.oracle.com if you need additional information or have any
    22 # questions.
    25 # This script launches HotSpot.
    26 #
    27 # If the first parameter is either "-gdb" or "-gud", HotSpot will be
    28 # launched inside gdb. "-gud" means "open an Emacs window and run gdb
    29 # inside Emacs".
    30 #
    31 # If the first parameter is "-dbx", HotSpot will be launched inside dbx.
    32 # 
    33 # If the first parameter is "-valgrind", HotSpot will be launched
    34 # inside Valgrind (http://valgrind.kde.org) using the Memcheck skin,
    35 # and with memory leak detection enabled.  This currently (2005jan19)
    36 # requires at least Valgrind 2.3.0.  -Xmx16m will also be passed as
    37 # the first parameter to HotSpot, since lowering HotSpot's memory
    38 # consumption makes execution inside of Valgrind *a lot* faster.
    39 #
    42 #
    43 # User changeable parameters ------------------------------------------------
    44 #
    46 # This is the name of the gdb binary to use
    47 if [ ! "$GDB" ]
    48 then 
    49     GDB=gdb
    50 fi
    52 # This is the name of the gdb binary to use
    53 if [ ! "$DBX" ]
    54 then 
    55     DBX=dbx
    56 fi
    58 # This is the name of the Valgrind binary to use
    59 if [ ! "$VALGRIND" ]
    60 then 
    61     VALGRIND=valgrind
    62 fi
    64 # This is the name of Emacs for running GUD
    65 EMACS=emacs
    67 #
    68 # End of user changeable parameters -----------------------------------------
    69 #
    71 # Make sure the paths are fully specified, i.e. they must begin with /.
    72 SCRIPT=$(cd $(dirname $0) && pwd)/$(basename $0)
    73 RUNDIR=$(pwd)
    75 # Look whether the user wants to run inside gdb
    76 case "$1" in
    77     -gdb)
    78         MODE=gdb
    79         shift
    80         ;;
    81     -gud)
    82         MODE=gud
    83         shift
    84         ;;
    85     -dbx)
    86         MODE=dbx
    87         shift
    88         ;;
    89     -valgrind)
    90         MODE=valgrind
    91         shift
    92         ;;
    93     *)
    94         MODE=run
    95         ;;
    96 esac
    98 if [ "${ALT_JAVA_HOME}" = "" ]; then
    99     if [ "${JAVA_HOME}" = "" ]; then
   100 	echo "Neither ALT_JAVA_HOME nor JAVA_HOME is set. Aborting.";
   101 	exit 1;
   102     else
   103 	JDK=${JAVA_HOME%%/jre};
   104     fi
   105 else 
   106     JDK=${ALT_JAVA_HOME%%/jre};
   107 fi
   109 # We will set the LD_LIBRARY_PATH as follows:
   110 #     o		$JVMPATH (directory portion only)
   111 #     o		$JRE/lib/$ARCH
   112 # followed by the user's previous effective LD_LIBRARY_PATH, if
   113 # any.
   114 JRE=$JDK/jre
   115 JAVA_HOME=$JDK
   116 ARCH=@@LIBARCH@@
   118 # Find out the absolute path to this script
   119 MYDIR=$(cd $(dirname $SCRIPT) && pwd)
   121 SBP=${MYDIR}:${JRE}/lib/${ARCH}
   123 # Set up a suitable LD_LIBRARY_PATH
   125 if [ -z "$LD_LIBRARY_PATH" ]
   126 then
   127     LD_LIBRARY_PATH="$SBP"
   128 else
   129     LD_LIBRARY_PATH="$SBP:$LD_LIBRARY_PATH"
   130 fi
   132 export LD_LIBRARY_PATH
   133 export JAVA_HOME
   135 JPARMS="$@ $JAVA_ARGS";
   137 # Locate the gamma development launcher
   138 LAUNCHER=${MYDIR}/gamma
   139 if [ ! -x $LAUNCHER ] ; then
   140     echo Error: Cannot find the gamma development launcher \"$LAUNCHER\"
   141     exit 1
   142 fi
   144 GDBSRCDIR=$MYDIR
   145 BASEDIR=$(cd $MYDIR/../../.. && pwd)
   147 init_gdb() {
   148 # Create a gdb script in case we should run inside gdb
   149     GDBSCR=/tmp/hsl.$$
   150     rm -f $GDBSCR
   151     cat >>$GDBSCR <<EOF
   152 cd `pwd`
   153 handle SIGUSR1 nostop noprint
   154 handle SIGUSR2 nostop noprint
   155 set args $JPARMS
   156 file $LAUNCHER
   157 directory $GDBSRCDIR
   158 # Get us to a point where we can set breakpoints in libjvm.so
   159 break InitializeJVM
   160 run
   161 # Stop in InitializeJVM
   162 delete 1
   163 # We can now set breakpoints wherever we like
   164 EOF
   165 }
   168 case "$MODE" in
   169     gdb)
   170 	init_gdb
   171         $GDB -x $GDBSCR
   172 	rm -f $GDBSCR
   173         ;;
   174     gud)
   175 	init_gdb
   176 # First find out what emacs version we're using, so that we can
   177 # use the new pretty GDB mode if emacs -version >= 22.1
   178 	case $($EMACS -version 2> /dev/null) in
   179 	    *GNU\ Emacs\ 2[23]*)
   180 	    emacs_gud_cmd="gdba"
   181 	    emacs_gud_args="--annotate=3"
   182 	    ;;
   183 	    *)
   184 		emacs_gud_cmd="gdb"
   185 		emacs_gud_args=
   186 		;;
   187 	esac
   188         $EMACS --eval "($emacs_gud_cmd \"$GDB $emacs_gud_args -x $GDBSCR\")";
   189 	rm -f $GDBSCR
   190         ;;
   191     dbx)
   192         $DBX -s $MYDIR/.dbxrc $LAUNCHER $JPARAMS
   193         ;;
   194     valgrind)
   195         echo Warning: Defaulting to 16Mb heap to make Valgrind run faster, use -Xmx for larger heap
   196         echo
   197         $VALGRIND --tool=memcheck --leak-check=yes --num-callers=50 $LAUNCHER -Xmx16m $JPARMS
   198         ;;
   199     run)
   200         LD_PRELOAD=$PRELOADING exec $LAUNCHER $JPARMS
   201         ;;
   202     *)
   203         echo Error: Internal error, unknown launch mode \"$MODE\"
   204         exit 1
   205         ;;
   206 esac
   207 RETVAL=$?
   208 exit $RETVAL

mercurial