From: Gyorgy Sarvari <skandigraun@gmail.com>
To: jon.mason@arm.com, openembedded-core@lists.openembedded.org
Subject: Re: [OE-core] [RESEND PATCH 2/2] runqemu: resize rootfs image to power of 2 for SD or pflash
Date: Thu, 2 Oct 2025 19:29:13 +0200 [thread overview]
Message-ID: <5cc51968-6aeb-4b61-9724-17bf112c771f@gmail.com> (raw)
In-Reply-To: <20251001175702.62563-2-jon.mason@arm.com>
On 10/1/25 19:57, Jon Mason via lists.openembedded.org wrote:
> QEMU requires that SD and pflash images are sized to be a power of 2
> (e.g., 32M, 64M, etc). So, if the image being used is not a power of 2
> and it's being used for SD or pflash, increase it to the next power of 2
> size via the truncate command.
>
> This might not be an actual spec requirement, and is being investigated
> in https://gitlab.com/qemu-project/qemu/-/issues/1754
>
> Signed-off-by: Jon Mason <jon.mason@arm.com>
> ---
> scripts/runqemu | 24 ++++++++++++++++++++++--
> 1 file changed, 22 insertions(+), 2 deletions(-)
>
> diff --git a/scripts/runqemu b/scripts/runqemu
> index a8144aa68c3d..cd2ded69916a 100755
> --- a/scripts/runqemu
> +++ b/scripts/runqemu
> @@ -421,7 +421,27 @@ class BaseConfig(object):
> else:
> raise RunQemuError("Unknown path arg %s" % p)
>
> - def uncompress_rootfs(self):
> + def rootfs_fixups(self):
> +
> + """Resize rootfs image if needed"""
Nit: the docstring now only describes the newly added behavior, but not
the original. The original docstring is also present, but it is now in
the middle of the method.
> + qb_rootfs_opt = self.get('QB_ROOTFS_OPT')
> +
> + # Check if sdcard size is a power of 2, as that is currently a requirement for qemu
> + # See https://gitlab.com/qemu-project/qemu/-/issues/1754
> + rootfs_size = os.path.getsize(self.rootfs)
> + rootfs_size_pwr2 = 1 << (rootfs_size - 1).bit_length()
> + if ("if=sd" in qb_rootfs_opt or "if=pflash" in qb_rootfs_opt) and rootfs_size != rootfs_size_pwr2:
> + logger.info("Using sd-card or pflash and is not power of 2. File size %d, power of 2 size %d" %(rootfs_size, rootfs_size_pwr2))
> + logger.info("Attempting to use truncate to correct this.")
> +
> + # Ensure the 'truncate' tool is installed before attempting to make a power of 2.
> + if not shutil.which('truncate'):
> + raise RunQemuError(f"'truncate' is required to make {self.rootfs} a power of 2 in size but was not found in PATH")
> + try:
> + subprocess.check_call(['truncate', '-s', str(rootfs_size_pwr2), self.rootfs])
> + except subprocess.CalledProcessError as e:
> + raise RunQemuError(f"Failed to make {self.rootfs} power of 2 in size: {e}")
> +
> """Decompress ZST rootfs image if needed"""
> if not self.rootfs or not self.fstype.endswith('.zst'):
> return
> @@ -1808,7 +1828,7 @@ def main():
> config.check_args()
> config.read_qemuboot()
> config.check_and_set()
> - config.uncompress_rootfs()
> + config.rootfs_fixups()
> # Check whether the combos is valid or not
> config.validate_combos()
> config.print_config()
>
> -=-=-=-=-=-=-=-=-=-=-=-
> Links: You receive all messages sent to this group.
> View/Reply Online (#224315): https://lists.openembedded.org/g/openembedded-core/message/224315
> Mute This Topic: https://lists.openembedded.org/mt/115538558/6084445
> Group Owner: openembedded-core+owner@lists.openembedded.org
> Unsubscribe: https://lists.openembedded.org/g/openembedded-core/unsub [skandigraun@gmail.com]
> -=-=-=-=-=-=-=-=-=-=-=-
>
next prev parent reply other threads:[~2025-10-02 17:29 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-10-01 17:57 [RESEND PATCH 1/2] runqemu: remove setting of mem on kernel command line for certain systems Jon Mason
2025-10-01 17:57 ` [RESEND PATCH 2/2] runqemu: resize rootfs image to power of 2 for SD or pflash Jon Mason
2025-10-02 17:29 ` Gyorgy Sarvari [this message]
2025-10-03 14:42 ` [OE-core] " Jon Mason
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=5cc51968-6aeb-4b61-9724-17bf112c771f@gmail.com \
--to=skandigraun@gmail.com \
--cc=jon.mason@arm.com \
--cc=openembedded-core@lists.openembedded.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox