[OE-core] [PATCH 3/3] wic: apply --extra-space + --overhead to squashfs
Ed Bartosh
ed.bartosh at linux.intel.com
Tue Sep 12 12:57:20 UTC 2017
On Tue, Sep 12, 2017 at 02:18:41PM +0200, Enrico Scholz wrote:
> Ed Bartosh <ed.bartosh at linux.intel.com> writes:
>
> >> >> >> The --extra-space and --overhead option did not had an effect to squashfs
> >> >> >> partitions. Although squashfs is read-only, it can be useful to allocate
> >> >> >> more space for the on-disk partition to avoid repartitioning of the whole
> >> >> >> disk when a new (and larger) squashfs image is written on later updates.
> >> >> >
> >> >> > Is it possible to just use --size or --fixed-size in .wks to allocate
> >> >> > partition of certain size?
> >> >>
> >> >> --fixed-size works with this patch (tested); --size should work.
> >> >
> >> > Sorry for not being clear. Why do we need this if we can use --size to
> >> > explicity specify partition size?
> >>
> >> --size and --fixed-size did not had an effect for squashfs with the old
> >> code.
> >>
> >
> > I'd propose to fix this instead of applying extra space and overhead
> > factor to the filesystems that don't support this by design.
> >
> > The idea is to make size and fixed-size parameters to set partition size
> > and use extra-space and overhead-factor to extend filesystem size as
> > they're currently used.
>
> For what is this overhead to be used? In most cases, to allow future
> updates. And this is required for squashfs too.
>
It depends on the usage scenario. Additional space may be required
for other purposes too. It may me needed for the system to be able to
boot and perform what it was built for.
> Only difference is, that updates for squashfs are to be applied on
> partition level and these for other file systems on file system level.
> But the need for extra space exists in both cases.
>
>
> >> I want/need it to allow updates of the running system without complete
> >> repartitioning. E.g. at wic creation time, the squashfs has a certain
> >> size. Sometime in the future, there are needed e.g. 5 MiB more because
> >> a new package was added or so.
> >>
> >
> > Yep, I understood what you want. I think it's better achieved by setting
> > partition size with --size option than artificially apply extra-space and
> > overhead factor to the filesystem that doesn't support this.
>
> It really does not matter for me whether the filesystem itself can be
> extended or whether I need a larger partition to apply future updates.
>
It matters for me. I think I explained why.
> I just need a partition which provides an absolute or relative amount of
> additional space.
>
>
> >> I need to reserve space in the partition so that I can 'dd' the new
> >> image without a complete repartitioning.
> >>
> >> --extra-space/--overhead has the meaning which I want (e.g. to say
> >> "reserve +20% for changes in the future").
> >
> > So far extra-space and overhead factor were used to allocate additional
> > space on the file system. This is different from the way you want to
> > use them. You're not allocating space on squashfs, you're allocating
> > unformatted space on the partition. It's better to use --size for this.
>
> No; --size is not what I want. --size (or --fixed-size) assume that I
> know the absolute size.
>
> Of course, I can get this size empirically. But it is highly inflexible
> and requires different wks files for different image types.
>
> I want to reserve an extra percentage for future updates. And these
> percentages can be in the range of 1 - 5 MB (for small images with
> only test tools) or several hundred MB (for large image types with
> e.g. desktop environments).
>
> --size or --fixed-size for these image types would be in completely
> different ranges while --extra-space/--overhead fits to all.
>
I agree. --size is less suitable for your needs than extra space and
overhead factor. I still don't like the idea of using them to reserve
non-formatted space. Any other ideas how to do it?
--
Regards,
Ed
More information about the Openembedded-core
mailing list