Bash程序  |  189行  |  5.8 KB

#!/system/bin/sh
#set -x

###### KNOWN ISSUES ######
# - qbpfs pull is returning $?=0 when it fails
# - AP needs a more deterministic way of detecting the max dumps the BP will
#   store.  Otherwise the script will fail to calculate the rollover back
#   to index 0.

###### FUNCTIONS ######

setupDirs() {
    case $parentExists in
    1)
        outDirRoot=$1
        outDirBranch=$2
        ;;
    0)
        outDirRoot="/data/misc/ril"
        outDirBranch="bp-dump/${timestamp}/qcom"
        cd $outDirRoot
        case $? in 0) ;; *) echo "Couldn\'t cd to $outDirRoot"; exit 1;; esac
        # Set delimiter to slash for separating directories
        OIFS=$IFS; IFS='/'
        for dir in $outDirBranch; do
            mkdir "$dir" 2>/dev/null
            cd "$dir" 2>&1
            case $? in 0) ;; *) echo "Couldn\'t cd to $dir"; exit 1;; esac
            outDirBranchUnwind="$dir $outDirBranchUnwind"
        done
        IFS=$OIFS
        ;;
    esac
    outDir="${outDirRoot}/${outDirBranch}"
}

processLogs() {
    # Initialize communication with the BP
    qbpfs hello
    case $? in 0) ;; *) echo "qbpfs hello failed"; return;; esac

    local maxIndexes=$1
    local nextErrIndex=""
    local indexesToPull=""
    case $maxIndexes in
    0)
        echo "Nothing to do for indexes=0"
        return
        ;;
    1)
        # If we only support one dump, then we can detect when it has finished
        # by first removing the err_index.txt and then watching for it to
        # reappear.
        qbpfs rm "/err/err_index.txt"
        indexesToPull="00"
        nextErrIndex="00"
        ;;
    *)
        # If we support more than one dump, we can watch the index to change.
        qbpfs pull "/err/err_index.txt" "${outDir}/err_index.txt" 2>&1
        local lastErrIndex=`cat ${outDir}/err_index.txt`
        rm "${outDir}/err_index.txt"
        case $maxIndexes in
        2)
            indexesToPull="00 01"
            case $lastErrIndex in
                "") nextErrIndex="00";;
                00) nextErrIndex="01";;
                01) nextErrIndex="00";;
            esac
            ;;
        3)
            indexesToPull="00 01 02"
            case $lastErrIndex in
                "") nextErrIndex="00";;
                00) nextErrIndex="01";;
                01) nextErrIndex="02";;
                02) nextErrIndex="00";;
            esac
            ;;
        4)
            indexesToPull="00 01 02 03"
            case $lastErrIndex in
                "") nextErrIndex="00";;
                00) nextErrIndex="01";;
                01) nextErrIndex="02";;
                02) nextErrIndex="03";;
                03) nextErrIndex="00";;
            esac
            ;;
        *)
            echo "No support for indexes=$maxIndexes"
            return
            ;;
        esac
        ;;
    esac

    # Trigger dump from RAM to EFS
    echo dump_log > /sys/class/radio/mdm6600/command

    local errIndex=""
    # Loop until err_index.txt changes
    for i in 1 2 3 4 5 ; do
        qbpfs ls # This defeats a dir caching bug in the BP
        qbpfs pull "/err/err_index.txt" "${outDir}/err_index.txt" 2>&1
        errIndex=$(cat ${outDir}/err_index.txt)
        rm "${outDir}/err_index.txt"
        case $errIndex in
        $nextErrIndex)
            break
            ;;
        *)
            case $i in
                5) echo "Could not find BP log after $i attempts"; return;;
                *) echo "No change to err_index.txt: $errIndex"; sleep 1;;
            esac
            ;;
        esac
    done

    # Dump err_index.txt
    echo "file:begin:txt:${outDirBranch}/err_index.txt"
    echo "$errIndex"
    echo "file:end:txt:${outDirBranch}/err_index.txt"

    # Do NOT redirect stderr to stdout for bin files.  It may confuse the base64 decoder.
    for i in $indexesToPull ; do
        dataIndexFile="err_data_index${i}_log00.txt"
        qbpfs pull "/err/${dataIndexFile}" "${outDir}/${dataIndexFile}" 2>&1
        case $? in 0) ;; *) echo "qbpfs pull failed for /err/${dataIndexFile}"; continue;; esac
        echo "file:begin:txt:${outDirBranch}/${dataIndexFile}"
        cat "${outDir}/${dataIndexFile}"
        catRes=$?
        echo "file:end:txt:${outDirBranch}/${dataIndexFile}"
        rm "${outDir}/${dataIndexFile}"
        case $catRes in 0) ;; *) echo "cat failed for /err/${dataIndexFile}"; continue;; esac

        binFileExtensions="crs f3 id"
        for ext in $binFileExtensions; do
            binFile="err_f3_index${i}.${ext}"
            qbpfs pull "/err/${binFile}" "${outDir}/${binFile}" 2>&1
            case $? in 0) ;; *) echo "qbpfs pull failed for /err/${binFile}"; continue;; esac
            base64 -e "${outDir}/${binFile}" "${outDir}/${binFile}-base64" 2>&1
            case $? in
            0)
                ;;
            *)
                echo "base64 failed for ${outDir}/${binFile}"
                rm "${outDir}/${binFile}"
                continue
                ;;
            esac
            echo "file:begin:bin:${outDirBranch}/${binFile}"
            cat "${outDir}/${binFile}-base64"
            catRes=$?
            echo "file:end:bin:${outDirBranch}/${binFile}"
            case $catRes in 0) ;; *) "cat failed for ${outDir}/${binFile}-base64";; esac
            rm "${outDir}/${binFile}" "${outDir}/${binFile}-base64"
        done
    done
}

cleanupDirs() {
    case $parentExists in
    0)
        # Cleanup output dirs
        cd $outDir
        case $? in 0) ;; *) echo "Couldn\'t cd to $outDir"; exit 1;; esac
        for dir in $outDirBranchUnwind; do
            cd ..
            rmdir $dir
        done
        ;;
    esac
}

###### MAIN ROUTINE ######

# Generate a timestamp if none passed in from parent script
case $1 in
    "") timestamp=$(date +'%Y-%m-%d_%H-%M-%S'); parentExists=0;;
    *) timestamp=$1; parentExists=1;;
esac

echo "Dumping QCOM BP logs @ $timestamp"
setupDirs $2 $3
processLogs 2
cleanupDirs