diff options
| author | Ross Burton <ross@burtonini.com> | 2021-08-09 16:36:48 +0100 |
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2021-08-26 08:32:14 +0100 |
| commit | 02c3c6dbc8970acbe08b73f7fe1555d151eb53e6 (patch) | |
| tree | 7274a8141294324378dcd9623d5a429cbc254188 | |
| parent | 8c4fda3807d0a1992b80f2393b813812f2cb7144 (diff) | |
| download | poky-02c3c6dbc8970acbe08b73f7fe1555d151eb53e6.tar.gz | |
e2fsprogs: ensure small images have 256-byte inodes
e2fsprogs calls filesystems larger than 3MB but smaller than 512MB
"small", which has some implications:
- blocksize 1024 instead of 4096
- inode_ratio 4096 instead of 16384
- inode_size 128 instead of 256
The outcome of the inode size dropping to 128 bytes is that they cannot
store 64-bit timestamps, so are not Y2038-safe.
A previous attempt to solve this problem[1] changed some of the canned
wic files to pass -T default to mkfs.ext4, but this only covered wic
images and not traditional images. Also, actually small filesystems,
for example a core-image-minimal, will happily be tens of megabytes and
with the "default" options will result in an image which runs out of
blocks before it runs out of space:
mkfs.ext4: Could not allocate block in ext2 filesystem while populating file system
Considering that many OpenEmbedded images are in fact "small", being
2038-safe is worth the marginal increase is disk usage. This patch
alters the small configuration in native builds so that it also has
256-byte inodes. Target is unchanged so that standard behaviour is
maintained outside of the build.
This is actually the same underlying patch that Mathieu Dubois-Briand
sent in April, but the wic change in [1] was accepted instead. I believe
that is the wrong approach and this approach covers more cases.
[ YOCTO #14478 ]
[1] openembedded-core eecbe62
[2] https://lists.openembedded.org/g/openembedded-core/message/150298
(From OE-Core rev: e89bac87c91e943060662be04775a1ff8e4c4f22)
Signed-off-by: Ross Burton <ross.burton@arm.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
(cherry picked from commit 9ab0ae83a24ee99e69f8ac54256b253a122aef8a)
Signed-off-by: Anuj Mittal <anuj.mittal@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
| -rw-r--r-- | meta/recipes-devtools/e2fsprogs/e2fsprogs/big-inodes-for-small-fs.patch | 22 | ||||
| -rw-r--r-- | meta/recipes-devtools/e2fsprogs/e2fsprogs_1.46.1.bb | 1 |
2 files changed, 23 insertions, 0 deletions
diff --git a/meta/recipes-devtools/e2fsprogs/e2fsprogs/big-inodes-for-small-fs.patch b/meta/recipes-devtools/e2fsprogs/e2fsprogs/big-inodes-for-small-fs.patch new file mode 100644 index 0000000000..caeb560d32 --- /dev/null +++ b/meta/recipes-devtools/e2fsprogs/e2fsprogs/big-inodes-for-small-fs.patch | |||
| @@ -0,0 +1,22 @@ | |||
| 1 | Ensure "small" file systems also have the default inode size (256 bytes) so that | ||
| 2 | can store 64-bit timestamps and work past 2038. | ||
| 3 | |||
| 4 | The "small" type is any size >3MB and <512MB, which covers a lot of relatively | ||
| 5 | small filesystems built by OE, especially when they're sized to fit the contents | ||
| 6 | and expand to the storage on boot. | ||
| 7 | |||
| 8 | Upstream-Status: Inappropriate | ||
| 9 | Signed-off-by: Ross Burton <ross.burton@arm.com> | ||
| 10 | |||
| 11 | diff --git a/misc/mke2fs.conf.in b/misc/mke2fs.conf.in | ||
| 12 | index 01e35cf8..29f41dc0 100644 | ||
| 13 | --- a/misc/mke2fs.conf.in | ||
| 14 | +++ b/misc/mke2fs.conf.in | ||
| 15 | @@ -16,7 +16,6 @@ | ||
| 16 | } | ||
| 17 | small = { | ||
| 18 | blocksize = 1024 | ||
| 19 | - inode_size = 128 | ||
| 20 | inode_ratio = 4096 | ||
| 21 | } | ||
| 22 | floppy = { | ||
diff --git a/meta/recipes-devtools/e2fsprogs/e2fsprogs_1.46.1.bb b/meta/recipes-devtools/e2fsprogs/e2fsprogs_1.46.1.bb index be8b67c35d..ddc9bfec90 100644 --- a/meta/recipes-devtools/e2fsprogs/e2fsprogs_1.46.1.bb +++ b/meta/recipes-devtools/e2fsprogs/e2fsprogs_1.46.1.bb | |||
| @@ -8,6 +8,7 @@ SRC_URI += "file://remove.ldconfig.call.patch \ | |||
| 8 | 8 | ||
| 9 | SRC_URI_append_class-native = " file://e2fsprogs-fix-missing-check-for-permission-denied.patch \ | 9 | SRC_URI_append_class-native = " file://e2fsprogs-fix-missing-check-for-permission-denied.patch \ |
| 10 | file://quiet-debugfs.patch \ | 10 | file://quiet-debugfs.patch \ |
| 11 | file://big-inodes-for-small-fs.patch \ | ||
| 11 | " | 12 | " |
| 12 | 13 | ||
| 13 | 14 | ||
