projects
/
powerpc.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Pull bugzilla-5534 into release branch
[powerpc.git]
/
fs
/
dcache.c
diff --git
a/fs/dcache.c
b/fs/dcache.c
index
fd4a428
..
d68631f
100644
(file)
--- a/
fs/dcache.c
+++ b/
fs/dcache.c
@@
-43,7
+43,7
@@
static __cacheline_aligned_in_smp DEFINE_SEQLOCK(rename_lock);
EXPORT_SYMBOL(dcache_lock);
EXPORT_SYMBOL(dcache_lock);
-static
kmem_cache_t
*dentry_cache __read_mostly;
+static
struct kmem_cache
*dentry_cache __read_mostly;
#define DNAME_INLINE_LEN (sizeof(struct dentry)-offsetof(struct dentry,d_iname))
#define DNAME_INLINE_LEN (sizeof(struct dentry)-offsetof(struct dentry,d_iname))
@@
-68,15
+68,19
@@
struct dentry_stat_t dentry_stat = {
.age_limit = 45,
};
.age_limit = 45,
};
-static void
d_callback(struct rcu_head *head
)
+static void
__d_free(struct dentry *dentry
)
{
{
- struct dentry * dentry = container_of(head, struct dentry, d_u.d_rcu);
-
if (dname_external(dentry))
kfree(dentry->d_name.name);
kmem_cache_free(dentry_cache, dentry);
}
if (dname_external(dentry))
kfree(dentry->d_name.name);
kmem_cache_free(dentry_cache, dentry);
}
+static void d_callback(struct rcu_head *head)
+{
+ struct dentry * dentry = container_of(head, struct dentry, d_u.d_rcu);
+ __d_free(dentry);
+}
+
/*
* no dcache_lock, please. The caller must decrement dentry_stat.nr_dentry
* inside dcache_lock.
/*
* no dcache_lock, please. The caller must decrement dentry_stat.nr_dentry
* inside dcache_lock.
@@
-85,7
+89,11
@@
static void d_free(struct dentry *dentry)
{
if (dentry->d_op && dentry->d_op->d_release)
dentry->d_op->d_release(dentry);
{
if (dentry->d_op && dentry->d_op->d_release)
dentry->d_op->d_release(dentry);
- call_rcu(&dentry->d_u.d_rcu, d_callback);
+ /* if dentry was never inserted into hash, immediate free is OK */
+ if (dentry->d_hash.pprev == NULL)
+ __d_free(dentry);
+ else
+ call_rcu(&dentry->d_u.d_rcu, d_callback);
}
/*
}
/*
@@
-2072,10
+2080,10
@@
static void __init dcache_init(unsigned long mempages)
}
/* SLAB cache for __getname() consumers */
}
/* SLAB cache for __getname() consumers */
-
kmem_cache_t
*names_cachep __read_mostly;
+
struct kmem_cache
*names_cachep __read_mostly;
/* SLAB cache for file structures */
/* SLAB cache for file structures */
-
kmem_cache_t
*filp_cachep __read_mostly;
+
struct kmem_cache
*filp_cachep __read_mostly;
EXPORT_SYMBOL(d_genocide);
EXPORT_SYMBOL(d_genocide);