xref: /rkbin/scripts/checkpatch.sh (revision 2a884fcb3aa40d683a613c178d4744f9c1883f2d)
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