[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
01/08: build: syscalls: Add clone syscall wrapper.
From: |
David Thompson |
Subject: |
01/08: build: syscalls: Add clone syscall wrapper. |
Date: |
Mon, 08 Jun 2015 15:57:32 +0000 |
davexunit pushed a commit to branch wip-container
in repository guix.
commit 57ab10cd9fde6c5c32905ad3db3601871f8e3da1
Author: David Thompson <address@hidden>
Date: Sun May 31 20:26:47 2015 -0400
build: syscalls: Add clone syscall wrapper.
* guix/build/syscalls.scm (clone): New procedure.
(CLONE_NEWNS, CLONE_NEWUTS, CLONE_NEWIPC, CLONE_NEWUSER, CLONE_NEWPID,
CLONE_NEWNET): New variables.
---
guix/build/syscalls.scm | 32 ++++++++++++++++++++++++++++++++
1 files changed, 32 insertions(+), 0 deletions(-)
diff --git a/guix/build/syscalls.scm b/guix/build/syscalls.scm
index 3585bf2..3346358 100644
--- a/guix/build/syscalls.scm
+++ b/guix/build/syscalls.scm
@@ -1,5 +1,6 @@
;;; GNU Guix --- Functional package management for GNU
;;; Copyright © 2014, 2015 Ludovic Courtès <address@hidden>
+;;; Copyright © 2015 David Thompson <address@hidden>
;;;
;;; This file is part of GNU Guix.
;;;
@@ -37,6 +38,14 @@
swapoff
processes
+ CLONE_NEWNS
+ CLONE_NEWUTS
+ CLONE_NEWIPC
+ CLONE_NEWUSER
+ CLONE_NEWPID
+ CLONE_NEWNET
+ clone
+
IFF_UP
IFF_BROADCAST
IFF_LOOPBACK
@@ -247,6 +256,29 @@ user-land process."
(scandir "/proc"))
<))
+;; Linux clone flags, from linux/sched.h
+(define CLONE_NEWNS #x00020000)
+(define CLONE_NEWUTS #x04000000)
+(define CLONE_NEWIPC #x08000000)
+(define CLONE_NEWUSER #x10000000)
+(define CLONE_NEWPID #x20000000)
+(define CLONE_NEWNET #x40000000)
+
+;; The libc interface to sys_clone is not useful for Scheme programs, so the
+;; low-level system call is wrapped instead.
+(define clone
+ (let* ((ptr (dynamic-func "syscall" (dynamic-link)))
+ (proc (pointer->procedure int ptr (list int int '*)))
+ ;; TODO: Handle all supported architectures
+ (syscall-id (match (utsname:machine (uname))
+ ("x86_64" 56)
+ (_ 120))))
+ (lambda (flags)
+ "Create a new child process by duplicating the current parent process.
+Unlike the fork system call, clone accepts FLAGS that specify which resources
+are shared between the parent and child processes."
+ (proc syscall-id flags %null-pointer))))
+
;;;
;;; Packed structures.
- branch wip-container created (now fe415d6), David Thompson, 2015/06/08
- 01/08: build: syscalls: Add clone syscall wrapper.,
David Thompson <=
- 02/08: build: syscalls: Add setns syscall wrapper., David Thompson, 2015/06/08
- 03/08: build: syscalls: Add additional mount flags., David Thompson, 2015/06/08
- 05/08: gnu: Add Linux container system script., David Thompson, 2015/06/08
- 06/08: gnu: system: Do not activate firmware when activating a container., David Thompson, 2015/06/08
- 04/08: gnu: Add Linux container module., David Thompson, 2015/06/08
- 08/08: scripts: system: Add 'container' subcommand., David Thompson, 2015/06/08
- 07/08: gnu: system: Add operating-system-derivation/container., David Thompson, 2015/06/08