Revert "xbps-uchroot: make sure to cleanup tempdir with overlayfs."
This reverts commit f6a6385b42d6946b8b72e1084b4827591967e147. Does not work as expected, and does not fix the real issue which is still not understood.
This commit is contained in:
parent
c4019aa923
commit
71a594f681
@ -1,5 +1,5 @@
|
|||||||
/*-
|
/*-
|
||||||
* Copyright (c) 2014-2020 Juan Romero Pardines.
|
* Copyright (c) 2014-2015 Juan Romero Pardines.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
@ -109,34 +109,22 @@ die(const char *fmt, ...)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
ftw_perms_cb(const char *fpath, const struct stat *sb UNUSED,
|
ftw_cb(const char *fpath, const struct stat *sb UNUSED, int type,
|
||||||
int type UNUSED, struct FTW *ftwbuf UNUSED)
|
struct FTW *ftwbuf UNUSED)
|
||||||
{
|
{
|
||||||
chmod(fpath, 0755);
|
int sverrno = 0;
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int
|
if (type == FTW_F || type == FTW_SL || type == FTW_SLN) {
|
||||||
ftw_cb(const char *fpath, const struct stat *sb UNUSED,
|
if (unlink(fpath) == -1)
|
||||||
int type UNUSED, struct FTW *ftwbuf UNUSED)
|
sverrno = errno;
|
||||||
{
|
} else if (type == FTW_D || type == FTW_DNR || type == FTW_DP) {
|
||||||
switch (type) {
|
if (rmdir(fpath) == -1)
|
||||||
case FTW_F:
|
sverrno = errno;
|
||||||
case FTW_SL:
|
} else {
|
||||||
case FTW_SLN:
|
return 0;
|
||||||
if (unlink(fpath) != 0) {
|
}
|
||||||
fprintf(stderr, "failed to remove %s: %s\n", fpath, strerror(errno));
|
if (sverrno != 0) {
|
||||||
}
|
fprintf(stderr, "Failed to remove %s: %s\n", fpath, strerror(sverrno));
|
||||||
break;
|
|
||||||
case FTW_D:
|
|
||||||
case FTW_DP:
|
|
||||||
case FTW_DNR:
|
|
||||||
if (rmdir(fpath) != 0) {
|
|
||||||
fprintf(stderr, "failed to remove %s: %s\n", fpath, strerror(errno));
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -144,39 +132,17 @@ ftw_cb(const char *fpath, const struct stat *sb UNUSED,
|
|||||||
static void
|
static void
|
||||||
cleanup_overlayfs(void)
|
cleanup_overlayfs(void)
|
||||||
{
|
{
|
||||||
char *workdir;
|
|
||||||
|
|
||||||
if (tmpdir == NULL)
|
if (tmpdir == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (!overlayfs_on_tmpfs) {
|
if (!overlayfs_on_tmpfs) {
|
||||||
/*
|
/* recursively remove the temporary dir */
|
||||||
* nftw() runs twice because the first run
|
if (nftw(tmpdir, ftw_cb, 20, FTW_MOUNT|FTW_PHYS|FTW_DEPTH) != 0) {
|
||||||
* chmods all files and directories to be 755,
|
|
||||||
* so that second run can remove all them.
|
|
||||||
*
|
|
||||||
* Go modules in xbps-src seem to have too
|
|
||||||
* restrictive permissions and this cleans up
|
|
||||||
* this mess.
|
|
||||||
*/
|
|
||||||
if (nftw(tmpdir, ftw_perms_cb, 256, FTW_MOUNT|FTW_PHYS|FTW_DEPTH) != 0) {
|
|
||||||
fprintf(stderr, "Failed to remove directory tree %s: %s\n",
|
|
||||||
tmpdir, strerror(errno));
|
|
||||||
exit(EXIT_FAILURE);
|
|
||||||
}
|
|
||||||
if (nftw(tmpdir, ftw_cb, 256, FTW_MOUNT|FTW_PHYS|FTW_DEPTH) != 0) {
|
|
||||||
fprintf(stderr, "Failed to remove directory tree %s: %s\n",
|
fprintf(stderr, "Failed to remove directory tree %s: %s\n",
|
||||||
tmpdir, strerror(errno));
|
tmpdir, strerror(errno));
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
workdir = xbps_xasprintf("%s/workdir/work", tmpdir);
|
|
||||||
chmod(workdir, 0755);
|
|
||||||
rmdir(workdir);
|
|
||||||
free(workdir);
|
|
||||||
workdir = xbps_xasprintf("%s/workdir", tmpdir);
|
|
||||||
rmdir(workdir);
|
|
||||||
free(workdir);
|
|
||||||
rmdir(tmpdir);
|
rmdir(tmpdir);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -376,16 +342,17 @@ main(int argc, char **argv)
|
|||||||
die("failed to create tmpdir directory");
|
die("failed to create tmpdir directory");
|
||||||
if (chown(tmpdir, ruid, rgid) == -1)
|
if (chown(tmpdir, ruid, rgid) == -1)
|
||||||
die("chown tmpdir %s", tmpdir);
|
die("chown tmpdir %s", tmpdir);
|
||||||
/*
|
|
||||||
* Register a signal handler to clean up temporary masterdir.
|
|
||||||
*/
|
|
||||||
memset(&sa, 0, sizeof(sa));
|
|
||||||
sa.sa_handler = sighandler_cleanup;
|
|
||||||
sigaction(SIGINT, &sa, NULL);
|
|
||||||
sigaction(SIGTERM, &sa, NULL);
|
|
||||||
sigaction(SIGQUIT, &sa, NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Register a signal handler to clean up temporary masterdir.
|
||||||
|
*/
|
||||||
|
memset(&sa, 0, sizeof(sa));
|
||||||
|
sa.sa_handler = sighandler_cleanup;
|
||||||
|
sigaction(SIGINT, &sa, NULL);
|
||||||
|
sigaction(SIGTERM, &sa, NULL);
|
||||||
|
sigaction(SIGQUIT, &sa, NULL);
|
||||||
|
|
||||||
clone_flags = (SIGCHLD|CLONE_NEWNS|CLONE_NEWIPC|CLONE_NEWUTS|CLONE_NEWPID);
|
clone_flags = (SIGCHLD|CLONE_NEWNS|CLONE_NEWIPC|CLONE_NEWUTS|CLONE_NEWPID);
|
||||||
container_flags = clone_flags & ~(CLONE_NEWNS|CLONE_NEWIPC|CLONE_NEWUTS|CLONE_NEWPID);
|
container_flags = clone_flags & ~(CLONE_NEWNS|CLONE_NEWIPC|CLONE_NEWUTS|CLONE_NEWPID);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user