blob: 1ce8334e3a92dee12efd410f6e06f65a8aae68ee [file] [log] [blame]
Patrick Williamsd8c66bc2016-06-20 12:57:21 -05001# IMAGE_NAME is the base name for everything produced when building images.
2# The actual image that contains the rootfs has an additional suffix (.rootfs
3# by default) followed by additional suffices which describe the format (.ext4,
4# .ext4.xz, etc.).
5IMAGE_NAME_SUFFIX ??= ".rootfs"
Patrick Williamsc124f4f2015-09-15 14:41:29 -05006
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):
Patrick Williamsc0f7c042017-02-23 20:41:17 -060014 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)
Patrick Williamsc124f4f2015-09-15 14:41:29 -050019
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050020 fstypes = set((d.getVar('IMAGE_FSTYPES', True) or "").split())
21 fstypes |= set((d.getVar('IMAGE_FSTYPES_DEBUGFS', True) or "").split())
Patrick Williamsc0f7c042017-02-23 20:41:17 -060022
23 deps = set()
24 for typestring in fstypes:
25 types = typestring.split(".")
26 basetype, resttypes = types[0], types[1:]
27
28 adddep(d.getVar('IMAGE_DEPENDS_%s' % basetype, True) , deps)
Patrick Williamsc124f4f2015-09-15 14:41:29 -050029 for typedepends in (d.getVar("IMAGE_TYPEDEP_%s" % basetype, True) or "").split():
30 adddep(d.getVar('IMAGE_DEPENDS_%s' % typedepends, True) , deps)
Patrick Williamsc0f7c042017-02-23 20:41:17 -060031 for ctype in resttypes:
32 adddep(d.getVar("CONVERSION_DEPENDS_%s" % ctype, True), deps)
33 adddep(d.getVar("COMPRESS_DEPENDS_%s" % ctype, True), deps)
Patrick Williamsc124f4f2015-09-15 14:41:29 -050034
Patrick Williamsc0f7c042017-02-23 20:41:17 -060035 # Sort the set so that ordering is consistant
36 return " ".join(sorted(deps))
Patrick Williamsc124f4f2015-09-15 14:41:29 -050037
Patrick Williamsc0f7c042017-02-23 20:41:17 -060038XZ_COMPRESSION_LEVEL ?= "-3"
Patrick Williamsc124f4f2015-09-15 14:41:29 -050039XZ_INTEGRITY_CHECK ?= "crc32"
40XZ_THREADS ?= "-T 0"
41
Patrick Williamsc0f7c042017-02-23 20:41:17 -060042ZIP_COMPRESSION_LEVEL ?= "-9"
Patrick Williamsc124f4f2015-09-15 14:41:29 -050043
Patrick Williamsc0f7c042017-02-23 20:41:17 -060044JFFS2_SUM_EXTRA_ARGS ?= ""
45IMAGE_CMD_jffs2 = "mkfs.jffs2 --root=${IMAGE_ROOTFS} --faketime --output=${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.jffs2 ${EXTRA_IMAGECMD}"
46
47IMAGE_CMD_cramfs = "mkfs.cramfs ${IMAGE_ROOTFS} ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.cramfs ${EXTRA_IMAGECMD}"
Patrick Williamsc124f4f2015-09-15 14:41:29 -050048
49oe_mkext234fs () {
50 fstype=$1
51 extra_imagecmd=""
52
53 if [ $# -gt 1 ]; then
54 shift
55 extra_imagecmd=$@
56 fi
57
58 # If generating an empty image the size of the sparse block should be large
59 # enough to allocate an ext4 filesystem using 4096 bytes per inode, this is
60 # about 60K, so dd needs a minimum count of 60, with bs=1024 (bytes per IO)
61 eval local COUNT=\"0\"
62 eval local MIN_COUNT=\"60\"
63 if [ $ROOTFS_SIZE -lt $MIN_COUNT ]; then
64 eval COUNT=\"$MIN_COUNT\"
65 fi
66 # Create a sparse image block
Patrick Williamsc0f7c042017-02-23 20:41:17 -060067 dd if=/dev/zero of=${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.$fstype seek=$ROOTFS_SIZE count=$COUNT bs=1024
68 mkfs.$fstype -F $extra_imagecmd ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.$fstype -d ${IMAGE_ROOTFS}
Patrick Williamsc124f4f2015-09-15 14:41:29 -050069}
70
71IMAGE_CMD_ext2 = "oe_mkext234fs ext2 ${EXTRA_IMAGECMD}"
72IMAGE_CMD_ext3 = "oe_mkext234fs ext3 ${EXTRA_IMAGECMD}"
73IMAGE_CMD_ext4 = "oe_mkext234fs ext4 ${EXTRA_IMAGECMD}"
74
75MIN_BTRFS_SIZE ?= "16384"
76IMAGE_CMD_btrfs () {
77 if [ ${ROOTFS_SIZE} -gt ${MIN_BTRFS_SIZE} ]; then
Patrick Williamsc0f7c042017-02-23 20:41:17 -060078 dd if=/dev/zero of=${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.btrfs count=${ROOTFS_SIZE} bs=1024
79 mkfs.btrfs ${EXTRA_IMAGECMD} -r ${IMAGE_ROOTFS} ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.btrfs
Patrick Williamsc124f4f2015-09-15 14:41:29 -050080 else
81 bbfatal "Rootfs is too small for BTRFS (Rootfs Actual Size: ${ROOTFS_SIZE}, BTRFS Minimum Size: ${MIN_BTRFS_SIZE})"
82 fi
83}
84
Patrick Williamsc0f7c042017-02-23 20:41:17 -060085IMAGE_CMD_squashfs = "mksquashfs ${IMAGE_ROOTFS} ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.squashfs ${EXTRA_IMAGECMD} -noappend"
86IMAGE_CMD_squashfs-xz = "mksquashfs ${IMAGE_ROOTFS} ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.squashfs-xz ${EXTRA_IMAGECMD} -noappend -comp xz"
87IMAGE_CMD_squashfs-lzo = "mksquashfs ${IMAGE_ROOTFS} ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.squashfs-lzo ${EXTRA_IMAGECMD} -noappend -comp lzo"
Patrick Williamsc124f4f2015-09-15 14:41:29 -050088
89# By default, tar from the host is used, which can be quite old. If
90# you need special parameters (like --xattrs) which are only supported
91# by GNU tar upstream >= 1.27, then override that default:
92# IMAGE_CMD_TAR = "tar --xattrs --xattrs-include=*"
93# IMAGE_DEPENDS_tar_append = " tar-replacement-native"
94# EXTRANATIVEPATH += "tar-native"
95#
96# The GNU documentation does not specify whether --xattrs-include is necessary.
97# In practice, it turned out to be not needed when creating archives and
98# required when extracting, but it seems prudent to use it in both cases.
99IMAGE_CMD_TAR ?= "tar"
Patrick Williamsc0f7c042017-02-23 20:41:17 -0600100IMAGE_CMD_tar = "${IMAGE_CMD_TAR} -cvf ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.tar -C ${IMAGE_ROOTFS} ."
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500101
Patrick Williamsd8c66bc2016-06-20 12:57:21 -0500102do_image_cpio[cleandirs] += "${WORKDIR}/cpio_append"
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500103IMAGE_CMD_cpio () {
Patrick Williamsc0f7c042017-02-23 20:41:17 -0600104 (cd ${IMAGE_ROOTFS} && find . | cpio -o -H newc >${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.cpio)
105 # We only need the /init symlink if we're building the real
106 # image. The -dbg image doesn't need it! By being clever
107 # about this we also avoid 'touch' below failing, as it
108 # might be trying to touch /sbin/init on the host since both
109 # the normal and the -dbg image share the same WORKDIR
110 if [ "${IMAGE_BUILDING_DEBUGFS}" != "true" ]; then
111 if [ ! -L ${IMAGE_ROOTFS}/init ] && [ ! -e ${IMAGE_ROOTFS}/init ]; then
112 if [ -L ${IMAGE_ROOTFS}/sbin/init ] || [ -e ${IMAGE_ROOTFS}/sbin/init ]; then
113 ln -sf /sbin/init ${WORKDIR}/cpio_append/init
114 else
115 touch ${WORKDIR}/cpio_append/init
116 fi
117 (cd ${WORKDIR}/cpio_append && echo ./init | cpio -oA -H newc -F ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.cpio)
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500118 fi
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500119 fi
120}
121
Patrick Williamsd8c66bc2016-06-20 12:57:21 -0500122ELF_KERNEL ?= "${DEPLOY_DIR_IMAGE}/${KERNEL_IMAGETYPE}"
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500123ELF_APPEND ?= "ramdisk_size=32768 root=/dev/ram0 rw console="
124
125IMAGE_CMD_elf () {
Patrick Williamsc0f7c042017-02-23 20:41:17 -0600126 test -f ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.elf && rm -f ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.elf
127 mkelfImage --kernel=${ELF_KERNEL} --initrd=${DEPLOY_DIR_IMAGE}/${IMAGE_LINK_NAME}.cpio.gz --output=${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.elf --append='${ELF_APPEND}' ${EXTRA_IMAGECMD}
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500128}
Patrick Williamsd8c66bc2016-06-20 12:57:21 -0500129
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500130IMAGE_TYPEDEP_elf = "cpio.gz"
131
132UBI_VOLNAME ?= "${MACHINE}-rootfs"
133
134multiubi_mkfs() {
135 local mkubifs_args="$1"
136 local ubinize_args="$2"
137 if [ -z "$3" ]; then
138 local vname=""
139 else
140 local vname="_$3"
141 fi
142
Patrick Williamsd8c66bc2016-06-20 12:57:21 -0500143 echo \[ubifs\] > ubinize${vname}-${IMAGE_NAME}.cfg
144 echo mode=ubi >> ubinize${vname}-${IMAGE_NAME}.cfg
Patrick Williamsc0f7c042017-02-23 20:41:17 -0600145 echo image=${IMGDEPLOYDIR}/${IMAGE_NAME}${vname}${IMAGE_NAME_SUFFIX}.ubifs >> ubinize${vname}-${IMAGE_NAME}.cfg
Patrick Williamsd8c66bc2016-06-20 12:57:21 -0500146 echo vol_id=0 >> ubinize${vname}-${IMAGE_NAME}.cfg
147 echo vol_type=dynamic >> ubinize${vname}-${IMAGE_NAME}.cfg
148 echo vol_name=${UBI_VOLNAME} >> ubinize${vname}-${IMAGE_NAME}.cfg
149 echo vol_flags=autoresize >> ubinize${vname}-${IMAGE_NAME}.cfg
Patrick Williamsc0f7c042017-02-23 20:41:17 -0600150 mkfs.ubifs -r ${IMAGE_ROOTFS} -o ${IMGDEPLOYDIR}/${IMAGE_NAME}${vname}${IMAGE_NAME_SUFFIX}.ubifs ${mkubifs_args}
151 ubinize -o ${IMGDEPLOYDIR}/${IMAGE_NAME}${vname}${IMAGE_NAME_SUFFIX}.ubi ${ubinize_args} ubinize${vname}-${IMAGE_NAME}.cfg
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500152
153 # Cleanup cfg file
Patrick Williamsc0f7c042017-02-23 20:41:17 -0600154 mv ubinize${vname}-${IMAGE_NAME}.cfg ${IMGDEPLOYDIR}/
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500155
Patrick Williamsf1e5d692016-03-30 15:21:19 -0500156 # Create own symlinks for 'named' volumes
157 if [ -n "$vname" ]; then
Patrick Williamsc0f7c042017-02-23 20:41:17 -0600158 cd ${IMGDEPLOYDIR}
Patrick Williamsd8c66bc2016-06-20 12:57:21 -0500159 if [ -e ${IMAGE_NAME}${vname}${IMAGE_NAME_SUFFIX}.ubifs ]; then
160 ln -sf ${IMAGE_NAME}${vname}${IMAGE_NAME_SUFFIX}.ubifs \
Patrick Williamsf1e5d692016-03-30 15:21:19 -0500161 ${IMAGE_LINK_NAME}${vname}.ubifs
162 fi
Patrick Williamsd8c66bc2016-06-20 12:57:21 -0500163 if [ -e ${IMAGE_NAME}${vname}${IMAGE_NAME_SUFFIX}.ubi ]; then
164 ln -sf ${IMAGE_NAME}${vname}${IMAGE_NAME_SUFFIX}.ubi \
Patrick Williamsf1e5d692016-03-30 15:21:19 -0500165 ${IMAGE_LINK_NAME}${vname}.ubi
166 fi
167 cd -
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500168 fi
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500169}
170
171IMAGE_CMD_multiubi () {
172 # Split MKUBIFS_ARGS_<name> and UBINIZE_ARGS_<name>
173 for name in ${MULTIUBI_BUILD}; do
174 eval local mkubifs_args=\"\$MKUBIFS_ARGS_${name}\"
175 eval local ubinize_args=\"\$UBINIZE_ARGS_${name}\"
176
177 multiubi_mkfs "${mkubifs_args}" "${ubinize_args}" "${name}"
178 done
179}
180
181IMAGE_CMD_ubi () {
182 multiubi_mkfs "${MKUBIFS_ARGS}" "${UBINIZE_ARGS}"
183}
184
Patrick Williamsc0f7c042017-02-23 20:41:17 -0600185IMAGE_CMD_ubifs = "mkfs.ubifs -r ${IMAGE_ROOTFS} -o ${IMGDEPLOYDIR}/${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.ubifs ${MKUBIFS_ARGS}"
Patrick Williamsd8c66bc2016-06-20 12:57:21 -0500186
Patrick Williamsc0f7c042017-02-23 20:41:17 -0600187WKS_FILE ??= "${IMAGE_BASENAME}.${MACHINE}.wks"
Patrick Williamsd8c66bc2016-06-20 12:57:21 -0500188WKS_FILES ?= "${WKS_FILE} ${IMAGE_BASENAME}.wks"
189WKS_SEARCH_PATH ?= "${THISDIR}:${@':'.join('%s/scripts/lib/wic/canned-wks' % l for l in '${BBPATH}:${COREBASE}'.split(':'))}"
190WKS_FULL_PATH = "${@wks_search('${WKS_FILES}'.split(), '${WKS_SEARCH_PATH}') or ''}"
191
192def wks_search(files, search_path):
193 for f in files:
194 if os.path.isabs(f):
195 if os.path.exists(f):
196 return f
197 else:
198 searched = bb.utils.which(search_path, f)
199 if searched:
200 return searched
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500201
Patrick Williamsc0f7c042017-02-23 20:41:17 -0600202WIC_CREATE_EXTRA_ARGS ?= ""
203
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500204IMAGE_CMD_wic () {
Patrick Williamsc0f7c042017-02-23 20:41:17 -0600205 out="${IMGDEPLOYDIR}/${IMAGE_NAME}"
Patrick Williamsd8c66bc2016-06-20 12:57:21 -0500206 wks="${WKS_FULL_PATH}"
207 if [ -z "$wks" ]; then
208 bbfatal "No kickstart files from WKS_FILES were found: ${WKS_FILES}. Please set WKS_FILE or WKS_FILES appropriately."
209 fi
210
Patrick Williamsc0f7c042017-02-23 20:41:17 -0600211 BUILDDIR="${TOPDIR}" wic create "$wks" --vars "${STAGING_DIR_TARGET}/imgdata/" -e "${IMAGE_BASENAME}" -o "$out/" ${WIC_CREATE_EXTRA_ARGS}
Patrick Williamsd8c66bc2016-06-20 12:57:21 -0500212 mv "$out/build/$(basename "${wks%.wks}")"*.direct "$out${IMAGE_NAME_SUFFIX}.wic"
213 rm -rf "$out/"
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500214}
Patrick Williamsd8c66bc2016-06-20 12:57:21 -0500215IMAGE_CMD_wic[vardepsexclude] = "WKS_FULL_PATH WKS_FILES"
216
217# Rebuild when the wks file or vars in WICVARS change
Patrick Williamsc0f7c042017-02-23 20:41:17 -0600218USING_WIC = "${@bb.utils.contains_any('IMAGE_FSTYPES', 'wic ' + ' '.join('wic.%s' % c for c in '${CONVERSIONTYPES}'.split()), '1', '', d)}"
219WKS_FILE_CHECKSUM = "${@'${WKS_FULL_PATH}:%s' % os.path.exists('${WKS_FULL_PATH}') if '${USING_WIC}' else ''}"
220do_image_wic[file-checksums] += "${WKS_FILE_CHECKSUM}"
221
222python () {
223 if d.getVar('USING_WIC', True) and 'do_bootimg' in d:
224 bb.build.addtask('do_image_wic', '', 'do_bootimg', d)
225}
226
227python do_write_wks_template () {
228 """Write out expanded template contents to WKS_FULL_PATH."""
229 import re
230
231 template_body = d.getVar('_WKS_TEMPLATE', True)
232
233 # Remove any remnant variable references left behind by the expansion
234 # due to undefined variables
235 expand_var_regexp = re.compile(r"\${[^{}@\n\t :]+}")
236 while True:
237 new_body = re.sub(expand_var_regexp, '', template_body)
238 if new_body == template_body:
239 break
240 else:
241 template_body = new_body
242
243 wks_file = d.getVar('WKS_FULL_PATH', True)
244 with open(wks_file, 'w') as f:
245 f.write(template_body)
246}
247
248python () {
249 if d.getVar('USING_WIC', True):
250 wks_file_u = d.getVar('WKS_FULL_PATH', False)
251 wks_file = d.expand(wks_file_u)
252 base, ext = os.path.splitext(wks_file)
253 if ext == '.in' and os.path.exists(wks_file):
254 wks_out_file = os.path.join(d.getVar('WORKDIR', True), os.path.basename(base))
255 d.setVar('WKS_FULL_PATH', wks_out_file)
256 d.setVar('WKS_TEMPLATE_PATH', wks_file_u)
257 d.setVar('WKS_FILE_CHECKSUM', '${WKS_TEMPLATE_PATH}:True')
258
259 try:
260 with open(wks_file, 'r') as f:
261 body = f.read()
262 except (IOError, OSError) as exc:
263 pass
264 else:
265 # Previously, I used expandWithRefs to get the dependency list
266 # and add it to WICVARS, but there's no point re-parsing the
267 # file in process_wks_template as well, so just put it in
268 # a variable and let the metadata deal with the deps.
269 d.setVar('_WKS_TEMPLATE', body)
270 bb.build.addtask('do_write_wks_template', 'do_image_wic', None, d)
271}
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500272
273EXTRA_IMAGECMD = ""
274
275inherit siteinfo
276JFFS2_ENDIANNESS ?= "${@base_conditional('SITEINFO_ENDIANNESS', 'le', '-l', '-b', d)}"
277JFFS2_ERASEBLOCK ?= "0x40000"
278EXTRA_IMAGECMD_jffs2 ?= "--pad ${JFFS2_ENDIANNESS} --eraseblock=${JFFS2_ERASEBLOCK} --no-cleanmarkers"
279
280# Change these if you want default mkfs behavior (i.e. create minimal inode number)
281EXTRA_IMAGECMD_ext2 ?= "-i 4096"
282EXTRA_IMAGECMD_ext3 ?= "-i 4096"
283EXTRA_IMAGECMD_ext4 ?= "-i 4096"
Patrick Williamsd8c66bc2016-06-20 12:57:21 -0500284EXTRA_IMAGECMD_btrfs ?= "-n 4096"
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500285EXTRA_IMAGECMD_elf ?= ""
286
287IMAGE_DEPENDS = ""
288IMAGE_DEPENDS_jffs2 = "mtd-utils-native"
289IMAGE_DEPENDS_cramfs = "util-linux-native"
290IMAGE_DEPENDS_ext2 = "e2fsprogs-native"
291IMAGE_DEPENDS_ext3 = "e2fsprogs-native"
292IMAGE_DEPENDS_ext4 = "e2fsprogs-native"
293IMAGE_DEPENDS_btrfs = "btrfs-tools-native"
294IMAGE_DEPENDS_squashfs = "squashfs-tools-native"
295IMAGE_DEPENDS_squashfs-xz = "squashfs-tools-native"
296IMAGE_DEPENDS_squashfs-lzo = "squashfs-tools-native"
297IMAGE_DEPENDS_elf = "virtual/kernel mkelfimage-native"
298IMAGE_DEPENDS_ubi = "mtd-utils-native"
299IMAGE_DEPENDS_ubifs = "mtd-utils-native"
300IMAGE_DEPENDS_multiubi = "mtd-utils-native"
301IMAGE_DEPENDS_wic = "parted-native"
302
303# This variable is available to request which values are suitable for IMAGE_FSTYPES
304IMAGE_TYPES = " \
305 jffs2 jffs2.sum \
306 cramfs \
307 ext2 ext2.gz ext2.bz2 ext2.lzma \
308 ext3 ext3.gz \
309 ext4 ext4.gz \
310 btrfs \
311 iso \
312 hddimg \
313 squashfs squashfs-xz squashfs-lzo \
314 ubi ubifs multiubi \
315 tar tar.gz tar.bz2 tar.xz tar.lz4 \
316 cpio cpio.gz cpio.xz cpio.lzma cpio.lz4 \
317 vmdk \
318 vdi \
319 qcow2 \
Patrick Williamsf1e5d692016-03-30 15:21:19 -0500320 hdddirect \
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500321 elf \
322 wic wic.gz wic.bz2 wic.lzma \
323"
324
Patrick Williamsc0f7c042017-02-23 20:41:17 -0600325# Compression is a special case of conversion. The old variable
326# names are still supported for backward-compatibility. When defining
327# new compression or conversion commands, use CONVERSIONTYPES and
328# CONVERSION_CMD/DEPENDS.
329COMPRESSIONTYPES ?= ""
330
331CONVERSIONTYPES = "gz bz2 lzma xz lz4 zip sum md5sum sha1sum sha224sum sha256sum sha384sum sha512sum bmap ${COMPRESSIONTYPES}"
332CONVERSION_CMD_lzma = "lzma -k -f -7 ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}"
333CONVERSION_CMD_gz = "gzip -f -9 -c ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} > ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.gz"
334CONVERSION_CMD_bz2 = "pbzip2 -f -k ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}"
335CONVERSION_CMD_xz = "xz -f -k -c ${XZ_COMPRESSION_LEVEL} ${XZ_THREADS} --check=${XZ_INTEGRITY_CHECK} ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} > ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.xz"
336CONVERSION_CMD_lz4 = "lz4c -9 -c ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} > ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.lz4"
337CONVERSION_CMD_zip = "zip ${ZIP_COMPRESSION_LEVEL} ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.zip ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}"
338CONVERSION_CMD_sum = "sumtool -i ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} -o ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.sum ${JFFS2_SUM_EXTRA_ARGS}"
339CONVERSION_CMD_md5sum = "md5sum ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} > ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.md5sum"
340CONVERSION_CMD_sha1sum = "sha1sum ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} > ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.sha1sum"
341CONVERSION_CMD_sha224sum = "sha224sum ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} > ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.sha224sum"
342CONVERSION_CMD_sha256sum = "sha256sum ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} > ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.sha256sum"
343CONVERSION_CMD_sha384sum = "sha384sum ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} > ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.sha384sum"
344CONVERSION_CMD_sha512sum = "sha512sum ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} > ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.sha512sum"
345CONVERSION_CMD_bmap = "bmaptool create ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type} -o ${IMAGE_NAME}${IMAGE_NAME_SUFFIX}.${type}.bmap"
346CONVERSION_DEPENDS_lzma = "xz-native"
347CONVERSION_DEPENDS_gz = ""
348CONVERSION_DEPENDS_bz2 = "pbzip2-native"
349CONVERSION_DEPENDS_xz = "xz-native"
350CONVERSION_DEPENDS_lz4 = "lz4-native"
351CONVERSION_DEPENDS_zip = "zip-native"
352CONVERSION_DEPENDS_sum = "mtd-utils-native"
353CONVERSION_DEPENDS_bmap = "bmap-tools-native"
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500354
355RUNNABLE_IMAGE_TYPES ?= "ext2 ext3 ext4"
356RUNNABLE_MACHINE_PATTERNS ?= "qemu"
357
358DEPLOYABLE_IMAGE_TYPES ?= "hddimg iso"
359
360# Use IMAGE_EXTENSION_xxx to map image type 'xxx' with real image file extension name(s) for Hob
361IMAGE_EXTENSION_live = "hddimg iso"
362
363# The IMAGE_TYPES_MASKED variable will be used to mask out from the IMAGE_FSTYPES,
Patrick Williamsf1e5d692016-03-30 15:21:19 -0500364# images that will not be built at do_rootfs time: vmdk, vdi, qcow2, hdddirect, hddimg, iso, etc.
Patrick Williamsc124f4f2015-09-15 14:41:29 -0500365IMAGE_TYPES_MASKED ?= ""
366
367# The WICVARS variable is used to define list of bitbake variables used in wic code
368# variables from this list is written to <image>.env file
Patrick Williamsc0f7c042017-02-23 20:41:17 -0600369WICVARS ?= "BBLAYERS IMGDEPLOYDIR DEPLOY_DIR_IMAGE HDDDIR IMAGE_BASENAME IMAGE_BOOT_FILES IMAGE_LINK_NAME IMAGE_ROOTFS INITRAMFS_FSTYPES INITRD ISODIR MACHINE_ARCH ROOTFS_SIZE STAGING_DATADIR STAGING_DIR_NATIVE STAGING_LIBDIR TARGET_SYS"