summaryrefslogtreecommitdiffstats
path: root/classes/image_types_ota.bbclass
diff options
context:
space:
mode:
authorAnton Gerasimov <anton@advancedtelematic.com>2016-08-16 12:17:17 +0200
committerAnton Gerasimov <anton@advancedtelematic.com>2016-08-16 12:26:30 +0200
commit4b9938d16e06ce05b8bdefd1f48f2e9bd85fca5a (patch)
tree1e5064d11f7db1625063fa73f32c4788cba8abff /classes/image_types_ota.bbclass
parent291d597cf414f1a69ed7999f0a86689e657adcca (diff)
downloadmeta-updater-4b9938d16e06ce05b8bdefd1f48f2e9bd85fca5a.tar.gz
Add support for emulating OSTree updates in qemux86: new live image,
u-boot that can be used as BIOS, machine that uses both and fork of poky runqemu supporting the new live image. Bug-AGL: SPEC-236 Change-Id: Id99d122c05a00eb94902e8f6907455a1e681f2a3 Signed-off-by: Anton Gerasimov <anton@advancedtelematic.com>
Diffstat (limited to 'classes/image_types_ota.bbclass')
-rw-r--r--classes/image_types_ota.bbclass73
1 files changed, 73 insertions, 0 deletions
diff --git a/classes/image_types_ota.bbclass b/classes/image_types_ota.bbclass
new file mode 100644
index 0000000..a67cc80
--- /dev/null
+++ b/classes/image_types_ota.bbclass
@@ -0,0 +1,73 @@
1# Image to use with u-boot as BIOS and OSTree deployment system
2
3inherit image_types
4
5# Boot filesystem size in MiB
6# OSTree updates may require some space on boot file system for
7# boot scripts, kernel and initramfs images
8#
9BOOTFS_EXTRA_SIZE ?= "512"
10export BOOTFS_EXTRA_SIZE
11
12IMAGE_TYPES += " otaimg"
13IMAGE_DEPENDS_ota = "e2fsprogs-native \
14 virtual/bootloader \
15 virtual/kernel \
16 parted-native \
17 ${INITRD_IMAGE}"
18
19build_bootfs () {
20 KERNEL_FILE=${DEPLOY_DIR_IMAGE}/${KERNEL_IMAGETYPE}
21 KERNEL_SIZE=`du -Lbs ${KERNEL_FILE} | cut -f 1`
22
23 RAMDISK_FILE=${DEPLOY_DIR_IMAGE}/${INITRD_IMAGE}-${MACHINE}.cpio.gz
24 RAMDISK_SIZE=`du -Lbs ${RAMDISK_FILE} | cut -f 1`
25
26 EXTRA_BYTES=$(expr $BOOTFS_EXTRA_SIZE \* 1024 \* 1024)
27
28 TOTAL_SIZE=$(expr ${KERNEL_SIZE} \+ ${RAMDISK_SIZE} \+ ${EXTRA_BYTES})
29 TOTAL_BLOCKS=$(expr 1 \+ $TOTAL_SIZE / 1024)
30
31 dd if=/dev/zero of=$1 bs=1024 count=${TOTAL_BLOCKS}
32 BOOTTMP=$(mktemp -d mkotaboot-XXX)
33 cp ${DEPLOY_DIR_IMAGE}/${KERNEL_IMAGETYPE} ${BOOTTMP}
34 cp ${DEPLOY_DIR_IMAGE}/${INITRD_IMAGE}-${MACHINE}.cpio.gz ${BOOTTMP}
35 mkfs.ext4 $1 -d ${BOOTTMP}
36 rm -rf $BOOTTMP
37}
38
39IMAGE_CMD_otaimg () {
40 BOOTIMG=${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.otaboot.ext4
41 rm -f $BOOTIMG
42 build_bootfs $BOOTIMG
43
44 # ext4 image should be already here because of IMAGE_TYPEDEP_otaimg
45 ROOTIMG=${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.rootfs.ext4
46
47 BOOTFSBLOCKS=`du -bks ${BOOTIMG} | cut -f 1`
48
49 ROOTFSBLOCKS=`du -bks ${ROOTIMG} | cut -f 1`
50 TOTALSIZE=`expr $BOOTFSBLOCKS \+ $ROOTFSBLOCKS`
51 END1=`expr $BOOTFSBLOCKS \* 1024`
52 END2=`expr $END1 + 512`
53 END3=`expr \( $ROOTFSBLOCKS \* 1024 \) + $END1`
54
55 FULLIMG=${DEPLOY_DIR_IMAGE}/${IMAGE_NAME}.otaimg
56 rm -rf ${FULLIMG}
57
58 dd if=/dev/zero of=${FULLIMG} bs=1024 seek=${TOTALSIZE} count=1
59 parted ${FULLIMG} mklabel msdos
60 parted ${FULLIMG} mkpart primary ext4 0 ${END1}B
61 parted ${FULLIMG} unit B mkpart primary ext4 ${END2}B ${END3}B
62
63 OFFSET=`expr $END2 / 512`
64
65 dd if=${BOOTIMG} of=${FULLIMG} conv=notrunc seek=1 bs=512
66 dd if=${ROOTIMG} of=${FULLIMG} conv=notrunc seek=$OFFSET bs=512
67
68 cd ${DEPLOY_DIR_IMAGE}
69 rm -f ${IMAGE_LINK_NAME}.otaimg
70 ln -s ${IMAGE_NAME}.otaimg ${IMAGE_LINK_NAME}.otaimg
71}
72
73IMAGE_TYPEDEP_otaimg = "ext4"