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 " +#"` 4139a57210SJoseph Chen DATE=`sed -n "/^+| 20[0-9][0-9]-/p" ${DIFF_DOC_ALL} | tr -d " " | awk -F "|" '{ print $2 }'` 4239a57210SJoseph Chen YEAR=`sed -n "/^+| 20[0-9][0-9]-/p" ${DIFF_DOC_ALL} | tr -d " " | awk -F "|" '{ print $2 }' | awk -F "-" '{ print $1 }'` 43f3572ad9SJoseph Chen FILE=`sed -n "/^+| 20[0-9][0-9]-/p" ${DIFF_DOC_ALL} | tr -d " " | awk -F "|" '{ print $3 }'` 44f3572ad9SJoseph Chen COMMIT=`sed -n "/^+| 20[0-9][0-9]-/p" ${DIFF_DOC_ALL} | tr -d " " | awk -F "|" '{ print $4 }'` 45f3572ad9SJoseph Chen SEVERITY=`sed -n "/^+| 20[0-9][0-9]-/p" ${DIFF_DOC_ALL} | tr -d " " | awk -F "|" '{ print $5 }'` 461ba7d1c8SJoseph Chen END_LINE_3=`tail -n 3 ${DIFF_DOC_ALL} | sed -n '1p'` 471ba7d1c8SJoseph Chen END_LINE_2=`tail -n 3 ${DIFF_DOC_ALL} | sed -n '2p'` 481ba7d1c8SJoseph Chen END_LINE_1=`tail -n 3 ${DIFF_DOC_ALL} | sed -n '3p'` 49958c7bcfSJoseph Chen HOST_YEAR=`date +%Y` 50f3572ad9SJoseph Chen # echo "### ${COMMIT}, ${SEVERITY}, ${TITLE}, ${FILE}" 51f3572ad9SJoseph Chen 52407510a0SJoseph Chen # check blank line after Heading 1 53407510a0SJoseph Chen HEADING_1=`sed -n '1p' ${DOC}` 54407510a0SJoseph Chen if sed -n '2p' ${DOC} | grep -q [a-z,A-Z] ; then 55958c7bcfSJoseph Chen echo "ERROR: ${DOC}: Please add blank line after '${HEADING_1}'" 56407510a0SJoseph Chen exit 1 57407510a0SJoseph Chen fi 58407510a0SJoseph Chen 598e4858bdSJoseph Chen # check space 608e4858bdSJoseph Chen if sed -n "/##/p" ${DOC} | grep -v '## [a-z,A-Z]' ; then 61958c7bcfSJoseph Chen echo "ERROR: ${DOC}: Please only 1 space between '#' and word" 628e4858bdSJoseph Chen exit 1 638e4858bdSJoseph Chen fi 648e4858bdSJoseph Chen 650287fa94SJoseph Chen # check new content location 66acf80986SJoseph Chen if ! git show ${ARG_COMMIT} -1 ${DOC} | grep -q 'Release Note' ; then 67958c7bcfSJoseph Chen echo "ERROR: ${DOC}: Please add new content at the top but not bottom" 680287fa94SJoseph Chen exit 1 690287fa94SJoseph Chen fi 700287fa94SJoseph Chen 716c6cd5efSJoseph Chen # check title 72*2bef28e8SJoseph Chen if grep -Eq '### WARN|### WARNING|### Warning|### warn|### warning' ${DIFF_DOC_ALL} ; then 73*2bef28e8SJoseph Chen echo "ERROR: ${DOC}: Please use '### Warn'" 74*2bef28e8SJoseph Chen exit 1 75*2bef28e8SJoseph Chen fi 76*2bef28e8SJoseph Chen 776c6cd5efSJoseph Chen if grep -Eq '### NEW|### new' ${DIFF_DOC_ALL} ; then 786c6cd5efSJoseph Chen echo "ERROR: ${DOC}: Please use '### New'" 796c6cd5efSJoseph Chen exit 1 806c6cd5efSJoseph Chen fi 816c6cd5efSJoseph Chen 826c6cd5efSJoseph Chen if grep -Eq '### FIXED|### fixed' ${DIFF_DOC_ALL} ; then 836c6cd5efSJoseph Chen echo "ERROR: ${DOC}: Please use '### Fixed'" 846c6cd5efSJoseph Chen exit 1 856c6cd5efSJoseph Chen fi 866c6cd5efSJoseph Chen 8739a57210SJoseph Chen # check year 8839a57210SJoseph Chen if [ "${HOST_YEAR}" != "${YEAR}" ]; then 8939a57210SJoseph Chen echo "ERROR: ${DOC}: '${DATE}' is wrong, the year should be ${HOST_YEAR}" 9039a57210SJoseph Chen exit 1 9139a57210SJoseph Chen fi 9239a57210SJoseph Chen 930287fa94SJoseph Chen # check TAB before index of 'New' body 940287fa94SJoseph Chen if grep -q $'\t[0-9]' ${DOC} ; then 950287fa94SJoseph Chen echo "ERROR: ${DOC}: Don't add TAB before index:" 960287fa94SJoseph Chen grep $'\t[0-9]' ${DOC} 970287fa94SJoseph Chen exit 1 980287fa94SJoseph Chen fi 990287fa94SJoseph Chen 10077aaba73SJoseph Chen # check upper case and line end 10177aaba73SJoseph Chen if [ "${LANGUAGE}" == "EN" ] ; then 10277aaba73SJoseph Chen if grep -q '^[0-9]\. [a-z]' ${DOC} ; then 10377aaba73SJoseph Chen echo "ERROR: ${DOC}: Please use upper case of first word(i.e. \"1. add ..\" => \"1. Add ...\"):" 10477aaba73SJoseph Chen grep '^[0-9]\. [a-z]' ${DOC} 10577aaba73SJoseph Chen exit 1 10677aaba73SJoseph Chen fi 10777aaba73SJoseph Chen 10877aaba73SJoseph Chen # check end with '.' 10977aaba73SJoseph Chen if sed -n '/^[0-9]\. [A-Z]/p' ${DOC} | grep -q '[^.]$' ; then 11077aaba73SJoseph Chen echo "ERROR: ${DOC}: Please end line with '.'" 11177aaba73SJoseph Chen grep '^[0-9]\. [A-Z]' ${DOC} | grep '[^.]$' 11277aaba73SJoseph Chen exit 1 11377aaba73SJoseph Chen fi 11400951929SJoseph Chen 11500951929SJoseph Chen # check Chinese language 11600951929SJoseph Chen if grep -P '[\x{4e00}-\x{9fa5}]' ${DOC} ; then 11700951929SJoseph Chen echo "ERROR: ${DOC}: The Chinese language was found" 11800951929SJoseph Chen exit 1 11900951929SJoseph Chen fi 12077aaba73SJoseph Chen else 12177aaba73SJoseph Chen # check end with '。' 12277aaba73SJoseph Chen if sed -n '/^[0-9]\. /p' ${DOC} | grep -q '[^。]$' ; then 12377aaba73SJoseph Chen echo "ERROR: ${DOC}: Please end line with '。'" 12477aaba73SJoseph Chen grep '^[0-9]\. ' ${DOC} | grep '[^。]$' 12577aaba73SJoseph Chen exit 1 12677aaba73SJoseph Chen fi 12777aaba73SJoseph Chen fi 12877aaba73SJoseph Chen 1292d300a6dSJoseph Chen # check space after index of 'New' body 1302d300a6dSJoseph Chen SUM1=`grep '^[0-9]\.' ${DOC} | wc -l` 1312d300a6dSJoseph Chen SUM2=`grep '^[0-9]\.[[:blank:]]' ${DOC} | wc -l` 1322d300a6dSJoseph Chen if [ "$SUM1" != "$SUM2" ]; then 1332d300a6dSJoseph Chen echo "ERROR: ${DOC}: Please add space after index (e.g: '1. ' but not '1.'):" 1342d300a6dSJoseph Chen grep '^+[0-9]\.' ${DIFF_DOC_ALL} 1352d300a6dSJoseph Chen exit 1 1362d300a6dSJoseph Chen fi 1372d300a6dSJoseph Chen 138f3572ad9SJoseph Chen # check standalone file 139fd99385aSJoseph Chen if ! echo ${FILE} | grep -Eq '\.bin|\.elf|\.img' ; then 140fd99385aSJoseph Chen echo "ERROR: ${DOC}: '${FILE}' missing the file format suffix" 141fd99385aSJoseph Chen exit 1 142fd99385aSJoseph Chen fi 143f3572ad9SJoseph Chen if ! echo ${FILE} | grep -q { ; then 144acf80986SJoseph Chen if ! git log ${ARG_COMMIT} -1 --name-only | grep -q ${FILE}; then 1450f8ea74fSJoseph Chen echo "ERROR: ${DOC}: '${FILE}' is not updated in this patch" 146f3572ad9SJoseph Chen exit 1 147f3572ad9SJoseph Chen fi 148f3572ad9SJoseph Chen fi 149f3572ad9SJoseph Chen 150f3572ad9SJoseph Chen # check title 151f3572ad9SJoseph Chen if [ "${TITLE}" != "${FILE}" ]; then 152f3572ad9SJoseph Chen echo "ERROR: ${DOC}: Title '${TITLE}' is not match with '${FILE}'" 153f3572ad9SJoseph Chen exit 1 154f3572ad9SJoseph Chen fi 155f3572ad9SJoseph Chen 156f3572ad9SJoseph Chen # check commit 157f3572ad9SJoseph Chen COMMIT=${COMMIT//#/ } 158f3572ad9SJoseph Chen for LIST in ${COMMIT}; do 159f3572ad9SJoseph Chen CMT=`echo ${LIST} | cut -d : -f 2` 160acf80986SJoseph Chen if ! git log ${ARG_COMMIT} -1 | grep -q ${CMT} ; then 1612d300a6dSJoseph Chen echo "ERROR: ${DOC}: '${CMT}' is not match in commit message" 162f3572ad9SJoseph Chen exit 1 163f3572ad9SJoseph Chen fi 16439bfe203SJoseph Chen 16539bfe203SJoseph Chen if ! echo ${FILE} | grep -q { ; then 16639bfe203SJoseph Chen if echo ${FILE} | grep -Eq 'spl_|tpl_|bl31_|bl32_|tee_' ; then 16739bfe203SJoseph Chen FILE_PATH=`find -name ${FILE}` 168acf80986SJoseph Chen if [ -z "${FILE_PATH}" ]; then 169acf80986SJoseph Chen echo "ERROR: ${DOC}: No ${FILE}" 170acf80986SJoseph Chen exit 1 171acf80986SJoseph Chen fi 17239bfe203SJoseph Chen if ! strings ${FILE_PATH} | grep -q ${CMT} ; then 17339bfe203SJoseph Chen echo "ERROR: ${DOC}: ${FILE} is not build from '${CMT}'" 17439bfe203SJoseph Chen exit 1 17539bfe203SJoseph Chen fi 17639bfe203SJoseph Chen fi 17739bfe203SJoseph Chen fi 178f3572ad9SJoseph Chen done 179f3572ad9SJoseph Chen 180f3572ad9SJoseph Chen # check severity 181f3572ad9SJoseph Chen if [ "${SEVERITY}" != "${SVT_CRITIAL}" -a "${SEVERITY}" != "${SVT_IMPORTANT}" -a "${SEVERITY}" != "${SVT_MODERATE}" ]; then 182f3572ad9SJoseph Chen echo "ERROR: ${DOC}: Unknown main severity: ${SEVERITY}" 183f3572ad9SJoseph Chen exit 1 184f3572ad9SJoseph Chen fi 185f3572ad9SJoseph Chen 186f3572ad9SJoseph Chen # check horizontal line 1871ba7d1c8SJoseph Chen if [ "${END_LINE_2}" != "+------" ]; then 188958c7bcfSJoseph Chen echo "ERROR: ${DOC}: Please add horizontal line '------' at the last of new content" 189f3572ad9SJoseph Chen exit 1 190f3572ad9SJoseph Chen fi 1911ba7d1c8SJoseph Chen if [ "${END_LINE_3}" != "+" ]; then 192958c7bcfSJoseph Chen echo "ERROR: ${DOC}: Please add blank line before horizontal line '------'" 1931ba7d1c8SJoseph Chen exit 1 1941ba7d1c8SJoseph Chen fi 1951ba7d1c8SJoseph Chen if [ "${END_LINE_1}" != "+" ]; then 196958c7bcfSJoseph Chen echo "ERROR: ${DOC}: Please add blank line after horizontal line '------'" 1972c1affb8SJoseph Chen exit 1 1982c1affb8SJoseph Chen fi 1992c1affb8SJoseph Chen 200f3572ad9SJoseph Chen # check 'Fixed' content 201f3572ad9SJoseph Chen if grep -q "^+### Fixed" ${DIFF_DOC_ALL} ; then 202f3572ad9SJoseph Chen awk -v RS='### Fixed' 'END{printf "%s", $0}' ${DIFF_DOC_ALL} > ${DIFF_DOC_FIXED} 203f3572ad9SJoseph Chen sed -i "/^$/d" ${DIFF_DOC_FIXED} 204f3572ad9SJoseph Chen sed -i "/Index/d" ${DIFF_DOC_FIXED} 205f3572ad9SJoseph Chen sed -i "/---/d" ${DIFF_DOC_FIXED} 206f3572ad9SJoseph Chen sed -i "/^+$/d" ${DIFF_DOC_FIXED} 207f3572ad9SJoseph Chen 208f3572ad9SJoseph Chen while read LINE 209f3572ad9SJoseph Chen do 210f3572ad9SJoseph Chen EACH_SEVERITY=`echo "${LINE}" | awk -F "|" '{ print $3 }' | tr -d " "` 211f3572ad9SJoseph Chen if [ "${EACH_SEVERITY}" != "${SVT_CRITIAL}" -a "${EACH_SEVERITY}" != "${SVT_IMPORTANT}" -a "${EACH_SEVERITY}" != "${SVT_MODERATE}" ]; then 21213413eecSJoseph Chen if [ -z "${EACH_SEVERITY}" ]; then 21313413eecSJoseph Chen echo "ERROR: ${DOC}: No severity found, please use Table to list what you '### Fixed'" 21413413eecSJoseph Chen else 215f3572ad9SJoseph Chen echo "ERROR: ${DOC}: Unknown severity: ${EACH_SEVERITY}" 21613413eecSJoseph Chen fi 217f3572ad9SJoseph Chen exit 1 218f3572ad9SJoseph Chen fi 219f3572ad9SJoseph Chen 220f3572ad9SJoseph Chen # echo "## EACH: $EACH_SEVERITY" 221f3572ad9SJoseph Chen if [ -z "${TOP_SEVERITY}" ]; then 222f3572ad9SJoseph Chen TOP_SEVERITY="${EACH_SEVERITY}" 223f3572ad9SJoseph Chen elif [ "${TOP_SEVERITY}" == "${SVT_MODERATE}" ]; then 224f3572ad9SJoseph Chen if [ "${EACH_SEVERITY}" == "${SVT_CRITIAL}" -o "${EACH_SEVERITY}" == "${SVT_IMPORTANT}" ]; then 225f3572ad9SJoseph Chen TOP_SEVERITY="${EACH_SEVERITY}" 226f3572ad9SJoseph Chen fi 227f3572ad9SJoseph Chen elif [ "${TOP_SEVERITY}" == "${SVT_IMPORTANT}" ]; then 228f3572ad9SJoseph Chen if [ "${EACH_SEVERITY}" == "${SVT_CRITIAL}" ]; then 229f3572ad9SJoseph Chen TOP_SEVERITY="${EACH_SEVERITY}" 230f3572ad9SJoseph Chen fi 231f3572ad9SJoseph Chen fi 232f3572ad9SJoseph Chen done < ${DIFF_DOC_FIXED} 233f3572ad9SJoseph Chen 234f3572ad9SJoseph Chen if [ "${SEVERITY}" != "${TOP_SEVERITY}" ]; then 2352a884fcbSJoseph Chen echo "ERROR: ${DOC}: Top severity should be '${TOP_SEVERITY}' as it's the highest level of all sub severity" 236f3572ad9SJoseph Chen exit 1 237f3572ad9SJoseph Chen fi 2382a884fcbSJoseph Chen 2392a884fcbSJoseph Chen # check top severity miss match 2402a884fcbSJoseph Chen if [ ! -z ${LAST_SEVERITY} ]; then 2412a884fcbSJoseph Chen if [ "${LAST_SEVERITY}" == "普通" -a "${TOP_SEVERITY}" != "moderate" ]; then 2422a884fcbSJoseph Chen MISS_MATCH="y" 2432a884fcbSJoseph Chen elif [ "${LAST_SEVERITY}" == "重要" -a "${TOP_SEVERITY}" != "important" ]; then 2442a884fcbSJoseph Chen MISS_MATCH="y" 2452a884fcbSJoseph Chen elif [ "${LAST_SEVERITY}" == "紧急" -a "${TOP_SEVERITY}" != "critical" ]; then 2462a884fcbSJoseph Chen MISS_MATCH="y" 2472a884fcbSJoseph Chen elif [ "${LAST_SEVERITY}" == "moderate" -a "${TOP_SEVERITY}" != "普通" ]; then 2482a884fcbSJoseph Chen MISS_MATCH="y" 2492a884fcbSJoseph Chen elif [ "${LAST_SEVERITY}" == "important" -a "${TOP_SEVERITY}" != "重要" ]; then 2502a884fcbSJoseph Chen MISS_MATCH="y" 2512a884fcbSJoseph Chen elif [ "${LAST_SEVERITY}" == "critical" -a "${TOP_SEVERITY}" != "紧急" ]; then 2522a884fcbSJoseph Chen MISS_MATCH="y" 2532a884fcbSJoseph Chen fi 2542a884fcbSJoseph Chen 25577aaba73SJoseph Chen if [ "${MISS_MATCH}" == "y" ]; then 2562a884fcbSJoseph Chen echo "ERROR: ${DOC}: top Severity is '${SEVERITY}', while ${LAST_DOC}: top Severity is '${LAST_SEVERITY}'" 2572a884fcbSJoseph Chen echo " Available Severity types are: moderate(普通), important(重要), critical(紧急)" 2582a884fcbSJoseph Chen exit 1 2592a884fcbSJoseph Chen fi 2602a884fcbSJoseph Chen fi 2612a884fcbSJoseph Chen 2622a884fcbSJoseph Chen LAST_SEVERITY="${SEVERITY}" 2632a884fcbSJoseph Chen LAST_DOC="${DOC}" 264f3572ad9SJoseph Chen fi 265f3572ad9SJoseph Chen} 266f3572ad9SJoseph Chen 267f3572ad9SJoseph Chenfunction check_docs() 268f3572ad9SJoseph Chen{ 269732d9493SJoseph Chen if git log ${ARG_COMMIT} -1 --name-only | sed -n '5p' | grep -Eq '^ Revert "' ; then 270732d9493SJoseph Chen return; 271732d9493SJoseph Chen fi 272732d9493SJoseph Chen 273acf80986SJoseph Chen if git log ${ARG_COMMIT} -1 --name-only | grep -Eq '\.bin|\.elf' ; then 274acf80986SJoseph Chen DOC_CN=`git log ${ARG_COMMIT} -1 --name-only | sed -n "/_CN\.md/p"` 275acf80986SJoseph Chen DOC_EN=`git log ${ARG_COMMIT} -1 --name-only | sed -n "/_EN\.md/p"` 276f3572ad9SJoseph Chen if [ -z "${DOC_CN}" -o -z "${DOC_EN}" ]; then 277acf80986SJoseph Chen echo "ERROR: Should update CN and EN Release-Note when .bin/elf changed" 278f3572ad9SJoseph Chen exit 1 279f3572ad9SJoseph Chen fi 280755bd534SJoseph Chen 2816c6cd5efSJoseph Chen NUM=`git log ${ARG_COMMIT} -1 --name-only | sed -n "/\.md/p" | wc -l` 2826c6cd5efSJoseph Chen if [ ${NUM} -gt 2 ]; then 2836c6cd5efSJoseph Chen echo "ERROR: More than 2 release note are updated" 2846c6cd5efSJoseph Chen exit 1 2856c6cd5efSJoseph Chen fi 2866c6cd5efSJoseph Chen 287755bd534SJoseph Chen if ! which dos2unix > /dev/null 2>&1 ; then 288755bd534SJoseph Chen echo "ERROR: No 'dos2unix'. Fix by: sudo apt-get install dos2unix" 289755bd534SJoseph Chen exit 1 290755bd534SJoseph Chen fi 291755bd534SJoseph Chen 292f3572ad9SJoseph Chen check_doc CN 293f3572ad9SJoseph Chen check_doc EN 294f3572ad9SJoseph Chen fi 2956f2bc86dSJoseph Chen 2966f2bc86dSJoseph Chen rm -f ${DIFF_SUBSET} 297f3572ad9SJoseph Chen} 298f3572ad9SJoseph Chen 29915aaf94fSJoseph Chenfunction pack_loader_image() 30024a8c2d6SJoseph Chen{ 30115aaf94fSJoseph Chen for FILE in `ls ./RKBOOT/*MINIALL*.ini` 30224a8c2d6SJoseph Chen do 30315aaf94fSJoseph Chen if [ "${FILE}" = "./RKBOOT/RK302AMINIALL.ini" -o \ 30415aaf94fSJoseph Chen "${FILE}" = "./RKBOOT/RK30BMINIALL.ini" -o \ 30515aaf94fSJoseph Chen "${FILE}" = "./RKBOOT/RK30MINIALL.ini" -o \ 30615aaf94fSJoseph Chen "${FILE}" = "./RKBOOT/RK310BMINIALL.ini" ]; then 30724a8c2d6SJoseph Chen continue; 30824a8c2d6SJoseph Chen fi 30924a8c2d6SJoseph Chen 31015aaf94fSJoseph Chen if grep -q '^PATH=img/' ${FILE}; then 31107c86261SJoseph Chen continue; 31207c86261SJoseph Chen fi 31307c86261SJoseph Chen 31415aaf94fSJoseph Chen echo "Pack loader: ${FILE}" 31515aaf94fSJoseph Chen ./tools/boot_merger ${FILE} 316f3822d68SJoseph Chen rm -f *loader*.bin *download*.bin *idblock*.img 31724a8c2d6SJoseph Chen echo 31824a8c2d6SJoseph Chen done 31924a8c2d6SJoseph Chen} 32024a8c2d6SJoseph Chen 32115aaf94fSJoseph Chenfunction pack_trust_image() 32224a8c2d6SJoseph Chen{ 32324a8c2d6SJoseph Chen # Pack 32-bit trust 32415aaf94fSJoseph Chen for FILE in `ls ./RKTRUST/*TOS*.ini` 32524a8c2d6SJoseph Chen do 32615aaf94fSJoseph Chen if ! test -s ${FILE}; then 327075296bdSJoseph Chen continue; 32815aaf94fSJoseph Chen elif ! grep -q 'TOS' ${FILE}; then 329d4bf7444SJoseph Chen continue; 33015aaf94fSJoseph Chen elif grep -q '^PATH=img/' ${FILE}; then 33107c86261SJoseph Chen continue; 33207c86261SJoseph Chen fi 33307c86261SJoseph Chen 33415aaf94fSJoseph Chen echo "Pack trust: ${FILE}" 33524a8c2d6SJoseph Chen # Parse orignal path 33615aaf94fSJoseph Chen TOS=`sed -n "/TOS=/s/TOS=//p" ${FILE}|tr -d '\r'` 33715aaf94fSJoseph Chen TOS_TA=`sed -n "/TOSTA=/s/TOSTA=//p" ${FILE}|tr -d '\r'` 33824a8c2d6SJoseph Chen 33924a8c2d6SJoseph Chen # replace "./tools/rk_tools/" with "./" to compatible legacy ini content of rkdevelop branch 34024a8c2d6SJoseph Chen TOS=$(echo ${TOS} | sed "s/tools\/rk_tools\//\.\//g") 34124a8c2d6SJoseph Chen TOS_TA=$(echo ${TOS_TA} | sed "s/tools\/rk_tools\//\.\//g") 34224a8c2d6SJoseph Chen 3439d00b70aSJoseph Chen if [ x${TOS_TA} != x -a x${TOS} != x ]; then 34424a8c2d6SJoseph Chen ./tools/loaderimage --pack --trustos ${TOS} ./trust.img 0x68400000 34524a8c2d6SJoseph Chen ./tools/loaderimage --pack --trustos ${TOS_TA} ./trust_with_ta.img 0x68400000 3469d00b70aSJoseph Chen elif [ ${TOS} ]; then 34724a8c2d6SJoseph Chen ./tools/loaderimage --pack --trustos ${TOS} ./trust.img 0x68400000 3489d00b70aSJoseph Chen elif [ ${TOS_TA} ]; then 34924a8c2d6SJoseph Chen ./tools/loaderimage --pack --trustos ${TOS_TA} ./trust.img 0x68400000 35024a8c2d6SJoseph Chen else 35124a8c2d6SJoseph Chen exit 1 35224a8c2d6SJoseph Chen fi 353f3822d68SJoseph Chen rm -f trust*.img 35424a8c2d6SJoseph Chen echo 35524a8c2d6SJoseph Chen done 35624a8c2d6SJoseph Chen 35724a8c2d6SJoseph Chen # Pack 64-bit trust 35815aaf94fSJoseph Chen for FILE in `ls ./RKTRUST/*TRUST*.ini` 35924a8c2d6SJoseph Chen do 36015aaf94fSJoseph Chen if grep -q '^PATH=img/' ${FILE}; then 36107c86261SJoseph Chen continue; 36207c86261SJoseph Chen fi 36307c86261SJoseph Chen 36415aaf94fSJoseph Chen echo "Pack trust: ${FILE}" 36515aaf94fSJoseph Chen ./tools/trust_merger ${FILE} 36615aaf94fSJoseph Chen rm -f trust*.img 36724a8c2d6SJoseph Chen echo 36824a8c2d6SJoseph Chen done 36924a8c2d6SJoseph Chen} 37024a8c2d6SJoseph Chen 37115aaf94fSJoseph Chenfunction check_dirty() 3727448aaf2SJoseph Chen{ 373f3572ad9SJoseph 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 374f3572ad9SJoseph Chen echo "Checking clean: ${FILE}" 37515aaf94fSJoseph Chen if strings ${FILE} | grep '\-dirty ' ; then 37615aaf94fSJoseph Chen echo "ERROR: ${FILE} is dirty" 3777448aaf2SJoseph Chen exit 1 3787448aaf2SJoseph Chen fi 3797448aaf2SJoseph Chen done 3807448aaf2SJoseph Chen} 3817448aaf2SJoseph Chen 38215aaf94fSJoseph Chenfunction check_stripped() 383c0efc7efSJoseph Chen{ 38415aaf94fSJoseph Chen for FILE in `find -name '*bl31*.elf'`; do 38515aaf94fSJoseph Chen echo "Checking strip: ${FILE}" 38615aaf94fSJoseph Chen INFO=`file ${FILE}` 38715aaf94fSJoseph Chen if echo ${INFO} | grep -q "not stripped" ; then 38815aaf94fSJoseph Chen echo "ERROR: ${FILE} is not stripped" 389c0efc7efSJoseph Chen exit 1 390c0efc7efSJoseph Chen fi 391c0efc7efSJoseph Chen done 392c0efc7efSJoseph Chen} 393c0efc7efSJoseph Chen 394f3572ad9SJoseph Chenfunction check_mode() 395f3572ad9SJoseph Chen{ 396f3572ad9SJoseph Chen echo "Checking file mode..." 397acf80986SJoseph 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 398acf80986SJoseph Chen git whatchanged ${ARG_COMMIT} -1 --oneline | sed -n '/RKBOOT\//p; /RKTRUST\//p; /bin\//p; /doc\//p;' | grep 755 3990f8ea74fSJoseph Chen echo "ERROR: Set 644 file permission but not 755." 400f3572ad9SJoseph Chen exit 1 401f3572ad9SJoseph Chen fi 402f3572ad9SJoseph Chen} 403f3572ad9SJoseph Chen 40415aaf94fSJoseph Chenfunction finish() 40524a8c2d6SJoseph Chen{ 406f3572ad9SJoseph Chen echo "OK, everything is nice." 40724a8c2d6SJoseph Chen echo 40824a8c2d6SJoseph Chen} 40924a8c2d6SJoseph Chen 410f3572ad9SJoseph Chencheck_mode 411f3572ad9SJoseph Chencheck_docs 4127448aaf2SJoseph Chencheck_dirty 413c0efc7efSJoseph Chencheck_stripped 41424a8c2d6SJoseph Chenpack_loader_image 41524a8c2d6SJoseph Chenpack_trust_image 41624a8c2d6SJoseph Chenfinish 417