All of lore.kernel.org
 help / color / mirror / Atom feed
From: Theodore Tso <tytso@mit.edu>
To: Jamie Lokier <jamie@shareable.org>
Cc: linux-fsdevel@vger.kernel.org, jmorris@namei.org,
	ocfs2-devel@oss.oracle.com, viro@zeniv.linux.org.uk
Subject: [Ocfs2-devel] [PATCH 1/3] fs: Document the reflink(2) system call.
Date: Tue, 5 May 2009 10:21:02 -0400	[thread overview]
Message-ID: <20090505142102.GE17486@mit.edu> (raw)
In-Reply-To: <20090505131907.GF25328@shareable.org>

On Tue, May 05, 2009 at 02:19:07PM +0100, Jamie Lokier wrote:
> There was an attempt at something like that for ext3 a year or two ago.
> Search for "cowlink" if you're interested.

Yeah, I remember that discussion.  The hard part was always the VM
infrastructure, not the fs metadata.

> Instead of a circular list, a proposed implementation was to create a
> separate "host" inode on the first reflink, converting the source
> inode to a reflink inode and moving the data block references to the
> new host inode.  Each reflink was simply a reference to the host
> inode, much like your design, and the host inode was only to hold the
> data blocks, with it's i_nlink counting the number of reflinks
> pointing to it.
> 
> Using a circular list means the space must be reserved in every inode,
> even those which are not (yet) reflinks.  It also does a bit more
> writing sometimes, because of having to update next and previous
> entries on the list.

It's a tradeoff.  If you use a separate "host" inode on the first
reflink, then then if you burn 3 inodes instead of two for which is
"copied"/"reflinked" once.  The only reason why we need to reserve an
extra field in the inode structure is for the pointer from the "host"
inode to the circular linked list.  (The space for the circular linked
list gets stored in i_data in the reflink inodes.)  If we are using
256 byte inodes we have the space to spare --- and if we really cared
about not utilizing the space in the inode structure if it wasn't
necessary, it could always be stored as an extended attribute
(although that has a greater overhead).

The question of which of these design tradeoffs is preferable is
really one of how many inodes will get copied via reflinks, and how
many times will a particular inode will be copied by a reflink.  If it
is common (for example, in a virtualization or container workload) for
a single file to be copied via reflink 50 or 100 times, then the extra
inode created when you create the first reflink is no big deal.  If
most of the time a file is only going to be reflink'ed once or twice,
then the overhead is much bigger.

This is really a design detail, though.

The bigger questions, which we really need to answer are:

1) If someone other than the owner of a file uses reflink to "make a
copy" of the file, is it new inode, with the new inode number, owned
by the original owner (making it look more like a link), or owned by
the person creating the reflink (making it look more like a copy).

2) Does changing the metadata --- atime, user/group ownership, ctime,
etc., break the COW link and cause a copy?

(2) could be a per-filesystem implementation detail, but (1) goes to
the semantics of the how the reflink() system call will work, so I
think we need to have a common answer which is the same across all
filesystems.  

Maybe some filesystems could simply refuse to support a user who isn't
the owner creating a reflink, but saying that some filesystems might
CAP_FOWNER (because the inode will be created with owner of the uid)
would still mean that in the case where you had a setuid binary, or if
the system supports fine-grained capability support, so a user with a
non-zero UID has CAP_FOWNER, it would be unfortunate if a file owned
by uid 23, when copied via reflink by uid 45 with CAP_FOWNER privs, on
some filesystems creates a reflinked inode which when stat'ed, st_uid
is 23, and on other filesystems creates a reflink inode which when
stat'ed, st_uid is 45.

							- Ted

WARNING: multiple messages have this Message-ID (diff)
From: Theodore Tso <tytso@mit.edu>
To: Jamie Lokier <jamie@shareable.org>
Cc: linux-fsdevel@vger.kernel.org, jmorris@namei.org,
	ocfs2-devel@oss.oracle.com, viro@zeniv.linux.org.uk
Subject: Re: [PATCH 1/3] fs: Document the reflink(2) system call.
Date: Tue, 5 May 2009 10:21:02 -0400	[thread overview]
Message-ID: <20090505142102.GE17486@mit.edu> (raw)
In-Reply-To: <20090505131907.GF25328@shareable.org>

On Tue, May 05, 2009 at 02:19:07PM +0100, Jamie Lokier wrote:
> There was an attempt at something like that for ext3 a year or two ago.
> Search for "cowlink" if you're interested.

Yeah, I remember that discussion.  The hard part was always the VM
infrastructure, not the fs metadata.

> Instead of a circular list, a proposed implementation was to create a
> separate "host" inode on the first reflink, converting the source
> inode to a reflink inode and moving the data block references to the
> new host inode.  Each reflink was simply a reference to the host
> inode, much like your design, and the host inode was only to hold the
> data blocks, with it's i_nlink counting the number of reflinks
> pointing to it.
> 
> Using a circular list means the space must be reserved in every inode,
> even those which are not (yet) reflinks.  It also does a bit more
> writing sometimes, because of having to update next and previous
> entries on the list.

It's a tradeoff.  If you use a separate "host" inode on the first
reflink, then then if you burn 3 inodes instead of two for which is
"copied"/"reflinked" once.  The only reason why we need to reserve an
extra field in the inode structure is for the pointer from the "host"
inode to the circular linked list.  (The space for the circular linked
list gets stored in i_data in the reflink inodes.)  If we are using
256 byte inodes we have the space to spare --- and if we really cared
about not utilizing the space in the inode structure if it wasn't
necessary, it could always be stored as an extended attribute
(although that has a greater overhead).

The question of which of these design tradeoffs is preferable is
really one of how many inodes will get copied via reflinks, and how
many times will a particular inode will be copied by a reflink.  If it
is common (for example, in a virtualization or container workload) for
a single file to be copied via reflink 50 or 100 times, then the extra
inode created when you create the first reflink is no big deal.  If
most of the time a file is only going to be reflink'ed once or twice,
then the overhead is much bigger.

This is really a design detail, though.

The bigger questions, which we really need to answer are:

1) If someone other than the owner of a file uses reflink to "make a
copy" of the file, is it new inode, with the new inode number, owned
by the original owner (making it look more like a link), or owned by
the person creating the reflink (making it look more like a copy).

2) Does changing the metadata --- atime, user/group ownership, ctime,
etc., break the COW link and cause a copy?

(2) could be a per-filesystem implementation detail, but (1) goes to
the semantics of the how the reflink() system call will work, so I
think we need to have a common answer which is the same across all
filesystems.  

Maybe some filesystems could simply refuse to support a user who isn't
the owner creating a reflink, but saying that some filesystems might
CAP_FOWNER (because the inode will be created with owner of the uid)
would still mean that in the case where you had a setuid binary, or if
the system supports fine-grained capability support, so a user with a
non-zero UID has CAP_FOWNER, it would be unfortunate if a file owned
by uid 23, when copied via reflink by uid 45 with CAP_FOWNER privs, on
some filesystems creates a reflinked inode which when stat'ed, st_uid
is 23, and on other filesystems creates a reflink inode which when
stat'ed, st_uid is 45.

							- Ted

  parent reply	other threads:[~2009-05-05 14:21 UTC|newest]

Thread overview: 304+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-05-03  6:15 [Ocfs2-devel] [RFC] The reflink(2) system call Joel Becker
2009-05-03  6:15 ` Joel Becker
2009-05-03  6:15 ` [Ocfs2-devel] [PATCH 1/3] fs: Document the " Joel Becker
2009-05-03  6:15   ` Joel Becker
2009-05-03  8:01   ` [Ocfs2-devel] " Christoph Hellwig
2009-05-03  8:01     ` Christoph Hellwig
2009-05-04  2:46     ` [Ocfs2-devel] " Joel Becker
2009-05-04  2:46       ` Joel Becker
2009-05-04  6:36       ` [Ocfs2-devel] " Michael Kerrisk
2009-05-04  6:36         ` Michael Kerrisk
2009-05-04  7:12         ` [Ocfs2-devel] " Joel Becker
2009-05-04  7:12           ` Joel Becker
2009-05-03 13:08   ` [Ocfs2-devel] " Boaz Harrosh
2009-05-03 13:08     ` Boaz Harrosh
2009-05-03 23:08     ` [Ocfs2-devel] " Al Viro
2009-05-03 23:08       ` Al Viro
2009-05-04  2:49     ` [Ocfs2-devel] " Joel Becker
2009-05-04  2:49       ` Joel Becker
2009-05-03 23:45   ` [Ocfs2-devel] " Theodore Tso
2009-05-03 23:45     ` Theodore Tso
2009-05-04  1:44     ` [Ocfs2-devel] " Tao Ma
2009-05-04  1:44       ` Tao Ma
2009-05-04 18:25       ` [Ocfs2-devel] " Joel Becker
2009-05-04 18:25         ` Joel Becker
2009-05-04 21:18         ` [Ocfs2-devel] " Joel Becker
2009-05-04 21:18           ` Joel Becker
2009-05-04 22:23           ` Theodore Tso
2009-05-04 22:23             ` Theodore Tso
2009-05-05  6:55             ` Joel Becker
2009-05-05  6:55               ` Joel Becker
2009-05-05  1:07   ` Jamie Lokier
2009-05-05  1:07     ` Jamie Lokier
2009-05-05  7:16     ` [Ocfs2-devel] " Joel Becker
2009-05-05  7:16       ` Joel Becker
2009-05-05  8:09       ` [Ocfs2-devel] " Andreas Dilger
2009-05-05  8:09         ` Andreas Dilger
2009-05-05 16:56         ` [Ocfs2-devel] " Joel Becker
2009-05-05 16:56           ` Joel Becker
2009-05-05 21:24           ` [Ocfs2-devel] " Andreas Dilger
2009-05-05 21:24             ` Andreas Dilger
2009-05-05 21:32             ` [Ocfs2-devel] " Joel Becker
2009-05-05 21:32               ` Joel Becker
2009-05-06  7:15               ` [Ocfs2-devel] " Theodore Tso
2009-05-06  7:15                 ` Theodore Tso
2009-05-06 14:24                 ` jim owens
2009-05-06 14:24                   ` jim owens
2009-05-06 14:30                   ` jim owens
2009-05-06 14:30                     ` jim owens
2009-05-06 17:50                     ` jim owens
2009-05-06 17:50                       ` jim owens
2009-05-12 19:20                       ` Jamie Lokier
2009-05-12 19:20                         ` Jamie Lokier
2009-05-12 19:30                       ` Jamie Lokier
2009-05-12 19:30                         ` Jamie Lokier
2009-05-12 19:11                   ` Jamie Lokier
2009-05-12 19:11                     ` Jamie Lokier
2009-05-12 19:37                     ` jim owens
2009-05-12 19:37                       ` jim owens
2009-05-12 20:11                       ` Jamie Lokier
2009-05-12 20:11                         ` Jamie Lokier
2009-05-05 13:01       ` Theodore Tso
2009-05-05 13:01         ` Theodore Tso
2009-05-05 13:19         ` [Ocfs2-devel] " Jamie Lokier
2009-05-05 13:19           ` Jamie Lokier
2009-05-05 13:39           ` [Ocfs2-devel] " Chris Mason
2009-05-05 13:39             ` Chris Mason
2009-05-05 15:36             ` [Ocfs2-devel] " Jamie Lokier
2009-05-05 15:36               ` Jamie Lokier
2009-05-05 15:41               ` [Ocfs2-devel] " Chris Mason
2009-05-05 15:41                 ` Chris Mason
2009-05-05 16:03                 ` [Ocfs2-devel] " Jamie Lokier
2009-05-05 16:03                   ` Jamie Lokier
2009-05-05 16:18                   ` [Ocfs2-devel] " Chris Mason
2009-05-05 16:18                     ` Chris Mason
2009-05-05 20:48                   ` [Ocfs2-devel] " jim owens
2009-05-05 20:48                     ` jim owens
2009-05-05 21:57                     ` [Ocfs2-devel] " Jamie Lokier
2009-05-05 21:57                       ` Jamie Lokier
2009-05-05 22:04                       ` [Ocfs2-devel] " Joel Becker
2009-05-05 22:04                         ` Joel Becker
2009-05-05 22:11                         ` [Ocfs2-devel] " Jamie Lokier
2009-05-05 22:11                           ` Jamie Lokier
2009-05-05 22:24                           ` [Ocfs2-devel] " Joel Becker
2009-05-05 22:24                             ` Joel Becker
2009-05-05 23:14                             ` [Ocfs2-devel] " Jamie Lokier
2009-05-05 23:14                               ` Jamie Lokier
2009-05-05 22:12                         ` [Ocfs2-devel] " Jamie Lokier
2009-05-05 22:12                           ` Jamie Lokier
2009-05-05 22:21                           ` [Ocfs2-devel] " Joel Becker
2009-05-05 22:21                             ` Joel Becker
2009-05-05 22:32                             ` [Ocfs2-devel] " James Morris
2009-05-05 22:32                               ` James Morris
2009-05-05 22:39                               ` [Ocfs2-devel] " Joel Becker
2009-05-05 22:39                                 ` Joel Becker
2009-05-12 19:40                               ` [Ocfs2-devel] " Jamie Lokier
2009-05-12 19:40                                 ` Jamie Lokier
2009-05-05 22:28                         ` [Ocfs2-devel] " jim owens
2009-05-05 22:28                           ` jim owens
2009-05-05 23:12                           ` [Ocfs2-devel] " Jamie Lokier
2009-05-05 23:12                             ` Jamie Lokier
2009-05-05 16:46               ` [Ocfs2-devel] " Jörn Engel
2009-05-05 16:46                 ` Jörn Engel
2009-05-05 16:54                 ` [Ocfs2-devel] " Jörn Engel
2009-05-05 16:54                   ` Jörn Engel
2009-05-05 22:03                   ` [Ocfs2-devel] " Jamie Lokier
2009-05-05 22:03                     ` Jamie Lokier
2009-05-05 21:44                 ` [Ocfs2-devel] copyfile semantics Andreas Dilger
2009-05-05 21:44                   ` Andreas Dilger
2009-05-05 21:48                   ` [Ocfs2-devel] " Matthew Wilcox
2009-05-05 21:48                     ` Matthew Wilcox
2009-05-05 22:25                     ` [Ocfs2-devel] " Trond Myklebust
2009-05-05 22:25                       ` Trond Myklebust
2009-05-05 22:06                   ` [Ocfs2-devel] " Jamie Lokier
2009-05-05 22:06                     ` Jamie Lokier
2009-05-06  5:57                   ` [Ocfs2-devel] " Jörn Engel
2009-05-06  5:57                     ` Jörn Engel
2009-05-05 14:21           ` Theodore Tso [this message]
2009-05-05 14:21             ` [PATCH 1/3] fs: Document the reflink(2) system call Theodore Tso
2009-05-05 15:32             ` [Ocfs2-devel] " Jamie Lokier
2009-05-05 15:32               ` Jamie Lokier
2009-05-05 22:49             ` [Ocfs2-devel] " James Morris
2009-05-05 22:49               ` James Morris
2009-05-05 17:05           ` [Ocfs2-devel] " Joel Becker
2009-05-05 17:05             ` Joel Becker
2009-05-05 17:00         ` [Ocfs2-devel] " Joel Becker
2009-05-05 17:00           ` Joel Becker
2009-05-05 17:29           ` [Ocfs2-devel] " Theodore Tso
2009-05-05 17:29             ` Theodore Tso
2009-05-05 22:36             ` [Ocfs2-devel] " Jamie Lokier
2009-05-05 22:36               ` Jamie Lokier
2009-05-05 22:30           ` [Ocfs2-devel] " Jamie Lokier
2009-05-05 22:30             ` Jamie Lokier
2009-05-05 22:37             ` [Ocfs2-devel] " Joel Becker
2009-05-05 22:37               ` Joel Becker
2009-05-05 23:08             ` [Ocfs2-devel] " jim owens
2009-05-05 23:08               ` jim owens
2009-05-05 13:01       ` [Ocfs2-devel] " Jamie Lokier
2009-05-05 13:01         ` Jamie Lokier
2009-05-05 17:09         ` [Ocfs2-devel] " Joel Becker
2009-05-05 17:09           ` Joel Becker
2009-05-03  6:15 ` [Ocfs2-devel] [PATCH 2/3] fs: Add vfs_reflink() and the ->reflink() inode operation Joel Becker
2009-05-03  6:15   ` Joel Becker
2009-05-03  8:03   ` [Ocfs2-devel] " Christoph Hellwig
2009-05-03  8:03     ` Christoph Hellwig
2009-05-04  2:51     ` [Ocfs2-devel] " Joel Becker
2009-05-04  2:51       ` Joel Becker
2009-05-03  6:15 ` [Ocfs2-devel] [PATCH 3/3] fs: Add the reflink(2) system call Joel Becker
2009-05-03  6:15   ` Joel Becker
2009-05-03  6:27   ` [Ocfs2-devel] " Matthew Wilcox
2009-05-03  6:27     ` Matthew Wilcox
2009-05-03  6:39     ` [Ocfs2-devel] " Al Viro
2009-05-03  6:39       ` Al Viro
2009-05-03  7:48       ` [Ocfs2-devel] " Christoph Hellwig
2009-05-03  7:48         ` Christoph Hellwig
2009-05-03 11:16         ` [Ocfs2-devel] " Al Viro
2009-05-03 11:16           ` Al Viro
2009-05-04  2:53       ` [Ocfs2-devel] " Joel Becker
2009-05-04  2:53         ` Joel Becker
2009-05-04  2:53     ` [Ocfs2-devel] " Joel Becker
2009-05-04  2:53       ` Joel Becker
2009-05-03  8:04   ` [Ocfs2-devel] " Christoph Hellwig
2009-05-03  8:04     ` Christoph Hellwig
2009-05-07 22:15 ` [Ocfs2-devel] [RFC] The reflink(2) system call v2 Joel Becker
2009-05-07 22:15   ` Joel Becker
2009-05-08  1:39   ` [Ocfs2-devel] " James Morris
2009-05-08  1:39     ` James Morris
2009-05-08  1:49     ` [Ocfs2-devel] " Joel Becker
2009-05-08  1:49       ` Joel Becker
2009-05-08 13:01       ` Tetsuo Handa
2009-05-08  2:59   ` [Ocfs2-devel] " jim owens
2009-05-08  2:59     ` jim owens
2009-05-08  3:10     ` [Ocfs2-devel] " Joel Becker
2009-05-08  3:10       ` Joel Becker
2009-05-08 11:53       ` [Ocfs2-devel] " jim owens
2009-05-08 11:53         ` jim owens
2009-05-08 12:16       ` [Ocfs2-devel] " jim owens
2009-05-08 12:16         ` jim owens
2009-05-08 14:11         ` [Ocfs2-devel] " jim owens
2009-05-08 14:11           ` jim owens
2009-05-11 20:40       ` [Ocfs2-devel] [RFC] The reflink(2) system call v4 Joel Becker
2009-05-11 20:40         ` Joel Becker
2009-05-11 22:27         ` [Ocfs2-devel] " James Morris
2009-05-11 22:27           ` James Morris
2009-05-11 22:34           ` [Ocfs2-devel] " Joel Becker
2009-05-11 22:34             ` Joel Becker
2009-05-12  1:12             ` [Ocfs2-devel] " James Morris
2009-05-12  1:12               ` James Morris
2009-05-12 12:18               ` [Ocfs2-devel] " Stephen Smalley
2009-05-12 12:18                 ` Stephen Smalley
2009-05-12 17:22                 ` [Ocfs2-devel] " Joel Becker
2009-05-12 17:22                   ` Joel Becker
2009-05-12 17:32                   ` [Ocfs2-devel] " Stephen Smalley
2009-05-12 17:32                     ` Stephen Smalley
2009-05-12 18:03                     ` [Ocfs2-devel] " Joel Becker
2009-05-12 18:03                       ` Joel Becker
2009-05-12 18:04                       ` [Ocfs2-devel] " Stephen Smalley
2009-05-12 18:04                         ` Stephen Smalley
2009-05-12 18:28                         ` [Ocfs2-devel] " Joel Becker
2009-05-12 18:28                           ` Joel Becker
2009-05-12 18:37                           ` [Ocfs2-devel] " Stephen Smalley
2009-05-12 18:37                             ` Stephen Smalley
2009-05-14 18:06                         ` [Ocfs2-devel] " Stephen Smalley
2009-05-14 18:06                           ` Stephen Smalley
2009-05-14 18:25                           ` [Ocfs2-devel] " Stephen Smalley
2009-05-14 18:25                             ` Stephen Smalley
2009-05-14 23:25                             ` [Ocfs2-devel] " James Morris
2009-05-14 23:25                               ` James Morris
2009-05-15 11:54                               ` [Ocfs2-devel] " Stephen Smalley
2009-05-15 11:54                                 ` Stephen Smalley
2009-05-15 13:35                                 ` [Ocfs2-devel] " James Morris
2009-05-15 13:35                                   ` James Morris
2009-05-15 15:44                                   ` [Ocfs2-devel] " Stephen Smalley
2009-05-15 15:44                                     ` Stephen Smalley
2009-05-13  1:47                       ` [Ocfs2-devel] " Casey Schaufler
2009-05-13  1:47                         ` Casey Schaufler
2009-05-13 16:43                         ` [Ocfs2-devel] " Joel Becker
2009-05-13 16:43                           ` Joel Becker
2009-05-13 17:23                           ` [Ocfs2-devel] " Stephen Smalley
2009-05-13 17:23                             ` Stephen Smalley
2009-05-13 18:27                             ` [Ocfs2-devel] " Joel Becker
2009-05-13 18:27                               ` Joel Becker
2009-05-12 12:01           ` [Ocfs2-devel] " Stephen Smalley
2009-05-12 12:01             ` Stephen Smalley
2009-05-11 23:11         ` [Ocfs2-devel] " jim owens
2009-05-11 23:11           ` jim owens
2009-05-11 23:42           ` [Ocfs2-devel] " Joel Becker
2009-05-11 23:42             ` Joel Becker
2009-05-12 11:31         ` [Ocfs2-devel] " Jörn Engel
2009-05-12 11:31           ` Jörn Engel
2009-05-12 13:12           ` [Ocfs2-devel] " jim owens
2009-05-12 13:12             ` jim owens
2009-05-12 20:24             ` [Ocfs2-devel] " Jamie Lokier
2009-05-12 20:24               ` Jamie Lokier
2009-05-14 18:43             ` [Ocfs2-devel] " Jörn Engel
2009-05-14 18:43               ` Jörn Engel
2009-05-12 15:04         ` [Ocfs2-devel] " Sage Weil
2009-05-12 15:04           ` Sage Weil
2009-05-12 15:23           ` [Ocfs2-devel] " jim owens
2009-05-12 15:23             ` jim owens
2009-05-12 16:16             ` [Ocfs2-devel] " Sage Weil
2009-05-12 16:16               ` Sage Weil
2009-05-12 17:45               ` [Ocfs2-devel] " jim owens
2009-05-12 17:45                 ` jim owens
2009-05-12 20:29                 ` [Ocfs2-devel] " Jamie Lokier
2009-05-12 20:29                   ` Jamie Lokier
2009-05-12 17:28           ` [Ocfs2-devel] " Joel Becker
2009-05-12 17:28             ` Joel Becker
2009-05-13  4:30             ` [Ocfs2-devel] " Sage Weil
2009-05-13  4:30               ` Sage Weil
2009-05-14  3:57         ` [Ocfs2-devel] " Andy Lutomirski
2009-05-14  3:57           ` Andy Lutomirski
2009-05-14 18:12           ` [Ocfs2-devel] " Stephen Smalley
2009-05-14 18:12             ` Stephen Smalley
2009-05-14 22:00             ` [Ocfs2-devel] " Joel Becker
2009-05-14 22:00               ` Joel Becker
2009-05-15  1:20               ` Jamie Lokier
2009-05-15  1:20               ` [Ocfs2-devel] " Jamie Lokier
2009-05-15 12:01               ` Stephen Smalley
2009-05-15 12:01                 ` Stephen Smalley
2009-05-15 15:22                 ` [Ocfs2-devel] " Joel Becker
2009-05-15 15:22                   ` Joel Becker
2009-05-15 15:55                   ` [Ocfs2-devel] " Stephen Smalley
2009-05-15 15:55                     ` Stephen Smalley
2009-05-15 16:42                     ` [Ocfs2-devel] " Joel Becker
2009-05-15 16:42                       ` Joel Becker
2009-05-15 17:01                       ` [Ocfs2-devel] " Shaya Potter
2009-05-15 17:01                       ` Shaya Potter
2009-05-15 20:53                       ` [Ocfs2-devel] " Joel Becker
2009-05-15 20:53                         ` Joel Becker
2009-05-18  9:17                         ` Jörn Engel
2009-05-18  9:17                           ` Jörn Engel
2009-05-18 13:02                         ` Stephen Smalley
2009-05-18 13:02                           ` Stephen Smalley
2009-05-18 14:33                           ` Stephen Smalley
2009-05-18 14:33                             ` Stephen Smalley
2009-05-18 17:15                             ` Stephen Smalley
2009-05-18 17:15                               ` Stephen Smalley
2009-05-18 18:26                           ` Joel Becker
2009-05-18 18:26                             ` Joel Becker
2009-05-19 16:32                             ` [Ocfs2-devel] " Sage Weil
2009-05-19 16:32                               ` Sage Weil
2009-05-19 19:20                         ` Jonathan Corbet
2009-05-19 19:32                           ` Joel Becker
2009-05-19 19:41                             ` Jonathan Corbet
2009-05-19 19:41                               ` Jonathan Corbet
2009-05-19 19:33                         ` Jonathan Corbet
2009-05-19 20:15                           ` Jamie Lokier
2009-05-25  7:44         ` [Ocfs2-devel] [RFC] The reflink(2) system call v4. - Question for suitability Mihail Daskalov
2009-05-25 20:42           ` Joel Becker
2009-05-28  0:24         ` [RFC] The reflink(2) system call v5 Joel Becker
2009-05-28  0:24         ` [Ocfs2-devel] " Joel Becker
2009-09-14 22:24         ` Joel Becker
2009-09-14 22:24           ` Joel Becker
2009-09-14 22:24         ` Joel Becker
2009-05-11 20:49     ` [Ocfs2-devel] [RFC] The reflink(2) system call v2 Joel Becker
2009-05-11 20:49       ` Joel Becker
2009-05-11 22:49       ` [Ocfs2-devel] " jim owens
2009-05-11 22:49         ` jim owens
2009-05-11 23:46         ` [Ocfs2-devel] " Joel Becker
2009-05-11 23:46           ` Joel Becker
2009-05-12  0:54           ` [Ocfs2-devel] " Chris Mason
2009-05-12  0:54             ` Chris Mason
2009-05-12 20:36           ` [Ocfs2-devel] " Jamie Lokier
2009-05-12 20:36             ` Jamie Lokier

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=20090505142102.GE17486@mit.edu \
    --to=tytso@mit.edu \
    --cc=jamie@shareable.org \
    --cc=jmorris@namei.org \
    --cc=linux-fsdevel@vger.kernel.org \
    --cc=ocfs2-devel@oss.oracle.com \
    --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 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.