If build happens on zfs filesystem with compression enabled, then image size calculations in do_image_wic task can fail:
output: mke2fs 1.47.0 (5-Feb-2023) Discarding device blocks: done Creating filesystem with 351999 4k blocks and 176000 inodes Filesystem UUID: 6091b3a4-ce08-3020-93a6-f755a22ef03b Superblock backups stored on blocks: 32768, 98304, 163840, 229376, 294912 Allocating group tables: done Writing inode tables: done Creating journal (8192 blocks): done Copying files into the device: __populate_fs: Could not allocate block in ext2 filesystem while writing file "service-2.json" mkfs.ext4: Could not allocate block in ext2 filesystem while populating file system du --help says: --apparent-size print apparent sizes, rather than disk usage; although the apparent size is usually smaller, it may be larger due to holes in ('sparse') files, internal fragmentation, indirect blocks, and the like du -b already includes --apparent-size. Same issue reported also in https://lists.yoctoproject.org/g/poky/message/12389 Signed-off-by: Mikko Rapeli <mikko.rap...@linaro.org> --- scripts/lib/wic/partition.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/scripts/lib/wic/partition.py b/scripts/lib/wic/partition.py index 795707ec5d..4690ddaa4d 100644 --- a/scripts/lib/wic/partition.py +++ b/scripts/lib/wic/partition.py @@ -254,7 +254,7 @@ class Partition(): # Bitbake variable ROOTFS_SIZE is not defined so compute it # from the rootfs_dir size using the same logic found in # get_rootfs_size() from meta/classes/image.bbclass - du_cmd = "du -ks %s" % rootfs_dir + du_cmd = "du -ks --apparent-size %s" % rootfs_dir out = exec_cmd(du_cmd) self.size = int(out.split()[0]) @@ -273,7 +273,7 @@ class Partition(): """ Prepare content for an ext2/3/4 rootfs partition. """ - du_cmd = "du -ks %s" % rootfs_dir + du_cmd = "du -ks --apparent-size %s" % rootfs_dir out = exec_cmd(du_cmd) actual_rootfs_size = int(out.split()[0]) @@ -349,7 +349,7 @@ class Partition(): """ Prepare content for a btrfs rootfs partition. """ - du_cmd = "du -ks %s" % rootfs_dir + du_cmd = "du -ks --apparent-size %s" % rootfs_dir out = exec_cmd(du_cmd) actual_rootfs_size = int(out.split()[0]) -- 2.34.1
-=-=-=-=-=-=-=-=-=-=-=- Links: You receive all messages sent to this group. View/Reply Online (#196261): https://lists.openembedded.org/g/openembedded-core/message/196261 Mute This Topic: https://lists.openembedded.org/mt/104600633/21656 Group Owner: openembedded-core+ow...@lists.openembedded.org Unsubscribe: https://lists.openembedded.org/g/openembedded-core/unsub [arch...@mail-archive.com] -=-=-=-=-=-=-=-=-=-=-=-