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" 82a884fcbSJoseph ChenLAST_SEVERITY= 92a884fcbSJoseph 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 666c6cd5efSJoseph Chen # check title 676c6cd5efSJoseph Chen if grep -Eq '### NEW|### new' ${DIFF_DOC_ALL} ; then 686c6cd5efSJoseph Chen echo "ERROR: ${DOC}: Please use '### New'" 696c6cd5efSJoseph Chen exit 1 706c6cd5efSJoseph Chen fi 716c6cd5efSJoseph Chen 726c6cd5efSJoseph Chen if grep -Eq '### FIXED|### fixed' ${DIFF_DOC_ALL} ; then 736c6cd5efSJoseph Chen echo "ERROR: ${DOC}: Please use '### Fixed'" 746c6cd5efSJoseph Chen exit 1 756c6cd5efSJoseph Chen fi 766c6cd5efSJoseph Chen 770287fa94SJoseph Chen # check TAB before index of 'New' body 780287fa94SJoseph Chen if grep -q $'\t[0-9]' ${DOC} ; then 790287fa94SJoseph Chen echo "ERROR: ${DOC}: Don't add TAB before index:" 800287fa94SJoseph Chen grep $'\t[0-9]' ${DOC} 810287fa94SJoseph Chen exit 1 820287fa94SJoseph Chen fi 830287fa94SJoseph Chen 8477aaba73SJoseph Chen # check upper case and line end 8577aaba73SJoseph Chen if [ "${LANGUAGE}" == "EN" ] ; then 8677aaba73SJoseph Chen if grep -q '^[0-9]\. [a-z]' ${DOC} ; then 8777aaba73SJoseph Chen echo "ERROR: ${DOC}: Please use upper case of first word(i.e. \"1. add ..\" => \"1. Add ...\"):" 8877aaba73SJoseph Chen grep '^[0-9]\. [a-z]' ${DOC} 8977aaba73SJoseph Chen exit 1 9077aaba73SJoseph Chen fi 9177aaba73SJoseph Chen 9277aaba73SJoseph Chen # check end with '.' 9377aaba73SJoseph Chen if sed -n '/^[0-9]\. [A-Z]/p' ${DOC} | grep -q '[^.]$' ; then 9477aaba73SJoseph Chen echo "ERROR: ${DOC}: Please end line with '.'" 9577aaba73SJoseph Chen grep '^[0-9]\. [A-Z]' ${DOC} | grep '[^.]$' 9677aaba73SJoseph Chen exit 1 9777aaba73SJoseph Chen fi 9877aaba73SJoseph Chen else 9977aaba73SJoseph Chen # check end with '。' 10077aaba73SJoseph Chen if sed -n '/^[0-9]\. /p' ${DOC} | grep -q '[^。]$' ; then 10177aaba73SJoseph Chen echo "ERROR: ${DOC}: Please end line with '。'" 10277aaba73SJoseph Chen grep '^[0-9]\. ' ${DOC} | grep '[^。]$' 10377aaba73SJoseph Chen exit 1 10477aaba73SJoseph Chen fi 10577aaba73SJoseph Chen fi 10677aaba73SJoseph Chen 1072d300a6dSJoseph Chen # check space after index of 'New' body 1082d300a6dSJoseph Chen SUM1=`grep '^[0-9]\.' ${DOC} | wc -l` 1092d300a6dSJoseph Chen SUM2=`grep '^[0-9]\.[[:blank:]]' ${DOC} | wc -l` 1102d300a6dSJoseph Chen if [ "$SUM1" != "$SUM2" ]; then 1112d300a6dSJoseph Chen echo "ERROR: ${DOC}: Please add space after index (e.g: '1. ' but not '1.'):" 1122d300a6dSJoseph Chen grep '^+[0-9]\.' ${DIFF_DOC_ALL} 1132d300a6dSJoseph Chen exit 1 1142d300a6dSJoseph Chen fi 1152d300a6dSJoseph Chen 116f3572ad9SJoseph Chen # check standalone file 117fd99385aSJoseph Chen if ! echo ${FILE} | grep -Eq '\.bin|\.elf|\.img' ; then 118fd99385aSJoseph Chen echo "ERROR: ${DOC}: '${FILE}' missing the file format suffix" 119fd99385aSJoseph Chen exit 1 120fd99385aSJoseph Chen fi 121f3572ad9SJoseph Chen if ! echo ${FILE} | grep -q { ; then 122acf80986SJoseph Chen if ! git log ${ARG_COMMIT} -1 --name-only | grep -q ${FILE}; then 1230f8ea74fSJoseph Chen echo "ERROR: ${DOC}: '${FILE}' is not updated in this patch" 124f3572ad9SJoseph Chen exit 1 125f3572ad9SJoseph Chen fi 126f3572ad9SJoseph Chen fi 127f3572ad9SJoseph Chen 128f3572ad9SJoseph Chen # check title 129f3572ad9SJoseph Chen if [ "${TITLE}" != "${FILE}" ]; then 130f3572ad9SJoseph Chen echo "ERROR: ${DOC}: Title '${TITLE}' is not match with '${FILE}'" 131f3572ad9SJoseph Chen exit 1 132f3572ad9SJoseph Chen fi 133f3572ad9SJoseph Chen 134f3572ad9SJoseph Chen # check commit 135f3572ad9SJoseph Chen COMMIT=${COMMIT//#/ } 136f3572ad9SJoseph Chen for LIST in ${COMMIT}; do 137f3572ad9SJoseph Chen CMT=`echo ${LIST} | cut -d : -f 2` 138acf80986SJoseph Chen if ! git log ${ARG_COMMIT} -1 | grep -q ${CMT} ; then 1392d300a6dSJoseph Chen echo "ERROR: ${DOC}: '${CMT}' is not match in commit message" 140f3572ad9SJoseph Chen exit 1 141f3572ad9SJoseph Chen fi 14239bfe203SJoseph Chen 14339bfe203SJoseph Chen if ! echo ${FILE} | grep -q { ; then 14439bfe203SJoseph Chen if echo ${FILE} | grep -Eq 'spl_|tpl_|bl31_|bl32_|tee_' ; then 14539bfe203SJoseph Chen FILE_PATH=`find -name ${FILE}` 146acf80986SJoseph Chen if [ -z "${FILE_PATH}" ]; then 147acf80986SJoseph Chen echo "ERROR: ${DOC}: No ${FILE}" 148acf80986SJoseph Chen exit 1 149acf80986SJoseph Chen fi 15039bfe203SJoseph Chen if ! strings ${FILE_PATH} | grep -q ${CMT} ; then 15139bfe203SJoseph Chen echo "ERROR: ${DOC}: ${FILE} is not build from '${CMT}'" 15239bfe203SJoseph Chen exit 1 15339bfe203SJoseph Chen fi 15439bfe203SJoseph Chen fi 15539bfe203SJoseph Chen fi 156f3572ad9SJoseph Chen done 157f3572ad9SJoseph Chen 158f3572ad9SJoseph Chen # check severity 159f3572ad9SJoseph Chen if [ "${SEVERITY}" != "${SVT_CRITIAL}" -a "${SEVERITY}" != "${SVT_IMPORTANT}" -a "${SEVERITY}" != "${SVT_MODERATE}" ]; then 160f3572ad9SJoseph Chen echo "ERROR: ${DOC}: Unknown main severity: ${SEVERITY}" 161f3572ad9SJoseph Chen exit 1 162f3572ad9SJoseph Chen fi 163f3572ad9SJoseph Chen 164f3572ad9SJoseph Chen # check horizontal line 165f3572ad9SJoseph Chen if [ -z "${HORIZONTAL_LINE}" ]; then 1660f8ea74fSJoseph Chen echo "ERROR: ${DOC}: No horizontal line '------' at the last of new content" 167f3572ad9SJoseph Chen exit 1 168f3572ad9SJoseph Chen fi 169f3572ad9SJoseph Chen 170f3572ad9SJoseph Chen # check 'Fixed' content 171f3572ad9SJoseph Chen if grep -q "^+### Fixed" ${DIFF_DOC_ALL} ; then 172f3572ad9SJoseph Chen awk -v RS='### Fixed' 'END{printf "%s", $0}' ${DIFF_DOC_ALL} > ${DIFF_DOC_FIXED} 173f3572ad9SJoseph Chen sed -i "/^$/d" ${DIFF_DOC_FIXED} 174f3572ad9SJoseph Chen sed -i "/Index/d" ${DIFF_DOC_FIXED} 175f3572ad9SJoseph Chen sed -i "/---/d" ${DIFF_DOC_FIXED} 176f3572ad9SJoseph Chen sed -i "/^+$/d" ${DIFF_DOC_FIXED} 177f3572ad9SJoseph Chen 178f3572ad9SJoseph Chen while read LINE 179f3572ad9SJoseph Chen do 180f3572ad9SJoseph Chen EACH_SEVERITY=`echo "${LINE}" | awk -F "|" '{ print $3 }' | tr -d " "` 181f3572ad9SJoseph Chen if [ "${EACH_SEVERITY}" != "${SVT_CRITIAL}" -a "${EACH_SEVERITY}" != "${SVT_IMPORTANT}" -a "${EACH_SEVERITY}" != "${SVT_MODERATE}" ]; then 182*13413eecSJoseph Chen if [ -z "${EACH_SEVERITY}" ]; then 183*13413eecSJoseph Chen echo "ERROR: ${DOC}: No severity found, please use Table to list what you '### Fixed'" 184*13413eecSJoseph Chen else 185f3572ad9SJoseph Chen echo "ERROR: ${DOC}: Unknown severity: ${EACH_SEVERITY}" 186*13413eecSJoseph Chen fi 187f3572ad9SJoseph Chen exit 1 188f3572ad9SJoseph Chen fi 189f3572ad9SJoseph Chen 190f3572ad9SJoseph Chen # echo "## EACH: $EACH_SEVERITY" 191f3572ad9SJoseph Chen if [ -z "${TOP_SEVERITY}" ]; then 192f3572ad9SJoseph Chen TOP_SEVERITY="${EACH_SEVERITY}" 193f3572ad9SJoseph Chen elif [ "${TOP_SEVERITY}" == "${SVT_MODERATE}" ]; then 194f3572ad9SJoseph Chen if [ "${EACH_SEVERITY}" == "${SVT_CRITIAL}" -o "${EACH_SEVERITY}" == "${SVT_IMPORTANT}" ]; then 195f3572ad9SJoseph Chen TOP_SEVERITY="${EACH_SEVERITY}" 196f3572ad9SJoseph Chen fi 197f3572ad9SJoseph Chen elif [ "${TOP_SEVERITY}" == "${SVT_IMPORTANT}" ]; then 198f3572ad9SJoseph Chen if [ "${EACH_SEVERITY}" == "${SVT_CRITIAL}" ]; then 199f3572ad9SJoseph Chen TOP_SEVERITY="${EACH_SEVERITY}" 200f3572ad9SJoseph Chen fi 201f3572ad9SJoseph Chen fi 202f3572ad9SJoseph Chen done < ${DIFF_DOC_FIXED} 203f3572ad9SJoseph Chen 204f3572ad9SJoseph Chen if [ "${SEVERITY}" != "${TOP_SEVERITY}" ]; then 2052a884fcbSJoseph Chen echo "ERROR: ${DOC}: Top severity should be '${TOP_SEVERITY}' as it's the highest level of all sub severity" 206f3572ad9SJoseph Chen exit 1 207f3572ad9SJoseph Chen fi 2082a884fcbSJoseph Chen 2092a884fcbSJoseph Chen # check top severity miss match 2102a884fcbSJoseph Chen if [ ! -z ${LAST_SEVERITY} ]; then 2112a884fcbSJoseph Chen if [ "${LAST_SEVERITY}" == "普通" -a "${TOP_SEVERITY}" != "moderate" ]; then 2122a884fcbSJoseph Chen MISS_MATCH="y" 2132a884fcbSJoseph Chen elif [ "${LAST_SEVERITY}" == "重要" -a "${TOP_SEVERITY}" != "important" ]; then 2142a884fcbSJoseph Chen MISS_MATCH="y" 2152a884fcbSJoseph Chen elif [ "${LAST_SEVERITY}" == "紧急" -a "${TOP_SEVERITY}" != "critical" ]; then 2162a884fcbSJoseph Chen MISS_MATCH="y" 2172a884fcbSJoseph Chen elif [ "${LAST_SEVERITY}" == "moderate" -a "${TOP_SEVERITY}" != "普通" ]; then 2182a884fcbSJoseph Chen MISS_MATCH="y" 2192a884fcbSJoseph Chen elif [ "${LAST_SEVERITY}" == "important" -a "${TOP_SEVERITY}" != "重要" ]; then 2202a884fcbSJoseph Chen MISS_MATCH="y" 2212a884fcbSJoseph Chen elif [ "${LAST_SEVERITY}" == "critical" -a "${TOP_SEVERITY}" != "紧急" ]; then 2222a884fcbSJoseph Chen MISS_MATCH="y" 2232a884fcbSJoseph Chen fi 2242a884fcbSJoseph Chen 22577aaba73SJoseph Chen if [ "${MISS_MATCH}" == "y" ]; then 2262a884fcbSJoseph Chen echo "ERROR: ${DOC}: top Severity is '${SEVERITY}', while ${LAST_DOC}: top Severity is '${LAST_SEVERITY}'" 2272a884fcbSJoseph Chen echo " Available Severity types are: moderate(普通), important(重要), critical(紧急)" 2282a884fcbSJoseph Chen exit 1 2292a884fcbSJoseph Chen fi 2302a884fcbSJoseph Chen fi 2312a884fcbSJoseph Chen 2322a884fcbSJoseph Chen LAST_SEVERITY="${SEVERITY}" 2332a884fcbSJoseph Chen LAST_DOC="${DOC}" 234f3572ad9SJoseph Chen fi 235f3572ad9SJoseph Chen} 236f3572ad9SJoseph Chen 237f3572ad9SJoseph Chenfunction check_docs() 238f3572ad9SJoseph Chen{ 239acf80986SJoseph Chen if git log ${ARG_COMMIT} -1 --name-only | grep -Eq '\.bin|\.elf' ; then 240acf80986SJoseph Chen DOC_CN=`git log ${ARG_COMMIT} -1 --name-only | sed -n "/_CN\.md/p"` 241acf80986SJoseph Chen DOC_EN=`git log ${ARG_COMMIT} -1 --name-only | sed -n "/_EN\.md/p"` 242f3572ad9SJoseph Chen if [ -z "${DOC_CN}" -o -z "${DOC_EN}" ]; then 243acf80986SJoseph Chen echo "ERROR: Should update CN and EN Release-Note when .bin/elf changed" 244f3572ad9SJoseph Chen exit 1 245f3572ad9SJoseph Chen fi 246755bd534SJoseph Chen 2476c6cd5efSJoseph Chen NUM=`git log ${ARG_COMMIT} -1 --name-only | sed -n "/\.md/p" | wc -l` 2486c6cd5efSJoseph Chen if [ ${NUM} -gt 2 ]; then 2496c6cd5efSJoseph Chen echo "ERROR: More than 2 release note are updated" 2506c6cd5efSJoseph Chen exit 1 2516c6cd5efSJoseph Chen fi 2526c6cd5efSJoseph Chen 253755bd534SJoseph Chen if ! which dos2unix > /dev/null 2>&1 ; then 254755bd534SJoseph Chen echo "ERROR: No 'dos2unix'. Fix by: sudo apt-get install dos2unix" 255755bd534SJoseph Chen exit 1 256755bd534SJoseph Chen fi 257755bd534SJoseph Chen 258f3572ad9SJoseph Chen check_doc CN 259f3572ad9SJoseph Chen check_doc EN 260f3572ad9SJoseph Chen fi 2616f2bc86dSJoseph Chen 2626f2bc86dSJoseph Chen rm -f ${DIFF_SUBSET} 263f3572ad9SJoseph Chen} 264f3572ad9SJoseph Chen 26515aaf94fSJoseph Chenfunction pack_loader_image() 26624a8c2d6SJoseph Chen{ 26715aaf94fSJoseph Chen for FILE in `ls ./RKBOOT/*MINIALL*.ini` 26824a8c2d6SJoseph Chen do 26915aaf94fSJoseph Chen if [ "${FILE}" = "./RKBOOT/RK302AMINIALL.ini" -o \ 27015aaf94fSJoseph Chen "${FILE}" = "./RKBOOT/RK30BMINIALL.ini" -o \ 27115aaf94fSJoseph Chen "${FILE}" = "./RKBOOT/RK30MINIALL.ini" -o \ 27215aaf94fSJoseph Chen "${FILE}" = "./RKBOOT/RK310BMINIALL.ini" ]; then 27324a8c2d6SJoseph Chen continue; 27424a8c2d6SJoseph Chen fi 27524a8c2d6SJoseph Chen 27615aaf94fSJoseph Chen if grep -q '^PATH=img/' ${FILE}; then 27707c86261SJoseph Chen continue; 27807c86261SJoseph Chen fi 27907c86261SJoseph Chen 28015aaf94fSJoseph Chen echo "Pack loader: ${FILE}" 28115aaf94fSJoseph Chen ./tools/boot_merger ${FILE} 282f3822d68SJoseph Chen rm -f *loader*.bin *download*.bin *idblock*.img 28324a8c2d6SJoseph Chen echo 28424a8c2d6SJoseph Chen done 28524a8c2d6SJoseph Chen} 28624a8c2d6SJoseph Chen 28715aaf94fSJoseph Chenfunction pack_trust_image() 28824a8c2d6SJoseph Chen{ 28924a8c2d6SJoseph Chen # Pack 32-bit trust 29015aaf94fSJoseph Chen for FILE in `ls ./RKTRUST/*TOS*.ini` 29124a8c2d6SJoseph Chen do 29215aaf94fSJoseph Chen if ! test -s ${FILE}; then 293075296bdSJoseph Chen continue; 29415aaf94fSJoseph Chen elif ! grep -q 'TOS' ${FILE}; then 295d4bf7444SJoseph Chen continue; 29615aaf94fSJoseph Chen elif grep -q '^PATH=img/' ${FILE}; then 29707c86261SJoseph Chen continue; 29807c86261SJoseph Chen fi 29907c86261SJoseph Chen 30015aaf94fSJoseph Chen echo "Pack trust: ${FILE}" 30124a8c2d6SJoseph Chen # Parse orignal path 30215aaf94fSJoseph Chen TOS=`sed -n "/TOS=/s/TOS=//p" ${FILE}|tr -d '\r'` 30315aaf94fSJoseph Chen TOS_TA=`sed -n "/TOSTA=/s/TOSTA=//p" ${FILE}|tr -d '\r'` 30424a8c2d6SJoseph Chen 30524a8c2d6SJoseph Chen # replace "./tools/rk_tools/" with "./" to compatible legacy ini content of rkdevelop branch 30624a8c2d6SJoseph Chen TOS=$(echo ${TOS} | sed "s/tools\/rk_tools\//\.\//g") 30724a8c2d6SJoseph Chen TOS_TA=$(echo ${TOS_TA} | sed "s/tools\/rk_tools\//\.\//g") 30824a8c2d6SJoseph Chen 3099d00b70aSJoseph Chen if [ x${TOS_TA} != x -a x${TOS} != x ]; then 31024a8c2d6SJoseph Chen ./tools/loaderimage --pack --trustos ${TOS} ./trust.img 0x68400000 31124a8c2d6SJoseph Chen ./tools/loaderimage --pack --trustos ${TOS_TA} ./trust_with_ta.img 0x68400000 3129d00b70aSJoseph Chen elif [ ${TOS} ]; then 31324a8c2d6SJoseph Chen ./tools/loaderimage --pack --trustos ${TOS} ./trust.img 0x68400000 3149d00b70aSJoseph Chen elif [ ${TOS_TA} ]; then 31524a8c2d6SJoseph Chen ./tools/loaderimage --pack --trustos ${TOS_TA} ./trust.img 0x68400000 31624a8c2d6SJoseph Chen else 31724a8c2d6SJoseph Chen exit 1 31824a8c2d6SJoseph Chen fi 319f3822d68SJoseph Chen rm -f trust*.img 32024a8c2d6SJoseph Chen echo 32124a8c2d6SJoseph Chen done 32224a8c2d6SJoseph Chen 32324a8c2d6SJoseph Chen # Pack 64-bit trust 32415aaf94fSJoseph Chen for FILE in `ls ./RKTRUST/*TRUST*.ini` 32524a8c2d6SJoseph Chen do 32615aaf94fSJoseph Chen if grep -q '^PATH=img/' ${FILE}; then 32707c86261SJoseph Chen continue; 32807c86261SJoseph Chen fi 32907c86261SJoseph Chen 33015aaf94fSJoseph Chen echo "Pack trust: ${FILE}" 33115aaf94fSJoseph Chen ./tools/trust_merger ${FILE} 33215aaf94fSJoseph Chen rm -f trust*.img 33324a8c2d6SJoseph Chen echo 33424a8c2d6SJoseph Chen done 33524a8c2d6SJoseph Chen} 33624a8c2d6SJoseph Chen 33715aaf94fSJoseph Chenfunction check_dirty() 3387448aaf2SJoseph Chen{ 339f3572ad9SJoseph 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 340f3572ad9SJoseph Chen echo "Checking clean: ${FILE}" 34115aaf94fSJoseph Chen if strings ${FILE} | grep '\-dirty ' ; then 34215aaf94fSJoseph Chen echo "ERROR: ${FILE} is dirty" 3437448aaf2SJoseph Chen exit 1 3447448aaf2SJoseph Chen fi 3457448aaf2SJoseph Chen done 3467448aaf2SJoseph Chen} 3477448aaf2SJoseph Chen 34815aaf94fSJoseph Chenfunction check_stripped() 349c0efc7efSJoseph Chen{ 35015aaf94fSJoseph Chen for FILE in `find -name '*bl31*.elf'`; do 35115aaf94fSJoseph Chen echo "Checking strip: ${FILE}" 35215aaf94fSJoseph Chen INFO=`file ${FILE}` 35315aaf94fSJoseph Chen if echo ${INFO} | grep -q "not stripped" ; then 35415aaf94fSJoseph Chen echo "ERROR: ${FILE} is not stripped" 355c0efc7efSJoseph Chen exit 1 356c0efc7efSJoseph Chen fi 357c0efc7efSJoseph Chen done 358c0efc7efSJoseph Chen} 359c0efc7efSJoseph Chen 360f3572ad9SJoseph Chenfunction check_mode() 361f3572ad9SJoseph Chen{ 362f3572ad9SJoseph Chen echo "Checking file mode..." 363acf80986SJoseph 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 364acf80986SJoseph Chen git whatchanged ${ARG_COMMIT} -1 --oneline | sed -n '/RKBOOT\//p; /RKTRUST\//p; /bin\//p; /doc\//p;' | grep 755 3650f8ea74fSJoseph Chen echo "ERROR: Set 644 file permission but not 755." 366f3572ad9SJoseph Chen exit 1 367f3572ad9SJoseph Chen fi 368f3572ad9SJoseph Chen} 369f3572ad9SJoseph Chen 37015aaf94fSJoseph Chenfunction finish() 37124a8c2d6SJoseph Chen{ 372f3572ad9SJoseph Chen echo "OK, everything is nice." 37324a8c2d6SJoseph Chen echo 37424a8c2d6SJoseph Chen} 37524a8c2d6SJoseph Chen 376f3572ad9SJoseph Chencheck_mode 377f3572ad9SJoseph Chencheck_docs 3787448aaf2SJoseph Chencheck_dirty 379c0efc7efSJoseph Chencheck_stripped 38024a8c2d6SJoseph Chenpack_loader_image 38124a8c2d6SJoseph Chenpack_trust_image 38224a8c2d6SJoseph Chenfinish 383