From: Satoru Takeuchi <satoru.takeuchi@gmail.com>
To: Qu Wenruo <quwenruo.btrfs@gmx.com>
Cc: linux-btrfs@vger.kernel.org, dsterba@suse.cz
Subject: Re: [PATCH v2] btrfs-progs: Output time elapsed for each major tree it checked
Date: Mon, 18 Sep 2017 10:47:00 +0900 [thread overview]
Message-ID: <874ls0aicr.wl-satoru.takeuchi@gmail.com> (raw)
In-Reply-To: <20170918004729.5871-1-quwenruo.btrfs@gmx.com>
At Mon, 18 Sep 2017 09:47:29 +0900,
Qu Wenruo wrote:
>
> Marc reported that "btrfs check --repair" runs much faster than "btrfs
> check", which is quite weird.
>
> This patch will add time elapsed for each major tree it checked, for
> both original mode and lowmem mode, so we can have a clue what's going
> wrong.
>
> Reported-by: Marc MERLIN <marc@merlins.org>
> Signed-off-by: Qu Wenruo <quwenruo.btrfs@gmx.com>
> ---
> v2:
> Add prefix for each time report, as error message may make the output
> hard to understand. Suggested by Satoru.
Reviewed-by: Satoru Takeuchi <satoru.takeuchi@gmail.com>
> ---
> cmds-check.c | 21 +++++++++++++++++++--
> utils.h | 24 ++++++++++++++++++++++++
> 2 files changed, 43 insertions(+), 2 deletions(-)
>
> diff --git a/cmds-check.c b/cmds-check.c
> index 006edbde..f1074c73 100644
> --- a/cmds-check.c
> +++ b/cmds-check.c
> @@ -5318,13 +5318,16 @@ static int do_check_fs_roots(struct btrfs_fs_info *fs_info,
> struct cache_tree *root_cache)
> {
> int ret;
> + struct timer timer;
>
> if (!ctx.progress_enabled)
> fprintf(stderr, "checking fs roots\n");
> + start_timer(&timer);
> if (check_mode == CHECK_MODE_LOWMEM)
> ret = check_fs_roots_v2(fs_info);
> else
> ret = check_fs_roots(fs_info, root_cache);
> + printf("fs roots checked in %d seconds\n", stop_timer(&timer));
>
> return ret;
> }
> @@ -11584,14 +11587,16 @@ out:
> static int do_check_chunks_and_extents(struct btrfs_fs_info *fs_info)
> {
> int ret;
> + struct timer timer;
>
> if (!ctx.progress_enabled)
> fprintf(stderr, "checking extents\n");
> + start_timer(&timer);
> if (check_mode == CHECK_MODE_LOWMEM)
> ret = check_chunks_and_extents_v2(fs_info);
> else
> ret = check_chunks_and_extents(fs_info);
> -
> + printf("extents checked in %d seconds\n", stop_timer(&timer));
> return ret;
> }
>
> @@ -12772,6 +12777,7 @@ int cmd_check(int argc, char **argv)
> int qgroups_repaired = 0;
> unsigned ctree_flags = OPEN_CTREE_EXCLUSIVE;
> int force = 0;
> + struct timer timer;
>
> while(1) {
> int c;
> @@ -12953,8 +12959,11 @@ int cmd_check(int argc, char **argv)
> if (repair)
> ctree_flags |= OPEN_CTREE_PARTIAL;
>
> + printf("opening btrfs filesystem\n");
> + start_timer(&timer);
> info = open_ctree_fs_info(argv[optind], bytenr, tree_root_bytenr,
> chunk_root_bytenr, ctree_flags);
> + printf("btrfs filesystem opened in %d seconds\n", stop_timer(&timer));
> if (!info) {
> error("cannot open file system");
> ret = -EIO;
> @@ -13115,8 +13124,10 @@ int cmd_check(int argc, char **argv)
> else
> fprintf(stderr, "checking free space cache\n");
> }
> + start_timer(&timer);
> ret = check_space_cache(root);
> err |= !!ret;
> + printf("free space cache (tree) checked in %d seconds\n", stop_timer(&timer));
> if (ret) {
> if (btrfs_fs_compat_ro(info, FREE_SPACE_TREE))
> error("errors found in free space tree");
> @@ -13140,18 +13151,22 @@ int cmd_check(int argc, char **argv)
> }
>
> fprintf(stderr, "checking csums\n");
> + start_timer(&timer);
> ret = check_csums(root);
> err |= !!ret;
> + printf("csums tree checked in %d seconds\n", stop_timer(&timer));
> if (ret) {
> error("errors found in csum tree");
> goto out;
> }
>
> - fprintf(stderr, "checking root refs\n");
> /* For low memory mode, check_fs_roots_v2 handles root refs */
> if (check_mode != CHECK_MODE_LOWMEM) {
> + fprintf(stderr, "checking root refs\n");
> + start_timer(&timer);
> ret = check_root_refs(root, &root_cache);
> err |= !!ret;
> + printf("root refs checked in %d seconds\n", stop_timer(&timer));
> if (ret) {
> error("errors found in root refs");
> goto out;
> @@ -13186,8 +13201,10 @@ int cmd_check(int argc, char **argv)
>
> if (info->quota_enabled) {
> fprintf(stderr, "checking quota groups\n");
> + start_timer(&timer);
> ret = qgroup_verify_all(info);
> err |= !!ret;
> + printf("quota groups checked in %d seconds\n", stop_timer(&timer));
> if (ret) {
> error("failed to check quota groups");
> goto out;
> diff --git a/utils.h b/utils.h
> index d28a05a6..159487db 100644
> --- a/utils.h
> +++ b/utils.h
> @@ -172,4 +172,28 @@ u64 rand_u64(void);
> unsigned int rand_range(unsigned int upper);
> void init_rand_seed(u64 seed);
>
> +/* Utils to report time duration */
> +struct timer {
> + time_t start;
> +};
> +
> +static inline void start_timer(struct timer *t)
> +{
> + time(&t->start);
> +}
> +
> +/*
> + * Stop timer and return the time elapsed in int
> + *
> + * int should be large enough to "btrfs check" and avoid
> + * type converting.
> + */
> +static inline int stop_timer(struct timer *t)
> +{
> + time_t end;
> +
> + time(&end);
> +
> + return (int)(difftime(end, t->start));
> +}
> #endif
> --
> 2.14.1
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
prev parent reply other threads:[~2017-09-18 1:46 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-09-18 0:47 [PATCH v2] btrfs-progs: Output time elapsed for each major tree it checked Qu Wenruo
2017-09-18 1:47 ` Satoru Takeuchi [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=874ls0aicr.wl-satoru.takeuchi@gmail.com \
--to=satoru.takeuchi@gmail.com \
--cc=dsterba@suse.cz \
--cc=linux-btrfs@vger.kernel.org \
--cc=quwenruo.btrfs@gmx.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).