{
    "version": 1,
    "title": "WARNING: kmalloc bug in xdp_umem_create",
    "display-title": "WARNING: kmalloc bug in xdp_umem_create (2)",
    "id": "f7c5a86e747f9b7ce333e7295875cd4ede2c7a0d",
    "status": "fixed",
    "fix-commits": [
        {
            "title": "mm: Consider __GFP_NOWARN flag for oversized kvmalloc() calls",
            "link": "https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=0708a0afe291bdfe1386d74d5ec1f0c27e8b9168",
            "hash": "0708a0afe291bdfe1386d74d5ec1f0c27e8b9168",
            "repo": "git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git",
            "branch": "master"
        }
    ],
    "cause-commit": {
        "title": "mm: don't allow oversized kvmalloc() calls",
        "link": "https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=7661809d493b426e979f39ab512e3adf41fbcc69",
        "hash": "7661809d493b426e979f39ab512e3adf41fbcc69",
        "repo": "git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git",
        "branch": "master"
    },
    "discussions": [
        "https://lore.kernel.org/all/000000000000a3571605d27817b5@google.com/T/",
        "https://lore.kernel.org/all/20220307091644.179885033@linuxfoundation.org/T/",
        "https://lore.kernel.org/all/20220307091654.092878898@linuxfoundation.org/T/",
        "https://lore.kernel.org/all/20220307091702.378509770@linuxfoundation.org/T/",
        "https://lore.kernel.org/all/8a99a175d25f4bcce6b78cee8fa536e40b987b0a.1646403182.git.daniel@iogearbox.net/T/"
    ],
    "crashes": [
        {
            "title": "WARNING: kmalloc bug in xdp_umem_create",
            "syz-reproducer": "/text?tag=ReproSyz&x=12e514a4700000",
            "c-reproducer": "/text?tag=ReproC&x=15fcdf8a700000",
            "kernel-config": "/text?tag=KernelConfig&x=5707221760c00a20",
            "kernel-source-git": "https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/log/?id=f4bc5bbb5fef3cf421ba3485d6d383c27ec473ed",
            "kernel-source-commit": "f4bc5bbb5fef3cf421ba3485d6d383c27ec473ed",
            "syzkaller-git": "https://github.com/google/syzkaller/commits/0b33604d8e2793b82ec89abecf82d92b82e3d410",
            "syzkaller-commit": "0b33604d8e2793b82ec89abecf82d92b82e3d410",
            "compiler-description": "gcc (Debian 10.2.1-6) 10.2.1 20210110, GNU ld (GNU Binutils for Debian) 2.35.2",
            "architecture": "amd64",
            "crash-report-link": "/text?tag=CrashReport&x=1670f428700000"
        }
    ],
    "patch_modified_functions": [
        [
            "kvmalloc_node",
            "mm/util.c"
        ]
    ],
    "cause_modified_functions": [
        [
            "kvmalloc_node",
            "mm/util.c"
        ]
    ],
    "patch_commit_date": "2022-03-04T14:26:32+00:00",
    "cause_commit_date": "2021-07-14T16:45:49+00:00",
    "subsystems": [
        "bpf",
        "net"
    ],
    "parent_of_fix_commit": "38f80f42147ff658aff218edb0a88c37e58bf44f",
    "patch": "diff --git a/mm/util.c b/mm/util.c\nindex 7e43369064c8..d3102081add0 100644\n--- a/mm/util.c\n+++ b/mm/util.c\n@@ -587,8 +587,10 @@ void *kvmalloc_node(size_t size, gfp_t flags, int node)\n \t\treturn ret;\n \n \t/* Don't even allow crazy sizes */\n-\tif (WARN_ON_ONCE(size > INT_MAX))\n+\tif (unlikely(size > INT_MAX)) {\n+\t\tWARN_ON_ONCE(!(flags & __GFP_NOWARN));\n \t\treturn NULL;\n+\t}\n \n \treturn __vmalloc_node(size, 1, flags, node,\n \t\t\t__builtin_return_address(0));\n",
    "patch_modified_files": [
        "mm/util.c"
    ]
}