aboutsummaryrefslogtreecommitdiff
path: root/toys
diff options
context:
space:
mode:
authorRob Landley <rob@landley.net>2011-12-12 23:49:55 -0600
committerRob Landley <rob@landley.net>2011-12-12 23:49:55 -0600
commit9272a9dfbc9acb2b6201bb7556a523d56ff2c0f0 (patch)
treea7a974d848e2295a08134afeaaf565e18db40b0d /toys
parentad63f4bfd38c3728268983f15345010248614b01 (diff)
downloadtoybox-9272a9dfbc9acb2b6201bb7556a523d56ff2c0f0.tar.gz
Implement unshare.
Diffstat (limited to 'toys')
-rw-r--r--toys/unshare.c44
1 files changed, 44 insertions, 0 deletions
diff --git a/toys/unshare.c b/toys/unshare.c
new file mode 100644
index 00000000..c708ebe9
--- /dev/null
+++ b/toys/unshare.c
@@ -0,0 +1,44 @@
+/* vi: set sw=4 ts=4:
+ *
+ * unshare.c - run command in new context
+ *
+ * Copyright 2011 Rob Landley <rob@landley.net>
+ *
+ * Not in SUSv4.
+
+USE_UNSHARE(NEWTOY(unshare, "<1^nium", TOYFLAG_USR|TOYFLAG_BIN))
+
+config UNSHARE
+ bool "unshare"
+ default y
+ help
+ usage: unshare [-muin] COMMAND...
+
+ Create new namespace(s) for this process and its children, so some
+ attribute is not shared with the parent process. This is part of
+ Linux Containers. Each process can have its own:
+
+ -m Mount/unmount tree
+ -u Host and domain names
+ -i SysV IPC (message queues, semaphores, shared memory)
+ -n Network address, sockets, routing, iptables
+*/
+
+#include "toys.h"
+
+#include <sched.h>
+
+void unshare_main(void)
+{
+ unsigned flags[]={CLONE_NEWNS, CLONE_NEWUTS, CLONE_NEWIPC, CLONE_NEWNET,0};
+ unsigned f=0;
+ int i;
+
+ for (i=0; flags[i]; i++)
+ if (toys.optflags & (1<<i))
+ f |= flags[i];
+
+ if(unshare(f)) perror_exit("failed");
+
+ xexec(toys.optargs);
+}