linux-fsdevel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* Re: review: don't block non-blocking writes when frozen
       [not found]   ` <20070423231337.GN32602149@melbourne.sgi.com>
@ 2007-04-24 14:55     ` Christoph Hellwig
  0 siblings, 0 replies; only message in thread
From: Christoph Hellwig @ 2007-04-24 14:55 UTC (permalink / raw)
  To: David Chinner
  Cc: Christoph Hellwig, gnb, xfs-oss, linux-fsdevel, linux-kernel

On Tue, Apr 24, 2007 at 09:13:37AM +1000, David Chinner wrote:
> So, given the catch-22 you've just presented us can we revisit the
> nfsd non-blocking I/O issue again?  This affects anyone using DM
> snapshots on their NFS servers and has nothing to do with HSMs
> or DMAPI...
> 
> FWIW, you can still do non-blocking userspace I/O to a file, so this
> XFS patch is still valid for mainline (that's how I tested it).

I've been investigating the situation a little bit more, and here's
what's going on:

 - SuS allows for O_NONBLOCK on regular files as per
   http://www.opengroup.org/onlinepubs/007908799/xsh/write.html
 - actually implementing O_NONBLOCK semantics for regular fixes
   breaks userspace when poll/select claims files are ready to
   read/write but they aren't, see http://lkml.org/lkml/2004/10/17/17

So we can't really expose O_NONBLOCK on regular files to userspace,
and we need to make sure in common code this does not happen.

EJUKEBOX on snaphots does make sense, though.  Can you please send
a full patchseries for nfsd, the common code and the xfs writepath
so that this actually gets used and behaviour is consistant for all
(or at least most) filesystems?

Also now that the patch goes to mainline please kill ugly FILP_DELAY_FLAG
and just check the flags directly.  And it should probably only check
O_NONBLOCK.  The only architecture having O_NDELAY different from
O_NONBLOCK is sparc, and it already translates the value for us.




^ permalink raw reply	[flat|nested] only message in thread

only message in thread, other threads:[~2007-04-24 14:55 UTC | newest]

Thread overview: (only message) (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
     [not found] <20070423002616.GY32602149@melbourne.sgi.com>
     [not found] ` <20070423212715.GF13572@infradead.org>
     [not found]   ` <20070423231337.GN32602149@melbourne.sgi.com>
2007-04-24 14:55     ` review: don't block non-blocking writes when frozen Christoph Hellwig

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).