[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <alpine.LFD.2.00.0903251337410.3032@localhost.localdomain>
Date: Wed, 25 Mar 2009 13:40:37 -0700 (PDT)
From: Linus Torvalds <torvalds@...ux-foundation.org>
To: Jeff Garzik <jeff@...zik.org>
cc: Theodore Tso <tytso@....edu>, Ingo Molnar <mingo@...e.hu>,
Alan Cox <alan@...rguk.ukuu.org.uk>,
Arjan van de Ven <arjan@...radead.org>,
Andrew Morton <akpm@...ux-foundation.org>,
Peter Zijlstra <a.p.zijlstra@...llo.nl>,
Nick Piggin <npiggin@...e.de>, David Rees <drees76@...il.com>,
Jesper Krogh <jesper@...gh.cc>,
Linux Kernel Mailing List <linux-kernel@...r.kernel.org>
Subject: Re: Linux 2.6.29
On Wed, 25 Mar 2009, Jeff Garzik wrote:
>
> It is clearly possible to implement an fsync(2) that causes FLUSH CACHE to be
> issued, without adding full barrier support to a filesystem. It is likely
> doable to avoid touching per-filesystem code at all, if we issue the flush
> from a generic fsync(2) code path in the kernel.
We could easily do that. It would even work for most cases. The
problematic ones are where filesystems do their own disk management, but I
guess those people can do their own fsync() management too.
Somebody send me the patch, we can try it out.
> Remember, fsync(2) means that the user _expects_ a performance hit.
Within reason, though.
OS X, for example, doesn't do the disk barrier. It requires you to do a
separate FULL_FSYNC (or something similar) ioctl to get that. Apparently
exactly because users don't expect quite _that_ big of a performance hit.
(Or maybe just because it was easier to do that way. Never attribute to
malice what can be sufficiently explained by stupidity).
Linus
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists