]> git.ipfire.org Git - thirdparty/grub.git/commitdiff
loader/linux: Only emit newc directory once
authorGlenn Washburn <development@efficientek.com>
Wed, 28 Jun 2023 07:25:16 +0000 (02:25 -0500)
committerDaniel Kiper <daniel.kiper@oracle.com>
Mon, 3 Jul 2023 11:36:10 +0000 (13:36 +0200)
When creating at runtime a newc initrd via arguments to initrd with "newc:"
prefixes, only emit a directory path record once. The original code
intended to do that by bailing out of emitting the record when the record
to be created matches an existing record. However, this does not happen
because grub_memcmp() is improperly checked.

Generating duplicate newc directory records does not cause any problems
because the Linux unpacker will skip it once it sees the directory already
exists. This fix saves a little processing and makes the generated newc
cpio archive a little smaller.

Fixes: 92750e4c60 (Add ability to generate newc additions on runtime.)
Signed-off-by: Glenn Washburn <development@efficientek.com>
Reviewed-by: Daniel Kiper <daniel.kiper@oracle.com>
grub-core/loader/linux.c

index 3948302d2c434f94a2a8d0d65d05fefcb3b82728..cb2c3f6e4f062b95bdd539b774da0fb3d7d5239a 100644 (file)
@@ -114,7 +114,7 @@ insert_dir (const char *name, struct dir **root,
        break;
 
       for (cur = *root; cur; cur = cur->next)
-       if (grub_memcmp (cur->name, cb, ce - cb)
+       if (grub_memcmp (cur->name, cb, ce - cb) == 0
            && cur->name[ce - cb] == 0)
          break;
       if (!cur)