diff options
author | Android Build Coastguard Worker <android-build-coastguard-worker@google.com> | 2021-11-10 19:55:55 +0000 |
---|---|---|
committer | Android Build Coastguard Worker <android-build-coastguard-worker@google.com> | 2021-11-10 19:55:55 +0000 |
commit | 9924d2f7c2c55e3cca7710b3ea638904222e27c5 (patch) | |
tree | a9f42f5fec12b5124ed530b3e83bb5e1ff33fa24 | |
parent | a3d09b8abe4bc226387626002606916f9eda5013 (diff) | |
parent | e4c4584652fc74abd76e6e6f23d8285bd9ccc137 (diff) | |
download | f2fs-tools-9924d2f7c2c55e3cca7710b3ea638904222e27c5.tar.gz |
Snap for 7901677 from e4c4584652fc74abd76e6e6f23d8285bd9ccc137 to sc-platform-releaseandroid-platform-12.0.0_r9android-platform-12.0.0_r8android-platform-12.0.0_r7android-platform-12.0.0_r6android-platform-12.0.0_r5android-platform-12.0.0_r4android-platform-12.0.0_r32android-platform-12.0.0_r31android-platform-12.0.0_r30android-platform-12.0.0_r3android-platform-12.0.0_r29android-platform-12.0.0_r28android-platform-12.0.0_r27android-platform-12.0.0_r26android-platform-12.0.0_r25android-platform-12.0.0_r24android-platform-12.0.0_r23android-platform-12.0.0_r22android-platform-12.0.0_r21android-platform-12.0.0_r20android-platform-12.0.0_r2android-platform-12.0.0_r19android-platform-12.0.0_r18android-platform-12.0.0_r17android-platform-12.0.0_r16android-platform-12.0.0_r15android-platform-12.0.0_r14android-platform-12.0.0_r13android-platform-12.0.0_r12android-platform-12.0.0_r11android-platform-12.0.0_r10android12-platform-release
Change-Id: I214270de4c1727e1cb946d0d0565f50af977e71e
-rw-r--r-- | fsck/mount.c | 53 | ||||
-rw-r--r-- | include/f2fs_fs.h | 4 | ||||
-rw-r--r-- | lib/libf2fs.c | 6 |
3 files changed, 51 insertions, 12 deletions
diff --git a/fsck/mount.c b/fsck/mount.c index de692b6..5e805c7 100644 --- a/fsck/mount.c +++ b/fsck/mount.c @@ -13,6 +13,7 @@ #include "xattr.h" #include <locale.h> #include <stdbool.h> +#include <time.h> #ifdef HAVE_LINUX_POSIX_ACL_H #include <linux/posix_acl.h> #endif @@ -424,7 +425,7 @@ printout: DISP_u32(sb, meta_ino); DISP_u32(sb, cp_payload); DISP_u32(sb, crc); - DISP("%-.256s", sb, version); + DISP("%-.252s", sb, version); printf("\n"); } @@ -944,6 +945,8 @@ int sanity_check_raw_super(struct f2fs_super_block *sb, enum SB_ADDR sb_addr) return 0; } +#define CHECK_PERIOD (3600 * 24 * 30) // one month by default + int validate_super_block(struct f2fs_sb_info *sbi, enum SB_ADDR sb_addr) { char buf[F2FS_BLKSIZE]; @@ -961,31 +964,65 @@ int validate_super_block(struct f2fs_sb_info *sbi, enum SB_ADDR sb_addr) if (!sanity_check_raw_super(sbi->raw_super, sb_addr)) { /* get kernel version */ if (c.kd >= 0) { - dev_read_version(c.version, 0, VERSION_LEN); + dev_read_version(c.version, 0, VERSION_NAME_LEN); get_kernel_version(c.version); } else { get_kernel_uname_version(c.version); } /* build sb version */ - memcpy(c.sb_version, sbi->raw_super->version, VERSION_LEN); + memcpy(c.sb_version, sbi->raw_super->version, VERSION_NAME_LEN); get_kernel_version(c.sb_version); - memcpy(c.init_version, sbi->raw_super->init_version, VERSION_LEN); + memcpy(c.init_version, sbi->raw_super->init_version, + VERSION_NAME_LEN); get_kernel_version(c.init_version); MSG(0, "Info: MKFS version\n \"%s\"\n", c.init_version); MSG(0, "Info: FSCK version\n from \"%s\"\n to \"%s\"\n", c.sb_version, c.version); +#if defined(__APPLE__) if (!c.no_kernel_check && - memcmp(c.sb_version, c.version, VERSION_LEN)) { + memcmp(c.sb_version, c.version, VERSION_NAME_LEN)) { c.auto_fix = 0; c.fix_on = 1; - } - if (c.fix_on) { memcpy(sbi->raw_super->version, - c.version, VERSION_LEN); + c.version, VERSION_NAME_LEN); update_superblock(sbi->raw_super, SB_MASK(sb_addr)); } +#else + if (!c.no_kernel_check) { + struct timespec t; + u32 prev_time, cur_time, time_diff; + __le32 *ver_ts_ptr = (__le32 *)(sbi->raw_super->version + + VERSION_NAME_LEN); + + t.tv_sec = t.tv_nsec = 0; + clock_gettime(CLOCK_REALTIME, &t); + cur_time = (u32)t.tv_sec; + prev_time = le32_to_cpu(*ver_ts_ptr); + + MSG(0, "Info: version timestamp cur: %u, prev: %u\n", + cur_time, prev_time); + if (!memcmp(c.sb_version, c.version, + VERSION_NAME_LEN)) { + /* valid prev_time */ + if (prev_time != 0 && cur_time > prev_time) { + time_diff = cur_time - prev_time; + if (time_diff < CHECK_PERIOD) + goto out; + c.auto_fix = 0; + c.fix_on = 1; + } + } else { + memcpy(sbi->raw_super->version, + c.version, VERSION_NAME_LEN); + } + + *ver_ts_ptr = cpu_to_le32(cur_time); + update_superblock(sbi->raw_super, SB_MASK(sb_addr)); + } +out: +#endif print_sb_state(sbi->raw_super); return 0; } diff --git a/include/f2fs_fs.h b/include/f2fs_fs.h index 8969ae2..84811db 100644 --- a/include/f2fs_fs.h +++ b/include/f2fs_fs.h @@ -350,7 +350,9 @@ static inline uint64_t bswap_64(uint64_t val) #define DEFAULT_BLOCKS_PER_SEGMENT 512 #define DEFAULT_SEGMENTS_PER_SECTION 1 -#define VERSION_LEN 256 +#define VERSION_LEN 256 +#define VERSION_TIMESTAMP_LEN 4 +#define VERSION_NAME_LEN (VERSION_LEN - VERSION_TIMESTAMP_LEN) #define LPF "lost+found" diff --git a/lib/libf2fs.c b/lib/libf2fs.c index 0add901..f2649f1 100644 --- a/lib/libf2fs.c +++ b/lib/libf2fs.c @@ -819,7 +819,7 @@ int f2fs_devs_are_umounted(void) void get_kernel_version(__u8 *version) { int i; - for (i = 0; i < VERSION_LEN; i++) { + for (i = 0; i < VERSION_NAME_LEN; i++) { if (version[i] == '\n') break; } @@ -837,10 +837,10 @@ void get_kernel_uname_version(__u8 *version) #if defined(WITH_KERNEL_VERSION) snprintf((char *)version, - VERSION_LEN, "%s %s", buf.release, buf.version); + VERSION_NAME_LEN, "%s %s", buf.release, buf.version); #else snprintf((char *)version, - VERSION_LEN, "%s", buf.release); + VERSION_NAME_LEN, "%s", buf.release); #endif #else memset(version, 0, VERSION_LEN); |