diff options
Diffstat (limited to 'fs/nfsd/nfs4state.c')
-rw-r--r-- | fs/nfsd/nfs4state.c | 58 |
1 files changed, 34 insertions, 24 deletions
diff --git a/fs/nfsd/nfs4state.c b/fs/nfsd/nfs4state.c index 8ac0c9abe941..260c1cbe25c4 100644 --- a/fs/nfsd/nfs4state.c +++ b/fs/nfsd/nfs4state.c | |||
@@ -70,8 +70,6 @@ u32 list_add_perfile = 0; | |||
70 | u32 list_del_perfile = 0; | 70 | u32 list_del_perfile = 0; |
71 | u32 add_perclient = 0; | 71 | u32 add_perclient = 0; |
72 | u32 del_perclient = 0; | 72 | u32 del_perclient = 0; |
73 | u32 alloc_file = 0; | ||
74 | u32 free_file = 0; | ||
75 | u32 vfsopen = 0; | 73 | u32 vfsopen = 0; |
76 | u32 vfsclose = 0; | 74 | u32 vfsclose = 0; |
77 | u32 alloc_delegation= 0; | 75 | u32 alloc_delegation= 0; |
@@ -90,6 +88,9 @@ static void release_stateid_lockowners(struct nfs4_stateid *open_stp); | |||
90 | */ | 88 | */ |
91 | static DECLARE_MUTEX(client_sema); | 89 | static DECLARE_MUTEX(client_sema); |
92 | 90 | ||
91 | kmem_cache_t *stateowner_slab = NULL; | ||
92 | kmem_cache_t *file_slab = NULL; | ||
93 | |||
93 | void | 94 | void |
94 | nfs4_lock_state(void) | 95 | nfs4_lock_state(void) |
95 | { | 96 | { |
@@ -961,14 +962,14 @@ alloc_init_file(struct inode *ino) | |||
961 | struct nfs4_file *fp; | 962 | struct nfs4_file *fp; |
962 | unsigned int hashval = file_hashval(ino); | 963 | unsigned int hashval = file_hashval(ino); |
963 | 964 | ||
964 | if ((fp = kmalloc(sizeof(struct nfs4_file),GFP_KERNEL))) { | 965 | fp = kmem_cache_alloc(file_slab, GFP_KERNEL); |
966 | if (fp) { | ||
965 | INIT_LIST_HEAD(&fp->fi_hash); | 967 | INIT_LIST_HEAD(&fp->fi_hash); |
966 | INIT_LIST_HEAD(&fp->fi_perfile); | 968 | INIT_LIST_HEAD(&fp->fi_perfile); |
967 | INIT_LIST_HEAD(&fp->fi_del_perfile); | 969 | INIT_LIST_HEAD(&fp->fi_del_perfile); |
968 | list_add(&fp->fi_hash, &file_hashtbl[hashval]); | 970 | list_add(&fp->fi_hash, &file_hashtbl[hashval]); |
969 | fp->fi_inode = igrab(ino); | 971 | fp->fi_inode = igrab(ino); |
970 | fp->fi_id = current_fileid++; | 972 | fp->fi_id = current_fileid++; |
971 | alloc_file++; | ||
972 | return fp; | 973 | return fp; |
973 | } | 974 | } |
974 | return NULL; | 975 | return NULL; |
@@ -992,29 +993,41 @@ release_all_files(void) | |||
992 | } | 993 | } |
993 | } | 994 | } |
994 | 995 | ||
995 | kmem_cache_t *stateowner_slab = NULL; | 996 | static void |
996 | 997 | nfsd4_free_slab(kmem_cache_t **slab) | |
997 | static int | ||
998 | nfsd4_init_slabs(void) | ||
999 | { | 998 | { |
1000 | stateowner_slab = kmem_cache_create("nfsd4_stateowners", | 999 | int status; |
1001 | sizeof(struct nfs4_stateowner), 0, 0, NULL, NULL); | 1000 | |
1002 | if (stateowner_slab == NULL) { | 1001 | if (*slab == NULL) |
1003 | dprintk("nfsd4: out of memory while initializing nfsv4\n"); | 1002 | return; |
1004 | return -ENOMEM; | 1003 | status = kmem_cache_destroy(*slab); |
1005 | } | 1004 | *slab = NULL; |
1006 | return 0; | 1005 | WARN_ON(status); |
1007 | } | 1006 | } |
1008 | 1007 | ||
1009 | static void | 1008 | static void |
1010 | nfsd4_free_slabs(void) | 1009 | nfsd4_free_slabs(void) |
1011 | { | 1010 | { |
1012 | int status = 0; | 1011 | nfsd4_free_slab(&stateowner_slab); |
1012 | nfsd4_free_slab(&file_slab); | ||
1013 | } | ||
1013 | 1014 | ||
1014 | if (stateowner_slab) | 1015 | static int |
1015 | status = kmem_cache_destroy(stateowner_slab); | 1016 | nfsd4_init_slabs(void) |
1016 | stateowner_slab = NULL; | 1017 | { |
1017 | BUG_ON(status); | 1018 | stateowner_slab = kmem_cache_create("nfsd4_stateowners", |
1019 | sizeof(struct nfs4_stateowner), 0, 0, NULL, NULL); | ||
1020 | if (stateowner_slab == NULL) | ||
1021 | goto out_nomem; | ||
1022 | file_slab = kmem_cache_create("nfsd4_files", | ||
1023 | sizeof(struct nfs4_file), 0, 0, NULL, NULL); | ||
1024 | if (file_slab == NULL) | ||
1025 | goto out_nomem; | ||
1026 | return 0; | ||
1027 | out_nomem: | ||
1028 | nfsd4_free_slabs(); | ||
1029 | dprintk("nfsd4: out of memory while initializing nfsv4\n"); | ||
1030 | return -ENOMEM; | ||
1018 | } | 1031 | } |
1019 | 1032 | ||
1020 | void | 1033 | void |
@@ -1167,10 +1180,9 @@ release_stateid(struct nfs4_stateid *stp, int flags) | |||
1167 | static void | 1180 | static void |
1168 | release_file(struct nfs4_file *fp) | 1181 | release_file(struct nfs4_file *fp) |
1169 | { | 1182 | { |
1170 | free_file++; | ||
1171 | list_del(&fp->fi_hash); | 1183 | list_del(&fp->fi_hash); |
1172 | iput(fp->fi_inode); | 1184 | iput(fp->fi_inode); |
1173 | kfree(fp); | 1185 | kmem_cache_free(file_slab, fp); |
1174 | } | 1186 | } |
1175 | 1187 | ||
1176 | void | 1188 | void |
@@ -3286,8 +3298,6 @@ __nfs4_state_shutdown(void) | |||
3286 | list_add_perfile, list_del_perfile); | 3298 | list_add_perfile, list_del_perfile); |
3287 | dprintk("NFSD: add_perclient %d del_perclient %d\n", | 3299 | dprintk("NFSD: add_perclient %d del_perclient %d\n", |
3288 | add_perclient, del_perclient); | 3300 | add_perclient, del_perclient); |
3289 | dprintk("NFSD: alloc_file %d free_file %d\n", | ||
3290 | alloc_file, free_file); | ||
3291 | dprintk("NFSD: vfsopen %d vfsclose %d\n", | 3301 | dprintk("NFSD: vfsopen %d vfsclose %d\n", |
3292 | vfsopen, vfsclose); | 3302 | vfsopen, vfsclose); |
3293 | dprintk("NFSD: alloc_delegation %d free_delegation %d\n", | 3303 | dprintk("NFSD: alloc_delegation %d free_delegation %d\n", |