]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
ntfs: add bounds check before accessing EA entries
authorHyunchul Lee <hyc.lee@gmail.com>
Sat, 23 May 2026 04:14:23 +0000 (13:14 +0900)
committerNamjae Jeon <linkinjeon@kernel.org>
Fri, 5 Jun 2026 15:19:59 +0000 (00:19 +0900)
in ntfs_ea_lookup and ntfs_listxattr, this verifies that there is enough
space in the EA entry before accessing the next_entry_offset field of
the EA entry.

Cc: stable@vger.kernel.org # v7.1
Signed-off-by: Hyunchul Lee <hyc.lee@gmail.com>
Signed-off-by: Namjae Jeon <linkinjeon@kernel.org>
fs/ntfs/ea.c

index c4a4a3e3e599667e849af31c92ea19af3d10b2c3..0cd192752b7cd72dd4cc180045b69d0d9833e765 100644 (file)
@@ -53,11 +53,11 @@ static int ntfs_ea_lookup(char *ea_buf, s64 ea_buf_size, const char *name,
        loff_t offset, p_ea_size;
        unsigned int next;
 
-       if (ea_buf_size < sizeof(struct ea_attr))
-               goto out;
-
        offset = 0;
        do {
+               if (ea_buf_size - offset < sizeof(struct ea_attr))
+                       break;
+
                p_ea = (const struct ea_attr *)&ea_buf[offset];
                next = le32_to_cpu(p_ea->next_entry_offset);
                p_ea_size = next ? next : (ea_buf_size - offset);
@@ -479,13 +479,13 @@ ssize_t ntfs_listxattr(struct dentry *dentry, char *buffer, size_t size)
        if (ea_info_qsize > ea_buf_size || ea_info_qsize == 0)
                goto out;
 
-       if (ea_info_qsize < sizeof(struct ea_attr)) {
-               err = -EIO;
-               goto out;
-       }
-
        offset = 0;
        do {
+               if (ea_info_qsize - offset < sizeof(struct ea_attr)) {
+                       err = -EIO;
+                       goto out;
+               }
+
                p_ea = (const struct ea_attr *)&ea_buf[offset];
                next = le32_to_cpu(p_ea->next_entry_offset);
                ea_size = next ? next : (ea_info_qsize - offset);