From: "J. Bruce Fields" <bfields@fieldses.org>
To: Neil Brown <neilb@suse.de>
Cc: linux-nfs@vger.kernel.org
Subject: Re: [PATCH 2/2] sunrpc: use monotonic time in expiry cache
Date: Wed, 25 Aug 2010 12:09:48 -0400 [thread overview]
Message-ID: <20100825160948.GC14440@fieldses.org> (raw)
In-Reply-To: <20100825091226.5a68986d@notabene>
On Wed, Aug 25, 2010 at 09:12:26AM +1000, Neil Brown wrote:
> Yes.... I think I developed this against 2.6.16 which has different naming
> conventions, and then forward-parted to -current without giving too much
> thought to the names. seconds_since_boot() does sound better.
>
> >
> > Oh, and
> >
> > get_seconds() - monotonic_seconds()
> >
> > isn't the most intuitive way possible to say "boot time in seconds". If
> > you want to fix either of those, fine, otherwise no big deal.)
>
> To be fair, I don't use that exactly. I use
>
> some_monotonic_based_value - monotonic_seconds() + get_seconds()
>
> to turn a monotonic_based value to a wallclock based value.
> This makes sense to me - subtract the base I don't want, and add the base
> that I do.
Sure....
> I guess you could wrap that in convert_to_wallclock and use getboottime
> directly:
>
> static inline time_t convert_to_wallclock(time_t sinceboot)
> {
> struct timespec boot;
> getboottime(&boot);
> return sinceboot + boot.tv_sec;
> }
.... But I think that makes the calculation truly, blindingly obvious.
> Following is only compile tested.
Merged into the previous patch (not pushed out yet pending some
testing). Thanks!
--b.
>
> Thanks,
> NeilBrown
>
> -------
>
> Rename monotonic_seconds to seconds_since_boot
>
> monotonic has a meaning in Linux timekeeping slight different to what we
> use in sunrpc_cache, so change the name.
>
> Also make the conversion from second_since_boot times to wallclock times less
> obscure.
>
> Signed-off-by: NeilBrown <neilb@suse.de>
>
> diff --git a/fs/nfs/dns_resolve.c b/fs/nfs/dns_resolve.c
> index 3e6aab2..97c03ca 100644
> --- a/fs/nfs/dns_resolve.c
> +++ b/fs/nfs/dns_resolve.c
> @@ -144,7 +144,7 @@ static int nfs_dns_show(struct seq_file *m, struct cache_detail *cd,
> return 0;
> }
> item = container_of(h, struct nfs_dns_ent, h);
> - ttl = item->h.expiry_time - monotonic_seconds();
> + ttl = item->h.expiry_time - seconds_since_boot();
> if (ttl < 0)
> ttl = 0;
>
> @@ -216,7 +216,7 @@ static int nfs_dns_parse(struct cache_detail *cd, char *buf, int buflen)
> ttl = get_expiry(&buf);
> if (ttl == 0)
> goto out;
> - key.h.expiry_time = ttl + monotonic_seconds();
> + key.h.expiry_time = ttl + seconds_since_boot();
>
> ret = -ENOMEM;
> item = nfs_dns_lookup(cd, &key);
> @@ -278,7 +278,7 @@ static int do_cache_lookup_nowait(struct cache_detail *cd,
> goto out_err;
> ret = -ETIMEDOUT;
> if (!test_bit(CACHE_VALID, &(*item)->h.flags)
> - || (*item)->h.expiry_time < monotonic_seconds()
> + || (*item)->h.expiry_time < seconds_since_boot()
> || cd->flush_time > (*item)->h.last_refresh)
> goto out_put;
> ret = -ENOENT;
> diff --git a/fs/nfsd/nfs4idmap.c b/fs/nfsd/nfs4idmap.c
> index 6031a90..808b33a 100644
> --- a/fs/nfsd/nfs4idmap.c
> +++ b/fs/nfsd/nfs4idmap.c
> @@ -550,7 +550,7 @@ do_idmap_lookup_nowait(struct ent *(*lookup_fn)(struct ent *),
> goto out_err;
> ret = -ETIMEDOUT;
> if (!test_bit(CACHE_VALID, &(*item)->h.flags)
> - || (*item)->h.expiry_time < monotonic_seconds()
> + || (*item)->h.expiry_time < seconds_since_boot()
> || detail->flush_time > (*item)->h.last_refresh)
> goto out_put;
> ret = -ENOENT;
> diff --git a/include/linux/sunrpc/cache.h b/include/linux/sunrpc/cache.h
> index df7c19b..ece432b 100644
> --- a/include/linux/sunrpc/cache.h
> +++ b/include/linux/sunrpc/cache.h
> @@ -223,13 +223,20 @@ static inline int get_int(char **bpp, int *anint)
> * since boot. This is the best for measuring differences in
> * real time.
> */
> -static inline time_t monotonic_seconds(void)
> +static inline time_t seconds_since_boot(void)
> {
> struct timespec boot;
> getboottime(&boot);
> return get_seconds() - boot.tv_sec;
> }
>
> +static inline time_t convert_to_wallclock(time_t sinceboot)
> +{
> + struct timespec boot;
> + getboottime(&boot);
> + return boot.tv_sec + sinceboot;
> +}
> +
> static inline time_t get_expiry(char **bpp)
> {
> int rv;
> @@ -246,7 +253,7 @@ static inline time_t get_expiry(char **bpp)
> static inline void sunrpc_invalidate(struct cache_head *h,
> struct cache_detail *detail)
> {
> - h->expiry_time = monotonic_seconds() - 1;
> - detail->nextcheck = monotonic_seconds();
> + h->expiry_time = seconds_since_boot() - 1;
> + detail->nextcheck = seconds_since_boot();
> }
> #endif /* _LINUX_SUNRPC_CACHE_H_ */
> diff --git a/net/sunrpc/cache.c b/net/sunrpc/cache.c
> index 99d852e..8dc1219 100644
> --- a/net/sunrpc/cache.c
> +++ b/net/sunrpc/cache.c
> @@ -42,7 +42,7 @@ static void cache_revisit_request(struct cache_head *item);
>
> static void cache_init(struct cache_head *h)
> {
> - time_t now = monotonic_seconds();
> + time_t now = seconds_since_boot();
> h->next = NULL;
> h->flags = 0;
> kref_init(&h->ref);
> @@ -52,7 +52,7 @@ static void cache_init(struct cache_head *h)
>
> static inline int cache_is_expired(struct cache_detail *detail, struct cache_head *h)
> {
> - return (h->expiry_time < monotonic_seconds()) ||
> + return (h->expiry_time < seconds_since_boot()) ||
> (detail->flush_time > h->last_refresh);
> }
>
> @@ -127,7 +127,7 @@ static void cache_dequeue(struct cache_detail *detail, struct cache_head *ch);
> static void cache_fresh_locked(struct cache_head *head, time_t expiry)
> {
> head->expiry_time = expiry;
> - head->last_refresh = monotonic_seconds();
> + head->last_refresh = seconds_since_boot();
> set_bit(CACHE_VALID, &head->flags);
> }
>
> @@ -238,7 +238,7 @@ int cache_check(struct cache_detail *detail,
>
> /* now see if we want to start an upcall */
> refresh_age = (h->expiry_time - h->last_refresh);
> - age = monotonic_seconds() - h->last_refresh;
> + age = seconds_since_boot() - h->last_refresh;
>
> if (rqstp == NULL) {
> if (rv == -EAGAIN)
> @@ -253,7 +253,7 @@ int cache_check(struct cache_detail *detail,
> cache_revisit_request(h);
> if (rv == -EAGAIN) {
> set_bit(CACHE_NEGATIVE, &h->flags);
> - cache_fresh_locked(h, monotonic_seconds()+CACHE_NEW_EXPIRY);
> + cache_fresh_locked(h, seconds_since_boot()+CACHE_NEW_EXPIRY);
> cache_fresh_unlocked(h, detail);
> rv = -ENOENT;
> }
> @@ -388,11 +388,11 @@ static int cache_clean(void)
> return -1;
> }
> current_detail = list_entry(next, struct cache_detail, others);
> - if (current_detail->nextcheck > monotonic_seconds())
> + if (current_detail->nextcheck > seconds_since_boot())
> current_index = current_detail->hash_size;
> else {
> current_index = 0;
> - current_detail->nextcheck = monotonic_seconds()+30*60;
> + current_detail->nextcheck = seconds_since_boot()+30*60;
> }
> }
>
> @@ -477,7 +477,7 @@ EXPORT_SYMBOL_GPL(cache_flush);
> void cache_purge(struct cache_detail *detail)
> {
> detail->flush_time = LONG_MAX;
> - detail->nextcheck = monotonic_seconds();
> + detail->nextcheck = seconds_since_boot();
> cache_flush();
> detail->flush_time = 1;
> }
> @@ -902,7 +902,7 @@ static int cache_release(struct inode *inode, struct file *filp,
> filp->private_data = NULL;
> kfree(rp);
>
> - cd->last_close = monotonic_seconds();
> + cd->last_close = seconds_since_boot();
> atomic_dec(&cd->readers);
> }
> module_put(cd->owner);
> @@ -1034,7 +1034,7 @@ int sunrpc_cache_pipe_upcall(struct cache_detail *detail, struct cache_head *h,
> int len;
>
> if (atomic_read(&detail->readers) == 0 &&
> - detail->last_close < monotonic_seconds() - 30) {
> + detail->last_close < seconds_since_boot() - 30) {
> warn_no_listener(detail);
> return -EINVAL;
> }
> @@ -1219,7 +1219,7 @@ static int c_show(struct seq_file *m, void *p)
>
> ifdebug(CACHE)
> seq_printf(m, "# expiry=%ld refcnt=%d flags=%lx\n",
> - cp->expiry_time - monotonic_seconds() + get_seconds(),
> + convert_to_wallclock(cp->expiry_time),
> atomic_read(&cp->ref.refcount), cp->flags);
> cache_get(cp);
> if (cache_check(cd, cp, NULL))
> @@ -1286,8 +1286,7 @@ static ssize_t read_flush(struct file *file, char __user *buf,
> unsigned long p = *ppos;
> size_t len;
>
> - sprintf(tbuf, "%lu\n", (cd->flush_time - monotonic_seconds()
> - + get_seconds()));
> + sprintf(tbuf, "%lu\n", convert_to_wallclock(cd->flush_time));
> len = strlen(tbuf);
> if (p >= len)
> return 0;
> @@ -1318,7 +1317,7 @@ static ssize_t write_flush(struct file *file, const char __user *buf,
>
> bp = tbuf;
> cd->flush_time = get_expiry(&bp);
> - cd->nextcheck = monotonic_seconds();
> + cd->nextcheck = seconds_since_boot();
> cache_flush();
>
> *ppos += count;
next prev parent reply other threads:[~2010-08-25 16:09 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-08-12 6:55 [PATCH 0/2] Use monotonic time stamps in sunrpc auth cache NeilBrown
2010-08-12 6:55 ` [PATCH 2/2] sunrpc: use monotonic time in expiry cache NeilBrown
2010-08-24 18:15 ` J. Bruce Fields
2010-08-24 23:12 ` Neil Brown
2010-08-25 16:09 ` J. Bruce Fields [this message]
2010-08-12 6:55 ` [PATCH 1/2] sunrpc: extract some common sunrpc_cache code from nfsd NeilBrown
[not found] ` <20100812065522.3408.34827.stgit-bi+AKbBUZKY6gyzm1THtWbp2dZbC/Bob@public.gmane.org>
2010-08-20 22:18 ` J. Bruce Fields
-- strict thread matches above, loose matches on Subject: below --
2010-02-17 6:47 [PATCH 0/2] sunrpc: use monotonic time for expiry times NeilBrown
[not found] ` <20100217064330.13656.61404.stgit-wvvUuzkyo1EYVZTmpyfIwg@public.gmane.org>
2010-02-17 6:47 ` [PATCH 2/2] sunrpc: use monotonic time in expiry cache NeilBrown
[not found] ` <20100217064730.13656.67205.stgit-wvvUuzkyo1EYVZTmpyfIwg@public.gmane.org>
2010-02-17 22:00 ` Chuck Lever
2010-03-02 4:11 ` Neil Brown
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=20100825160948.GC14440@fieldses.org \
--to=bfields@fieldses.org \
--cc=linux-nfs@vger.kernel.org \
--cc=neilb@suse.de \
/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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.