blob: 764e6a5574c638845d43288b7c4070144164d523 [file] [log] [blame]
Patrick Williams92b42cb2022-09-03 06:53:57 -05001#
2# Copyright OpenEmbedded Contributors
3#
4# SPDX-License-Identifier: MIT
5#
6
7# The default aligment of the size of the rootfs is set to 1KiB. In case
8# you're using the SD card emulation of a QEMU system simulator you may
9# set this value to 2048 (2MiB alignment).
10IMAGE_ROOTFS_ALIGNMENT ?= "1"
11
12def imagetypes_getdepends(d):
13 def adddep(depstr, deps):
14 for d in (depstr or "").split():
15 # Add task dependency if not already present
16 if ":" not in d:
17 d += ":do_populate_sysroot"
18 deps.add(d)
19
20 # Take a type in the form of foo.bar.car and split it into the items
21 # needed for the image deps "foo", and the conversion deps ["bar", "car"]
22 def split_types(typestring):
23 types = typestring.split(".")
24 return types[0], types[1:]
25
26 fstypes = set((d.getVar('IMAGE_FSTYPES') or "").split())
27 fstypes |= set((d.getVar('IMAGE_FSTYPES_DEBUGFS') or "").split())
28
29 deprecated = set()
30 deps = set()
31 for typestring in fstypes:
32 basetype, resttypes = split_types(typestring)
33
34 var = "IMAGE_DEPENDS_%s" % basetype
35 if d.getVar(var) is not None:
36 deprecated.add(var)
37
38 for typedepends in (d.getVar("IMAGE_TYPEDEP:%s" % basetype) or "").split():
39 base, rest = split_types(typedepends)
40 resttypes += rest
41
42 var = "IMAGE_DEPENDS_%s" % base
43 if d.getVar(var) is not None:
44 deprecated.add(var)
45
46 for ctype in resttypes:
47 adddep(d.getVar("CONVERSION_DEPENDS_%s" % ctype), deps)
48 adddep(d.getVar("COMPRESS_DEPENDS_%s" % ctype), deps)
49
50 if deprecated:
51 bb.fatal('Deprecated variable(s) found: "%s". '
52 'Use do_image_<type>[depends] += "<recipe>:<task>" instead' % ', '.join(deprecated))
53
54 # Sort the set so that ordering is consistant
55 return " ".join(sorted(deps))
56
57XZ_COMPRESSION_LEVEL ?= "-9"
58XZ_INTEGRITY_CHECK ?= "crc32"
59
60ZIP_COMPRESSION_LEVEL ?= "-9"
61
62ZSTD_COMPRESSION_LEVEL ?= "-3"
63
64JFFS2_SUM_EXTRA_ARGS ?= ""
65IMAGE_CMD:jffs2 = "mkfs.jffs2 --root=${IMAGE_ROOTFS} --faketime --output=${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.jffs2 ${EXTRA_IMAGECMD}"
66
67IMAGE_CMD:cramfs = "mkfs.cramfs ${IMAGE_ROOTFS} ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.cramfs ${EXTRA_IMAGECMD}"
68
69oe_mkext234fs () {
70 fstype=$1
71 extra_imagecmd=""
72
73 if [ $# -gt 1 ]; then
74 shift
75 extra_imagecmd=$@
76 fi
77
78 # If generating an empty image the size of the sparse block should be large
79 # enough to allocate an ext4 filesystem using 4096 bytes per inode, this is
80 # about 60K, so dd needs a minimum count of 60, with bs=1024 (bytes per IO)
81 eval local COUNT=\"0\"
82 eval local MIN_COUNT=\"60\"
83 if [ $ROOTFS_SIZE -lt $MIN_COUNT ]; then
84 eval COUNT=\"$MIN_COUNT\"
85 fi
86 # Create a sparse image block
87 bbdebug 1 Executing "dd if=/dev/zero of=${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.$fstype seek=$ROOTFS_SIZE count=$COUNT bs=1024"
88 dd if=/dev/zero of=${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.$fstype seek=$ROOTFS_SIZE count=$COUNT bs=1024
89 bbdebug 1 "Actual Rootfs size: `du -s ${IMAGE_ROOTFS}`"
90 bbdebug 1 "Actual Partition size: `stat -c '%s' ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.$fstype`"
91 bbdebug 1 Executing "mkfs.$fstype -F $extra_imagecmd ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.$fstype -d ${IMAGE_ROOTFS}"
92 mkfs.$fstype -F $extra_imagecmd ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.$fstype -d ${IMAGE_ROOTFS}
93 # Error codes 0-3 indicate successfull operation of fsck (no errors or errors corrected)
94 fsck.$fstype -pvfD ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.$fstype || [ $? -le 3 ]
95}
96
97IMAGE_CMD:ext2 = "oe_mkext234fs ext2 ${EXTRA_IMAGECMD}"
98IMAGE_CMD:ext3 = "oe_mkext234fs ext3 ${EXTRA_IMAGECMD}"
99IMAGE_CMD:ext4 = "oe_mkext234fs ext4 ${EXTRA_IMAGECMD}"
100
101MIN_BTRFS_SIZE ?= "16384"
102IMAGE_CMD:btrfs () {
103 size=${ROOTFS_SIZE}
104 if [ ${size} -lt ${MIN_BTRFS_SIZE} ] ; then
105 size=${MIN_BTRFS_SIZE}
106 bbwarn "Rootfs size is too small for BTRFS. Filesystem will be extended to ${size}K"
107 fi
108 dd if=/dev/zero of=${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.btrfs seek=${size} count=0 bs=1024
109 mkfs.btrfs ${EXTRA_IMAGECMD} -r ${IMAGE_ROOTFS} ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.btrfs
110}
111
112oe_mksquashfs () {
113 local comp=$1
114 local suffix=$2
115
116 # Use the bitbake reproducible timestamp instead of the hardcoded squashfs one
117 export SOURCE_DATE_EPOCH=$(stat -c '%Y' ${IMAGE_ROOTFS})
118 mksquashfs ${IMAGE_ROOTFS} ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.squashfs${comp:+-}${suffix:-$comp} ${EXTRA_IMAGECMD} -noappend ${comp:+-comp }$comp
119}
120IMAGE_CMD:squashfs = "oe_mksquashfs"
121IMAGE_CMD:squashfs-xz = "oe_mksquashfs xz"
122IMAGE_CMD:squashfs-lzo = "oe_mksquashfs lzo"
123IMAGE_CMD:squashfs-lz4 = "oe_mksquashfs lz4"
124IMAGE_CMD:squashfs-zst = "oe_mksquashfs zstd zst"
125
126IMAGE_CMD:erofs = "mkfs.erofs ${EXTRA_IMAGECMD} ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.erofs ${IMAGE_ROOTFS}"
127IMAGE_CMD:erofs-lz4 = "mkfs.erofs -zlz4 ${EXTRA_IMAGECMD} ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.erofs-lz4 ${IMAGE_ROOTFS}"
128IMAGE_CMD:erofs-lz4hc = "mkfs.erofs -zlz4hc ${EXTRA_IMAGECMD} ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.erofs-lz4hc ${IMAGE_ROOTFS}"
129
130
131IMAGE_CMD_TAR ?= "tar"
132# ignore return code 1 "file changed as we read it" as other tasks(e.g. do_image_wic) may be hardlinking rootfs
133IMAGE_CMD:tar = "${IMAGE_CMD_TAR} --sort=name --format=posix --numeric-owner -cf ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.tar -C ${IMAGE_ROOTFS} . || [ $? -eq 1 ]"
134
135do_image_cpio[cleandirs] += "${WORKDIR}/cpio_append"
136IMAGE_CMD:cpio () {
137 (cd ${IMAGE_ROOTFS} && find . | sort | cpio --reproducible -o -H newc >${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.cpio)
138 # We only need the /init symlink if we're building the real
139 # image. The -dbg image doesn't need it! By being clever
140 # about this we also avoid 'touch' below failing, as it
141 # might be trying to touch /sbin/init on the host since both
142 # the normal and the -dbg image share the same WORKDIR
143 if [ "${IMAGE_BUILDING_DEBUGFS}" != "true" ]; then
144 if [ ! -L ${IMAGE_ROOTFS}/init ] && [ ! -e ${IMAGE_ROOTFS}/init ]; then
145 if [ -L ${IMAGE_ROOTFS}/sbin/init ] || [ -e ${IMAGE_ROOTFS}/sbin/init ]; then
146 ln -sf /sbin/init ${WORKDIR}/cpio_append/init
147 else
148 touch ${WORKDIR}/cpio_append/init
149 fi
150 (cd ${WORKDIR}/cpio_append && echo ./init | cpio -oA -H newc -F ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.cpio)
151 fi
152 fi
153}
154
155UBI_VOLNAME ?= "${MACHINE}-rootfs"
156UBI_VOLTYPE ?= "dynamic"
157UBI_IMGTYPE ?= "ubifs"
158
159write_ubi_config() {
160 if [ -z "$1" ]; then
161 local vname=""
162 else
163 local vname="_$1"
164 fi
165
166 cat <<EOF > ubinize${vname}-${IMAGE_NAME}.cfg
167[ubifs]
168mode=ubi
169image=${IMGDEPLOYDIR}/${IMAGE_NAME}${vname}${IMAGE_NAME_SUFFIX}.${UBI_IMGTYPE}
170vol_id=0
171vol_type=${UBI_VOLTYPE}
172vol_name=${UBI_VOLNAME}
173vol_flags=autoresize
174EOF
175}
176
177multiubi_mkfs() {
178 local mkubifs_args="$1"
179 local ubinize_args="$2"
180
181 # Added prompt error message for ubi and ubifs image creation.
182 if [ -z "$mkubifs_args" ] || [ -z "$ubinize_args" ]; then
183 bbfatal "MKUBIFS_ARGS and UBINIZE_ARGS have to be set, see http://www.linux-mtd.infradead.org/faq/ubifs.html for details"
184 fi
185
186 write_ubi_config "$3"
187
188 if [ -n "$vname" ]; then
189 mkfs.ubifs -r ${IMAGE_ROOTFS} -o ${IMGDEPLOYDIR}/${IMAGE_NAME}${vname}${IMAGE_NAME_SUFFIX}.ubifs ${mkubifs_args}
190 fi
191 ubinize -o ${IMGDEPLOYDIR}/${IMAGE_NAME}${vname}${IMAGE_NAME_SUFFIX}.ubi ${ubinize_args} ubinize${vname}-${IMAGE_NAME}.cfg
192
193 # Cleanup cfg file
194 mv ubinize${vname}-${IMAGE_NAME}.cfg ${IMGDEPLOYDIR}/
195
196 # Create own symlinks for 'named' volumes
197 if [ -n "$vname" ]; then
198 cd ${IMGDEPLOYDIR}
199 if [ -e ${IMAGE_NAME}${vname}${IMAGE_NAME_SUFFIX}.ubifs ]; then
200 ln -sf ${IMAGE_NAME}${vname}${IMAGE_NAME_SUFFIX}.ubifs \
201 ${IMAGE_LINK_NAME}${vname}.ubifs
202 fi
203 if [ -e ${IMAGE_NAME}${vname}${IMAGE_NAME_SUFFIX}.ubi ]; then
204 ln -sf ${IMAGE_NAME}${vname}${IMAGE_NAME_SUFFIX}.ubi \
205 ${IMAGE_LINK_NAME}${vname}.ubi
206 fi
207 cd -
208 fi
209}
210
211IMAGE_CMD:multiubi () {
212 # Split MKUBIFS_ARGS_<name> and UBINIZE_ARGS_<name>
213 for name in ${MULTIUBI_BUILD}; do
214 eval local mkubifs_args=\"\$MKUBIFS_ARGS_${name}\"
215 eval local ubinize_args=\"\$UBINIZE_ARGS_${name}\"
216
217 multiubi_mkfs "${mkubifs_args}" "${ubinize_args}" "${name}"
218 done
219}
220
221IMAGE_CMD:ubi () {
222 multiubi_mkfs "${MKUBIFS_ARGS}" "${UBINIZE_ARGS}"
223}
224IMAGE_TYPEDEP:ubi = "${UBI_IMGTYPE}"
225
226IMAGE_CMD:ubifs = "mkfs.ubifs -r ${IMAGE_ROOTFS} -o ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.ubifs ${MKUBIFS_ARGS}"
227
228MIN_F2FS_SIZE ?= "524288"
229IMAGE_CMD:f2fs () {
230 # We need to add additional smarts here form devices smaller than 1.5G
231 # Need to scale appropriately between 40M -> 1.5G as the "overprovision
232 # ratio" goes down as the device gets bigger (70% -> 4.5%), below about
233 # 500M the standard IMAGE_OVERHEAD_FACTOR does not work, so add additional
234 # space here when under 500M
235 size=${ROOTFS_SIZE}
236 if [ ${size} -lt ${MIN_F2FS_SIZE} ] ; then
237 size=${MIN_F2FS_SIZE}
238 bbwarn "Rootfs size is too small for F2FS. Filesystem will be extended to ${size}K"
239 fi
240 dd if=/dev/zero of=${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.f2fs seek=${size} count=0 bs=1024
241 mkfs.f2fs ${EXTRA_IMAGECMD} ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.f2fs
242 sload.f2fs -f ${IMAGE_ROOTFS} ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.f2fs
243}
244
245EXTRA_IMAGECMD = ""
246
247inherit siteinfo kernel-arch image-artifact-names
248
249JFFS2_ENDIANNESS ?= "${@oe.utils.conditional('SITEINFO_ENDIANNESS', 'le', '-l', '-b', d)}"
250JFFS2_ERASEBLOCK ?= "0x40000"
251EXTRA_IMAGECMD:jffs2 ?= "--pad ${JFFS2_ENDIANNESS} --eraseblock=${JFFS2_ERASEBLOCK} --no-cleanmarkers"
252
253# Change these if you want default mkfs behavior (i.e. create minimal inode number)
254EXTRA_IMAGECMD:ext2 ?= "-i 4096"
255EXTRA_IMAGECMD:ext3 ?= "-i 4096"
256EXTRA_IMAGECMD:ext4 ?= "-i 4096"
257EXTRA_IMAGECMD:btrfs ?= "-n 4096 --shrink"
258EXTRA_IMAGECMD:f2fs ?= ""
259
260do_image_cpio[depends] += "cpio-native:do_populate_sysroot"
261do_image_jffs2[depends] += "mtd-utils-native:do_populate_sysroot"
262do_image_cramfs[depends] += "util-linux-native:do_populate_sysroot"
263do_image_ext2[depends] += "e2fsprogs-native:do_populate_sysroot"
264do_image_ext3[depends] += "e2fsprogs-native:do_populate_sysroot"
265do_image_ext4[depends] += "e2fsprogs-native:do_populate_sysroot"
266do_image_btrfs[depends] += "btrfs-tools-native:do_populate_sysroot"
267do_image_squashfs[depends] += "squashfs-tools-native:do_populate_sysroot"
268do_image_squashfs_xz[depends] += "squashfs-tools-native:do_populate_sysroot"
269do_image_squashfs_lzo[depends] += "squashfs-tools-native:do_populate_sysroot"
270do_image_squashfs_lz4[depends] += "squashfs-tools-native:do_populate_sysroot"
271do_image_squashfs_zst[depends] += "squashfs-tools-native:do_populate_sysroot"
272do_image_ubi[depends] += "mtd-utils-native:do_populate_sysroot"
273do_image_ubifs[depends] += "mtd-utils-native:do_populate_sysroot"
274do_image_multiubi[depends] += "mtd-utils-native:do_populate_sysroot"
275do_image_f2fs[depends] += "f2fs-tools-native:do_populate_sysroot"
276do_image_erofs[depends] += "erofs-utils-native:do_populate_sysroot"
277do_image_erofs_lz4[depends] += "erofs-utils-native:do_populate_sysroot"
278do_image_erofs_lz4hc[depends] += "erofs-utils-native:do_populate_sysroot"
279
280# This variable is available to request which values are suitable for IMAGE_FSTYPES
281IMAGE_TYPES = " \
282 jffs2 jffs2.sum \
283 cramfs \
284 ext2 ext2.gz ext2.bz2 ext2.lzma \
285 ext3 ext3.gz \
286 ext4 ext4.gz \
287 btrfs \
288 squashfs squashfs-xz squashfs-lzo squashfs-lz4 squashfs-zst \
289 ubi ubifs multiubi \
290 tar tar.gz tar.bz2 tar.xz tar.lz4 tar.zst \
291 cpio cpio.gz cpio.xz cpio.lzma cpio.lz4 cpio.zst \
292 wic wic.gz wic.bz2 wic.lzma wic.zst \
293 container \
294 f2fs \
295 erofs erofs-lz4 erofs-lz4hc \
296"
297# These image types are x86 specific as they need syslinux
298IMAGE_TYPES:append:x86 = " hddimg iso"
299IMAGE_TYPES:append:x86-64 = " hddimg iso"
300
301# Compression is a special case of conversion. The old variable
302# names are still supported for backward-compatibility. When defining
303# new compression or conversion commands, use CONVERSIONTYPES and
304# CONVERSION_CMD/DEPENDS.
305COMPRESSIONTYPES ?= ""
306
307CONVERSIONTYPES = "gz bz2 lzma xz lz4 lzo zip zst sum md5sum sha1sum sha224sum sha256sum sha384sum sha512sum bmap u-boot vmdk vhd vhdx vdi qcow2 base64 gzsync zsync ${COMPRESSIONTYPES}"
308CONVERSION_CMD:lzma = "lzma -k -f -7 ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}"
309CONVERSION_CMD:gz = "gzip -f -9 -n -c --rsyncable ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} > ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.gz"
310CONVERSION_CMD:bz2 = "pbzip2 -f -k ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}"
311CONVERSION_CMD:xz = "xz -f -k -c ${XZ_COMPRESSION_LEVEL} ${XZ_DEFAULTS} --check=${XZ_INTEGRITY_CHECK} ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} > ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.xz"
312CONVERSION_CMD:lz4 = "lz4 -9 -z -l ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.lz4"
313CONVERSION_CMD:lzo = "lzop -9 ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}"
314CONVERSION_CMD:zip = "zip ${ZIP_COMPRESSION_LEVEL} ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.zip ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}"
315CONVERSION_CMD:zst = "zstd -f -k -T0 -c ${ZSTD_COMPRESSION_LEVEL} ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} > ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.zst"
316CONVERSION_CMD:sum = "sumtool -i ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} -o ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.sum ${JFFS2_SUM_EXTRA_ARGS}"
317CONVERSION_CMD:md5sum = "md5sum ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} > ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.md5sum"
318CONVERSION_CMD:sha1sum = "sha1sum ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} > ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.sha1sum"
319CONVERSION_CMD:sha224sum = "sha224sum ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} > ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.sha224sum"
320CONVERSION_CMD:sha256sum = "sha256sum ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} > ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.sha256sum"
321CONVERSION_CMD:sha384sum = "sha384sum ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} > ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.sha384sum"
322CONVERSION_CMD:sha512sum = "sha512sum ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} > ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.sha512sum"
323CONVERSION_CMD:bmap = "bmaptool create ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} -o ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.bmap"
324CONVERSION_CMD:u-boot = "mkimage -A ${UBOOT_ARCH} -O linux -T ramdisk -C none -n ${IMAGE_NAME} -d ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.u-boot"
325CONVERSION_CMD:vmdk = "qemu-img convert -O vmdk ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.vmdk"
326CONVERSION_CMD:vhdx = "qemu-img convert -O vhdx -o subformat=dynamic ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.vhdx"
327CONVERSION_CMD:vhd = "qemu-img convert -O vpc -o subformat=fixed ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.vhd"
328CONVERSION_CMD:vdi = "qemu-img convert -O vdi ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.vdi"
329CONVERSION_CMD:qcow2 = "qemu-img convert -O qcow2 ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.qcow2"
330CONVERSION_CMD:base64 = "base64 ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} > ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.base64"
331CONVERSION_CMD:zsync = "zsyncmake_curl ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}"
332CONVERSION_CMD:gzsync = "zsyncmake_curl -z ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}"
333CONVERSION_DEPENDS_lzma = "xz-native"
334CONVERSION_DEPENDS_gz = "pigz-native"
335CONVERSION_DEPENDS_bz2 = "pbzip2-native"
336CONVERSION_DEPENDS_xz = "xz-native"
337CONVERSION_DEPENDS_lz4 = "lz4-native"
338CONVERSION_DEPENDS_lzo = "lzop-native"
339CONVERSION_DEPENDS_zip = "zip-native"
340CONVERSION_DEPENDS_zst = "zstd-native"
341CONVERSION_DEPENDS_sum = "mtd-utils-native"
342CONVERSION_DEPENDS_bmap = "bmap-tools-native"
343CONVERSION_DEPENDS_u-boot = "u-boot-tools-native"
344CONVERSION_DEPENDS_vmdk = "qemu-system-native"
345CONVERSION_DEPENDS_vdi = "qemu-system-native"
346CONVERSION_DEPENDS_qcow2 = "qemu-system-native"
347CONVERSION_DEPENDS_base64 = "coreutils-native"
348CONVERSION_DEPENDS_vhdx = "qemu-system-native"
349CONVERSION_DEPENDS_vhd = "qemu-system-native"
350CONVERSION_DEPENDS_zsync = "zsync-curl-native"
351CONVERSION_DEPENDS_gzsync = "zsync-curl-native"
352
353RUNNABLE_IMAGE_TYPES ?= "ext2 ext3 ext4"
354RUNNABLE_MACHINE_PATTERNS ?= "qemu"
355
356DEPLOYABLE_IMAGE_TYPES ?= "hddimg iso"
357
358# The IMAGE_TYPES_MASKED variable will be used to mask out from the IMAGE_FSTYPES,
359# images that will not be built at do_rootfs time: vmdk, vhd, vhdx, vdi, qcow2, hddimg, iso, etc.
360IMAGE_TYPES_MASKED ?= ""
361
362# bmap requires python3 to be in the PATH
363EXTRANATIVEPATH += "${@'python3-native' if d.getVar('IMAGE_FSTYPES').find('.bmap') else ''}"