Skip to content

Commit

Permalink
filp_cachep can be static in fs/file_table.c
Browse files Browse the repository at this point in the history
Instead of creating the "filp" kmem_cache in vfs_caches_init(),
we can do it a litle be later in files_init(), so that filp_cachep
is static to fs/file_table.c

Acked-by: Paul E. McKenney <paulmck@linux.vnet.ibm.com>

Signed-off-by: Eric Dumazet <dada1@cosmosbay.com>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
  • Loading branch information
Eric Dumazet authored and Al Viro committed Dec 31, 2008
1 parent fd659fd commit b6b3fde
Show file tree
Hide file tree
Showing 3 changed files with 9 additions and 9 deletions.
6 changes: 0 additions & 6 deletions fs/dcache.c
Original file line number Diff line number Diff line change
Expand Up @@ -2314,9 +2314,6 @@ static void __init dcache_init(void)
/* SLAB cache for __getname() consumers */
struct kmem_cache *names_cachep __read_mostly;

/* SLAB cache for file structures */
struct kmem_cache *filp_cachep __read_mostly;

EXPORT_SYMBOL(d_genocide);

void __init vfs_caches_init_early(void)
Expand All @@ -2338,9 +2335,6 @@ void __init vfs_caches_init(unsigned long mempages)
names_cachep = kmem_cache_create("names_cache", PATH_MAX, 0,
SLAB_HWCACHE_ALIGN|SLAB_PANIC, NULL);

filp_cachep = kmem_cache_create("filp", sizeof(struct file), 0,
SLAB_HWCACHE_ALIGN|SLAB_PANIC, NULL);

dcache_init();
inode_init();
files_init(mempages);
Expand Down
10 changes: 9 additions & 1 deletion fs/file_table.c
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,9 @@ struct files_stat_struct files_stat = {
/* public. Not pretty! */
__cacheline_aligned_in_smp DEFINE_SPINLOCK(files_lock);

/* SLAB cache for file structures */
static struct kmem_cache *filp_cachep __read_mostly;

static struct percpu_counter nr_files __cacheline_aligned_in_smp;

static inline void file_free_rcu(struct rcu_head *head)
Expand Down Expand Up @@ -397,7 +400,12 @@ int fs_may_remount_ro(struct super_block *sb)
void __init files_init(unsigned long mempages)
{
int n;
/* One file with associated inode and dcache is very roughly 1K.

filp_cachep = kmem_cache_create("filp", sizeof(struct file), 0,
SLAB_HWCACHE_ALIGN | SLAB_PANIC, NULL);

/*
* One file with associated inode and dcache is very roughly 1K.
* Per default don't use more than 10% of our memory for files.
*/

Expand Down
2 changes: 0 additions & 2 deletions include/linux/fdtable.h
Original file line number Diff line number Diff line change
Expand Up @@ -57,8 +57,6 @@ struct files_struct {

#define files_fdtable(files) (rcu_dereference((files)->fdt))

extern struct kmem_cache *filp_cachep;

struct file_operations;
struct vfsmount;
struct dentry;
Expand Down

0 comments on commit b6b3fde

Please sign in to comment.