ndk-gdb revision 4cff650ddc3e0b2e56528b6aca56ef9171cac972
1a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner#!/bin/sh 2a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# 3a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Copyright (C) 2010 The Android Open Source Project 4a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# 5a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Licensed under the Apache License, Version 2.0 (the "License"); 6a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# you may not use this file except in compliance with the License. 7a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# You may obtain a copy of the License at 8a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# 9a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# http://www.apache.org/licenses/LICENSE-2.0 10a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# 11a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Unless required by applicable law or agreed to in writing, software 12a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# distributed under the License is distributed on an "AS IS" BASIS, 13a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# See the License for the specific language governing permissions and 15a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# limitations under the License. 16a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# 17a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 18a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# This wrapper script is used to launch a native debugging session 19a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# on a given NDK application. The application must be debuggable, i.e. 20a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# its android:debuggable attribute must be set to 'true' in the 21a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# <application> element of its manifest. 22a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# 23a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# See docs/NDK-GDB.TXT for usage description. Essentially, you just 24a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# need to launch ndk-gdb from your application project directory 25a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# after doing ndk-build && ant install && <start-application-on-device> 26a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# 27a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner. `dirname $0`/build/core/ndk-common.sh 28a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 29a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerforce_32bit_binaries 30a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 31a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfind_program ADB_CMD adb 32a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerADB_FLAGS= 33a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 34a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerAWK_CMD=awk 35a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 36a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerDEBUG_PORT=5039 37a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 38a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerPARAMETERS= 39a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerOPTION_HELP=no 40a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerOPTION_PROJECT= 41a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerOPTION_FORCE=no 42a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerOPTION_ADB= 43a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerOPTION_EXEC= 440b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' TurnerOPTION_START=no 450b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' TurnerOPTION_LAUNCH= 460b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' TurnerOPTION_LAUNCH_LIST=no 47a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 48a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnercheck_parameter () 49a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner{ 50a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner if [ -z "$2" ]; then 51a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "ERROR: Missing parameter after option '$1'" 52a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 1 53a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner fi 54a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner} 55a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 56a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnercheck_adb_flags () 57a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner{ 58a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner if [ -n "$ADB_FLAGS" ] ; then 59a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "ERROR: Only one of -e, -d or -s <serial> can be used at the same time!" 60a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 1 61a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner fi 62a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner} 63a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 64a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerget_build_var () 65a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner{ 66a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner if [ -z "$GNUMAKE" ] ; then 67a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner GNUMAKE=make 68a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner fi 69a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner $GNUMAKE --no-print-dir -f $ANDROID_NDK_ROOT/build/core/build-local.mk -C $PROJECT DUMP_$1 70a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner} 71a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 72a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerget_build_var_for_abi () 73a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner{ 74a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner if [ -z "$GNUMAKE" ] ; then 75a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner GNUMAKE=make 76a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner fi 77a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner $GNUMAKE --no-print-dir -f $ANDROID_NDK_ROOT/build/core/build-local.mk -C $PROJECT DUMP_$1 APP_ABI=$2 78a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner} 79a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 800b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner# Used to run an awk script on the manifest 810b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turnerrun_awk_manifest_script () 820b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner{ 830b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner $AWK_CMD -f $AWK_SCRIPTS/$1 $PROJECT/$MANIFEST 840b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner} 850b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner 86a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerVERBOSE=no 87a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerwhile [ -n "$1" ]; do 88a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner opt="$1" 89a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner optarg=`expr "x$opt" : 'x[^=]*=\(.*\)'` 90a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner case "$opt" in 91a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner --help|-h|-\?) 92a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner OPTION_HELP=yes 93a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ;; 94a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner --verbose) 95a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner VERBOSE=yes 96a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ;; 97a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner -s) 98a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner check_parameter $1 $2 99a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner check_adb_flags 100a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ADB_FLAGS=" -s $2" 101a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner shift 102a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ;; 103a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner -s*) 104a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner check_adb_flags 105a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner optarg=`expr -- "$opt" : '-s\(.*\)'` 106a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ADB_FLAGS=" -s $optarg" 107a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ;; 108a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner -p) 109a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner check_parameter $1 $2 110a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner OPTION_PROJECT="$2" 111a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner shift 112a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ;; 113a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner -p*) 114a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner optarg=`expr -- "$opt" : '-p\(.*\)'` 115a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner OPTION_PROJECT="$optarg" 116a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ;; 117a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner --exec=*) 118a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner OPTION_EXEC="$optarg" 119a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ;; 120a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner -x) 121a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner check_parameter $1 $2 122a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner OPTION_EXEC="$2" 123a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner shift 124a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ;; 125a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner -x*) 126a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner optarg=`expr -- "$opt" : '-x\(.*\)'` 127a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner OPTION_EXEC="$optarg" 128a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ;; 129a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner -e) 130a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner check_adb_flags 131a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ADB_FLAGS=" -e" 132a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ;; 133a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner -d) 134a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner check_adb_flags 135a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ADB_FLAGS=" -d" 136a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ;; 137a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner --adb=*) # specify ADB command 138a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner OPTION_ADB="$optarg" 139a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ;; 140a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner --awk=*) 141a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner AWK_CMD="$optarg" 142a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ;; 143a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner --project=*) 144a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner OPTION_PROJECT="$optarg" 145a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ;; 146a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner --port=*) 147a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner DEBUG_PORT="$optarg" 148a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ;; 149a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner --force) 150a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner OPTION_FORCE="yes" 151a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ;; 1520b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner --launch-list) 1530b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner OPTION_LAUNCH_LIST="yes" 1540b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner ;; 1550b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner --launch=*) 1560b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner OPTION_LAUNCH="$optarg" 1570b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner ;; 1580b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner --start) 1590b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner OPTION_START=yes 1600b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner ;; 161a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner -*) # unknown options 162a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "ERROR: Unknown option '$opt', use --help for list of valid ones." 163a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 1 164a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ;; 165a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner *) # Simply record parameter 166a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner if [ -z "$PARAMETERS" ] ; then 167a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner PARAMETERS="$opt" 168a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner else 169a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner PARAMETERS="$PARAMETERS $opt" 170a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner fi 171a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ;; 172a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner esac 173a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner shift 174a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerdone 175a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 176a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ "$OPTION_HELP" = "yes" ] ; then 177a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "Usage: $PROGNAME [options]" 178a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "" 1790b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo "Setup a gdb debugging session for your Android NDK application." 1800b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo "Read $$NDK/docs/NDK-GDB.TXT for complete usage instructions." 1810b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo "" 182a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "Valid options:" 183a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "" 184a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo " --help|-h|-? Print this help" 185a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo " --verbose Enable verbose mode" 186a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo " --force Kill existing debug session if it exists" 1870b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo " --start Launch application instead of attaching to existing one" 1880b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo " --launch=<name> Same as --start, but specify activity name (see below)" 1890b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo " --launch-list List all launchable activity names from manifest" 1900b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo " --project=<path> Specify application project path" 191a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo " -p <path> Same as --project=<path>" 1920b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo " --port=<port> Use tcp:localhost:<port> to communicate with gdbserver [$DEBUG_PORT]" 193a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo " --exec=<file> Execute gdb initialization commands in <file> after connection" 194a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo " -x <file> Same as --exec=<file>" 1950b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo " --adb=<file> Use specific adb command [$ADB_CMD]" 1960b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo " --awk=<file> Use specific awk command [$AWK_CMD]" 197a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo " -e Connect to single emulator instance" 198a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo " -d Connect to single target device" 199a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo " -s <serial> Connect to specific emulator or device" 200a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "" 201a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 0 202a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi 203a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 204a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Android NDK installation path: $ANDROID_NDK_ROOT" 205a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 206a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ -n "$OPTION_EXEC" ] ; then 207a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner if [ ! -f "$OPTION_EXEC" ]; then 208a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "ERROR: Invalid initialization file: $OPTION_EXEC" 209a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 1 210a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner fi 211a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi 212a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 213a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Check ADB tool version 214a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ -n "$OPTION_ADB" ] ; then 215a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner ADB_CMD="$OPTION_ADB" 216a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner log "Using specific adb command: $ADB_CMD" 217a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerelse 218a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner if [ -z "$ADB_CMD" ] ; then 219a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "ERROR: The 'adb' tool is not in your path." 220a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo " You can change your PATH variable, or use" 221a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo " --adb=<executable> to point to a valid one." 222a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 1 223a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner fi 224a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner log "Using default adb command: $ADB_CMD" 225a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi 226a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 227a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerADB_VERSION=`$ADB_CMD version` 228a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ $? != 0 ] ; then 229a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "ERROR: Could not run ADB with: $ADB_CMD" 230a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 1 231a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi 232a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "ADB version found: $ADB_VERSION" 233a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 234a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerADB_CMD="${ADB_CMD}${ADB_FLAGS}" 235a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Using final ADB command: '$ADB_CMD'" 236a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 2374cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turneradb_shell () 2384cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner{ 2394cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner # Run an adb shell command and return its output. 2404cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner # 2414cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner # We need to filter weird control characters like \r that are 2424cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner # included in the output. 2434cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner # 2444cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner $ADB_CMD shell $@ | sed -e 's![[:cntrl:]]!!g' 2454cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner} 246a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 247a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Check the awk tool 2480b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' TurnerAWK_SCRIPTS=$ANDROID_NDK_ROOT/build/awk 2490b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' TurnerAWK_TEST=`$AWK_CMD -f $AWK_SCRIPTS/check-awk.awk` 250a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ $? != 0 ] ; then 2510b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo "ERROR: Could not run '$AWK_CMD' command. Do you have it installed properly?" 252a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 1 253a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi 254a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ "$AWK_TEST" != "Pass" ] ; then 255a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "ERROR: Your version of 'awk' is obsolete. Please use --awk=<file> to point to Nawk or Gawk!" 256a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 1 257a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi 258a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 259a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Name of the manifest file 260a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerMANIFEST=AndroidManifest.xml 261a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 262a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Find the root of the application project. 263a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ -n "$OPTION_PROJECT" ] ; then 264a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner PROJECT=$OPTION_PROJECT 265a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner log "Using specified project path: $PROJECT" 266a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner if [ ! -d "$PROJECT" ] ; then 267a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "ERROR: Your --project option does not point to a directory!" 268a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 1 269a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner fi 270a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner if [ ! -f "$PROJECT/$MANIFEST" ] ; then 271a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "ERROR: Your --project does not point to an Android project path!" 272a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo " It is missing a $MANIFEST file." 273a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 1 274a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner fi 275a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerelse 276a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner # Assume we are in the project directory 277a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner if [ -f "$MANIFEST" ] ; then 278a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner PROJECT=. 279a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner else 280a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner PROJECT= 281a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner CURDIR=`pwd` 282a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner while [ "$CURDIR" != "/" ] ; do 283a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner if [ -f "$CURDIR/$MANIFEST" ] ; then 284a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner PROJECT="$CURDIR" 285a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner break 286a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner fi 287a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner CURDIR=`dirname $CURDIR` 288a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner done 289a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner if [ -z "$PROJECT" ] ; then 290a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "ERROR: Launch this script from an application project directory, or use --project=<path>." 291a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 1 292a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner fi 293a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner fi 294a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner log "Using auto-detected project path: $PROJECT" 295a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi 296a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 297a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Extract the package name from the manifest 2980b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' TurnerPACKAGE_NAME=`run_awk_manifest_script extract-package-name.awk` 299a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Found package name: $PACKAGE_NAME" 300a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ $? != 0 -o "$PACKAGE_NAME" = "<none>" ] ; then 301a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "ERROR: Could not extract package name from $PROJECT/$MANIFEST." 302a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo " Please check that the file is well-formed!" 303a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 1 304a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi 305a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 3060b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner# If --launch-list is used, list all launchable activities, and be done with it 3070b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turnerif [ "$OPTION_LAUNCH_LIST" = "yes" ] ; then 3080b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner log "Extracting list of launchable activities from manifest:" 3090b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner run_awk_manifest_script extract-launchable.awk 3100b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner exit 0 3110b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turnerfi 3120b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner 313a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Check that the application is debuggable, or nothing will work 3140b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' TurnerDEBUGGABLE=`run_awk_manifest_script extract-debuggable.awk` 315a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Found debuggable flag: $DEBUGGABLE" 316a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ $? != 0 -o "$DEBUGGABLE" != "true" ] ; then 317a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "ERROR: Package $PACKAGE_NAME is not debuggable ! Please fix your manifest," 318a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo " rebuild your application and re-install it to fix this." 319a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 1 320a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi 321a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 322a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerAPP_ABIS=`get_build_var APP_ABI` 323a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "ABIs targetted by application: $APP_ABIS" 324a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 325a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Check the ADB command, and that we can connect to the device/emulator 326a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerADB_TEST=`$ADB_CMD shell ls` 327a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ $? != 0 ] ; then 328a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "ERROR: Could not connect to device or emulator!" 329a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo " Please check that an emulator is running or a device is connected" 3302e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner echo " through USB to this machine. You can use -e, -d and -s <serial>" 331a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo " in case of multiple ones." 332a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 1 333a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi 334a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 3354cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner# Check that the device is running Froyo (API Level 8) or higher 3364cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner# 3374cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' TurnerAPI_LEVEL=`adb_shell getprop ro.build.version.sdk` 3384cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turnerif [ $? != 0 -o -z "$API_LEVEL" ] ; then 3394cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner echo "ERROR: Could not find target device's supported API level !" 3404cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner echo "ndk-gdb will only work if your device is running Android 2.2 or higher." 3414cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner exit 1 3424cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turnerfi 3434cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turnerif [ "$API_LEVEL" -lt "8" ] ; then 3444cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner echo "ERROR: ndk-gdb requires a target device running Android 2.2 (API level 8) or higher." 3454cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner echo "The target device is running API level $API_LEVEL !" 3464cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner exit 1 3474cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turnerfi 3484cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turner 349a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Get the target device's supported ABI(s) 350a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# And check that they are supported by the application 351a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# 352a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerCOMPAT_ABI=none 3534cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' TurnerCPU_ABI=`adb_shell getprop ro.product.cpu.abi` 354a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerecho "$APP_ABIS" | grep -q -F "$CPU_ABI" 355a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ $? = 0 ] ; then 356a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner COMPAT_ABI=$CPU_ABI 357a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi 358a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 3594cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' TurnerCPU_ABI2=`adb_shell getprop ro.product.cpu.abi2` 360a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ -z "$CPU_ABI2" ] ; then 361a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner log "Device CPU ABI: $CPU_ABI" 362a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerelse 363a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner log "Device CPU ABIs: $CPU_ABI $CPU_ABI2" 364a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "$APP_ABIS" | grep -q -F "$CPU_ABI2" 365a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner if [ $? = 0 ] ; then 366a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner COMPAT_ABI=$CPU_ABI2 367a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner fi 368a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi 369a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ "$COMPAT_ABI" = none ] ; then 370a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "ERROR: The device does not support the application's targetted CPU ABIs!" 371a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner if [ "$CPU_ABI2" = "$CPU_ABI" ] ; then 372a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner CPU_ABI2= 373a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner fi 374a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo " Device supports: $CPU_ABI $CPU_ABI2" 375a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo " Package supports: $APP_ABIS" 376a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 1 377a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi 378a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Compatible device ABI: $COMPAT_ABI" 379a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 3802e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner# Let's check that the user didn't change the debuggable flag in 3812e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner# the manifest without calling ndk-build afterwards. 3822e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turnerif [ ! -f $PROJECT/libs/$COMPAT_ABI/gdbserver ] ; then 3832e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner echo "ERROR: Could not find gdbserver binary under $PROJECT/libs/$COMPAT_ABI" 3842e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner echo " This usually means you modified your AndroidManifest.xml to set" 3852e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner echo " the android:debuggable flag to 'true' but did not rebuild the" 3862e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner echo " native binaries. Please call 'ndk-build' to do so," 3872e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner echo " *then* re-install to the device !" 3882e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner exit 1 3892e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turnerfi 3902e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner 3912e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner# Let's check that 'gdbserver' is properly installed on the device too. If this 3922e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner# is not the case, the user didn't install the proper package after rebuilding. 3932e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner# 3944cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' TurnerDEVICE_GDBSERVER=`adb_shell ls /data/data/$PACKAGE_NAME/lib/gdbserver` 3952e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turnerlog "Found device gdbserver: $DEVICE_GDBSERVER" 3962e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turnerif pattern_match "No such file or directory" "$DEVICE_GDBSERVER" ] ; then 3972e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner echo "ERROR: Non-debuggable application installed on the target device." 3982e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner echo " Please re-install the debuggable version !" 3992e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner exit 1 4002e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turnerfi 4012e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner 402a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Get information from the build system 403a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerGDBSETUP_INIT=`get_build_var_for_abi NDK_APP_GDBSETUP $COMPAT_ABI` 404a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Using gdb setup init: $GDBSETUP_INIT" 405a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 406a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerTOOLCHAIN_PREFIX=`get_build_var_for_abi TOOLCHAIN_PREFIX $COMPAT_ABI` 407a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Using toolchain prefix: $TOOLCHAIN_PREFIX" 408a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 409a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerAPP_OUT=`get_build_var_for_abi TARGET_OUT $COMPAT_ABI` 410a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Using app out directory: $APP_OUT" 411a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 412a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Find the <dataDir> of the package on the device 4134cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' TurnerDATA_DIR=`adb_shell run-as $PACKAGE_NAME /system/bin/sh -c pwd` 414a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Found data directory: '$DATA_DIR'" 4154cff650ddc3e0b2e56528b6aca56ef9171cac972David 'Digit' Turnerif [ $? != 0 -o -z "$DATA_DIR" ] ; then 416a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "ERROR: Could not extract package's data directory. Are you sure that" 4170b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo " your installed application is debuggable?" 418a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 1 419a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi 420a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 4210b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner# Launch the activity if needed 4220b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turnerif [ -n "$OPTION_START" ] ; then 4230b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner # If --launch is used, ignore --start, otherwise extract the first 4240b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner # launchable activity name from the manifest and use it as if --launch=<name> 4250b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner # was used instead. 4260b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner # 4270b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner if [ -z "$OPTION_LAUNCH" ] ; then 4280b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner OPTION_LAUNCH=`run_awk_manifest_script extract-launchable.awk | sed 2q` 4290b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner if [ $? != 0 ] ; then 4300b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo "ERROR: Could not extract name of launchable activity from manifest!" 4310b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo " Try to use --launch=<name> directly instead as a work-around." 4320b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner exit 1 4330b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner fi 4340b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner log "Found first launchable activity: $OPTION_LAUNCH" 4350b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner if [ -z "$OPTION_LAUNCH" ] ; then 4360b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo "ERROR: It seems that your Application does not have any launchable activity!" 4370b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo " Please fix your manifest file and rebuild/re-install your application." 4380b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner exit 1 4390b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner fi 4400b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner fi 4410b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turnerfi 4420b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner 4430b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turnerif [ -n "$OPTION_LAUNCH" ] ; then 4440b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner log "Launching activity: $PACKAGE_NAME/$OPTION_LAUNCH" 4450b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner run $ADB_CMD shell am start -n $PACKAGE_NAME/$OPTION_LAUNCH 4460b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner if [ $? != 0 ] ; then 4470b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo "ERROR: Could not launch specified activity: $OPTION_LAUNCH" 4480b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo " Use --launch-list to dump a list of valid values." 4490b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner exit 1 4500b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner fi 4510b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner # Sleep a bit, it sometimes take one second to start properly 4520b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner # Note that we use the 'sleep' command on the device here. 4530b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner run $ADB_CMD shell sleep 1 4540b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turnerfi 4550b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner 456a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Find the PID of the application being run 4570b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' TurnerPID=`$ADB_CMD shell ps | $AWK_CMD -f $AWK_SCRIPTS/extract-pid.awk -v PACKAGE=$PACKAGE_NAME` 458a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Found running PID: $PID" 459a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ $? != 0 -o "$PID" = "0" ] ; then 460a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "ERROR: Could not extract PID of application on device/emulator." 4610b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner if [ -n "$OPTION_LAUNCH" ] ; then 4622e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner echo " Weird, this probably means one of these:" 4632e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner echo "" 4642e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner echo " - The installed package does not match your current manifest." 4652e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner echo " - The application process was terminated." 4662e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner echo "" 4672e063fe130190c48101e4150afee80802d0c7a3eDavid 'Digit' Turner echo " Try using the --verbose option and look at its output for details." 4680b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner else 4690b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo " Are you sure the application is already started?" 4700b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo " Consider using --start or --launch=<name> if not." 4710b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner fi 472a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 1 473a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi 474a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 475a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Check that there is no other instance of gdbserver running 476a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerGDBSERVER_PS=`$ADB_CMD shell ps | grep lib/gdbserver` 477a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ -n "$GDBSERVER_PS" ] ; then 478a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner if [ "$OPTION_FORCE" = "no" ] ; then 479a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner echo "ERROR: Another debug session running, Use --force to kill it." 480a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 1 481a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner fi 482a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner log "Killing existing debugging session" 4830b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner GDBSERVER_PID=`echo $GDBSERVER_PS | $AWK_CMD -f $AWK_SCRIPTS/extract-pid.awk -v PACKAGE=lib/gdbserver` 484a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner if [ $GDBSERVER_PID != 0 ] ; then 485a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner run $ADB_CMD shell kill -9 $GDBSERVER_PID 486a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner fi 487a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi 488a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 489a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Launch gdbserver now 490a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerDEBUG_SOCKET=debug-socket 491a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerrun $ADB_CMD shell run-as $PACKAGE_NAME lib/gdbserver +$DEBUG_SOCKET --attach $PID & 492a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ $? != 0 ] ; then 4930b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo "ERROR: Could not launch gdbserver on the device?" 494a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 1 495a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi 496a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Launched gdbserver succesfully." 497a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 498a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Setup network redirection 499a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Setup network redirection" 500a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerrun $ADB_CMD forward tcp:$DEBUG_PORT localfilesystem:$DATA_DIR/$DEBUG_SOCKET 501a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ $? != 0 ] ; then 5020b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo "ERROR: Could not setup network redirection to gdbserver?" 5030b2676bac67c271de9989357f6e3b2e762a7adf1David 'Digit' Turner echo " Maybe using --port=<port> to use a different TCP port might help?" 504a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner exit 1 505a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi 506a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 507a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Get the app_server binary from the device 508a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerAPP_PROCESS=$APP_OUT/app_process 509a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerrun adb pull /system/bin/app_process $APP_PROCESS 510a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerlog "Pulled $APP_BINARY from device/emulator." 511a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner 512a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# Now launch the appropriate gdb client with the right init commands 513a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner# 514a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerGDBCLIENT=${TOOLCHAIN_PREFIX}gdb 515a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' TurnerGDBSETUP=$APP_OUT/gdb.setup 516a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnercp -f $GDBSETUP_INIT $GDBSETUP 517a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerecho "target remote :$DEBUG_PORT" >> $GDBSETUP 518a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerif [ -n "$OPTION_EXEC" ] ; then 519a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner cat $OPTION_EXEC >> $GDBSETUP 520a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turnerfi 521a08d605794902f5c7ed79b3d894adb722e1b6cacDavid 'Digit' Turner$GDBCLIENT -x $GDBSETUP -e $APP_PROCESS 522