| #!/bin/bash |
| |
| set -euxo pipefail |
| |
| OUTPUT_DIR=$(dirname "$0") |
| . "$OUTPUT_DIR"/include.sh |
| |
| TRACEDIR=`mktemp -d` |
| |
| ### Make sure we can connect to the device. |
| |
| # Get the device's wlan0 address. |
| IP_ADDR=$(adb shell ip route get 0.0.0.0 oif wlan0 | sed -En -e 's/.*src (\S+)\s.*/\1/p') |
| REMOTE_PORT=5555 |
| REMOTE=$IP_ADDR:$REMOTE_PORT |
| LOCAL_SERIAL=$(adb shell getprop ro.serialno) |
| |
| # Check that we can connect to it. |
| adb disconnect |
| |
| TRANSPORT_ID=$(adb transport-id) |
| adb tcpip $REMOTE_PORT |
| adb -t $TRANSPORT_ID wait-for-disconnect |
| |
| adb connect $REMOTE |
| |
| REMOTE_FETCHED_SERIAL=$(adb -s $REMOTE shell getprop ro.serialno) |
| |
| if [[ "$LOCAL_SERIAL" != "$REMOTE_FETCHED_SERIAL" ]]; then |
| echo "Mismatch: local serial = $LOCAL_SERIAL, remote serial = $REMOTE_FETCHED_SERIAL" |
| exit 1 |
| fi |
| |
| # Back to USB, and make sure adbd is root. |
| adb -s $REMOTE usb |
| adb disconnect $REMOTE |
| |
| adb wait-for-device root |
| adb root |
| adb wait-for-device |
| |
| TRANSPORT_ID=$(adb transport-id) |
| adb usb |
| adb -t $TRANSPORT_ID wait-for-disconnect |
| |
| adb wait-for-device |
| |
| ### Run the adb unit tests and fetch traces from them. |
| mkdir "$TRACEDIR"/test_traces |
| adb shell rm -rf /data/local/tmp/adb_coverage |
| adb shell mkdir /data/local/tmp/adb_coverage |
| |
| for TEST in $ADB_TESTS; do |
| adb shell LLVM_PROFILE_FILE=/data/local/tmp/adb_coverage/$TEST.profraw /data/nativetest64/$TEST/$TEST |
| adb pull /data/local/tmp/adb_coverage/$TEST.profraw "$TRACEDIR"/test_traces/ |
| done |
| |
| # Clear logcat and increase the buffer to something ridiculous so we can fetch the pids of adbd later. |
| adb shell logcat -c -G128M |
| |
| # Turn on extremely verbose logging so as to not count debug logging against us. |
| adb shell setprop persist.adb.trace_mask 1 |
| |
| ### Run test_device.py over USB. |
| TRANSPORT_ID=$(adb transport-id) |
| adb shell killall adbd |
| adb -t $TRANSPORT_ID wait-for-disconnect |
| |
| adb wait-for-device shell rm -rf "/data/misc/trace/*" /data/local/tmp/adb_coverage/ |
| "$OUTPUT_DIR"/../test_device.py |
| |
| # Do a usb reset to exercise the disconnect code. |
| adb_usbreset |
| adb wait-for-device |
| |
| # Dump traces from the currently running adbd. |
| adb shell killall -37 adbd |
| |
| echo Waiting for adbd to finish dumping traces |
| sleep 5 |
| |
| # Restart adbd in tcp mode. |
| TRANSPORT_ID=$(adb transport-id) |
| adb tcpip $REMOTE_PORT |
| adb -t $TRANSPORT_ID wait-for-disconnect |
| |
| adb connect $REMOTE |
| adb -s $REMOTE wait-for-device |
| |
| # Instead of running test_device.py again, which takes forever, do some I/O back and forth instead. |
| dd if=/dev/zero bs=1024 count=10240 | adb -s $REMOTE raw sink:10485760 |
| adb -s $REMOTE raw source:10485760 | dd of=/dev/null bs=1024 count=10240 |
| |
| # Dump traces again. |
| adb disconnect $REMOTE |
| |
| sleep 5 |
| adb shell killall -37 adbd |
| |
| echo Waiting for adbd to finish dumping traces |
| sleep 5 |
| |
| adb pull /data/misc/trace "$TRACEDIR"/ |
| echo Pulled traces to $TRACEDIR |
| |
| # Identify which of the trace files are actually adbd, in case something else exited simultaneously. |
| ADBD_PIDS=$(adb shell "logcat -d -s adbd --format=process | grep 'adbd started' | cut -c 3-7 | tr -d ' ' | sort | uniq") |
| mkdir "$TRACEDIR"/adbd_traces |
| |
| adb shell 'setprop persist.adb.trace_mask 0; killall adbd' |
| |
| IFS=$'\n' |
| for PID in $ADBD_PIDS; do |
| cp "$TRACEDIR"/trace/clang-$PID-*.profraw "$TRACEDIR"/adbd_traces 2>/dev/null || true |
| done |
| unset IFS |
| |
| ### Merge the traces. |
| echo "Traces fetched to $TRACEDIR" |
| llvm-profdata merge --output="$OUTPUT_DIR"/adbd.profdata "$TRACEDIR"/adbd_traces/* "$TRACEDIR"/test_traces/* |