{
    "version": 1,
    "title": "KASAN: use-after-free Read in mas_next_entry",
    "display-title": "KASAN: use-after-free Read in mas_next_entry",
    "id": "1a351beaed9d438481f1fc96aa336a25f71a2ae1",
    "status": "fixed",
    "fix-commits": [
        {
            "title": "fs/userfaultfd: Fix maple tree iterator in userfaultfd_unregister()",
            "link": "https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=59f2f4b8a757412fce372f6d0767bdb55da127a8",
            "hash": "59f2f4b8a757412fce372f6d0767bdb55da127a8",
            "repo": "git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git",
            "branch": "master"
        }
    ],
    "discussions": [
        "https://lore.kernel.org/all/0000000000002bcfe805ebadbe9c@google.com/T/",
        "https://lore.kernel.org/all/20221107201121.1169273-1-Liam.Howlett@oracle.com/T/"
    ],
    "crashes": [
        {
            "title": "KASAN: use-after-free Read in mas_next_entry",
            "syz-reproducer": "/text?tag=ReproSyz&x=103d4bc2880000",
            "c-reproducer": "/text?tag=ReproC&x=100e4926880000",
            "kernel-config": "/text?tag=KernelConfig&x=4789759e8a6d5f57",
            "kernel-source-git": "https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/log/?id=4da34b7d175dc99b8befebd69e96546c960d526c",
            "kernel-source-commit": "4da34b7d175dc99b8befebd69e96546c960d526c",
            "syzkaller-git": "https://github.com/google/syzkaller/commits/c0b80a55c9c8cfe75e77c555ed0d4ae7aa373cc2",
            "syzkaller-commit": "c0b80a55c9c8cfe75e77c555ed0d4ae7aa373cc2",
            "compiler-description": "Debian clang version 13.0.1-++20220126092033+75e33f71c2da-1~exp1~20220126212112.63, GNU ld (GNU Binutils for Debian) 2.35.2",
            "architecture": "amd64",
            "crash-report-link": "/text?tag=CrashReport&x=14cbbb72880000"
        }
    ],
    "patch_modified_functions": [
        [
            "userfaultfd_unregister",
            "fs/userfaultfd.c"
        ]
    ],
    "patch_commit_date": "2022-11-07T20:11:42+00:00",
    "cause_commit_date": null,
    "subsystems": [
        "fs"
    ],
    "parent_of_fix_commit": "a1de832bd3243577de365222d8bc92708005ebf3",
    "patch": "diff --git a/fs/userfaultfd.c b/fs/userfaultfd.c\nindex 07c81ab3fd4d..98ac37e34e3d 100644\n--- a/fs/userfaultfd.c\n+++ b/fs/userfaultfd.c\n@@ -1630,17 +1630,20 @@ static int userfaultfd_unregister(struct userfaultfd_ctx *ctx,\n \t\t\t\t NULL_VM_UFFD_CTX, anon_vma_name(vma));\n \t\tif (prev) {\n \t\t\tvma = prev;\n+\t\t\tmas_pause(&mas);\n \t\t\tgoto next;\n \t\t}\n \t\tif (vma->vm_start < start) {\n \t\t\tret = split_vma(mm, vma, start, 1);\n \t\t\tif (ret)\n \t\t\t\tbreak;\n+\t\t\tmas_pause(&mas);\n \t\t}\n \t\tif (vma->vm_end > end) {\n \t\t\tret = split_vma(mm, vma, end, 0);\n \t\t\tif (ret)\n \t\t\t\tbreak;\n+\t\t\tmas_pause(&mas);\n \t\t}\n \tnext:\n \t\t/*\n",
    "patch_modified_files": [
        "fs/userfaultfd.c"
    ]
}