Blame support/support_can_chroot.c

Packit Service 82fcde
/* Return true if the process can perform a chroot operation.
Packit Service 82fcde
   Copyright (C) 2017-2018 Free Software Foundation, Inc.
Packit Service 82fcde
   This file is part of the GNU C Library.
Packit Service 82fcde
Packit Service 82fcde
   The GNU C Library is free software; you can redistribute it and/or
Packit Service 82fcde
   modify it under the terms of the GNU Lesser General Public
Packit Service 82fcde
   License as published by the Free Software Foundation; either
Packit Service 82fcde
   version 2.1 of the License, or (at your option) any later version.
Packit Service 82fcde
Packit Service 82fcde
   The GNU C Library is distributed in the hope that it will be useful,
Packit Service 82fcde
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 82fcde
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service 82fcde
   Lesser General Public License for more details.
Packit Service 82fcde
Packit Service 82fcde
   You should have received a copy of the GNU Lesser General Public
Packit Service 82fcde
   License along with the GNU C Library; if not, see
Packit Service 82fcde
   <http://www.gnu.org/licenses/>.  */
Packit Service 82fcde
Packit Service 82fcde
#include <errno.h>
Packit Service 82fcde
#include <stdio.h>
Packit Service 82fcde
#include <support/check.h>
Packit Service 82fcde
#include <support/namespace.h>
Packit Service 82fcde
#include <support/support.h>
Packit Service 82fcde
#include <support/xunistd.h>
Packit Service 82fcde
#include <sys/stat.h>
Packit Service 82fcde
#include <unistd.h>
Packit Service 82fcde
Packit Service 82fcde
static void
Packit Service 82fcde
callback (void *closure)
Packit Service 82fcde
{
Packit Service 82fcde
  int *result = closure;
Packit Service 82fcde
  struct stat64 before;
Packit Service 82fcde
  xstat ("/dev", &before);
Packit Service 82fcde
  if (chroot ("/dev") != 0)
Packit Service 82fcde
    {
Packit Service 82fcde
      *result = errno;
Packit Service 82fcde
      return;
Packit Service 82fcde
    }
Packit Service 82fcde
  struct stat64 after;
Packit Service 82fcde
  xstat ("/", &after);
Packit Service 82fcde
  TEST_VERIFY (before.st_dev == after.st_dev);
Packit Service 82fcde
  TEST_VERIFY (before.st_ino == after.st_ino);
Packit Service 82fcde
  *result = 0;
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
bool
Packit Service 82fcde
support_can_chroot (void)
Packit Service 82fcde
{
Packit Service 82fcde
  int *result = support_shared_allocate (sizeof (*result));
Packit Service 82fcde
  *result = 0;
Packit Service 82fcde
  support_isolate_in_subprocess (callback, result);
Packit Service 82fcde
  bool ok = *result == 0;
Packit Service 82fcde
  if (!ok)
Packit Service 82fcde
    {
Packit Service 82fcde
      static bool already_warned;
Packit Service 82fcde
      if (!already_warned)
Packit Service 82fcde
        {
Packit Service 82fcde
          already_warned = true;
Packit Service 82fcde
          errno = *result;
Packit Service 82fcde
          printf ("warning: this process does not support chroot: %m\n");
Packit Service 82fcde
        }
Packit Service 82fcde
    }
Packit Service 82fcde
  support_shared_free (result);
Packit Service 82fcde
  return ok;
Packit Service 82fcde
}