124a8c2d6SJoseph Chen#!/bin/bash 224a8c2d6SJoseph Chenset -e 324a8c2d6SJoseph Chen 4f3572ad9SJoseph ChenDIFF_DOC_ALL="scripts/.diff_all.txt" 5f3572ad9SJoseph ChenDIFF_DOC_FIXED="scripts/.diff_fixed.txt" 6f3572ad9SJoseph Chen 7f3572ad9SJoseph Chenfunction check_doc() 8f3572ad9SJoseph Chen{ 9f3572ad9SJoseph Chen local TOP_SEVERITY LANGUAGE=$1 10f3572ad9SJoseph Chen 11f3572ad9SJoseph Chen if [ "${LANGUAGE}" == "EN" ] ; then 12f3572ad9SJoseph Chen SVT_CRITIAL="critical" 13f3572ad9SJoseph Chen SVT_IMPORTANT="important" 14f3572ad9SJoseph Chen SVT_MODERATE="moderate" 15f3572ad9SJoseph Chen DOC=`git log -1 --name-only | sed -n "/_EN\.md/p"` 16f3572ad9SJoseph Chen else 17f3572ad9SJoseph Chen SVT_CRITIAL="紧急" 18f3572ad9SJoseph Chen SVT_IMPORTANT="重要" 19f3572ad9SJoseph Chen SVT_MODERATE="普通" 20f3572ad9SJoseph Chen DOC=`git log -1 --name-only | sed -n "/_CN\.md/p"` 21f3572ad9SJoseph Chen fi 22f3572ad9SJoseph Chen 23f3572ad9SJoseph Chen echo "Checking doc: ${DOC}" 24f3572ad9SJoseph Chen 25f3572ad9SJoseph Chen git show -1 ${DOC} | sed -n "/^+/p" > ${DIFF_DOC_ALL} 26f3572ad9SJoseph Chen TITLE=`sed -n "/^+## /p" ${DIFF_DOC_ALL} | tr -d " +#"` 27f3572ad9SJoseph Chen FILE=`sed -n "/^+| 20[0-9][0-9]-/p" ${DIFF_DOC_ALL} | tr -d " " | awk -F "|" '{ print $3 }'` 28f3572ad9SJoseph Chen COMMIT=`sed -n "/^+| 20[0-9][0-9]-/p" ${DIFF_DOC_ALL} | tr -d " " | awk -F "|" '{ print $4 }'` 29f3572ad9SJoseph Chen SEVERITY=`sed -n "/^+| 20[0-9][0-9]-/p" ${DIFF_DOC_ALL} | tr -d " " | awk -F "|" '{ print $5 }'` 30f3572ad9SJoseph Chen HORIZONTAL_LINE=`sed -n "/^+------$/p" ${DIFF_DOC_ALL}` 31f3572ad9SJoseph Chen # echo "### ${COMMIT}, ${SEVERITY}, ${TITLE}, ${FILE}" 32f3572ad9SJoseph Chen 33f3572ad9SJoseph Chen # check standalone file 34f3572ad9SJoseph Chen if ! echo ${FILE} | grep -q { ; then 35f3572ad9SJoseph Chen if ! git log -1 --name-only | grep -q ${FILE}; then 36f3572ad9SJoseph Chen echo "ERROR: ${DOC}: '${FILE}' is not update in this patch" 37f3572ad9SJoseph Chen exit 1 38f3572ad9SJoseph Chen fi 39f3572ad9SJoseph Chen fi 40f3572ad9SJoseph Chen 41f3572ad9SJoseph Chen # check title 42f3572ad9SJoseph Chen if [ "${TITLE}" != "${FILE}" ]; then 43f3572ad9SJoseph Chen echo "ERROR: ${DOC}: Title '${TITLE}' is not match with '${FILE}'" 44f3572ad9SJoseph Chen exit 1 45f3572ad9SJoseph Chen fi 46f3572ad9SJoseph Chen 47f3572ad9SJoseph Chen # check commit 48f3572ad9SJoseph Chen COMMIT=${COMMIT//#/ } 49f3572ad9SJoseph Chen for LIST in ${COMMIT}; do 50f3572ad9SJoseph Chen CMT=`echo ${LIST} | cut -d : -f 2` 51f3572ad9SJoseph Chen if ! git log -1 | grep -q ${CMT} ; then 52f3572ad9SJoseph Chen echo "ERROR: ${DOC}: '${CMT}' is not match in commit message" 53f3572ad9SJoseph Chen exit 1 54f3572ad9SJoseph Chen fi 55*39bfe203SJoseph Chen 56*39bfe203SJoseph Chen if ! echo ${FILE} | grep -q { ; then 57*39bfe203SJoseph Chen if echo ${FILE} | grep -Eq 'spl_|tpl_|bl31_|bl32_|tee_' ; then 58*39bfe203SJoseph Chen FILE_PATH=`find -name ${FILE}` 59*39bfe203SJoseph Chen if ! strings ${FILE_PATH} | grep -q ${CMT} ; then 60*39bfe203SJoseph Chen echo "ERROR: ${DOC}: ${FILE} is not build from '${CMT}'" 61*39bfe203SJoseph Chen exit 1 62*39bfe203SJoseph Chen fi 63*39bfe203SJoseph Chen fi 64*39bfe203SJoseph Chen fi 65f3572ad9SJoseph Chen done 66f3572ad9SJoseph Chen 67f3572ad9SJoseph Chen # check severity 68f3572ad9SJoseph Chen if [ "${SEVERITY}" != "${SVT_CRITIAL}" -a "${SEVERITY}" != "${SVT_IMPORTANT}" -a "${SEVERITY}" != "${SVT_MODERATE}" ]; then 69f3572ad9SJoseph Chen echo "ERROR: ${DOC}: Unknown main severity: ${SEVERITY}" 70f3572ad9SJoseph Chen exit 1 71f3572ad9SJoseph Chen fi 72f3572ad9SJoseph Chen 73f3572ad9SJoseph Chen # check horizontal line 74f3572ad9SJoseph Chen if [ -z "${HORIZONTAL_LINE}" ]; then 75f3572ad9SJoseph Chen echo "ERROR: ${DOC}: No horizontal line '------' at the last" 76f3572ad9SJoseph Chen exit 1 77f3572ad9SJoseph Chen fi 78f3572ad9SJoseph Chen 79f3572ad9SJoseph Chen # check 'Fixed' content 80f3572ad9SJoseph Chen if grep -q "^+### Fixed" ${DIFF_DOC_ALL} ; then 81f3572ad9SJoseph Chen awk -v RS='### Fixed' 'END{printf "%s", $0}' ${DIFF_DOC_ALL} > ${DIFF_DOC_FIXED} 82f3572ad9SJoseph Chen sed -i "/^$/d" ${DIFF_DOC_FIXED} 83f3572ad9SJoseph Chen sed -i "/Index/d" ${DIFF_DOC_FIXED} 84f3572ad9SJoseph Chen sed -i "/---/d" ${DIFF_DOC_FIXED} 85f3572ad9SJoseph Chen sed -i "/^+$/d" ${DIFF_DOC_FIXED} 86f3572ad9SJoseph Chen 87f3572ad9SJoseph Chen while read LINE 88f3572ad9SJoseph Chen do 89f3572ad9SJoseph Chen EACH_SEVERITY=`echo "${LINE}" | awk -F "|" '{ print $3 }' | tr -d " "` 90f3572ad9SJoseph Chen if [ "${EACH_SEVERITY}" != "${SVT_CRITIAL}" -a "${EACH_SEVERITY}" != "${SVT_IMPORTANT}" -a "${EACH_SEVERITY}" != "${SVT_MODERATE}" ]; then 91f3572ad9SJoseph Chen echo "ERROR: ${DOC}: Unknown severity: ${EACH_SEVERITY}" 92f3572ad9SJoseph Chen exit 1 93f3572ad9SJoseph Chen fi 94f3572ad9SJoseph Chen 95f3572ad9SJoseph Chen # echo "## EACH: $EACH_SEVERITY" 96f3572ad9SJoseph Chen if [ -z "${TOP_SEVERITY}" ]; then 97f3572ad9SJoseph Chen TOP_SEVERITY="${EACH_SEVERITY}" 98f3572ad9SJoseph Chen elif [ "${TOP_SEVERITY}" == "${SVT_MODERATE}" ]; then 99f3572ad9SJoseph Chen if [ "${EACH_SEVERITY}" == "${SVT_CRITIAL}" -o "${EACH_SEVERITY}" == "${SVT_IMPORTANT}" ]; then 100f3572ad9SJoseph Chen TOP_SEVERITY="${EACH_SEVERITY}" 101f3572ad9SJoseph Chen fi 102f3572ad9SJoseph Chen elif [ "${TOP_SEVERITY}" == "${SVT_IMPORTANT}" ]; then 103f3572ad9SJoseph Chen if [ "${EACH_SEVERITY}" == "${SVT_CRITIAL}" ]; then 104f3572ad9SJoseph Chen TOP_SEVERITY="${EACH_SEVERITY}" 105f3572ad9SJoseph Chen fi 106f3572ad9SJoseph Chen fi 107f3572ad9SJoseph Chen done < ${DIFF_DOC_FIXED} 108f3572ad9SJoseph Chen 109f3572ad9SJoseph Chen if [ "${SEVERITY}" != "${TOP_SEVERITY}" ]; then 110f3572ad9SJoseph Chen echo "ERROR: ${DOC}: Main severity should be '${TOP_SEVERITY}'" 111f3572ad9SJoseph Chen exit 1 112f3572ad9SJoseph Chen fi 113f3572ad9SJoseph Chen fi 114f3572ad9SJoseph Chen} 115f3572ad9SJoseph Chen 116f3572ad9SJoseph Chenfunction check_docs() 117f3572ad9SJoseph Chen{ 118*39bfe203SJoseph Chen if git log -1 --name-only | grep -Eq '\.bin|\.elf' ; then 119f3572ad9SJoseph Chen DOC_CN=`git log -1 --name-only | sed -n "/_CN\.md/p"` 120f3572ad9SJoseph Chen DOC_EN=`git log -1 --name-only | sed -n "/_EN\.md/p"` 121f3572ad9SJoseph Chen if [ -z "${DOC_CN}" -o -z "${DOC_EN}" ]; then 122f3572ad9SJoseph Chen echo "ERROR: Update CN/EN Release-Note when .bin or .elf changes" 123f3572ad9SJoseph Chen exit 1 124f3572ad9SJoseph Chen fi 125f3572ad9SJoseph Chen check_doc CN 126f3572ad9SJoseph Chen check_doc EN 127f3572ad9SJoseph Chen fi 128f3572ad9SJoseph Chen} 129f3572ad9SJoseph Chen 13015aaf94fSJoseph Chenfunction pack_loader_image() 13124a8c2d6SJoseph Chen{ 13215aaf94fSJoseph Chen for FILE in `ls ./RKBOOT/*MINIALL*.ini` 13324a8c2d6SJoseph Chen do 13415aaf94fSJoseph Chen if [ "${FILE}" = "./RKBOOT/RK302AMINIALL.ini" -o \ 13515aaf94fSJoseph Chen "${FILE}" = "./RKBOOT/RK30BMINIALL.ini" -o \ 13615aaf94fSJoseph Chen "${FILE}" = "./RKBOOT/RK30MINIALL.ini" -o \ 13715aaf94fSJoseph Chen "${FILE}" = "./RKBOOT/RK310BMINIALL.ini" ]; then 13824a8c2d6SJoseph Chen continue; 13924a8c2d6SJoseph Chen fi 14024a8c2d6SJoseph Chen 14115aaf94fSJoseph Chen if grep -q '^PATH=img/' ${FILE}; then 14207c86261SJoseph Chen continue; 14307c86261SJoseph Chen fi 14407c86261SJoseph Chen 14515aaf94fSJoseph Chen echo "Pack loader: ${FILE}" 14615aaf94fSJoseph Chen ./tools/boot_merger ${FILE} 147f3822d68SJoseph Chen rm -f *loader*.bin *download*.bin *idblock*.img 14824a8c2d6SJoseph Chen echo 14924a8c2d6SJoseph Chen done 15024a8c2d6SJoseph Chen} 15124a8c2d6SJoseph Chen 15215aaf94fSJoseph Chenfunction pack_trust_image() 15324a8c2d6SJoseph Chen{ 15424a8c2d6SJoseph Chen # Pack 32-bit trust 15515aaf94fSJoseph Chen for FILE in `ls ./RKTRUST/*TOS*.ini` 15624a8c2d6SJoseph Chen do 15715aaf94fSJoseph Chen if ! test -s ${FILE}; then 158075296bdSJoseph Chen continue; 15915aaf94fSJoseph Chen elif ! grep -q 'TOS' ${FILE}; then 160d4bf7444SJoseph Chen continue; 16115aaf94fSJoseph Chen elif grep -q '^PATH=img/' ${FILE}; then 16207c86261SJoseph Chen continue; 16307c86261SJoseph Chen fi 16407c86261SJoseph Chen 16515aaf94fSJoseph Chen echo "Pack trust: ${FILE}" 16624a8c2d6SJoseph Chen # Parse orignal path 16715aaf94fSJoseph Chen TOS=`sed -n "/TOS=/s/TOS=//p" ${FILE}|tr -d '\r'` 16815aaf94fSJoseph Chen TOS_TA=`sed -n "/TOSTA=/s/TOSTA=//p" ${FILE}|tr -d '\r'` 16924a8c2d6SJoseph Chen 17024a8c2d6SJoseph Chen # replace "./tools/rk_tools/" with "./" to compatible legacy ini content of rkdevelop branch 17124a8c2d6SJoseph Chen TOS=$(echo ${TOS} | sed "s/tools\/rk_tools\//\.\//g") 17224a8c2d6SJoseph Chen TOS_TA=$(echo ${TOS_TA} | sed "s/tools\/rk_tools\//\.\//g") 17324a8c2d6SJoseph Chen 1749d00b70aSJoseph Chen if [ x${TOS_TA} != x -a x${TOS} != x ]; then 17524a8c2d6SJoseph Chen ./tools/loaderimage --pack --trustos ${TOS} ./trust.img 0x68400000 17624a8c2d6SJoseph Chen ./tools/loaderimage --pack --trustos ${TOS_TA} ./trust_with_ta.img 0x68400000 1779d00b70aSJoseph Chen elif [ ${TOS} ]; then 17824a8c2d6SJoseph Chen ./tools/loaderimage --pack --trustos ${TOS} ./trust.img 0x68400000 1799d00b70aSJoseph Chen elif [ ${TOS_TA} ]; then 18024a8c2d6SJoseph Chen ./tools/loaderimage --pack --trustos ${TOS_TA} ./trust.img 0x68400000 18124a8c2d6SJoseph Chen else 18224a8c2d6SJoseph Chen exit 1 18324a8c2d6SJoseph Chen fi 184f3822d68SJoseph Chen rm -f trust*.img 18524a8c2d6SJoseph Chen echo 18624a8c2d6SJoseph Chen done 18724a8c2d6SJoseph Chen 18824a8c2d6SJoseph Chen # Pack 64-bit trust 18915aaf94fSJoseph Chen for FILE in `ls ./RKTRUST/*TRUST*.ini` 19024a8c2d6SJoseph Chen do 19115aaf94fSJoseph Chen if grep -q '^PATH=img/' ${FILE}; then 19207c86261SJoseph Chen continue; 19307c86261SJoseph Chen fi 19407c86261SJoseph Chen 19515aaf94fSJoseph Chen echo "Pack trust: ${FILE}" 19615aaf94fSJoseph Chen ./tools/trust_merger ${FILE} 19715aaf94fSJoseph Chen rm -f trust*.img 19824a8c2d6SJoseph Chen echo 19924a8c2d6SJoseph Chen done 20024a8c2d6SJoseph Chen} 20124a8c2d6SJoseph Chen 20215aaf94fSJoseph Chenfunction check_dirty() 2037448aaf2SJoseph Chen{ 204f3572ad9SJoseph 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 205f3572ad9SJoseph Chen echo "Checking clean: ${FILE}" 20615aaf94fSJoseph Chen if strings ${FILE} | grep '\-dirty ' ; then 20715aaf94fSJoseph Chen echo "ERROR: ${FILE} is dirty" 2087448aaf2SJoseph Chen exit 1 2097448aaf2SJoseph Chen fi 2107448aaf2SJoseph Chen done 2117448aaf2SJoseph Chen} 2127448aaf2SJoseph Chen 21315aaf94fSJoseph Chenfunction check_stripped() 214c0efc7efSJoseph Chen{ 21515aaf94fSJoseph Chen for FILE in `find -name '*bl31*.elf'`; do 21615aaf94fSJoseph Chen echo "Checking strip: ${FILE}" 21715aaf94fSJoseph Chen INFO=`file ${FILE}` 21815aaf94fSJoseph Chen if echo ${INFO} | grep -q "not stripped" ; then 21915aaf94fSJoseph Chen echo "ERROR: ${FILE} is not stripped" 220c0efc7efSJoseph Chen exit 1 221c0efc7efSJoseph Chen fi 222c0efc7efSJoseph Chen done 223c0efc7efSJoseph Chen} 224c0efc7efSJoseph Chen 225f3572ad9SJoseph Chenfunction check_mode() 226f3572ad9SJoseph Chen{ 227f3572ad9SJoseph Chen echo "Checking file mode..." 228f3572ad9SJoseph Chen if git whatchanged -1 --oneline | sed -n '/RKBOOT\//p; /RKTRUST\//p; /bin\//p; /doc\//p;' | awk '{ print $2 }' | grep -q 755 ; then 229f3572ad9SJoseph Chen git whatchanged -1 --oneline | sed -n '/RKBOOT\//p; /RKTRUST\//p; /bin\//p; /doc\//p;' | grep 755 230f3572ad9SJoseph Chen echo "ERROR: Set 644 permission but not 755." 231f3572ad9SJoseph Chen exit 1 232f3572ad9SJoseph Chen fi 233f3572ad9SJoseph Chen} 234f3572ad9SJoseph Chen 23515aaf94fSJoseph Chenfunction finish() 23624a8c2d6SJoseph Chen{ 237f3572ad9SJoseph Chen rm -f ${DIFF_DOC_ALL} ${DIFF_DOC_FIXED} 238f3572ad9SJoseph Chen echo "OK, everything is nice." 23924a8c2d6SJoseph Chen echo 24024a8c2d6SJoseph Chen} 24124a8c2d6SJoseph Chen 242f3572ad9SJoseph Chencheck_mode 243f3572ad9SJoseph Chencheck_docs 2447448aaf2SJoseph Chencheck_dirty 245c0efc7efSJoseph Chencheck_stripped 24624a8c2d6SJoseph Chenpack_loader_image 24724a8c2d6SJoseph Chenpack_trust_image 24824a8c2d6SJoseph Chenfinish 249