pNFS/flexfiles: track when layout is first used
authorPeng Tao <tao.peng@primarydata.com>
Tue, 23 Jun 2015 11:52:00 +0000 (19:52 +0800)
committerTrond Myklebust <trond.myklebust@primarydata.com>
Wed, 24 Jun 2015 14:53:10 +0000 (10:53 -0400)
So that we can report cumulative time since the beginning
of statistics collection of the layout.

Reviewed-by: Jeff Layton <jeff.layton@primarydata.com>
Signed-off-by: Peng Tao <tao.peng@primarydata.com>
Signed-off-by: Trond Myklebust <trond.myklebust@primarydata.com>
fs/nfs/flexfilelayout/flexfilelayout.c
fs/nfs/flexfilelayout/flexfilelayout.h

index 8ac31fbf040a6b1fe9666145693c3cbaed25dc02..4215278c9c76ece5e348b75b39bf7b6454ea26fb 100644 (file)
@@ -451,9 +451,13 @@ nfs4_ff_layout_calc_completion_time(struct rpc_task *task)
 }
 
 static void
-nfs4_ff_layoutstat_start_io(struct nfs4_ff_layoutstat *layoutstat)
+nfs4_ff_layoutstat_start_io(struct nfs4_ff_layout_mirror *mirror,
+                           struct nfs4_ff_layoutstat *layoutstat)
 {
+       static const ktime_t notime = {0};
+
        nfs4_ff_start_busy_timer(&layoutstat->busy_timer);
+       cmpxchg(&mirror->start_time, notime, ktime_get());
 }
 
 static void
@@ -491,7 +495,7 @@ nfs4_ff_layout_stat_io_start_read(struct nfs4_ff_layout_mirror *mirror,
                __u64 requested)
 {
        spin_lock(&mirror->lock);
-       nfs4_ff_layoutstat_start_io(&mirror->read_stat);
+       nfs4_ff_layoutstat_start_io(mirror, &mirror->read_stat);
        nfs4_ff_layout_stat_io_update_requested(&mirror->read_stat, requested);
        spin_unlock(&mirror->lock);
 }
@@ -514,7 +518,7 @@ nfs4_ff_layout_stat_io_start_write(struct nfs4_ff_layout_mirror *mirror,
                __u64 requested)
 {
        spin_lock(&mirror->lock);
-       nfs4_ff_layoutstat_start_io(&mirror->write_stat);
+       nfs4_ff_layoutstat_start_io(mirror, &mirror->write_stat);
        nfs4_ff_layout_stat_io_update_requested(&mirror->write_stat, requested);
        spin_unlock(&mirror->lock);
 }
index f7493f7cf13c44bcbf39c9a0bd66db9ae63fc9d6..0e7366f44d1128551bc6cac16d1fa427ba5803b4 100644 (file)
@@ -74,6 +74,7 @@ struct nfs4_ff_layout_mirror {
        spinlock_t                      lock;
        struct nfs4_ff_layoutstat       read_stat;
        struct nfs4_ff_layoutstat       write_stat;
+       ktime_t                         start_time;
 };
 
 struct nfs4_ff_layout_segment {