diff options
| -rwxr-xr-x | script/build/serprog/rp2040 | 21 | ||||
| -rwxr-xr-x | script/build/serprog/stm32 | 19 | 
2 files changed, 29 insertions, 11 deletions
| diff --git a/script/build/serprog/rp2040 b/script/build/serprog/rp2040 index 3b4fbf14..83c8af69 100755 --- a/script/build/serprog/rp2040 +++ b/script/build/serprog/rp2040 @@ -24,23 +24,25 @@ set -u -e  . "include/err.sh"  serprog_release_dir=$(pwd)/bin/serprog_rp2040 -sdk_dir=$(pwd)/util-fw/rp2040/pico-sdk  src_dir=$(pwd)/util-fw/rp2040/pico-serprog +sdk_dir=$(pwd)/util-fw/rp2040/pico-sdk +boards_dir=${sdk_dir}/src/boards/include/boards  main()  { -	printf "Compiling serprog firmware for Raspberry Pi Pico\n" -  	[ -d "${src_dir}/" ] || ./update project repo rpi-pico-serprog \  		|| err "fetch rpi-pico-serprog failed!\n"  	mkdir -p "${serprog_release_dir}" || \  	    err "can't create dir: ${serprog_release_dir}" -	boards_dir=${sdk_dir}/src/boards/include/boards -  	if [ $# -gt 0 ] ; then -		buildrom "${1}" +		if [ "${1}" = "list" ] ; then +			list_boards +		else +			buildrom "${1}" +		fi  	else +		printf "Building pico-serprog for all boards\n"  		basename -a -s .h ${boards_dir}/*.h | while read board ; do  			[ "${board}" = "none" ] || buildrom ${board}  		done @@ -51,6 +53,7 @@ main()  buildrom()  {  	board=${1} +	printf "Building pico-serprog for ${board}\n"  	cmake -DPICO_BOARD="${board}" -DPICO_SDK_PATH="${sdk_dir}" \  	      -B "${src_dir}/build" "${src_dir}" \  		|| err "can't cmake ${src_dir}" @@ -61,4 +64,10 @@ buildrom()  	printf "output to ${serprog_release_dir}/serprog_${board}.uf2\n"  } +list_boards() +{ +	printf "Available boards for pico-serprog:\n" +	basename -a -s .h ${boards_dir}/*.h +} +  main $@ diff --git a/script/build/serprog/stm32 b/script/build/serprog/stm32 index 41412957..94c45bc8 100755 --- a/script/build/serprog/stm32 +++ b/script/build/serprog/stm32 @@ -25,21 +25,23 @@ set -u -e  serprog_release_dir=$(pwd)/bin/serprog_stm32  src_dir=$(pwd)/util-fw/stm32-vserprog +boards_dir=${src_dir}/boards  main()  { -	printf "Compiling serprog firmware for STM32\n" -  	[ -d "${src_dir}/" ] || ./update project repo stm32-vserprog \  		|| err "fetch stm32-vserprog failed!\n"  	mkdir -p "${serprog_release_dir}" || \  	    err "can't create dir: ${serprog_release_dir}" -	boards_dir=${src_dir}/boards -  	if [ $# -gt 0 ] ; then -		buildrom "${1}" +		if [ "${1}" = "list" ] ; then +			list_boards +		else +			buildrom "${1}" +		fi  	else +		printf "Building stm32-vserprog for all boards\n"  		basename -a -s .h ${boards_dir}/*.h | while read board ; do  			buildrom ${board}  		done @@ -50,6 +52,7 @@ main()  buildrom()  {  	board=${1} +	printf "Building stm32-vserprog for ${board}\n"  	make -C ${src_dir} libopencm3-just-make BOARD=${board}  	make -C ${src_dir} BOARD=${board}  	mv ${src_dir}/stm32-vserprog.hex \ @@ -58,4 +61,10 @@ buildrom()  	printf "output to ${serprog_release_dir}/serprog_${board}.hex\n"  } +list_boards() +{ +	printf "Available boards for stm32-vserprog:\n" +	basename -a -s .h ${boards_dir}/*.h +} +  main $@ | 
