aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/fork.c
diff options
context:
space:
mode:
Diffstat (limited to 'kernel/fork.c')
-rw-r--r--kernel/fork.c21
1 files changed, 18 insertions, 3 deletions
diff --git a/kernel/fork.c b/kernel/fork.c
index 9440d61b925c..0e23deb5acfc 100644
--- a/kernel/fork.c
+++ b/kernel/fork.c
@@ -303,11 +303,26 @@ struct kmem_cache *files_cachep;
303struct kmem_cache *fs_cachep; 303struct kmem_cache *fs_cachep;
304 304
305/* SLAB cache for vm_area_struct structures */ 305/* SLAB cache for vm_area_struct structures */
306struct kmem_cache *vm_area_cachep; 306static struct kmem_cache *vm_area_cachep;
307 307
308/* SLAB cache for mm_struct structures (tsk->mm) */ 308/* SLAB cache for mm_struct structures (tsk->mm) */
309static struct kmem_cache *mm_cachep; 309static struct kmem_cache *mm_cachep;
310 310
311struct vm_area_struct *vm_area_alloc(void)
312{
313 return kmem_cache_zalloc(vm_area_cachep, GFP_KERNEL);
314}
315
316struct vm_area_struct *vm_area_dup(struct vm_area_struct *orig)
317{
318 return kmem_cache_alloc(vm_area_cachep, GFP_KERNEL);
319}
320
321void vm_area_free(struct vm_area_struct *vma)
322{
323 kmem_cache_free(vm_area_cachep, vma);
324}
325
311static void account_kernel_stack(struct task_struct *tsk, int account) 326static void account_kernel_stack(struct task_struct *tsk, int account)
312{ 327{
313 void *stack = task_stack_page(tsk); 328 void *stack = task_stack_page(tsk);
@@ -455,7 +470,7 @@ static __latent_entropy int dup_mmap(struct mm_struct *mm,
455 goto fail_nomem; 470 goto fail_nomem;
456 charge = len; 471 charge = len;
457 } 472 }
458 tmp = kmem_cache_alloc(vm_area_cachep, GFP_KERNEL); 473 tmp = vm_area_dup(mpnt);
459 if (!tmp) 474 if (!tmp)
460 goto fail_nomem; 475 goto fail_nomem;
461 *tmp = *mpnt; 476 *tmp = *mpnt;
@@ -539,7 +554,7 @@ fail_uprobe_end:
539fail_nomem_anon_vma_fork: 554fail_nomem_anon_vma_fork:
540 mpol_put(vma_policy(tmp)); 555 mpol_put(vma_policy(tmp));
541fail_nomem_policy: 556fail_nomem_policy:
542 kmem_cache_free(vm_area_cachep, tmp); 557 vm_area_free(tmp);
543fail_nomem: 558fail_nomem:
544 retval = -ENOMEM; 559 retval = -ENOMEM;
545 vm_unacct_memory(charge); 560 vm_unacct_memory(charge);