diff options
author | Nick Piggin <npiggin@kernel.dk> | 2011-01-07 01:49:55 -0500 |
---|---|---|
committer | Nick Piggin <npiggin@kernel.dk> | 2011-01-07 01:50:28 -0500 |
commit | fb045adb99d9b7c562dc7fef834857f78249daa1 (patch) | |
tree | 1fd6a4024fffeec568abe100d730589bfdb81c38 /fs/dcache.c | |
parent | 5f57cbcc02cf18f6b22ef4066bb10afeb8f930ff (diff) |
fs: dcache reduce branches in lookup path
Reduce some branches and memory accesses in dcache lookup by adding dentry
flags to indicate common d_ops are set, rather than having to check them.
This saves a pointer memory access (dentry->d_op) in common path lookup
situations, and saves another pointer load and branch in cases where we
have d_op but not the particular operation.
Patched with:
git grep -E '[.>]([[:space:]])*d_op([[:space:]])*=' | xargs sed -e 's/\([^\t ]*\)->d_op = \(.*\);/d_set_d_op(\1, \2);/' -e 's/\([^\t ]*\)\.d_op = \(.*\);/d_set_d_op(\&\1, \2);/' -i
Signed-off-by: Nick Piggin <npiggin@kernel.dk>
Diffstat (limited to 'fs/dcache.c')
-rw-r--r-- | fs/dcache.c | 30 |
1 files changed, 26 insertions, 4 deletions
diff --git a/fs/dcache.c b/fs/dcache.c index 1d5cf511e1c..f9693da3efb 100644 --- a/fs/dcache.c +++ b/fs/dcache.c | |||
@@ -398,7 +398,7 @@ repeat: | |||
398 | return; | 398 | return; |
399 | } | 399 | } |
400 | 400 | ||
401 | if (dentry->d_op && dentry->d_op->d_delete) { | 401 | if (dentry->d_flags & DCACHE_OP_DELETE) { |
402 | if (dentry->d_op->d_delete(dentry)) | 402 | if (dentry->d_op->d_delete(dentry)) |
403 | goto kill_it; | 403 | goto kill_it; |
404 | } | 404 | } |
@@ -1301,6 +1301,28 @@ struct dentry *d_alloc_name(struct dentry *parent, const char *name) | |||
1301 | } | 1301 | } |
1302 | EXPORT_SYMBOL(d_alloc_name); | 1302 | EXPORT_SYMBOL(d_alloc_name); |
1303 | 1303 | ||
1304 | void d_set_d_op(struct dentry *dentry, const struct dentry_operations *op) | ||
1305 | { | ||
1306 | BUG_ON(dentry->d_op); | ||
1307 | BUG_ON(dentry->d_flags & (DCACHE_OP_HASH | | ||
1308 | DCACHE_OP_COMPARE | | ||
1309 | DCACHE_OP_REVALIDATE | | ||
1310 | DCACHE_OP_DELETE )); | ||
1311 | dentry->d_op = op; | ||
1312 | if (!op) | ||
1313 | return; | ||
1314 | if (op->d_hash) | ||
1315 | dentry->d_flags |= DCACHE_OP_HASH; | ||
1316 | if (op->d_compare) | ||
1317 | dentry->d_flags |= DCACHE_OP_COMPARE; | ||
1318 | if (op->d_revalidate) | ||
1319 | dentry->d_flags |= DCACHE_OP_REVALIDATE; | ||
1320 | if (op->d_delete) | ||
1321 | dentry->d_flags |= DCACHE_OP_DELETE; | ||
1322 | |||
1323 | } | ||
1324 | EXPORT_SYMBOL(d_set_d_op); | ||
1325 | |||
1304 | static void __d_instantiate(struct dentry *dentry, struct inode *inode) | 1326 | static void __d_instantiate(struct dentry *dentry, struct inode *inode) |
1305 | { | 1327 | { |
1306 | spin_lock(&dentry->d_lock); | 1328 | spin_lock(&dentry->d_lock); |
@@ -1731,7 +1753,7 @@ seqretry: | |||
1731 | */ | 1753 | */ |
1732 | if (read_seqcount_retry(&dentry->d_seq, *seq)) | 1754 | if (read_seqcount_retry(&dentry->d_seq, *seq)) |
1733 | goto seqretry; | 1755 | goto seqretry; |
1734 | if (parent->d_op && parent->d_op->d_compare) { | 1756 | if (parent->d_flags & DCACHE_OP_COMPARE) { |
1735 | if (parent->d_op->d_compare(parent, *inode, | 1757 | if (parent->d_op->d_compare(parent, *inode, |
1736 | dentry, i, | 1758 | dentry, i, |
1737 | tlen, tname, name)) | 1759 | tlen, tname, name)) |
@@ -1846,7 +1868,7 @@ struct dentry *__d_lookup(struct dentry *parent, struct qstr *name) | |||
1846 | */ | 1868 | */ |
1847 | tlen = dentry->d_name.len; | 1869 | tlen = dentry->d_name.len; |
1848 | tname = dentry->d_name.name; | 1870 | tname = dentry->d_name.name; |
1849 | if (parent->d_op && parent->d_op->d_compare) { | 1871 | if (parent->d_flags & DCACHE_OP_COMPARE) { |
1850 | if (parent->d_op->d_compare(parent, parent->d_inode, | 1872 | if (parent->d_op->d_compare(parent, parent->d_inode, |
1851 | dentry, dentry->d_inode, | 1873 | dentry, dentry->d_inode, |
1852 | tlen, tname, name)) | 1874 | tlen, tname, name)) |
@@ -1887,7 +1909,7 @@ struct dentry *d_hash_and_lookup(struct dentry *dir, struct qstr *name) | |||
1887 | * routine may choose to leave the hash value unchanged. | 1909 | * routine may choose to leave the hash value unchanged. |
1888 | */ | 1910 | */ |
1889 | name->hash = full_name_hash(name->name, name->len); | 1911 | name->hash = full_name_hash(name->name, name->len); |
1890 | if (dir->d_op && dir->d_op->d_hash) { | 1912 | if (dir->d_flags & DCACHE_OP_HASH) { |
1891 | if (dir->d_op->d_hash(dir, dir->d_inode, name) < 0) | 1913 | if (dir->d_op->d_hash(dir, dir->d_inode, name) < 0) |
1892 | goto out; | 1914 | goto out; |
1893 | } | 1915 | } |