X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=lib_internal%2Fsys_clone.h;h=59066e625dcfb0864b7f0f1549e0e49887a918b1;hb=95e2774070e989fe9cf9f48dae5fa054e55e2a3e;hp=e31b8da8a558dc3bde22388658948f167f4e5723;hpb=3f3cf95f755f3ef1c31ad8e38153deb4ee214c66;p=util-vserver.git diff --git a/lib_internal/sys_clone.h b/lib_internal/sys_clone.h index e31b8da..59066e6 100644 --- a/lib_internal/sys_clone.h +++ b/lib_internal/sys_clone.h @@ -1,4 +1,4 @@ -// $Id: sys_clone.h,v 1.3 2005/04/28 18:01:37 ensc Exp $ --*- c -*-- +// $Id: sys_clone.h 2446 2007-01-09 13:22:11Z dhozac $ --*- c -*-- // Copyright (C) 2004 Enrico Scholz // @@ -19,33 +19,47 @@ #ifndef H_UTIL_VSERVER_SRC_SYS_CLONE_H #define H_UTIL_VSERVER_SRC_SYS_CLONE_H +#include #include "lib/syscall-wrap.h" -#define __NR_sys_clone __NR_clone +#define __NR__sys_clone __NR_clone -#ifndef CLONE_NEWNS -# define CLONE_NEWNS 0x00020000 -#endif +#ifndef ENSC_SYSCALL_TRADITIONAL +# include -#ifdef ENSC_SYSCALL_TRADITIONAL -#include +# if defined(__s390__) +inline static UNUSED ALWAYSINLINE +_syscall2(int, _sys_clone, void *, child_stack, int, flags) +# else +inline static UNUSED ALWAYSINLINE +_syscall2(int, _sys_clone, int, flags, void *, child_stack) +# endif +#endif inline static UNUSED ALWAYSINLINE -int sys_clone(int flags, void *stack) +int sys_clone(int flags, void *child_stack) { -#if defined __dietlibc__ - extern long int syscall (long int __sysno, ...); + int ret; +#ifdef __sparc__ + int parent = getpid(); #endif - - return syscall(__NR_sys_clone, flags, stack); -} -#else -#include -inline static UNUSED ALWAYSINLINE -_syscall2(int, sys_clone, int, flags, void *, child_stack) +#if defined(__s390__) && defined(ENSC_SYSCALL_TRADITIONAL) + ret = syscall(__NR__sys_clone, child_stack, flags); +#elif defined(__s390__) + ret = _sys_clone(child_stack, flags); +#elif defined(ENSC_SYSCALL_TRADITIONAL) + ret = syscall(__NR__sys_clone, flags, child_stack); +#else + ret = _sys_clone(flags, child_stack); +#endif +#ifdef __sparc__ + if (ret == parent) + ret = 0; #endif + return ret; +} -#undef __NR_sys_clone +#undef __NR__sys_clone #define ENSC_HAVE_SYSCLONE 1