| Patrick Williams | 8b8bc41 | 2016-08-17 15:02:23 -0500 | [diff] [blame] | 1 | inherit image_types | 
 | 2 | inherit linux-raspberrypi-base | 
 | 3 |  | 
 | 4 | # | 
 | 5 | # Create an image that can by written onto a SD card using dd. | 
 | 6 | # | 
 | 7 | # The disk layout used is: | 
 | 8 | # | 
 | 9 | #    0                      -> IMAGE_ROOTFS_ALIGNMENT         - reserved for other data | 
 | 10 | #    IMAGE_ROOTFS_ALIGNMENT -> BOOT_SPACE                     - bootloader and kernel | 
 | 11 | #    BOOT_SPACE             -> SDIMG_SIZE                     - rootfs | 
 | 12 | # | 
 | 13 |  | 
 | 14 | #                                                     Default Free space = 1.3x | 
 | 15 | #                                                     Use IMAGE_OVERHEAD_FACTOR to add more space | 
 | 16 | #                                                     <---------> | 
 | 17 | #            4MiB              40MiB           SDIMG_ROOTFS | 
 | 18 | # <-----------------------> <----------> <----------------------> | 
 | 19 | #  ------------------------ ------------ ------------------------ | 
 | 20 | # | IMAGE_ROOTFS_ALIGNMENT | BOOT_SPACE | ROOTFS_SIZE            | | 
 | 21 | #  ------------------------ ------------ ------------------------ | 
 | 22 | # ^                        ^            ^                        ^ | 
 | 23 | # |                        |            |                        | | 
 | 24 | # 0                      4MiB     4MiB + 40MiB       4MiB + 40Mib + SDIMG_ROOTFS | 
 | 25 |  | 
 | 26 | # This image depends on the rootfs image | 
 | 27 | IMAGE_TYPEDEP_rpi-sdimg = "${SDIMG_ROOTFS_TYPE}" | 
 | 28 |  | 
 | 29 | # Set kernel and boot loader | 
 | 30 | IMAGE_BOOTLOADER ?= "bcm2835-bootfiles" | 
 | 31 |  | 
 | 32 | # Set initramfs extension | 
 | 33 | KERNEL_INITRAMFS ?= "" | 
 | 34 |  | 
 | 35 | # Kernel image name | 
 | 36 | SDIMG_KERNELIMAGE_raspberrypi  ?= "kernel.img" | 
 | 37 | SDIMG_KERNELIMAGE_raspberrypi2 ?= "kernel7.img" | 
 | 38 |  | 
 | 39 | # Boot partition volume id | 
 | 40 | BOOTDD_VOLUME_ID ?= "${MACHINE}" | 
 | 41 |  | 
 | 42 | # Boot partition size [in KiB] (will be rounded up to IMAGE_ROOTFS_ALIGNMENT) | 
 | 43 | BOOT_SPACE ?= "40960" | 
 | 44 |  | 
 | 45 | # Set alignment to 4MB [in KiB] | 
 | 46 | IMAGE_ROOTFS_ALIGNMENT = "4096" | 
 | 47 |  | 
 | 48 | # Use an uncompressed ext3 by default as rootfs | 
 | 49 | SDIMG_ROOTFS_TYPE ?= "ext3" | 
 | 50 | SDIMG_ROOTFS = "${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.rootfs.${SDIMG_ROOTFS_TYPE}" | 
 | 51 |  | 
 | 52 | IMAGE_DEPENDS_rpi-sdimg = " \ | 
 | 53 | 			parted-native \ | 
 | 54 | 			mtools-native \ | 
 | 55 | 			dosfstools-native \ | 
 | 56 | 			virtual/kernel:do_deploy \ | 
 | 57 | 			${IMAGE_BOOTLOADER} \ | 
 | 58 | 			${@bb.utils.contains('KERNEL_IMAGETYPE', 'uImage', 'u-boot', '',d)} \ | 
 | 59 | 			" | 
 | 60 |  | 
 | 61 | # SD card image name | 
 | 62 | SDIMG = "${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.rootfs.rpi-sdimg" | 
 | 63 |  | 
 | 64 | # Compression method to apply to SDIMG after it has been created. Supported | 
 | 65 | # compression formats are "gzip", "bzip2" or "xz". The original .rpi-sdimg file | 
 | 66 | # is kept and a new compressed file is created if one of these compression | 
 | 67 | # formats is chosen. If SDIMG_COMPRESSION is set to any other value it is | 
 | 68 | # silently ignored. | 
 | 69 | #SDIMG_COMPRESSION ?= "" | 
 | 70 |  | 
 | 71 | # Additional files and/or directories to be copied into the vfat partition from the IMAGE_ROOTFS. | 
 | 72 | FATPAYLOAD ?= "" | 
 | 73 |  | 
 | 74 | IMAGEDATESTAMP = "${@time.strftime('%Y.%m.%d',time.gmtime())}" | 
 | 75 | IMAGE_CMD_rpi-sdimg[vardepsexclude] += "IMAGEDATESTAMP" | 
 | 76 | IMAGE_CMD_rpi-sdimg[vardepsexclude] += "DATETIME" | 
 | 77 |  | 
 | 78 | IMAGE_CMD_rpi-sdimg () { | 
 | 79 |  | 
 | 80 | 	# Align partitions | 
 | 81 | 	BOOT_SPACE_ALIGNED=$(expr ${BOOT_SPACE} + ${IMAGE_ROOTFS_ALIGNMENT} - 1) | 
 | 82 | 	BOOT_SPACE_ALIGNED=$(expr ${BOOT_SPACE_ALIGNED} - ${BOOT_SPACE_ALIGNED} % ${IMAGE_ROOTFS_ALIGNMENT}) | 
 | 83 | 	SDIMG_SIZE=$(expr ${IMAGE_ROOTFS_ALIGNMENT} + ${BOOT_SPACE_ALIGNED} + $ROOTFS_SIZE) | 
 | 84 |  | 
 | 85 | 	echo "Creating filesystem with Boot partition ${BOOT_SPACE_ALIGNED} KiB and RootFS $ROOTFS_SIZE KiB" | 
 | 86 |  | 
 | 87 | 	# Check if we are building with device tree support | 
 | 88 | 	DTS="${@get_dts(d, None)}" | 
 | 89 |  | 
 | 90 | 	# Initialize sdcard image file | 
 | 91 | 	dd if=/dev/zero of=${SDIMG} bs=1024 count=0 seek=${SDIMG_SIZE} | 
 | 92 |  | 
 | 93 | 	# Create partition table | 
 | 94 | 	parted -s ${SDIMG} mklabel msdos | 
 | 95 | 	# Create boot partition and mark it as bootable | 
 | 96 | 	parted -s ${SDIMG} unit KiB mkpart primary fat32 ${IMAGE_ROOTFS_ALIGNMENT} $(expr ${BOOT_SPACE_ALIGNED} \+ ${IMAGE_ROOTFS_ALIGNMENT}) | 
 | 97 | 	parted -s ${SDIMG} set 1 boot on | 
 | 98 | 	# Create rootfs partition to the end of disk | 
 | 99 | 	parted -s ${SDIMG} -- unit KiB mkpart primary ext2 $(expr ${BOOT_SPACE_ALIGNED} \+ ${IMAGE_ROOTFS_ALIGNMENT}) -1s | 
 | 100 | 	parted ${SDIMG} print | 
 | 101 |  | 
 | 102 | 	# Create a vfat image with boot files | 
 | 103 | 	BOOT_BLOCKS=$(LC_ALL=C parted -s ${SDIMG} unit b print | awk '/ 1 / { print substr($4, 1, length($4 -1)) / 512 /2 }') | 
 | 104 | 	rm -f ${WORKDIR}/boot.img | 
 | 105 | 	mkfs.vfat -n "${BOOTDD_VOLUME_ID}" -S 512 -C ${WORKDIR}/boot.img $BOOT_BLOCKS | 
 | 106 | 	mcopy -i ${WORKDIR}/boot.img -s ${DEPLOY_DIR_IMAGE}/bcm2835-bootfiles/* ::/ | 
 | 107 | 	if test -n "${DTS}"; then | 
 | 108 | 		# Device Tree Overlays are assumed to be suffixed by '-overlay.dtb' string and will be put in a dedicated folder | 
 | 109 | 		DT_OVERLAYS="${@split_overlays(d, 0)}" | 
 | 110 | 		DT_ROOT="${@split_overlays(d, 1)}" | 
 | 111 |  | 
 | 112 | 		# Copy board device trees to root folder | 
 | 113 | 		for DTB in ${DT_ROOT}; do | 
 | 114 | 			DTB_BASE_NAME=`basename ${DTB} .dtb` | 
 | 115 |  | 
 | 116 | 			mcopy -i ${WORKDIR}/boot.img -s ${DEPLOY_DIR_IMAGE}/${KERNEL_IMAGETYPE}-${DTB_BASE_NAME}.dtb ::${DTB_BASE_NAME}.dtb | 
 | 117 | 		done | 
 | 118 |  | 
 | 119 | 		# Copy device tree overlays to dedicated folder | 
 | 120 | 		mmd -i ${WORKDIR}/boot.img overlays | 
 | 121 | 		for DTB in ${DT_OVERLAYS}; do | 
 | 122 | 			DTB_BASE_NAME=`basename ${DTB} .dtb` | 
 | 123 |  | 
 | 124 | 			mcopy -i ${WORKDIR}/boot.img -s ${DEPLOY_DIR_IMAGE}/${KERNEL_IMAGETYPE}-${DTB_BASE_NAME}.dtb ::overlays/${DTB_BASE_NAME}.dtb | 
 | 125 | 		done | 
 | 126 | 	fi | 
 | 127 | 	case "${KERNEL_IMAGETYPE}" in | 
 | 128 | 	"uImage") | 
 | 129 | 		mcopy -i ${WORKDIR}/boot.img -s ${DEPLOY_DIR_IMAGE}/u-boot.bin ::${SDIMG_KERNELIMAGE} | 
 | 130 | 		mcopy -i ${WORKDIR}/boot.img -s ${DEPLOY_DIR_IMAGE}/${KERNEL_IMAGETYPE}${KERNEL_INITRAMFS}-${MACHINE}.bin ::uImage | 
 | 131 | 		;; | 
 | 132 | 	*) | 
 | 133 | 		mcopy -i ${WORKDIR}/boot.img -s ${DEPLOY_DIR_IMAGE}/${KERNEL_IMAGETYPE}${KERNEL_INITRAMFS}-${MACHINE}.bin ::${SDIMG_KERNELIMAGE} | 
 | 134 | 		;; | 
 | 135 | 	esac | 
 | 136 |  | 
 | 137 | 	if [ -n ${FATPAYLOAD} ] ; then | 
 | 138 | 		echo "Copying payload into VFAT" | 
 | 139 | 		for entry in ${FATPAYLOAD} ; do | 
 | 140 | 				# add the || true to stop aborting on vfat issues like not supporting .~lock files | 
 | 141 | 				mcopy -i ${WORKDIR}/boot.img -s -v ${IMAGE_ROOTFS}$entry :: || true | 
 | 142 | 		done | 
 | 143 | 	fi | 
 | 144 |  | 
 | 145 | 	# Add stamp file | 
 | 146 | 	echo "${IMAGE_NAME}-${IMAGEDATESTAMP}" > ${WORKDIR}/image-version-info | 
 | 147 | 	mcopy -i ${WORKDIR}/boot.img -v ${WORKDIR}//image-version-info :: | 
 | 148 |  | 
 | 149 | 	# Burn Partitions | 
 | 150 | 	dd if=${WORKDIR}/boot.img of=${SDIMG} conv=notrunc seek=1 bs=$(expr ${IMAGE_ROOTFS_ALIGNMENT} \* 1024) && sync && sync | 
 | 151 | 	# If SDIMG_ROOTFS_TYPE is a .xz file use xzcat | 
 | 152 | 	if echo "${SDIMG_ROOTFS_TYPE}" | egrep -q "*\.xz" | 
 | 153 | 	then | 
 | 154 | 		xzcat ${SDIMG_ROOTFS} | dd of=${SDIMG} conv=notrunc seek=1 bs=$(expr 1024 \* ${BOOT_SPACE_ALIGNED} + ${IMAGE_ROOTFS_ALIGNMENT} \* 1024) && sync && sync | 
 | 155 | 	else | 
 | 156 | 		dd if=${SDIMG_ROOTFS} of=${SDIMG} conv=notrunc seek=1 bs=$(expr 1024 \* ${BOOT_SPACE_ALIGNED} + ${IMAGE_ROOTFS_ALIGNMENT} \* 1024) && sync && sync | 
 | 157 | 	fi | 
 | 158 |  | 
 | 159 | 	# Optionally apply compression | 
 | 160 | 	case "${SDIMG_COMPRESSION}" in | 
 | 161 | 	"gzip") | 
 | 162 | 		gzip -k9 "${SDIMG}" | 
 | 163 | 		;; | 
 | 164 | 	"bzip2") | 
 | 165 | 		bzip2 -k9 "${SDIMG}" | 
 | 166 | 		;; | 
 | 167 | 	"xz") | 
 | 168 | 		xz -k "${SDIMG}" | 
 | 169 | 		;; | 
 | 170 | 	esac | 
 | 171 | } | 
 | 172 |  | 
 | 173 | ROOTFS_POSTPROCESS_COMMAND += " rpi_generate_sysctl_config ; " | 
 | 174 |  | 
 | 175 | rpi_generate_sysctl_config() { | 
 | 176 | 	# systemd sysctl config | 
 | 177 | 	test -d ${IMAGE_ROOTFS}${sysconfdir}/sysctl.d && \ | 
 | 178 | 		echo "vm.min_free_kbytes = 8192" > ${IMAGE_ROOTFS}${sysconfdir}/sysctl.d/rpi-vm.conf | 
 | 179 |  | 
 | 180 | 	# sysv sysctl config | 
 | 181 | 	IMAGE_SYSCTL_CONF="${IMAGE_ROOTFS}${sysconfdir}/sysctl.conf" | 
 | 182 | 	test -e ${IMAGE_ROOTFS}${sysconfdir}/sysctl.conf && \ | 
 | 183 | 		sed -e "/vm.min_free_kbytes/d" -i ${IMAGE_SYSCTL_CONF} | 
 | 184 | 	echo "" >> ${IMAGE_SYSCTL_CONF} && echo "vm.min_free_kbytes = 8192" >> ${IMAGE_SYSCTL_CONF} | 
 | 185 | } |