Whamcloud - gitweb
e2fsck: set E2F_FLAG_ALLOC_OK after threads
authorWang Shilong <wshilong@ddn.com>
Thu, 16 Apr 2020 07:08:31 +0000 (15:08 +0800)
committerLi Dongyang <dongyangli@ddn.com>
Thu, 8 Apr 2021 00:57:44 +0000 (10:57 +1000)
Only flag ALLOC OK after all threads finished without problem.

E2fsprogs-commit: 2c1e9ced674f0d8e634c3b6299ce9bdfbe4b8739

Change-Id: I764d08bab5299ec0aec9d7d5e9b21320c085dee9
Signed-off-by: Wang Shilong <wshilong@ddn.com>
Reviewed-by: Andreas Dilger <adilger@whamcloud.com>
Signed-off-by: Theodore Ts'o <tytso@mit.edu>
e2fsck/pass1.c

index 26e7ab4..aceede7 100644 (file)
@@ -1382,9 +1382,12 @@ static void e2fsck_pass1_post(e2fsck_t ctx)
 {
        struct problem_context pctx;
        ext2_filsys fs = ctx->fs;
+       char *block_buf;
 
-       char *block_buf =
-               (char *)e2fsck_allocate_memory(ctx, ctx->fs->blocksize * 3,
+       if (e2fsck_should_abort(ctx))
+               return;
+
+       block_buf = (char *)e2fsck_allocate_memory(ctx, ctx->fs->blocksize * 3,
                                              "block interate buffer");
        reserve_block_for_root_repair(ctx);
        reserve_block_for_lnf_repair(ctx);
@@ -1462,6 +1465,8 @@ static void e2fsck_pass1_post(e2fsck_t ctx)
                ext2fs_free_mem(&block_buf);
                ctx->flags &= ~E2F_FLAG_DUP_BLOCK;
        }
+
+       ctx->flags |= E2F_FLAG_ALLOC_OK;
 }
 
 
@@ -2327,6 +2332,7 @@ void e2fsck_pass1_run(e2fsck_t ctx)
        }
 
        ctx->flags |= E2F_FLAG_ALLOC_OK;
+       ext2fs_free_mem(&inodes_to_process);
 endit:
        e2fsck_use_inode_shortcuts(ctx, 0);
        ext2fs_free_mem(&inodes_to_process);