diff options
Diffstat (limited to 'kernel')
-rw-r--r-- | kernel/fork.c | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/kernel/fork.c b/kernel/fork.c index 1987c57abb0..314f5101d2b 100644 --- a/kernel/fork.c +++ b/kernel/fork.c | |||
@@ -792,15 +792,21 @@ out: | |||
792 | return error; | 792 | return error; |
793 | } | 793 | } |
794 | 794 | ||
795 | static int copy_io(struct task_struct *tsk) | 795 | static int copy_io(unsigned long clone_flags, struct task_struct *tsk) |
796 | { | 796 | { |
797 | #ifdef CONFIG_BLOCK | 797 | #ifdef CONFIG_BLOCK |
798 | struct io_context *ioc = current->io_context; | 798 | struct io_context *ioc = current->io_context; |
799 | 799 | ||
800 | if (!ioc) | 800 | if (!ioc) |
801 | return 0; | 801 | return 0; |
802 | 802 | /* | |
803 | if (ioprio_valid(ioc->ioprio)) { | 803 | * Share io context with parent, if CLONE_IO is set |
804 | */ | ||
805 | if (clone_flags & CLONE_IO) { | ||
806 | tsk->io_context = ioc_task_link(ioc); | ||
807 | if (unlikely(!tsk->io_context)) | ||
808 | return -ENOMEM; | ||
809 | } else if (ioprio_valid(ioc->ioprio)) { | ||
804 | tsk->io_context = alloc_io_context(GFP_KERNEL, -1); | 810 | tsk->io_context = alloc_io_context(GFP_KERNEL, -1); |
805 | if (unlikely(!tsk->io_context)) | 811 | if (unlikely(!tsk->io_context)) |
806 | return -ENOMEM; | 812 | return -ENOMEM; |
@@ -1176,7 +1182,7 @@ static struct task_struct *copy_process(unsigned long clone_flags, | |||
1176 | goto bad_fork_cleanup_mm; | 1182 | goto bad_fork_cleanup_mm; |
1177 | if ((retval = copy_namespaces(clone_flags, p))) | 1183 | if ((retval = copy_namespaces(clone_flags, p))) |
1178 | goto bad_fork_cleanup_keys; | 1184 | goto bad_fork_cleanup_keys; |
1179 | if ((retval = copy_io(p))) | 1185 | if ((retval = copy_io(clone_flags, p))) |
1180 | goto bad_fork_cleanup_namespaces; | 1186 | goto bad_fork_cleanup_namespaces; |
1181 | retval = copy_thread(0, clone_flags, stack_start, stack_size, p, regs); | 1187 | retval = copy_thread(0, clone_flags, stack_start, stack_size, p, regs); |
1182 | if (retval) | 1188 | if (retval) |