124a8c2d6SJoseph Chen#!/bin/bash 224a8c2d6SJoseph Chenset -e 324a8c2d6SJoseph Chen 4acf80986SJoseph ChenARG_COMMIT=$1 56f2bc86dSJoseph ChenDIFF_SUBSET="scripts/.diff_*" 6f3572ad9SJoseph ChenDIFF_DOC_ALL="scripts/.diff_all.txt" 7f3572ad9SJoseph ChenDIFF_DOC_FIXED="scripts/.diff_fixed.txt" 8*2a884fcbSJoseph ChenLAST_SEVERITY= 9*2a884fcbSJoseph ChenLAST_DOC= 10f3572ad9SJoseph Chen 11f3572ad9SJoseph Chenfunction check_doc() 12f3572ad9SJoseph Chen{ 13f3572ad9SJoseph Chen local TOP_SEVERITY LANGUAGE=$1 14f3572ad9SJoseph Chen 15f3572ad9SJoseph Chen if [ "${LANGUAGE}" == "EN" ] ; then 16f3572ad9SJoseph Chen SVT_CRITIAL="critical" 17f3572ad9SJoseph Chen SVT_IMPORTANT="important" 18f3572ad9SJoseph Chen SVT_MODERATE="moderate" 19acf80986SJoseph Chen DOC=`git log ${ARG_COMMIT} -1 --name-only | sed -n "/_EN\.md/p"` 20f3572ad9SJoseph Chen else 21f3572ad9SJoseph Chen SVT_CRITIAL="紧急" 22f3572ad9SJoseph Chen SVT_IMPORTANT="重要" 23f3572ad9SJoseph Chen SVT_MODERATE="普通" 24acf80986SJoseph Chen DOC=`git log ${ARG_COMMIT} -1 --name-only | sed -n "/_CN\.md/p"` 25f3572ad9SJoseph Chen fi 26f3572ad9SJoseph Chen 27f3572ad9SJoseph Chen echo "Checking doc: ${DOC}" 28f3572ad9SJoseph Chen 296f2bc86dSJoseph Chen # check DOS encoding 30acf80986SJoseph Chen git show ${ARG_COMMIT} -1 ${DOC} | sed -n "/^+/p" > ${DIFF_DOC_ALL} 31acf80986SJoseph Chen git show ${ARG_COMMIT} -1 ${DOC} | sed -n "/^+/p" > ${DIFF_DOC_ALL}.dos 326f2bc86dSJoseph Chen dos2unix ${DIFF_DOC_ALL}.dos >/dev/null 2>&1 336f2bc86dSJoseph Chen CSUM1=`md5sum ${DIFF_DOC_ALL} | awk '{ print $1 }'` 346f2bc86dSJoseph Chen CSUM2=`md5sum ${DIFF_DOC_ALL}.dos | awk '{ print $1 }'` 356f2bc86dSJoseph Chen if [ "${CSUM1}" != "${CSUM2}" ]; then 366f2bc86dSJoseph Chen echo "ERROR: ${DOC} is DOS encoding. Fix it by: 'dos2unix ${DOC}'" 376f2bc86dSJoseph Chen exit 1 386f2bc86dSJoseph Chen fi 396f2bc86dSJoseph Chen 40f3572ad9SJoseph Chen TITLE=`sed -n "/^+## /p" ${DIFF_DOC_ALL} | tr -d " +#"` 41f3572ad9SJoseph Chen FILE=`sed -n "/^+| 20[0-9][0-9]-/p" ${DIFF_DOC_ALL} | tr -d " " | awk -F "|" '{ print $3 }'` 42f3572ad9SJoseph Chen COMMIT=`sed -n "/^+| 20[0-9][0-9]-/p" ${DIFF_DOC_ALL} | tr -d " " | awk -F "|" '{ print $4 }'` 43f3572ad9SJoseph Chen SEVERITY=`sed -n "/^+| 20[0-9][0-9]-/p" ${DIFF_DOC_ALL} | tr -d " " | awk -F "|" '{ print $5 }'` 44f3572ad9SJoseph Chen HORIZONTAL_LINE=`sed -n "/^+------$/p" ${DIFF_DOC_ALL}` 45f3572ad9SJoseph Chen # echo "### ${COMMIT}, ${SEVERITY}, ${TITLE}, ${FILE}" 46f3572ad9SJoseph Chen 47407510a0SJoseph Chen # check blank line after Heading 1 48407510a0SJoseph Chen HEADING_1=`sed -n '1p' ${DOC}` 49407510a0SJoseph Chen if sed -n '2p' ${DOC} | grep -q [a-z,A-Z] ; then 50407510a0SJoseph Chen echo "ERROR: ${DOC}: Should reserve blank line after '${HEADING_1}'" 51407510a0SJoseph Chen exit 1 52407510a0SJoseph Chen fi 53407510a0SJoseph Chen 548e4858bdSJoseph Chen # check space 558e4858bdSJoseph Chen if sed -n "/##/p" ${DOC} | grep -v '## [a-z,A-Z]' ; then 568e4858bdSJoseph Chen echo "ERROR: ${DOC}: Should only 1 space between '#' and word" 578e4858bdSJoseph Chen exit 1 588e4858bdSJoseph Chen fi 598e4858bdSJoseph Chen 600287fa94SJoseph Chen # check new content location 61acf80986SJoseph Chen if ! git show ${ARG_COMMIT} -1 ${DOC} | grep -q 'Release Note' ; then 620287fa94SJoseph Chen echo "ERROR: ${DOC}: Adding new content at the top but not bottom" 630287fa94SJoseph Chen exit 1 640287fa94SJoseph Chen fi 650287fa94SJoseph Chen 660287fa94SJoseph Chen # check TAB before index of 'New' body 670287fa94SJoseph Chen if grep -q $'\t[0-9]' ${DOC} ; then 680287fa94SJoseph Chen echo "ERROR: ${DOC}: Don't add TAB before index:" 690287fa94SJoseph Chen grep $'\t[0-9]' ${DOC} 700287fa94SJoseph Chen exit 1 710287fa94SJoseph Chen fi 720287fa94SJoseph Chen 732d300a6dSJoseph Chen # check space after index of 'New' body 742d300a6dSJoseph Chen SUM1=`grep '^[0-9]\.' ${DOC} | wc -l` 752d300a6dSJoseph Chen SUM2=`grep '^[0-9]\.[[:blank:]]' ${DOC} | wc -l` 762d300a6dSJoseph Chen if [ "$SUM1" != "$SUM2" ]; then 772d300a6dSJoseph Chen echo "ERROR: ${DOC}: Please add space after index (e.g: '1. ' but not '1.'):" 782d300a6dSJoseph Chen grep '^+[0-9]\.' ${DIFF_DOC_ALL} 792d300a6dSJoseph Chen exit 1 802d300a6dSJoseph Chen fi 812d300a6dSJoseph Chen 82f3572ad9SJoseph Chen # check standalone file 83fd99385aSJoseph Chen if ! echo ${FILE} | grep -Eq '\.bin|\.elf|\.img' ; then 84fd99385aSJoseph Chen echo "ERROR: ${DOC}: '${FILE}' missing the file format suffix" 85fd99385aSJoseph Chen exit 1 86fd99385aSJoseph Chen fi 87f3572ad9SJoseph Chen if ! echo ${FILE} | grep -q { ; then 88acf80986SJoseph Chen if ! git log ${ARG_COMMIT} -1 --name-only | grep -q ${FILE}; then 890f8ea74fSJoseph Chen echo "ERROR: ${DOC}: '${FILE}' is not updated in this patch" 90f3572ad9SJoseph Chen exit 1 91f3572ad9SJoseph Chen fi 92f3572ad9SJoseph Chen fi 93f3572ad9SJoseph Chen 94f3572ad9SJoseph Chen # check title 95f3572ad9SJoseph Chen if [ "${TITLE}" != "${FILE}" ]; then 96f3572ad9SJoseph Chen echo "ERROR: ${DOC}: Title '${TITLE}' is not match with '${FILE}'" 97f3572ad9SJoseph Chen exit 1 98f3572ad9SJoseph Chen fi 99f3572ad9SJoseph Chen 100f3572ad9SJoseph Chen # check commit 101f3572ad9SJoseph Chen COMMIT=${COMMIT//#/ } 102f3572ad9SJoseph Chen for LIST in ${COMMIT}; do 103f3572ad9SJoseph Chen CMT=`echo ${LIST} | cut -d : -f 2` 104acf80986SJoseph Chen if ! git log ${ARG_COMMIT} -1 | grep -q ${CMT} ; then 1052d300a6dSJoseph Chen echo "ERROR: ${DOC}: '${CMT}' is not match in commit message" 106f3572ad9SJoseph Chen exit 1 107f3572ad9SJoseph Chen fi 10839bfe203SJoseph Chen 10939bfe203SJoseph Chen if ! echo ${FILE} | grep -q { ; then 11039bfe203SJoseph Chen if echo ${FILE} | grep -Eq 'spl_|tpl_|bl31_|bl32_|tee_' ; then 11139bfe203SJoseph Chen FILE_PATH=`find -name ${FILE}` 112acf80986SJoseph Chen if [ -z "${FILE_PATH}" ]; then 113acf80986SJoseph Chen echo "ERROR: ${DOC}: No ${FILE}" 114acf80986SJoseph Chen exit 1 115acf80986SJoseph Chen fi 11639bfe203SJoseph Chen if ! strings ${FILE_PATH} | grep -q ${CMT} ; then 11739bfe203SJoseph Chen echo "ERROR: ${DOC}: ${FILE} is not build from '${CMT}'" 11839bfe203SJoseph Chen exit 1 11939bfe203SJoseph Chen fi 12039bfe203SJoseph Chen fi 12139bfe203SJoseph Chen fi 122f3572ad9SJoseph Chen done 123f3572ad9SJoseph Chen 124f3572ad9SJoseph Chen # check severity 125f3572ad9SJoseph Chen if [ "${SEVERITY}" != "${SVT_CRITIAL}" -a "${SEVERITY}" != "${SVT_IMPORTANT}" -a "${SEVERITY}" != "${SVT_MODERATE}" ]; then 126f3572ad9SJoseph Chen echo "ERROR: ${DOC}: Unknown main severity: ${SEVERITY}" 127f3572ad9SJoseph Chen exit 1 128f3572ad9SJoseph Chen fi 129f3572ad9SJoseph Chen 130f3572ad9SJoseph Chen # check horizontal line 131f3572ad9SJoseph Chen if [ -z "${HORIZONTAL_LINE}" ]; then 1320f8ea74fSJoseph Chen echo "ERROR: ${DOC}: No horizontal line '------' at the last of new content" 133f3572ad9SJoseph Chen exit 1 134f3572ad9SJoseph Chen fi 135f3572ad9SJoseph Chen 136f3572ad9SJoseph Chen # check 'Fixed' content 137f3572ad9SJoseph Chen if grep -q "^+### Fixed" ${DIFF_DOC_ALL} ; then 138f3572ad9SJoseph Chen awk -v RS='### Fixed' 'END{printf "%s", $0}' ${DIFF_DOC_ALL} > ${DIFF_DOC_FIXED} 139f3572ad9SJoseph Chen sed -i "/^$/d" ${DIFF_DOC_FIXED} 140f3572ad9SJoseph Chen sed -i "/Index/d" ${DIFF_DOC_FIXED} 141f3572ad9SJoseph Chen sed -i "/---/d" ${DIFF_DOC_FIXED} 142f3572ad9SJoseph Chen sed -i "/^+$/d" ${DIFF_DOC_FIXED} 143f3572ad9SJoseph Chen 144f3572ad9SJoseph Chen while read LINE 145f3572ad9SJoseph Chen do 146f3572ad9SJoseph Chen EACH_SEVERITY=`echo "${LINE}" | awk -F "|" '{ print $3 }' | tr -d " "` 147f3572ad9SJoseph Chen if [ "${EACH_SEVERITY}" != "${SVT_CRITIAL}" -a "${EACH_SEVERITY}" != "${SVT_IMPORTANT}" -a "${EACH_SEVERITY}" != "${SVT_MODERATE}" ]; then 148f3572ad9SJoseph Chen echo "ERROR: ${DOC}: Unknown severity: ${EACH_SEVERITY}" 149f3572ad9SJoseph Chen exit 1 150f3572ad9SJoseph Chen fi 151f3572ad9SJoseph Chen 152f3572ad9SJoseph Chen # echo "## EACH: $EACH_SEVERITY" 153f3572ad9SJoseph Chen if [ -z "${TOP_SEVERITY}" ]; then 154f3572ad9SJoseph Chen TOP_SEVERITY="${EACH_SEVERITY}" 155f3572ad9SJoseph Chen elif [ "${TOP_SEVERITY}" == "${SVT_MODERATE}" ]; then 156f3572ad9SJoseph Chen if [ "${EACH_SEVERITY}" == "${SVT_CRITIAL}" -o "${EACH_SEVERITY}" == "${SVT_IMPORTANT}" ]; then 157f3572ad9SJoseph Chen TOP_SEVERITY="${EACH_SEVERITY}" 158f3572ad9SJoseph Chen fi 159f3572ad9SJoseph Chen elif [ "${TOP_SEVERITY}" == "${SVT_IMPORTANT}" ]; then 160f3572ad9SJoseph Chen if [ "${EACH_SEVERITY}" == "${SVT_CRITIAL}" ]; then 161f3572ad9SJoseph Chen TOP_SEVERITY="${EACH_SEVERITY}" 162f3572ad9SJoseph Chen fi 163f3572ad9SJoseph Chen fi 164f3572ad9SJoseph Chen done < ${DIFF_DOC_FIXED} 165f3572ad9SJoseph Chen 166f3572ad9SJoseph Chen if [ "${SEVERITY}" != "${TOP_SEVERITY}" ]; then 167*2a884fcbSJoseph Chen echo "ERROR: ${DOC}: Top severity should be '${TOP_SEVERITY}' as it's the highest level of all sub severity" 168f3572ad9SJoseph Chen exit 1 169f3572ad9SJoseph Chen fi 170*2a884fcbSJoseph Chen 171*2a884fcbSJoseph Chen # check top severity miss match 172*2a884fcbSJoseph Chen if [ ! -z ${LAST_SEVERITY} ]; then 173*2a884fcbSJoseph Chen if [ "${LAST_SEVERITY}" == "普通" -a "${TOP_SEVERITY}" != "moderate" ]; then 174*2a884fcbSJoseph Chen MISS_MATCH="y" 175*2a884fcbSJoseph Chen elif [ "${LAST_SEVERITY}" == "重要" -a "${TOP_SEVERITY}" != "important" ]; then 176*2a884fcbSJoseph Chen MISS_MATCH="y" 177*2a884fcbSJoseph Chen elif [ "${LAST_SEVERITY}" == "紧急" -a "${TOP_SEVERITY}" != "critical" ]; then 178*2a884fcbSJoseph Chen MISS_MATCH="y" 179*2a884fcbSJoseph Chen elif [ "${LAST_SEVERITY}" == "moderate" -a "${TOP_SEVERITY}" != "普通" ]; then 180*2a884fcbSJoseph Chen MISS_MATCH="y" 181*2a884fcbSJoseph Chen elif [ "${LAST_SEVERITY}" == "important" -a "${TOP_SEVERITY}" != "重要" ]; then 182*2a884fcbSJoseph Chen MISS_MATCH="y" 183*2a884fcbSJoseph Chen elif [ "${LAST_SEVERITY}" == "critical" -a "${TOP_SEVERITY}" != "紧急" ]; then 184*2a884fcbSJoseph Chen MISS_MATCH="y" 185*2a884fcbSJoseph Chen fi 186*2a884fcbSJoseph Chen 187*2a884fcbSJoseph Chen if [ ${MISS_MATCH} == "y" ]; then 188*2a884fcbSJoseph Chen echo "ERROR: ${DOC}: top Severity is '${SEVERITY}', while ${LAST_DOC}: top Severity is '${LAST_SEVERITY}'" 189*2a884fcbSJoseph Chen echo " Available Severity types are: moderate(普通), important(重要), critical(紧急)" 190*2a884fcbSJoseph Chen exit 1 191*2a884fcbSJoseph Chen fi 192*2a884fcbSJoseph Chen fi 193*2a884fcbSJoseph Chen 194*2a884fcbSJoseph Chen LAST_SEVERITY="${SEVERITY}" 195*2a884fcbSJoseph Chen LAST_DOC="${DOC}" 196f3572ad9SJoseph Chen fi 197f3572ad9SJoseph Chen} 198f3572ad9SJoseph Chen 199f3572ad9SJoseph Chenfunction check_docs() 200f3572ad9SJoseph Chen{ 201acf80986SJoseph Chen if git log ${ARG_COMMIT} -1 --name-only | grep -Eq '\.bin|\.elf' ; then 202acf80986SJoseph Chen DOC_CN=`git log ${ARG_COMMIT} -1 --name-only | sed -n "/_CN\.md/p"` 203acf80986SJoseph Chen DOC_EN=`git log ${ARG_COMMIT} -1 --name-only | sed -n "/_EN\.md/p"` 204f3572ad9SJoseph Chen if [ -z "${DOC_CN}" -o -z "${DOC_EN}" ]; then 205acf80986SJoseph Chen echo "ERROR: Should update CN and EN Release-Note when .bin/elf changed" 206f3572ad9SJoseph Chen exit 1 207f3572ad9SJoseph Chen fi 208755bd534SJoseph Chen 209755bd534SJoseph Chen if ! which dos2unix > /dev/null 2>&1 ; then 210755bd534SJoseph Chen echo "ERROR: No 'dos2unix'. Fix by: sudo apt-get install dos2unix" 211755bd534SJoseph Chen exit 1 212755bd534SJoseph Chen fi 213755bd534SJoseph Chen 214f3572ad9SJoseph Chen check_doc CN 215f3572ad9SJoseph Chen check_doc EN 216f3572ad9SJoseph Chen fi 2176f2bc86dSJoseph Chen 2186f2bc86dSJoseph Chen rm -f ${DIFF_SUBSET} 219f3572ad9SJoseph Chen} 220f3572ad9SJoseph Chen 22115aaf94fSJoseph Chenfunction pack_loader_image() 22224a8c2d6SJoseph Chen{ 22315aaf94fSJoseph Chen for FILE in `ls ./RKBOOT/*MINIALL*.ini` 22424a8c2d6SJoseph Chen do 22515aaf94fSJoseph Chen if [ "${FILE}" = "./RKBOOT/RK302AMINIALL.ini" -o \ 22615aaf94fSJoseph Chen "${FILE}" = "./RKBOOT/RK30BMINIALL.ini" -o \ 22715aaf94fSJoseph Chen "${FILE}" = "./RKBOOT/RK30MINIALL.ini" -o \ 22815aaf94fSJoseph Chen "${FILE}" = "./RKBOOT/RK310BMINIALL.ini" ]; then 22924a8c2d6SJoseph Chen continue; 23024a8c2d6SJoseph Chen fi 23124a8c2d6SJoseph Chen 23215aaf94fSJoseph Chen if grep -q '^PATH=img/' ${FILE}; then 23307c86261SJoseph Chen continue; 23407c86261SJoseph Chen fi 23507c86261SJoseph Chen 23615aaf94fSJoseph Chen echo "Pack loader: ${FILE}" 23715aaf94fSJoseph Chen ./tools/boot_merger ${FILE} 238f3822d68SJoseph Chen rm -f *loader*.bin *download*.bin *idblock*.img 23924a8c2d6SJoseph Chen echo 24024a8c2d6SJoseph Chen done 24124a8c2d6SJoseph Chen} 24224a8c2d6SJoseph Chen 24315aaf94fSJoseph Chenfunction pack_trust_image() 24424a8c2d6SJoseph Chen{ 24524a8c2d6SJoseph Chen # Pack 32-bit trust 24615aaf94fSJoseph Chen for FILE in `ls ./RKTRUST/*TOS*.ini` 24724a8c2d6SJoseph Chen do 24815aaf94fSJoseph Chen if ! test -s ${FILE}; then 249075296bdSJoseph Chen continue; 25015aaf94fSJoseph Chen elif ! grep -q 'TOS' ${FILE}; then 251d4bf7444SJoseph Chen continue; 25215aaf94fSJoseph Chen elif grep -q '^PATH=img/' ${FILE}; then 25307c86261SJoseph Chen continue; 25407c86261SJoseph Chen fi 25507c86261SJoseph Chen 25615aaf94fSJoseph Chen echo "Pack trust: ${FILE}" 25724a8c2d6SJoseph Chen # Parse orignal path 25815aaf94fSJoseph Chen TOS=`sed -n "/TOS=/s/TOS=//p" ${FILE}|tr -d '\r'` 25915aaf94fSJoseph Chen TOS_TA=`sed -n "/TOSTA=/s/TOSTA=//p" ${FILE}|tr -d '\r'` 26024a8c2d6SJoseph Chen 26124a8c2d6SJoseph Chen # replace "./tools/rk_tools/" with "./" to compatible legacy ini content of rkdevelop branch 26224a8c2d6SJoseph Chen TOS=$(echo ${TOS} | sed "s/tools\/rk_tools\//\.\//g") 26324a8c2d6SJoseph Chen TOS_TA=$(echo ${TOS_TA} | sed "s/tools\/rk_tools\//\.\//g") 26424a8c2d6SJoseph Chen 2659d00b70aSJoseph Chen if [ x${TOS_TA} != x -a x${TOS} != x ]; then 26624a8c2d6SJoseph Chen ./tools/loaderimage --pack --trustos ${TOS} ./trust.img 0x68400000 26724a8c2d6SJoseph Chen ./tools/loaderimage --pack --trustos ${TOS_TA} ./trust_with_ta.img 0x68400000 2689d00b70aSJoseph Chen elif [ ${TOS} ]; then 26924a8c2d6SJoseph Chen ./tools/loaderimage --pack --trustos ${TOS} ./trust.img 0x68400000 2709d00b70aSJoseph Chen elif [ ${TOS_TA} ]; then 27124a8c2d6SJoseph Chen ./tools/loaderimage --pack --trustos ${TOS_TA} ./trust.img 0x68400000 27224a8c2d6SJoseph Chen else 27324a8c2d6SJoseph Chen exit 1 27424a8c2d6SJoseph Chen fi 275f3822d68SJoseph Chen rm -f trust*.img 27624a8c2d6SJoseph Chen echo 27724a8c2d6SJoseph Chen done 27824a8c2d6SJoseph Chen 27924a8c2d6SJoseph Chen # Pack 64-bit trust 28015aaf94fSJoseph Chen for FILE in `ls ./RKTRUST/*TRUST*.ini` 28124a8c2d6SJoseph Chen do 28215aaf94fSJoseph Chen if grep -q '^PATH=img/' ${FILE}; then 28307c86261SJoseph Chen continue; 28407c86261SJoseph Chen fi 28507c86261SJoseph Chen 28615aaf94fSJoseph Chen echo "Pack trust: ${FILE}" 28715aaf94fSJoseph Chen ./tools/trust_merger ${FILE} 28815aaf94fSJoseph Chen rm -f trust*.img 28924a8c2d6SJoseph Chen echo 29024a8c2d6SJoseph Chen done 29124a8c2d6SJoseph Chen} 29224a8c2d6SJoseph Chen 29315aaf94fSJoseph Chenfunction check_dirty() 2947448aaf2SJoseph Chen{ 295f3572ad9SJoseph Chen for FILE in `find -name '*spl*.bin' -o -name '*tpl*.bin' -o -name '*usbplug*.bin' -o -name '*bl31*.elf' -o -name '*bl32*.bin'`; do 296f3572ad9SJoseph Chen echo "Checking clean: ${FILE}" 29715aaf94fSJoseph Chen if strings ${FILE} | grep '\-dirty ' ; then 29815aaf94fSJoseph Chen echo "ERROR: ${FILE} is dirty" 2997448aaf2SJoseph Chen exit 1 3007448aaf2SJoseph Chen fi 3017448aaf2SJoseph Chen done 3027448aaf2SJoseph Chen} 3037448aaf2SJoseph Chen 30415aaf94fSJoseph Chenfunction check_stripped() 305c0efc7efSJoseph Chen{ 30615aaf94fSJoseph Chen for FILE in `find -name '*bl31*.elf'`; do 30715aaf94fSJoseph Chen echo "Checking strip: ${FILE}" 30815aaf94fSJoseph Chen INFO=`file ${FILE}` 30915aaf94fSJoseph Chen if echo ${INFO} | grep -q "not stripped" ; then 31015aaf94fSJoseph Chen echo "ERROR: ${FILE} is not stripped" 311c0efc7efSJoseph Chen exit 1 312c0efc7efSJoseph Chen fi 313c0efc7efSJoseph Chen done 314c0efc7efSJoseph Chen} 315c0efc7efSJoseph Chen 316f3572ad9SJoseph Chenfunction check_mode() 317f3572ad9SJoseph Chen{ 318f3572ad9SJoseph Chen echo "Checking file mode..." 319acf80986SJoseph Chen if git whatchanged ${ARG_COMMIT} -1 --oneline | sed -n '/RKBOOT\//p; /RKTRUST\//p; /bin\//p; /doc\//p;' | awk '{ print $2 }' | grep -q 755 ; then 320acf80986SJoseph Chen git whatchanged ${ARG_COMMIT} -1 --oneline | sed -n '/RKBOOT\//p; /RKTRUST\//p; /bin\//p; /doc\//p;' | grep 755 3210f8ea74fSJoseph Chen echo "ERROR: Set 644 file permission but not 755." 322f3572ad9SJoseph Chen exit 1 323f3572ad9SJoseph Chen fi 324f3572ad9SJoseph Chen} 325f3572ad9SJoseph Chen 32615aaf94fSJoseph Chenfunction finish() 32724a8c2d6SJoseph Chen{ 328f3572ad9SJoseph Chen echo "OK, everything is nice." 32924a8c2d6SJoseph Chen echo 33024a8c2d6SJoseph Chen} 33124a8c2d6SJoseph Chen 332f3572ad9SJoseph Chencheck_mode 333f3572ad9SJoseph Chencheck_docs 3347448aaf2SJoseph Chencheck_dirty 335c0efc7efSJoseph Chencheck_stripped 33624a8c2d6SJoseph Chenpack_loader_image 33724a8c2d6SJoseph Chenpack_trust_image 33824a8c2d6SJoseph Chenfinish 339