Skip to content

Commit

Permalink
Merge pull request #2293 from pkun/master
Browse files Browse the repository at this point in the history
Fix tool_utils.c build when HAVE_SETNS is unset
  • Loading branch information
Christian Brauner committed Apr 26, 2018
2 parents fca96eb + 09e6e41 commit 61068d3
Showing 1 changed file with 33 additions and 0 deletions.
33 changes: 33 additions & 0 deletions src/lxc/tools/tool_utils.h
Expand Up @@ -23,6 +23,8 @@
/* Properly support loop devices on 32bit systems. */
#define _FILE_OFFSET_BITS 64

#include "config.h"

#include <errno.h>
#include <stdarg.h>
#include <stdio.h>
Expand Down Expand Up @@ -109,6 +111,37 @@ extern signed long lxc_config_parse_arch(const char *arch);
extern int lxc_namespace_2_cloneflag(const char *namespace);
extern int lxc_fill_namespace_flags(char *flaglist, int *flags);

#if !defined(__NR_setns) && !defined(__NR_set_ns)
#if defined(__x86_64__)
#define __NR_setns 308
#elif defined(__i386__)
#define __NR_setns 346
#elif defined(__arm__)
#define __NR_setns 375
#elif defined(__aarch64__)
#define __NR_setns 375
#elif defined(__powerpc__)
#define __NR_setns 350
#elif defined(__s390__)
#define __NR_setns 339
#endif
#endif

/* Define setns() if missing from the C library */
#ifndef HAVE_SETNS
static inline int setns(int fd, int nstype)
{
#ifdef __NR_setns
return syscall(__NR_setns, fd, nstype);
#elif defined(__NR_set_ns)
return syscall(__NR_set_ns, fd, nstype);
#else
errno = ENOSYS;
return -1;
#endif
}
#endif

#if HAVE_LIBCAP
#include <sys/capability.h>

Expand Down

0 comments on commit 61068d3

Please sign in to comment.