Blame SOURCES/0242-fs-f2fs-Do-not-copy-file-names-that-are-too-long.patch

fd0330
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
fd0330
From: Sudhakar Kuppusamy <sudhakar@linux.ibm.com>
fd0330
Date: Wed, 6 Apr 2022 18:17:43 +0530
fd0330
Subject: [PATCH] fs/f2fs: Do not copy file names that are too long
fd0330
fd0330
A corrupt f2fs file system might specify a name length which is greater
fd0330
than the maximum name length supported by the GRUB f2fs driver.
fd0330
fd0330
We will allocate enough memory to store the overly long name, but there
fd0330
are only F2FS_NAME_LEN bytes in the source, so we would read past the end
fd0330
of the source.
fd0330
fd0330
While checking directory entries, do not copy a file name with an invalid
fd0330
length.
fd0330
fd0330
Signed-off-by: Sudhakar Kuppusamy <sudhakar@linux.ibm.com>
fd0330
Signed-off-by: Daniel Axtens <dja@axtens.net>
fd0330
Reviewed-by: Daniel Kiper <daniel.kiper@oracle.com>
fd0330
(cherry picked from commit 9a891f638509e031d322c94e3cbcf38d36f3993a)
fd0330
---
fd0330
 grub-core/fs/f2fs.c | 4 ++++
fd0330
 1 file changed, 4 insertions(+)
fd0330
fd0330
diff --git a/grub-core/fs/f2fs.c b/grub-core/fs/f2fs.c
fd0330
index 8898b235e0..df6beb544c 100644
fd0330
--- a/grub-core/fs/f2fs.c
fd0330
+++ b/grub-core/fs/f2fs.c
fd0330
@@ -1003,6 +1003,10 @@ grub_f2fs_check_dentries (struct grub_f2fs_dir_iter_ctx *ctx)
fd0330
 
fd0330
       ftype = ctx->dentry[i].file_type;
fd0330
       name_len = grub_le_to_cpu16 (ctx->dentry[i].name_len);
fd0330
+
fd0330
+      if (name_len >= F2FS_NAME_LEN)
fd0330
+        return 0;
fd0330
+
fd0330
       filename = grub_malloc (name_len + 1);
fd0330
       if (!filename)
fd0330
         return 0;