From: Andreas Rohner <andreas.rohner-hi6Y0CQ0nG0@public.gmane.org>
To: Ryusuke Konishi
<konishi.ryusuke-Zyj7fXuS5i5L9jVzuh4AOg@public.gmane.org>
Cc: linux-nilfs <linux-nilfs-u79uwXL29TY76Z2rM5mHXA@public.gmane.org>
Subject: Re: [PATCH v4 5/6] nilfs-utils: add optimized version of nilfs_xreclaim_segments
Date: Thu, 06 Feb 2014 01:09:25 +0100 [thread overview]
Message-ID: <52F2D2B5.1080109@gmx.net> (raw)
In-Reply-To: <f5be23fa1b72d7e7e2d1403bdd043ebeafd4407d.1391566347.git.andreas.rohner-hi6Y0CQ0nG0@public.gmane.org>
Hi Ryusuke,
On 2014-02-05 03:16, Andreas Rohner wrote:
> This patch adds an additional parameter min_reclaimable_blks to
> the nilfs_reclaim_params structure. This parameter specifies the
> minimum number of reclaimable blocks in a segment, before it can be
> cleaned. If a segment is below this threshold, it is considered to
> be not worth cleaning, because all the live blocks would need to be
> moved to a new segment, which is expensive, and the number of
> reclaimable blocks is too low. But it is still necessary to update
> the segment usage information to turn the old segment into a new
> one.
>
> This is basically a shortcut to cleaning the segment. It is still
> necessary to read the segment summary information, but the writing
> of the live blocks can be skipped if it's not worth it.
>
> This optimization can be enabled and disabled by the
> use_set_suinfo switch in the configuration file. If the kernel
> doesn't support the set_suinfo ioctl it returns the error
> number ENOTTY, which also permanently disables the optimization.
>
> Signed-off-by: Andreas Rohner <andreas.rohner-hi6Y0CQ0nG0@public.gmane.org>
> ---
> include/nilfs_gc.h | 7 +++---
> lib/gc.c | 63 +++++++++++++++++++++++++++++++++++++++++++++---
> sbin/cleanerd/cleanerd.c | 18 +++++++++++---
> 3 files changed, 77 insertions(+), 11 deletions(-)
>
> diff --git a/include/nilfs_gc.h b/include/nilfs_gc.h
> index e49cbf4..1196c55 100644
> --- a/include/nilfs_gc.h
> +++ b/include/nilfs_gc.h
> @@ -17,18 +17,19 @@
> /* flags for nilfs_reclaim_params struct */
> #define NILFS_RECLAIM_PARAM_PROTSEQ (1UL << 0)
> #define NILFS_RECLAIM_PARAM_PROTCNO (1UL << 1)
> -#define __NR_NILFS_RECLAIM_PARAMS 2
> +#define NILFS_RECLAIM_PARAM_DEFERRABLE (1UL << 2)
> +#define __NR_NILFS_RECLAIM_PARAMS 3
>
> /**
> * struct nilfs_reclaim_params - structure to specify GC parameters
> * @flags: flags of valid fields
> - * @reserved: padding bytes
> + * @min_reclaimable_blks: minimum number of reclaimable blocks
> * @protseq: start of sequence number of protected segments
> * @protcno: start number of checkpoint to be protected
> */
> struct nilfs_reclaim_params {
> unsigned long flags;
> - unsigned long reserved;
> + unsigned long min_reclaimable_blks;
> __u64 protseq;
> nilfs_cno_t protcno;
> };
> diff --git a/lib/gc.c b/lib/gc.c
> index 71c7307..4aa6a2c 100644
> --- a/lib/gc.c
> +++ b/lib/gc.c
> @@ -29,6 +29,10 @@
> #include <syslog.h>
> #endif /* HAVE_SYSLOG_H */
>
> +#if HAVE_SYS_TIME_H
> +#include <sys/time.h>
> +#endif /* HAVE_SYS_TIME */
> +
> #include <errno.h>
> #include <assert.h>
> #include <stdarg.h>
> @@ -617,8 +621,11 @@ int nilfs_xreclaim_segment(struct nilfs *nilfs,
> struct nilfs_vector *vdescv, *bdescv, *periodv, *vblocknrv;
> sigset_t sigset, oldset, waitset;
> nilfs_cno_t protcno;
> - ssize_t n, ret = -1;
> + ssize_t n, i, ret = -1;
> size_t nblocks;
> + __u32 reclaimable_blocks;
> + struct nilfs_suinfo_update *supv;
> + struct timeval tv;
>
> if (!(params->flags & NILFS_RECLAIM_PARAM_PROTSEQ) ||
> (params->flags & (~0UL << __NR_NILFS_RECLAIM_PARAMS))) {
> @@ -703,13 +710,16 @@ int nilfs_xreclaim_segment(struct nilfs *nilfs,
> if (ret < 0)
> goto out_lock;
>
> + reclaimable_blocks = (nilfs_get_blocks_per_segment(nilfs) * n) -
> + (nilfs_vector_get_size(vdescv) +
> + nilfs_vector_get_size(bdescv));
> +
> if (stat) {
> stat->live_pblks = nilfs_vector_get_size(bdescv);
> stat->defunct_pblks = nblocks - stat->live_pblks;
>
> stat->live_blks = stat->live_vblks + stat->live_pblks;
> - stat->defunct_blks = n * nilfs_get_blocks_per_segment(nilfs) -
> - stat->live_blks;
> + stat->defunct_blks = reclaimable_blocks;
> }
> if (dryrun)
> goto out_lock;
> @@ -725,6 +735,51 @@ int nilfs_xreclaim_segment(struct nilfs *nilfs,
> goto out_lock;
> }
>
> + /* if there are less reclaimable blocks than the
> + * minimal threshold try to update suinfo
> + * instead of cleaning */
> + if ((params->flags & NILFS_RECLAIM_PARAM_DEFERRABLE) &&
> + reclaimable_blocks < params->min_reclaimable_blks * n) {
> + if (stat)
> + stat->deferred_segs = n;
> +
> + ret = gettimeofday(&tv, NULL);
> + if (ret < 0)
> + goto out_lock;
> +
> + supv = malloc(sizeof(struct nilfs_suinfo_update) * n);
> + if (supv == NULL) {
> + ret = -1;
> + goto out_lock;
> + }
I have already changed nilfs_xreclaim_segments to use
nilfs_vector_create for supv instead of malloc and free directly. Don't
know why I originally used malloc, since the rest of the function uses
the nilfs_vector API.
Regards,
Andreas Rohner
--
To unsubscribe from this list: send the line "unsubscribe linux-nilfs" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
next prev parent reply other threads:[~2014-02-06 0:09 UTC|newest]
Thread overview: 23+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-02-04 18:37 [PATCH 0/2] refactor reclaim function Ryusuke Konishi
[not found] ` <1391539046-13046-1-git-send-email-konishi.ryusuke-Zyj7fXuS5i5L9jVzuh4AOg@public.gmane.org>
2014-02-04 18:37 ` [PATCH 1/2] lib/gc.c: " Ryusuke Konishi
2014-02-04 18:37 ` [PATCH 2/2] cleanerd: use nilfs_xreclaim_segment() Ryusuke Konishi
2014-02-04 18:42 ` [PATCH 0/2] refactor reclaim function Ryusuke Konishi
[not found] ` <20140205.034242.281476472.konishi.ryusuke-Zyj7fXuS5i5L9jVzuh4AOg@public.gmane.org>
2014-02-04 20:46 ` Andreas Rohner
2014-02-05 2:16 ` [PATCH v4 0/6] nilfs-utils: shortcut for certain GC operations Andreas Rohner
[not found] ` <cover.1391566347.git.andreas.rohner-hi6Y0CQ0nG0@public.gmane.org>
2014-02-05 2:16 ` [PATCH v4 1/6] nilfs-utils: cldconfig add an option to set min. reclaimable blocks Andreas Rohner
[not found] ` <ede3809c3f131ed641336d7a078c4dc1d9d4b578.1391566347.git.andreas.rohner-hi6Y0CQ0nG0@public.gmane.org>
2014-02-05 18:47 ` Ryusuke Konishi
2014-02-05 2:16 ` [PATCH v4 2/6] nilfs-utils: add NILFS_OPT_SET_SUINFO Andreas Rohner
[not found] ` <a55d555da27aea71386cfe777a0adec95e6ded2e.1391566347.git.andreas.rohner-hi6Y0CQ0nG0@public.gmane.org>
2014-02-05 18:50 ` Ryusuke Konishi
2014-02-05 2:16 ` [PATCH v4 3/6] nilfs-utils: nilfs-clean add cmdline param min-reclaimable-blocks Andreas Rohner
[not found] ` <9004dd6e3a276447371eda93413a6f0766821510.1391566347.git.andreas.rohner-hi6Y0CQ0nG0@public.gmane.org>
2014-02-05 19:16 ` Ryusuke Konishi
2014-02-05 2:16 ` [PATCH v4 4/6] nilfs-utils: add suport for NILFS_IOCTL_SET_SUINFO ioctl Andreas Rohner
[not found] ` <6b62cd72448c48055cfab9017753349cb2cd7da9.1391566347.git.andreas.rohner-hi6Y0CQ0nG0@public.gmane.org>
2014-02-05 19:25 ` Ryusuke Konishi
[not found] ` <20140206.042518.139122814.konishi.ryusuke-Zyj7fXuS5i5L9jVzuh4AOg@public.gmane.org>
2014-02-05 23:43 ` Andreas Rohner
[not found] ` <52F2CC85.3000004-hi6Y0CQ0nG0@public.gmane.org>
2014-02-06 0:04 ` Ryusuke Konishi
2014-02-05 2:16 ` [PATCH v4 5/6] nilfs-utils: add optimized version of nilfs_xreclaim_segments Andreas Rohner
[not found] ` <f5be23fa1b72d7e7e2d1403bdd043ebeafd4407d.1391566347.git.andreas.rohner-hi6Y0CQ0nG0@public.gmane.org>
2014-02-06 0:09 ` Andreas Rohner [this message]
[not found] ` <52F2D2B5.1080109-hi6Y0CQ0nG0@public.gmane.org>
2014-02-06 0:24 ` Ryusuke Konishi
2014-02-05 2:16 ` [PATCH v4 6/6] nilfs-utils: add a no_timeout flag to enable faster loop Andreas Rohner
[not found] ` <43f9673512b7a2e95d3036f2e829aa80fb2cca03.1391566347.git.andreas.rohner-hi6Y0CQ0nG0@public.gmane.org>
2014-02-06 1:16 ` Ryusuke Konishi
[not found] ` <20140206.101641.184822830.konishi.ryusuke-Zyj7fXuS5i5L9jVzuh4AOg@public.gmane.org>
2014-02-06 14:37 ` Andreas Rohner
[not found] ` <52F39E20.8000803-hi6Y0CQ0nG0@public.gmane.org>
2014-02-06 15:07 ` Andreas Rohner
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=52F2D2B5.1080109@gmx.net \
--to=andreas.rohner-hi6y0cq0ng0@public.gmane.org \
--cc=konishi.ryusuke-Zyj7fXuS5i5L9jVzuh4AOg@public.gmane.org \
--cc=linux-nilfs-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
/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