blob: cc285920dfde7848597303b5021743162797d791 [file] [log] [blame]
jeffhao5d1ac922011-09-29 17:41:15 -07001#!/bin/sh
2#
3# Run the code in test.jar on the device. The jar should contain a top-level
4# class named Main to run.
jeffhao5d1ac922011-09-29 17:41:15 -07005
6msg() {
7 if [ "$QUIET" = "n" ]; then
8 echo "$@"
9 fi
10}
11
Brian Carlstromfa42b442013-06-17 12:53:45 -070012LIB="libartd.so"
Ian Rogers4c1bf1a2012-12-11 10:44:28 -080013GDB="n"
Brian Carlstromfa42b442013-06-17 12:53:45 -070014DEBUGGER="n"
jeffhao0dff3f42012-11-20 15:13:43 -080015INTERPRETER="n"
jeffhao5d1ac922011-09-29 17:41:15 -070016VERIFY="y"
17OPTIMIZE="y"
Elliott Hughes58bcc402012-02-14 14:10:10 -080018ZYGOTE=""
jeffhao5d1ac922011-09-29 17:41:15 -070019QUIET="n"
jeffhao5d1ac922011-09-29 17:41:15 -070020DEV_MODE="n"
Elliott Hughes7c046102011-10-19 18:16:03 -070021INVOKE_WITH=""
jeffhao5d1ac922011-09-29 17:41:15 -070022
23while true; do
24 if [ "x$1" = "x--quiet" ]; then
25 QUIET="y"
26 shift
Brian Carlstromfa42b442013-06-17 12:53:45 -070027 elif [ "x$1" = "x-lib" ]; then
28 shift
29 LIB="$1"
Ian Rogers7769f502012-02-03 18:02:28 -080030 elif [ "x$1" = "x-O" ]; then
Brian Carlstromfa42b442013-06-17 12:53:45 -070031 LIB="libart.so"
Elliott Hughes7c046102011-10-19 18:16:03 -070032 shift
jeffhao5d1ac922011-09-29 17:41:15 -070033 elif [ "x$1" = "x--debug" ]; then
Brian Carlstromfa42b442013-06-17 12:53:45 -070034 DEBUGGER="y"
jeffhao5d1ac922011-09-29 17:41:15 -070035 shift
Ian Rogers4c1bf1a2012-12-11 10:44:28 -080036 elif [ "x$1" = "x--gdb" ]; then
37 GDB="y"
38 DEV_MODE="y"
39 shift
jeffhao5d1ac922011-09-29 17:41:15 -070040 elif [ "x$1" = "x--zygote" ]; then
Elliott Hughes58bcc402012-02-14 14:10:10 -080041 ZYGOTE="--zygote"
jeffhao5d1ac922011-09-29 17:41:15 -070042 msg "Spawning from zygote"
43 shift
44 elif [ "x$1" = "x--dev" ]; then
45 DEV_MODE="y"
46 shift
jeffhao0dff3f42012-11-20 15:13:43 -080047 elif [ "x$1" = "x--interpreter" ]; then
48 INTERPRETER="y"
49 shift
Elliott Hughes7c046102011-10-19 18:16:03 -070050 elif [ "x$1" = "x--invoke-with" ]; then
51 shift
Ian Rogers0e033672013-04-19 10:22:46 -070052 if [ "x$INVOKE_WITH" = "x" ]; then
53 INVOKE_WITH="$1"
54 else
55 INVOKE_WITH="$INVOKE_WITH $1"
56 fi
Elliott Hughes7c046102011-10-19 18:16:03 -070057 shift
jeffhao5d1ac922011-09-29 17:41:15 -070058 elif [ "x$1" = "x--no-verify" ]; then
59 VERIFY="n"
60 shift
61 elif [ "x$1" = "x--no-optimize" ]; then
62 OPTIMIZE="n"
63 shift
jeffhao5d1ac922011-09-29 17:41:15 -070064 elif [ "x$1" = "x--" ]; then
65 shift
66 break
67 elif expr "x$1" : "x--" >/dev/null 2>&1; then
Elliott Hughes7c046102011-10-19 18:16:03 -070068 echo "unknown $0 option: $1" 1>&2
jeffhao5d1ac922011-09-29 17:41:15 -070069 exit 1
70 else
71 break
72 fi
73done
74
Elliott Hughes58bcc402012-02-14 14:10:10 -080075if [ "$ZYGOTE" = "" ]; then
jeffhao5d1ac922011-09-29 17:41:15 -070076 if [ "$OPTIMIZE" = "y" ]; then
77 if [ "$VERIFY" = "y" ]; then
78 DEX_OPTIMIZE="-Xdexopt:verified"
79 else
80 DEX_OPTIMIZE="-Xdexopt:all"
81 fi
82 msg "Performing optimizations"
83 else
84 DEX_OPTIMIZE="-Xdexopt:none"
85 msg "Skipping optimizations"
86 fi
87
88 if [ "$VERIFY" = "y" ]; then
89 DEX_VERIFY=""
90 msg "Performing verification"
91 else
92 DEX_VERIFY="-Xverify:none"
93 msg "Skipping verification"
94 fi
95fi
96
97msg "------------------------------"
98
99if [ "$QUIET" = "n" ]; then
Brian Carlstrom4ec9b1f2012-06-17 22:27:43 -0700100 adb shell rm -r $DEX_LOCATION
Brian Carlstrom105215d2012-06-14 12:50:44 -0700101 adb shell mkdir -p $DEX_LOCATION
102 adb push $TEST_NAME.jar $DEX_LOCATION
103 adb push $TEST_NAME-ex.jar $DEX_LOCATION
jeffhao5d1ac922011-09-29 17:41:15 -0700104else
Brian Carlstrom4ec9b1f2012-06-17 22:27:43 -0700105 adb shell rm -r $DEX_LOCATION >/dev/null 2>&1
Brian Carlstrom105215d2012-06-14 12:50:44 -0700106 adb shell mkdir -p $DEX_LOCATION >/dev/null 2>&1
107 adb push $TEST_NAME.jar $DEX_LOCATION >/dev/null 2>&1
108 adb push $TEST_NAME-ex.jar $DEX_LOCATION >/dev/null 2>&1
jeffhao5d1ac922011-09-29 17:41:15 -0700109fi
110
Brian Carlstromfa42b442013-06-17 12:53:45 -0700111if [ "$DEBUGGER" = "y" ]; then
Elliott Hughes72395bf2012-04-24 13:45:26 -0700112 # Use this instead for ddms and connect by running 'ddms':
Brian Carlstromfa42b442013-06-17 12:53:45 -0700113 # DEBUGGER_OPTS="-agentlib:jdwp=transport=dt_android_adb,server=y,suspend=y"
Elliott Hughes72395bf2012-04-24 13:45:26 -0700114 # TODO: add a separate --ddms option?
Elliott Hughesd1cc8362011-10-24 16:58:50 -0700115
Elliott Hughes72395bf2012-04-24 13:45:26 -0700116 PORT=12345
117 msg "Waiting for jdb to connect:"
118 msg " adb forward tcp:$PORT tcp:$PORT"
119 msg " jdb -attach localhost:$PORT"
Brian Carlstromfa42b442013-06-17 12:53:45 -0700120 DEBUGGER_OPTS="-agentlib:jdwp=transport=dt_socket,address=$PORT,server=y,suspend=y"
jeffhao5d1ac922011-09-29 17:41:15 -0700121fi
122
Ian Rogers4c1bf1a2012-12-11 10:44:28 -0800123if [ "$GDB" = "y" ]; then
124 gdb="gdbserver :5039"
125 gdbargs="--args $exe"
126fi
127
jeffhao0dff3f42012-11-20 15:13:43 -0800128if [ "$INTERPRETER" = "y" ]; then
129 INT_OPTS="-Xint"
130fi
131
Mathieu Chartierdbe6f462012-09-25 16:54:50 -0700132JNI_OPTS="-Xjnigreflimit:512 -Xcheck:jni"
Elliott Hughes72395bf2012-04-24 13:45:26 -0700133
Brian Carlstrom7675e162013-06-10 16:18:04 -0700134cmdline="cd $DEX_LOCATION && mkdir dalvik-cache && export ANDROID_DATA=$DEX_LOCATION && export DEX_LOCATION=$DEX_LOCATION && \
Brian Carlstromfa42b442013-06-17 12:53:45 -0700135 $INVOKE_WITH $gdb dalvikvm $gdbargs -XXlib:$LIB $ZYGOTE $JNI_OPTS $INT_OPTS $DEBUGGER_OPTS -Ximage:/data/art-test/core.art -cp $DEX_LOCATION/$TEST_NAME.jar Main"
Elliott Hughes58bcc402012-02-14 14:10:10 -0800136if [ "$DEV_MODE" = "y" ]; then
137 echo $cmdline "$@"
jeffhao5d1ac922011-09-29 17:41:15 -0700138fi
Elliott Hughes58bcc402012-02-14 14:10:10 -0800139
140adb shell $cmdline "$@"