From: Richard W.M. Jones Date: Wed, 27 Apr 2011 09:39:24 +0000 (+0100) Subject: helper: Change to root directory before running find command. X-Git-Tag: 3.5~6 X-Git-Url: http://git.annexia.org/?a=commitdiff_plain;h=d638270b133f19ca7f9570e47a498381dc4cfe10;hp=b6cce31ec4d8232d6400fe4fe915f53d285a3b4f;p=febootstrap.git helper: Change to root directory before running find command. --- diff --git a/helper/ext2initrd.c b/helper/ext2initrd.c index f10aef2..3d765ca 100644 --- a/helper/ext2initrd.c +++ b/helper/ext2initrd.c @@ -26,6 +26,7 @@ #include #include #include +#include #include "error.h" #include "full-write.h" @@ -80,7 +81,18 @@ ext2_make_initrd (const char *modpath, const char *initrd) for (i = 0; kmods[i] != NULL; ++i) n += strlen (kmods[i]) + 16; cmd = malloc (n); - sprintf (cmd, "find '%s' ", modpath); + /* "cd /" here is for virt-v2v. It's cwd might not be accessible by + * the current user (because it sometimes sets its own uid) and the + * "find" command works by changing directory then changing back to + * the cwd. This results in a warning: + * + * find: failed to restore initial working directory: Permission denied + * + * Note this only works because "modpath" and temporary "dir" are + * currently guaranteed to be absolute paths, hence assertion. + */ + assert (modpath[0] == '/'); + sprintf (cmd, "cd / ; find '%s' ", modpath); for (i = 0; kmods[i] != NULL; ++i) { if (i > 0) strcat (cmd, "-o "); strcat (cmd, "-name '");