Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(241)

Side by Side Diff: platform_tools/android/bin/android_gdb_app

Issue 1509853006: Fix 'debugging on Android' android_gdb_app script. (Closed) Base URL: https://skia.googlesource.com/skia@master
Patch Set: Update doc with optional parameters information. Created 5 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | site/user/quick/android.md » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 #!/bin/bash 1 #!/bin/bash
2 # 2 #
3 # android_gdb_app: Pushes gdbserver, launches sampleApp, and connects 3 # android_gdb_app: Pushes gdbserver, launches sampleApp, and connects
4 # the debugging environment. 4 # the debugging environment.
5 5
6 SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" 6 SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
7 source $SCRIPT_DIR/android_setup.sh 7 source $SCRIPT_DIR/android_setup.sh "$@"
djsollen 2015/12/10 21:01:37 I don't think this line is necessary.
aam 2015/12/10 21:16:53 If I comment this line out, I get === $ ./platform
8 8
9 APP_NAME=${APP_ARGS[0]} 9 APP_NAME=${APP_ARGS[0]}
10 PORT=5039 10 PORT=5039
11 11
12 source $SCRIPT_DIR/utils/setup_adb.sh 12 source $SCRIPT_DIR/utils/setup_adb.sh
13 13
14 14
15 # Forward local to remote socket connection. 15 # Forward local to remote socket connection.
16 $ADB $DEVICE_SERIAL forward "tcp:$PORT" "tcp:$PORT" 16 $ADB $DEVICE_SERIAL forward "tcp:$PORT" "tcp:$PORT"
17 17
18 # We kill all previous instances of gdbserver to rid all port overriding errors. 18 # We kill all previous instances of gdbserver to rid all port overriding errors.
19 if [ $(uname) == "Linux" ]; then 19 if [ $(uname) == "Linux" ]; then
20 $ADB $DEVICE_SERIAL shell ps | grep gdbserver | awk '{print $2}' | xargs -r $ADB $DEVICE_SERIAL shell kill 20 $ADB $DEVICE_SERIAL shell ps | grep gdbserver | awk '{print $2}' | xargs -r $ADB $DEVICE_SERIAL shell kill
21 elif [ $(uname) == "Darwin" ]; then 21 elif [ $(uname) == "Darwin" ]; then
22 $ADB $DEVICE_SERIAL shell ps | grep gdbserver | awk '{print $2}' | xargs $AD B $DEVICE_SERIAL shell kill 22 $ADB $DEVICE_SERIAL shell ps | grep gdbserver | awk '{print $2}' | xargs $AD B $DEVICE_SERIAL shell kill
23 else 23 else
24 echo "Could not automatically determine OS!" 24 echo "Could not automatically determine OS!"
25 exit 1; 25 exit 1;
26 fi 26 fi
27 27
28 # We need the debug symbols from these files 28 # We need the debug symbols from these files
29 GDB_TMP_DIR=$SKIA_OUT/android_gdb_tmp 29 GDB_TMP_DIR=$SKIA_OUT/android_gdb_tmp
30 mkdir -p $GDB_TMP_DIR 30 mkdir -p $GDB_TMP_DIR
31 echo "Copying symbol files" 31 echo "Copying symbol files"
32 adb_pull_if_needed /system/bin/app_process $GDB_TMP_DIR 32 adb_pull_if_needed /system/bin/app_process $GDB_TMP_DIR
33 adb_pull_if_needed /system/lib/libc.so $GDB_TMP_DIR 33 adb_pull_if_needed /system/lib/libc.so $GDB_TMP_DIR
34 adb_pull_if_needed /data/data/com.skia/lib/libskia_android.so $GDB_TMP_DIR 34 adb_pull_if_needed /data/data/com.skia.sample_app/lib/libskia_android.so $GDB_TM P_DIR
35 adb_pull_if_needed /data/data/com.skia/lib/libSampleApp.so $GDB_TMP_DIR 35 adb_pull_if_needed /data/data/com.skia.sample_app/lib/libSampleApp.so $GDB_TMP_D IR
36 36
37 echo "Pushing gdbserver..." 37 echo "Pushing gdbserver..."
38 adb_push_if_needed $ANDROID_TOOLCHAIN/../gdbserver /data/local/tmp 38 adb_push_if_needed $ANDROID_TOOLCHAIN/../gdbserver /data/local/tmp
39 39
40 # Launch the app 40 # Launch the app
41 echo "Launching the app..." 41 echo "Launching the app..."
42 $ADB $DEVICE_SERIAL shell am start -n com.skia/com.skia.SkiaSampleActivity 42 $ADB $DEVICE_SERIAL shell am start -n com.skia.sample_app/com.skia.SkiaSampleAct ivity
43 43
44 # Wait for app process to initialize 44 # Wait for app process to initialize
45 sleep 2 45 sleep 2
46 46
47 # Attach gdbserver to the app process 47 # Attach gdbserver to the app process
48 PID=$($ADB shell ps | grep com.skia | awk '{print $2}') 48 PID=$($ADB shell ps | grep com.skia.sample_app | awk '{print $2}')
49 echo "Attaching to pid: $PID" 49 echo "Attaching to pid: $PID"
50 $ADB $DEVICE_SERIAL shell /data/local/tmp/gdbserver :$PORT --attach $PID & 50 $ADB $DEVICE_SERIAL shell /data/local/tmp/gdbserver :$PORT --attach $PID &
51 51
52 # Wait for gdbserver 52 # Wait for gdbserver
53 sleep 2 53 sleep 2
54 54
55 # Set up gdb commands 55 # Set up gdb commands
56 GDBSETUP=$GDB_TMP_DIR/gdb.setup 56 GDBSETUP=$GDB_TMP_DIR/gdb.setup
57 echo "file $GDB_TMP_DIR/app_process" >> $GDBSETUP 57 echo "file $GDB_TMP_DIR/app_process" >> $GDBSETUP
58 echo "target remote :$PORT" >> $GDBSETUP 58 echo "target remote :$PORT" >> $GDBSETUP
59 echo "set solib-absolute-prefix $GDB_TMP_DIR" >> $GDBSETUP 59 echo "set solib-absolute-prefix $GDB_TMP_DIR" >> $GDBSETUP
60 echo "set solib-search-path $GDB_TMP_DIR" >> $GDBSETUP 60 echo "set solib-search-path $GDB_TMP_DIR" >> $GDBSETUP
61 61
62 # Launch gdb client 62 # Launch gdb client
63 echo "Entering gdb client shell" 63 echo "Entering gdb client shell"
64 GDB_COMMAND=$(command ls "$ANDROID_TOOLCHAIN"/*-gdb | head -n1) 64 GDB_COMMAND=$(command ls "$ANDROID_TOOLCHAIN"/*-gdb | head -n1)
65 "$GDB_COMMAND" -x $GDBSETUP 65 "$GDB_COMMAND" -x $GDBSETUP
66 66
67 # Clean up: 67 # Clean up:
68 # We could 'rm -rf $GDB_TMP_DIR', but doing so would cause subsequent debugging 68 # We could 'rm -rf $GDB_TMP_DIR', but doing so would cause subsequent debugging
69 # sessions to take longer than necessary. The tradeoff is to now force the user 69 # sessions to take longer than necessary. The tradeoff is to now force the user
70 # to remove the directory when they are done debugging. 70 # to remove the directory when they are done debugging.
71 rm $GDBSETUP 71 rm $GDBSETUP
72 72
73 73
OLDNEW
« no previous file with comments | « no previous file | site/user/quick/android.md » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698