]> git.ipfire.org Git - thirdparty/grub.git/commitdiff
util/grub-install-common: Confirm directory creation in grub_install_mkdir_p()
authorDarren Kenny <darren.kenny@oracle.com>
Tue, 9 Aug 2022 13:29:05 +0000 (13:29 +0000)
committerDaniel Kiper <daniel.kiper@oracle.com>
Fri, 19 Aug 2022 19:41:51 +0000 (21:41 +0200)
Because grub_util_mkdir() is implemented to not return a value on any
platform, grub_instal_mkdir_p() can test for success by confirming that
the directory requested exists after attempting to create it, otherwise
it should fail with an error and exit.

While fixing this, a flaw in the logic was shown, where the first match
of the path separator, which almost always was the first character in
the path (e.g. /boot/grub2) would result in creating a directory with an
empty name (i.e. ""). To avoid that, it should skip the handling of the
path separator where p is pointing to the first character.

Signed-off-by: Darren Kenny <darren.kenny@oracle.com>
Reviewed-by: Daniel Kiper <daniel.kiper@oracle.com>
util/grub-install-common.c

index 347558bf54124411d4accdf95c9547f677f610fb..e45fb290307150bc1ee8bacc71d23adff579de44 100644 (file)
@@ -173,15 +173,20 @@ grub_install_mkdir_p (const char *dst)
   char *p;
   for (p = t; *p; p++)
     {
-      if (is_path_separator (*p))
+      if (is_path_separator (*p) && p != t)
        {
          char s = *p;
          *p = '\0';
          grub_util_mkdir (t);
+         if (!grub_util_is_directory (t))
+           grub_util_error (_("failed to make directory: '%s'"), t);
+
          *p = s;
        }
     }
   grub_util_mkdir (t);
+  if (!grub_util_is_directory (t))
+    grub_util_error (_("failed to make directory: '%s'"), t);
   free (t);
 }