| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 | 
							- #!/usr/bin/env bash
 
- #
 
- # Licensed under the terms of the GNU GPL License version 2 or later.
 
- #
 
- # Author: Peter Tyser <[email protected]>
 
- #
 
- # U-Boot firmware supports the booting of images in the Flattened Image
 
- # Tree (FIT) format.  The FIT format uses a device tree structure to
 
- # describe a kernel image, device tree blob, ramdisk, etc.  This script
 
- # creates an Image Tree Source (.its file) which can be passed to the
 
- # 'mkimage' utility to generate an Image Tree Blob (.itb file).  The .itb
 
- # file can then be booted by U-Boot (or other bootloaders which support
 
- # FIT images).  See doc/uImage.FIT/howto.txt in U-Boot source code for
 
- # additional information on FIT images.
 
- #
 
- usage() {
 
- 	echo "Usage: `basename $0` -A arch -C comp -a addr -e entry" \
 
- 		"-v version -k kernel [-D name -d dtb] -o its_file"
 
- 	echo -e "\t-A ==> set architecture to 'arch'"
 
- 	echo -e "\t-C ==> set compression type 'comp'"
 
- 	echo -e "\t-c ==> set config name 'config'"
 
- 	echo -e "\t-a ==> set load address to 'addr' (hex)"
 
- 	echo -e "\t-e ==> set entry point to 'entry' (hex)"
 
- 	echo -e "\t-v ==> set kernel version to 'version'"
 
- 	echo -e "\t-k ==> include kernel image 'kernel'"
 
- 	echo -e "\t-D ==> human friendly Device Tree Blob 'name'"
 
- 	echo -e "\t-d ==> include Device Tree Blob 'dtb'"
 
- 	echo -e "\t-o ==> create output file 'its_file'"
 
- 	exit 1
 
- }
 
- while getopts ":A:a:c:C:D:d:e:k:o:v:" OPTION
 
- do
 
- 	case $OPTION in
 
- 		A ) ARCH=$OPTARG;;
 
- 		a ) LOAD_ADDR=$OPTARG;;
 
- 		c ) CONFIG=$OPTARG;;
 
- 		C ) COMPRESS=$OPTARG;;
 
- 		D ) DEVICE=$OPTARG;;
 
- 		d ) DTB=$OPTARG;;
 
- 		e ) ENTRY_ADDR=$OPTARG;;
 
- 		k ) KERNEL=$OPTARG;;
 
- 		o ) OUTPUT=$OPTARG;;
 
- 		v ) VERSION=$OPTARG;;
 
- 		* ) echo "Invalid option passed to '$0' (options:$@)"
 
- 		usage;;
 
- 	esac
 
- done
 
- # Make sure user entered all required parameters
 
- if [ -z "${ARCH}" ] || [ -z "${COMPRESS}" ] || [ -z "${LOAD_ADDR}" ] || \
 
- 	[ -z "${ENTRY_ADDR}" ] || [ -z "${VERSION}" ] || [ -z "${KERNEL}" ] || \
 
- 	[ -z "${OUTPUT}" ] || [ -z "${CONFIG}" ]; then
 
- 	usage
 
- fi
 
- ARCH_UPPER=`echo $ARCH | tr '[:lower:]' '[:upper:]'`
 
- # Conditionally create fdt information
 
- if [ -n "${DTB}" ]; then
 
- 	FDT="
 
- 		fdt@1 {
 
- 			description = \"${ARCH_UPPER} OpenWrt ${DEVICE} device tree blob\";
 
- 			data = /incbin/(\"${DTB}\");
 
- 			type = \"flat_dt\";
 
- 			arch = \"${ARCH}\";
 
- 			compression = \"none\";
 
- 			hash@1 {
 
- 				algo = \"crc32\";
 
- 			};
 
- 			hash@2 {
 
- 				algo = \"sha1\";
 
- 			};
 
- 		};
 
- "
 
- fi
 
- # Create a default, fully populated DTS file
 
- DATA="/dts-v1/;
 
- / {
 
- 	description = \"${ARCH_UPPER} OpenWrt FIT (Flattened Image Tree)\";
 
- 	#address-cells = <1>;
 
- 	images {
 
- 		kernel@1 {
 
- 			description = \"${ARCH_UPPER} OpenWrt Linux-${VERSION}\";
 
- 			data = /incbin/(\"${KERNEL}\");
 
- 			type = \"kernel\";
 
- 			arch = \"${ARCH}\";
 
- 			os = \"linux\";
 
- 			compression = \"${COMPRESS}\";
 
- 			load = <${LOAD_ADDR}>;
 
- 			entry = <${ENTRY_ADDR}>;
 
- 			hash@1 {
 
- 				algo = \"crc32\";
 
- 			};
 
- 			hash@2 {
 
- 				algo = \"sha1\";
 
- 			};
 
- 		};
 
- ${FDT}
 
- 	};
 
- 	configurations {
 
- 		default = \"${CONFIG}\";
 
- 		${CONFIG} {
 
- 			description = \"OpenWrt\";
 
- 			kernel = \"kernel@1\";
 
- 			fdt = \"fdt@1\";
 
- 		};
 
- 	};
 
- };"
 
- # Write .its file to disk
 
- echo "$DATA" > ${OUTPUT}
 
 
  |