|
@@ -530,8 +530,6 @@ static struct mm_struct *mm_init(struct mm_struct *mm, struct task_struct *p)
|
|
|
atomic_set(&mm->mm_count, 1);
|
|
|
init_rwsem(&mm->mmap_sem);
|
|
|
INIT_LIST_HEAD(&mm->mmlist);
|
|
|
- mm->flags = (current->mm) ?
|
|
|
- (current->mm->flags & MMF_INIT_MASK) : default_dump_filter;
|
|
|
mm->core_state = NULL;
|
|
|
atomic_long_set(&mm->nr_ptes, 0);
|
|
|
memset(&mm->rss_stat, 0, sizeof(mm->rss_stat));
|
|
@@ -540,8 +538,15 @@ static struct mm_struct *mm_init(struct mm_struct *mm, struct task_struct *p)
|
|
|
mm_init_owner(mm, p);
|
|
|
clear_tlb_flush_pending(mm);
|
|
|
|
|
|
- if (likely(!mm_alloc_pgd(mm))) {
|
|
|
+ if (current->mm) {
|
|
|
+ mm->flags = current->mm->flags & MMF_INIT_MASK;
|
|
|
+ mm->def_flags = current->mm->def_flags & VM_INIT_DEF_MASK;
|
|
|
+ } else {
|
|
|
+ mm->flags = default_dump_filter;
|
|
|
mm->def_flags = 0;
|
|
|
+ }
|
|
|
+
|
|
|
+ if (likely(!mm_alloc_pgd(mm))) {
|
|
|
mmu_notifier_mm_init(mm);
|
|
|
return mm;
|
|
|
}
|