linux-fsdevel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Jan Kara <jack@suse.cz>
To: Theodore Ts'o <tytso@mit.edu>
Cc: Jan Kara <jack@suse.cz>,
	Linus Torvalds <torvalds@linux-foundation.org>,
	linux-fsdevel <linux-fsdevel@vger.kernel.org>,
	Alexander Viro <viro@zeniv.linux.org.uk>
Subject: Re: Lazytime feature bugs
Date: Thu, 26 Feb 2015 15:38:28 +0100	[thread overview]
Message-ID: <20150226143828.GA21485@quack.suse.cz> (raw)
In-Reply-To: <20150226134553.GF11217@thunk.org>

On Thu 26-02-15 08:45:53, Ted Tso wrote:
> On Thu, Feb 26, 2015 at 09:34:55AM +0100, Jan Kara wrote:
> >   I don't think you can reset i_dirty_time_when to "now" in b) because in
> > that case continually dirtied files won't ever have timestamps written (you
> > are completely loosing track of when you last wrote timestamps to disk).
> 
> In the case of continually dirtied files, in my proposal we would be
> checking to see if i_dirty_time_when is older when we scan files in
> b_io, which means that we would discover files with stale timestamps
> on disk, and they would get written out.
  But you wrote you'll reset i_dirty_time_when to "now" when queueing into
b_dirty_time. Thus frequently dirtied inodes will just travel back and
forth between b_dirty and b_dirty_time lists and i_dirty_time will be
continuously reset. And you never end up writing it. That's why I suggested
to reset i_dirted_when instead (since it would be unused in b_dirty_time
list anyway).

> This was the same as (4) in your propsal:
> 
> 
> > 4) When processing inodes on b_io list we also check whether
> >    i_dirty_time_when is older than 12 hours. If so, we writeout inode.
> 
> But your mechanism would work as well; I preferred to keep
> i_dirty_when to only mean when the pages were dirtied, but the
> important thing is that we have to track when the timestamps were
> dirtied and when the pages were dirtied as separate things.

								Honza
-- 
Jan Kara <jack@suse.cz>
SUSE Labs, CR

  reply	other threads:[~2015-02-26 14:38 UTC|newest]

Thread overview: 14+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-02-18 13:19 Lazytime feature bugs Jan Kara
2015-02-24 18:31 ` Jan Kara
2015-02-24 18:58   ` Linus Torvalds
2015-02-25 14:52     ` Theodore Ts'o
2015-02-25 16:25       ` Jan Kara
2015-02-26  4:33         ` Theodore Ts'o
2015-02-26  8:34           ` Jan Kara
2015-02-26 13:45             ` Theodore Ts'o
2015-02-26 14:38               ` Jan Kara [this message]
2015-02-26 19:27                 ` Theodore Ts'o
2015-03-02  8:29                   ` Jan Kara
2015-03-07  5:34                     ` [PATCH] fs: make sure the timestamps for lazytime inodes eventually get written Theodore Ts'o
2015-03-08 10:06                       ` Jan Kara
2015-03-08 19:06                         ` Theodore Ts'o

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=20150226143828.GA21485@quack.suse.cz \
    --to=jack@suse.cz \
    --cc=linux-fsdevel@vger.kernel.org \
    --cc=torvalds@linux-foundation.org \
    --cc=tytso@mit.edu \
    --cc=viro@zeniv.linux.org.uk \
    /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).