summaryrefslogtreecommitdiffstats
path: root/fs/ceph/file.c
diff options
context:
space:
mode:
authorSage Weil <sage@newdream.net>2009-10-06 20:31:08 +0200
committerSage Weil <sage@newdream.net>2009-10-06 20:31:08 +0200
commit2817b000b02c5f0c05af67c01fb2684e1381d6ef (patch)
tree32efd3c3cddde6824d4f1e44deb5e7694899dbe1 /fs/ceph/file.c
parentceph: inode operations (diff)
downloadlinux-2817b000b02c5f0c05af67c01fb2684e1381d6ef.tar.xz
linux-2817b000b02c5f0c05af67c01fb2684e1381d6ef.zip
ceph: directory operations
Directory operations, including lookup, are defined here. We take advantage of lookup intents when possible. For the most part, we just need to build the proper requests for the metadata server(s) and pass things off to the mds_client. The results of most operations are normally incorporated into the client's cache when the reply is parsed by ceph_fill_trace(). However, if the MDS replies without a trace (e.g., when retrying an update after an MDS failure recovery), some operation-specific cleanup may be needed. We can validate cached dentries in two ways. A per-dentry lease may be issued by the MDS, or a per-directory cap may be issued that acts as a lease on the entire directory. In the latter case, a 'gen' value is used to determine which dentries belong to the currently leased directory contents. We normally prepopulate the dcache and icache with readdir results. This makes subsequent lookups and getattrs avoid any server interaction. It also lets us satisfy readdir operation by peeking at the dcache IFF we hold the per-directory cap/lease, previously performed a readdir, and haven't dropped any of the resulting dentries. Signed-off-by: Sage Weil <sage@newdream.net>
Diffstat (limited to 'fs/ceph/file.c')
0 files changed, 0 insertions, 0 deletions