]> git.ipfire.org Git - thirdparty/e2fsprogs.git/commitdiff
e2fsck: Add new e2fsck.conf option: broken_system_clock
authorTheodore Ts'o <tytso@mit.edu>
Mon, 4 Jan 2010 18:59:04 +0000 (13:59 -0500)
committerTheodore Ts'o <tytso@mit.edu>
Mon, 4 Jan 2010 18:59:04 +0000 (13:59 -0500)
The broken_system_clock allows the time to be in the future when in
preen mode.  It's useful for people who have, as the name implies,
broken system clocks.

Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
e2fsck/e2fsck.conf.5.in
e2fsck/problem.c

index a5021bd16ecb4689fdbd5010968851999ec9b02c..64aafd702368fdbcc2f6367741e6f36808b05989 100644 (file)
@@ -109,6 +109,19 @@ This can be disabled by setting
 to the
 boolean value of false.  This setting defaults to true.
 .TP
+.I broken_system_clock
+The
+.BR e2fsck (8)
+program has some hueristics that assume that the system clock is
+correct.  In addition, many system programs make similar assumptions.
+For example, the UUID library depends on time not going backwards in
+order for it to be able to make its guarantees about issuing universally
+unique ID's.  Systems with broken system clocks, are well, broken.
+However, broken system clocks, particularly in embedded systems, do
+exist.  If true, e2fsck will not abort a preen check if it detects a
+last mounted or last write time in the superblock in the future.  This
+setting defaults to false.
+.TP
 .I clear_test_fs_flag
 This boolean relation controls whether or not 
 .BR e2fsck (8)
index a713f1b27936690308f423fb844d6fb1bae701b2..9043281dcdd28f27e8c9ab3bcd2bde4cfc815007 100644 (file)
@@ -1741,7 +1741,7 @@ int fix_problem(e2fsck_t ctx, problem_t code, struct problem_context *pctx)
        struct e2fsck_problem *ptr;
        struct latch_descr *ldesc = 0;
        const char *message;
-       int             def_yn, answer, ans;
+       int             def_yn, answer, ans, broken_system_clock;
        int             print_answer = 0;
        int             suppress = 0;
 
@@ -1753,6 +1753,15 @@ int fix_problem(e2fsck_t ctx, problem_t code, struct problem_context *pctx)
        if (!(ptr->flags & PR_CONFIG)) {
                char    key[9], *new_desc;
 
+               if ((code == PR_0_FUTURE_SB_LAST_MOUNT) ||
+                   (code == PR_0_FUTURE_SB_LAST_WRITE)) {
+                       profile_get_boolean(ctx->profile, "options",
+                                           "broken_system_clock", 0, 0,
+                                           &broken_system_clock);
+                       if (broken_system_clock)
+                               ptr->flags |= PR_PREEN_OK;
+               }
+
                sprintf(key, "0x%06x", code);
 
                profile_get_string(ctx->profile, "problems", key,