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" 8f3572ad9SJoseph Chen 9f3572ad9SJoseph Chenfunction check_doc() 10f3572ad9SJoseph Chen{ 11f3572ad9SJoseph Chen local TOP_SEVERITY LANGUAGE=$1 12f3572ad9SJoseph Chen 13f3572ad9SJoseph Chen if [ "${LANGUAGE}" == "EN" ] ; then 14f3572ad9SJoseph Chen SVT_CRITIAL="critical" 15f3572ad9SJoseph Chen SVT_IMPORTANT="important" 16f3572ad9SJoseph Chen SVT_MODERATE="moderate" 17acf80986SJoseph Chen DOC=`git log ${ARG_COMMIT} -1 --name-only | sed -n "/_EN\.md/p"` 18f3572ad9SJoseph Chen else 19f3572ad9SJoseph Chen SVT_CRITIAL="紧急" 20f3572ad9SJoseph Chen SVT_IMPORTANT="重要" 21f3572ad9SJoseph Chen SVT_MODERATE="普通" 22acf80986SJoseph Chen DOC=`git log ${ARG_COMMIT} -1 --name-only | sed -n "/_CN\.md/p"` 23f3572ad9SJoseph Chen fi 24f3572ad9SJoseph Chen 25f3572ad9SJoseph Chen echo "Checking doc: ${DOC}" 26f3572ad9SJoseph Chen 276f2bc86dSJoseph Chen # check DOS encoding 28acf80986SJoseph Chen git show ${ARG_COMMIT} -1 ${DOC} | sed -n "/^+/p" > ${DIFF_DOC_ALL} 29acf80986SJoseph Chen git show ${ARG_COMMIT} -1 ${DOC} | sed -n "/^+/p" > ${DIFF_DOC_ALL}.dos 306f2bc86dSJoseph Chen dos2unix ${DIFF_DOC_ALL}.dos >/dev/null 2>&1 316f2bc86dSJoseph Chen CSUM1=`md5sum ${DIFF_DOC_ALL} | awk '{ print $1 }'` 326f2bc86dSJoseph Chen CSUM2=`md5sum ${DIFF_DOC_ALL}.dos | awk '{ print $1 }'` 336f2bc86dSJoseph Chen if [ "${CSUM1}" != "${CSUM2}" ]; then 346f2bc86dSJoseph Chen echo "ERROR: ${DOC} is DOS encoding. Fix it by: 'dos2unix ${DOC}'" 356f2bc86dSJoseph Chen exit 1 366f2bc86dSJoseph Chen fi 376f2bc86dSJoseph Chen 38f3572ad9SJoseph Chen TITLE=`sed -n "/^+## /p" ${DIFF_DOC_ALL} | tr -d " +#"` 39f3572ad9SJoseph Chen FILE=`sed -n "/^+| 20[0-9][0-9]-/p" ${DIFF_DOC_ALL} | tr -d " " | awk -F "|" '{ print $3 }'` 40f3572ad9SJoseph Chen COMMIT=`sed -n "/^+| 20[0-9][0-9]-/p" ${DIFF_DOC_ALL} | tr -d " " | awk -F "|" '{ print $4 }'` 41f3572ad9SJoseph Chen SEVERITY=`sed -n "/^+| 20[0-9][0-9]-/p" ${DIFF_DOC_ALL} | tr -d " " | awk -F "|" '{ print $5 }'` 42f3572ad9SJoseph Chen HORIZONTAL_LINE=`sed -n "/^+------$/p" ${DIFF_DOC_ALL}` 43f3572ad9SJoseph Chen # echo "### ${COMMIT}, ${SEVERITY}, ${TITLE}, ${FILE}" 44f3572ad9SJoseph Chen 45*8e4858bdSJoseph Chen # check space 46*8e4858bdSJoseph Chen if sed -n "/##/p" ${DOC} | grep -v '## [a-z,A-Z]' ; then 47*8e4858bdSJoseph Chen echo "ERROR: ${DOC}: Should only 1 space between '#' and word" 48*8e4858bdSJoseph Chen exit 1 49*8e4858bdSJoseph Chen fi 50*8e4858bdSJoseph Chen 510287fa94SJoseph Chen # check new content location 52acf80986SJoseph Chen if ! git show ${ARG_COMMIT} -1 ${DOC} | grep -q 'Release Note' ; then 530287fa94SJoseph Chen echo "ERROR: ${DOC}: Adding new content at the top but not bottom" 540287fa94SJoseph Chen exit 1 550287fa94SJoseph Chen fi 560287fa94SJoseph Chen 570287fa94SJoseph Chen # check TAB before index of 'New' body 580287fa94SJoseph Chen if grep -q $'\t[0-9]' ${DOC} ; then 590287fa94SJoseph Chen echo "ERROR: ${DOC}: Don't add TAB before index:" 600287fa94SJoseph Chen grep $'\t[0-9]' ${DOC} 610287fa94SJoseph Chen exit 1 620287fa94SJoseph Chen fi 630287fa94SJoseph Chen 64f3572ad9SJoseph Chen # check standalone file 65f3572ad9SJoseph Chen if ! echo ${FILE} | grep -q { ; then 66acf80986SJoseph Chen if ! git log ${ARG_COMMIT} -1 --name-only | grep -q ${FILE}; then 670f8ea74fSJoseph Chen echo "ERROR: ${DOC}: '${FILE}' is not updated in this patch" 68f3572ad9SJoseph Chen exit 1 69f3572ad9SJoseph Chen fi 70f3572ad9SJoseph Chen fi 71f3572ad9SJoseph Chen 72f3572ad9SJoseph Chen # check title 73f3572ad9SJoseph Chen if [ "${TITLE}" != "${FILE}" ]; then 74f3572ad9SJoseph Chen echo "ERROR: ${DOC}: Title '${TITLE}' is not match with '${FILE}'" 75f3572ad9SJoseph Chen exit 1 76f3572ad9SJoseph Chen fi 77f3572ad9SJoseph Chen 78f3572ad9SJoseph Chen # check commit 79f3572ad9SJoseph Chen COMMIT=${COMMIT//#/ } 80f3572ad9SJoseph Chen for LIST in ${COMMIT}; do 81f3572ad9SJoseph Chen CMT=`echo ${LIST} | cut -d : -f 2` 82acf80986SJoseph Chen if ! git log ${ARG_COMMIT} -1 | grep -q ${CMT} ; then 83acf80986SJoseph Chen echo "ERROR: ${DOC}: '${CMT}' is not match in ARG_COMMIT message" 84f3572ad9SJoseph Chen exit 1 85f3572ad9SJoseph Chen fi 8639bfe203SJoseph Chen 8739bfe203SJoseph Chen if ! echo ${FILE} | grep -q { ; then 8839bfe203SJoseph Chen if echo ${FILE} | grep -Eq 'spl_|tpl_|bl31_|bl32_|tee_' ; then 8939bfe203SJoseph Chen FILE_PATH=`find -name ${FILE}` 90acf80986SJoseph Chen if [ -z "${FILE_PATH}" ]; then 91acf80986SJoseph Chen echo "ERROR: ${DOC}: No ${FILE}" 92acf80986SJoseph Chen exit 1 93acf80986SJoseph Chen fi 9439bfe203SJoseph Chen if ! strings ${FILE_PATH} | grep -q ${CMT} ; then 9539bfe203SJoseph Chen echo "ERROR: ${DOC}: ${FILE} is not build from '${CMT}'" 9639bfe203SJoseph Chen exit 1 9739bfe203SJoseph Chen fi 9839bfe203SJoseph Chen fi 9939bfe203SJoseph Chen fi 100f3572ad9SJoseph Chen done 101f3572ad9SJoseph Chen 102f3572ad9SJoseph Chen # check severity 103f3572ad9SJoseph Chen if [ "${SEVERITY}" != "${SVT_CRITIAL}" -a "${SEVERITY}" != "${SVT_IMPORTANT}" -a "${SEVERITY}" != "${SVT_MODERATE}" ]; then 104f3572ad9SJoseph Chen echo "ERROR: ${DOC}: Unknown main severity: ${SEVERITY}" 105f3572ad9SJoseph Chen exit 1 106f3572ad9SJoseph Chen fi 107f3572ad9SJoseph Chen 108f3572ad9SJoseph Chen # check horizontal line 109f3572ad9SJoseph Chen if [ -z "${HORIZONTAL_LINE}" ]; then 1100f8ea74fSJoseph Chen echo "ERROR: ${DOC}: No horizontal line '------' at the last of new content" 111f3572ad9SJoseph Chen exit 1 112f3572ad9SJoseph Chen fi 113f3572ad9SJoseph Chen 114f3572ad9SJoseph Chen # check 'Fixed' content 115f3572ad9SJoseph Chen if grep -q "^+### Fixed" ${DIFF_DOC_ALL} ; then 116f3572ad9SJoseph Chen awk -v RS='### Fixed' 'END{printf "%s", $0}' ${DIFF_DOC_ALL} > ${DIFF_DOC_FIXED} 117f3572ad9SJoseph Chen sed -i "/^$/d" ${DIFF_DOC_FIXED} 118f3572ad9SJoseph Chen sed -i "/Index/d" ${DIFF_DOC_FIXED} 119f3572ad9SJoseph Chen sed -i "/---/d" ${DIFF_DOC_FIXED} 120f3572ad9SJoseph Chen sed -i "/^+$/d" ${DIFF_DOC_FIXED} 121f3572ad9SJoseph Chen 122f3572ad9SJoseph Chen while read LINE 123f3572ad9SJoseph Chen do 124f3572ad9SJoseph Chen EACH_SEVERITY=`echo "${LINE}" | awk -F "|" '{ print $3 }' | tr -d " "` 125f3572ad9SJoseph Chen if [ "${EACH_SEVERITY}" != "${SVT_CRITIAL}" -a "${EACH_SEVERITY}" != "${SVT_IMPORTANT}" -a "${EACH_SEVERITY}" != "${SVT_MODERATE}" ]; then 126f3572ad9SJoseph Chen echo "ERROR: ${DOC}: Unknown severity: ${EACH_SEVERITY}" 127f3572ad9SJoseph Chen exit 1 128f3572ad9SJoseph Chen fi 129f3572ad9SJoseph Chen 130f3572ad9SJoseph Chen # echo "## EACH: $EACH_SEVERITY" 131f3572ad9SJoseph Chen if [ -z "${TOP_SEVERITY}" ]; then 132f3572ad9SJoseph Chen TOP_SEVERITY="${EACH_SEVERITY}" 133f3572ad9SJoseph Chen elif [ "${TOP_SEVERITY}" == "${SVT_MODERATE}" ]; then 134f3572ad9SJoseph Chen if [ "${EACH_SEVERITY}" == "${SVT_CRITIAL}" -o "${EACH_SEVERITY}" == "${SVT_IMPORTANT}" ]; then 135f3572ad9SJoseph Chen TOP_SEVERITY="${EACH_SEVERITY}" 136f3572ad9SJoseph Chen fi 137f3572ad9SJoseph Chen elif [ "${TOP_SEVERITY}" == "${SVT_IMPORTANT}" ]; then 138f3572ad9SJoseph Chen if [ "${EACH_SEVERITY}" == "${SVT_CRITIAL}" ]; then 139f3572ad9SJoseph Chen TOP_SEVERITY="${EACH_SEVERITY}" 140f3572ad9SJoseph Chen fi 141f3572ad9SJoseph Chen fi 142f3572ad9SJoseph Chen done < ${DIFF_DOC_FIXED} 143f3572ad9SJoseph Chen 144f3572ad9SJoseph Chen if [ "${SEVERITY}" != "${TOP_SEVERITY}" ]; then 145f3572ad9SJoseph Chen echo "ERROR: ${DOC}: Main severity should be '${TOP_SEVERITY}'" 146f3572ad9SJoseph Chen exit 1 147f3572ad9SJoseph Chen fi 148f3572ad9SJoseph Chen fi 149f3572ad9SJoseph Chen} 150f3572ad9SJoseph Chen 151f3572ad9SJoseph Chenfunction check_docs() 152f3572ad9SJoseph Chen{ 153acf80986SJoseph Chen if git log ${ARG_COMMIT} -1 --name-only | grep -Eq '\.bin|\.elf' ; then 154acf80986SJoseph Chen DOC_CN=`git log ${ARG_COMMIT} -1 --name-only | sed -n "/_CN\.md/p"` 155acf80986SJoseph Chen DOC_EN=`git log ${ARG_COMMIT} -1 --name-only | sed -n "/_EN\.md/p"` 156f3572ad9SJoseph Chen if [ -z "${DOC_CN}" -o -z "${DOC_EN}" ]; then 157acf80986SJoseph Chen echo "ERROR: Should update CN and EN Release-Note when .bin/elf changed" 158f3572ad9SJoseph Chen exit 1 159f3572ad9SJoseph Chen fi 160755bd534SJoseph Chen 161755bd534SJoseph Chen if ! which dos2unix > /dev/null 2>&1 ; then 162755bd534SJoseph Chen echo "ERROR: No 'dos2unix'. Fix by: sudo apt-get install dos2unix" 163755bd534SJoseph Chen exit 1 164755bd534SJoseph Chen fi 165755bd534SJoseph Chen 166f3572ad9SJoseph Chen check_doc CN 167f3572ad9SJoseph Chen check_doc EN 168f3572ad9SJoseph Chen fi 1696f2bc86dSJoseph Chen 1706f2bc86dSJoseph Chen rm -f ${DIFF_SUBSET} 171f3572ad9SJoseph Chen} 172f3572ad9SJoseph Chen 17315aaf94fSJoseph Chenfunction pack_loader_image() 17424a8c2d6SJoseph Chen{ 17515aaf94fSJoseph Chen for FILE in `ls ./RKBOOT/*MINIALL*.ini` 17624a8c2d6SJoseph Chen do 17715aaf94fSJoseph Chen if [ "${FILE}" = "./RKBOOT/RK302AMINIALL.ini" -o \ 17815aaf94fSJoseph Chen "${FILE}" = "./RKBOOT/RK30BMINIALL.ini" -o \ 17915aaf94fSJoseph Chen "${FILE}" = "./RKBOOT/RK30MINIALL.ini" -o \ 18015aaf94fSJoseph Chen "${FILE}" = "./RKBOOT/RK310BMINIALL.ini" ]; then 18124a8c2d6SJoseph Chen continue; 18224a8c2d6SJoseph Chen fi 18324a8c2d6SJoseph Chen 18415aaf94fSJoseph Chen if grep -q '^PATH=img/' ${FILE}; then 18507c86261SJoseph Chen continue; 18607c86261SJoseph Chen fi 18707c86261SJoseph Chen 18815aaf94fSJoseph Chen echo "Pack loader: ${FILE}" 18915aaf94fSJoseph Chen ./tools/boot_merger ${FILE} 190f3822d68SJoseph Chen rm -f *loader*.bin *download*.bin *idblock*.img 19124a8c2d6SJoseph Chen echo 19224a8c2d6SJoseph Chen done 19324a8c2d6SJoseph Chen} 19424a8c2d6SJoseph Chen 19515aaf94fSJoseph Chenfunction pack_trust_image() 19624a8c2d6SJoseph Chen{ 19724a8c2d6SJoseph Chen # Pack 32-bit trust 19815aaf94fSJoseph Chen for FILE in `ls ./RKTRUST/*TOS*.ini` 19924a8c2d6SJoseph Chen do 20015aaf94fSJoseph Chen if ! test -s ${FILE}; then 201075296bdSJoseph Chen continue; 20215aaf94fSJoseph Chen elif ! grep -q 'TOS' ${FILE}; then 203d4bf7444SJoseph Chen continue; 20415aaf94fSJoseph Chen elif grep -q '^PATH=img/' ${FILE}; then 20507c86261SJoseph Chen continue; 20607c86261SJoseph Chen fi 20707c86261SJoseph Chen 20815aaf94fSJoseph Chen echo "Pack trust: ${FILE}" 20924a8c2d6SJoseph Chen # Parse orignal path 21015aaf94fSJoseph Chen TOS=`sed -n "/TOS=/s/TOS=//p" ${FILE}|tr -d '\r'` 21115aaf94fSJoseph Chen TOS_TA=`sed -n "/TOSTA=/s/TOSTA=//p" ${FILE}|tr -d '\r'` 21224a8c2d6SJoseph Chen 21324a8c2d6SJoseph Chen # replace "./tools/rk_tools/" with "./" to compatible legacy ini content of rkdevelop branch 21424a8c2d6SJoseph Chen TOS=$(echo ${TOS} | sed "s/tools\/rk_tools\//\.\//g") 21524a8c2d6SJoseph Chen TOS_TA=$(echo ${TOS_TA} | sed "s/tools\/rk_tools\//\.\//g") 21624a8c2d6SJoseph Chen 2179d00b70aSJoseph Chen if [ x${TOS_TA} != x -a x${TOS} != x ]; then 21824a8c2d6SJoseph Chen ./tools/loaderimage --pack --trustos ${TOS} ./trust.img 0x68400000 21924a8c2d6SJoseph Chen ./tools/loaderimage --pack --trustos ${TOS_TA} ./trust_with_ta.img 0x68400000 2209d00b70aSJoseph Chen elif [ ${TOS} ]; then 22124a8c2d6SJoseph Chen ./tools/loaderimage --pack --trustos ${TOS} ./trust.img 0x68400000 2229d00b70aSJoseph Chen elif [ ${TOS_TA} ]; then 22324a8c2d6SJoseph Chen ./tools/loaderimage --pack --trustos ${TOS_TA} ./trust.img 0x68400000 22424a8c2d6SJoseph Chen else 22524a8c2d6SJoseph Chen exit 1 22624a8c2d6SJoseph Chen fi 227f3822d68SJoseph Chen rm -f trust*.img 22824a8c2d6SJoseph Chen echo 22924a8c2d6SJoseph Chen done 23024a8c2d6SJoseph Chen 23124a8c2d6SJoseph Chen # Pack 64-bit trust 23215aaf94fSJoseph Chen for FILE in `ls ./RKTRUST/*TRUST*.ini` 23324a8c2d6SJoseph Chen do 23415aaf94fSJoseph Chen if grep -q '^PATH=img/' ${FILE}; then 23507c86261SJoseph Chen continue; 23607c86261SJoseph Chen fi 23707c86261SJoseph Chen 23815aaf94fSJoseph Chen echo "Pack trust: ${FILE}" 23915aaf94fSJoseph Chen ./tools/trust_merger ${FILE} 24015aaf94fSJoseph Chen rm -f trust*.img 24124a8c2d6SJoseph Chen echo 24224a8c2d6SJoseph Chen done 24324a8c2d6SJoseph Chen} 24424a8c2d6SJoseph Chen 24515aaf94fSJoseph Chenfunction check_dirty() 2467448aaf2SJoseph Chen{ 247f3572ad9SJoseph 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 248f3572ad9SJoseph Chen echo "Checking clean: ${FILE}" 24915aaf94fSJoseph Chen if strings ${FILE} | grep '\-dirty ' ; then 25015aaf94fSJoseph Chen echo "ERROR: ${FILE} is dirty" 2517448aaf2SJoseph Chen exit 1 2527448aaf2SJoseph Chen fi 2537448aaf2SJoseph Chen done 2547448aaf2SJoseph Chen} 2557448aaf2SJoseph Chen 25615aaf94fSJoseph Chenfunction check_stripped() 257c0efc7efSJoseph Chen{ 25815aaf94fSJoseph Chen for FILE in `find -name '*bl31*.elf'`; do 25915aaf94fSJoseph Chen echo "Checking strip: ${FILE}" 26015aaf94fSJoseph Chen INFO=`file ${FILE}` 26115aaf94fSJoseph Chen if echo ${INFO} | grep -q "not stripped" ; then 26215aaf94fSJoseph Chen echo "ERROR: ${FILE} is not stripped" 263c0efc7efSJoseph Chen exit 1 264c0efc7efSJoseph Chen fi 265c0efc7efSJoseph Chen done 266c0efc7efSJoseph Chen} 267c0efc7efSJoseph Chen 268f3572ad9SJoseph Chenfunction check_mode() 269f3572ad9SJoseph Chen{ 270f3572ad9SJoseph Chen echo "Checking file mode..." 271acf80986SJoseph 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 272acf80986SJoseph Chen git whatchanged ${ARG_COMMIT} -1 --oneline | sed -n '/RKBOOT\//p; /RKTRUST\//p; /bin\//p; /doc\//p;' | grep 755 2730f8ea74fSJoseph Chen echo "ERROR: Set 644 file permission but not 755." 274f3572ad9SJoseph Chen exit 1 275f3572ad9SJoseph Chen fi 276f3572ad9SJoseph Chen} 277f3572ad9SJoseph Chen 27815aaf94fSJoseph Chenfunction finish() 27924a8c2d6SJoseph Chen{ 280f3572ad9SJoseph Chen echo "OK, everything is nice." 28124a8c2d6SJoseph Chen echo 28224a8c2d6SJoseph Chen} 28324a8c2d6SJoseph Chen 284f3572ad9SJoseph Chencheck_mode 285f3572ad9SJoseph Chencheck_docs 2867448aaf2SJoseph Chencheck_dirty 287c0efc7efSJoseph Chencheck_stripped 28824a8c2d6SJoseph Chenpack_loader_image 28924a8c2d6SJoseph Chenpack_trust_image 29024a8c2d6SJoseph Chenfinish 291