xref: /rkbin/scripts/checkpatch.sh (revision 6f2bc86d6ba789c0e02549b797208093a1f01473)
124a8c2d6SJoseph Chen#!/bin/bash
224a8c2d6SJoseph Chenset -e
324a8c2d6SJoseph Chen
4*6f2bc86dSJoseph ChenDIFF_SUBSET="scripts/.diff_*"
5f3572ad9SJoseph ChenDIFF_DOC_ALL="scripts/.diff_all.txt"
6f3572ad9SJoseph ChenDIFF_DOC_FIXED="scripts/.diff_fixed.txt"
7f3572ad9SJoseph Chen
8f3572ad9SJoseph Chenfunction check_doc()
9f3572ad9SJoseph Chen{
10f3572ad9SJoseph Chen	local TOP_SEVERITY LANGUAGE=$1
11f3572ad9SJoseph Chen
12f3572ad9SJoseph Chen	if [ "${LANGUAGE}" == "EN" ] ; then
13f3572ad9SJoseph Chen		SVT_CRITIAL="critical"
14f3572ad9SJoseph Chen		SVT_IMPORTANT="important"
15f3572ad9SJoseph Chen		SVT_MODERATE="moderate"
16f3572ad9SJoseph Chen		DOC=`git log -1 --name-only | sed -n "/_EN\.md/p"`
17f3572ad9SJoseph Chen	else
18f3572ad9SJoseph Chen		SVT_CRITIAL="紧急"
19f3572ad9SJoseph Chen		SVT_IMPORTANT="重要"
20f3572ad9SJoseph Chen		SVT_MODERATE="普通"
21f3572ad9SJoseph Chen		DOC=`git log -1 --name-only | sed -n "/_CN\.md/p"`
22f3572ad9SJoseph Chen	fi
23f3572ad9SJoseph Chen
24f3572ad9SJoseph Chen	echo "Checking doc: ${DOC}"
25f3572ad9SJoseph Chen
26*6f2bc86dSJoseph Chen	# check DOS encoding
27f3572ad9SJoseph Chen	git show -1 ${DOC} | sed -n "/^+/p" > ${DIFF_DOC_ALL}
28*6f2bc86dSJoseph Chen	git show -1 ${DOC} | sed -n "/^+/p" > ${DIFF_DOC_ALL}.dos
29*6f2bc86dSJoseph Chen	dos2unix ${DIFF_DOC_ALL}.dos >/dev/null 2>&1
30*6f2bc86dSJoseph Chen	CSUM1=`md5sum ${DIFF_DOC_ALL} | awk '{ print $1 }'`
31*6f2bc86dSJoseph Chen	CSUM2=`md5sum ${DIFF_DOC_ALL}.dos | awk '{ print $1 }'`
32*6f2bc86dSJoseph Chen	if [ "${CSUM1}" != "${CSUM2}" ]; then
33*6f2bc86dSJoseph Chen		echo "ERROR: ${DOC} is DOS encoding. Fix it by: 'dos2unix ${DOC}'"
34*6f2bc86dSJoseph Chen		exit 1
35*6f2bc86dSJoseph Chen	fi
36*6f2bc86dSJoseph Chen
37f3572ad9SJoseph Chen	TITLE=`sed -n "/^+## /p" ${DIFF_DOC_ALL} | tr -d " +#"`
38f3572ad9SJoseph Chen	FILE=`sed -n "/^+| 20[0-9][0-9]-/p" ${DIFF_DOC_ALL} | tr -d " " | awk -F "|" '{ print $3 }'`
39f3572ad9SJoseph Chen	COMMIT=`sed -n "/^+| 20[0-9][0-9]-/p" ${DIFF_DOC_ALL} | tr -d " " | awk -F "|" '{ print $4 }'`
40f3572ad9SJoseph Chen	SEVERITY=`sed -n "/^+| 20[0-9][0-9]-/p" ${DIFF_DOC_ALL} | tr -d " " | awk -F "|" '{ print $5 }'`
41f3572ad9SJoseph Chen	HORIZONTAL_LINE=`sed -n "/^+------$/p" ${DIFF_DOC_ALL}`
42f3572ad9SJoseph Chen	# echo "### ${COMMIT}, ${SEVERITY}, ${TITLE}, ${FILE}"
43f3572ad9SJoseph Chen
44f3572ad9SJoseph Chen	# check standalone file
45f3572ad9SJoseph Chen	if ! echo ${FILE} | grep -q { ; then
46f3572ad9SJoseph Chen		if ! git log -1 --name-only | grep -q ${FILE}; then
47f3572ad9SJoseph Chen			echo "ERROR: ${DOC}: '${FILE}' is not update in this patch"
48f3572ad9SJoseph Chen			exit 1
49f3572ad9SJoseph Chen		fi
50f3572ad9SJoseph Chen	fi
51f3572ad9SJoseph Chen
52f3572ad9SJoseph Chen	# check title
53f3572ad9SJoseph Chen	if [ "${TITLE}" != "${FILE}" ]; then
54f3572ad9SJoseph Chen		echo "ERROR: ${DOC}: Title '${TITLE}' is not match with '${FILE}'"
55f3572ad9SJoseph Chen		exit 1
56f3572ad9SJoseph Chen	fi
57f3572ad9SJoseph Chen
58f3572ad9SJoseph Chen	# check commit
59f3572ad9SJoseph Chen	COMMIT=${COMMIT//#/ }
60f3572ad9SJoseph Chen	for LIST in ${COMMIT}; do
61f3572ad9SJoseph Chen		CMT=`echo ${LIST} | cut -d : -f 2`
62f3572ad9SJoseph Chen		if ! git log -1 | grep -q ${CMT} ; then
63f3572ad9SJoseph Chen			echo "ERROR: ${DOC}: '${CMT}' is not match in commit message"
64f3572ad9SJoseph Chen			exit 1
65f3572ad9SJoseph Chen		fi
6639bfe203SJoseph Chen
6739bfe203SJoseph Chen		if ! echo ${FILE} | grep -q { ; then
6839bfe203SJoseph Chen			if echo ${FILE} | grep -Eq 'spl_|tpl_|bl31_|bl32_|tee_' ; then
6939bfe203SJoseph Chen				FILE_PATH=`find -name ${FILE}`
7039bfe203SJoseph Chen				if ! strings ${FILE_PATH} | grep -q ${CMT} ; then
7139bfe203SJoseph Chen					echo "ERROR: ${DOC}: ${FILE} is not build from '${CMT}'"
7239bfe203SJoseph Chen					exit 1
7339bfe203SJoseph Chen				fi
7439bfe203SJoseph Chen			fi
7539bfe203SJoseph Chen		fi
76f3572ad9SJoseph Chen	done
77f3572ad9SJoseph Chen
78f3572ad9SJoseph Chen	# check severity
79f3572ad9SJoseph Chen	if [ "${SEVERITY}" != "${SVT_CRITIAL}" -a "${SEVERITY}" != "${SVT_IMPORTANT}" -a "${SEVERITY}" != "${SVT_MODERATE}" ]; then
80f3572ad9SJoseph Chen		echo "ERROR: ${DOC}: Unknown main severity: ${SEVERITY}"
81f3572ad9SJoseph Chen		exit 1
82f3572ad9SJoseph Chen	fi
83f3572ad9SJoseph Chen
84f3572ad9SJoseph Chen	# check horizontal line
85f3572ad9SJoseph Chen	if [ -z "${HORIZONTAL_LINE}" ]; then
86f3572ad9SJoseph Chen		echo "ERROR: ${DOC}: No horizontal line '------' at the last"
87f3572ad9SJoseph Chen		exit 1
88f3572ad9SJoseph Chen	fi
89f3572ad9SJoseph Chen
90f3572ad9SJoseph Chen	# check 'Fixed' content
91f3572ad9SJoseph Chen	if grep -q "^+### Fixed" ${DIFF_DOC_ALL} ; then
92f3572ad9SJoseph Chen		awk -v RS='### Fixed' 'END{printf "%s", $0}' ${DIFF_DOC_ALL} > ${DIFF_DOC_FIXED}
93f3572ad9SJoseph Chen		sed -i "/^$/d"    ${DIFF_DOC_FIXED}
94f3572ad9SJoseph Chen		sed -i "/Index/d" ${DIFF_DOC_FIXED}
95f3572ad9SJoseph Chen		sed -i "/---/d"   ${DIFF_DOC_FIXED}
96f3572ad9SJoseph Chen		sed -i "/^+$/d"   ${DIFF_DOC_FIXED}
97f3572ad9SJoseph Chen
98f3572ad9SJoseph Chen		while read LINE
99f3572ad9SJoseph Chen		do
100f3572ad9SJoseph Chen			EACH_SEVERITY=`echo "${LINE}" | awk -F "|" '{ print $3 }' | tr -d " "`
101f3572ad9SJoseph Chen			if [ "${EACH_SEVERITY}" != "${SVT_CRITIAL}" -a "${EACH_SEVERITY}" != "${SVT_IMPORTANT}" -a "${EACH_SEVERITY}" != "${SVT_MODERATE}" ]; then
102f3572ad9SJoseph Chen				echo "ERROR: ${DOC}: Unknown severity: ${EACH_SEVERITY}"
103f3572ad9SJoseph Chen				exit 1
104f3572ad9SJoseph Chen			fi
105f3572ad9SJoseph Chen
106f3572ad9SJoseph Chen			# echo "## EACH: $EACH_SEVERITY"
107f3572ad9SJoseph Chen			if [ -z "${TOP_SEVERITY}" ]; then
108f3572ad9SJoseph Chen				TOP_SEVERITY="${EACH_SEVERITY}"
109f3572ad9SJoseph Chen			elif [ "${TOP_SEVERITY}" == "${SVT_MODERATE}" ]; then
110f3572ad9SJoseph Chen				if [ "${EACH_SEVERITY}" == "${SVT_CRITIAL}" -o "${EACH_SEVERITY}" == "${SVT_IMPORTANT}" ]; then
111f3572ad9SJoseph Chen						TOP_SEVERITY="${EACH_SEVERITY}"
112f3572ad9SJoseph Chen				fi
113f3572ad9SJoseph Chen			elif [ "${TOP_SEVERITY}" == "${SVT_IMPORTANT}" ]; then
114f3572ad9SJoseph Chen				if [ "${EACH_SEVERITY}" == "${SVT_CRITIAL}" ]; then
115f3572ad9SJoseph Chen						TOP_SEVERITY="${EACH_SEVERITY}"
116f3572ad9SJoseph Chen				fi
117f3572ad9SJoseph Chen			fi
118f3572ad9SJoseph Chen		done < ${DIFF_DOC_FIXED}
119f3572ad9SJoseph Chen
120f3572ad9SJoseph Chen		if [ "${SEVERITY}" != "${TOP_SEVERITY}" ]; then
121f3572ad9SJoseph Chen			echo "ERROR: ${DOC}: Main severity should be '${TOP_SEVERITY}'"
122f3572ad9SJoseph Chen			exit 1
123f3572ad9SJoseph Chen		fi
124f3572ad9SJoseph Chen	fi
125f3572ad9SJoseph Chen}
126f3572ad9SJoseph Chen
127f3572ad9SJoseph Chenfunction check_docs()
128f3572ad9SJoseph Chen{
12939bfe203SJoseph Chen	if git log -1 --name-only | grep -Eq '\.bin|\.elf' ; then
130f3572ad9SJoseph Chen		DOC_CN=`git log -1 --name-only | sed -n "/_CN\.md/p"`
131f3572ad9SJoseph Chen		DOC_EN=`git log -1 --name-only | sed -n "/_EN\.md/p"`
132f3572ad9SJoseph Chen		if [ -z "${DOC_CN}" -o -z "${DOC_EN}" ]; then
133f3572ad9SJoseph Chen			echo "ERROR: Update CN/EN Release-Note when .bin or .elf changes"
134f3572ad9SJoseph Chen			exit 1
135f3572ad9SJoseph Chen		fi
136f3572ad9SJoseph Chen		check_doc CN
137f3572ad9SJoseph Chen		check_doc EN
138f3572ad9SJoseph Chen	fi
139*6f2bc86dSJoseph Chen
140*6f2bc86dSJoseph Chen	rm -f ${DIFF_SUBSET}
141f3572ad9SJoseph Chen}
142f3572ad9SJoseph Chen
14315aaf94fSJoseph Chenfunction pack_loader_image()
14424a8c2d6SJoseph Chen{
14515aaf94fSJoseph Chen	for FILE in `ls ./RKBOOT/*MINIALL*.ini`
14624a8c2d6SJoseph Chen	do
14715aaf94fSJoseph Chen		if [ "${FILE}" = "./RKBOOT/RK302AMINIALL.ini" -o \
14815aaf94fSJoseph Chen			 "${FILE}" = "./RKBOOT/RK30BMINIALL.ini" -o \
14915aaf94fSJoseph Chen			 "${FILE}" = "./RKBOOT/RK30MINIALL.ini" -o \
15015aaf94fSJoseph Chen			 "${FILE}" = "./RKBOOT/RK310BMINIALL.ini" ]; then
15124a8c2d6SJoseph Chen			continue;
15224a8c2d6SJoseph Chen		fi
15324a8c2d6SJoseph Chen
15415aaf94fSJoseph Chen		if grep -q '^PATH=img/' ${FILE}; then
15507c86261SJoseph Chen			continue;
15607c86261SJoseph Chen		fi
15707c86261SJoseph Chen
15815aaf94fSJoseph Chen		echo "Pack loader: ${FILE}"
15915aaf94fSJoseph Chen		./tools/boot_merger ${FILE}
160f3822d68SJoseph Chen		rm -f *loader*.bin *download*.bin *idblock*.img
16124a8c2d6SJoseph Chen		echo
16224a8c2d6SJoseph Chen	done
16324a8c2d6SJoseph Chen}
16424a8c2d6SJoseph Chen
16515aaf94fSJoseph Chenfunction pack_trust_image()
16624a8c2d6SJoseph Chen{
16724a8c2d6SJoseph Chen	# Pack 32-bit trust
16815aaf94fSJoseph Chen	for FILE in `ls ./RKTRUST/*TOS*.ini`
16924a8c2d6SJoseph Chen	do
17015aaf94fSJoseph Chen		if ! test -s ${FILE}; then
171075296bdSJoseph Chen			continue;
17215aaf94fSJoseph Chen		elif ! grep -q 'TOS' ${FILE}; then
173d4bf7444SJoseph Chen			continue;
17415aaf94fSJoseph Chen		elif grep -q '^PATH=img/' ${FILE}; then
17507c86261SJoseph Chen			continue;
17607c86261SJoseph Chen		fi
17707c86261SJoseph Chen
17815aaf94fSJoseph Chen		echo "Pack trust: ${FILE}"
17924a8c2d6SJoseph Chen		# Parse orignal path
18015aaf94fSJoseph Chen		TOS=`sed -n "/TOS=/s/TOS=//p" ${FILE}|tr -d '\r'`
18115aaf94fSJoseph Chen		TOS_TA=`sed -n "/TOSTA=/s/TOSTA=//p" ${FILE}|tr -d '\r'`
18224a8c2d6SJoseph Chen
18324a8c2d6SJoseph Chen		# replace "./tools/rk_tools/" with "./" to compatible legacy ini content of rkdevelop branch
18424a8c2d6SJoseph Chen		TOS=$(echo ${TOS} | sed "s/tools\/rk_tools\//\.\//g")
18524a8c2d6SJoseph Chen		TOS_TA=$(echo ${TOS_TA} | sed "s/tools\/rk_tools\//\.\//g")
18624a8c2d6SJoseph Chen
1879d00b70aSJoseph Chen		if [ x${TOS_TA} != x -a x${TOS} != x ]; then
18824a8c2d6SJoseph Chen			./tools/loaderimage --pack --trustos ${TOS} ./trust.img 0x68400000
18924a8c2d6SJoseph Chen			./tools/loaderimage --pack --trustos ${TOS_TA} ./trust_with_ta.img 0x68400000
1909d00b70aSJoseph Chen		elif [ ${TOS} ]; then
19124a8c2d6SJoseph Chen			./tools/loaderimage --pack --trustos ${TOS} ./trust.img 0x68400000
1929d00b70aSJoseph Chen		elif [ ${TOS_TA} ]; then
19324a8c2d6SJoseph Chen			./tools/loaderimage --pack --trustos ${TOS_TA} ./trust.img 0x68400000
19424a8c2d6SJoseph Chen		else
19524a8c2d6SJoseph Chen			exit 1
19624a8c2d6SJoseph Chen		fi
197f3822d68SJoseph Chen		rm -f trust*.img
19824a8c2d6SJoseph Chen		echo
19924a8c2d6SJoseph Chen	done
20024a8c2d6SJoseph Chen
20124a8c2d6SJoseph Chen	# Pack 64-bit trust
20215aaf94fSJoseph Chen	for FILE in `ls ./RKTRUST/*TRUST*.ini`
20324a8c2d6SJoseph Chen	do
20415aaf94fSJoseph Chen		if grep -q '^PATH=img/' ${FILE}; then
20507c86261SJoseph Chen			continue;
20607c86261SJoseph Chen		fi
20707c86261SJoseph Chen
20815aaf94fSJoseph Chen		echo "Pack trust: ${FILE}"
20915aaf94fSJoseph Chen		./tools/trust_merger ${FILE}
21015aaf94fSJoseph Chen		rm -f trust*.img
21124a8c2d6SJoseph Chen		echo
21224a8c2d6SJoseph Chen	done
21324a8c2d6SJoseph Chen}
21424a8c2d6SJoseph Chen
21515aaf94fSJoseph Chenfunction check_dirty()
2167448aaf2SJoseph Chen{
217f3572ad9SJoseph 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
218f3572ad9SJoseph Chen		echo "Checking clean: ${FILE}"
21915aaf94fSJoseph Chen		if strings ${FILE} | grep '\-dirty ' ; then
22015aaf94fSJoseph Chen			echo "ERROR: ${FILE} is dirty"
2217448aaf2SJoseph Chen			exit 1
2227448aaf2SJoseph Chen		fi
2237448aaf2SJoseph Chen	done
2247448aaf2SJoseph Chen}
2257448aaf2SJoseph Chen
22615aaf94fSJoseph Chenfunction check_stripped()
227c0efc7efSJoseph Chen{
22815aaf94fSJoseph Chen	for FILE in `find -name '*bl31*.elf'`; do
22915aaf94fSJoseph Chen		echo "Checking strip: ${FILE}"
23015aaf94fSJoseph Chen		INFO=`file ${FILE}`
23115aaf94fSJoseph Chen		if echo ${INFO} | grep -q "not stripped" ; then
23215aaf94fSJoseph Chen			echo "ERROR: ${FILE} is not stripped"
233c0efc7efSJoseph Chen			exit 1
234c0efc7efSJoseph Chen		fi
235c0efc7efSJoseph Chen	done
236c0efc7efSJoseph Chen}
237c0efc7efSJoseph Chen
238f3572ad9SJoseph Chenfunction check_mode()
239f3572ad9SJoseph Chen{
240f3572ad9SJoseph Chen	echo "Checking file mode..."
241f3572ad9SJoseph Chen	if git whatchanged -1 --oneline | sed -n '/RKBOOT\//p; /RKTRUST\//p; /bin\//p; /doc\//p;' | awk '{ print $2 }' | grep -q 755 ; then
242f3572ad9SJoseph Chen		git whatchanged -1 --oneline | sed -n '/RKBOOT\//p; /RKTRUST\//p; /bin\//p; /doc\//p;' | grep 755
243f3572ad9SJoseph Chen		echo "ERROR: Set 644 permission but not 755."
244f3572ad9SJoseph Chen		exit 1
245f3572ad9SJoseph Chen	fi
246f3572ad9SJoseph Chen}
247f3572ad9SJoseph Chen
24815aaf94fSJoseph Chenfunction finish()
24924a8c2d6SJoseph Chen{
250f3572ad9SJoseph Chen	echo "OK, everything is nice."
25124a8c2d6SJoseph Chen	echo
25224a8c2d6SJoseph Chen}
25324a8c2d6SJoseph Chen
254f3572ad9SJoseph Chencheck_mode
255f3572ad9SJoseph Chencheck_docs
2567448aaf2SJoseph Chencheck_dirty
257c0efc7efSJoseph Chencheck_stripped
25824a8c2d6SJoseph Chenpack_loader_image
25924a8c2d6SJoseph Chenpack_trust_image
26024a8c2d6SJoseph Chenfinish
261