[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20130221080358.7965659207B@miso.sublimeip.com>
Date: Thu, 21 Feb 2013 19:03:58 +1100 (EST)
From: u3557@...o.sublimeip.com (Amnon Shiloh)
To: gorcunov@...nvz.org (Cyrill Gorcunov)
Cc: rostedt@...dmis.org (Steven Rostedt), u3557@...lix.com.au,
oleg@...hat.com (Oleg Nesterov), palves@...hat.com (Pedro Alves),
dvlasenk@...hat.com (Denys Vlasenko),
jan.kratochvil@...hat.com (Jan Kratochvil),
xemul@...allels.com (Pavel Emelyanov),
fweisbec@...il.com (Frederic Weisbecker),
mingo@...hat.com (Ingo Molnar),
a.p.zijlstra@...llo.nl (Peter Zijlstra),
linux-kernel@...r.kernel.org,
akpm@...ux-foundation.org (Andrew Morton)
Subject: Re: prctl(PR_SET_MM)
Hi,
Cyrill Gorcunov wrote:
> Wouldn't the below do the same trick but eliminate OR in preproc code?
Yes it would. I don't mind having it either way.
Best Regards,
Amnon.
> ---
> From: Amnon Shiloh <u3557@...o.sublimeip.com>
> Subject: prctl: Make PR_SET_MM being depend on own CONFIG_MM_FIELDS_SETTING
>
> ...
>
> Signed-off-by: Amnon Shiloh <u3557@...o.sublimeip.com>
> ---
> init/Kconfig | 17 +++++++++++++++++
> kernel/sys.c | 16 ++++++++--------
> 2 files changed, 25 insertions(+), 8 deletions(-)
>
> Index: linux-2.6.git/init/Kconfig
> ===================================================================
> --- linux-2.6.git.orig/init/Kconfig
> +++ linux-2.6.git/init/Kconfig
> @@ -991,6 +991,7 @@ endif # CGROUPS
> config CHECKPOINT_RESTORE
> bool "Checkpoint/restore support" if EXPERT
> default n
> + select MM_FIELDS_SETTING
> help
> Enables additional kernel features in a sake of checkpoint/restore.
> In particular it adds auxiliary prctl codes to setup process text,
> @@ -999,6 +1000,22 @@ config CHECKPOINT_RESTORE
>
> If unsure, say N here.
>
> +config MM_FIELDS_SETTING
> + bool "Allow modifying per-process memory-region fields"
> + default y
> + help
> + Support "prctl(PR_SET_MM)" which allows applications to modify
> + the following in their "mm_struct":
> +
> + start_code, end_code, start_data, end_data, start_brk, brk,
> + start_stack, arg_start, arg_end, env_start, env_end.
> +
> + Also to modify their executable file ("/proc/self/exe").
> +
> + This option is needed for reconstructing processes (such as when
> + restoring a process from a checkpoint; duplicating a process;
> + or migrating it to another computer).
> +
> menuconfig NAMESPACES
> bool "Namespaces support" if EXPERT
> default !EXPERT
> Index: linux-2.6.git/kernel/sys.c
> ===================================================================
> --- linux-2.6.git.orig/kernel/sys.c
> +++ linux-2.6.git/kernel/sys.c
> @@ -1788,7 +1788,7 @@ SYSCALL_DEFINE1(umask, int, mask)
> return mask;
> }
>
> -#ifdef CONFIG_CHECKPOINT_RESTORE
> +#ifdef CONFIG_MM_FIELDS_SETTING
> static int prctl_set_mm_exe_file(struct mm_struct *mm, unsigned int fd)
> {
> struct fd exe;
> @@ -1981,23 +1981,23 @@ out:
> up_read(&mm->mmap_sem);
> return error;
> }
> +#else /* CONFIG_MM_FIELDS_SETTING */
>
> -static int prctl_get_tid_address(struct task_struct *me, int __user **tid_addr)
> -{
> - return put_user(me->clear_child_tid, tid_addr);
> -}
> -
> -#else /* CONFIG_CHECKPOINT_RESTORE */
> static int prctl_set_mm(int opt, unsigned long addr,
> unsigned long arg4, unsigned long arg5)
> {
> return -EINVAL;
> }
> +#endif
> +
> static int prctl_get_tid_address(struct task_struct *me, int __user **tid_addr)
> {
> +#ifdef CONFIG_CHECKPOINT_RESTORE
> + return put_user(me->clear_child_tid, tid_addr);
> +#else
> return -EINVAL;
> -}
> #endif
> +}
>
> SYSCALL_DEFINE5(prctl, int, option, unsigned long, arg2, unsigned long, arg3,
> unsigned long, arg4, unsigned long, arg5)
>
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists