]> Git Repo - buildroot-mgba.git/commit
fs/ext2: generate Y2K38-resilient filesystems
authorYann E. MORIN <[email protected]>
Sun, 20 Nov 2022 20:42:26 +0000 (21:42 +0100)
committerPeter Korsgaard <[email protected]>
Wed, 14 Dec 2022 19:29:11 +0000 (20:29 +0100)
commit319d2735f99e95955c2a75c8fc6282ddf7de232a
treef101c34932ed878b2353f4642c189fcabfafc395
parentbe3a6bf2e7130b084ec4ed65274ff7c4bf67510c
fs/ext2: generate Y2K38-resilient filesystems

When creating a filesystem, mkfs.ext will chose the inode size depending
on the size of the filesystem. Small filesystem get 128-bytes inodes,
while bigger filesystems use 256-byte inodes (inode must be a power of 2
larger or equal to 128, and smaller or equal to the blocksize).

However, 128-byte inodes can't store timestamps past the dreaded
2038-01-19 03:14:07Z deadline, while inodes larger than or equal to 256
do not have the issue.

It turns out that the tipping point to decide whether a filesystem is
small or big, is about around the size of the filesystems we generate
for our runtime tests. This causes the kernel to emit warning like:

    ext2 filesystem being remounted at / supports timestamps until 2038 (0x7fffffff)

We add a new option to our ext2 filesystem, so that user can specify the
size of the inode. That new option defaults to 256 to be resilient to
the Y2K38 problem.

Note: it was already possible for users to explicitly pass the -I
option, through BR2_TARGET_ROOTFS_EXT2_MKFS_OPTIONS. We could have
chosen to extend the existing value with a -I 256, but that is not
satisfactory. Indeed, we do want to ensure that the default is now
Y2K38-OK, even for existing configurations that did not have explicit
setting.

We also pass that new option before the user-specified arbitrary ones,
so that BR2_TARGET_ROOTFS_EXT2_MKFS_OPTIONS still wins (in case -I was
set there).

Signed-off-by: Yann E. MORIN <[email protected]>
[Peter: tweak help text]
Signed-off-by: Peter Korsgaard <[email protected]>
fs/ext2/Config.in
fs/ext2/ext2.mk
This page took 0.035625 seconds and 4 git commands to generate.