54 lines
1.5 KiB
Diff
54 lines
1.5 KiB
Diff
Musl realpath() implementation currently depends on /proc which is
|
|
not available when setting up pivot root. For the time being just
|
|
fallback to a naive normalization algorithm originated from
|
|
VoidLinux' xbps. If there was path that would have required advanced
|
|
normalizing as provided by realpath() the following parse_mountinfo()
|
|
will fail.
|
|
|
|
|
|
diff --git bind-mount.c.orig bind-mount.c
|
|
index 045fa0e..d05b540 100644
|
|
--- ./bind-mount.c.orig
|
|
+++ ./bind-mount.c
|
|
@@ -23,6 +23,28 @@
|
|
#include "utils.h"
|
|
#include "bind-mount.h"
|
|
|
|
+#ifndef __GLIBC__
|
|
+static char *
|
|
+normpath(char *path)
|
|
+{
|
|
+ char *seg = NULL, *p = NULL;
|
|
+
|
|
+ for (p = path, seg = NULL; *p; p++) {
|
|
+ if (strncmp(p, "/../", 4) == 0 || strncmp(p, "/..", 4) == 0) {
|
|
+ memmove(seg ? seg : p, p+3, strlen(p+3) + 1);
|
|
+ return normpath(path);
|
|
+ } else if (strncmp(p, "/./", 3) == 0 || strncmp(p, "/.", 3) == 0) {
|
|
+ memmove(p, p+2, strlen(p+2) + 1);
|
|
+ } else if (strncmp(p, "//", 2) == 0 || strncmp(p, "/", 2) == 0) {
|
|
+ memmove(p, p+1, strlen(p+1) + 1);
|
|
+ }
|
|
+ if (*p == '/')
|
|
+ seg = p;
|
|
+ }
|
|
+ return path;
|
|
+}
|
|
+#endif
|
|
+
|
|
static char *
|
|
skip_token (char *line, bool eat_whitespace)
|
|
{
|
|
@@ -397,7 +419,11 @@ bind_mount (int proc_fd,
|
|
path, so to find it in the mount table we need to do that too. */
|
|
resolved_dest = realpath (dest, NULL);
|
|
if (resolved_dest == NULL)
|
|
+#ifdef __GLIBC__
|
|
return 2;
|
|
+#else
|
|
+ resolved_dest = normpath(strdup(dest));
|
|
+#endif
|
|
|
|
mount_tab = parse_mountinfo (proc_fd, resolved_dest);
|
|
if (mount_tab[0].mountpoint == NULL)
|