From: "Serge E. Hallyn" <serue-r/Jw6+rmf7HQT0dZR+AlfA@public.gmane.org>
To: Linux Containers <containers-qjLDD68F18O7TbgM5vRIOg@public.gmane.org>
Subject: Re: [PATCH 1/1] mktree: use clone_with_pid on s390
Date: Mon, 15 Jun 2009 14:08:21 -0500 [thread overview]
Message-ID: <20090615190821.GA16990@us.ibm.com> (raw)
In-Reply-To: <20090615171337.GA15152-r/Jw6+rmf7HQT0dZR+AlfA@public.gmane.org>
Quoting Serge E. Hallyn (serue-r/Jw6+rmf7HQT0dZR+AlfA@public.gmane.org):
> Signed-off-by: Serge Hallyn <serue-r/Jw6+rmf7HQT0dZR+AlfA@public.gmane.org>
> ---
> mktree.c | 41 +++++++++++++++++++++++++++++++++++++++++
> 1 files changed, 41 insertions(+), 0 deletions(-)
>
> diff --git a/mktree.c b/mktree.c
> index db5a060..af18b57 100644
> --- a/mktree.c
> +++ b/mktree.c
> @@ -1720,6 +1720,47 @@ static int clone_with_pids(int (*fn)(void *), void *child_stack, int flags,
> }
> #else
>
> +#elif defined __s390__
Boy, I am having a BAD patching day. Clearly, the chunk of new code
should come before the #else. Here's the trivial update.
-serge
From 12ef5d382693f3e47adf36d0211e3ae1f94c2b02 Mon Sep 17 00:00:00 2001
From: root <root-4X4tz4w3nuxpk64qw6wm7cxtgHpCUUYS@public.gmane.org>
Date: Mon, 15 Jun 2009 13:14:08 -0400
Subject: [PATCH 1/1] mktree: use clone_with_pid on s390
Signed-off-by: Serge Hallyn <serue-r/Jw6+rmf7HQT0dZR+AlfA@public.gmane.org>
---
mktree.c | 41 +++++++++++++++++++++++++++++++++++++++++
1 files changed, 41 insertions(+), 0 deletions(-)
diff --git a/mktree.c b/mktree.c
index db5a060..504e2c6 100644
--- a/mktree.c
+++ b/mktree.c
@@ -1718,6 +1718,47 @@ static int clone_with_pids(int (*fn)(void *), void *child_stack, int flags,
}
return retval;
}
+#elif defined __s390__
+
+#ifndef __NR_clone_with_pids
+#define __NR_clone_with_pids 332
+#endif
+
+#define do_clone_with_pids(stack, flags, ptid, ctid, setp) ({ \
+ register unsigned long int __r2 asm ("2") = (unsigned long int)(stack);\
+ register unsigned long int __r3 asm ("3") = (unsigned long int)(flags);\
+ register unsigned long int __r4 asm ("4") = (unsigned long int)(ptid); \
+ register unsigned long int __r5 asm ("5") = (unsigned long int)(ctid); \
+ register unsigned long int __r6 asm ("6") = (unsigned long int)(NULL); \
+ register unsigned long int __r7 asm ("7") = (unsigned long int)(setp); \
+ register unsigned long int __result asm ("2"); \
+ __asm__ __volatile__( \
+ " lghi %%r1,332\n" \
+ " svc 0\n" \
+ : "=d" (__result) \
+ : "0" (__r2), "d" (__r3), \
+ "d" (__r4), "d" (__r5), "d" (__r6), "d" (__r7) \
+ : "1", "cc", "memory" \
+ ); \
+ __result; \
+ })
+
+int clone_with_pids(int (*fn)(void *), void *child_stack, int flags,
+ struct target_pid_set *target_pids, void *arg)
+{
+ long retval;
+ retval = do_clone_with_pids(child_stack, flags, NULL, NULL,
+ target_pids);
+
+ if (retval < 0) {
+ errno = -retval;
+ return -1;
+ } else if (retval == 0) {
+ return fn(arg);
+ } else
+ return retval;
+}
+
#else
#error mktree requires arch support for clone_with_pids() syscall
--
1.6.1.1
next prev parent reply other threads:[~2009-06-15 19:08 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-06-15 17:13 [PATCH 1/1] mktree: use clone_with_pid on s390 Serge E. Hallyn
[not found] ` <20090615171337.GA15152-r/Jw6+rmf7HQT0dZR+AlfA@public.gmane.org>
2009-06-15 19:08 ` Serge E. Hallyn [this message]
[not found] ` <20090615190821.GA16990-r/Jw6+rmf7HQT0dZR+AlfA@public.gmane.org>
2009-06-19 6:56 ` Oren Laadan
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20090615190821.GA16990@us.ibm.com \
--to=serue-r/jw6+rmf7hqt0dzr+alfa@public.gmane.org \
--cc=containers-qjLDD68F18O7TbgM5vRIOg@public.gmane.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.