btrfs-progs: check: enhanced progress indicator
commit078e9a1cc973e042ad8fde2d84e0db62fee9c45a
authorStéphane Lesimple <stephane_btrfs@lesimple.fr>
Wed, 4 Jul 2018 19:20:14 +0000 (4 21:20 +0200)
committerDavid Sterba <dsterba@suse.com>
Mon, 6 Aug 2018 13:03:23 +0000 (6 15:03 +0200)
treea7eb3c003d64350e03076959a00c499843f6209d
parent48a2818159792bdd1fcb98aab6203a1080d4c310
btrfs-progs: check: enhanced progress indicator

We reuse the task_position enum and task_ctx struct of the original progress
indicator, adding more values and fields for our needs.

Then add hooks in all steps of the check to properly record progress.

Here's how the output looks like on a 22 Tb 5-disk RAID1 FS:

Opening filesystem to check...
Checking filesystem on /dev/mapper/luks-ST10000VN0004-XXXXXXXX
UUID: xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
[1/7] checking extents           (0:20:21 elapsed, 950958 items checked)
[2/7] checking root items        (0:01:29 elapsed, 15121 items checked)
[3/7] checking free space cache  (0:00:11 elapsed, 4928 items checked)
[4/7] checking fs roots          (0:51:31 elapsed, 600892 items checked)
[5/7] checking csums             (0:14:35 elapsed, 754522 items checked)
[6/7] checking root refs         (0:00:00 elapsed, 232 items checked)
[7/7] checking quota groups skipped (not enabled on this FS)
found 5286458060800 bytes used, no error found

Signed-off-by: Stéphane Lesimple <stephane_btrfs@lesimple.fr>
Signed-off-by: David Sterba <dsterba@suse.com>
check/main.c
check/mode-common.h
check/mode-lowmem.c
convert/main.c
qgroup-verify.c
qgroup-verify.h
task-utils.c
task-utils.h