Home | History | Annotate | Download | only in tools
      1 #!/bin/bash
      2 #
      3 # Copyright (C) 2009 The Android Open Source Project
      4 #
      5 # Licensed under the Apache License, Version 2.0 (the "License");
      6 # you may not use this file except in compliance with the License.
      7 # You may obtain a copy of the License at
      8 #
      9 #      http://www.apache.org/licenses/LICENSE-2.0
     10 #
     11 # Unless required by applicable law or agreed to in writing, software
     12 # distributed under the License is distributed on an "AS IS" BASIS,
     13 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     14 # See the License for the specific language governing permissions and
     15 # limitations under the License.
     16 
     17 #
     18 # This tool checks the integrity of the optimized dex files on a single
     19 # Android device connected to your computer.
     20 #
     21 # Brief HOW-TO:
     22 #
     23 # 1. Disconnect all but one device from USB.
     24 # 2. Set up a standard shell environment (envsetup.sh, lunch, etc.).
     25 # 3. Run "adb root" if necessary to ensure read permission on
     26 #    /data/dalvik-cache. If in doubt, run the command. Power users may
     27 #    also use "su" followed by "chmod 777 /data/dalvik-cache".
     28 # 4. Run this script, e.g. from the build root, "dalvik/tools/dexcheck".
     29 #
     30 # If all of the dex files are okay, you will just see a series of
     31 # lines written to your shell window naming each of the files. If
     32 # there is a problem, though, you will see something like this:
     33 #
     34 #     system@app (at] Maps.apk@classes.dex
     35 #     Failure in system@app (at] Maps.apk@classes.dex: ERROR: DEX parse failed
     36 #
     37 # When this happens, the log ("adb logcat") will generally have at
     38 # least a little more information about the dex level of the problem.
     39 # However, any error at all usually indicates some form of lower level
     40 # filesystem or filesystem cache corruption.
     41 #
     42 
     43 # Get the list of files.  Use "sed" to drop the trailing carriage return.
     44 files=`adb shell "cd /data/dalvik-cache; echo *" | sed -e s/.$//`
     45 if [ "$files" = "*" ]; then
     46     echo 'ERROR: commands must run as root on device (try "adb root" first?)'
     47     exit 1
     48 fi
     49 
     50 failure=0
     51 
     52 # Check each file in turn.  This is much faster with "dexdump -c", but that
     53 # flag was not available in 1.6 and earlier.
     54 #
     55 # The dexdump found in older builds does not stop on checksum failures and
     56 # will likely crash.
     57 for file in $files; do
     58     echo $file
     59     errout=`adb shell "dexdump /data/dalvik-cache/$file > dev/null"`
     60     errcount=`echo $errout | wc -w` > /dev/null
     61     if [ $errcount != "0" ]; then
     62         echo "  Failure in $file: $errout"
     63         failure=1
     64     fi
     65 done
     66 
     67 exit $failure
     68