]> git.ipfire.org Git - thirdparty/grub.git/commitdiff
fs/affs: Fix resource leaks
authorAlec Brown <alec.r.brown@oracle.com>
Thu, 3 Feb 2022 00:08:21 +0000 (19:08 -0500)
committerDaniel Kiper <daniel.kiper@oracle.com>
Tue, 8 Feb 2022 15:06:50 +0000 (16:06 +0100)
In commit 178ac5107389 (affs: Fix memory leaks), fixes were made to
grub_affs_iterate_dir() to prevent memory leaks from occurring after it
returns without freeing node. However, there were still some instances
where node was causing a memory leak when the function returns after
calling grub_affs_create_node(). In this function, new memory is
allocated to node but doesn't get freed until the hook() function is
called near the end. Before hook() is called, node should be freed in
grub_affs_create_node() before returning out of it.

Fixes: 178ac5107389 (affs: Fix memory leaks)
Fixes: CID 73759
Signed-off-by: Alec Brown <alec.r.brown@oracle.com>
Reviewed-by: Darren Kenny <darren.kenny@oracle.com>
Reviewed-by: Daniel Kiper <daniel.kiper@oracle.com>
grub-core/fs/affs.c

index cafcd0fba916d4df59541967af55dc85322f3f10..7b9e62064e1dc5fa3a699d7ba3cc7388fa5230e2 100644 (file)
@@ -370,17 +370,26 @@ grub_affs_create_node (grub_fshelp_node_t dir,
                                  GRUB_DISK_SECTOR_SIZE - GRUB_AFFS_FILE_LOCATION,
                                  sizeof ((*node)->di), (char *) &(*node)->di);
            if (err)
-             return 1;
+             {
+               grub_free (*node);
+               return 1;
+             }
            continue;
          }
        default:
-         return 0;
+         {
+           grub_free (*node);
+           return 0;
+         }
        }
       break;
     }
 
   if (nest == 8)
-    return 0;
+    {
+      grub_free (*node);
+      return 0;
+    }
 
   type |= GRUB_FSHELP_CASE_INSENSITIVE;