diff options
Diffstat (limited to 'kernel/fork.c')
| -rw-r--r-- | kernel/fork.c | 20 |
1 files changed, 12 insertions, 8 deletions
diff --git a/kernel/fork.c b/kernel/fork.c index b6cce14ba047..b7e9d60a675d 100644 --- a/kernel/fork.c +++ b/kernel/fork.c | |||
| @@ -300,7 +300,7 @@ out: | |||
| 300 | #ifdef CONFIG_MMU | 300 | #ifdef CONFIG_MMU |
| 301 | static int dup_mmap(struct mm_struct *mm, struct mm_struct *oldmm) | 301 | static int dup_mmap(struct mm_struct *mm, struct mm_struct *oldmm) |
| 302 | { | 302 | { |
| 303 | struct vm_area_struct *mpnt, *tmp, **pprev; | 303 | struct vm_area_struct *mpnt, *tmp, *prev, **pprev; |
| 304 | struct rb_node **rb_link, *rb_parent; | 304 | struct rb_node **rb_link, *rb_parent; |
| 305 | int retval; | 305 | int retval; |
| 306 | unsigned long charge; | 306 | unsigned long charge; |
| @@ -328,6 +328,7 @@ static int dup_mmap(struct mm_struct *mm, struct mm_struct *oldmm) | |||
| 328 | if (retval) | 328 | if (retval) |
| 329 | goto out; | 329 | goto out; |
| 330 | 330 | ||
| 331 | prev = NULL; | ||
| 331 | for (mpnt = oldmm->mmap; mpnt; mpnt = mpnt->vm_next) { | 332 | for (mpnt = oldmm->mmap; mpnt; mpnt = mpnt->vm_next) { |
| 332 | struct file *file; | 333 | struct file *file; |
| 333 | 334 | ||
| @@ -359,7 +360,7 @@ static int dup_mmap(struct mm_struct *mm, struct mm_struct *oldmm) | |||
| 359 | goto fail_nomem_anon_vma_fork; | 360 | goto fail_nomem_anon_vma_fork; |
| 360 | tmp->vm_flags &= ~VM_LOCKED; | 361 | tmp->vm_flags &= ~VM_LOCKED; |
| 361 | tmp->vm_mm = mm; | 362 | tmp->vm_mm = mm; |
| 362 | tmp->vm_next = NULL; | 363 | tmp->vm_next = tmp->vm_prev = NULL; |
| 363 | file = tmp->vm_file; | 364 | file = tmp->vm_file; |
| 364 | if (file) { | 365 | if (file) { |
| 365 | struct inode *inode = file->f_path.dentry->d_inode; | 366 | struct inode *inode = file->f_path.dentry->d_inode; |
| @@ -392,6 +393,8 @@ static int dup_mmap(struct mm_struct *mm, struct mm_struct *oldmm) | |||
| 392 | */ | 393 | */ |
| 393 | *pprev = tmp; | 394 | *pprev = tmp; |
| 394 | pprev = &tmp->vm_next; | 395 | pprev = &tmp->vm_next; |
| 396 | tmp->vm_prev = prev; | ||
| 397 | prev = tmp; | ||
| 395 | 398 | ||
| 396 | __vma_link_rb(mm, tmp, rb_link, rb_parent); | 399 | __vma_link_rb(mm, tmp, rb_link, rb_parent); |
| 397 | rb_link = &tmp->vm_rb.rb_right; | 400 | rb_link = &tmp->vm_rb.rb_right; |
| @@ -752,13 +755,13 @@ static int copy_fs(unsigned long clone_flags, struct task_struct *tsk) | |||
| 752 | struct fs_struct *fs = current->fs; | 755 | struct fs_struct *fs = current->fs; |
| 753 | if (clone_flags & CLONE_FS) { | 756 | if (clone_flags & CLONE_FS) { |
| 754 | /* tsk->fs is already what we want */ | 757 | /* tsk->fs is already what we want */ |
| 755 | write_lock(&fs->lock); | 758 | spin_lock(&fs->lock); |
| 756 | if (fs->in_exec) { | 759 | if (fs->in_exec) { |
| 757 | write_unlock(&fs->lock); | 760 | spin_unlock(&fs->lock); |
| 758 | return -EAGAIN; | 761 | return -EAGAIN; |
| 759 | } | 762 | } |
| 760 | fs->users++; | 763 | fs->users++; |
| 761 | write_unlock(&fs->lock); | 764 | spin_unlock(&fs->lock); |
| 762 | return 0; | 765 | return 0; |
| 763 | } | 766 | } |
| 764 | tsk->fs = copy_fs_struct(fs); | 767 | tsk->fs = copy_fs_struct(fs); |
| @@ -899,6 +902,7 @@ static int copy_signal(unsigned long clone_flags, struct task_struct *tsk) | |||
| 899 | tty_audit_fork(sig); | 902 | tty_audit_fork(sig); |
| 900 | 903 | ||
| 901 | sig->oom_adj = current->signal->oom_adj; | 904 | sig->oom_adj = current->signal->oom_adj; |
| 905 | sig->oom_score_adj = current->signal->oom_score_adj; | ||
| 902 | 906 | ||
| 903 | return 0; | 907 | return 0; |
| 904 | } | 908 | } |
| @@ -907,7 +911,7 @@ static void copy_flags(unsigned long clone_flags, struct task_struct *p) | |||
| 907 | { | 911 | { |
| 908 | unsigned long new_flags = p->flags; | 912 | unsigned long new_flags = p->flags; |
| 909 | 913 | ||
| 910 | new_flags &= ~PF_SUPERPRIV; | 914 | new_flags &= ~(PF_SUPERPRIV | PF_WQ_WORKER); |
| 911 | new_flags |= PF_FORKNOEXEC; | 915 | new_flags |= PF_FORKNOEXEC; |
| 912 | new_flags |= PF_STARTING; | 916 | new_flags |= PF_STARTING; |
| 913 | p->flags = new_flags; | 917 | p->flags = new_flags; |
| @@ -1675,13 +1679,13 @@ SYSCALL_DEFINE1(unshare, unsigned long, unshare_flags) | |||
| 1675 | 1679 | ||
| 1676 | if (new_fs) { | 1680 | if (new_fs) { |
| 1677 | fs = current->fs; | 1681 | fs = current->fs; |
| 1678 | write_lock(&fs->lock); | 1682 | spin_lock(&fs->lock); |
| 1679 | current->fs = new_fs; | 1683 | current->fs = new_fs; |
| 1680 | if (--fs->users) | 1684 | if (--fs->users) |
| 1681 | new_fs = NULL; | 1685 | new_fs = NULL; |
| 1682 | else | 1686 | else |
| 1683 | new_fs = fs; | 1687 | new_fs = fs; |
| 1684 | write_unlock(&fs->lock); | 1688 | spin_unlock(&fs->lock); |
| 1685 | } | 1689 | } |
| 1686 | 1690 | ||
| 1687 | if (new_mm) { | 1691 | if (new_mm) { |
