hotspot/agent/test/jdi/runsa.sh
changeset 1 489c9b5090e2
child 5547 f4b087cbb361
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/hotspot/agent/test/jdi/runsa.sh	Sat Dec 01 00:00:00 2007 +0000
@@ -0,0 +1,184 @@
+#!/bin/ksh
+#
+# Copyright 2002-2003 Sun Microsystems, Inc.  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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
+# CA 95054 USA or visit www.sun.com if you need additional information or
+# have any questions.
+#  
+#
+
+
+# This jdk must be hopper or better; it must have the 
+# SA connectors in VirtualMachineManagerImpl.
+jdk=/java/re/jdk/1.4.1/promoted/latest/binaries/solaris-sparc
+#jdk=/net/mmm/export/mmm/jdk1.4fcs.sa
+
+doUsage()
+{
+    cat <<EOF
+    Run sagclient.class using Serviceability Agent to talk to a corefile/pid/debugserver.
+    Usage:  runsa.sh [-jdk <jdk-pathname>] [-jdb] [ -jdbx ] [ -d64 ] [ -remote ] [ pid | corefile | debugserver ]
+
+    -jdk means to use that jdk.  Default is 1.4.1/latest.
+    -jdbx means to run it under jdbx
+    -jdb means to connect using jdb instead of the sagclient program.
+    -remote debugserver means you want to connect to a remote debug server
+
+    The corefile must have been produced by the same java as is running SA.
+
+EOF
+}
+
+if [ $# = 0 ] ; then
+    doUsage
+    exit 1
+fi
+
+# License file for development version of dbx
+#LM_LICENSE_FILE=7588@extend.eng:/usr/dist/local/config/sparcworks/license.dat:7588@setlicense
+#export LM_LICENSE_FILE
+
+do=
+args=
+theClass=sagclient
+javaArgs=
+
+while [ $# != 0 ] ; do
+    case $1 in
+      -vv)
+        set -x
+        ;;
+     -jdk)
+        jdk=$2
+        shift
+        ;;
+     -jdbx)
+        do=jdbx
+        ;;
+     -jdb)
+        do=jdb
+        ;;
+     -help | help)
+        doUsage
+        exit
+        ;;
+     -d64) 
+        d64=-d64
+        ;;
+     -remote)
+        shift 
+        args="$1"
+        do=remote
+        ;;
+     -*)
+        javaArgs="$javaArgs $1"
+        ;;
+     *)
+        echo "$1" | grep -s '^[0-9]*$' > /dev/null
+        if [ $? = 0 ] ; then
+            # it is a pid
+            args="$args $1"
+        else
+            # It is a core.        
+            # We have to pass the name of the program that produced the
+            # core, and the core file itself.
+            args="$jdk/bin/java $1"
+        fi
+        ;;
+   esac
+   shift
+done
+
+if [ -z "$jdk" ] ; then
+    error "--Error: runsa.sh:  Must specify -jdk <jdk-pathname>."
+    error "         Do runsa.sh -help for more info"
+    exit 1
+fi
+
+set -x
+#setenv USE_LIBPROC_DEBUGGER "-Dsun.jvm.hotspot.debugger.useProcDebugger -Djava.library.path=$saprocdir"
+
+# If jjh makes this, then the classes are in .../build/agent.
+# if someone else does, they are in  .
+classesDir=../../../../../../build/agent
+if [ ! -r $classesDir ] ; then
+    classesDir=.
+    if [ ! -r $classesDir ] ; then
+        echo "-- Error: runsa.sh can't find the SA classes"
+        exit 1
+    fi
+fi
+#javacp="/net/mmm/export/mmm/ws/sabaseline/build/solaris/solaris_sparc_compiler1/generated/sa-jdi.jar:$classesDir:$jdk/lib/tools.jar:$jdk/classes:./workdir"
+
+javacp="$jdk/lib/sa-jdi.jar:$classesDir:$jdk/lib/tools.jar:$jdk/classes:./workdir"
+
+
+extraArgs="-showversion $javaArgs"
+#extraArgs="-DdbxSvcAgentDSOPathName=/net/mmm/export/mmm/ws/m/b2/sa/src/os/solaris/agent/64bit/libsvc_agent_dbx.so $extraArgs"
+#extraArgs="-DdbxSvcAgentDSOPathName=/net/jano.eng/export/disk05/hotspot/sa/solaris/sparcv9/lib/libsvc_agent_dbx.so $extraArgs"
+
+mkdir -p workdir
+if [ sagclient.java -nt ./workdir/sagclient.class ] ; then
+    $jdk/bin/javac -d ./workdir -classpath $javacp sagclient.java
+    if [ $? != 0 ] ; then
+        exit 1
+    fi
+fi
+if [ sagdoit.java -nt ./workdir/sagdoit.class ] ; then
+    $jdk/bin/javac -d ./workdir -classpath $javacp sagdoit.java
+    if [ $? != 0 ] ; then
+        exit 1
+    fi
+fi
+
+if [ "$do" = jdbx ] ; then
+    set -x
+    dbx=/net/sparcworks.eng/export/set/sparcworks2/dbx_70_nightly/dev/buildbin/Derived-sparc-S2-opt/bin/dbx
+
+    # Have to do this export for jdbx to work.  -cp and -classpath don't work.
+    CLASSPATH=$javacp
+    export CLASSPATH
+    #extraArgs="-Djava.class.path=$mhs/../sa/build/agent sun.jvm.hotspot.HSDB $*"
+    jvm_invocation="$jdk/bin/java -Xdebug \
+               -Dsun.boot.class.path=$jdk/classes \
+               $extraArgs"
+    #export jvm_invocation
+    
+    JAVASRCPATH=$mhs/../sa/src/share/vm/agent
+    export JAVASRCPATH
+
+    #operand is pathname of .class file, eg ./jj.class.
+    echo run $args
+    clss=`echo $theClass | sed -e 's@\.@/@'`
+    if [ -r ./workdir/$clss.class ] ; then
+        # kludge for running sagclient
+        $dbx  ./workdir/$clss.class
+    else
+        # kludge for running HSDB
+        $dbx  $mhs/../sa/build/agent/$clss.class
+    fi
+elif [ "$do" = jdb ] ; then
+    # This hasn't been tested.
+    $jdk/bin/jdb -J-Xbootclasspath/a:$classesDir -connect sun.jvm.hotspot.jdi.SACoreAttachingConnector:core=sagcore
+elif [ "$do" = remote ] ; then
+    $jdk/bin/java $d64 -Djava.class.path=$javacp $extraArgs $theClass $args
+else
+    $jdk/bin/java $d64 -Djava.class.path=$javacp $extraArgs $theClass $args
+
+fi