{
    "0ec05481e31f2772a2c6f16aecb38f48467da26e": {
        "non_crash": [
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 1971ca325fb4..3507cc48f5cc 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -1744,13 +1744,12 @@ static int check_max_stack_depth(struct bpf_verifier_env *env)\n static int get_callee_stack_depth(struct bpf_verifier_env *env,\n \t\t\t\t  const struct bpf_insn *insn, int idx)\n {\n-\tint start = idx + insn->imm + 1, subprog;\n+\tint start = idx + insn->imm + 1;\n+\tint subprog = find_subprog(env, start);\n \n-\tsubprog = find_subprog(env, start);\n \tif (subprog < 0) {\n-\t\tWARN_ONCE(1, \"verifier bug. No program starts at insn %d\\n\",\n-\t\t\t  start);\n-\t\treturn -EFAULT;\n+\t\tpr_warn(\"No subprogram starts at instruction %d\\n\", start);\n+\t\treturn -EINVAL;\n \t}\n \treturn env->subprog_info[subprog].stack_depth;\n }\n",
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 1971ca325fb4..a210651fecb6 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -1748,9 +1748,8 @@ static int get_callee_stack_depth(struct bpf_verifier_env *env,\n \n \tsubprog = find_subprog(env, start);\n \tif (subprog < 0) {\n-\t\tWARN_ONCE(1, \"verifier bug. No program starts at insn %d\\n\",\n-\t\t\t  start);\n-\t\treturn -EFAULT;\n+\t\tpr_warn(\"BPF verifier: No program starts at insn %d\\n\", start);\n+\t\treturn -EINVAL;\n \t}\n \treturn env->subprog_info[subprog].stack_depth;\n }\n@@ -6032,8 +6031,10 @@ static int fixup_call_args(struct bpf_verifier_env *env)\n \t\t    insn->src_reg != BPF_PSEUDO_CALL)\n \t\t\tcontinue;\n \t\tdepth = get_callee_stack_depth(env, insn, i);\n-\t\tif (depth < 0)\n+\t\tif (depth < 0) {\n+\t\t\tpr_warn(\"BPF verifier: Failed to get callee stack depth at insn %d\\n\", i);\n \t\t\treturn depth;\n+\t\t}\n \t\tbpf_patch_call_args(insn, depth);\n \t}\n \terr = 0;\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 1971ca325fb4..1c5b10754636 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -1746,6 +1746,11 @@ static int get_callee_stack_depth(struct bpf_verifier_env *env,\n {\n \tint start = idx + insn->imm + 1, subprog;\n \n+\tif (start >= env->prog->len) {\n+\t\tWARN_ONCE(1, \"verifier bug. Invalid start index %d\\n\", start);\n+\t\treturn -EFAULT;\n+\t}\n+\n \tsubprog = find_subprog(env, start);\n \tif (subprog < 0) {\n \t\tWARN_ONCE(1, \"verifier bug. No program starts at insn %d\\n\",\n",
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 1971ca325fb4..7b30aa1affc1 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -1746,6 +1746,11 @@ static int get_callee_stack_depth(struct bpf_verifier_env *env,\n {\n \tint start = idx + insn->imm + 1, subprog;\n \n+\tif (start < 0 || start >= env->prog->len) {\n+\t\tWARN_ONCE(1, \"verifier bug. Invalid start index %d\\n\", start);\n+\t\treturn -EFAULT;\n+\t}\n+\n \tsubprog = find_subprog(env, start);\n \tif (subprog < 0) {\n \t\tWARN_ONCE(1, \"verifier bug. No program starts at insn %d\\n\",\n",
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 1971ca325fb4..4f8aef3b6c75 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -1746,6 +1746,12 @@ static int get_callee_stack_depth(struct bpf_verifier_env *env,\n {\n \tint start = idx + insn->imm + 1, subprog;\n \n+\tif (start < 0 || start >= env->prog->len) {\n+\t\tWARN_ONCE(1, \"verifier bug. Invalid program start at insn %d\\n\",\n+\t\t\t  start);\n+\t\treturn -EFAULT;\n+\t}\n+\n \tsubprog = find_subprog(env, start);\n \tif (subprog < 0) {\n \t\tWARN_ONCE(1, \"verifier bug. No program starts at insn %d\\n\",\n"
        ],
        "error": []
    },
    "e2907149c69cbccae0842eb502b8af4f6fac52a0": {
        "non_crash": [
            "diff --git a/fs/xfs/libxfs/xfs_btree.c b/fs/xfs/libxfs/xfs_btree.c\nindex c4649cc624e1..cfc1a36db986 100644\n--- a/fs/xfs/libxfs/xfs_btree.c\n+++ b/fs/xfs/libxfs/xfs_btree.c\n@@ -1810,7 +1810,15 @@ xfs_btree_lookup_get_block(\n \t *\n \t * Otherwise throw it away and get a new one.\n \t */\n+\tif (level < 0 || level >= cur->bc_nlevels) {\n+\t\treturn -EINVAL; // Invalid level\n+\t}\n+\n \tbp = cur->bc_levels[level].bp;\n+\tif (!bp) {\n+\t\treturn -EFAULT; // Uninitialized buffer pointer\n+\t}\n+\n \terror = xfs_btree_ptr_to_daddr(cur, pp, &daddr);\n \tif (error)\n \t\treturn error;\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/xfs/libxfs/xfs_btree.c b/fs/xfs/libxfs/xfs_btree.c\nindex c4649cc624e1..0813993add58 100644\n--- a/fs/xfs/libxfs/xfs_btree.c\n+++ b/fs/xfs/libxfs/xfs_btree.c\n@@ -1810,6 +1810,9 @@ xfs_btree_lookup_get_block(\n \t *\n \t * Otherwise throw it away and get a new one.\n \t */\n+\tif (level < 0 || level >= cur->bc_nlevels) {\n+\t\treturn -EINVAL; // Invalid level, return error\n+\t}\n \tbp = cur->bc_levels[level].bp;\n \terror = xfs_btree_ptr_to_daddr(cur, pp, &daddr);\n \tif (error)\n",
            "diff --git a/fs/xfs/libxfs/xfs_btree.c b/fs/xfs/libxfs/xfs_btree.c\nindex c4649cc624e1..5d5c0619b51c 100644\n--- a/fs/xfs/libxfs/xfs_btree.c\n+++ b/fs/xfs/libxfs/xfs_btree.c\n@@ -1810,6 +1810,9 @@ xfs_btree_lookup_get_block(\n \t *\n \t * Otherwise throw it away and get a new one.\n \t */\n+\tif (level >= cur->bc_nlevels) {\n+\t\treturn -EINVAL; // Invalid level, return error\n+\t}\n \tbp = cur->bc_levels[level].bp;\n \terror = xfs_btree_ptr_to_daddr(cur, pp, &daddr);\n \tif (error)\n",
            "diff --git a/fs/xfs/libxfs/xfs_btree.c b/fs/xfs/libxfs/xfs_btree.c\nindex c4649cc624e1..8849da8e064c 100644\n--- a/fs/xfs/libxfs/xfs_btree.c\n+++ b/fs/xfs/libxfs/xfs_btree.c\n@@ -1810,13 +1810,17 @@ xfs_btree_lookup_get_block(\n \t *\n \t * Otherwise throw it away and get a new one.\n \t */\n-\tbp = cur->bc_levels[level].bp;\n-\terror = xfs_btree_ptr_to_daddr(cur, pp, &daddr);\n-\tif (error)\n-\t\treturn error;\n-\tif (bp && xfs_buf_daddr(bp) == daddr) {\n-\t\t*blkp = XFS_BUF_TO_BLOCK(bp);\n-\t\treturn 0;\n+\tif (level < cur->bc_nlevels && cur->bc_levels[level].bp) {\n+\t\tbp = cur->bc_levels[level].bp;\n+\t\terror = xfs_btree_ptr_to_daddr(cur, pp, &daddr);\n+\t\tif (error)\n+\t\t\treturn error;\n+\t\tif (xfs_buf_daddr(bp) == daddr) {\n+\t\t\t*blkp = XFS_BUF_TO_BLOCK(bp);\n+\t\t\treturn 0;\n+\t\t}\n+\t} else {\n+\t\tbp = NULL;\n \t}\n \n \terror = xfs_btree_read_buf_block(cur, pp, 0, blkp, &bp);\n",
            "diff --git a/fs/xfs/libxfs/xfs_btree.c b/fs/xfs/libxfs/xfs_btree.c\nindex c4649cc624e1..74c3abbbeee4 100644\n--- a/fs/xfs/libxfs/xfs_btree.c\n+++ b/fs/xfs/libxfs/xfs_btree.c\n@@ -1810,6 +1810,9 @@ xfs_btree_lookup_get_block(\n \t *\n \t * Otherwise throw it away and get a new one.\n \t */\n+\tif (level < 0 || level >= cur->bc_nlevels) {\n+\t\treturn -EINVAL; // Invalid level index\n+\t}\n \tbp = cur->bc_levels[level].bp;\n \terror = xfs_btree_ptr_to_daddr(cur, pp, &daddr);\n \tif (error)\n"
        ],
        "error": []
    },
    "0cd33d8e114be941da0773f8980488e1ca71ed58": {
        "non_crash": [
            "diff --git a/net/rxrpc/recvmsg.c b/net/rxrpc/recvmsg.c\nindex eaf19ebaa964..2a8a67e83a88 100644\n--- a/net/rxrpc/recvmsg.c\n+++ b/net/rxrpc/recvmsg.c\n@@ -604,6 +604,7 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n wait_error:\n \tfinish_wait(sk_sleep(&rx->sk), &wait);\n \tcall = NULL;\n+\tlock_sock(&rx->sk);\n \tgoto error_no_call;\n }\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/rxrpc/recvmsg.c b/net/rxrpc/recvmsg.c\nindex eaf19ebaa964..9f0c2de764d3 100644\n--- a/net/rxrpc/recvmsg.c\n+++ b/net/rxrpc/recvmsg.c\n@@ -452,8 +452,7 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \tif (RB_EMPTY_ROOT(&rx->calls) &&\n \t    list_empty(&rx->recvmsg_q) &&\n \t    rx->sk.sk_state != RXRPC_SERVER_LISTENING) {\n-\t\trelease_sock(&rx->sk);\n-\t\treturn -ENODATA;\n+\t\tgoto error_no_call;\n \t}\n \n \tif (list_empty(&rx->recvmsg_q)) {\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/rxrpc/recvmsg.c b/net/rxrpc/recvmsg.c\nindex eaf19ebaa964..c8600ad98d3f 100644\n--- a/net/rxrpc/recvmsg.c\n+++ b/net/rxrpc/recvmsg.c\n@@ -452,7 +452,8 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \tif (RB_EMPTY_ROOT(&rx->calls) &&\n \t    list_empty(&rx->recvmsg_q) &&\n \t    rx->sk.sk_state != RXRPC_SERVER_LISTENING) {\n-\t\trelease_sock(&rx->sk);\n+\t\tif (lockdep_is_held(&rx->sk.lock))\n+\t\t\trelease_sock(&rx->sk);\n \t\treturn -ENODATA;\n \t}\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/rxrpc/recvmsg.c b/net/rxrpc/recvmsg.c\nindex eaf19ebaa964..3e176d6c9046 100644\n--- a/net/rxrpc/recvmsg.c\n+++ b/net/rxrpc/recvmsg.c\n@@ -452,7 +452,9 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \tif (RB_EMPTY_ROOT(&rx->calls) &&\n \t    list_empty(&rx->recvmsg_q) &&\n \t    rx->sk.sk_state != RXRPC_SERVER_LISTENING) {\n-\t\trelease_sock(&rx->sk);\n+\t\tif (lock_sock_nested(&rx->sk, SINGLE_DEPTH_NESTING)) {\n+\t\t\trelease_sock(&rx->sk);\n+\t\t}\n \t\treturn -ENODATA;\n \t}\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/rxrpc/recvmsg.c b/net/rxrpc/recvmsg.c\nindex eaf19ebaa964..d912398351af 100644\n--- a/net/rxrpc/recvmsg.c\n+++ b/net/rxrpc/recvmsg.c\n@@ -452,8 +452,10 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \tif (RB_EMPTY_ROOT(&rx->calls) &&\n \t    list_empty(&rx->recvmsg_q) &&\n \t    rx->sk.sk_state != RXRPC_SERVER_LISTENING) {\n-\t\trelease_sock(&rx->sk);\n-\t\treturn -ENODATA;\n+\t\tif (lock_sock_nested(&rx->sk, SINGLE_DEPTH_NESTING)) {\n+\t\t\trelease_sock(&rx->sk);\n+\t\t\treturn -ENODATA;\n+\t\t}\n \t}\n \n \tif (list_empty(&rx->recvmsg_q)) {\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "949ecf93b67ab1df8f890571d24ef9db50872c96": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/core/dev.c b/net/core/dev.c\nindex a979b86dbacd..0b783e6482c8 100644\n--- a/net/core/dev.c\n+++ b/net/core/dev.c\n@@ -792,7 +792,10 @@ int __init netdev_boot_setup(char *str)\n \t\tmap.mem_end = ints[4];\n \n \t/* Add new entry to the list */\n-\treturn netdev_boot_setup_add(str, &map);\n+\tint ret = netdev_boot_setup_add(str, &map);\n+\tif (ret)\n+\t\tdev_put(dev); // Ensure the device reference is released on failure\n+\treturn ret;\n }\n \n __setup(\"netdev=\", netdev_boot_setup);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/core/dev.c b/net/core/dev.c\nindex a979b86dbacd..87dabfc89a49 100644\n--- a/net/core/dev.c\n+++ b/net/core/dev.c\n@@ -792,7 +792,10 @@ int __init netdev_boot_setup(char *str)\n \t\tmap.mem_end = ints[4];\n \n \t/* Add new entry to the list */\n-\treturn netdev_boot_setup_add(str, &map);\n+\tint ret = netdev_boot_setup_add(str, &map);\n+\tif (ret)\n+\t\tdev_put(dev); // Hypothetical function to decrement the reference count\n+\treturn ret;\n }\n \n __setup(\"netdev=\", netdev_boot_setup);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/core/dev.c b/net/core/dev.c\nindex a979b86dbacd..eb79ca9e19da 100644\n--- a/net/core/dev.c\n+++ b/net/core/dev.c\n@@ -792,7 +792,10 @@ int __init netdev_boot_setup(char *str)\n \t\tmap.mem_end = ints[4];\n \n \t/* Add new entry to the list */\n-\treturn netdev_boot_setup_add(str, &map);\n+\tint ret = netdev_boot_setup_add(str, &map);\n+\tif (ret)\n+\t\tdev_put(dev); // Ensure reference count is decremented on failure\n+\treturn ret;\n }\n \n __setup(\"netdev=\", netdev_boot_setup);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/core/dev.c b/net/core/dev.c\nindex a979b86dbacd..44e683e6c43c 100644\n--- a/net/core/dev.c\n+++ b/net/core/dev.c\n@@ -792,7 +792,10 @@ int __init netdev_boot_setup(char *str)\n \t\tmap.mem_end = ints[4];\n \n \t/* Add new entry to the list */\n-\treturn netdev_boot_setup_add(str, &map);\n+\tint ret = netdev_boot_setup_add(str, &map);\n+\tif (ret)\n+\t\tdev_put(dev); // Hypothetical function to release the device reference\n+\treturn ret;\n }\n \n __setup(\"netdev=\", netdev_boot_setup);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/core/dev.c b/net/core/dev.c\nindex a979b86dbacd..5c69f3e96901 100644\n--- a/net/core/dev.c\n+++ b/net/core/dev.c\n@@ -792,7 +792,10 @@ int __init netdev_boot_setup(char *str)\n \t\tmap.mem_end = ints[4];\n \n \t/* Add new entry to the list */\n-\treturn netdev_boot_setup_add(str, &map);\n+\tint ret = netdev_boot_setup_add(str, &map);\n+\tif (ret)\n+\t\tdev_put(dev); // Ensure the device is released if setup fails\n+\treturn ret;\n }\n \n __setup(\"netdev=\", netdev_boot_setup);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "2db2545ff94291fabe4a5dd4ee182db44ef35d4b": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/drivers/hid/uhid.c b/drivers/hid/uhid.c\nindex 3c5507313606..0f97329e3199 100644\n--- a/drivers/hid/uhid.c\n+++ b/drivers/hid/uhid.c\n@@ -539,7 +539,8 @@ static int uhid_dev_create(struct uhid_device *uhid,\n \n \tif (orig.rd_size <= 0 || orig.rd_size > HID_MAX_DESCRIPTOR_SIZE)\n \t\treturn -EINVAL;\n-\tif (copy_from_user(&ev->u.create2.rd_data, orig.rd_data, orig.rd_size))\n+\tif (!access_ok(orig.rd_data, orig.rd_size) ||\n+\t    copy_from_user(&ev->u.create2.rd_data, orig.rd_data, orig.rd_size))\n \t\treturn -EFAULT;\n \n \tmemcpy(ev->u.create2.name, orig.name, sizeof(orig.name));\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/hid/uhid.c b/drivers/hid/uhid.c\nindex 3c5507313606..d6606a69ae73 100644\n--- a/drivers/hid/uhid.c\n+++ b/drivers/hid/uhid.c\n@@ -539,7 +539,8 @@ static int uhid_dev_create(struct uhid_device *uhid,\n \n \tif (orig.rd_size <= 0 || orig.rd_size > HID_MAX_DESCRIPTOR_SIZE)\n \t\treturn -EINVAL;\n-\tif (copy_from_user(&ev->u.create2.rd_data, orig.rd_data, orig.rd_size))\n+\tif (!orig.rd_data || !access_ok(orig.rd_data, orig.rd_size) ||\n+\t    copy_from_user(&ev->u.create2.rd_data, orig.rd_data, orig.rd_size))\n \t\treturn -EFAULT;\n \n \tmemcpy(ev->u.create2.name, orig.name, sizeof(orig.name));\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/hid/uhid.c b/drivers/hid/uhid.c\nindex 3c5507313606..0f97329e3199 100644\n--- a/drivers/hid/uhid.c\n+++ b/drivers/hid/uhid.c\n@@ -539,7 +539,8 @@ static int uhid_dev_create(struct uhid_device *uhid,\n \n \tif (orig.rd_size <= 0 || orig.rd_size > HID_MAX_DESCRIPTOR_SIZE)\n \t\treturn -EINVAL;\n-\tif (copy_from_user(&ev->u.create2.rd_data, orig.rd_data, orig.rd_size))\n+\tif (!access_ok(orig.rd_data, orig.rd_size) ||\n+\t    copy_from_user(&ev->u.create2.rd_data, orig.rd_data, orig.rd_size))\n \t\treturn -EFAULT;\n \n \tmemcpy(ev->u.create2.name, orig.name, sizeof(orig.name));\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/hid/uhid.c b/drivers/hid/uhid.c\nindex 3c5507313606..0f97329e3199 100644\n--- a/drivers/hid/uhid.c\n+++ b/drivers/hid/uhid.c\n@@ -539,7 +539,8 @@ static int uhid_dev_create(struct uhid_device *uhid,\n \n \tif (orig.rd_size <= 0 || orig.rd_size > HID_MAX_DESCRIPTOR_SIZE)\n \t\treturn -EINVAL;\n-\tif (copy_from_user(&ev->u.create2.rd_data, orig.rd_data, orig.rd_size))\n+\tif (!access_ok(orig.rd_data, orig.rd_size) ||\n+\t    copy_from_user(&ev->u.create2.rd_data, orig.rd_data, orig.rd_size))\n \t\treturn -EFAULT;\n \n \tmemcpy(ev->u.create2.name, orig.name, sizeof(orig.name));\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/hid/uhid.c b/drivers/hid/uhid.c\nindex 3c5507313606..0f97329e3199 100644\n--- a/drivers/hid/uhid.c\n+++ b/drivers/hid/uhid.c\n@@ -539,7 +539,8 @@ static int uhid_dev_create(struct uhid_device *uhid,\n \n \tif (orig.rd_size <= 0 || orig.rd_size > HID_MAX_DESCRIPTOR_SIZE)\n \t\treturn -EINVAL;\n-\tif (copy_from_user(&ev->u.create2.rd_data, orig.rd_data, orig.rd_size))\n+\tif (!access_ok(orig.rd_data, orig.rd_size) ||\n+\t    copy_from_user(&ev->u.create2.rd_data, orig.rd_data, orig.rd_size))\n \t\treturn -EFAULT;\n \n \tmemcpy(ev->u.create2.name, orig.name, sizeof(orig.name));\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "a59816f87c8e514d1b5ed891ae85341fbef1e553": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/iomap/direct-io.c b/fs/iomap/direct-io.c\nindex 62da020d02a1..89150dc5749f 100644\n--- a/fs/iomap/direct-io.c\n+++ b/fs/iomap/direct-io.c\n@@ -654,7 +654,7 @@ __iomap_dio_rw(struct kiocb *iocb, struct iov_iter *iter,\n \t\t\t\tbreak;\n \n \t\t\tif (!dio->submit.poll_bio ||\n-\t\t\t    !bio_poll(dio->submit.poll_bio, NULL, 0))\n+\t\t\t    (dio->submit.poll_bio && !bio_poll(dio->submit.poll_bio, NULL, 0)))\n \t\t\t\tblk_io_schedule();\n \t\t}\n \t\t__set_current_state(TASK_RUNNING);\n",
            "diff --git a/fs/iomap/direct-io.c b/fs/iomap/direct-io.c\nindex 62da020d02a1..4e78d95e4d89 100644\n--- a/fs/iomap/direct-io.c\n+++ b/fs/iomap/direct-io.c\n@@ -654,6 +654,7 @@ __iomap_dio_rw(struct kiocb *iocb, struct iov_iter *iter,\n \t\t\t\tbreak;\n \n \t\t\tif (!dio->submit.poll_bio ||\n+\t\t\t    page_ref_count(virt_to_page(dio->submit.poll_bio)) == 0 ||\n \t\t\t    !bio_poll(dio->submit.poll_bio, NULL, 0))\n \t\t\t\tblk_io_schedule();\n \t\t}\n",
            "diff --git a/fs/iomap/direct-io.c b/fs/iomap/direct-io.c\nindex 62da020d02a1..643bcfbf23d5 100644\n--- a/fs/iomap/direct-io.c\n+++ b/fs/iomap/direct-io.c\n@@ -653,7 +653,8 @@ __iomap_dio_rw(struct kiocb *iocb, struct iov_iter *iter,\n \t\t\tif (!READ_ONCE(dio->submit.waiter))\n \t\t\t\tbreak;\n \n-\t\t\tif (!dio->submit.poll_bio ||\n+\t\t\tif (dio->submit.poll_bio &&\n+\t\t\t    page_ref_count(dio->submit.poll_bio->bi_io_vec->bv_page) > 0 &&\n \t\t\t    !bio_poll(dio->submit.poll_bio, NULL, 0))\n \t\t\t\tblk_io_schedule();\n \t\t}\n"
        ],
        "error": [
            {
                "patch": "diff --git a/block/blk-core.c b/block/blk-core.c\nindex f305cb66c72a..87ec2f457a85 100644\n--- a/block/blk-core.c\n+++ b/block/blk-core.c\n@@ -946,6 +946,10 @@ int bio_poll(struct bio *bio, struct io_comp_batch *iob, unsigned int flags)\n \tblk_qc_t cookie = READ_ONCE(bio->bi_cookie);\n \tint ret = 0;\n \n+\t/* Ensure bio is still valid by checking its reference count */\n+\tif (refcount_read(&bio->bi_cnt) <= 0)\n+\t\treturn 0;\n+\n \tif (cookie == BLK_QC_T_NONE ||\n \t    !test_bit(QUEUE_FLAG_POLL, &q->queue_flags))\n \t\treturn 0;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/block/blk-core.c b/block/blk-core.c\nindex f305cb66c72a..42871b3650da 100644\n--- a/block/blk-core.c\n+++ b/block/blk-core.c\n@@ -942,17 +942,27 @@ EXPORT_SYMBOL(submit_bio);\n  */\n int bio_poll(struct bio *bio, struct io_comp_batch *iob, unsigned int flags)\n {\n-\tstruct request_queue *q = bdev_get_queue(bio->bi_bdev);\n-\tblk_qc_t cookie = READ_ONCE(bio->bi_cookie);\n+\tstruct request_queue *q;\n+\tblk_qc_t cookie;\n \tint ret = 0;\n \n+\t/* Ensure bio is valid */\n+\tif (!bio || !bio_tryget(bio))\n+\t\treturn 0;\n+\n+\tq = bdev_get_queue(bio->bi_bdev);\n+\tcookie = READ_ONCE(bio->bi_cookie);\n+\n \tif (cookie == BLK_QC_T_NONE ||\n-\t    !test_bit(QUEUE_FLAG_POLL, &q->queue_flags))\n+\t    !test_bit(QUEUE_FLAG_POLL, &q->queue_flags)) {\n+\t\tbio_put(bio);\n \t\treturn 0;\n+\t}\n \n \tblk_flush_plug(current->plug, false);\n \n-\tif (blk_queue_enter(q, BLK_MQ_REQ_NOWAIT))\n+\tif (blk_queue_enter(q, BLK_MQ_REQ_NOWAIT)) {\n+\t\tbio_put(bio);\n \t\treturn 0;\n \tif (queue_is_mq(q)) {\n \t\tret = blk_mq_poll(q, cookie, iob, flags);\ndiff --git a/fs/iomap/direct-io.c b/fs/iomap/direct-io.c\nindex 62da020d02a1..bfde51e3ed14 100644\n--- a/fs/iomap/direct-io.c\n+++ b/fs/iomap/direct-io.c\n@@ -654,8 +654,12 @@ __iomap_dio_rw(struct kiocb *iocb, struct iov_iter *iter,\n \t\t\t\tbreak;\n \n \t\t\tif (!dio->submit.poll_bio ||\n-\t\t\t    !bio_poll(dio->submit.poll_bio, NULL, 0))\n+\t\t\t    !bio_tryget(dio->submit.poll_bio) ||\n+\t\t\t    !bio_poll(dio->submit.poll_bio, NULL, 0)) {\n+\t\t\t\tif (dio->submit.poll_bio)\n+\t\t\t\t\tbio_put(dio->submit.poll_bio);\n \t\t\t\tblk_io_schedule();\n+\t\t\t}\n \t\t}\n \t\t__set_current_state(TASK_RUNNING);\n \t}\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "4892aaa2ef26ab83c6b974f1db422f526f9aaec0": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/video/fbdev/core/sysfillrect.c b/drivers/video/fbdev/core/sysfillrect.c\nindex 33ee3d34f9d2..d9a72ecac2b8 100644\n--- a/drivers/video/fbdev/core/sysfillrect.c\n+++ b/drivers/video/fbdev/core/sysfillrect.c\n@@ -49,20 +49,22 @@ bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\t}\n \n \t\t/* Main chunk */\n-\t\tn /= bits;\n-\t\twhile (n >= 8) {\n-\t\t\t*dst++ = pat;\n-\t\t\t*dst++ = pat;\n-\t\t\t*dst++ = pat;\n-\t\t\t*dst++ = pat;\n-\t\t\t*dst++ = pat;\n-\t\t\t*dst++ = pat;\n-\t\t\t*dst++ = pat;\n-\t\t\t*dst++ = pat;\n-\t\t\tn -= 8;\n+\t\tn = n / bits;\n+\t\tif (n > 0) {\n+\t\t\twhile (n >= 8) {\n+\t\t\t\t*dst++ = pat;\n+\t\t\t\t*dst++ = pat;\n+\t\t\t\t*dst++ = pat;\n+\t\t\t\t*dst++ = pat;\n+\t\t\t\t*dst++ = pat;\n+\t\t\t\t*dst++ = pat;\n+\t\t\t\t*dst++ = pat;\n+\t\t\t\t*dst++ = pat;\n+\t\t\t\tn -= 8;\n+\t\t\t}\n+\t\t\twhile (n--)\n+\t\t\t\t*dst++ = pat;\n \t\t}\n-\t\twhile (n--)\n-\t\t\t*dst++ = pat;\n \t\t/* Trailing bits */\n \t\tif (last)\n \t\t\t*dst = comp(pat, *dst, last);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/video/fbdev/core/sysfillrect.c b/drivers/video/fbdev/core/sysfillrect.c\nindex 33ee3d34f9d2..2bdf73726221 100644\n--- a/drivers/video/fbdev/core/sysfillrect.c\n+++ b/drivers/video/fbdev/core/sysfillrect.c\n@@ -51,18 +51,28 @@ bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\t/* Main chunk */\n \t\tn /= bits;\n \t\twhile (n >= 8) {\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n \t\t\tn -= 8;\n \t\t}\n-\t\twhile (n--)\n+\t\twhile (n--) {\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t}\n \t\t/* Trailing bits */\n \t\tif (last)\n \t\t\t*dst = comp(pat, *dst, last);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/video/fbdev/core/sysfillrect.c b/drivers/video/fbdev/core/sysfillrect.c\nindex 33ee3d34f9d2..2bdf73726221 100644\n--- a/drivers/video/fbdev/core/sysfillrect.c\n+++ b/drivers/video/fbdev/core/sysfillrect.c\n@@ -51,18 +51,28 @@ bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\t/* Main chunk */\n \t\tn /= bits;\n \t\twhile (n >= 8) {\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n \t\t\tn -= 8;\n \t\t}\n-\t\twhile (n--)\n+\t\twhile (n--) {\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t}\n \t\t/* Trailing bits */\n \t\tif (last)\n \t\t\t*dst = comp(pat, *dst, last);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/video/fbdev/core/sysfillrect.c b/drivers/video/fbdev/core/sysfillrect.c\nindex 33ee3d34f9d2..2bdf73726221 100644\n--- a/drivers/video/fbdev/core/sysfillrect.c\n+++ b/drivers/video/fbdev/core/sysfillrect.c\n@@ -51,18 +51,28 @@ bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\t/* Main chunk */\n \t\tn /= bits;\n \t\twhile (n >= 8) {\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n \t\t\tn -= 8;\n \t\t}\n-\t\twhile (n--)\n+\t\twhile (n--) {\n+\t\t\tif (dst >= dst_end) break;\n \t\t\t*dst++ = pat;\n+\t\t}\n \t\t/* Trailing bits */\n \t\tif (last)\n \t\t\t*dst = comp(pat, *dst, last);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/video/fbdev/core/sysfillrect.c b/drivers/video/fbdev/core/sysfillrect.c\nindex 33ee3d34f9d2..80460c8e4e74 100644\n--- a/drivers/video/fbdev/core/sysfillrect.c\n+++ b/drivers/video/fbdev/core/sysfillrect.c\n@@ -50,7 +50,7 @@ bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \n \t\t/* Main chunk */\n \t\tn /= bits;\n-\t\twhile (n >= 8) {\n+\t\twhile (n >= 8 && dst < dst_end) {\n \t\t\t*dst++ = pat;\n \t\t\t*dst++ = pat;\n \t\t\t*dst++ = pat;\n@@ -61,7 +61,7 @@ bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\t\t*dst++ = pat;\n \t\t\tn -= 8;\n \t\t}\n-\t\twhile (n--)\n+\t\twhile (n-- && dst < dst_end)\n \t\t\t*dst++ = pat;\n \t\t/* Trailing bits */\n \t\tif (last)\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "02617ac69815ae324053c954118c2dc7ba0e59b2": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/tls/tls_sw.c b/net/tls/tls_sw.c\nindex 0024a692f0f8..fd2462820d04 100644\n--- a/net/tls/tls_sw.c\n+++ b/net/tls/tls_sw.c\n@@ -2523,7 +2523,7 @@ int tls_set_sw_offload(struct sock *sk, struct tls_context *ctx, int tx)\n \t\t\t      prot->tag_size + prot->tail_size;\n \tprot->iv_size = iv_size;\n \tprot->salt_size = salt_size;\n-\tcctx->iv = kmalloc(iv_size + salt_size, GFP_KERNEL);\n+\tcctx->iv = kmalloc(iv_size + salt_size + prot->salt_size, GFP_KERNEL);\n \tif (!cctx->iv) {\n \t\trc = -ENOMEM;\n \t\tgoto free_priv;\n",
            "diff --git a/net/tls/tls_sw.c b/net/tls/tls_sw.c\nindex 0024a692f0f8..7e21c13a0715 100644\n--- a/net/tls/tls_sw.c\n+++ b/net/tls/tls_sw.c\n@@ -2523,7 +2523,7 @@ int tls_set_sw_offload(struct sock *sk, struct tls_context *ctx, int tx)\n \t\t\t      prot->tag_size + prot->tail_size;\n \tprot->iv_size = iv_size;\n \tprot->salt_size = salt_size;\n-\tcctx->iv = kmalloc(iv_size + salt_size, GFP_KERNEL);\n+\tcctx->iv = kmalloc(iv_size + salt_size + prot->iv_size, GFP_KERNEL);\n \tif (!cctx->iv) {\n \t\trc = -ENOMEM;\n \t\tgoto free_priv;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/tls/tls_sw.c b/net/tls/tls_sw.c\nindex 0024a692f0f8..db3acbcdeb70 100644\n--- a/net/tls/tls_sw.c\n+++ b/net/tls/tls_sw.c\n@@ -1498,7 +1498,12 @@ static int decrypt_internal(struct sock *sk, struct sk_buff *skb,\n \t\tmemcpy(iv + iv_offset, tls_ctx->rx.iv,\n \t\t       crypto_aead_ivsize(ctx->aead_recv));\n \telse\n+\t\tif (iv_offset + prot->salt_size <= iv_size + salt_size) {\n \t\tmemcpy(iv + iv_offset, tls_ctx->rx.iv, prot->salt_size);\n+\t} else {\n+\t\tkfree(mem);\n+\t\treturn -EINVAL; // Return an error if the offset exceeds buffer size\n+\t}\n \n \txor_iv_with_seq(prot, iv + iv_offset, tls_ctx->rx.rec_seq);\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/tls/tls_sw.c b/net/tls/tls_sw.c\nindex 0024a692f0f8..a7dd51ded273 100644\n--- a/net/tls/tls_sw.c\n+++ b/net/tls/tls_sw.c\n@@ -1495,8 +1495,7 @@ static int decrypt_internal(struct sock *sk, struct sk_buff *skb,\n \t}\n \tif (prot->version == TLS_1_3_VERSION ||\n \t    prot->cipher_type == TLS_CIPHER_CHACHA20_POLY1305)\n-\t\tmemcpy(iv + iv_offset, tls_ctx->rx.iv,\n-\t\t       crypto_aead_ivsize(ctx->aead_recv));\n+\t\tmemcpy(iv + iv_offset, tls_ctx->rx.iv, iv_size);\n \telse\n \t\tmemcpy(iv + iv_offset, tls_ctx->rx.iv, prot->salt_size);\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "ffb9228cab75ad9d812af93d19e9637873d18439": {
        "non_crash": [
            "diff --git a/net/ipv4/ip_gre.c b/net/ipv4/ip_gre.c\nindex 7e474a85deaf..0c9b460dfd1e 100644\n--- a/net/ipv4/ip_gre.c\n+++ b/net/ipv4/ip_gre.c\n@@ -636,7 +636,7 @@ static netdev_tx_t ipgre_xmit(struct sk_buff *skb,\n \n \t\ttnl_params = (const struct iphdr *)skb->data;\n \n-\t\tif (pull_len > skb_transport_offset(skb))\n+\t\tif (skb_transport_header_was_set(skb) && pull_len > skb_transport_offset(skb))\n \t\t\tgoto free_skb;\n \n \t\t/* Pull skb since ip_tunnel_xmit() needs skb->data pointing\n",
            "diff --git a/net/ipv4/ip_gre.c b/net/ipv4/ip_gre.c\nindex 7e474a85deaf..e0d988d314af 100644\n--- a/net/ipv4/ip_gre.c\n+++ b/net/ipv4/ip_gre.c\n@@ -636,7 +636,7 @@ static netdev_tx_t ipgre_xmit(struct sk_buff *skb,\n \n \t\ttnl_params = (const struct iphdr *)skb->data;\n \n-\t\tif (pull_len > skb_transport_offset(skb))\n+\t\tif (!skb_transport_header_was_set(skb) || pull_len > skb_transport_offset(skb))\n \t\t\tgoto free_skb;\n \n \t\t/* Pull skb since ip_tunnel_xmit() needs skb->data pointing\n",
            "diff --git a/net/ipv4/ip_gre.c b/net/ipv4/ip_gre.c\nindex 7e474a85deaf..017b2bcd0b6e 100644\n--- a/net/ipv4/ip_gre.c\n+++ b/net/ipv4/ip_gre.c\n@@ -636,6 +636,9 @@ static netdev_tx_t ipgre_xmit(struct sk_buff *skb,\n \n \t\ttnl_params = (const struct iphdr *)skb->data;\n \n+\t\tif (!skb_transport_header_was_set(skb))\n+\t\t\tskb_set_transport_header(skb, pull_len);\n+\n \t\tif (pull_len > skb_transport_offset(skb))\n \t\t\tgoto free_skb;\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/ipv4/ip_gre.c b/net/ipv4/ip_gre.c\nindex 7e474a85deaf..14bb8d144ffe 100644\n--- a/net/ipv4/ip_gre.c\n+++ b/net/ipv4/ip_gre.c\n@@ -636,7 +636,7 @@ static netdev_tx_t ipgre_xmit(struct sk_buff *skb,\n \n \t\ttnl_params = (const struct iphdr *)skb->data;\n \n-\t\tif (pull_len > skb_transport_offset(skb))\n+\t\tif (!pskb_may_pull(skb, pull_len) || pull_len > skb_transport_offset(skb))\n \t\t\tgoto free_skb;\n \n \t\t/* Pull skb since ip_tunnel_xmit() needs skb->data pointing\n",
            "diff --git a/net/ipv4/ip_gre.c b/net/ipv4/ip_gre.c\nindex 7e474a85deaf..6790b68388fd 100644\n--- a/net/ipv4/ip_gre.c\n+++ b/net/ipv4/ip_gre.c\n@@ -636,7 +636,7 @@ static netdev_tx_t ipgre_xmit(struct sk_buff *skb,\n \n \t\ttnl_params = (const struct iphdr *)skb->data;\n \n-\t\tif (pull_len > skb_transport_offset(skb))\n+\t\tif (pull_len >= skb_transport_offset(skb))\n \t\t\tgoto free_skb;\n \n \t\t/* Pull skb since ip_tunnel_xmit() needs skb->data pointing\n"
        ],
        "error": []
    },
    "6922c8c31f1fdd120d1cef3f58b319b6dd1d8c00": {
        "non_crash": [
            "diff --git a/drivers/misc/vmw_vmci/vmci_queue_pair.c b/drivers/misc/vmw_vmci/vmci_queue_pair.c\nindex 8531ae781195..b1489517d711 100644\n--- a/drivers/misc/vmw_vmci/vmci_queue_pair.c\n+++ b/drivers/misc/vmw_vmci/vmci_queue_pair.c\n@@ -657,8 +657,10 @@ static int qp_host_get_user_memory(u64 produce_uva,\n \tif (retval < (int)produce_q->kernel_if->num_pages) {\n \t\tpr_debug(\"get_user_pages_fast(produce) failed (retval=%d)\",\n \t\t\tretval);\n-\t\tqp_release_pages(produce_q->kernel_if->u.h.header_page,\n-\t\t\t\t retval, false);\n+\t\tif (retval > 0) {\n+\t\t\tqp_release_pages(produce_q->kernel_if->u.h.header_page,\n+\t\t\t\t\t retval, false);\n+\t\t}\n \t\terr = VMCI_ERROR_NO_MEM;\n \t\tgoto out;\n \t}\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/misc/vmw_vmci/vmci_queue_pair.c b/drivers/misc/vmw_vmci/vmci_queue_pair.c\nindex 8531ae781195..c07450395d47 100644\n--- a/drivers/misc/vmw_vmci/vmci_queue_pair.c\n+++ b/drivers/misc/vmw_vmci/vmci_queue_pair.c\n@@ -629,10 +629,12 @@ static void qp_release_pages(struct page **pages,\n \tint i;\n \n \tfor (i = 0; i < num_pages; i++) {\n-\t\tif (dirty)\n-\t\t\tset_page_dirty(pages[i]);\n+\t\tif (pages[i]) {\n+\t\t\tif (dirty)\n+\t\t\t\tset_page_dirty(pages[i]);\n \n-\t\tput_page(pages[i]);\n+\t\t\tput_page(pages[i]);\n+\t\t}\n \t\tpages[i] = NULL;\n \t}\n }\n",
            "diff --git a/drivers/misc/vmw_vmci/vmci_queue_pair.c b/drivers/misc/vmw_vmci/vmci_queue_pair.c\nindex 8531ae781195..c07450395d47 100644\n--- a/drivers/misc/vmw_vmci/vmci_queue_pair.c\n+++ b/drivers/misc/vmw_vmci/vmci_queue_pair.c\n@@ -629,10 +629,12 @@ static void qp_release_pages(struct page **pages,\n \tint i;\n \n \tfor (i = 0; i < num_pages; i++) {\n-\t\tif (dirty)\n-\t\t\tset_page_dirty(pages[i]);\n+\t\tif (pages[i]) {\n+\t\t\tif (dirty)\n+\t\t\t\tset_page_dirty(pages[i]);\n \n-\t\tput_page(pages[i]);\n+\t\t\tput_page(pages[i]);\n+\t\t}\n \t\tpages[i] = NULL;\n \t}\n }\n",
            "diff --git a/drivers/misc/vmw_vmci/vmci_queue_pair.c b/drivers/misc/vmw_vmci/vmci_queue_pair.c\nindex 8531ae781195..a63aff2a3343 100644\n--- a/drivers/misc/vmw_vmci/vmci_queue_pair.c\n+++ b/drivers/misc/vmw_vmci/vmci_queue_pair.c\n@@ -629,11 +629,13 @@ static void qp_release_pages(struct page **pages,\n \tint i;\n \n \tfor (i = 0; i < num_pages; i++) {\n-\t\tif (dirty)\n-\t\t\tset_page_dirty(pages[i]);\n+\t\tif (pages[i]) {\n+\t\t\tif (dirty)\n+\t\t\t\tset_page_dirty(pages[i]);\n \n-\t\tput_page(pages[i]);\n-\t\tpages[i] = NULL;\n+\t\t\tput_page(pages[i]);\n+\t\t\tpages[i] = NULL;\n+\t\t}\n \t}\n }\n \n",
            "diff --git a/drivers/misc/vmw_vmci/vmci_queue_pair.c b/drivers/misc/vmw_vmci/vmci_queue_pair.c\nindex 8531ae781195..c07450395d47 100644\n--- a/drivers/misc/vmw_vmci/vmci_queue_pair.c\n+++ b/drivers/misc/vmw_vmci/vmci_queue_pair.c\n@@ -629,10 +629,12 @@ static void qp_release_pages(struct page **pages,\n \tint i;\n \n \tfor (i = 0; i < num_pages; i++) {\n-\t\tif (dirty)\n-\t\t\tset_page_dirty(pages[i]);\n+\t\tif (pages[i]) {\n+\t\t\tif (dirty)\n+\t\t\t\tset_page_dirty(pages[i]);\n \n-\t\tput_page(pages[i]);\n+\t\t\tput_page(pages[i]);\n+\t\t}\n \t\tpages[i] = NULL;\n \t}\n }\n"
        ],
        "error": []
    },
    "91e171a9aa357b24b62b3ab188bc04996448c99b": {
        "non_crash": [
            "diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c\nindex 5864cbc30db6..60991ff12db3 100644\n--- a/net/ipv6/addrconf.c\n+++ b/net/ipv6/addrconf.c\n@@ -5168,6 +5168,7 @@ static int in6_dump_addrs(struct inet6_dev *idev, struct sk_buff *skb,\n \t\tfillargs->event = RTM_GETMULTICAST;\n \n \t\t/* multicast address */\n+\t\trcu_read_lock();\n \t\tfor (ifmca = rcu_dereference(idev->mc_list);\n \t\t     ifmca;\n \t\t     ifmca = rcu_dereference(ifmca->next), ip_idx++) {\n@@ -5177,6 +5178,7 @@ static int in6_dump_addrs(struct inet6_dev *idev, struct sk_buff *skb,\n \t\t\tif (err < 0)\n \t\t\t\tbreak;\n \t\t}\n+\t\trcu_read_unlock();\n \t\tread_lock_bh(&idev->lock);\n \t\tbreak;\n \tcase ANYCAST_ADDR:\n",
            "diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c\nindex 5864cbc30db6..60991ff12db3 100644\n--- a/net/ipv6/addrconf.c\n+++ b/net/ipv6/addrconf.c\n@@ -5168,6 +5168,7 @@ static int in6_dump_addrs(struct inet6_dev *idev, struct sk_buff *skb,\n \t\tfillargs->event = RTM_GETMULTICAST;\n \n \t\t/* multicast address */\n+\t\trcu_read_lock();\n \t\tfor (ifmca = rcu_dereference(idev->mc_list);\n \t\t     ifmca;\n \t\t     ifmca = rcu_dereference(ifmca->next), ip_idx++) {\n@@ -5177,6 +5178,7 @@ static int in6_dump_addrs(struct inet6_dev *idev, struct sk_buff *skb,\n \t\t\tif (err < 0)\n \t\t\t\tbreak;\n \t\t}\n+\t\trcu_read_unlock();\n \t\tread_lock_bh(&idev->lock);\n \t\tbreak;\n \tcase ANYCAST_ADDR:\n",
            "diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c\nindex 5864cbc30db6..60991ff12db3 100644\n--- a/net/ipv6/addrconf.c\n+++ b/net/ipv6/addrconf.c\n@@ -5168,6 +5168,7 @@ static int in6_dump_addrs(struct inet6_dev *idev, struct sk_buff *skb,\n \t\tfillargs->event = RTM_GETMULTICAST;\n \n \t\t/* multicast address */\n+\t\trcu_read_lock();\n \t\tfor (ifmca = rcu_dereference(idev->mc_list);\n \t\t     ifmca;\n \t\t     ifmca = rcu_dereference(ifmca->next), ip_idx++) {\n@@ -5177,6 +5178,7 @@ static int in6_dump_addrs(struct inet6_dev *idev, struct sk_buff *skb,\n \t\t\tif (err < 0)\n \t\t\t\tbreak;\n \t\t}\n+\t\trcu_read_unlock();\n \t\tread_lock_bh(&idev->lock);\n \t\tbreak;\n \tcase ANYCAST_ADDR:\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c\nindex 5864cbc30db6..0cc72401e260 100644\n--- a/net/ipv6/addrconf.c\n+++ b/net/ipv6/addrconf.c\n@@ -5168,6 +5168,7 @@ static int in6_dump_addrs(struct inet6_dev *idev, struct sk_buff *skb,\n \t\tfillargs->event = RTM_GETMULTICAST;\n \n \t\t/* multicast address */\n+\t\trcu_read_lock();\n \t\tfor (ifmca = rcu_dereference(idev->mc_list);\n \t\t     ifmca;\n \t\t     ifmca = rcu_dereference(ifmca->next), ip_idx++) {\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c\nindex 5864cbc30db6..e03b81e3ca6e 100644\n--- a/net/ipv6/addrconf.c\n+++ b/net/ipv6/addrconf.c\n@@ -5168,9 +5168,9 @@ static int in6_dump_addrs(struct inet6_dev *idev, struct sk_buff *skb,\n \t\tfillargs->event = RTM_GETMULTICAST;\n \n \t\t/* multicast address */\n-\t\tfor (ifmca = rcu_dereference(idev->mc_list);\n+\t\tfor (ifmca = rcu_dereference_protected(idev->mc_list, lockdep_is_held(&rtnl_mutex));\n \t\t     ifmca;\n-\t\t     ifmca = rcu_dereference(ifmca->next), ip_idx++) {\n+\t\t     ifmca = rcu_dereference_protected(ifmca->next, lockdep_is_held(&rtnl_mutex)), ip_idx++) {\n \t\t\tif (ip_idx < s_ip_idx)\n \t\t\t\tcontinue;\n \t\t\terr = inet6_fill_ifmcaddr(skb, ifmca, fillargs);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "cfaa72b0f8cf807081aad90d4fe7c2442f0bf12b": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/vmw_vsock/virtio_transport_common.c b/net/vmw_vsock/virtio_transport_common.c\nindex 6564192e7f20..719b8a9b8abd 100644\n--- a/net/vmw_vsock/virtio_transport_common.c\n+++ b/net/vmw_vsock/virtio_transport_common.c\n@@ -1368,7 +1368,7 @@ int virtio_transport_purge_skbs(void *vsk, struct sk_buff_head *queue)\n \n \tspin_lock_bh(&queue->lock);\n \tskb_queue_walk_safe(queue, skb, tmp) {\n-\t\tif (vsock_sk(skb->sk) != vsk)\n+\t\tif (!skb->sk || vsock_sk(skb->sk) != vsk)\n \t\t\tcontinue;\n \n \t\t__skb_unlink(skb, queue);\n",
            "diff --git a/net/vmw_vsock/virtio_transport_common.c b/net/vmw_vsock/virtio_transport_common.c\nindex 6564192e7f20..719b8a9b8abd 100644\n--- a/net/vmw_vsock/virtio_transport_common.c\n+++ b/net/vmw_vsock/virtio_transport_common.c\n@@ -1368,7 +1368,7 @@ int virtio_transport_purge_skbs(void *vsk, struct sk_buff_head *queue)\n \n \tspin_lock_bh(&queue->lock);\n \tskb_queue_walk_safe(queue, skb, tmp) {\n-\t\tif (vsock_sk(skb->sk) != vsk)\n+\t\tif (!skb->sk || vsock_sk(skb->sk) != vsk)\n \t\t\tcontinue;\n \n \t\t__skb_unlink(skb, queue);\n",
            "diff --git a/net/vmw_vsock/virtio_transport_common.c b/net/vmw_vsock/virtio_transport_common.c\nindex 6564192e7f20..719b8a9b8abd 100644\n--- a/net/vmw_vsock/virtio_transport_common.c\n+++ b/net/vmw_vsock/virtio_transport_common.c\n@@ -1368,7 +1368,7 @@ int virtio_transport_purge_skbs(void *vsk, struct sk_buff_head *queue)\n \n \tspin_lock_bh(&queue->lock);\n \tskb_queue_walk_safe(queue, skb, tmp) {\n-\t\tif (vsock_sk(skb->sk) != vsk)\n+\t\tif (!skb->sk || vsock_sk(skb->sk) != vsk)\n \t\t\tcontinue;\n \n \t\t__skb_unlink(skb, queue);\n",
            "diff --git a/net/vmw_vsock/virtio_transport_common.c b/net/vmw_vsock/virtio_transport_common.c\nindex 6564192e7f20..719b8a9b8abd 100644\n--- a/net/vmw_vsock/virtio_transport_common.c\n+++ b/net/vmw_vsock/virtio_transport_common.c\n@@ -1368,7 +1368,7 @@ int virtio_transport_purge_skbs(void *vsk, struct sk_buff_head *queue)\n \n \tspin_lock_bh(&queue->lock);\n \tskb_queue_walk_safe(queue, skb, tmp) {\n-\t\tif (vsock_sk(skb->sk) != vsk)\n+\t\tif (!skb->sk || vsock_sk(skb->sk) != vsk)\n \t\t\tcontinue;\n \n \t\t__skb_unlink(skb, queue);\n",
            "diff --git a/net/vmw_vsock/virtio_transport_common.c b/net/vmw_vsock/virtio_transport_common.c\nindex 6564192e7f20..f1d84bd6455a 100644\n--- a/net/vmw_vsock/virtio_transport_common.c\n+++ b/net/vmw_vsock/virtio_transport_common.c\n@@ -1368,7 +1368,7 @@ int virtio_transport_purge_skbs(void *vsk, struct sk_buff_head *queue)\n \n \tspin_lock_bh(&queue->lock);\n \tskb_queue_walk_safe(queue, skb, tmp) {\n-\t\tif (vsock_sk(skb->sk) != vsk)\n+\t\tif (!skb || vsock_sk(skb->sk) != vsk)\n \t\t\tcontinue;\n \n \t\t__skb_unlink(skb, queue);\n"
        ],
        "error": []
    },
    "07c9d71dc1a215b19c6a245c68f502bc57dbdb83": {
        "non_crash": [
            "diff --git a/net/qrtr/ns.c b/net/qrtr/ns.c\nindex d8252fdab851..adca8cd459b1 100644\n--- a/net/qrtr/ns.c\n+++ b/net/qrtr/ns.c\n@@ -554,6 +554,7 @@ static int ctrl_cmd_new_lookup(struct sockaddr_qrtr *from,\n \tfilter.service = service;\n \tfilter.instance = instance;\n \n+\trcu_read_lock();\n \tradix_tree_for_each_slot(node_slot, &nodes, &node_iter, 0) {\n \t\tnode = radix_tree_deref_slot(node_slot);\n \n@@ -568,6 +569,7 @@ static int ctrl_cmd_new_lookup(struct sockaddr_qrtr *from,\n \t\t\tlookup_notify(from, srv, true);\n \t\t}\n \t}\n+\trcu_read_unlock();\n \n \t/* Empty notification, to indicate end of listing */\n \tlookup_notify(from, NULL, true);\n",
            "diff --git a/net/qrtr/ns.c b/net/qrtr/ns.c\nindex d8252fdab851..adca8cd459b1 100644\n--- a/net/qrtr/ns.c\n+++ b/net/qrtr/ns.c\n@@ -554,6 +554,7 @@ static int ctrl_cmd_new_lookup(struct sockaddr_qrtr *from,\n \tfilter.service = service;\n \tfilter.instance = instance;\n \n+\trcu_read_lock();\n \tradix_tree_for_each_slot(node_slot, &nodes, &node_iter, 0) {\n \t\tnode = radix_tree_deref_slot(node_slot);\n \n@@ -568,6 +569,7 @@ static int ctrl_cmd_new_lookup(struct sockaddr_qrtr *from,\n \t\t\tlookup_notify(from, srv, true);\n \t\t}\n \t}\n+\trcu_read_unlock();\n \n \t/* Empty notification, to indicate end of listing */\n \tlookup_notify(from, NULL, true);\n",
            "diff --git a/net/qrtr/ns.c b/net/qrtr/ns.c\nindex d8252fdab851..adca8cd459b1 100644\n--- a/net/qrtr/ns.c\n+++ b/net/qrtr/ns.c\n@@ -554,6 +554,7 @@ static int ctrl_cmd_new_lookup(struct sockaddr_qrtr *from,\n \tfilter.service = service;\n \tfilter.instance = instance;\n \n+\trcu_read_lock();\n \tradix_tree_for_each_slot(node_slot, &nodes, &node_iter, 0) {\n \t\tnode = radix_tree_deref_slot(node_slot);\n \n@@ -568,6 +569,7 @@ static int ctrl_cmd_new_lookup(struct sockaddr_qrtr *from,\n \t\t\tlookup_notify(from, srv, true);\n \t\t}\n \t}\n+\trcu_read_unlock();\n \n \t/* Empty notification, to indicate end of listing */\n \tlookup_notify(from, NULL, true);\n",
            "diff --git a/net/qrtr/ns.c b/net/qrtr/ns.c\nindex d8252fdab851..adca8cd459b1 100644\n--- a/net/qrtr/ns.c\n+++ b/net/qrtr/ns.c\n@@ -554,6 +554,7 @@ static int ctrl_cmd_new_lookup(struct sockaddr_qrtr *from,\n \tfilter.service = service;\n \tfilter.instance = instance;\n \n+\trcu_read_lock();\n \tradix_tree_for_each_slot(node_slot, &nodes, &node_iter, 0) {\n \t\tnode = radix_tree_deref_slot(node_slot);\n \n@@ -568,6 +569,7 @@ static int ctrl_cmd_new_lookup(struct sockaddr_qrtr *from,\n \t\t\tlookup_notify(from, srv, true);\n \t\t}\n \t}\n+\trcu_read_unlock();\n \n \t/* Empty notification, to indicate end of listing */\n \tlookup_notify(from, NULL, true);\n",
            "diff --git a/net/qrtr/ns.c b/net/qrtr/ns.c\nindex d8252fdab851..adca8cd459b1 100644\n--- a/net/qrtr/ns.c\n+++ b/net/qrtr/ns.c\n@@ -554,6 +554,7 @@ static int ctrl_cmd_new_lookup(struct sockaddr_qrtr *from,\n \tfilter.service = service;\n \tfilter.instance = instance;\n \n+\trcu_read_lock();\n \tradix_tree_for_each_slot(node_slot, &nodes, &node_iter, 0) {\n \t\tnode = radix_tree_deref_slot(node_slot);\n \n@@ -568,6 +569,7 @@ static int ctrl_cmd_new_lookup(struct sockaddr_qrtr *from,\n \t\t\tlookup_notify(from, srv, true);\n \t\t}\n \t}\n+\trcu_read_unlock();\n \n \t/* Empty notification, to indicate end of listing */\n \tlookup_notify(from, NULL, true);\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "d1975758ab72f25acdc552246472398abe66c7fd": {
        "non_crash": [
            "diff --git a/drivers/iommu/iommufd/selftest.c b/drivers/iommu/iommufd/selftest.c\nindex 74c2076105d4..b704a613a757 100644\n--- a/drivers/iommu/iommufd/selftest.c\n+++ b/drivers/iommu/iommufd/selftest.c\n@@ -756,11 +756,12 @@ static int iommufd_test_check_pages(void __user *uptr, struct page **pages,\n \t\tstruct page *tmp_pages[1];\n \t\tlong rc;\n \n-\t\trc = get_user_pages_fast((uintptr_t)uptr, 1, 0, tmp_pages);\n-\t\tif (rc < 0)\n+\t\trc = get_user_pages_fast((uintptr_t)uptr, 1, FOLL_WRITE, tmp_pages);\n+\t\tif (rc <= 0) {\n+\t\t\tif (rc == 0)\n+\t\t\t\treturn -EFAULT;\n \t\t\treturn rc;\n-\t\tif (WARN_ON(rc != 1))\n-\t\t\treturn -EFAULT;\n+\t\t}\n \t\tput_page(tmp_pages[0]);\n \t\tif (tmp_pages[0] != *pages)\n \t\t\treturn -EBADE;\n",
            "diff --git a/drivers/iommu/iommufd/selftest.c b/drivers/iommu/iommufd/selftest.c\nindex 74c2076105d4..759808e50e03 100644\n--- a/drivers/iommu/iommufd/selftest.c\n+++ b/drivers/iommu/iommufd/selftest.c\n@@ -759,8 +759,10 @@ static int iommufd_test_check_pages(void __user *uptr, struct page **pages,\n \t\trc = get_user_pages_fast((uintptr_t)uptr, 1, 0, tmp_pages);\n \t\tif (rc < 0)\n \t\t\treturn rc;\n-\t\tif (WARN_ON(rc != 1))\n+\t\tif (rc != 1) {\n+\t\t\tpr_warn(\"get_user_pages_fast returned %ld, expected 1\\n\", rc);\n \t\t\treturn -EFAULT;\n+\t\t}\n \t\tput_page(tmp_pages[0]);\n \t\tif (tmp_pages[0] != *pages)\n \t\t\treturn -EBADE;\n",
            "diff --git a/drivers/iommu/iommufd/selftest.c b/drivers/iommu/iommufd/selftest.c\nindex 74c2076105d4..9bfc41703943 100644\n--- a/drivers/iommu/iommufd/selftest.c\n+++ b/drivers/iommu/iommufd/selftest.c\n@@ -756,11 +756,16 @@ static int iommufd_test_check_pages(void __user *uptr, struct page **pages,\n \t\tstruct page *tmp_pages[1];\n \t\tlong rc;\n \n+\t\tif (!uptr || !pages)\n+\t\t\treturn -EINVAL;\n+\n \t\trc = get_user_pages_fast((uintptr_t)uptr, 1, 0, tmp_pages);\n \t\tif (rc < 0)\n \t\t\treturn rc;\n-\t\tif (WARN_ON(rc != 1))\n+\t\tif (rc != 1) {\n+\t\t\tpr_warn(\"Expected 1 page, got %ld\\n\", rc);\n \t\t\treturn -EFAULT;\n+\t\t}\n \t\tput_page(tmp_pages[0]);\n \t\tif (tmp_pages[0] != *pages)\n \t\t\treturn -EBADE;\n",
            "diff --git a/drivers/iommu/iommufd/selftest.c b/drivers/iommu/iommufd/selftest.c\nindex 74c2076105d4..be2cf6da2e53 100644\n--- a/drivers/iommu/iommufd/selftest.c\n+++ b/drivers/iommu/iommufd/selftest.c\n@@ -756,11 +756,15 @@ static int iommufd_test_check_pages(void __user *uptr, struct page **pages,\n \t\tstruct page *tmp_pages[1];\n \t\tlong rc;\n \n+\t\tif (!access_ok(uptr, PAGE_SIZE))\n+\t\t\treturn -EFAULT;\n+\n \t\trc = get_user_pages_fast((uintptr_t)uptr, 1, 0, tmp_pages);\n-\t\tif (rc < 0)\n-\t\t\treturn rc;\n-\t\tif (WARN_ON(rc != 1))\n+\t\tif (rc != 1) {\n+\t\t\tif (rc < 0)\n+\t\t\t\treturn rc;\n \t\t\treturn -EFAULT;\n+\t\t}\n \t\tput_page(tmp_pages[0]);\n \t\tif (tmp_pages[0] != *pages)\n \t\t\treturn -EBADE;\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/drivers/iommu/iommufd/selftest.c b/drivers/iommu/iommufd/selftest.c\nindex 74c2076105d4..0fb974a4eaeb 100644\n--- a/drivers/iommu/iommufd/selftest.c\n+++ b/drivers/iommu/iommufd/selftest.c\n@@ -756,11 +756,16 @@ static int iommufd_test_check_pages(void __user *uptr, struct page **pages,\n \t\tstruct page *tmp_pages[1];\n \t\tlong rc;\n \n+\t\tif (!access_ok(uptr, PAGE_SIZE))\n+\t\t\treturn -EFAULT;\n+\n \t\trc = get_user_pages_fast((uintptr_t)uptr, 1, 0, tmp_pages);\n \t\tif (rc < 0)\n \t\t\treturn rc;\n-\t\tif (WARN_ON(rc != 1))\n+\t\tif (rc != 1) {\n+\t\t\tWARN_ON(1);\n \t\t\treturn -EFAULT;\n+\t\t}\n \t\tput_page(tmp_pages[0]);\n \t\tif (tmp_pages[0] != *pages)\n \t\t\treturn -EBADE;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "12be9aa373be9d8727cdd172f190de39528a413a": {
        "non_crash": [
            "diff --git a/security/selinux/hooks.c b/security/selinux/hooks.c\nindex 4c037c2545c1..acc8a6f6e76e 100644\n--- a/security/selinux/hooks.c\n+++ b/security/selinux/hooks.c\n@@ -4838,6 +4838,8 @@ static int selinux_socket_sendmsg(struct socket *sock, struct msghdr *msg,\n static int selinux_socket_recvmsg(struct socket *sock, struct msghdr *msg,\n \t\t\t\t  int size, int flags)\n {\n+\tif (!sock || !sock->sk)\n+\t\treturn -EINVAL;\n \treturn sock_has_perm(sock->sk, SOCKET__READ);\n }\n \n",
            "diff --git a/security/selinux/hooks.c b/security/selinux/hooks.c\nindex 4c037c2545c1..68b38c5da7cc 100644\n--- a/security/selinux/hooks.c\n+++ b/security/selinux/hooks.c\n@@ -4838,6 +4838,8 @@ static int selinux_socket_sendmsg(struct socket *sock, struct msghdr *msg,\n static int selinux_socket_recvmsg(struct socket *sock, struct msghdr *msg,\n \t\t\t\t  int size, int flags)\n {\n+\tif (!sock)\n+\t\treturn -EINVAL;\n \treturn sock_has_perm(sock->sk, SOCKET__READ);\n }\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/security/selinux/hooks.c b/security/selinux/hooks.c\nindex 4c037c2545c1..b40018cd780d 100644\n--- a/security/selinux/hooks.c\n+++ b/security/selinux/hooks.c\n@@ -4838,6 +4838,8 @@ static int selinux_socket_sendmsg(struct socket *sock, struct msghdr *msg,\n static int selinux_socket_recvmsg(struct socket *sock, struct msghdr *msg,\n \t\t\t\t  int size, int flags)\n {\n+\tif (!sock->sk)\n+\t\treturn -EINVAL;\n \treturn sock_has_perm(sock->sk, SOCKET__READ);\n }\n \n"
        ],
        "error": []
    },
    "76c0afb6e24e6dc4093c36801d0b3a61b486ec4d": {
        "non_crash": [
            "diff --git a/fs/nilfs2/segment.c b/fs/nilfs2/segment.c\nindex ac949fd7603f..fe95495d4f32 100644\n--- a/fs/nilfs2/segment.c\n+++ b/fs/nilfs2/segment.c\n@@ -1498,6 +1498,11 @@ static void nilfs_segctor_truncate_segments(struct nilfs_sc_info *sci,\n \tint ret;\n \n \tlist_for_each_entry_continue(segbuf, &sci->sc_segbufs, sb_list) {\n+\t\tif (segbuf->sb_nextnum >= nilfs_sufile_get_nsegments(sufile)) {\n+\t\t\tnilfs_warn(sufile->i_sb, \"nilfs_segctor_truncate_segments: invalid segment number: %llu\",\n+\t\t\t\t   (unsigned long long)segbuf->sb_nextnum);\n+\t\t\tcontinue;\n+\t\t}\n \t\tsci->sc_segbuf_nblocks -= segbuf->sb_rest_blocks;\n \t\tret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n \t\tWARN_ON(ret);\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/segment.c b/fs/nilfs2/segment.c\nindex ac949fd7603f..d6145276964d 100644\n--- a/fs/nilfs2/segment.c\n+++ b/fs/nilfs2/segment.c\n@@ -1409,8 +1409,13 @@ static int nilfs_segctor_extend_segments(struct nilfs_sc_info *sci,\n \tnilfs_segbuf_free(segbuf);\n  failed:\n \tlist_for_each_entry(segbuf, &list, sb_list) {\n-\t\tret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n-\t\tWARN_ON(ret); /* never fails */\n+\t\tif (segbuf->sb_nextnum < nilfs_sufile_get_nsegments(sufile)) {\n+\t\t\tret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+\t\t\tWARN_ON(ret);\n+\t\t} else {\n+\t\t\tnilfs_warn(sufile->i_sb, \"Attempted to free invalid segment number: %llu\",\n+\t\t\t\t   (unsigned long long)segbuf->sb_nextnum);\n+\t\t} /* never fails */\n \t}\n \tnilfs_destroy_logs(&list);\n \treturn err;\ndiff --git a/fs/nilfs2/sufile.c b/fs/nilfs2/sufile.c\nindex dc359b56fdfa..4d0ff83a2fa1 100644\n--- a/fs/nilfs2/sufile.c\n+++ b/fs/nilfs2/sufile.c\n@@ -170,7 +170,7 @@ int nilfs_sufile_updatev(struct inode *sufile, __u64 *segnumv, size_t nsegs,\n \n \tdown_write(&NILFS_MDT(sufile)->mi_sem);\n \tfor (seg = segnumv; seg < segnumv + nsegs; seg++) {\n-\t\tif (unlikely(*seg >= nilfs_sufile_get_nsegments(sufile))) {\n+\t\tif (unlikely(*seg >= nilfs_sufile_get_nsegments(sufile) || *seg < 0)) {\n \t\t\tnilfs_warn(sufile->i_sb,\n \t\t\t\t   \"%s: invalid segment number: %llu\",\n \t\t\t\t   __func__, (unsigned long long)*seg);\n",
            "diff --git a/fs/nilfs2/segment.c b/fs/nilfs2/segment.c\nindex ac949fd7603f..452d88fdb02e 100644\n--- a/fs/nilfs2/segment.c\n+++ b/fs/nilfs2/segment.c\n@@ -1511,6 +1511,13 @@ static int nilfs_segctor_collect(struct nilfs_sc_info *sci,\n {\n \tstruct nilfs_cstage prev_stage = sci->sc_stage;\n \tint err, nadd = 1;\n+\t\n+\t/* Validate segment numbers before proceeding */\n+\tif (sci->sc_segbuf_nblocks >= nilfs_sufile_get_nsegments(nilfs->ns_sufile)) {\n+\t\tpr_warn(\"nilfs_segctor_collect: invalid segment number: %llu\\n\",\n+\t\t        (unsigned long long)sci->sc_segbuf_nblocks);\n+\t\treturn -EINVAL;\n+\t}\n \n \t/* Collection retry loop */\n \tfor (;;) {\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/nilfs2/segment.c b/fs/nilfs2/segment.c\nindex ac949fd7603f..5282d884a0aa 100644\n--- a/fs/nilfs2/segment.c\n+++ b/fs/nilfs2/segment.c\n@@ -1511,6 +1511,13 @@ static int nilfs_segctor_collect(struct nilfs_sc_info *sci,\n {\n \tstruct nilfs_cstage prev_stage = sci->sc_stage;\n \tint err, nadd = 1;\n+\t__u64 max_segments = nilfs_sufile_get_nsegments(sci->sc_sufile);\n+\n+\tif (sci->sc_curseg >= max_segments) {\n+\t\tpr_warn(\"nilfs: invalid current segment number: %llu\\n\",\n+\t\t\t(unsigned long long)sci->sc_curseg);\n+\t\treturn -EINVAL;\n+\t}\n \n \t/* Collection retry loop */\n \tfor (;;) {\ndiff --git a/fs/nilfs2/sufile.c b/fs/nilfs2/sufile.c\nindex dc359b56fdfa..78391cf1bc72 100644\n--- a/fs/nilfs2/sufile.c\n+++ b/fs/nilfs2/sufile.c\n@@ -229,7 +229,7 @@ int nilfs_sufile_update(struct inode *sufile, __u64 segnum, int create,\n \tstruct buffer_head *header_bh, *bh;\n \tint ret;\n \n-\tif (unlikely(segnum >= nilfs_sufile_get_nsegments(sufile))) {\n+\tif (unlikely(segnum >= nilfs_sufile_get_nsegments(sufile) || segnum < 0)) {\n \t\tnilfs_warn(sufile->i_sb, \"%s: invalid segment number: %llu\",\n \t\t\t   __func__, (unsigned long long)segnum);\n \t\treturn -EINVAL;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/nilfs2/segment.c b/fs/nilfs2/segment.c\nindex ac949fd7603f..5805b694e7a5 100644\n--- a/fs/nilfs2/segment.c\n+++ b/fs/nilfs2/segment.c\n@@ -1499,8 +1499,13 @@ static void nilfs_segctor_truncate_segments(struct nilfs_sc_info *sci,\n \n \tlist_for_each_entry_continue(segbuf, &sci->sc_segbufs, sb_list) {\n \t\tsci->sc_segbuf_nblocks -= segbuf->sb_rest_blocks;\n-\t\tret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n-\t\tWARN_ON(ret);\n+\t\tif (segbuf->sb_nextnum < nilfs_sufile_get_nsegments(sufile)) {\n+\t\t\tret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+\t\t\tWARN_ON(ret);\n+\t\t} else {\n+\t\t\tnilfs_warn(sufile->i_sb, \"nilfs_segctor_truncate_segments: invalid segment number: %llu\",\n+\t\t\t\t   (unsigned long long)segbuf->sb_nextnum);\n+\t\t}\n \t}\n \tnilfs_truncate_logs(&sci->sc_segbufs, last);\n }\n@@ -1512,6 +1517,12 @@ static int nilfs_segctor_collect(struct nilfs_sc_info *sci,\n \tstruct nilfs_cstage prev_stage = sci->sc_stage;\n \tint err, nadd = 1;\n \n+\tif (sci->sc_segbuf->sb_nextnum >= nilfs_sufile_get_nsegments(nilfs->ns_sufile)) {\n+\t\tnilfs_warn(nilfs->ns_sufile->i_sb, \"nilfs_segctor_collect: invalid segment number: %llu\",\n+\t\t\t   (unsigned long long)sci->sc_segbuf->sb_nextnum);\n+\t\treturn -EINVAL;\n+\t}\n+\n \t/* Collection retry loop */\n \tfor (;;) {\n \t\tsci->sc_nblk_this_inc = 0;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "943853d124b5c70143eb385e993d35cb42a883c7": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/qrtr/af_qrtr.c b/net/qrtr/af_qrtr.c\nindex 5c2fb992803b..0ca2d68a5b08 100644\n--- a/net/qrtr/af_qrtr.c\n+++ b/net/qrtr/af_qrtr.c\n@@ -395,7 +395,8 @@ static struct qrtr_node *qrtr_node_lookup(unsigned int nid)\n \n \tspin_lock_irqsave(&qrtr_nodes_lock, flags);\n \tnode = radix_tree_lookup(&qrtr_nodes, nid);\n-\tnode = qrtr_node_acquire(node);\n+\tif (node)\n+\t\tnode = qrtr_node_acquire(node);\n \tspin_unlock_irqrestore(&qrtr_nodes_lock, flags);\n \n \treturn node;\n",
            "diff --git a/net/qrtr/af_qrtr.c b/net/qrtr/af_qrtr.c\nindex 5c2fb992803b..0ca2d68a5b08 100644\n--- a/net/qrtr/af_qrtr.c\n+++ b/net/qrtr/af_qrtr.c\n@@ -395,7 +395,8 @@ static struct qrtr_node *qrtr_node_lookup(unsigned int nid)\n \n \tspin_lock_irqsave(&qrtr_nodes_lock, flags);\n \tnode = radix_tree_lookup(&qrtr_nodes, nid);\n-\tnode = qrtr_node_acquire(node);\n+\tif (node)\n+\t\tnode = qrtr_node_acquire(node);\n \tspin_unlock_irqrestore(&qrtr_nodes_lock, flags);\n \n \treturn node;\n",
            "diff --git a/net/qrtr/af_qrtr.c b/net/qrtr/af_qrtr.c\nindex 5c2fb992803b..0ca2d68a5b08 100644\n--- a/net/qrtr/af_qrtr.c\n+++ b/net/qrtr/af_qrtr.c\n@@ -395,7 +395,8 @@ static struct qrtr_node *qrtr_node_lookup(unsigned int nid)\n \n \tspin_lock_irqsave(&qrtr_nodes_lock, flags);\n \tnode = radix_tree_lookup(&qrtr_nodes, nid);\n-\tnode = qrtr_node_acquire(node);\n+\tif (node)\n+\t\tnode = qrtr_node_acquire(node);\n \tspin_unlock_irqrestore(&qrtr_nodes_lock, flags);\n \n \treturn node;\n",
            "diff --git a/net/qrtr/af_qrtr.c b/net/qrtr/af_qrtr.c\nindex 5c2fb992803b..0ca2d68a5b08 100644\n--- a/net/qrtr/af_qrtr.c\n+++ b/net/qrtr/af_qrtr.c\n@@ -395,7 +395,8 @@ static struct qrtr_node *qrtr_node_lookup(unsigned int nid)\n \n \tspin_lock_irqsave(&qrtr_nodes_lock, flags);\n \tnode = radix_tree_lookup(&qrtr_nodes, nid);\n-\tnode = qrtr_node_acquire(node);\n+\tif (node)\n+\t\tnode = qrtr_node_acquire(node);\n \tspin_unlock_irqrestore(&qrtr_nodes_lock, flags);\n \n \treturn node;\n",
            "diff --git a/net/qrtr/af_qrtr.c b/net/qrtr/af_qrtr.c\nindex 5c2fb992803b..0ca2d68a5b08 100644\n--- a/net/qrtr/af_qrtr.c\n+++ b/net/qrtr/af_qrtr.c\n@@ -395,7 +395,8 @@ static struct qrtr_node *qrtr_node_lookup(unsigned int nid)\n \n \tspin_lock_irqsave(&qrtr_nodes_lock, flags);\n \tnode = radix_tree_lookup(&qrtr_nodes, nid);\n-\tnode = qrtr_node_acquire(node);\n+\tif (node)\n+\t\tnode = qrtr_node_acquire(node);\n \tspin_unlock_irqrestore(&qrtr_nodes_lock, flags);\n \n \treturn node;\n"
        ],
        "error": []
    },
    "f0ec9a394925aafbdf13d0a7e6af4cff860f0ed6": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/lib/kobject.c b/lib/kobject.c\nindex 1e4b7382a88e..87107bc95d29 100644\n--- a/lib/kobject.c\n+++ b/lib/kobject.c\n@@ -193,7 +193,8 @@ static void kobj_kset_join(struct kobject *kobj)\n \n \tkset_get(kobj->kset);\n \tspin_lock(&kobj->kset->list_lock);\n-\tlist_add_tail(&kobj->entry, &kobj->kset->list);\n+\tif (list_empty(&kobj->entry))\n+\t\tlist_add_tail(&kobj->entry, &kobj->kset->list);\n \tspin_unlock(&kobj->kset->list_lock);\n }\n \n",
            "diff --git a/lib/kobject.c b/lib/kobject.c\nindex 1e4b7382a88e..505a5f8b289d 100644\n--- a/lib/kobject.c\n+++ b/lib/kobject.c\n@@ -193,7 +193,9 @@ static void kobj_kset_join(struct kobject *kobj)\n \n \tkset_get(kobj->kset);\n \tspin_lock(&kobj->kset->list_lock);\n-\tlist_add_tail(&kobj->entry, &kobj->kset->list);\n+\tif (list_empty(&kobj->entry)) {\n+\t\tlist_add_tail(&kobj->entry, &kobj->kset->list);\n+\t}\n \tspin_unlock(&kobj->kset->list_lock);\n }\n \n",
            "diff --git a/lib/kobject.c b/lib/kobject.c\nindex 1e4b7382a88e..505a5f8b289d 100644\n--- a/lib/kobject.c\n+++ b/lib/kobject.c\n@@ -193,7 +193,9 @@ static void kobj_kset_join(struct kobject *kobj)\n \n \tkset_get(kobj->kset);\n \tspin_lock(&kobj->kset->list_lock);\n-\tlist_add_tail(&kobj->entry, &kobj->kset->list);\n+\tif (list_empty(&kobj->entry)) {\n+\t\tlist_add_tail(&kobj->entry, &kobj->kset->list);\n+\t}\n \tspin_unlock(&kobj->kset->list_lock);\n }\n \n",
            "diff --git a/lib/kobject.c b/lib/kobject.c\nindex 1e4b7382a88e..1801c7ed6487 100644\n--- a/lib/kobject.c\n+++ b/lib/kobject.c\n@@ -193,6 +193,8 @@ static void kobj_kset_join(struct kobject *kobj)\n \n \tkset_get(kobj->kset);\n \tspin_lock(&kobj->kset->list_lock);\n+\tif (!list_empty(&kobj->entry))\n+\t\tlist_del(&kobj->entry);\n \tlist_add_tail(&kobj->entry, &kobj->kset->list);\n \tspin_unlock(&kobj->kset->list_lock);\n }\n",
            "diff --git a/lib/kobject.c b/lib/kobject.c\nindex 1e4b7382a88e..505a5f8b289d 100644\n--- a/lib/kobject.c\n+++ b/lib/kobject.c\n@@ -193,7 +193,9 @@ static void kobj_kset_join(struct kobject *kobj)\n \n \tkset_get(kobj->kset);\n \tspin_lock(&kobj->kset->list_lock);\n-\tlist_add_tail(&kobj->entry, &kobj->kset->list);\n+\tif (list_empty(&kobj->entry)) {\n+\t\tlist_add_tail(&kobj->entry, &kobj->kset->list);\n+\t}\n \tspin_unlock(&kobj->kset->list_lock);\n }\n \n"
        ],
        "error": []
    },
    "e2fdad19640cdf94dec600b3c67260b6095e5f7d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 4eae088046d0..288a7be950dc 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -202,9 +202,10 @@ __cold void io_uring_show_fdinfo(struct seq_file *m, struct file *f)\n {\n \tstruct io_ring_ctx *ctx = f->private_data;\n \n-\tif (percpu_ref_tryget(&ctx->refs)) {\n-\t\t__io_uring_show_fdinfo(ctx, m);\n-\t\tpercpu_ref_put(&ctx->refs);\n-\t}\n+\tif (!percpu_ref_tryget(&ctx->refs))\n+\t\treturn;\n+\n+\t__io_uring_show_fdinfo(ctx, m);\n+\tpercpu_ref_put(&ctx->refs);\n }\n #endif\n",
            "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 4eae088046d0..cada50e94156 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -200,11 +200,16 @@ static __cold void __io_uring_show_fdinfo(struct io_ring_ctx *ctx,\n \n __cold void io_uring_show_fdinfo(struct seq_file *m, struct file *f)\n {\n-\tstruct io_ring_ctx *ctx = f->private_data;\n+\tstruct io_ring_ctx *ctx;\n \n-\tif (percpu_ref_tryget(&ctx->refs)) {\n+\trcu_read_lock();\n+\tctx = rcu_dereference(f->private_data);\n+\tif (ctx && percpu_ref_tryget(&ctx->refs)) {\n+\t\trcu_read_unlock();\n \t\t__io_uring_show_fdinfo(ctx, m);\n \t\tpercpu_ref_put(&ctx->refs);\n+\t\treturn;\n \t}\n+\trcu_read_unlock();\n }\n #endif\n",
            "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 4eae088046d0..8d8975220624 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -202,7 +202,7 @@ __cold void io_uring_show_fdinfo(struct seq_file *m, struct file *f)\n {\n \tstruct io_ring_ctx *ctx = f->private_data;\n \n-\tif (percpu_ref_tryget(&ctx->refs)) {\n+\tif (ctx && percpu_ref_tryget(&ctx->refs)) {\n \t\t__io_uring_show_fdinfo(ctx, m);\n \t\tpercpu_ref_put(&ctx->refs);\n \t}\n",
            "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 4eae088046d0..288a7be950dc 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -202,9 +202,10 @@ __cold void io_uring_show_fdinfo(struct seq_file *m, struct file *f)\n {\n \tstruct io_ring_ctx *ctx = f->private_data;\n \n-\tif (percpu_ref_tryget(&ctx->refs)) {\n-\t\t__io_uring_show_fdinfo(ctx, m);\n-\t\tpercpu_ref_put(&ctx->refs);\n-\t}\n+\tif (!percpu_ref_tryget(&ctx->refs))\n+\t\treturn;\n+\n+\t__io_uring_show_fdinfo(ctx, m);\n+\tpercpu_ref_put(&ctx->refs);\n }\n #endif\n",
            "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 4eae088046d0..288a7be950dc 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -202,9 +202,10 @@ __cold void io_uring_show_fdinfo(struct seq_file *m, struct file *f)\n {\n \tstruct io_ring_ctx *ctx = f->private_data;\n \n-\tif (percpu_ref_tryget(&ctx->refs)) {\n-\t\t__io_uring_show_fdinfo(ctx, m);\n-\t\tpercpu_ref_put(&ctx->refs);\n-\t}\n+\tif (!percpu_ref_tryget(&ctx->refs))\n+\t\treturn;\n+\n+\t__io_uring_show_fdinfo(ctx, m);\n+\tpercpu_ref_put(&ctx->refs);\n }\n #endif\n"
        ],
        "error": []
    },
    "e0083a52ae0eb23d3186173d403646079b45c715": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/usb/core/hcd.c b/drivers/usb/core/hcd.c\nindex 9ffc63ae65ac..2e27d29d3da8 100644\n--- a/drivers/usb/core/hcd.c\n+++ b/drivers/usb/core/hcd.c\n@@ -771,7 +771,12 @@ void usb_hcd_poll_rh_status(struct usb_hcd *hcd)\n \t\t\tclear_bit(HCD_FLAG_POLL_PENDING, &hcd->flags);\n \t\t\thcd->status_urb = NULL;\n \t\t\turb->actual_length = length;\n-\t\t\tmemcpy(urb->transfer_buffer, buffer, length);\n+\t\t\tif (length <= urb->transfer_buffer_length) {\n+\t\t\t\tmemcpy(urb->transfer_buffer, buffer, length);\n+\t\t\t} else {\n+\t\t\t\t// Handle error: length exceeds buffer size\n+\t\t\t\tlength = 0;\n+\t\t\t}\n \n \t\t\tusb_hcd_unlink_urb_from_ep(hcd, urb);\n \t\t\tusb_hcd_giveback_urb(hcd, urb, 0);\n",
            "diff --git a/drivers/usb/core/hcd.c b/drivers/usb/core/hcd.c\nindex 9ffc63ae65ac..9d0bbd581c4e 100644\n--- a/drivers/usb/core/hcd.c\n+++ b/drivers/usb/core/hcd.c\n@@ -771,7 +771,13 @@ void usb_hcd_poll_rh_status(struct usb_hcd *hcd)\n \t\t\tclear_bit(HCD_FLAG_POLL_PENDING, &hcd->flags);\n \t\t\thcd->status_urb = NULL;\n \t\t\turb->actual_length = length;\n-\t\t\tmemcpy(urb->transfer_buffer, buffer, length);\n+\t\t\tif (length <= urb->transfer_buffer_length) {\n+\t\t\t\tmemcpy(urb->transfer_buffer, buffer, length);\n+\t\t\t} else {\n+\t\t\t\t// Handle error: length exceeds buffer size\n+\t\t\t\tlength = 0;\n+\t\t\t\tset_bit(HCD_FLAG_POLL_PENDING, &hcd->flags);\n+\t\t\t}\n \n \t\t\tusb_hcd_unlink_urb_from_ep(hcd, urb);\n \t\t\tusb_hcd_giveback_urb(hcd, urb, 0);\n",
            "diff --git a/drivers/usb/core/hcd.c b/drivers/usb/core/hcd.c\nindex 9ffc63ae65ac..25dd3abf4010 100644\n--- a/drivers/usb/core/hcd.c\n+++ b/drivers/usb/core/hcd.c\n@@ -771,6 +771,9 @@ void usb_hcd_poll_rh_status(struct usb_hcd *hcd)\n \t\t\tclear_bit(HCD_FLAG_POLL_PENDING, &hcd->flags);\n \t\t\thcd->status_urb = NULL;\n \t\t\turb->actual_length = length;\n+\t\t\tif (length > urb->transfer_buffer_length) {\n+\t\t\t\tlength = urb->transfer_buffer_length;\n+\t\t\t}\n \t\t\tmemcpy(urb->transfer_buffer, buffer, length);\n \n \t\t\tusb_hcd_unlink_urb_from_ep(hcd, urb);\n",
            "diff --git a/drivers/usb/core/hcd.c b/drivers/usb/core/hcd.c\nindex 9ffc63ae65ac..2e27d29d3da8 100644\n--- a/drivers/usb/core/hcd.c\n+++ b/drivers/usb/core/hcd.c\n@@ -771,7 +771,12 @@ void usb_hcd_poll_rh_status(struct usb_hcd *hcd)\n \t\t\tclear_bit(HCD_FLAG_POLL_PENDING, &hcd->flags);\n \t\t\thcd->status_urb = NULL;\n \t\t\turb->actual_length = length;\n-\t\t\tmemcpy(urb->transfer_buffer, buffer, length);\n+\t\t\tif (length <= urb->transfer_buffer_length) {\n+\t\t\t\tmemcpy(urb->transfer_buffer, buffer, length);\n+\t\t\t} else {\n+\t\t\t\t// Handle error: length exceeds buffer size\n+\t\t\t\tlength = 0;\n+\t\t\t}\n \n \t\t\tusb_hcd_unlink_urb_from_ep(hcd, urb);\n \t\t\tusb_hcd_giveback_urb(hcd, urb, 0);\n",
            "diff --git a/drivers/usb/core/hcd.c b/drivers/usb/core/hcd.c\nindex 9ffc63ae65ac..25dd3abf4010 100644\n--- a/drivers/usb/core/hcd.c\n+++ b/drivers/usb/core/hcd.c\n@@ -771,6 +771,9 @@ void usb_hcd_poll_rh_status(struct usb_hcd *hcd)\n \t\t\tclear_bit(HCD_FLAG_POLL_PENDING, &hcd->flags);\n \t\t\thcd->status_urb = NULL;\n \t\t\turb->actual_length = length;\n+\t\t\tif (length > urb->transfer_buffer_length) {\n+\t\t\t\tlength = urb->transfer_buffer_length;\n+\t\t\t}\n \t\t\tmemcpy(urb->transfer_buffer, buffer, length);\n \n \t\t\tusb_hcd_unlink_urb_from_ep(hcd, urb);\n"
        ],
        "error": []
    },
    "1665a0a4a1d6d4d3f61624353f8a9e5dbfff67bd": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/ipv4/inet_connection_sock.c b/net/ipv4/inet_connection_sock.c\nindex 4e84ed21d16f..0304285dd40c 100644\n--- a/net/ipv4/inet_connection_sock.c\n+++ b/net/ipv4/inet_connection_sock.c\n@@ -329,7 +329,7 @@ inet_csk_find_open_port(const struct sock *sk, struct inet_bind_bucket **tb_ret,\n \t\t\tcontinue;\n \t\thead = &hinfo->bhash[inet_bhashfn(net, port,\n \t\t\t\t\t\t  hinfo->bhash_size)];\n-\t\tspin_lock_bh(&head->lock);\n+\t\tspin_lock(&head->lock);\n \t\tif (inet_use_bhash2_on_bind(sk)) {\n \t\t\tif (inet_bhash2_addr_any_conflict(sk, port, l3mdev, relax, false))\n \t\t\t\tgoto next_port;\ndiff --git a/net/ipv4/inet_hashtables.c b/net/ipv4/inet_hashtables.c\nindex 3cec471a2cd2..7fa1336fdd0d 100644\n--- a/net/ipv4/inet_hashtables.c\n+++ b/net/ipv4/inet_hashtables.c\n@@ -226,8 +226,8 @@ int __inet_inherit_port(const struct sock *sk, struct sock *child)\n \thead = &table->bhash[bhash];\n \thead2 = inet_bhashfn_portaddr(table, child, net, port);\n \n-\tspin_lock(&head->lock);\n-\tspin_lock(&head2->lock);\n+\tspin_lock_bh(&head->lock);\n+\tspin_lock_bh(&head2->lock);\n \ttb = inet_csk(sk)->icsk_bind_hash;\n \ttb2 = inet_csk(sk)->icsk_bind2_hash;\n \tif (unlikely(!tb || !tb2)) {\ndiff --git a/net/l2tp/l2tp_core.c b/net/l2tp/l2tp_core.c\nindex 754fdda8a5f5..a093a2ae9e5b 100644\n--- a/net/l2tp/l2tp_core.c\n+++ b/net/l2tp/l2tp_core.c\n@@ -1474,7 +1474,9 @@ int l2tp_tunnel_register(struct l2tp_tunnel *tunnel, struct net *net,\n \t}\n \n \tsk = sock->sk;\n+\tlocal_bh_disable();\n \twrite_lock(&sk->sk_callback_lock);\n+\tlocal_bh_enable();\n \n \tret = l2tp_validate_socket(sk, net, tunnel->encap);\n \tif (ret < 0)\n",
            "diff --git a/net/l2tp/l2tp_core.c b/net/l2tp/l2tp_core.c\nindex 754fdda8a5f5..38683887926b 100644\n--- a/net/l2tp/l2tp_core.c\n+++ b/net/l2tp/l2tp_core.c\n@@ -1474,12 +1474,13 @@ int l2tp_tunnel_register(struct l2tp_tunnel *tunnel, struct net *net,\n \t}\n \n \tsk = sock->sk;\n-\twrite_lock(&sk->sk_callback_lock);\n-\n+\t// Acquire the lock after validation to avoid deadlock\n \tret = l2tp_validate_socket(sk, net, tunnel->encap);\n \tif (ret < 0)\n \t\tgoto err_sock;\n \n+\twrite_lock(&sk->sk_callback_lock);\n+\n \ttunnel->l2tp_net = net;\n \tpn = l2tp_pernet(net);\n \n",
            "diff --git a/net/l2tp/l2tp_core.c b/net/l2tp/l2tp_core.c\nindex 754fdda8a5f5..4eb5295e92aa 100644\n--- a/net/l2tp/l2tp_core.c\n+++ b/net/l2tp/l2tp_core.c\n@@ -1474,17 +1474,17 @@ int l2tp_tunnel_register(struct l2tp_tunnel *tunnel, struct net *net,\n \t}\n \n \tsk = sock->sk;\n-\twrite_lock(&sk->sk_callback_lock);\n-\n \tret = l2tp_validate_socket(sk, net, tunnel->encap);\n \tif (ret < 0)\n \t\tgoto err_sock;\n \n+\twrite_lock(&sk->sk_callback_lock);\n \ttunnel->l2tp_net = net;\n \tpn = l2tp_pernet(net);\n \n \tsock_hold(sk);\n \ttunnel->sock = sk;\n+\twrite_unlock(&sk->sk_callback_lock);\n \n \tspin_lock_bh(&pn->l2tp_tunnel_list_lock);\n \tlist_for_each_entry(tunnel_walk, &pn->l2tp_tunnel_list, list) {\n",
            "diff --git a/net/l2tp/l2tp_core.c b/net/l2tp/l2tp_core.c\nindex 754fdda8a5f5..5133be0ccf11 100644\n--- a/net/l2tp/l2tp_core.c\n+++ b/net/l2tp/l2tp_core.c\n@@ -1474,7 +1474,7 @@ int l2tp_tunnel_register(struct l2tp_tunnel *tunnel, struct net *net,\n \t}\n \n \tsk = sock->sk;\n-\twrite_lock(&sk->sk_callback_lock);\n+\twrite_lock_bh(&sk->sk_callback_lock);\n \n \tret = l2tp_validate_socket(sk, net, tunnel->encap);\n \tif (ret < 0)\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/ipv4/inet_connection_sock.c b/net/ipv4/inet_connection_sock.c\nindex 4e84ed21d16f..57c9bc5de870 100644\n--- a/net/ipv4/inet_connection_sock.c\n+++ b/net/ipv4/inet_connection_sock.c\n@@ -493,10 +493,13 @@ int inet_csk_get_port(struct sock *sk, unsigned short snum)\n \t} else {\n \t\thead = &hinfo->bhash[inet_bhashfn(net, port,\n \t\t\t\t\t\t  hinfo->bhash_size)];\n-\t\tspin_lock_bh(&head->lock);\n+\t\tlocal_bh_disable();\n+\t\tspin_lock(&head->lock);\n \t\tinet_bind_bucket_for_each(tb, &head->chain)\n \t\t\tif (inet_bind_bucket_match(tb, net, port, l3mdev))\n \t\t\t\tbreak;\n+\t\tspin_unlock(&head->lock);\n+\t\tlocal_bh_enable();\n \t}\n \n \tif (!tb) {\ndiff --git a/net/ipv4/inet_hashtables.c b/net/ipv4/inet_hashtables.c\nindex 3cec471a2cd2..6c55b952624e 100644\n--- a/net/ipv4/inet_hashtables.c\n+++ b/net/ipv4/inet_hashtables.c\n@@ -226,10 +226,14 @@ int __inet_inherit_port(const struct sock *sk, struct sock *child)\n \thead = &table->bhash[bhash];\n \thead2 = inet_bhashfn_portaddr(table, child, net, port);\n \n+\tlocal_bh_disable();\n \tspin_lock(&head->lock);\n \tspin_lock(&head2->lock);\n \ttb = inet_csk(sk)->icsk_bind_hash;\n \ttb2 = inet_csk(sk)->icsk_bind2_hash;\n+\tspin_unlock(&head2->lock);\n+\tspin_unlock(&head->lock);\n+\tlocal_bh_enable();\n \tif (unlikely(!tb || !tb2)) {\n \t\tspin_unlock(&head2->lock);\n \t\tspin_unlock(&head->lock);\ndiff --git a/net/l2tp/l2tp_core.c b/net/l2tp/l2tp_core.c\nindex 754fdda8a5f5..92f9067b7860 100644\n--- a/net/l2tp/l2tp_core.c\n+++ b/net/l2tp/l2tp_core.c\n@@ -1474,11 +1474,18 @@ int l2tp_tunnel_register(struct l2tp_tunnel *tunnel, struct net *net,\n \t}\n \n \tsk = sock->sk;\n+\tlocal_bh_disable();\n \twrite_lock(&sk->sk_callback_lock);\n \n \tret = l2tp_validate_socket(sk, net, tunnel->encap);\n-\tif (ret < 0)\n+\tif (ret < 0) {\n+\t\twrite_unlock(&sk->sk_callback_lock);\n+\t\tlocal_bh_enable();\n \t\tgoto err_sock;\n+\t}\n+\n+\twrite_unlock(&sk->sk_callback_lock);\n+\tlocal_bh_enable();\n \n \ttunnel->l2tp_net = net;\n \tpn = l2tp_pernet(net);\n",
                "error_message": "Failed to set up instance"
            }
        ]
    },
    "38efa4618c3379cf98642b9379d6e340b14d2702": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 91de361ea9ab..e1f222bc0bbd 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -2773,7 +2773,11 @@ static int io_do_iopoll(struct io_ring_ctx *ctx, bool force_nonspin)\n \t\tif (READ_ONCE(req->iopoll_completed))\n \t\t\tbreak;\n \n-\t\tret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\n+\t\tif (kiocb->ki_filp && kiocb->ki_filp->f_op && kiocb->ki_filp->f_op->iopoll) {\n+\t\t\tret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\n+\t\t} else {\n+\t\t\tret = -EINVAL; // or another appropriate error code\n+\t\t}\n \t\tif (unlikely(ret < 0))\n \t\t\treturn ret;\n \t\telse if (ret)\n",
            "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 91de361ea9ab..34acc2cc77b7 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -2773,7 +2773,11 @@ static int io_do_iopoll(struct io_ring_ctx *ctx, bool force_nonspin)\n \t\tif (READ_ONCE(req->iopoll_completed))\n \t\t\tbreak;\n \n-\t\tret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\n+\t\tif (kiocb->ki_filp && kiocb->ki_filp->f_op && kiocb->ki_filp->f_op->iopoll) {\n+\t\t\tret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\n+\t\t} else {\n+\t\t\tret = -EINVAL; // Return an error if kiocb->ki_filp is NULL or invalid\n+\t\t}\n \t\tif (unlikely(ret < 0))\n \t\t\treturn ret;\n \t\telse if (ret)\n",
            "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 91de361ea9ab..40492220f07b 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -2773,7 +2773,11 @@ static int io_do_iopoll(struct io_ring_ctx *ctx, bool force_nonspin)\n \t\tif (READ_ONCE(req->iopoll_completed))\n \t\t\tbreak;\n \n-\t\tret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\n+\t\tif (kiocb->ki_filp && kiocb->ki_filp->f_op && kiocb->ki_filp->f_op->iopoll) {\n+\t\t\tret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\n+\t\t} else {\n+\t\t\tret = -EINVAL; // or appropriate error handling\n+\t\t}\n \t\tif (unlikely(ret < 0))\n \t\t\treturn ret;\n \t\telse if (ret)\n",
            "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 91de361ea9ab..42de888f5a5b 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -2773,7 +2773,11 @@ static int io_do_iopoll(struct io_ring_ctx *ctx, bool force_nonspin)\n \t\tif (READ_ONCE(req->iopoll_completed))\n \t\t\tbreak;\n \n-\t\tret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\n+\t\tif (kiocb->ki_filp && kiocb->ki_filp->f_op && kiocb->ki_filp->f_op->iopoll) {\n+\t\t\tret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\n+\t\t} else {\n+\t\t\tret = -EINVAL; // Return an error if the iopoll function is not available\n+\t\t}\n \t\tif (unlikely(ret < 0))\n \t\t\treturn ret;\n \t\telse if (ret)\n",
            "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 91de361ea9ab..40492220f07b 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -2773,7 +2773,11 @@ static int io_do_iopoll(struct io_ring_ctx *ctx, bool force_nonspin)\n \t\tif (READ_ONCE(req->iopoll_completed))\n \t\t\tbreak;\n \n-\t\tret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\n+\t\tif (kiocb->ki_filp && kiocb->ki_filp->f_op && kiocb->ki_filp->f_op->iopoll) {\n+\t\t\tret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\n+\t\t} else {\n+\t\t\tret = -EINVAL; // or appropriate error handling\n+\t\t}\n \t\tif (unlikely(ret < 0))\n \t\t\treturn ret;\n \t\telse if (ret)\n"
        ],
        "error": []
    },
    "223c64b1a2c03f0d67d64fdf69606ee2d5e26672": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/batman-adv/network-coding.c b/net/batman-adv/network-coding.c\nindex 9f06132e007d..977734874a84 100644\n--- a/net/batman-adv/network-coding.c\n+++ b/net/batman-adv/network-coding.c\n@@ -1866,7 +1866,8 @@ void batadv_nc_mesh_free(struct batadv_priv *bat_priv)\n {\n \tbatadv_tvlv_container_unregister(bat_priv, BATADV_TVLV_NC, 1);\n \tbatadv_tvlv_handler_unregister(bat_priv, BATADV_TVLV_NC, 1);\n-\tcancel_delayed_work_sync(&bat_priv->nc.work);\n+\tif (delayed_work_pending(&bat_priv->nc.work))\n+\t\tcancel_delayed_work_sync(&bat_priv->nc.work);\n \n \tbatadv_nc_purge_paths(bat_priv, bat_priv->nc.coding_hash, NULL);\n \tbatadv_hash_destroy(bat_priv->nc.coding_hash);\n",
            "diff --git a/net/batman-adv/network-coding.c b/net/batman-adv/network-coding.c\nindex 9f06132e007d..6cdc13525134 100644\n--- a/net/batman-adv/network-coding.c\n+++ b/net/batman-adv/network-coding.c\n@@ -1866,7 +1866,8 @@ void batadv_nc_mesh_free(struct batadv_priv *bat_priv)\n {\n \tbatadv_tvlv_container_unregister(bat_priv, BATADV_TVLV_NC, 1);\n \tbatadv_tvlv_handler_unregister(bat_priv, BATADV_TVLV_NC, 1);\n-\tcancel_delayed_work_sync(&bat_priv->nc.work);\n+\tif (timer_pending(&bat_priv->nc.work.timer))\n+\t\tcancel_delayed_work_sync(&bat_priv->nc.work);\n \n \tbatadv_nc_purge_paths(bat_priv, bat_priv->nc.coding_hash, NULL);\n \tbatadv_hash_destroy(bat_priv->nc.coding_hash);\n",
            "diff --git a/net/batman-adv/network-coding.c b/net/batman-adv/network-coding.c\nindex 9f06132e007d..6cdc13525134 100644\n--- a/net/batman-adv/network-coding.c\n+++ b/net/batman-adv/network-coding.c\n@@ -1866,7 +1866,8 @@ void batadv_nc_mesh_free(struct batadv_priv *bat_priv)\n {\n \tbatadv_tvlv_container_unregister(bat_priv, BATADV_TVLV_NC, 1);\n \tbatadv_tvlv_handler_unregister(bat_priv, BATADV_TVLV_NC, 1);\n-\tcancel_delayed_work_sync(&bat_priv->nc.work);\n+\tif (timer_pending(&bat_priv->nc.work.timer))\n+\t\tcancel_delayed_work_sync(&bat_priv->nc.work);\n \n \tbatadv_nc_purge_paths(bat_priv, bat_priv->nc.coding_hash, NULL);\n \tbatadv_hash_destroy(bat_priv->nc.coding_hash);\n",
            "diff --git a/net/batman-adv/network-coding.c b/net/batman-adv/network-coding.c\nindex 9f06132e007d..977734874a84 100644\n--- a/net/batman-adv/network-coding.c\n+++ b/net/batman-adv/network-coding.c\n@@ -1866,7 +1866,8 @@ void batadv_nc_mesh_free(struct batadv_priv *bat_priv)\n {\n \tbatadv_tvlv_container_unregister(bat_priv, BATADV_TVLV_NC, 1);\n \tbatadv_tvlv_handler_unregister(bat_priv, BATADV_TVLV_NC, 1);\n-\tcancel_delayed_work_sync(&bat_priv->nc.work);\n+\tif (delayed_work_pending(&bat_priv->nc.work))\n+\t\tcancel_delayed_work_sync(&bat_priv->nc.work);\n \n \tbatadv_nc_purge_paths(bat_priv, bat_priv->nc.coding_hash, NULL);\n \tbatadv_hash_destroy(bat_priv->nc.coding_hash);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/batman-adv/network-coding.c b/net/batman-adv/network-coding.c\nindex 9f06132e007d..54464532d422 100644\n--- a/net/batman-adv/network-coding.c\n+++ b/net/batman-adv/network-coding.c\n@@ -158,6 +158,7 @@ int batadv_nc_mesh_init(struct batadv_priv *bat_priv)\n \tbatadv_hash_set_lock_class(bat_priv->nc.decoding_hash,\n \t\t\t\t   &batadv_nc_decoding_hash_lock_class_key);\n \n+\ttimer_setup(&bat_priv->nc.work.timer, batadv_nc_worker, 0);\n \tINIT_DELAYED_WORK(&bat_priv->nc.work, batadv_nc_worker);\n \tbatadv_nc_start_timer(bat_priv);\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "1bd2e7a7bb0310b1b0974022c78ee23975119187": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/rxrpc/conn_client.c b/net/rxrpc/conn_client.c\nindex ea7d4c21f889..c284d225d4ab 100644\n--- a/net/rxrpc/conn_client.c\n+++ b/net/rxrpc/conn_client.c\n@@ -135,10 +135,10 @@ static int rxrpc_get_client_connection_id(struct rxrpc_connection *conn,\n static void rxrpc_put_client_connection_id(struct rxrpc_connection *conn)\n {\n \tif (test_bit(RXRPC_CONN_HAS_IDR, &conn->flags)) {\n-\t\tspin_lock(&rxrpc_conn_id_lock);\n+\t\tspin_lock_bh(&rxrpc_conn_id_lock);\n \t\tidr_remove(&rxrpc_client_conn_ids,\n \t\t\t   conn->proto.cid >> RXRPC_CIDSHIFT);\n-\t\tspin_unlock(&rxrpc_conn_id_lock);\n+\t\tspin_unlock_bh(&rxrpc_conn_id_lock);\n \t}\n }\n \n",
            "diff --git a/net/rxrpc/conn_client.c b/net/rxrpc/conn_client.c\nindex ea7d4c21f889..c284d225d4ab 100644\n--- a/net/rxrpc/conn_client.c\n+++ b/net/rxrpc/conn_client.c\n@@ -135,10 +135,10 @@ static int rxrpc_get_client_connection_id(struct rxrpc_connection *conn,\n static void rxrpc_put_client_connection_id(struct rxrpc_connection *conn)\n {\n \tif (test_bit(RXRPC_CONN_HAS_IDR, &conn->flags)) {\n-\t\tspin_lock(&rxrpc_conn_id_lock);\n+\t\tspin_lock_bh(&rxrpc_conn_id_lock);\n \t\tidr_remove(&rxrpc_client_conn_ids,\n \t\t\t   conn->proto.cid >> RXRPC_CIDSHIFT);\n-\t\tspin_unlock(&rxrpc_conn_id_lock);\n+\t\tspin_unlock_bh(&rxrpc_conn_id_lock);\n \t}\n }\n \n",
            "diff --git a/net/rxrpc/conn_client.c b/net/rxrpc/conn_client.c\nindex ea7d4c21f889..c284d225d4ab 100644\n--- a/net/rxrpc/conn_client.c\n+++ b/net/rxrpc/conn_client.c\n@@ -135,10 +135,10 @@ static int rxrpc_get_client_connection_id(struct rxrpc_connection *conn,\n static void rxrpc_put_client_connection_id(struct rxrpc_connection *conn)\n {\n \tif (test_bit(RXRPC_CONN_HAS_IDR, &conn->flags)) {\n-\t\tspin_lock(&rxrpc_conn_id_lock);\n+\t\tspin_lock_bh(&rxrpc_conn_id_lock);\n \t\tidr_remove(&rxrpc_client_conn_ids,\n \t\t\t   conn->proto.cid >> RXRPC_CIDSHIFT);\n-\t\tspin_unlock(&rxrpc_conn_id_lock);\n+\t\tspin_unlock_bh(&rxrpc_conn_id_lock);\n \t}\n }\n \n",
            "diff --git a/net/rxrpc/conn_client.c b/net/rxrpc/conn_client.c\nindex ea7d4c21f889..c284d225d4ab 100644\n--- a/net/rxrpc/conn_client.c\n+++ b/net/rxrpc/conn_client.c\n@@ -135,10 +135,10 @@ static int rxrpc_get_client_connection_id(struct rxrpc_connection *conn,\n static void rxrpc_put_client_connection_id(struct rxrpc_connection *conn)\n {\n \tif (test_bit(RXRPC_CONN_HAS_IDR, &conn->flags)) {\n-\t\tspin_lock(&rxrpc_conn_id_lock);\n+\t\tspin_lock_bh(&rxrpc_conn_id_lock);\n \t\tidr_remove(&rxrpc_client_conn_ids,\n \t\t\t   conn->proto.cid >> RXRPC_CIDSHIFT);\n-\t\tspin_unlock(&rxrpc_conn_id_lock);\n+\t\tspin_unlock_bh(&rxrpc_conn_id_lock);\n \t}\n }\n \n",
            "diff --git a/net/rxrpc/conn_client.c b/net/rxrpc/conn_client.c\nindex ea7d4c21f889..c284d225d4ab 100644\n--- a/net/rxrpc/conn_client.c\n+++ b/net/rxrpc/conn_client.c\n@@ -135,10 +135,10 @@ static int rxrpc_get_client_connection_id(struct rxrpc_connection *conn,\n static void rxrpc_put_client_connection_id(struct rxrpc_connection *conn)\n {\n \tif (test_bit(RXRPC_CONN_HAS_IDR, &conn->flags)) {\n-\t\tspin_lock(&rxrpc_conn_id_lock);\n+\t\tspin_lock_bh(&rxrpc_conn_id_lock);\n \t\tidr_remove(&rxrpc_client_conn_ids,\n \t\t\t   conn->proto.cid >> RXRPC_CIDSHIFT);\n-\t\tspin_unlock(&rxrpc_conn_id_lock);\n+\t\tspin_unlock_bh(&rxrpc_conn_id_lock);\n \t}\n }\n \n"
        ],
        "error": []
    },
    "4894a6d412735394296e80976329c1a6848acc14": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/file_table.c b/fs/file_table.c\nindex e06c68e2d757..d7ebb5299cb3 100644\n--- a/fs/file_table.c\n+++ b/fs/file_table.c\n@@ -160,7 +160,7 @@ static int init_file(struct file *f, int flags, const struct cred *cred)\n \tf->f_cred = get_cred(cred);\n \terror = security_file_alloc(f);\n \tif (unlikely(error)) {\n-\t\tfile_free_rcu(&f->f_rcuhead);\n+\t\tkmem_cache_free(filp_cachep, f);\n \t\treturn error;\n \t}\n \n",
            "diff --git a/fs/file_table.c b/fs/file_table.c\nindex e06c68e2d757..d7ebb5299cb3 100644\n--- a/fs/file_table.c\n+++ b/fs/file_table.c\n@@ -160,7 +160,7 @@ static int init_file(struct file *f, int flags, const struct cred *cred)\n \tf->f_cred = get_cred(cred);\n \terror = security_file_alloc(f);\n \tif (unlikely(error)) {\n-\t\tfile_free_rcu(&f->f_rcuhead);\n+\t\tkmem_cache_free(filp_cachep, f);\n \t\treturn error;\n \t}\n \n",
            "diff --git a/fs/file_table.c b/fs/file_table.c\nindex e06c68e2d757..d7ebb5299cb3 100644\n--- a/fs/file_table.c\n+++ b/fs/file_table.c\n@@ -160,7 +160,7 @@ static int init_file(struct file *f, int flags, const struct cred *cred)\n \tf->f_cred = get_cred(cred);\n \terror = security_file_alloc(f);\n \tif (unlikely(error)) {\n-\t\tfile_free_rcu(&f->f_rcuhead);\n+\t\tkmem_cache_free(filp_cachep, f);\n \t\treturn error;\n \t}\n \n",
            "diff --git a/fs/file_table.c b/fs/file_table.c\nindex e06c68e2d757..d7ebb5299cb3 100644\n--- a/fs/file_table.c\n+++ b/fs/file_table.c\n@@ -160,7 +160,7 @@ static int init_file(struct file *f, int flags, const struct cred *cred)\n \tf->f_cred = get_cred(cred);\n \terror = security_file_alloc(f);\n \tif (unlikely(error)) {\n-\t\tfile_free_rcu(&f->f_rcuhead);\n+\t\tkmem_cache_free(filp_cachep, f);\n \t\treturn error;\n \t}\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/file_table.c b/fs/file_table.c\nindex e06c68e2d757..2a9f30a93d90 100644\n--- a/fs/file_table.c\n+++ b/fs/file_table.c\n@@ -209,6 +209,8 @@ struct file *alloc_empty_file(int flags, const struct cred *cred)\n \n \terror = init_file(f, flags, cred);\n \tif (unlikely(error))\n+\t\tkmem_cache_free(filp_cachep, f);\n+\t\tkfree(ff);\n \t\treturn ERR_PTR(error);\n \n \tpercpu_counter_inc(&nr_files);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "f7c5a86e747f9b7ce333e7295875cd4ede2c7a0d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/xdp/xdp_umem.c b/net/xdp/xdp_umem.c\nindex f01ef6bda390..0e404e47c0d9 100644\n--- a/net/xdp/xdp_umem.c\n+++ b/net/xdp/xdp_umem.c\n@@ -99,7 +99,10 @@ static int xdp_umem_pin_pages(struct xdp_umem *umem, unsigned long address)\n \tlong npgs;\n \tint err;\n \n-\tumem->pgs = kvcalloc(umem->npgs, sizeof(*umem->pgs), GFP_KERNEL | __GFP_NOWARN);\n+\tif (umem->npgs == 0 || umem->npgs > U32_MAX)\n+\t\treturn -EINVAL;\n+\n+\tumem->pgs = kvcalloc(umem->npgs, sizeof(*umem->pgs), GFP_KERNEL);\n \tif (!umem->pgs)\n \t\treturn -ENOMEM;\n \n",
            "diff --git a/net/xdp/xdp_umem.c b/net/xdp/xdp_umem.c\nindex f01ef6bda390..0cf9910bb1e7 100644\n--- a/net/xdp/xdp_umem.c\n+++ b/net/xdp/xdp_umem.c\n@@ -99,7 +99,7 @@ static int xdp_umem_pin_pages(struct xdp_umem *umem, unsigned long address)\n \tlong npgs;\n \tint err;\n \n-\tumem->pgs = kvcalloc(umem->npgs, sizeof(*umem->pgs), GFP_KERNEL | __GFP_NOWARN);\n+\tumem->pgs = kvcalloc(umem->npgs, sizeof(*umem->pgs), GFP_KERNEL);\n \tif (!umem->pgs)\n \t\treturn -ENOMEM;\n \n",
            "diff --git a/net/xdp/xdp_umem.c b/net/xdp/xdp_umem.c\nindex f01ef6bda390..0cf9910bb1e7 100644\n--- a/net/xdp/xdp_umem.c\n+++ b/net/xdp/xdp_umem.c\n@@ -99,7 +99,7 @@ static int xdp_umem_pin_pages(struct xdp_umem *umem, unsigned long address)\n \tlong npgs;\n \tint err;\n \n-\tumem->pgs = kvcalloc(umem->npgs, sizeof(*umem->pgs), GFP_KERNEL | __GFP_NOWARN);\n+\tumem->pgs = kvcalloc(umem->npgs, sizeof(*umem->pgs), GFP_KERNEL);\n \tif (!umem->pgs)\n \t\treturn -ENOMEM;\n \n",
            "diff --git a/net/xdp/xdp_umem.c b/net/xdp/xdp_umem.c\nindex f01ef6bda390..4fc7deace67b 100644\n--- a/net/xdp/xdp_umem.c\n+++ b/net/xdp/xdp_umem.c\n@@ -99,7 +99,11 @@ static int xdp_umem_pin_pages(struct xdp_umem *umem, unsigned long address)\n \tlong npgs;\n \tint err;\n \n-\tumem->pgs = kvcalloc(umem->npgs, sizeof(*umem->pgs), GFP_KERNEL | __GFP_NOWARN);\n+\tif (umem->npgs == 0 || umem->npgs > U32_MAX) {\n+\t\treturn -EINVAL;\n+\t}\n+\n+\tumem->pgs = kvcalloc(umem->npgs, sizeof(*umem->pgs), GFP_KERNEL);\n \tif (!umem->pgs)\n \t\treturn -ENOMEM;\n \n",
            "diff --git a/net/xdp/xdp_umem.c b/net/xdp/xdp_umem.c\nindex f01ef6bda390..0cf9910bb1e7 100644\n--- a/net/xdp/xdp_umem.c\n+++ b/net/xdp/xdp_umem.c\n@@ -99,7 +99,7 @@ static int xdp_umem_pin_pages(struct xdp_umem *umem, unsigned long address)\n \tlong npgs;\n \tint err;\n \n-\tumem->pgs = kvcalloc(umem->npgs, sizeof(*umem->pgs), GFP_KERNEL | __GFP_NOWARN);\n+\tumem->pgs = kvcalloc(umem->npgs, sizeof(*umem->pgs), GFP_KERNEL);\n \tif (!umem->pgs)\n \t\treturn -ENOMEM;\n \n"
        ],
        "error": []
    },
    "64619c0d6d2ef98d85b7bb4ff271bfa9df74ce03": {
        "non_crash": [
            "diff --git a/fs/ext4/mballoc.c b/fs/ext4/mballoc.c\nindex 9dad93059945..35c56ccd82c3 100644\n--- a/fs/ext4/mballoc.c\n+++ b/fs/ext4/mballoc.c\n@@ -4289,9 +4289,10 @@ static void ext4_mb_use_inode_pa(struct ext4_allocation_context *ac,\n \tac->ac_status = AC_STATUS_FOUND;\n \tac->ac_pa = pa;\n \n-\tBUG_ON(start < pa->pa_pstart);\n-\tBUG_ON(end > pa->pa_pstart + EXT4_C2B(sbi, pa->pa_len));\n-\tBUG_ON(pa->pa_free < len);\n+\tif (start < pa->pa_pstart || end > pa->pa_pstart + EXT4_C2B(sbi, pa->pa_len) || pa->pa_free < len) {\n+\t\tpr_err(\"ext4_mb_use_inode_pa: invalid preallocation range or insufficient free space\\n\");\n+\t\treturn;\n+\t}\n \tpa->pa_free -= len;\n \n \tmb_debug(ac->ac_sb, \"use %llu/%d from inode pa %p\\n\", start, len, pa);\n",
            "diff --git a/fs/ext4/mballoc.c b/fs/ext4/mballoc.c\nindex 9dad93059945..f83b2167fadc 100644\n--- a/fs/ext4/mballoc.c\n+++ b/fs/ext4/mballoc.c\n@@ -4289,9 +4289,10 @@ static void ext4_mb_use_inode_pa(struct ext4_allocation_context *ac,\n \tac->ac_status = AC_STATUS_FOUND;\n \tac->ac_pa = pa;\n \n-\tBUG_ON(start < pa->pa_pstart);\n-\tBUG_ON(end > pa->pa_pstart + EXT4_C2B(sbi, pa->pa_len));\n-\tBUG_ON(pa->pa_free < len);\n+\tif (start < pa->pa_pstart || end > pa->pa_pstart + EXT4_C2B(sbi, pa->pa_len) || pa->pa_free < len) {\n+\t\tpr_err(\"ext4_mb_use_inode_pa: invalid preallocated space usage\\n\");\n+\t\treturn;\n+\t}\n \tpa->pa_free -= len;\n \n \tmb_debug(ac->ac_sb, \"use %llu/%d from inode pa %p\\n\", start, len, pa);\n",
            "diff --git a/fs/ext4/mballoc.c b/fs/ext4/mballoc.c\nindex 9dad93059945..04f6fa3b3209 100644\n--- a/fs/ext4/mballoc.c\n+++ b/fs/ext4/mballoc.c\n@@ -4289,9 +4289,11 @@ static void ext4_mb_use_inode_pa(struct ext4_allocation_context *ac,\n \tac->ac_status = AC_STATUS_FOUND;\n \tac->ac_pa = pa;\n \n-\tBUG_ON(start < pa->pa_pstart);\n-\tBUG_ON(end > pa->pa_pstart + EXT4_C2B(sbi, pa->pa_len));\n-\tBUG_ON(pa->pa_free < len);\n+\tif (start < pa->pa_pstart || end > pa->pa_pstart + EXT4_C2B(sbi, pa->pa_len) || pa->pa_free < len) {\n+\t\tpr_err(\"ext4: invalid preallocated space usage: start=%llu, end=%llu, pa_pstart=%llu, pa_len=%u, pa_free=%u\\n\",\n+\t\t       start, end, pa->pa_pstart, pa->pa_len, pa->pa_free);\n+\t\treturn;\n+\t}\n \tpa->pa_free -= len;\n \n \tmb_debug(ac->ac_sb, \"use %llu/%d from inode pa %p\\n\", start, len, pa);\n",
            "diff --git a/fs/ext4/mballoc.c b/fs/ext4/mballoc.c\nindex 9dad93059945..15a656fecd03 100644\n--- a/fs/ext4/mballoc.c\n+++ b/fs/ext4/mballoc.c\n@@ -4289,9 +4289,18 @@ static void ext4_mb_use_inode_pa(struct ext4_allocation_context *ac,\n \tac->ac_status = AC_STATUS_FOUND;\n \tac->ac_pa = pa;\n \n-\tBUG_ON(start < pa->pa_pstart);\n-\tBUG_ON(end > pa->pa_pstart + EXT4_C2B(sbi, pa->pa_len));\n-\tBUG_ON(pa->pa_free < len);\n+\tif (start < pa->pa_pstart) {\n+\t\tpr_err(\"ext4: start block is less than pa_pstart\\n\");\n+\t\treturn;\n+\t}\n+\tif (end > pa->pa_pstart + EXT4_C2B(sbi, pa->pa_len)) {\n+\t\tpr_err(\"ext4: end block exceeds pa_pstart + pa_len\\n\");\n+\t\treturn;\n+\t}\n+\tif (pa->pa_free < len) {\n+\t\tpr_err(\"ext4: pa_free is less than required length\\n\");\n+\t\treturn;\n+\t}\n \tpa->pa_free -= len;\n \n \tmb_debug(ac->ac_sb, \"use %llu/%d from inode pa %p\\n\", start, len, pa);\n",
            "diff --git a/fs/ext4/mballoc.c b/fs/ext4/mballoc.c\nindex 9dad93059945..6df98b27c168 100644\n--- a/fs/ext4/mballoc.c\n+++ b/fs/ext4/mballoc.c\n@@ -4291,7 +4291,10 @@ static void ext4_mb_use_inode_pa(struct ext4_allocation_context *ac,\n \n \tBUG_ON(start < pa->pa_pstart);\n \tBUG_ON(end > pa->pa_pstart + EXT4_C2B(sbi, pa->pa_len));\n-\tBUG_ON(pa->pa_free < len);\n+\tif (pa->pa_free < len) {\n+\t\tmb_debug(ac->ac_sb, \"Not enough free blocks in inode pa %p\\n\", pa);\n+\t\treturn;\n+\t}\n \tpa->pa_free -= len;\n \n \tmb_debug(ac->ac_sb, \"use %llu/%d from inode pa %p\\n\", start, len, pa);\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "30f3a18df370dd15cce6f725620ac001e57dbee1": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/hfsplus/brec.c b/fs/hfsplus/brec.c\nindex 1918544a7871..d554c0beda94 100644\n--- a/fs/hfsplus/brec.c\n+++ b/fs/hfsplus/brec.c\n@@ -276,10 +276,10 @@ static struct hfs_bnode *hfs_bnode_split(struct hfs_find_data *fd)\n \t\tif (++num_recs < node->num_recs)\n \t\t\tcontinue;\n \t\t/* panic? */\n-\t\thfs_bnode_put(node);\n-\t\thfs_bnode_put(new_node);\n \t\tif (next_node)\n \t\t\thfs_bnode_put(next_node);\n+\t\thfs_bnode_put(new_node);\n+\t\thfs_bnode_put(node);\n \t\treturn ERR_PTR(-ENOSPC);\n \t}\n \n@@ -291,8 +291,8 @@ static struct hfs_bnode *hfs_bnode_split(struct hfs_find_data *fd)\n \t\tnum_recs--;\n \t\tdata_start = hfs_bnode_read_u16(node, old_rec_off);\n \t} else {\n-\t\thfs_bnode_put(node);\n \t\thfs_bnode_get(new_node);\n+\t\thfs_bnode_put(node);\n \t\tfd->bnode = new_node;\n \t\tfd->record -= num_recs;\n \t\tfd->keyoffset -= data_start - 14;\n",
            "diff --git a/fs/hfsplus/brec.c b/fs/hfsplus/brec.c\nindex 1918544a7871..e2f5523e32b4 100644\n--- a/fs/hfsplus/brec.c\n+++ b/fs/hfsplus/brec.c\n@@ -260,6 +260,8 @@ static struct hfs_bnode *hfs_bnode_split(struct hfs_find_data *fd)\n \t\tnext_node = NULL;\n \n \tif (IS_ERR(next_node)) {\n+\t\thfs_bnode_get(node);\n+\t\thfs_bnode_get(new_node);\n \t\thfs_bnode_put(node);\n \t\thfs_bnode_put(new_node);\n \t\treturn next_node;\n",
            "diff --git a/fs/hfs/btree.c b/fs/hfs/btree.c\nindex 2fa4b1f8cc7f..a3a23c884fbe 100644\n--- a/fs/hfs/btree.c\n+++ b/fs/hfs/btree.c\n@@ -310,6 +310,7 @@ struct hfs_bnode *hfs_bmap_alloc(struct hfs_btree *tree)\n \t\thfs_bnode_put(node);\n \t\tif (IS_ERR(next_node))\n \t\t\treturn next_node;\n+\t\thfs_bnode_get(next_node); // Increment reference count for next_node\n \t\tnode = next_node;\n \n \t\tlen = hfs_brec_lenoff(node, 0, &off16);\ndiff --git a/fs/hfsplus/brec.c b/fs/hfsplus/brec.c\nindex 1918544a7871..9c38a6b8905c 100644\n--- a/fs/hfsplus/brec.c\n+++ b/fs/hfsplus/brec.c\n@@ -245,6 +245,7 @@ static struct hfs_bnode *hfs_bnode_split(struct hfs_find_data *fd)\n \tnew_node = hfs_bmap_alloc(tree);\n \tif (IS_ERR(new_node))\n \t\treturn new_node;\n+\thfs_bnode_get(new_node); // Increment reference count for new_node\n \thfs_bnode_get(node);\n \thfs_dbg(BNODE_MOD, \"split_nodes: %d - %d - %d\\n\",\n \t\tnode->this, new_node->this, node->next);\n",
            "diff --git a/fs/hfsplus/brec.c b/fs/hfsplus/brec.c\nindex 1918544a7871..7f6009159002 100644\n--- a/fs/hfsplus/brec.c\n+++ b/fs/hfsplus/brec.c\n@@ -246,6 +246,7 @@ static struct hfs_bnode *hfs_bnode_split(struct hfs_find_data *fd)\n \tif (IS_ERR(new_node))\n \t\treturn new_node;\n \thfs_bnode_get(node);\n+\thfs_bnode_get(new_node); // Increment ref count for new_node\n \thfs_dbg(BNODE_MOD, \"split_nodes: %d - %d - %d\\n\",\n \t\tnode->this, new_node->this, node->next);\n \tnew_node->next = node->next;\n@@ -264,6 +265,7 @@ static struct hfs_bnode *hfs_bnode_split(struct hfs_find_data *fd)\n \t\thfs_bnode_put(new_node);\n \t\treturn next_node;\n \t}\n+\thfs_bnode_get(next_node); // Increment ref count for next_node\n \n \tsize = tree->node_size / 2 - node->num_recs * 2 - 14;\n \told_rec_off = tree->node_size - 4;\n",
            "diff --git a/fs/hfsplus/brec.c b/fs/hfsplus/brec.c\nindex 1918544a7871..e4323d6a222d 100644\n--- a/fs/hfsplus/brec.c\n+++ b/fs/hfsplus/brec.c\n@@ -143,6 +143,7 @@ int hfs_brec_insert(struct hfs_find_data *fd, void *entry, int entry_len)\n \t}\n \n \tif (new_node) {\n+\t\thfs_bnode_get(fd->bnode);\n \t\thfs_bnode_put(fd->bnode);\n \t\tif (!new_node->parent) {\n \t\t\thfs_btree_inc_height(tree);\n@@ -159,6 +160,8 @@ int hfs_brec_insert(struct hfs_find_data *fd, void *entry, int entry_len)\n \t\thfs_bnode_read_key(new_node, fd->search_key, 14);\n \t\t__hfs_brec_find(fd->bnode, fd, hfs_find_rec_by_key);\n \n+\t\thfs_bnode_get(new_node);\n+\t\thfs_bnode_get(new_node);\n \t\thfs_bnode_put(new_node);\n \t\tnew_node = NULL;\n \n@@ -202,6 +205,7 @@ int hfs_brec_remove(struct hfs_find_data *fd)\n \t\tparent = hfs_bnode_find(tree, node->parent);\n \t\tif (IS_ERR(parent))\n \t\t\treturn PTR_ERR(parent);\n+\t\thfs_bnode_get(node);\n \t\thfs_bnode_put(node);\n \t\tnode = fd->bnode = parent;\n \n@@ -279,7 +283,8 @@ static struct hfs_bnode *hfs_bnode_split(struct hfs_find_data *fd)\n \t\thfs_bnode_put(node);\n \t\thfs_bnode_put(new_node);\n \t\tif (next_node)\n-\t\t\thfs_bnode_put(next_node);\n+\t\t\thfs_bnode_get(next_node);\n+\t\thfs_bnode_put(next_node);\n \t\treturn ERR_PTR(-ENOSPC);\n \t}\n \n"
        ],
        "error": []
    },
    "08bcc3eb4d1892c93490ce2924713568b1fed364": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/f2fs/dir.c b/fs/f2fs/dir.c\nindex d635c58cf5a3..490d7bc0e0dc 100644\n--- a/fs/f2fs/dir.c\n+++ b/fs/f2fs/dir.c\n@@ -835,6 +835,7 @@ int f2fs_do_tmpfile(struct inode *inode, struct inode *dir)\n \tstruct page *page;\n \tint err = 0;\n \n+\tf2fs_down_read(&F2FS_I(inode)->i_xattr_sem);\n \tf2fs_down_write(&F2FS_I(inode)->i_sem);\n \tpage = f2fs_init_inode_metadata(inode, dir, NULL, NULL);\n \tif (IS_ERR(page)) {\n@@ -842,6 +843,7 @@ int f2fs_do_tmpfile(struct inode *inode, struct inode *dir)\n \t\tgoto fail;\n \t}\n \tf2fs_put_page(page, 1);\n+\tf2fs_up_read(&F2FS_I(inode)->i_xattr_sem);\n \n \tclear_inode_flag(inode, FI_NEW_INODE);\n \tf2fs_update_time(F2FS_I_SB(inode), REQ_TIME);\n",
            "diff --git a/fs/f2fs/dir.c b/fs/f2fs/dir.c\nindex d635c58cf5a3..c3a2e899ae20 100644\n--- a/fs/f2fs/dir.c\n+++ b/fs/f2fs/dir.c\n@@ -835,6 +835,7 @@ int f2fs_do_tmpfile(struct inode *inode, struct inode *dir)\n \tstruct page *page;\n \tint err = 0;\n \n+\tf2fs_down_read(&F2FS_I(inode)->i_xattr_sem);\n \tf2fs_down_write(&F2FS_I(inode)->i_sem);\n \tpage = f2fs_init_inode_metadata(inode, dir, NULL, NULL);\n \tif (IS_ERR(page)) {\n@@ -845,6 +846,7 @@ int f2fs_do_tmpfile(struct inode *inode, struct inode *dir)\n \n \tclear_inode_flag(inode, FI_NEW_INODE);\n \tf2fs_update_time(F2FS_I_SB(inode), REQ_TIME);\n+\tf2fs_up_read(&F2FS_I(inode)->i_xattr_sem);\n fail:\n \tf2fs_up_write(&F2FS_I(inode)->i_sem);\n \treturn err;\n",
            "diff --git a/fs/f2fs/dir.c b/fs/f2fs/dir.c\nindex d635c58cf5a3..c3a2e899ae20 100644\n--- a/fs/f2fs/dir.c\n+++ b/fs/f2fs/dir.c\n@@ -835,6 +835,7 @@ int f2fs_do_tmpfile(struct inode *inode, struct inode *dir)\n \tstruct page *page;\n \tint err = 0;\n \n+\tf2fs_down_read(&F2FS_I(inode)->i_xattr_sem);\n \tf2fs_down_write(&F2FS_I(inode)->i_sem);\n \tpage = f2fs_init_inode_metadata(inode, dir, NULL, NULL);\n \tif (IS_ERR(page)) {\n@@ -845,6 +846,7 @@ int f2fs_do_tmpfile(struct inode *inode, struct inode *dir)\n \n \tclear_inode_flag(inode, FI_NEW_INODE);\n \tf2fs_update_time(F2FS_I_SB(inode), REQ_TIME);\n+\tf2fs_up_read(&F2FS_I(inode)->i_xattr_sem);\n fail:\n \tf2fs_up_write(&F2FS_I(inode)->i_sem);\n \treturn err;\n",
            "diff --git a/fs/f2fs/dir.c b/fs/f2fs/dir.c\nindex d635c58cf5a3..490d7bc0e0dc 100644\n--- a/fs/f2fs/dir.c\n+++ b/fs/f2fs/dir.c\n@@ -835,6 +835,7 @@ int f2fs_do_tmpfile(struct inode *inode, struct inode *dir)\n \tstruct page *page;\n \tint err = 0;\n \n+\tf2fs_down_read(&F2FS_I(inode)->i_xattr_sem);\n \tf2fs_down_write(&F2FS_I(inode)->i_sem);\n \tpage = f2fs_init_inode_metadata(inode, dir, NULL, NULL);\n \tif (IS_ERR(page)) {\n@@ -842,6 +843,7 @@ int f2fs_do_tmpfile(struct inode *inode, struct inode *dir)\n \t\tgoto fail;\n \t}\n \tf2fs_put_page(page, 1);\n+\tf2fs_up_read(&F2FS_I(inode)->i_xattr_sem);\n \n \tclear_inode_flag(inode, FI_NEW_INODE);\n \tf2fs_update_time(F2FS_I_SB(inode), REQ_TIME);\n",
            "diff --git a/fs/f2fs/dir.c b/fs/f2fs/dir.c\nindex d635c58cf5a3..8d10cf5d6afc 100644\n--- a/fs/f2fs/dir.c\n+++ b/fs/f2fs/dir.c\n@@ -835,6 +835,7 @@ int f2fs_do_tmpfile(struct inode *inode, struct inode *dir)\n \tstruct page *page;\n \tint err = 0;\n \n+\tf2fs_down_read(&F2FS_I(inode)->i_xattr_sem);\n \tf2fs_down_write(&F2FS_I(inode)->i_sem);\n \tpage = f2fs_init_inode_metadata(inode, dir, NULL, NULL);\n \tif (IS_ERR(page)) {\n@@ -845,6 +846,8 @@ int f2fs_do_tmpfile(struct inode *inode, struct inode *dir)\n \n \tclear_inode_flag(inode, FI_NEW_INODE);\n \tf2fs_update_time(F2FS_I_SB(inode), REQ_TIME);\n+\tf2fs_up_write(&F2FS_I(inode)->i_sem);\n+\tf2fs_up_read(&F2FS_I(inode)->i_xattr_sem);\n fail:\n \tf2fs_up_write(&F2FS_I(inode)->i_sem);\n \treturn err;\n"
        ],
        "error": []
    },
    "cd246a3e7f0fd69a115b910b3b2cf6fa96351278": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/btree.c b/fs/nilfs2/btree.c\nindex b9d15c3df3cc..a2e1fdf8bf2d 100644\n--- a/fs/nilfs2/btree.c\n+++ b/fs/nilfs2/btree.c\n@@ -415,12 +415,18 @@ nilfs_btree_get_root(const struct nilfs_bmap *btree)\n static struct nilfs_btree_node *\n nilfs_btree_get_nonroot_node(const struct nilfs_btree_path *path, int level)\n {\n+\tif (!path[level].bp_bh) {\n+\t\treturn NULL;\n+\t}\n \treturn (struct nilfs_btree_node *)path[level].bp_bh->b_data;\n }\n \n static struct nilfs_btree_node *\n nilfs_btree_get_sib_node(const struct nilfs_btree_path *path, int level)\n {\n+\tif (!path[level].bp_sib_bh) {\n+\t\treturn NULL;\n+\t}\n \treturn (struct nilfs_btree_node *)path[level].bp_sib_bh->b_data;\n }\n \n",
            "diff --git a/fs/nilfs2/btree.c b/fs/nilfs2/btree.c\nindex b9d15c3df3cc..2d1f4842ca64 100644\n--- a/fs/nilfs2/btree.c\n+++ b/fs/nilfs2/btree.c\n@@ -421,6 +421,10 @@ nilfs_btree_get_nonroot_node(const struct nilfs_btree_path *path, int level)\n static struct nilfs_btree_node *\n nilfs_btree_get_sib_node(const struct nilfs_btree_path *path, int level)\n {\n+\tif (!path[level].bp_sib_bh) {\n+\t\t// Handle the null case, possibly return NULL or an error\n+\t\treturn NULL;\n+\t}\n \treturn (struct nilfs_btree_node *)path[level].bp_sib_bh->b_data;\n }\n \n",
            "diff --git a/fs/nilfs2/btree.c b/fs/nilfs2/btree.c\nindex b9d15c3df3cc..bdf6db4fcca2 100644\n--- a/fs/nilfs2/btree.c\n+++ b/fs/nilfs2/btree.c\n@@ -415,6 +415,9 @@ nilfs_btree_get_root(const struct nilfs_bmap *btree)\n static struct nilfs_btree_node *\n nilfs_btree_get_nonroot_node(const struct nilfs_btree_path *path, int level)\n {\n+\tif (!path[level].bp_bh) {\n+\t\treturn NULL;\n+\t}\n \treturn (struct nilfs_btree_node *)path[level].bp_bh->b_data;\n }\n \n",
            "diff --git a/fs/nilfs2/btree.c b/fs/nilfs2/btree.c\nindex b9d15c3df3cc..d3ea75d4b350 100644\n--- a/fs/nilfs2/btree.c\n+++ b/fs/nilfs2/btree.c\n@@ -877,7 +877,13 @@ static void nilfs_btree_carry_right(struct nilfs_bmap *btree,\n \tint nchildren, rnchildren, n, move, ncblk;\n \n \tnode = nilfs_btree_get_nonroot_node(path, level);\n-\tright = nilfs_btree_get_sib_node(path, level);\n+\tif (path[level].bp_sib_bh) {\n+\t\tright = nilfs_btree_get_sib_node(path, level);\n+\t} else {\n+\t\t// Handle the case where sibling buffer head is null\n+\t\t// This could be an error or a special case handling\n+\t\treturn; // or appropriate error handling\n+\t}\n \tnchildren = nilfs_btree_node_get_nchildren(node);\n \trnchildren = nilfs_btree_node_get_nchildren(right);\n \tncblk = nilfs_btree_nchildren_per_block(btree);\n",
            "diff --git a/fs/nilfs2/btree.c b/fs/nilfs2/btree.c\nindex b9d15c3df3cc..5e2b29b0c335 100644\n--- a/fs/nilfs2/btree.c\n+++ b/fs/nilfs2/btree.c\n@@ -421,6 +421,10 @@ nilfs_btree_get_nonroot_node(const struct nilfs_btree_path *path, int level)\n static struct nilfs_btree_node *\n nilfs_btree_get_sib_node(const struct nilfs_btree_path *path, int level)\n {\n+\tif (!path[level].bp_sib_bh) {\n+\t\t// Handle the error case, e.g., return NULL or handle appropriately\n+\t\treturn NULL;\n+\t}\n \treturn (struct nilfs_btree_node *)path[level].bp_sib_bh->b_data;\n }\n \n"
        ],
        "error": []
    },
    "0be1740a2972a1852f35a3ed7dc70577610edcbd": {
        "non_crash": [
            "diff --git a/sound/core/seq/seq_ports.c b/sound/core/seq/seq_ports.c\nindex 9b80f8275026..2501ce3e2f78 100644\n--- a/sound/core/seq/seq_ports.c\n+++ b/sound/core/seq/seq_ports.c\n@@ -150,6 +150,7 @@ int snd_seq_create_port(struct snd_seq_client *client, int port,\n \tlist_for_each_entry(p, &client->ports_list_head, list) {\n \t\tif (p->addr.port == port) {\n \t\t\tnum = -EBUSY;\n+\t\t\tkfree(new_port);\n \t\t\tgoto unlock;\n \t\t}\n \t\tif (p->addr.port > num)\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/sound/core/seq/seq_ports.c b/sound/core/seq/seq_ports.c\nindex 9b80f8275026..4ac37e1cfc90 100644\n--- a/sound/core/seq/seq_ports.c\n+++ b/sound/core/seq/seq_ports.c\n@@ -126,6 +126,9 @@ int snd_seq_create_port(struct snd_seq_client *client, int port,\n \tif (snd_BUG_ON(!client))\n \t\treturn -EINVAL;\n \n+\tif (new_port)\n+\t\tkfree(new_port);\n+\n \tif (client->num_ports >= SNDRV_SEQ_MAX_PORTS) {\n \t\tpr_warn(\"ALSA: seq: too many ports for client %d\\n\", client->number);\n \t\treturn -EINVAL;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/sound/core/seq/seq_ports.c b/sound/core/seq/seq_ports.c\nindex 9b80f8275026..e227489749fc 100644\n--- a/sound/core/seq/seq_ports.c\n+++ b/sound/core/seq/seq_ports.c\n@@ -160,6 +160,15 @@ int snd_seq_create_port(struct snd_seq_client *client, int port,\n \t/* insert the new port */\n \tlist_add_tail(&new_port->list, &p->list);\n \tclient->num_ports++;\n+\twrite_unlock_irq(&client->ports_lock);\n+\tmutex_unlock(&client->ports_mutex);\n+\treturn 0;\n+\n+unlock:\n+\twrite_unlock_irq(&client->ports_lock);\n+\tmutex_unlock(&client->ports_mutex);\n+\tkfree(new_port);\n+\treturn num;\n \tnew_port->addr.port = num;\t/* store the port number in the port */\n \tsprintf(new_port->name, \"port-%d\", num);\n \t*port_ret = new_port;\n@@ -293,10 +302,13 @@ int snd_seq_delete_port(struct snd_seq_client *client, int port)\n \t}\n \twrite_unlock_irq(&client->ports_lock);\n \tmutex_unlock(&client->ports_mutex);\n-\tif (found)\n-\t\treturn port_delete(client, found);\n-\telse\n+\tif (found) {\n+\t\tport_delete(client, found);\n+\t\tkfree(found);\n+\t\treturn 0;\n+\t} else {\n \t\treturn -ENOENT;\n+\t}\n }\n \n /* delete the all ports belonging to the given client */\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/sound/core/seq/seq_ports.c b/sound/core/seq/seq_ports.c\nindex 9b80f8275026..02271afcc3ba 100644\n--- a/sound/core/seq/seq_ports.c\n+++ b/sound/core/seq/seq_ports.c\n@@ -150,7 +150,7 @@ int snd_seq_create_port(struct snd_seq_client *client, int port,\n \tlist_for_each_entry(p, &client->ports_list_head, list) {\n \t\tif (p->addr.port == port) {\n \t\t\tnum = -EBUSY;\n-\t\t\tgoto unlock;\n+\t\t\tgoto unlock_free;\n \t\t}\n \t\tif (p->addr.port > num)\n \t\t\tbreak;\n@@ -160,6 +160,9 @@ int snd_seq_create_port(struct snd_seq_client *client, int port,\n \t/* insert the new port */\n \tlist_add_tail(&new_port->list, &p->list);\n \tclient->num_ports++;\n+\n+unlock_free:\n+\tkfree(new_port);\n \tnew_port->addr.port = num;\t/* store the port number in the port */\n \tsprintf(new_port->name, \"port-%d\", num);\n \t*port_ret = new_port;\n",
                "error_message": "Failed to set up instance"
            }
        ]
    },
    "74c4de068e77c137156235cc06a904c9baea491f": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex 1310d2d5feb3..e0af9c8609d5 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1014,10 +1014,12 @@ int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)\n \t\tif (unlikely(err))\n \t\t\treturn err;\n \t\tspin_lock(&nilfs->ns_inode_lock);\n-\t\tif (ii->i_bh == NULL)\n+\t\tif (ii->i_bh == NULL) {\n+\t\t\tget_bh(*pbh); // Increment reference count\n \t\t\tii->i_bh = *pbh;\n-\t\telse {\n+\t\t} else {\n \t\t\tbrelse(*pbh);\n+\t\t\tget_bh(ii->i_bh); // Ensure ii->i_bh is valid\n \t\t\t*pbh = ii->i_bh;\n \t\t}\n \t} else\n",
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex 1310d2d5feb3..7afee4af7558 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1014,10 +1014,12 @@ int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)\n \t\tif (unlikely(err))\n \t\t\treturn err;\n \t\tspin_lock(&nilfs->ns_inode_lock);\n-\t\tif (ii->i_bh == NULL)\n+\t\tif (ii->i_bh == NULL) {\n+\t\t\tget_bh(*pbh); // Increment the reference count\n \t\t\tii->i_bh = *pbh;\n-\t\telse {\n+\t\t} else {\n \t\t\tbrelse(*pbh);\n+\t\t\tget_bh(ii->i_bh); // Ensure the buffer head is valid\n \t\t\t*pbh = ii->i_bh;\n \t\t}\n \t} else\n",
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex 1310d2d5feb3..e0af9c8609d5 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1014,10 +1014,12 @@ int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)\n \t\tif (unlikely(err))\n \t\t\treturn err;\n \t\tspin_lock(&nilfs->ns_inode_lock);\n-\t\tif (ii->i_bh == NULL)\n+\t\tif (ii->i_bh == NULL) {\n+\t\t\tget_bh(*pbh); // Increment reference count\n \t\t\tii->i_bh = *pbh;\n-\t\telse {\n+\t\t} else {\n \t\t\tbrelse(*pbh);\n+\t\t\tget_bh(ii->i_bh); // Ensure ii->i_bh is valid\n \t\t\t*pbh = ii->i_bh;\n \t\t}\n \t} else\n",
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex 1310d2d5feb3..5932d6ffbb3d 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1014,10 +1014,12 @@ int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)\n \t\tif (unlikely(err))\n \t\t\treturn err;\n \t\tspin_lock(&nilfs->ns_inode_lock);\n-\t\tif (ii->i_bh == NULL)\n+\t\tif (ii->i_bh == NULL) {\n+\t\t\tget_bh(*pbh);  // Increment the reference count\n \t\t\tii->i_bh = *pbh;\n-\t\telse {\n+\t\t} else {\n \t\t\tbrelse(*pbh);\n+\t\t\tget_bh(ii->i_bh);  // Ensure the buffer head is valid\n \t\t\t*pbh = ii->i_bh;\n \t\t}\n \t} else\n",
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex 1310d2d5feb3..db9cb0ec65b1 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1014,9 +1014,10 @@ int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)\n \t\tif (unlikely(err))\n \t\t\treturn err;\n \t\tspin_lock(&nilfs->ns_inode_lock);\n-\t\tif (ii->i_bh == NULL)\n+\t\tif (ii->i_bh == NULL) {\n \t\t\tii->i_bh = *pbh;\n-\t\telse {\n+\t\t\tget_bh(ii->i_bh); // Increment reference count to prevent premature freeing\n+\t\t} else {\n \t\t\tbrelse(*pbh);\n \t\t\t*pbh = ii->i_bh;\n \t\t}\n"
        ],
        "error": []
    },
    "82136e2452d5e1ea212f5bf76fcd8db36512f981": {
        "non_crash": [
            "diff --git a/fs/erofs/inode.c b/fs/erofs/inode.c\nindex 95a403720e8c..e204f3771724 100644\n--- a/fs/erofs/inode.c\n+++ b/fs/erofs/inode.c\n@@ -219,6 +219,11 @@ static int erofs_fill_symlink(struct inode *inode, void *kaddr,\n \t\treturn 0;\n \t}\n \n+\tif (inode->i_size < 0 || inode->i_size >= EROFS_BLKSIZ) {\n+\t\terofs_err(inode->i_sb, \"invalid symlink size %lld\", inode->i_size);\n+\t\treturn -EINVAL;\n+\t}\n+\n \tlnk = kmalloc(inode->i_size + 1, GFP_KERNEL);\n \tif (!lnk)\n \t\treturn -ENOMEM;\n",
            "diff --git a/fs/erofs/inode.c b/fs/erofs/inode.c\nindex 95a403720e8c..7a53b04cc93c 100644\n--- a/fs/erofs/inode.c\n+++ b/fs/erofs/inode.c\n@@ -219,6 +219,13 @@ static int erofs_fill_symlink(struct inode *inode, void *kaddr,\n \t\treturn 0;\n \t}\n \n+\tif (inode->i_size < 0 || inode->i_size >= EROFS_BLKSIZ) {\n+\t\terofs_err(inode->i_sb,\n+\t\t\t  \"invalid symlink size @ nid %llu\",\n+\t\t\t  vi->nid);\n+\t\treturn -EINVAL;\n+\t}\n+\n \tlnk = kmalloc(inode->i_size + 1, GFP_KERNEL);\n \tif (!lnk)\n \t\treturn -ENOMEM;\n",
            "diff --git a/fs/erofs/inode.c b/fs/erofs/inode.c\nindex 95a403720e8c..3d887d1426ef 100644\n--- a/fs/erofs/inode.c\n+++ b/fs/erofs/inode.c\n@@ -219,6 +219,10 @@ static int erofs_fill_symlink(struct inode *inode, void *kaddr,\n \t\treturn 0;\n \t}\n \n+\tif (inode->i_size < 0 || inode->i_size >= EROFS_BLKSIZ) {\n+\t\terofs_err(inode->i_sb, \"invalid symlink size: %lld\", inode->i_size);\n+\t\treturn -EINVAL;\n+\t}\n \tlnk = kmalloc(inode->i_size + 1, GFP_KERNEL);\n \tif (!lnk)\n \t\treturn -ENOMEM;\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/erofs/inode.c b/fs/erofs/inode.c\nindex 95a403720e8c..c7c50971d331 100644\n--- a/fs/erofs/inode.c\n+++ b/fs/erofs/inode.c\n@@ -219,6 +219,11 @@ static int erofs_fill_symlink(struct inode *inode, void *kaddr,\n \t\treturn 0;\n \t}\n \n+\tif (inode->i_size >= EROFS_BLKSIZ) {\n+\t\terofs_err(inode->i_sb, \"symlink size too large: %llu\", inode->i_size);\n+\t\treturn -EINVAL;\n+\t}\n+\n \tlnk = kmalloc(inode->i_size + 1, GFP_KERNEL);\n \tif (!lnk)\n \t\treturn -ENOMEM;\n",
            "diff --git a/fs/erofs/inode.c b/fs/erofs/inode.c\nindex 95a403720e8c..aa0117cc15a4 100644\n--- a/fs/erofs/inode.c\n+++ b/fs/erofs/inode.c\n@@ -219,6 +219,11 @@ static int erofs_fill_symlink(struct inode *inode, void *kaddr,\n \t\treturn 0;\n \t}\n \n+\tif (inode->i_size >= EROFS_BLKSIZ) {\n+\t\terofs_err(inode->i_sb, \"invalid symlink size: %llu\", inode->i_size);\n+\t\treturn -EINVAL;\n+\t}\n+\n \tlnk = kmalloc(inode->i_size + 1, GFP_KERNEL);\n \tif (!lnk)\n \t\treturn -ENOMEM;\n"
        ],
        "error": []
    },
    "6c4345574ac937d9ccc195fdadb44f7cc95a19f9": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 2ee50e23c9b7..993db47a29a7 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -2217,8 +2217,10 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n \n \t\terr = nft_chain_parse_hook(net, nla, &hook, family, extack,\n \t\t\t\t\t   true);\n-\t\tif (err < 0)\n+\t\tif (err < 0) {\n+\t\t\tnft_chain_release_hook(&hook);\n \t\t\treturn err;\n+\t\t}\n \n \t\tbasechain = kzalloc(sizeof(*basechain), GFP_KERNEL_ACCOUNT);\n \t\tif (basechain == NULL) {\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 2ee50e23c9b7..4da5eab902d1 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -2217,8 +2217,12 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n \n \t\terr = nft_chain_parse_hook(net, nla, &hook, family, extack,\n \t\t\t\t\t   true);\n-\t\tif (err < 0)\n+\t\tif (err < 0) {\n+\t\t\tnft_chain_release_hook(&hook);\n+\t\t\tkfree(hook);\n+\t\t\t\tkfree(hook);\n \t\t\treturn err;\n+\t\t}\n \n \t\tbasechain = kzalloc(sizeof(*basechain), GFP_KERNEL_ACCOUNT);\n \t\tif (basechain == NULL) {\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 2ee50e23c9b7..82bfcfe26b84 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -459,8 +459,10 @@ static int nft_delrule_by_chain(struct nft_ctx *ctx)\n \t\t\tcontinue;\n \n \t\terr = nft_delrule(ctx, rule);\n-\t\tif (err < 0)\n+\t\tif (err < 0) {\n+\t\t\tkfree(hook);\n \t\t\treturn err;\n+\t\t}\n \t}\n \treturn 0;\n }\n@@ -2223,6 +2225,8 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n \t\tbasechain = kzalloc(sizeof(*basechain), GFP_KERNEL_ACCOUNT);\n \t\tif (basechain == NULL) {\n \t\t\tnft_chain_release_hook(&hook);\n+\t\t\tkfree(hook);\n+\t\t\t\tkfree(hook);\n \t\t\treturn -ENOMEM;\n \t\t}\n \t\tchain = &basechain->chain;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 2ee50e23c9b7..e5de2c7ea83c 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -459,8 +459,10 @@ static int nft_delrule_by_chain(struct nft_ctx *ctx)\n \t\t\tcontinue;\n \n \t\terr = nft_delrule(ctx, rule);\n-\t\tif (err < 0)\n+\t\tif (err < 0) {\n+\t\t\tnft_chain_release_hook(&hook);\n \t\t\treturn err;\n+\t\t}\n \t}\n \treturn 0;\n }\n@@ -2250,7 +2252,10 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n \t\t\treturn -EOPNOTSUPP;\n \n \t\tchain = kzalloc(sizeof(*chain), GFP_KERNEL_ACCOUNT);\n-\t\tif (chain == NULL)\n+\t\tif (chain == NULL) {\n+\t\t\tnft_chain_release_hook(&hook);\n+\t\t\treturn -ENOMEM;\n+\t\t}\n \t\t\treturn -ENOMEM;\n \n \t\tchain->flags = flags;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 2ee50e23c9b7..8d1637cc11e4 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -218,7 +218,9 @@ static int nft_netdev_register_hooks(struct net *net,\n \n \t\tnf_unregister_net_hook(net, &hook->ops);\n \t}\n-\treturn err;\n+\tnft_chain_release_hook(&hook);\n+\t\t\tkfree(basechain);\n+\t\t\treturn err;\n }\n \n static void nft_netdev_unregister_hooks(struct net *net,\n@@ -459,8 +461,10 @@ static int nft_delrule_by_chain(struct nft_ctx *ctx)\n \t\t\tcontinue;\n \n \t\terr = nft_delrule(ctx, rule);\n-\t\tif (err < 0)\n+\t\tif (err < 0) {\n+\t\t\tnft_chain_release_hook(&hook);\n \t\t\treturn err;\n+\t\t}\n \t}\n \treturn 0;\n }\n@@ -2223,6 +2227,7 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n \t\tbasechain = kzalloc(sizeof(*basechain), GFP_KERNEL_ACCOUNT);\n \t\tif (basechain == NULL) {\n \t\t\tnft_chain_release_hook(&hook);\n+\t\t\tkfree(hook);\n \t\t\treturn -ENOMEM;\n \t\t}\n \t\tchain = &basechain->chain;\n@@ -2230,6 +2235,8 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n \t\tif (nla[NFTA_CHAIN_COUNTERS]) {\n \t\t\tstats = nft_stats_alloc(nla[NFTA_CHAIN_COUNTERS]);\n \t\t\tif (IS_ERR(stats)) {\n+\t\t\t\tnft_chain_release_hook(&hook);\n+\t\t\t\tkfree(basechain);\n \t\t\t\tnft_chain_release_hook(&hook);\n \t\t\t\tkfree(basechain);\n \t\t\t\treturn PTR_ERR(stats);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "b32fa08468c9e84e361296e1bc502283ea202ec6": {
        "non_crash": [],
        "special_crash": [
            "diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c\nindex 46943a18a10d..90448d262fd6 100644\n--- a/net/packet/af_packet.c\n+++ b/net/packet/af_packet.c\n@@ -4493,7 +4493,7 @@ static int packet_set_ring(struct sock *sk, union tpacket_req_u *req_u,\n \n out_free_pg_vec:\n \tbitmap_free(rx_owner_map);\n-\tif (pg_vec)\n+\tif (pg_vec && err)\n \t\tfree_pg_vec(pg_vec, order, req->tp_block_nr);\n out:\n \treturn err;\n"
        ],
        "crash": [
            "diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c\nindex 46943a18a10d..652397671a53 100644\n--- a/net/packet/af_packet.c\n+++ b/net/packet/af_packet.c\n@@ -4493,8 +4493,10 @@ static int packet_set_ring(struct sock *sk, union tpacket_req_u *req_u,\n \n out_free_pg_vec:\n \tbitmap_free(rx_owner_map);\n-\tif (pg_vec)\n+\tif (pg_vec) {\n \t\tfree_pg_vec(pg_vec, order, req->tp_block_nr);\n+\t\tpg_vec = NULL; // Ensure pg_vec is not freed again\n+\t}\n out:\n \treturn err;\n }\n",
            "diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c\nindex 46943a18a10d..56324296f39e 100644\n--- a/net/packet/af_packet.c\n+++ b/net/packet/af_packet.c\n@@ -4493,8 +4493,10 @@ static int packet_set_ring(struct sock *sk, union tpacket_req_u *req_u,\n \n out_free_pg_vec:\n \tbitmap_free(rx_owner_map);\n-\tif (pg_vec)\n+\tif (pg_vec) {\n \t\tfree_pg_vec(pg_vec, order, req->tp_block_nr);\n+\t\tpg_vec = NULL; // Prevent double-free by nullifying the pointer\n+\t}\n out:\n \treturn err;\n }\n",
            "diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c\nindex 46943a18a10d..56324296f39e 100644\n--- a/net/packet/af_packet.c\n+++ b/net/packet/af_packet.c\n@@ -4493,8 +4493,10 @@ static int packet_set_ring(struct sock *sk, union tpacket_req_u *req_u,\n \n out_free_pg_vec:\n \tbitmap_free(rx_owner_map);\n-\tif (pg_vec)\n+\tif (pg_vec) {\n \t\tfree_pg_vec(pg_vec, order, req->tp_block_nr);\n+\t\tpg_vec = NULL; // Prevent double-free by nullifying the pointer\n+\t}\n out:\n \treturn err;\n }\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c\nindex 46943a18a10d..780cc0eabf92 100644\n--- a/net/packet/af_packet.c\n+++ b/net/packet/af_packet.c\n@@ -4493,8 +4493,10 @@ static int packet_set_ring(struct sock *sk, union tpacket_req_u *req_u,\n \n out_free_pg_vec:\n \tbitmap_free(rx_owner_map);\n-\tif (pg_vec)\n+\tif (pg_vec && !po->pg_vec_freed) {\n \t\tfree_pg_vec(pg_vec, order, req->tp_block_nr);\n+\t\tpo->pg_vec_freed = true;\n+\t}\n out:\n \treturn err;\n }\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "0518799fc2250353125d212fc510c44adbde73c3": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/net/wireless/ath/ath9k/hif_usb.c b/drivers/net/wireless/ath/ath9k/hif_usb.c\nindex 86ede591dafa..3dfcfe9de51c 100644\n--- a/drivers/net/wireless/ath/ath9k/hif_usb.c\n+++ b/drivers/net/wireless/ath/ath9k/hif_usb.c\n@@ -636,6 +636,7 @@ static void ath9k_hif_usb_rx_stream(struct hif_device_usb *hif_dev,\n \t\t\tif (!nskb) {\n \t\t\t\tdev_err(&hif_dev->udev->dev,\n \t\t\t\t\t\"ath9k_htc: RX memory allocation error\\n\");\n+\t\t\t\tkfree_skb(skb);\n \t\t\t\tgoto err;\n \t\t\t}\n \t\t\tskb_reserve(nskb, 32);\n",
            "diff --git a/drivers/net/wireless/ath/ath9k/hif_usb.c b/drivers/net/wireless/ath/ath9k/hif_usb.c\nindex 86ede591dafa..3531852cfea7 100644\n--- a/drivers/net/wireless/ath/ath9k/hif_usb.c\n+++ b/drivers/net/wireless/ath/ath9k/hif_usb.c\n@@ -636,6 +636,7 @@ static void ath9k_hif_usb_rx_stream(struct hif_device_usb *hif_dev,\n \t\t\tif (!nskb) {\n \t\t\t\tdev_err(&hif_dev->udev->dev,\n \t\t\t\t\t\"ath9k_htc: RX memory allocation error\\n\");\n+\t\t\t\tkfree_skb(skb); // Free the original skb\n \t\t\t\tgoto err;\n \t\t\t}\n \t\t\tskb_reserve(nskb, 32);\n",
            "diff --git a/drivers/net/wireless/ath/ath9k/hif_usb.c b/drivers/net/wireless/ath/ath9k/hif_usb.c\nindex 86ede591dafa..25050a64f324 100644\n--- a/drivers/net/wireless/ath/ath9k/hif_usb.c\n+++ b/drivers/net/wireless/ath/ath9k/hif_usb.c\n@@ -615,7 +615,8 @@ static void ath9k_hif_usb_rx_stream(struct hif_device_usb *hif_dev,\n \t\t\t\tdev_err(&hif_dev->udev->dev,\n \t\t\t\t\t\"ath9k_htc: RX memory allocation error\\n\");\n \t\t\t\tspin_unlock(&hif_dev->rx_lock);\n-\t\t\t\tgoto err;\n+\t\t\t\tdev_kfree_skb_any(nskb);\n+\t\t\tgoto err;\n \t\t\t}\n \t\t\tskb_reserve(nskb, 32);\n \t\t\tRX_STAT_INC(hif_dev, skb_allocated);\n",
            "diff --git a/drivers/net/wireless/ath/ath9k/hif_usb.c b/drivers/net/wireless/ath/ath9k/hif_usb.c\nindex 86ede591dafa..3dfcfe9de51c 100644\n--- a/drivers/net/wireless/ath/ath9k/hif_usb.c\n+++ b/drivers/net/wireless/ath/ath9k/hif_usb.c\n@@ -636,6 +636,7 @@ static void ath9k_hif_usb_rx_stream(struct hif_device_usb *hif_dev,\n \t\t\tif (!nskb) {\n \t\t\t\tdev_err(&hif_dev->udev->dev,\n \t\t\t\t\t\"ath9k_htc: RX memory allocation error\\n\");\n+\t\t\t\tkfree_skb(skb);\n \t\t\t\tgoto err;\n \t\t\t}\n \t\t\tskb_reserve(nskb, 32);\n",
            "diff --git a/drivers/net/wireless/ath/ath9k/hif_usb.c b/drivers/net/wireless/ath/ath9k/hif_usb.c\nindex 86ede591dafa..3dfcfe9de51c 100644\n--- a/drivers/net/wireless/ath/ath9k/hif_usb.c\n+++ b/drivers/net/wireless/ath/ath9k/hif_usb.c\n@@ -636,6 +636,7 @@ static void ath9k_hif_usb_rx_stream(struct hif_device_usb *hif_dev,\n \t\t\tif (!nskb) {\n \t\t\t\tdev_err(&hif_dev->udev->dev,\n \t\t\t\t\t\"ath9k_htc: RX memory allocation error\\n\");\n+\t\t\t\tkfree_skb(skb);\n \t\t\t\tgoto err;\n \t\t\t}\n \t\t\tskb_reserve(nskb, 32);\n"
        ],
        "error": []
    },
    "95277dbea9484baea60662d0243a93011a21ceb5": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex ce5dfa3babd2..cd39661b5bb7 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1163,15 +1163,17 @@ static void __ebt_unregister_table(struct net *net, struct ebt_table *table)\n \tmutex_lock(&ebt_mutex);\n \tlist_del(&table->list);\n \tmutex_unlock(&ebt_mutex);\n-\taudit_log_nfcfg(table->name, AF_BRIDGE, table->private->nentries,\n-\t\t\tAUDIT_XT_OP_UNREGISTER, GFP_KERNEL);\n-\tEBT_ENTRY_ITERATE(table->private->entries, table->private->entries_size,\n-\t\t\t  ebt_cleanup_entry, net, NULL);\n-\tif (table->private->nentries)\n-\t\tmodule_put(table->me);\n-\tvfree(table->private->entries);\n-\tebt_free_table_info(table->private);\n-\tvfree(table->private);\n+\tif (table->private) {\n+\t\taudit_log_nfcfg(table->name, AF_BRIDGE, table->private->nentries,\n+\t\t\t\tAUDIT_XT_OP_UNREGISTER, GFP_KERNEL);\n+\t\tEBT_ENTRY_ITERATE(table->private->entries, table->private->entries_size,\n+\t\t\t\t  ebt_cleanup_entry, net, NULL);\n+\t\tif (table->private->nentries)\n+\t\t\tmodule_put(table->me);\n+\t\tvfree(table->private->entries);\n+\t\tebt_free_table_info(table->private);\n+\t\tvfree(table->private);\n+\t}\n \tkfree(table->ops);\n \tkfree(table);\n }\n",
            "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex ce5dfa3babd2..cd39661b5bb7 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1163,15 +1163,17 @@ static void __ebt_unregister_table(struct net *net, struct ebt_table *table)\n \tmutex_lock(&ebt_mutex);\n \tlist_del(&table->list);\n \tmutex_unlock(&ebt_mutex);\n-\taudit_log_nfcfg(table->name, AF_BRIDGE, table->private->nentries,\n-\t\t\tAUDIT_XT_OP_UNREGISTER, GFP_KERNEL);\n-\tEBT_ENTRY_ITERATE(table->private->entries, table->private->entries_size,\n-\t\t\t  ebt_cleanup_entry, net, NULL);\n-\tif (table->private->nentries)\n-\t\tmodule_put(table->me);\n-\tvfree(table->private->entries);\n-\tebt_free_table_info(table->private);\n-\tvfree(table->private);\n+\tif (table->private) {\n+\t\taudit_log_nfcfg(table->name, AF_BRIDGE, table->private->nentries,\n+\t\t\t\tAUDIT_XT_OP_UNREGISTER, GFP_KERNEL);\n+\t\tEBT_ENTRY_ITERATE(table->private->entries, table->private->entries_size,\n+\t\t\t\t  ebt_cleanup_entry, net, NULL);\n+\t\tif (table->private->nentries)\n+\t\t\tmodule_put(table->me);\n+\t\tvfree(table->private->entries);\n+\t\tebt_free_table_info(table->private);\n+\t\tvfree(table->private);\n+\t}\n \tkfree(table->ops);\n \tkfree(table);\n }\n",
            "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex ce5dfa3babd2..cd39661b5bb7 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1163,15 +1163,17 @@ static void __ebt_unregister_table(struct net *net, struct ebt_table *table)\n \tmutex_lock(&ebt_mutex);\n \tlist_del(&table->list);\n \tmutex_unlock(&ebt_mutex);\n-\taudit_log_nfcfg(table->name, AF_BRIDGE, table->private->nentries,\n-\t\t\tAUDIT_XT_OP_UNREGISTER, GFP_KERNEL);\n-\tEBT_ENTRY_ITERATE(table->private->entries, table->private->entries_size,\n-\t\t\t  ebt_cleanup_entry, net, NULL);\n-\tif (table->private->nentries)\n-\t\tmodule_put(table->me);\n-\tvfree(table->private->entries);\n-\tebt_free_table_info(table->private);\n-\tvfree(table->private);\n+\tif (table->private) {\n+\t\taudit_log_nfcfg(table->name, AF_BRIDGE, table->private->nentries,\n+\t\t\t\tAUDIT_XT_OP_UNREGISTER, GFP_KERNEL);\n+\t\tEBT_ENTRY_ITERATE(table->private->entries, table->private->entries_size,\n+\t\t\t\t  ebt_cleanup_entry, net, NULL);\n+\t\tif (table->private->nentries)\n+\t\t\tmodule_put(table->me);\n+\t\tvfree(table->private->entries);\n+\t\tebt_free_table_info(table->private);\n+\t\tvfree(table->private);\n+\t}\n \tkfree(table->ops);\n \tkfree(table);\n }\n",
            "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex ce5dfa3babd2..cd39661b5bb7 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1163,15 +1163,17 @@ static void __ebt_unregister_table(struct net *net, struct ebt_table *table)\n \tmutex_lock(&ebt_mutex);\n \tlist_del(&table->list);\n \tmutex_unlock(&ebt_mutex);\n-\taudit_log_nfcfg(table->name, AF_BRIDGE, table->private->nentries,\n-\t\t\tAUDIT_XT_OP_UNREGISTER, GFP_KERNEL);\n-\tEBT_ENTRY_ITERATE(table->private->entries, table->private->entries_size,\n-\t\t\t  ebt_cleanup_entry, net, NULL);\n-\tif (table->private->nentries)\n-\t\tmodule_put(table->me);\n-\tvfree(table->private->entries);\n-\tebt_free_table_info(table->private);\n-\tvfree(table->private);\n+\tif (table->private) {\n+\t\taudit_log_nfcfg(table->name, AF_BRIDGE, table->private->nentries,\n+\t\t\t\tAUDIT_XT_OP_UNREGISTER, GFP_KERNEL);\n+\t\tEBT_ENTRY_ITERATE(table->private->entries, table->private->entries_size,\n+\t\t\t\t  ebt_cleanup_entry, net, NULL);\n+\t\tif (table->private->nentries)\n+\t\t\tmodule_put(table->me);\n+\t\tvfree(table->private->entries);\n+\t\tebt_free_table_info(table->private);\n+\t\tvfree(table->private);\n+\t}\n \tkfree(table->ops);\n \tkfree(table);\n }\n",
            "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex ce5dfa3babd2..cd39661b5bb7 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1163,15 +1163,17 @@ static void __ebt_unregister_table(struct net *net, struct ebt_table *table)\n \tmutex_lock(&ebt_mutex);\n \tlist_del(&table->list);\n \tmutex_unlock(&ebt_mutex);\n-\taudit_log_nfcfg(table->name, AF_BRIDGE, table->private->nentries,\n-\t\t\tAUDIT_XT_OP_UNREGISTER, GFP_KERNEL);\n-\tEBT_ENTRY_ITERATE(table->private->entries, table->private->entries_size,\n-\t\t\t  ebt_cleanup_entry, net, NULL);\n-\tif (table->private->nentries)\n-\t\tmodule_put(table->me);\n-\tvfree(table->private->entries);\n-\tebt_free_table_info(table->private);\n-\tvfree(table->private);\n+\tif (table->private) {\n+\t\taudit_log_nfcfg(table->name, AF_BRIDGE, table->private->nentries,\n+\t\t\t\tAUDIT_XT_OP_UNREGISTER, GFP_KERNEL);\n+\t\tEBT_ENTRY_ITERATE(table->private->entries, table->private->entries_size,\n+\t\t\t\t  ebt_cleanup_entry, net, NULL);\n+\t\tif (table->private->nentries)\n+\t\t\tmodule_put(table->me);\n+\t\tvfree(table->private->entries);\n+\t\tebt_free_table_info(table->private);\n+\t\tvfree(table->private);\n+\t}\n \tkfree(table->ops);\n \tkfree(table);\n }\n"
        ],
        "error": []
    },
    "874c5bfa1234dcef000574388df68a8d08274ecd": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..7bf586e81778 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -101,6 +101,8 @@ static bool hfsplus_release_folio(struct folio *folio, gfp_t mask)\n \t\tif (res && node) {\n \t\t\thfs_bnode_unhash(node);\n \t\t\thfs_bnode_free(node);\n+\t\t\tnode = NULL; // Ensure node is not used after free\n+\t\t\tnode = NULL; // Ensure node is not used after free\n \t\t}\n \t\tspin_unlock(&tree->hash_lock);\n \t} else {\n",
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..fc4a347e0f0f 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -101,6 +101,8 @@ static bool hfsplus_release_folio(struct folio *folio, gfp_t mask)\n \t\tif (res && node) {\n \t\t\thfs_bnode_unhash(node);\n \t\t\thfs_bnode_free(node);\n+\t\t\tnode = NULL;\n+\t\t\tnode = NULL;\n \t\t}\n \t\tspin_unlock(&tree->hash_lock);\n \t} else {\n",
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..fc4a347e0f0f 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -101,6 +101,8 @@ static bool hfsplus_release_folio(struct folio *folio, gfp_t mask)\n \t\tif (res && node) {\n \t\t\thfs_bnode_unhash(node);\n \t\t\thfs_bnode_free(node);\n+\t\t\tnode = NULL;\n+\t\t\tnode = NULL;\n \t\t}\n \t\tspin_unlock(&tree->hash_lock);\n \t} else {\n",
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..fc4a347e0f0f 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -101,6 +101,8 @@ static bool hfsplus_release_folio(struct folio *folio, gfp_t mask)\n \t\tif (res && node) {\n \t\t\thfs_bnode_unhash(node);\n \t\t\thfs_bnode_free(node);\n+\t\t\tnode = NULL;\n+\t\t\tnode = NULL;\n \t\t}\n \t\tspin_unlock(&tree->hash_lock);\n \t} else {\n",
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..fc4a347e0f0f 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -101,6 +101,8 @@ static bool hfsplus_release_folio(struct folio *folio, gfp_t mask)\n \t\tif (res && node) {\n \t\t\thfs_bnode_unhash(node);\n \t\t\thfs_bnode_free(node);\n+\t\t\tnode = NULL;\n+\t\t\tnode = NULL;\n \t\t}\n \t\tspin_unlock(&tree->hash_lock);\n \t} else {\n"
        ],
        "error": []
    },
    "bb281e89381b9ed55728c274447a575e69a96c35": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/overlayfs/ovl_entry.h b/fs/overlayfs/ovl_entry.h\nindex e1af8f660698..7fbfd2fbe4f7 100644\n--- a/fs/overlayfs/ovl_entry.h\n+++ b/fs/overlayfs/ovl_entry.h\n@@ -147,5 +147,5 @@ static inline struct ovl_inode *OVL_I(struct inode *inode)\n \n static inline struct dentry *ovl_upperdentry_dereference(struct ovl_inode *oi)\n {\n-\treturn READ_ONCE(oi->__upperdentry);\n+\treturn oi ? READ_ONCE(oi->__upperdentry) : NULL;\n }\ndiff --git a/fs/overlayfs/util.c b/fs/overlayfs/util.c\nindex 81a57a8d80d9..de3d8672d84e 100644\n--- a/fs/overlayfs/util.c\n+++ b/fs/overlayfs/util.c\n@@ -210,7 +210,8 @@ enum ovl_path_type ovl_path_realdata(struct dentry *dentry, struct path *path)\n \n struct dentry *ovl_dentry_upper(struct dentry *dentry)\n {\n-\treturn ovl_upperdentry_dereference(OVL_I(d_inode(dentry)));\n+\tstruct ovl_inode *oi = OVL_I(d_inode(dentry));\n+\treturn oi ? ovl_upperdentry_dereference(oi) : NULL;\n }\n \n struct dentry *ovl_dentry_lower(struct dentry *dentry)\n",
            "diff --git a/fs/overlayfs/util.c b/fs/overlayfs/util.c\nindex 81a57a8d80d9..de3d8672d84e 100644\n--- a/fs/overlayfs/util.c\n+++ b/fs/overlayfs/util.c\n@@ -210,7 +210,8 @@ enum ovl_path_type ovl_path_realdata(struct dentry *dentry, struct path *path)\n \n struct dentry *ovl_dentry_upper(struct dentry *dentry)\n {\n-\treturn ovl_upperdentry_dereference(OVL_I(d_inode(dentry)));\n+\tstruct ovl_inode *oi = OVL_I(d_inode(dentry));\n+\treturn oi ? ovl_upperdentry_dereference(oi) : NULL;\n }\n \n struct dentry *ovl_dentry_lower(struct dentry *dentry)\n",
            "diff --git a/fs/overlayfs/ovl_entry.h b/fs/overlayfs/ovl_entry.h\nindex e1af8f660698..fabe4ff99354 100644\n--- a/fs/overlayfs/ovl_entry.h\n+++ b/fs/overlayfs/ovl_entry.h\n@@ -147,5 +147,7 @@ static inline struct ovl_inode *OVL_I(struct inode *inode)\n \n static inline struct dentry *ovl_upperdentry_dereference(struct ovl_inode *oi)\n {\n+\tif (!oi)\n+\t\treturn NULL;\n \treturn READ_ONCE(oi->__upperdentry);\n }\n",
            "diff --git a/fs/overlayfs/ovl_entry.h b/fs/overlayfs/ovl_entry.h\nindex e1af8f660698..c95b224e48b5 100644\n--- a/fs/overlayfs/ovl_entry.h\n+++ b/fs/overlayfs/ovl_entry.h\n@@ -147,5 +147,6 @@ static inline struct ovl_inode *OVL_I(struct inode *inode)\n \n static inline struct dentry *ovl_upperdentry_dereference(struct ovl_inode *oi)\n {\n-\treturn READ_ONCE(oi->__upperdentry);\n+\tstruct dentry *upperdentry = READ_ONCE(oi->__upperdentry);\n+\treturn upperdentry ? upperdentry : NULL;\n }\n",
            "diff --git a/fs/overlayfs/ovl_entry.h b/fs/overlayfs/ovl_entry.h\nindex e1af8f660698..fabe4ff99354 100644\n--- a/fs/overlayfs/ovl_entry.h\n+++ b/fs/overlayfs/ovl_entry.h\n@@ -147,5 +147,7 @@ static inline struct ovl_inode *OVL_I(struct inode *inode)\n \n static inline struct dentry *ovl_upperdentry_dereference(struct ovl_inode *oi)\n {\n+\tif (!oi)\n+\t\treturn NULL;\n \treturn READ_ONCE(oi->__upperdentry);\n }\ndiff --git a/fs/overlayfs/util.c b/fs/overlayfs/util.c\nindex 81a57a8d80d9..4b9150acc837 100644\n--- a/fs/overlayfs/util.c\n+++ b/fs/overlayfs/util.c\n@@ -210,7 +210,10 @@ enum ovl_path_type ovl_path_realdata(struct dentry *dentry, struct path *path)\n \n struct dentry *ovl_dentry_upper(struct dentry *dentry)\n {\n-\treturn ovl_upperdentry_dereference(OVL_I(d_inode(dentry)));\n+\tstruct ovl_inode *oi = OVL_I(d_inode(dentry));\n+\tif (!oi)\n+\t\treturn NULL;\n+\treturn ovl_upperdentry_dereference(oi);\n }\n \n struct dentry *ovl_dentry_lower(struct dentry *dentry)\n"
        ],
        "error": []
    },
    "e9d3ca982b76224e183481018baa693a26655ac4": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex 1602d74b5eeb..07a67bf60e2b 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -341,8 +341,13 @@ static int ext4_update_inline_data(handle_t *handle, struct inode *inode,\n \n \tBUG_ON(is.s.not_found);\n \n-\tlen -= EXT4_MIN_INLINE_DATA_SIZE;\n-\tvalue = kzalloc(len, GFP_NOFS);\n+\tif (len > EXT4_MIN_INLINE_DATA_SIZE) {\n+\t\tlen -= EXT4_MIN_INLINE_DATA_SIZE;\n+\t\tvalue = kzalloc(len, GFP_NOFS);\n+\t} else {\n+\t\terror = -EINVAL;\n+\t\tgoto out;\n+\t}\n \tif (!value) {\n \t\terror = -ENOMEM;\n \t\tgoto out;\n",
            "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex 1602d74b5eeb..c090a47237a9 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -143,6 +143,7 @@ int ext4_find_inline_data_nolock(struct inode *inode)\n \terror = ext4_get_inode_loc(inode, &is.iloc);\n \tif (error)\n \t\treturn error;\n+\tbool iloc_initialized = true;\n \n \terror = ext4_xattr_ibody_find(inode, &i, &is);\n \tif (error)\n",
            "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex 1602d74b5eeb..00f69fc0774c 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -341,6 +341,11 @@ static int ext4_update_inline_data(handle_t *handle, struct inode *inode,\n \n \tBUG_ON(is.s.not_found);\n \n+\tif (len <= EXT4_MIN_INLINE_DATA_SIZE) {\n+\t\terror = -EINVAL;\n+\t\tgoto out;\n+\t}\n+\n \tlen -= EXT4_MIN_INLINE_DATA_SIZE;\n \tvalue = kzalloc(len, GFP_NOFS);\n \tif (!value) {\n",
            "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex 1602d74b5eeb..83ada33e33da 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -342,7 +342,7 @@ static int ext4_update_inline_data(handle_t *handle, struct inode *inode,\n \tBUG_ON(is.s.not_found);\n \n \tlen -= EXT4_MIN_INLINE_DATA_SIZE;\n-\tvalue = kzalloc(len, GFP_NOFS);\n+\tvalue = kzalloc(len, GFP_KERNEL);\n \tif (!value) {\n \t\terror = -ENOMEM;\n \t\tgoto out;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex 1602d74b5eeb..28c0d3320e4b 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -341,6 +341,11 @@ static int ext4_update_inline_data(handle_t *handle, struct inode *inode,\n \n \tBUG_ON(is.s.not_found);\n \n+\tif (len > EXT4_MAX_INLINE_DATA_SIZE) {\n+\t\terror = -EINVAL;\n+\t\tgoto out;\n+\t}\n+\n \tlen -= EXT4_MIN_INLINE_DATA_SIZE;\n \tvalue = kzalloc(len, GFP_NOFS);\n \tif (!value) {\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "251bb5cec78ffc6f0f277696516aafb04b1e1bd9": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/bpf/log.c b/kernel/bpf/log.c\nindex 046ddff37a76..a31e3a181cc4 100644\n--- a/kernel/bpf/log.c\n+++ b/kernel/bpf/log.c\n@@ -60,9 +60,9 @@ void bpf_verifier_vlog(struct bpf_verifier_log *log, const char *fmt,\n \tu64 cur_pos;\n \tu32 new_n, n;\n \n-\tn = vscnprintf(log->kbuf, BPF_VERIFIER_TMP_LOG_SIZE, fmt, args);\n+\tn = vscnprintf(log->kbuf, BPF_VERIFIER_TMP_LOG_SIZE * 2, fmt, args);\n \n-\tWARN_ONCE(n >= BPF_VERIFIER_TMP_LOG_SIZE - 1,\n+\tWARN_ONCE(n >= BPF_VERIFIER_TMP_LOG_SIZE * 2 - 1,\n \t\t  \"verifier log line truncated - local buffer too short\\n\");\n \n \tif (log->level == BPF_LOG_KERNEL) {\n",
            "diff --git a/kernel/bpf/log.c b/kernel/bpf/log.c\nindex 046ddff37a76..a31e3a181cc4 100644\n--- a/kernel/bpf/log.c\n+++ b/kernel/bpf/log.c\n@@ -60,9 +60,9 @@ void bpf_verifier_vlog(struct bpf_verifier_log *log, const char *fmt,\n \tu64 cur_pos;\n \tu32 new_n, n;\n \n-\tn = vscnprintf(log->kbuf, BPF_VERIFIER_TMP_LOG_SIZE, fmt, args);\n+\tn = vscnprintf(log->kbuf, BPF_VERIFIER_TMP_LOG_SIZE * 2, fmt, args);\n \n-\tWARN_ONCE(n >= BPF_VERIFIER_TMP_LOG_SIZE - 1,\n+\tWARN_ONCE(n >= BPF_VERIFIER_TMP_LOG_SIZE * 2 - 1,\n \t\t  \"verifier log line truncated - local buffer too short\\n\");\n \n \tif (log->level == BPF_LOG_KERNEL) {\n",
            "diff --git a/kernel/bpf/log.c b/kernel/bpf/log.c\nindex 046ddff37a76..a31e3a181cc4 100644\n--- a/kernel/bpf/log.c\n+++ b/kernel/bpf/log.c\n@@ -60,9 +60,9 @@ void bpf_verifier_vlog(struct bpf_verifier_log *log, const char *fmt,\n \tu64 cur_pos;\n \tu32 new_n, n;\n \n-\tn = vscnprintf(log->kbuf, BPF_VERIFIER_TMP_LOG_SIZE, fmt, args);\n+\tn = vscnprintf(log->kbuf, BPF_VERIFIER_TMP_LOG_SIZE * 2, fmt, args);\n \n-\tWARN_ONCE(n >= BPF_VERIFIER_TMP_LOG_SIZE - 1,\n+\tWARN_ONCE(n >= BPF_VERIFIER_TMP_LOG_SIZE * 2 - 1,\n \t\t  \"verifier log line truncated - local buffer too short\\n\");\n \n \tif (log->level == BPF_LOG_KERNEL) {\n",
            "diff --git a/kernel/bpf/log.c b/kernel/bpf/log.c\nindex 046ddff37a76..a31e3a181cc4 100644\n--- a/kernel/bpf/log.c\n+++ b/kernel/bpf/log.c\n@@ -60,9 +60,9 @@ void bpf_verifier_vlog(struct bpf_verifier_log *log, const char *fmt,\n \tu64 cur_pos;\n \tu32 new_n, n;\n \n-\tn = vscnprintf(log->kbuf, BPF_VERIFIER_TMP_LOG_SIZE, fmt, args);\n+\tn = vscnprintf(log->kbuf, BPF_VERIFIER_TMP_LOG_SIZE * 2, fmt, args);\n \n-\tWARN_ONCE(n >= BPF_VERIFIER_TMP_LOG_SIZE - 1,\n+\tWARN_ONCE(n >= BPF_VERIFIER_TMP_LOG_SIZE * 2 - 1,\n \t\t  \"verifier log line truncated - local buffer too short\\n\");\n \n \tif (log->level == BPF_LOG_KERNEL) {\n"
        ],
        "error": []
    },
    "accafa9281766c4630ea5aeaad0d83decd70406d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex a8ce522ac747..213aa823c2de 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1032,16 +1032,19 @@ int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)\n \t\tif (unlikely(err))\n \t\t\treturn err;\n \t\tspin_lock(&nilfs->ns_inode_lock);\n-\t\tif (ii->i_bh == NULL)\n+\t\tif (ii->i_bh == NULL) {\n \t\t\tii->i_bh = *pbh;\n-\t\telse {\n+\t\t\tget_bh(ii->i_bh);\n+\t\t} else {\n \t\t\tbrelse(*pbh);\n \t\t\t*pbh = ii->i_bh;\n+\t\t\tget_bh(*pbh);\n \t\t}\n-\t} else\n+\t} else {\n \t\t*pbh = ii->i_bh;\n+\t\tget_bh(*pbh);\n+\t}\n \n-\tget_bh(*pbh);\n \tspin_unlock(&nilfs->ns_inode_lock);\n \treturn 0;\n }\n",
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex a8ce522ac747..f6f62bf47fff 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1032,11 +1032,13 @@ int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)\n \t\tif (unlikely(err))\n \t\t\treturn err;\n \t\tspin_lock(&nilfs->ns_inode_lock);\n-\t\tif (ii->i_bh == NULL)\n+\t\tif (ii->i_bh == NULL) {\n \t\t\tii->i_bh = *pbh;\n-\t\telse {\n+\t\t\tget_bh(ii->i_bh);  // Ensure the buffer head is properly referenced\n+\t\t} else {\n \t\t\tbrelse(*pbh);\n \t\t\t*pbh = ii->i_bh;\n+\t\t\tget_bh(ii->i_bh);  // Ensure the buffer head is properly referenced\n \t\t}\n \t} else\n \t\t*pbh = ii->i_bh;\n",
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex a8ce522ac747..674d764375bc 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1032,16 +1032,19 @@ int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)\n \t\tif (unlikely(err))\n \t\t\treturn err;\n \t\tspin_lock(&nilfs->ns_inode_lock);\n-\t\tif (ii->i_bh == NULL)\n+\t\tif (ii->i_bh == NULL) {\n \t\t\tii->i_bh = *pbh;\n-\t\telse {\n+\t\t\tget_bh(ii->i_bh);  // Ensure buffer head is valid\n+\t\t} else {\n \t\t\tbrelse(*pbh);\n \t\t\t*pbh = ii->i_bh;\n+\t\t\tget_bh(ii->i_bh);  // Ensure buffer head is valid\n \t\t}\n-\t} else\n+\t} else {\n \t\t*pbh = ii->i_bh;\n+\t\tget_bh(ii->i_bh);  // Ensure buffer head is valid\n+\t}\n \n-\tget_bh(*pbh);\n \tspin_unlock(&nilfs->ns_inode_lock);\n \treturn 0;\n }\n",
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex a8ce522ac747..efd12d9a8dc0 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1032,16 +1032,19 @@ int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)\n \t\tif (unlikely(err))\n \t\t\treturn err;\n \t\tspin_lock(&nilfs->ns_inode_lock);\n-\t\tif (ii->i_bh == NULL)\n+\t\tif (ii->i_bh == NULL) {\n \t\t\tii->i_bh = *pbh;\n-\t\telse {\n+\t\t\tget_bh(ii->i_bh);  // Ensure buffer head is valid\n+\t\t} else {\n \t\t\tbrelse(*pbh);\n \t\t\t*pbh = ii->i_bh;\n+\t\t\tget_bh(*pbh);  // Ensure buffer head is valid\n \t\t}\n-\t} else\n+\t} else {\n \t\t*pbh = ii->i_bh;\n+\t\tget_bh(*pbh);  // Ensure buffer head is valid\n+\t}\n \n-\tget_bh(*pbh);\n \tspin_unlock(&nilfs->ns_inode_lock);\n \treturn 0;\n }\n",
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex a8ce522ac747..11711d0b8797 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1032,16 +1032,18 @@ int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)\n \t\tif (unlikely(err))\n \t\t\treturn err;\n \t\tspin_lock(&nilfs->ns_inode_lock);\n-\t\tif (ii->i_bh == NULL)\n+\t\tif (ii->i_bh == NULL) {\n \t\t\tii->i_bh = *pbh;\n-\t\telse {\n+\t\t\tget_bh(ii->i_bh); // Ensure buffer head is valid\n+\t\t} else {\n \t\t\tbrelse(*pbh);\n \t\t\t*pbh = ii->i_bh;\n+\t\t\tget_bh(ii->i_bh); // Ensure buffer head is valid\n \t\t}\n-\t} else\n+\t} else {\n \t\t*pbh = ii->i_bh;\n-\n-\tget_bh(*pbh);\n+\t\tget_bh(ii->i_bh); // Ensure buffer head is valid\n+\t}\n \tspin_unlock(&nilfs->ns_inode_lock);\n \treturn 0;\n }\n"
        ],
        "error": []
    },
    "8e9ea22655c782ac9af556ba3d4d822530a59390": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 4bb6d304eb4b..eea86d8fb31b 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -1951,6 +1951,11 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \t\tpipe = usb_rcvctrlpipe(data->usb_dev, 0);\n \telse\n \t\tpipe = usb_sndctrlpipe(data->usb_dev, 0);\n+\tif (is_in)\n+\t\trequest.req.bRequestType |= USB_DIR_IN;\n+\telse\n+\t\trequest.req.bRequestType &= ~USB_DIR_IN;\n+\n \trv = usb_control_msg(data->usb_dev,\n \t\t\tpipe,\n \t\t\trequest.req.bRequest,\n",
            "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 4bb6d304eb4b..c2ac77863d02 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -1947,10 +1947,13 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \t\t}\n \t}\n \n-\tif (is_in)\n+\tif (is_in) {\n \t\tpipe = usb_rcvctrlpipe(data->usb_dev, 0);\n-\telse\n+\t\trequest.req.bRequestType |= USB_DIR_IN;\n+\t} else {\n \t\tpipe = usb_sndctrlpipe(data->usb_dev, 0);\n+\t\trequest.req.bRequestType &= ~USB_DIR_IN;\n+\t}\n \trv = usb_control_msg(data->usb_dev,\n \t\t\tpipe,\n \t\t\trequest.req.bRequest,\n",
            "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 4bb6d304eb4b..97f362c00e36 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -1947,10 +1947,15 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \t\t}\n \t}\n \n-\tif (is_in)\n+\tif (is_in) {\n \t\tpipe = usb_rcvctrlpipe(data->usb_dev, 0);\n-\telse\n+\t\t/* Ensure bRequestType matches the direction */\n+\t\trequest.req.bRequestType |= USB_DIR_IN;\n+\t} else {\n \t\tpipe = usb_sndctrlpipe(data->usb_dev, 0);\n+\t\t/* Ensure bRequestType matches the direction */\n+\t\trequest.req.bRequestType &= ~USB_DIR_IN;\n+\t}\n \trv = usb_control_msg(data->usb_dev,\n \t\t\tpipe,\n \t\t\trequest.req.bRequest,\n",
            "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 4bb6d304eb4b..81d376ef4a02 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -1951,6 +1951,7 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \t\tpipe = usb_rcvctrlpipe(data->usb_dev, 0);\n \telse\n \t\tpipe = usb_sndctrlpipe(data->usb_dev, 0);\n+\trequest.req.bRequestType = is_in ? USB_DIR_IN : USB_DIR_OUT;\n \trv = usb_control_msg(data->usb_dev,\n \t\t\tpipe,\n \t\t\trequest.req.bRequest,\n",
            "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 4bb6d304eb4b..d22948d7f70e 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -1947,10 +1947,13 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \t\t}\n \t}\n \n-\tif (is_in)\n+\tif (is_in) {\n \t\tpipe = usb_rcvctrlpipe(data->usb_dev, 0);\n-\telse\n+\t\trequest.req.bRequestType |= USB_DIR_IN; // Ensure direction is set to IN\n+\t} else {\n \t\tpipe = usb_sndctrlpipe(data->usb_dev, 0);\n+\t\trequest.req.bRequestType &= ~USB_DIR_IN; // Ensure direction is set to OUT\n+\t}\n \trv = usb_control_msg(data->usb_dev,\n \t\t\tpipe,\n \t\t\trequest.req.bRequest,\n"
        ],
        "error": []
    },
    "14f3125f37b7c76896b25c222159f6c205ff7e08": {
        "non_crash": [
            "diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c\nindex 7da343efd090..e9aa831be19c 100644\n--- a/net/mac80211/cfg.c\n+++ b/net/mac80211/cfg.c\n@@ -517,12 +517,22 @@ static int ieee80211_del_key(struct wiphy *wiphy, struct net_device *dev,\n \t\tif (!sta)\n \t\t\tgoto out_unlock;\n \n+\t\tif (key_idx < 0 || key_idx >= ARRAY_SIZE(sta->ptk)) {\n+\t\t\tret = -EINVAL;\n+\t\t\tgoto out_unlock;\n+\t\t}\n+\n \t\tif (pairwise)\n \t\t\tkey = key_mtx_dereference(local, sta->ptk[key_idx]);\n \t\telse\n \t\t\tkey = key_mtx_dereference(local, sta->gtk[key_idx]);\n-\t} else\n+\t} else {\n+\t\tif (key_idx < 0 || key_idx >= ARRAY_SIZE(sdata->keys)) {\n+\t\t\tret = -EINVAL;\n+\t\t\tgoto out_unlock;\n+\t\t}\n \t\tkey = key_mtx_dereference(local, sdata->keys[key_idx]);\n+\t}\n \n \tif (!key) {\n \t\tret = -ENOENT;\n",
            "diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c\nindex 7da343efd090..e9f0d2685825 100644\n--- a/net/mac80211/cfg.c\n+++ b/net/mac80211/cfg.c\n@@ -510,6 +510,11 @@ static int ieee80211_del_key(struct wiphy *wiphy, struct net_device *dev,\n \tmutex_lock(&local->sta_mtx);\n \tmutex_lock(&local->key_mtx);\n \n+\tif (key_idx < 0 || key_idx >= 4) {\n+\t\tret = -EINVAL;\n+\t\tgoto out_unlock;\n+\t}\n+\n \tif (mac_addr) {\n \t\tret = -ENOENT;\n \n",
            "diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c\nindex 7da343efd090..e9f0d2685825 100644\n--- a/net/mac80211/cfg.c\n+++ b/net/mac80211/cfg.c\n@@ -510,6 +510,11 @@ static int ieee80211_del_key(struct wiphy *wiphy, struct net_device *dev,\n \tmutex_lock(&local->sta_mtx);\n \tmutex_lock(&local->key_mtx);\n \n+\tif (key_idx < 0 || key_idx >= 4) {\n+\t\tret = -EINVAL;\n+\t\tgoto out_unlock;\n+\t}\n+\n \tif (mac_addr) {\n \t\tret = -ENOENT;\n \n",
            "diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c\nindex 7da343efd090..e9f0d2685825 100644\n--- a/net/mac80211/cfg.c\n+++ b/net/mac80211/cfg.c\n@@ -510,6 +510,11 @@ static int ieee80211_del_key(struct wiphy *wiphy, struct net_device *dev,\n \tmutex_lock(&local->sta_mtx);\n \tmutex_lock(&local->key_mtx);\n \n+\tif (key_idx < 0 || key_idx >= 4) {\n+\t\tret = -EINVAL;\n+\t\tgoto out_unlock;\n+\t}\n+\n \tif (mac_addr) {\n \t\tret = -ENOENT;\n \n",
            "diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c\nindex 7da343efd090..e9f0d2685825 100644\n--- a/net/mac80211/cfg.c\n+++ b/net/mac80211/cfg.c\n@@ -510,6 +510,11 @@ static int ieee80211_del_key(struct wiphy *wiphy, struct net_device *dev,\n \tmutex_lock(&local->sta_mtx);\n \tmutex_lock(&local->key_mtx);\n \n+\tif (key_idx < 0 || key_idx >= 4) {\n+\t\tret = -EINVAL;\n+\t\tgoto out_unlock;\n+\t}\n+\n \tif (mac_addr) {\n \t\tret = -ENOENT;\n \n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "993d8b5e64393ed9e6a70f9ae4de0119c605a822": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/vhost/vhost.c b/drivers/vhost/vhost.c\nindex 59edb5a1ffe2..e0255ae0397d 100644\n--- a/drivers/vhost/vhost.c\n+++ b/drivers/vhost/vhost.c\n@@ -2332,7 +2332,9 @@ int vhost_get_vq_desc(struct vhost_virtqueue *vq,\n \n \t/* Assume notifications from guest are disabled at this point,\n \t * if they aren't we would need to update avail_event index. */\n-\tBUG_ON(!(vq->used_flags & VRING_USED_F_NO_NOTIFY));\n+\tif (!(vq->used_flags & VRING_USED_F_NO_NOTIFY)) {\n+\t\tvq->used_flags |= VRING_USED_F_NO_NOTIFY;\n+\t}\n \treturn head;\n }\n EXPORT_SYMBOL_GPL(vhost_get_vq_desc);\n",
            "diff --git a/drivers/vhost/vhost.c b/drivers/vhost/vhost.c\nindex 59edb5a1ffe2..cbbcf00a385d 100644\n--- a/drivers/vhost/vhost.c\n+++ b/drivers/vhost/vhost.c\n@@ -2332,7 +2332,10 @@ int vhost_get_vq_desc(struct vhost_virtqueue *vq,\n \n \t/* Assume notifications from guest are disabled at this point,\n \t * if they aren't we would need to update avail_event index. */\n-\tBUG_ON(!(vq->used_flags & VRING_USED_F_NO_NOTIFY));\n+\t/* Ensure that the VRING_USED_F_NO_NOTIFY flag is set */\n+\tif (!(vq->used_flags & VRING_USED_F_NO_NOTIFY)) {\n+\t\tvq->used_flags |= VRING_USED_F_NO_NOTIFY;\n+\t}\n \treturn head;\n }\n EXPORT_SYMBOL_GPL(vhost_get_vq_desc);\n",
            "diff --git a/drivers/vhost/vhost.c b/drivers/vhost/vhost.c\nindex 59edb5a1ffe2..e0255ae0397d 100644\n--- a/drivers/vhost/vhost.c\n+++ b/drivers/vhost/vhost.c\n@@ -2332,7 +2332,9 @@ int vhost_get_vq_desc(struct vhost_virtqueue *vq,\n \n \t/* Assume notifications from guest are disabled at this point,\n \t * if they aren't we would need to update avail_event index. */\n-\tBUG_ON(!(vq->used_flags & VRING_USED_F_NO_NOTIFY));\n+\tif (!(vq->used_flags & VRING_USED_F_NO_NOTIFY)) {\n+\t\tvq->used_flags |= VRING_USED_F_NO_NOTIFY;\n+\t}\n \treturn head;\n }\n EXPORT_SYMBOL_GPL(vhost_get_vq_desc);\n",
            "diff --git a/drivers/vhost/vhost.c b/drivers/vhost/vhost.c\nindex 59edb5a1ffe2..d0de5d6cd2e3 100644\n--- a/drivers/vhost/vhost.c\n+++ b/drivers/vhost/vhost.c\n@@ -2332,6 +2332,7 @@ int vhost_get_vq_desc(struct vhost_virtqueue *vq,\n \n \t/* Assume notifications from guest are disabled at this point,\n \t * if they aren't we would need to update avail_event index. */\n+\tvq->used_flags |= VRING_USED_F_NO_NOTIFY;\n \tBUG_ON(!(vq->used_flags & VRING_USED_F_NO_NOTIFY));\n \treturn head;\n }\n",
            "diff --git a/drivers/vhost/vhost.c b/drivers/vhost/vhost.c\nindex 59edb5a1ffe2..e0255ae0397d 100644\n--- a/drivers/vhost/vhost.c\n+++ b/drivers/vhost/vhost.c\n@@ -2332,7 +2332,9 @@ int vhost_get_vq_desc(struct vhost_virtqueue *vq,\n \n \t/* Assume notifications from guest are disabled at this point,\n \t * if they aren't we would need to update avail_event index. */\n-\tBUG_ON(!(vq->used_flags & VRING_USED_F_NO_NOTIFY));\n+\tif (!(vq->used_flags & VRING_USED_F_NO_NOTIFY)) {\n+\t\tvq->used_flags |= VRING_USED_F_NO_NOTIFY;\n+\t}\n \treturn head;\n }\n EXPORT_SYMBOL_GPL(vhost_get_vq_desc);\n"
        ],
        "error": []
    },
    "789df5b54ebd19aec0b5c3900c933d1910db8ec5": {
        "non_crash": [
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 6bdd502527f8..ab5b8c7959fc 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2548,6 +2548,10 @@ static int ext4_xattr_move_to_block(handle_t *handle, struct inode *inode,\n \n \tis = kzalloc(sizeof(struct ext4_xattr_ibody_find), GFP_NOFS);\n \tbs = kzalloc(sizeof(struct ext4_xattr_block_find), GFP_NOFS);\n+\tif (value_size > PAGE_SIZE) {\n+\t\terror = -ENOMEM;\n+\t\tgoto out;\n+\t}\n \tbuffer = kmalloc(value_size, GFP_NOFS);\n \tb_entry_name = kmalloc(entry->e_name_len + 1, GFP_NOFS);\n \tif (!is || !bs || !buffer || !b_entry_name) {\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 6bdd502527f8..a7e4f0387263 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -225,7 +225,16 @@ ext4_xattr_check_entries(struct ext4_xattr_entry *entry, void *end,\n \t\tentry = EXT4_XATTR_NEXT(entry);\n \t}\n \n-\treturn 0;\n+\tout_free_b_entry_name:\n+\tkfree(b_entry_name);\n+out_free_buffer:\n+\tkfree(buffer);\n+out_free_bs:\n+\tkfree(bs);\n+out_free_is:\n+\tkfree(is);\n+out:\n+\treturn error;\n }\n \n static inline int\n@@ -491,7 +500,7 @@ ext4_xattr_inode_get(struct inode *inode, struct ext4_xattr_entry *entry,\n \t\t\t\t    le32_to_cpu(entry->e_hash), &ea_inode);\n \tif (err) {\n \t\tea_inode = NULL;\n-\t\tgoto out;\n+\t\tgoto out_free_b_entry_name;\n \t}\n \n \tif (i_size_read(ea_inode) != size) {\n@@ -2547,12 +2556,24 @@ static int ext4_xattr_move_to_block(handle_t *handle, struct inode *inode,\n \tint error;\n \n \tis = kzalloc(sizeof(struct ext4_xattr_ibody_find), GFP_NOFS);\n+\tif (!is) {\n+\t\terror = -ENOMEM;\n+\t\tgoto out;\n+\t}\n \tbs = kzalloc(sizeof(struct ext4_xattr_block_find), GFP_NOFS);\n+\tif (!bs) {\n+\t\terror = -ENOMEM;\n+\t\tgoto out_free_is;\n+\t}\n \tbuffer = kmalloc(value_size, GFP_NOFS);\n+\tif (!buffer) {\n+\t\terror = -ENOMEM;\n+\t\tgoto out_free_bs;\n+\t}\n \tb_entry_name = kmalloc(entry->e_name_len + 1, GFP_NOFS);\n-\tif (!is || !bs || !buffer || !b_entry_name) {\n+\tif (!b_entry_name) {\n \t\terror = -ENOMEM;\n-\t\tgoto out;\n+\t\tgoto out_free_buffer;\n \t}\n \n \tis->s.not_found = -ENODATA;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 6bdd502527f8..a7e4f0387263 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -225,7 +225,16 @@ ext4_xattr_check_entries(struct ext4_xattr_entry *entry, void *end,\n \t\tentry = EXT4_XATTR_NEXT(entry);\n \t}\n \n-\treturn 0;\n+\tout_free_b_entry_name:\n+\tkfree(b_entry_name);\n+out_free_buffer:\n+\tkfree(buffer);\n+out_free_bs:\n+\tkfree(bs);\n+out_free_is:\n+\tkfree(is);\n+out:\n+\treturn error;\n }\n \n static inline int\n@@ -491,7 +500,7 @@ ext4_xattr_inode_get(struct inode *inode, struct ext4_xattr_entry *entry,\n \t\t\t\t    le32_to_cpu(entry->e_hash), &ea_inode);\n \tif (err) {\n \t\tea_inode = NULL;\n-\t\tgoto out;\n+\t\tgoto out_free_b_entry_name;\n \t}\n \n \tif (i_size_read(ea_inode) != size) {\n@@ -2547,12 +2556,24 @@ static int ext4_xattr_move_to_block(handle_t *handle, struct inode *inode,\n \tint error;\n \n \tis = kzalloc(sizeof(struct ext4_xattr_ibody_find), GFP_NOFS);\n+\tif (!is) {\n+\t\terror = -ENOMEM;\n+\t\tgoto out;\n+\t}\n \tbs = kzalloc(sizeof(struct ext4_xattr_block_find), GFP_NOFS);\n+\tif (!bs) {\n+\t\terror = -ENOMEM;\n+\t\tgoto out_free_is;\n+\t}\n \tbuffer = kmalloc(value_size, GFP_NOFS);\n+\tif (!buffer) {\n+\t\terror = -ENOMEM;\n+\t\tgoto out_free_bs;\n+\t}\n \tb_entry_name = kmalloc(entry->e_name_len + 1, GFP_NOFS);\n-\tif (!is || !bs || !buffer || !b_entry_name) {\n+\tif (!b_entry_name) {\n \t\terror = -ENOMEM;\n-\t\tgoto out;\n+\t\tgoto out_free_buffer;\n \t}\n \n \tis->s.not_found = -ENODATA;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 6bdd502527f8..88e3609f6679 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -550,6 +550,10 @@ ext4_xattr_block_get(struct inode *inode, int name_index, const char *name,\n \t\tatomic_read(&(bh->b_count)), le32_to_cpu(BHDR(bh)->h_refcount));\n \terror = ext4_xattr_check_block(inode, bh);\n \tif (error)\n+\t\tkfree(is);\n+\t\tkfree(bs);\n+\t\tkfree(buffer);\n+\t\tkfree(b_entry_name);\n \t\tgoto cleanup;\n \text4_xattr_block_cache_insert(ea_block_cache, bh);\n \tentry = BFIRST(bh);\n@@ -1832,8 +1836,13 @@ ext4_xattr_block_find(struct inode *inode, struct ext4_xattr_info *i,\n \t\t\tatomic_read(&(bs->bh->b_count)),\n \t\t\tle32_to_cpu(BHDR(bs->bh)->h_refcount));\n \t\terror = ext4_xattr_check_block(inode, bs->bh);\n-\t\tif (error)\n+\t\tif (error) {\n+\t\t\tkfree(is);\n+\t\t\tkfree(bs);\n+\t\t\tkfree(buffer);\n+\t\t\tkfree(b_entry_name);\n \t\t\treturn error;\n+\t\t}\n \t\t/* Find the named attribute. */\n \t\tbs->s.base = BHDR(bs->bh);\n \t\tbs->s.first = BFIRST(bs->bh);\n@@ -2552,6 +2561,10 @@ static int ext4_xattr_move_to_block(handle_t *handle, struct inode *inode,\n \tb_entry_name = kmalloc(entry->e_name_len + 1, GFP_NOFS);\n \tif (!is || !bs || !buffer || !b_entry_name) {\n \t\terror = -ENOMEM;\n+\t\tkfree(is);\n+\t\tkfree(bs);\n+\t\tkfree(buffer);\n+\t\tkfree(b_entry_name);\n \t\tgoto out;\n \t}\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 6bdd502527f8..a7e4f0387263 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -225,7 +225,16 @@ ext4_xattr_check_entries(struct ext4_xattr_entry *entry, void *end,\n \t\tentry = EXT4_XATTR_NEXT(entry);\n \t}\n \n-\treturn 0;\n+\tout_free_b_entry_name:\n+\tkfree(b_entry_name);\n+out_free_buffer:\n+\tkfree(buffer);\n+out_free_bs:\n+\tkfree(bs);\n+out_free_is:\n+\tkfree(is);\n+out:\n+\treturn error;\n }\n \n static inline int\n@@ -491,7 +500,7 @@ ext4_xattr_inode_get(struct inode *inode, struct ext4_xattr_entry *entry,\n \t\t\t\t    le32_to_cpu(entry->e_hash), &ea_inode);\n \tif (err) {\n \t\tea_inode = NULL;\n-\t\tgoto out;\n+\t\tgoto out_free_b_entry_name;\n \t}\n \n \tif (i_size_read(ea_inode) != size) {\n@@ -2547,12 +2556,24 @@ static int ext4_xattr_move_to_block(handle_t *handle, struct inode *inode,\n \tint error;\n \n \tis = kzalloc(sizeof(struct ext4_xattr_ibody_find), GFP_NOFS);\n+\tif (!is) {\n+\t\terror = -ENOMEM;\n+\t\tgoto out;\n+\t}\n \tbs = kzalloc(sizeof(struct ext4_xattr_block_find), GFP_NOFS);\n+\tif (!bs) {\n+\t\terror = -ENOMEM;\n+\t\tgoto out_free_is;\n+\t}\n \tbuffer = kmalloc(value_size, GFP_NOFS);\n+\tif (!buffer) {\n+\t\terror = -ENOMEM;\n+\t\tgoto out_free_bs;\n+\t}\n \tb_entry_name = kmalloc(entry->e_name_len + 1, GFP_NOFS);\n-\tif (!is || !bs || !buffer || !b_entry_name) {\n+\tif (!b_entry_name) {\n \t\terror = -ENOMEM;\n-\t\tgoto out;\n+\t\tgoto out_free_buffer;\n \t}\n \n \tis->s.not_found = -ENODATA;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "8dc7a6aed7b8ead4c982ecdf2cd1ea5a4c3b57bb": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/inode.c b/fs/inode.c\nindex b608528efd3a..93594ac3cb07 100644\n--- a/fs/inode.c\n+++ b/fs/inode.c\n@@ -2005,7 +2005,7 @@ static int __remove_privs(struct user_namespace *mnt_userns,\n {\n \tstruct iattr newattrs;\n \n-\tnewattrs.ia_valid = ATTR_FORCE | kill;\n+\tnewattrs.ia_valid = kill ? (ATTR_FORCE | kill) : kill;\n \t/*\n \t * Note we call this on write, so notify_change will not\n \t * encounter any conflicting delegations:\n",
            "diff --git a/fs/inode.c b/fs/inode.c\nindex b608528efd3a..dd6f0f366688 100644\n--- a/fs/inode.c\n+++ b/fs/inode.c\n@@ -2005,7 +2005,11 @@ static int __remove_privs(struct user_namespace *mnt_userns,\n {\n \tstruct iattr newattrs;\n \n-\tnewattrs.ia_valid = ATTR_FORCE | kill;\n+\tif (kill >= 0) {\n+\t\tnewattrs.ia_valid = ATTR_FORCE | kill;\n+\t} else {\n+\t\treturn -EINVAL; // Return an error if kill is invalid\n+\t}\n \t/*\n \t * Note we call this on write, so notify_change will not\n \t * encounter any conflicting delegations:\n",
            "diff --git a/fs/inode.c b/fs/inode.c\nindex b608528efd3a..deafc5cc737b 100644\n--- a/fs/inode.c\n+++ b/fs/inode.c\n@@ -2005,6 +2005,9 @@ static int __remove_privs(struct user_namespace *mnt_userns,\n {\n \tstruct iattr newattrs;\n \n+\tif (kill & ~(ATTR_KILL_SUID | ATTR_KILL_SGID | ATTR_KILL_PRIV)) {\n+\t\treturn -EINVAL; // Invalid attribute, return error\n+\t}\n \tnewattrs.ia_valid = ATTR_FORCE | kill;\n \t/*\n \t * Note we call this on write, so notify_change will not\n",
            "diff --git a/fs/inode.c b/fs/inode.c\nindex b608528efd3a..dd6f0f366688 100644\n--- a/fs/inode.c\n+++ b/fs/inode.c\n@@ -2005,7 +2005,11 @@ static int __remove_privs(struct user_namespace *mnt_userns,\n {\n \tstruct iattr newattrs;\n \n-\tnewattrs.ia_valid = ATTR_FORCE | kill;\n+\tif (kill >= 0) {\n+\t\tnewattrs.ia_valid = ATTR_FORCE | kill;\n+\t} else {\n+\t\treturn -EINVAL; // Return an error if kill is invalid\n+\t}\n \t/*\n \t * Note we call this on write, so notify_change will not\n \t * encounter any conflicting delegations:\n",
            "diff --git a/fs/inode.c b/fs/inode.c\nindex b608528efd3a..9d33cd4e3bd8 100644\n--- a/fs/inode.c\n+++ b/fs/inode.c\n@@ -2005,6 +2005,9 @@ static int __remove_privs(struct user_namespace *mnt_userns,\n {\n \tstruct iattr newattrs;\n \n+\tif (kill & ~(ATTR_KILL_SUID | ATTR_KILL_SGID | ATTR_KILL_PRIV)) {\n+\t\treturn -EINVAL; // Invalid flags in kill\n+\t}\n \tnewattrs.ia_valid = ATTR_FORCE | kill;\n \t/*\n \t * Note we call this on write, so notify_change will not\n"
        ],
        "error": []
    },
    "f55849742bdcdf58f6eaae61e747ac00e5c061f4": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/mprotect.c b/mm/mprotect.c\nindex 461dcbd4f21a..38c0fb91da55 100644\n--- a/mm/mprotect.c\n+++ b/mm/mprotect.c\n@@ -274,9 +274,13 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\t * pte is none, the page/swap cache could\n \t\t\t\t * exist.  Doing that by install a marker.\n \t\t\t\t */\n+\t\t\t\t#ifdef CONFIG_PTE_MARKER\n \t\t\t\tset_pte_at(vma->vm_mm, addr, pte,\n \t\t\t\t\t   make_pte_marker(PTE_MARKER_UFFD_WP));\n \t\t\t\tpages++;\n+#else\n+\t\t\t\tWARN_ON_ONCE(1);\n+#endif\n \t\t\t}\n \t\t}\n \t} while (pte++, addr += PAGE_SIZE, addr != end);\n",
            "diff --git a/mm/mprotect.c b/mm/mprotect.c\nindex 461dcbd4f21a..38c0fb91da55 100644\n--- a/mm/mprotect.c\n+++ b/mm/mprotect.c\n@@ -274,9 +274,13 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\t * pte is none, the page/swap cache could\n \t\t\t\t * exist.  Doing that by install a marker.\n \t\t\t\t */\n+\t\t\t\t#ifdef CONFIG_PTE_MARKER\n \t\t\t\tset_pte_at(vma->vm_mm, addr, pte,\n \t\t\t\t\t   make_pte_marker(PTE_MARKER_UFFD_WP));\n \t\t\t\tpages++;\n+#else\n+\t\t\t\tWARN_ON_ONCE(1);\n+#endif\n \t\t\t}\n \t\t}\n \t} while (pte++, addr += PAGE_SIZE, addr != end);\n",
            "diff --git a/mm/mprotect.c b/mm/mprotect.c\nindex 461dcbd4f21a..e2d58bdd3721 100644\n--- a/mm/mprotect.c\n+++ b/mm/mprotect.c\n@@ -268,6 +268,7 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t/* It must be an none page, or what else?.. */\n \t\t\tWARN_ON_ONCE(!pte_none(oldpte));\n \t\t\tif (unlikely(uffd_wp && !vma_is_anonymous(vma))) {\n+#ifdef CONFIG_PTE_MARKER\n \t\t\t\t/*\n \t\t\t\t * For file-backed mem, we need to be able to\n \t\t\t\t * wr-protect a none pte, because even if the\n@@ -277,6 +278,9 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tset_pte_at(vma->vm_mm, addr, pte,\n \t\t\t\t\t   make_pte_marker(PTE_MARKER_UFFD_WP));\n \t\t\t\tpages++;\n+#else\n+\t\t\t\tWARN_ON_ONCE(1);\n+#endif\n \t\t\t}\n \t\t}\n \t} while (pte++, addr += PAGE_SIZE, addr != end);\n",
            "diff --git a/mm/mprotect.c b/mm/mprotect.c\nindex 461dcbd4f21a..4a08880b3000 100644\n--- a/mm/mprotect.c\n+++ b/mm/mprotect.c\n@@ -274,9 +274,13 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\t * pte is none, the page/swap cache could\n \t\t\t\t * exist.  Doing that by install a marker.\n \t\t\t\t */\n+\t\t\t\t#ifdef CONFIG_PTE_MARKER\n \t\t\t\tset_pte_at(vma->vm_mm, addr, pte,\n \t\t\t\t\t   make_pte_marker(PTE_MARKER_UFFD_WP));\n \t\t\t\tpages++;\n+\t\t\t\t#else\n+\t\t\t\tWARN_ON_ONCE(1);\n+\t\t\t\t#endif\n \t\t\t}\n \t\t}\n \t} while (pte++, addr += PAGE_SIZE, addr != end);\n",
            "diff --git a/mm/mprotect.c b/mm/mprotect.c\nindex 461dcbd4f21a..38c0fb91da55 100644\n--- a/mm/mprotect.c\n+++ b/mm/mprotect.c\n@@ -274,9 +274,13 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\t * pte is none, the page/swap cache could\n \t\t\t\t * exist.  Doing that by install a marker.\n \t\t\t\t */\n+\t\t\t\t#ifdef CONFIG_PTE_MARKER\n \t\t\t\tset_pte_at(vma->vm_mm, addr, pte,\n \t\t\t\t\t   make_pte_marker(PTE_MARKER_UFFD_WP));\n \t\t\t\tpages++;\n+#else\n+\t\t\t\tWARN_ON_ONCE(1);\n+#endif\n \t\t\t}\n \t\t}\n \t} while (pte++, addr += PAGE_SIZE, addr != end);\n"
        ],
        "error": []
    },
    "6e185619b66eae1ef09684c5f6e283d6cfb5ba84": {
        "non_crash": [
            "diff --git a/fs/btrfs/file.c b/fs/btrfs/file.c\nindex 448b143a5cb2..cf19407c986c 100644\n--- a/fs/btrfs/file.c\n+++ b/fs/btrfs/file.c\n@@ -467,7 +467,10 @@ int btrfs_drop_extents(struct btrfs_trans_handle *trans,\n \t\t\t\t\t\tkey.offset - extent_offset, 0,\n \t\t\t\t\t\tfalse);\n \t\t\t\tret = btrfs_free_extent(trans, &ref);\n-\t\t\t\tBUG_ON(ret); /* -ENOMEM */\n+\t\t\t\tif (ret) {\n+\t\t\t\t\tbtrfs_abort_transaction(trans, ret);\n+\t\t\t\t\tgoto out;\n+\t\t\t\t}\n \t\t\t\targs->bytes_found += extent_end - key.offset;\n \t\t\t}\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/btrfs/file.c b/fs/btrfs/file.c\nindex 448b143a5cb2..88aab6a7fed7 100644\n--- a/fs/btrfs/file.c\n+++ b/fs/btrfs/file.c\n@@ -380,7 +380,10 @@ int btrfs_drop_extents(struct btrfs_trans_handle *trans,\n \t\t\t\t\t\targs->start - extent_offset,\n \t\t\t\t\t\t0, false);\n \t\t\t\tret = btrfs_inc_extent_ref(trans, &ref);\n-\t\t\t\tBUG_ON(ret); /* -ENOMEM */\n+\t\t\t\tif (ret) {\n+\t\t\t\t\tbtrfs_abort_transaction(trans, ret);\n+\t\t\t\t\tgoto out;\n+\t\t\t\t}\n \t\t\t}\n \t\t\tkey.offset = args->start;\n \t\t}\n",
            "diff --git a/fs/btrfs/file.c b/fs/btrfs/file.c\nindex 448b143a5cb2..88aab6a7fed7 100644\n--- a/fs/btrfs/file.c\n+++ b/fs/btrfs/file.c\n@@ -380,7 +380,10 @@ int btrfs_drop_extents(struct btrfs_trans_handle *trans,\n \t\t\t\t\t\targs->start - extent_offset,\n \t\t\t\t\t\t0, false);\n \t\t\t\tret = btrfs_inc_extent_ref(trans, &ref);\n-\t\t\t\tBUG_ON(ret); /* -ENOMEM */\n+\t\t\t\tif (ret) {\n+\t\t\t\t\tbtrfs_abort_transaction(trans, ret);\n+\t\t\t\t\tgoto out;\n+\t\t\t\t}\n \t\t\t}\n \t\t\tkey.offset = args->start;\n \t\t}\n",
            "diff --git a/fs/btrfs/file.c b/fs/btrfs/file.c\nindex 448b143a5cb2..88aab6a7fed7 100644\n--- a/fs/btrfs/file.c\n+++ b/fs/btrfs/file.c\n@@ -380,7 +380,10 @@ int btrfs_drop_extents(struct btrfs_trans_handle *trans,\n \t\t\t\t\t\targs->start - extent_offset,\n \t\t\t\t\t\t0, false);\n \t\t\t\tret = btrfs_inc_extent_ref(trans, &ref);\n-\t\t\t\tBUG_ON(ret); /* -ENOMEM */\n+\t\t\t\tif (ret) {\n+\t\t\t\t\tbtrfs_abort_transaction(trans, ret);\n+\t\t\t\t\tgoto out;\n+\t\t\t\t}\n \t\t\t}\n \t\t\tkey.offset = args->start;\n \t\t}\n",
            "diff --git a/fs/btrfs/file.c b/fs/btrfs/file.c\nindex 448b143a5cb2..88aab6a7fed7 100644\n--- a/fs/btrfs/file.c\n+++ b/fs/btrfs/file.c\n@@ -380,7 +380,10 @@ int btrfs_drop_extents(struct btrfs_trans_handle *trans,\n \t\t\t\t\t\targs->start - extent_offset,\n \t\t\t\t\t\t0, false);\n \t\t\t\tret = btrfs_inc_extent_ref(trans, &ref);\n-\t\t\t\tBUG_ON(ret); /* -ENOMEM */\n+\t\t\t\tif (ret) {\n+\t\t\t\t\tbtrfs_abort_transaction(trans, ret);\n+\t\t\t\t\tgoto out;\n+\t\t\t\t}\n \t\t\t}\n \t\t\tkey.offset = args->start;\n \t\t}\n"
        ],
        "error": []
    },
    "ecd1f6c4b2442ea4c47c7331ed1c27c0cfdc627e": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c\nindex 2b5ef1b64249..d56ef624bce7 100644\n--- a/fs/ext4/inode.c\n+++ b/fs/ext4/inode.c\n@@ -1526,7 +1526,9 @@ void ext4_da_release_space(struct inode *inode, int to_free)\n \t\t\t \"data blocks\", inode->i_ino, to_free,\n \t\t\t ei->i_reserved_data_blocks);\n \t\tWARN_ON(1);\n-\t\tto_free = ei->i_reserved_data_blocks;\n+\t\t/* Do not modify to_free, just return */\n+\t\tspin_unlock(&EXT4_I(inode)->i_block_reservation_lock);\n+\t\treturn;\n \t}\n \tei->i_reserved_data_blocks -= to_free;\n \n",
            "diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c\nindex 2b5ef1b64249..f5941d25b80d 100644\n--- a/fs/ext4/inode.c\n+++ b/fs/ext4/inode.c\n@@ -1528,10 +1528,16 @@ void ext4_da_release_space(struct inode *inode, int to_free)\n \t\tWARN_ON(1);\n \t\tto_free = ei->i_reserved_data_blocks;\n \t}\n-\tei->i_reserved_data_blocks -= to_free;\n+\tif (ei->i_reserved_data_blocks >= to_free) {\n+\t\tei->i_reserved_data_blocks -= to_free;\n \n-\t/* update fs dirty data blocks counter */\n-\tpercpu_counter_sub(&sbi->s_dirtyclusters_counter, to_free);\n+\t\t/* update fs dirty data blocks counter */\n+\t\tpercpu_counter_sub(&sbi->s_dirtyclusters_counter, to_free);\n+\t} else {\n+\t\text4_warning(inode->i_sb, \"ext4_da_release_space: \"\n+\t\t\t \"ino %lu, insufficient reserved data blocks to free %d\",\n+\t\t\t inode->i_ino, to_free);\n+\t}\n \n \tspin_unlock(&EXT4_I(inode)->i_block_reservation_lock);\n \n",
            "diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c\nindex 2b5ef1b64249..80f78ca0be4a 100644\n--- a/fs/ext4/inode.c\n+++ b/fs/ext4/inode.c\n@@ -1526,9 +1526,15 @@ void ext4_da_release_space(struct inode *inode, int to_free)\n \t\t\t \"data blocks\", inode->i_ino, to_free,\n \t\t\t ei->i_reserved_data_blocks);\n \t\tWARN_ON(1);\n+\t\t/* Do not attempt to free more blocks than reserved */\n \t\tto_free = ei->i_reserved_data_blocks;\n \t}\n-\tei->i_reserved_data_blocks -= to_free;\n+\t/* Ensure we do not decrement below zero */\n+\tif (ei->i_reserved_data_blocks >= to_free) {\n+\t\tei->i_reserved_data_blocks -= to_free;\n+\t} else {\n+\t\tei->i_reserved_data_blocks = 0;\n+\t}\n \n \t/* update fs dirty data blocks counter */\n \tpercpu_counter_sub(&sbi->s_dirtyclusters_counter, to_free);\n",
            "diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c\nindex 2b5ef1b64249..8df8bddff8fb 100644\n--- a/fs/ext4/inode.c\n+++ b/fs/ext4/inode.c\n@@ -1526,7 +1526,9 @@ void ext4_da_release_space(struct inode *inode, int to_free)\n \t\t\t \"data blocks\", inode->i_ino, to_free,\n \t\t\t ei->i_reserved_data_blocks);\n \t\tWARN_ON(1);\n-\t\tto_free = ei->i_reserved_data_blocks;\n+\t\t/* Do not proceed with freeing if the counter is inconsistent */\n+\t\tspin_unlock(&EXT4_I(inode)->i_block_reservation_lock);\n+\t\treturn;\n \t}\n \tei->i_reserved_data_blocks -= to_free;\n \n",
            "diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c\nindex 2b5ef1b64249..725c08171ad4 100644\n--- a/fs/ext4/inode.c\n+++ b/fs/ext4/inode.c\n@@ -1528,7 +1528,11 @@ void ext4_da_release_space(struct inode *inode, int to_free)\n \t\tWARN_ON(1);\n \t\tto_free = ei->i_reserved_data_blocks;\n \t}\n-\tei->i_reserved_data_blocks -= to_free;\n+\tif (ei->i_reserved_data_blocks >= to_free) {\n+\t\tei->i_reserved_data_blocks -= to_free;\n+\t} else {\n+\t\tei->i_reserved_data_blocks = 0;\n+\t}\n \n \t/* update fs dirty data blocks counter */\n \tpercpu_counter_sub(&sbi->s_dirtyclusters_counter, to_free);\n"
        ],
        "error": []
    },
    "7a56fd91f3db3a79c974b34e1aac3879898d6f29": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 3ac7c8c1548d..a2443cbfd700 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -401,7 +401,7 @@ static void __nf_unregister_net_hook(struct net *net, int pf,\n \t\treturn;\n \t}\n \n-\tif (nf_remove_net_hook(p, reg)) {\n+\tif (p && nf_remove_net_hook(p, reg)) {\n #ifdef CONFIG_NETFILTER_INGRESS\n \t\tif (pf == NFPROTO_NETDEV && reg->hooknum == NF_NETDEV_INGRESS)\n \t\t\tnet_dec_ingress_queue();\n@@ -409,8 +409,6 @@ static void __nf_unregister_net_hook(struct net *net, int pf,\n #ifdef CONFIG_JUMP_LABEL\n \t\tstatic_key_slow_dec(&nf_hooks_needed[pf][reg->hooknum]);\n #endif\n-\t} else {\n-\t\tWARN_ONCE(1, \"hook not found, pf %d num %d\", pf, reg->hooknum);\n \t}\n \n \tp = __nf_hook_entries_try_shrink(p, pp);\n",
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 3ac7c8c1548d..b0f32c098f58 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -401,7 +401,7 @@ static void __nf_unregister_net_hook(struct net *net, int pf,\n \t\treturn;\n \t}\n \n-\tif (nf_remove_net_hook(p, reg)) {\n+\tif (p && nf_remove_net_hook(p, reg)) {\n #ifdef CONFIG_NETFILTER_INGRESS\n \t\tif (pf == NFPROTO_NETDEV && reg->hooknum == NF_NETDEV_INGRESS)\n \t\t\tnet_dec_ingress_queue();\n@@ -409,7 +409,7 @@ static void __nf_unregister_net_hook(struct net *net, int pf,\n #ifdef CONFIG_JUMP_LABEL\n \t\tstatic_key_slow_dec(&nf_hooks_needed[pf][reg->hooknum]);\n #endif\n-\t} else {\n+\t} else if (p) {\n \t\tWARN_ONCE(1, \"hook not found, pf %d num %d\", pf, reg->hooknum);\n \t}\n \n",
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 3ac7c8c1548d..eb1c06d32c48 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -401,7 +401,7 @@ static void __nf_unregister_net_hook(struct net *net, int pf,\n \t\treturn;\n \t}\n \n-\tif (nf_remove_net_hook(p, reg)) {\n+\tif (p && nf_remove_net_hook(p, reg)) {\n #ifdef CONFIG_NETFILTER_INGRESS\n \t\tif (pf == NFPROTO_NETDEV && reg->hooknum == NF_NETDEV_INGRESS)\n \t\t\tnet_dec_ingress_queue();\n",
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 3ac7c8c1548d..75c3fcced417 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -410,7 +410,9 @@ static void __nf_unregister_net_hook(struct net *net, int pf,\n \t\tstatic_key_slow_dec(&nf_hooks_needed[pf][reg->hooknum]);\n #endif\n \t} else {\n-\t\tWARN_ONCE(1, \"hook not found, pf %d num %d\", pf, reg->hooknum);\n+\t\t// Hook not found, no need to warn, just return\n+\t\tmutex_unlock(&nf_hook_mutex);\n+\t\treturn;\n \t}\n \n \tp = __nf_hook_entries_try_shrink(p, pp);\n",
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 3ac7c8c1548d..eb1c06d32c48 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -401,7 +401,7 @@ static void __nf_unregister_net_hook(struct net *net, int pf,\n \t\treturn;\n \t}\n \n-\tif (nf_remove_net_hook(p, reg)) {\n+\tif (p && nf_remove_net_hook(p, reg)) {\n #ifdef CONFIG_NETFILTER_INGRESS\n \t\tif (pf == NFPROTO_NETDEV && reg->hooknum == NF_NETDEV_INGRESS)\n \t\t\tnet_dec_ingress_queue();\n"
        ],
        "error": []
    },
    "093e7092e01bed192b564b04528826cc6f1dbf91": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/drivers/media/platform/vivid/vivid-vid-cap.c b/drivers/media/platform/vivid/vivid-vid-cap.c\nindex 8213297ee9dc..67780007e7cb 100644\n--- a/drivers/media/platform/vivid/vivid-vid-cap.c\n+++ b/drivers/media/platform/vivid/vivid-vid-cap.c\n@@ -1079,13 +1079,15 @@ int vidioc_g_fmt_vid_overlay(struct file *file, void *priv,\n \tif (dev->bitmap_cap == NULL)\n \t\twin->bitmap = NULL;\n \telse if (win->bitmap) {\n-\t\tif (copy_to_user(win->bitmap, dev->bitmap_cap,\n-\t\t    ((compose->width + 7) / 8) * compose->height))\n+\t\tsize_t bitmap_size = ((compose->width + 7) / 8) * compose->height;\n+\t\tif (!access_ok(win->bitmap, bitmap_size) ||\n+\t\t    copy_to_user(win->bitmap, dev->bitmap_cap, bitmap_size))\n \t\t\treturn -EFAULT;\n \t}\n \tif (clipcount && win->clips) {\n-\t\tif (copy_to_user(win->clips, dev->clips_cap,\n-\t\t\t\t clipcount * sizeof(dev->clips_cap[0])))\n+\t\tsize_t clips_size = clipcount * sizeof(dev->clips_cap[0]);\n+\t\tif (!access_ok(win->clips, clips_size) ||\n+\t\t    copy_to_user(win->clips, dev->clips_cap, clips_size))\n \t\t\treturn -EFAULT;\n \t}\n \treturn 0;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/media/platform/vivid/vivid-vid-cap.c b/drivers/media/platform/vivid/vivid-vid-cap.c\nindex 8213297ee9dc..67780007e7cb 100644\n--- a/drivers/media/platform/vivid/vivid-vid-cap.c\n+++ b/drivers/media/platform/vivid/vivid-vid-cap.c\n@@ -1079,13 +1079,15 @@ int vidioc_g_fmt_vid_overlay(struct file *file, void *priv,\n \tif (dev->bitmap_cap == NULL)\n \t\twin->bitmap = NULL;\n \telse if (win->bitmap) {\n-\t\tif (copy_to_user(win->bitmap, dev->bitmap_cap,\n-\t\t    ((compose->width + 7) / 8) * compose->height))\n+\t\tsize_t bitmap_size = ((compose->width + 7) / 8) * compose->height;\n+\t\tif (!access_ok(win->bitmap, bitmap_size) ||\n+\t\t    copy_to_user(win->bitmap, dev->bitmap_cap, bitmap_size))\n \t\t\treturn -EFAULT;\n \t}\n \tif (clipcount && win->clips) {\n-\t\tif (copy_to_user(win->clips, dev->clips_cap,\n-\t\t\t\t clipcount * sizeof(dev->clips_cap[0])))\n+\t\tsize_t clips_size = clipcount * sizeof(dev->clips_cap[0]);\n+\t\tif (!access_ok(win->clips, clips_size) ||\n+\t\t    copy_to_user(win->clips, dev->clips_cap, clips_size))\n \t\t\treturn -EFAULT;\n \t}\n \treturn 0;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/media/platform/vivid/vivid-vid-cap.c b/drivers/media/platform/vivid/vivid-vid-cap.c\nindex 8213297ee9dc..9b8904f9f779 100644\n--- a/drivers/media/platform/vivid/vivid-vid-cap.c\n+++ b/drivers/media/platform/vivid/vivid-vid-cap.c\n@@ -1078,12 +1078,12 @@ int vidioc_g_fmt_vid_overlay(struct file *file, void *priv,\n \t\tclipcount = dev->clipcount_cap;\n \tif (dev->bitmap_cap == NULL)\n \t\twin->bitmap = NULL;\n-\telse if (win->bitmap) {\n+\telse if (win->bitmap && access_ok(win->bitmap, ((compose->width + 7) / 8) * compose->height)) {\n \t\tif (copy_to_user(win->bitmap, dev->bitmap_cap,\n \t\t    ((compose->width + 7) / 8) * compose->height))\n \t\t\treturn -EFAULT;\n \t}\n-\tif (clipcount && win->clips) {\n+\tif (clipcount && win->clips && access_ok(win->clips, clipcount * sizeof(dev->clips_cap[0]))) {\n \t\tif (copy_to_user(win->clips, dev->clips_cap,\n \t\t\t\t clipcount * sizeof(dev->clips_cap[0])))\n \t\t\treturn -EFAULT;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/media/platform/vivid/vivid-vid-cap.c b/drivers/media/platform/vivid/vivid-vid-cap.c\nindex 8213297ee9dc..6f436765a126 100644\n--- a/drivers/media/platform/vivid/vivid-vid-cap.c\n+++ b/drivers/media/platform/vivid/vivid-vid-cap.c\n@@ -1079,11 +1079,15 @@ int vidioc_g_fmt_vid_overlay(struct file *file, void *priv,\n \tif (dev->bitmap_cap == NULL)\n \t\twin->bitmap = NULL;\n \telse if (win->bitmap) {\n+\t\tif (!access_ok(win->bitmap, ((compose->width + 7) / 8) * compose->height))\n+\t\t\treturn -EFAULT;\n \t\tif (copy_to_user(win->bitmap, dev->bitmap_cap,\n \t\t    ((compose->width + 7) / 8) * compose->height))\n \t\t\treturn -EFAULT;\n \t}\n \tif (clipcount && win->clips) {\n+\t\tif (!access_ok(win->clips, clipcount * sizeof(dev->clips_cap[0])))\n+\t\t\treturn -EFAULT;\n \t\tif (copy_to_user(win->clips, dev->clips_cap,\n \t\t\t\t clipcount * sizeof(dev->clips_cap[0])))\n \t\t\treturn -EFAULT;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/media/platform/vivid/vivid-vid-cap.c b/drivers/media/platform/vivid/vivid-vid-cap.c\nindex 8213297ee9dc..8649aad94cc7 100644\n--- a/drivers/media/platform/vivid/vivid-vid-cap.c\n+++ b/drivers/media/platform/vivid/vivid-vid-cap.c\n@@ -1079,13 +1079,17 @@ int vidioc_g_fmt_vid_overlay(struct file *file, void *priv,\n \tif (dev->bitmap_cap == NULL)\n \t\twin->bitmap = NULL;\n \telse if (win->bitmap) {\n-\t\tif (copy_to_user(win->bitmap, dev->bitmap_cap,\n-\t\t    ((compose->width + 7) / 8) * compose->height))\n+\t\tsize_t bitmap_size = ((compose->width + 7) / 8) * compose->height;\n+\t\tif (!access_ok(win->bitmap, bitmap_size))\n+\t\t\treturn -EFAULT;\n+\t\tif (copy_to_user(win->bitmap, dev->bitmap_cap, bitmap_size))\n \t\t\treturn -EFAULT;\n \t}\n \tif (clipcount && win->clips) {\n-\t\tif (copy_to_user(win->clips, dev->clips_cap,\n-\t\t\t\t clipcount * sizeof(dev->clips_cap[0])))\n+\t\tsize_t clips_size = clipcount * sizeof(dev->clips_cap[0]);\n+\t\tif (!access_ok(win->clips, clips_size))\n+\t\t\treturn -EFAULT;\n+\t\tif (copy_to_user(win->clips, dev->clips_cap, clips_size))\n \t\t\treturn -EFAULT;\n \t}\n \treturn 0;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "deb061ff946b02c2f4821f91683d89a68b2f45f8": {
        "non_crash": [
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..5c94f28a51e0 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -588,9 +588,12 @@ int hfsplus_cat_write_inode(struct inode *inode)\n \tif (S_ISDIR(main_inode->i_mode)) {\n \t\tstruct hfsplus_cat_folder *folder = &entry.folder;\n \n-\t\tWARN_ON(fd.entrylength < sizeof(struct hfsplus_cat_folder));\n+\t\tif (fd.entrylength < sizeof(struct hfsplus_cat_folder)) {\n+\t\t\tpr_warn(\"hfsplus: entry length too small for folder\\n\");\n+\t\t\tgoto out;\n+\t\t}\n \t\thfs_bnode_read(fd.bnode, &entry, fd.entryoffset,\n-\t\t\t\t\tsizeof(struct hfsplus_cat_folder));\n+\t\t\t       sizeof(struct hfsplus_cat_folder));\n \t\t/* simple node checks? */\n \t\thfsplus_cat_set_perms(inode, &folder->permissions);\n \t\tfolder->access_date = hfsp_ut2mt(inode->i_atime);\n@@ -613,9 +616,12 @@ int hfsplus_cat_write_inode(struct inode *inode)\n \t} else {\n \t\tstruct hfsplus_cat_file *file = &entry.file;\n \n-\t\tWARN_ON(fd.entrylength < sizeof(struct hfsplus_cat_file));\n+\t\tif (fd.entrylength < sizeof(struct hfsplus_cat_file)) {\n+\t\t\tpr_warn(\"hfsplus: entry length too small for file\\n\");\n+\t\t\tgoto out;\n+\t\t}\n \t\thfs_bnode_read(fd.bnode, &entry, fd.entryoffset,\n-\t\t\t\t\tsizeof(struct hfsplus_cat_file));\n+\t\t\t       sizeof(struct hfsplus_cat_file));\n \t\thfsplus_inode_write_fork(inode, &file->data_fork);\n \t\thfsplus_cat_set_perms(inode, &file->permissions);\n \t\tif (HFSPLUS_FLG_IMMUTABLE &\n",
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..7413ae3dbec2 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -588,7 +588,10 @@ int hfsplus_cat_write_inode(struct inode *inode)\n \tif (S_ISDIR(main_inode->i_mode)) {\n \t\tstruct hfsplus_cat_folder *folder = &entry.folder;\n \n-\t\tWARN_ON(fd.entrylength < sizeof(struct hfsplus_cat_folder));\n+\t\tif (fd.entrylength < sizeof(struct hfsplus_cat_folder)) {\n+\t\t\tpr_warn(\"hfsplus: entry length too small for folder\\n\");\n+\t\t\tgoto out;\n+\t\t}\n \t\thfs_bnode_read(fd.bnode, &entry, fd.entryoffset,\n \t\t\t\t\tsizeof(struct hfsplus_cat_folder));\n \t\t/* simple node checks? */\n@@ -613,7 +616,10 @@ int hfsplus_cat_write_inode(struct inode *inode)\n \t} else {\n \t\tstruct hfsplus_cat_file *file = &entry.file;\n \n-\t\tWARN_ON(fd.entrylength < sizeof(struct hfsplus_cat_file));\n+\t\tif (fd.entrylength < sizeof(struct hfsplus_cat_file)) {\n+\t\t\tpr_warn(\"hfsplus: entry length too small for file\\n\");\n+\t\t\tgoto out;\n+\t\t}\n \t\thfs_bnode_read(fd.bnode, &entry, fd.entryoffset,\n \t\t\t\t\tsizeof(struct hfsplus_cat_file));\n \t\thfsplus_inode_write_fork(inode, &file->data_fork);\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..31ce4fe95448 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -588,9 +588,12 @@ int hfsplus_cat_write_inode(struct inode *inode)\n \tif (S_ISDIR(main_inode->i_mode)) {\n \t\tstruct hfsplus_cat_folder *folder = &entry.folder;\n \n-\t\tWARN_ON(fd.entrylength < sizeof(struct hfsplus_cat_folder));\n+\t\tif (fd.entrylength < sizeof(struct hfsplus_cat_folder)) {\n+\t\t\tpr_warn(\"hfsplus: entry length too small for folder\\n\");\n+\t\t\tgoto out;\n+\t\t}\n \t\thfs_bnode_read(fd.bnode, &entry, fd.entryoffset,\n-\t\t\t\t\tsizeof(struct hfsplus_cat_folder));\n+\t\t\t       sizeof(struct hfsplus_cat_folder));\n \t\t/* simple node checks? */\n \t\thfsplus_cat_set_perms(inode, &folder->permissions);\n \t\tfolder->access_date = hfsp_ut2mt(inode->i_atime);\n",
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..5cb659496158 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -588,9 +588,12 @@ int hfsplus_cat_write_inode(struct inode *inode)\n \tif (S_ISDIR(main_inode->i_mode)) {\n \t\tstruct hfsplus_cat_folder *folder = &entry.folder;\n \n-\t\tWARN_ON(fd.entrylength < sizeof(struct hfsplus_cat_folder));\n+\t\tif (fd.entrylength < sizeof(struct hfsplus_cat_folder)) {\n+\t\t\tpr_warn(\"Invalid entry length for folder: %d\\n\", fd.entrylength);\n+\t\t\tgoto out;\n+\t\t}\n \t\thfs_bnode_read(fd.bnode, &entry, fd.entryoffset,\n-\t\t\t\t\tsizeof(struct hfsplus_cat_folder));\n+\t\t\t       sizeof(struct hfsplus_cat_folder));\n \t\t/* simple node checks? */\n \t\thfsplus_cat_set_perms(inode, &folder->permissions);\n \t\tfolder->access_date = hfsp_ut2mt(inode->i_atime);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..e35714434f90 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -588,9 +588,13 @@ int hfsplus_cat_write_inode(struct inode *inode)\n \tif (S_ISDIR(main_inode->i_mode)) {\n \t\tstruct hfsplus_cat_folder *folder = &entry.folder;\n \n-\t\tWARN_ON(fd.entrylength < sizeof(struct hfsplus_cat_folder));\n+\t\tif (fd.entrylength < sizeof(struct hfsplus_cat_folder)) {\n+\t\t\tpr_warn(\"hfsplus: entry length too small for folder\\n\");\n+\t\t\terr = -EIO;\n+\t\t\tgoto out;\n+\t\t}\n \t\thfs_bnode_read(fd.bnode, &entry, fd.entryoffset,\n-\t\t\t\t\tsizeof(struct hfsplus_cat_folder));\n+\t\t\t       sizeof(struct hfsplus_cat_folder));\n \t\t/* simple node checks? */\n \t\thfsplus_cat_set_perms(inode, &folder->permissions);\n \t\tfolder->access_date = hfsp_ut2mt(inode->i_atime);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "e1c3525a4f4e2e4b6c1f73611ceaf61ef462700c": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/hid/hid-thrustmaster.c b/drivers/hid/hid-thrustmaster.c\nindex a4e20f9e598b..5740b23580d3 100644\n--- a/drivers/hid/hid-thrustmaster.c\n+++ b/drivers/hid/hid-thrustmaster.c\n@@ -155,6 +155,13 @@ static void thrustmaster_interrupts(struct hid_device *hdev)\n \tstruct usb_interface *usbif = to_usb_interface(dev->parent);\n \tstruct usb_device *usbdev = interface_to_usbdev(usbif);\n \n+\tsize_t max_size = 0;\n+\tfor (i = 0; i < ARRAY_SIZE(setup_arr_sizes); ++i) {\n+\t\tif (setup_arr_sizes[i] > max_size)\n+\t\t\tmax_size = setup_arr_sizes[i];\n+\t}\n+\n+\tsend_buf = kzalloc(max_size, GFP_KERNEL);\n \tif (!send_buf) {\n \t\thid_err(hdev, \"failed allocating send buffer\\n\");\n \t\treturn;\n",
            "diff --git a/drivers/hid/hid-thrustmaster.c b/drivers/hid/hid-thrustmaster.c\nindex a4e20f9e598b..34b32f0e895a 100644\n--- a/drivers/hid/hid-thrustmaster.c\n+++ b/drivers/hid/hid-thrustmaster.c\n@@ -155,6 +155,13 @@ static void thrustmaster_interrupts(struct hid_device *hdev)\n \tstruct usb_interface *usbif = to_usb_interface(dev->parent);\n \tstruct usb_device *usbdev = interface_to_usbdev(usbif);\n \n+\tsize_t max_buf_size = 0;\n+\tfor (i = 0; i < ARRAY_SIZE(setup_arr_sizes); ++i) {\n+\t\tif (setup_arr_sizes[i] > max_buf_size)\n+\t\t\tmax_buf_size = setup_arr_sizes[i];\n+\t}\n+\n+\tsend_buf = kmalloc(max_buf_size, GFP_KERNEL);\n \tif (!send_buf) {\n \t\thid_err(hdev, \"failed allocating send buffer\\n\");\n \t\treturn;\n",
            "diff --git a/drivers/hid/hid-thrustmaster.c b/drivers/hid/hid-thrustmaster.c\nindex a4e20f9e598b..73932a41490d 100644\n--- a/drivers/hid/hid-thrustmaster.c\n+++ b/drivers/hid/hid-thrustmaster.c\n@@ -155,6 +155,13 @@ static void thrustmaster_interrupts(struct hid_device *hdev)\n \tstruct usb_interface *usbif = to_usb_interface(dev->parent);\n \tstruct usb_device *usbdev = interface_to_usbdev(usbif);\n \n+\tsize_t max_size = 0;\n+\tfor (i = 0; i < ARRAY_SIZE(setup_arr_sizes); ++i) {\n+\t\tif (setup_arr_sizes[i] > max_size)\n+\t\t\tmax_size = setup_arr_sizes[i];\n+\t}\n+\n+\tsend_buf = kmalloc(max_size, GFP_KERNEL);\n \tif (!send_buf) {\n \t\thid_err(hdev, \"failed allocating send buffer\\n\");\n \t\treturn;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/hid/hid-thrustmaster.c b/drivers/hid/hid-thrustmaster.c\nindex a4e20f9e598b..5e13324a095f 100644\n--- a/drivers/hid/hid-thrustmaster.c\n+++ b/drivers/hid/hid-thrustmaster.c\n@@ -163,7 +163,17 @@ static void thrustmaster_interrupts(struct hid_device *hdev)\n \tep = &usbif->cur_altsetting->endpoint[1];\n \tb_ep = ep->desc.bEndpointAddress;\n \n+\tif (send_buf_size < max_setup_arr_size) {\n+\t\thid_err(hdev, \"send buffer too small\\n\");\n+\t\treturn;\n+\t}\n+\n \tfor (i = 0; i < ARRAY_SIZE(setup_arr); ++i) {\n+\t\tif (setup_arr_sizes[i] > send_buf_size) {\n+\t\t\thid_err(hdev, \"setup array size exceeds buffer\\n\");\n+\t\t\tcontinue;\n+\t\t}\n+\n \t\tmemcpy(send_buf, setup_arr[i], setup_arr_sizes[i]);\n \n \t\tret = usb_interrupt_msg(usbdev,\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/hid/hid-thrustmaster.c b/drivers/hid/hid-thrustmaster.c\nindex a4e20f9e598b..aa36f3edb187 100644\n--- a/drivers/hid/hid-thrustmaster.c\n+++ b/drivers/hid/hid-thrustmaster.c\n@@ -164,6 +164,10 @@ static void thrustmaster_interrupts(struct hid_device *hdev)\n \tb_ep = ep->desc.bEndpointAddress;\n \n \tfor (i = 0; i < ARRAY_SIZE(setup_arr); ++i) {\n+\t\tif (setup_arr_sizes[i] > SEND_BUF_SIZE) {\n+\t\t\thid_err(hdev, \"setup array size exceeds buffer size\\n\");\n+\t\t\tcontinue;\n+\t\t}\n \t\tmemcpy(send_buf, setup_arr[i], setup_arr_sizes[i]);\n \n \t\tret = usb_interrupt_msg(usbdev,\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "89740d8d8416726adeba5953543037142b3b20be": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/security/keys/keyctl_pkey.c b/security/keys/keyctl_pkey.c\nindex 70e65a2ff207..e411bb0f8c85 100644\n--- a/security/keys/keyctl_pkey.c\n+++ b/security/keys/keyctl_pkey.c\n@@ -102,7 +102,7 @@ static int keyctl_pkey_params_get(key_serial_t id,\n \t\treturn PTR_ERR(key_ref);\n \tparams->key = key_ref_to_ptr(key_ref);\n \n-\tif (!params->key->type->asym_query)\n+\tif (!params->key || !params->key->type->asym_query)\n \t\treturn -EOPNOTSUPP;\n \n \treturn 0;\n",
            "diff --git a/security/keys/keyctl_pkey.c b/security/keys/keyctl_pkey.c\nindex 70e65a2ff207..e411bb0f8c85 100644\n--- a/security/keys/keyctl_pkey.c\n+++ b/security/keys/keyctl_pkey.c\n@@ -102,7 +102,7 @@ static int keyctl_pkey_params_get(key_serial_t id,\n \t\treturn PTR_ERR(key_ref);\n \tparams->key = key_ref_to_ptr(key_ref);\n \n-\tif (!params->key->type->asym_query)\n+\tif (!params->key || !params->key->type->asym_query)\n \t\treturn -EOPNOTSUPP;\n \n \treturn 0;\n",
            "diff --git a/security/keys/keyctl_pkey.c b/security/keys/keyctl_pkey.c\nindex 70e65a2ff207..e411bb0f8c85 100644\n--- a/security/keys/keyctl_pkey.c\n+++ b/security/keys/keyctl_pkey.c\n@@ -102,7 +102,7 @@ static int keyctl_pkey_params_get(key_serial_t id,\n \t\treturn PTR_ERR(key_ref);\n \tparams->key = key_ref_to_ptr(key_ref);\n \n-\tif (!params->key->type->asym_query)\n+\tif (!params->key || !params->key->type->asym_query)\n \t\treturn -EOPNOTSUPP;\n \n \treturn 0;\n",
            "diff --git a/security/keys/keyctl_pkey.c b/security/keys/keyctl_pkey.c\nindex 70e65a2ff207..e411bb0f8c85 100644\n--- a/security/keys/keyctl_pkey.c\n+++ b/security/keys/keyctl_pkey.c\n@@ -102,7 +102,7 @@ static int keyctl_pkey_params_get(key_serial_t id,\n \t\treturn PTR_ERR(key_ref);\n \tparams->key = key_ref_to_ptr(key_ref);\n \n-\tif (!params->key->type->asym_query)\n+\tif (!params->key || !params->key->type->asym_query)\n \t\treturn -EOPNOTSUPP;\n \n \treturn 0;\n",
            "diff --git a/security/keys/keyctl_pkey.c b/security/keys/keyctl_pkey.c\nindex 70e65a2ff207..e411bb0f8c85 100644\n--- a/security/keys/keyctl_pkey.c\n+++ b/security/keys/keyctl_pkey.c\n@@ -102,7 +102,7 @@ static int keyctl_pkey_params_get(key_serial_t id,\n \t\treturn PTR_ERR(key_ref);\n \tparams->key = key_ref_to_ptr(key_ref);\n \n-\tif (!params->key->type->asym_query)\n+\tif (!params->key || !params->key->type->asym_query)\n \t\treturn -EOPNOTSUPP;\n \n \treturn 0;\n"
        ],
        "error": []
    },
    "7b2aea1ce02f87c175f94492d21d04a34bc99b5e": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/vhost/vsock.c b/drivers/vhost/vsock.c\nindex 37f0b4274113..978dcb74b824 100644\n--- a/drivers/vhost/vsock.c\n+++ b/drivers/vhost/vsock.c\n@@ -623,6 +623,8 @@ static int vhost_vsock_start(struct vhost_vsock *vsock)\n \t\tmutex_lock(&vq->mutex);\n \t\tvhost_vq_set_backend(vq, NULL);\n \t\tmutex_unlock(&vq->mutex);\n+\t\tif (ret)\n+\t\t\tmutex_unlock(&vq->mutex);\n \t}\n err:\n \tmutex_unlock(&vsock->dev.mutex);\n",
            "diff --git a/drivers/vhost/vsock.c b/drivers/vhost/vsock.c\nindex 37f0b4274113..a9ec012d90d4 100644\n--- a/drivers/vhost/vsock.c\n+++ b/drivers/vhost/vsock.c\n@@ -634,12 +634,14 @@ static int vhost_vsock_stop(struct vhost_vsock *vsock, bool check_owner)\n \tsize_t i;\n \tint ret = 0;\n \n-\tmutex_lock(&vsock->dev.mutex);\n-\n \tif (check_owner) {\n+\t\tmutex_lock(&vsock->dev.mutex);\n \t\tret = vhost_dev_check_owner(&vsock->dev);\n-\t\tif (ret)\n-\t\t\tgoto err;\n+\t\tif (ret) {\n+\t\t\tmutex_unlock(&vsock->dev.mutex);\n+\t\t\treturn ret;\n+\t\t}\n+\t\tmutex_unlock(&vsock->dev.mutex);\n \t}\n \n \tfor (i = 0; i < ARRAY_SIZE(vsock->vqs); i++) {\n@@ -649,9 +651,6 @@ static int vhost_vsock_stop(struct vhost_vsock *vsock, bool check_owner)\n \t\tvhost_vq_set_backend(vq, NULL);\n \t\tmutex_unlock(&vq->mutex);\n \t}\n-\n-err:\n-\tmutex_unlock(&vsock->dev.mutex);\n \treturn ret;\n }\n \n",
            "diff --git a/drivers/vhost/vsock.c b/drivers/vhost/vsock.c\nindex 37f0b4274113..3d643dd81231 100644\n--- a/drivers/vhost/vsock.c\n+++ b/drivers/vhost/vsock.c\n@@ -634,12 +634,12 @@ static int vhost_vsock_stop(struct vhost_vsock *vsock, bool check_owner)\n \tsize_t i;\n \tint ret = 0;\n \n-\tmutex_lock(&vsock->dev.mutex);\n-\n \tif (check_owner) {\n+\t\tmutex_lock(&vsock->dev.mutex);\n \t\tret = vhost_dev_check_owner(&vsock->dev);\n+\t\tmutex_unlock(&vsock->dev.mutex);\n \t\tif (ret)\n-\t\t\tgoto err;\n+\t\t\treturn ret;\n \t}\n \n \tfor (i = 0; i < ARRAY_SIZE(vsock->vqs); i++) {\n@@ -649,9 +649,6 @@ static int vhost_vsock_stop(struct vhost_vsock *vsock, bool check_owner)\n \t\tvhost_vq_set_backend(vq, NULL);\n \t\tmutex_unlock(&vq->mutex);\n \t}\n-\n-err:\n-\tmutex_unlock(&vsock->dev.mutex);\n \treturn ret;\n }\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/vhost/vsock.c b/drivers/vhost/vsock.c\nindex 37f0b4274113..ffd0bba80b93 100644\n--- a/drivers/vhost/vsock.c\n+++ b/drivers/vhost/vsock.c\n@@ -638,8 +638,12 @@ static int vhost_vsock_stop(struct vhost_vsock *vsock, bool check_owner)\n \n \tif (check_owner) {\n \t\tret = vhost_dev_check_owner(&vsock->dev);\n-\t\tif (ret)\n+\t\tif (ret) {\n+\t\t\tfor (size_t j = 0; j < i; j++) {\n+\t\t\t\tmutex_unlock(&vsock->vqs[j].mutex);\n+\t\t\t}\n \t\t\tgoto err;\n+\t\t}\n \t}\n \n \tfor (i = 0; i < ARRAY_SIZE(vsock->vqs); i++) {\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/vhost/vsock.c b/drivers/vhost/vsock.c\nindex 37f0b4274113..16476ebe4999 100644\n--- a/drivers/vhost/vsock.c\n+++ b/drivers/vhost/vsock.c\n@@ -639,7 +639,7 @@ static int vhost_vsock_stop(struct vhost_vsock *vsock, bool check_owner)\n \tif (check_owner) {\n \t\tret = vhost_dev_check_owner(&vsock->dev);\n \t\tif (ret)\n-\t\t\tgoto err;\n+\t\t\tgoto err_unlock_vq;\n \t}\n \n \tfor (i = 0; i < ARRAY_SIZE(vsock->vqs); i++) {\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "c861c927f694825cea94240c7acf698eccb2a8c2": {
        "non_crash": [
            "diff --git a/fs/nilfs2/alloc.c b/fs/nilfs2/alloc.c\nindex 6ce8617b562d..91682d662a95 100644\n--- a/fs/nilfs2/alloc.c\n+++ b/fs/nilfs2/alloc.c\n@@ -606,6 +606,12 @@ void nilfs_palloc_commit_free_entry(struct inode *inode,\n \n \tgroup = nilfs_palloc_group(inode, req->pr_entry_nr, &group_offset);\n \tdesc_kaddr = kmap(req->pr_desc_bh->b_page);\n+\tif (!desc_kaddr || !bitmap_kaddr) {\n+\t\tnilfs_warn(inode->i_sb, \"%s (ino=%lu): failed to map page\",\n+\t\t\t   __func__, inode->i_ino);\n+\t\treturn;\n+\t}\n+\n \tdesc = nilfs_palloc_block_get_group_desc(inode, group,\n \t\t\t\t\t\t req->pr_desc_bh, desc_kaddr);\n \tbitmap_kaddr = kmap(req->pr_bitmap_bh->b_page);\n",
            "diff --git a/fs/nilfs2/alloc.c b/fs/nilfs2/alloc.c\nindex 6ce8617b562d..a1e29e913ea1 100644\n--- a/fs/nilfs2/alloc.c\n+++ b/fs/nilfs2/alloc.c\n@@ -605,6 +605,12 @@ void nilfs_palloc_commit_free_entry(struct inode *inode,\n \tspinlock_t *lock;\n \n \tgroup = nilfs_palloc_group(inode, req->pr_entry_nr, &group_offset);\n+\tif (!req->pr_desc_bh || !req->pr_bitmap_bh) {\n+\t\tnilfs_warn(inode->i_sb, \"%s (ino=%lu): invalid buffer head\",\n+\t\t\t   __func__, inode->i_ino);\n+\t\treturn;\n+\t}\n+\n \tdesc_kaddr = kmap(req->pr_desc_bh->b_page);\n \tdesc = nilfs_palloc_block_get_group_desc(inode, group,\n \t\t\t\t\t\t req->pr_desc_bh, desc_kaddr);\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/alloc.c b/fs/nilfs2/alloc.c\nindex 6ce8617b562d..25363d1e1ca1 100644\n--- a/fs/nilfs2/alloc.c\n+++ b/fs/nilfs2/alloc.c\n@@ -606,9 +606,18 @@ void nilfs_palloc_commit_free_entry(struct inode *inode,\n \n \tgroup = nilfs_palloc_group(inode, req->pr_entry_nr, &group_offset);\n \tdesc_kaddr = kmap(req->pr_desc_bh->b_page);\n+\tif (!desc_kaddr) {\n+\t\tnilfs_warn(inode->i_sb, \"%s: failed to map desc page\", __func__);\n+\t\treturn;\n+\t}\n \tdesc = nilfs_palloc_block_get_group_desc(inode, group,\n \t\t\t\t\t\t req->pr_desc_bh, desc_kaddr);\n \tbitmap_kaddr = kmap(req->pr_bitmap_bh->b_page);\n+\tif (!bitmap_kaddr) {\n+\t\tkunmap(req->pr_desc_bh->b_page);\n+\t\tnilfs_warn(inode->i_sb, \"%s: failed to map bitmap page\", __func__);\n+\t\treturn;\n+\t}\n \tbitmap = bitmap_kaddr + bh_offset(req->pr_bitmap_bh);\n \tlock = nilfs_mdt_bgl_lock(inode, group);\n \n",
            "diff --git a/fs/nilfs2/alloc.c b/fs/nilfs2/alloc.c\nindex 6ce8617b562d..c63835cead46 100644\n--- a/fs/nilfs2/alloc.c\n+++ b/fs/nilfs2/alloc.c\n@@ -609,6 +609,11 @@ void nilfs_palloc_commit_free_entry(struct inode *inode,\n \tdesc = nilfs_palloc_block_get_group_desc(inode, group,\n \t\t\t\t\t\t req->pr_desc_bh, desc_kaddr);\n \tbitmap_kaddr = kmap(req->pr_bitmap_bh->b_page);\n+\tif (!bitmap_kaddr) {\n+\t\tnilfs_warn(inode->i_sb, \"%s (ino=%lu): failed to map bitmap page\",\n+\t\t\t   __func__, inode->i_ino);\n+\t\treturn;\n+\t}\n \tbitmap = bitmap_kaddr + bh_offset(req->pr_bitmap_bh);\n \tlock = nilfs_mdt_bgl_lock(inode, group);\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/nilfs2/alloc.c b/fs/nilfs2/alloc.c\nindex 6ce8617b562d..72f3e22d22c4 100644\n--- a/fs/nilfs2/alloc.c\n+++ b/fs/nilfs2/alloc.c\n@@ -606,13 +606,26 @@ void nilfs_palloc_commit_free_entry(struct inode *inode,\n \n \tgroup = nilfs_palloc_group(inode, req->pr_entry_nr, &group_offset);\n \tdesc_kaddr = kmap(req->pr_desc_bh->b_page);\n+\tif (!desc_kaddr) {\n+\t\tnilfs_warn(inode->i_sb, \"%s (ino=%lu): failed to map desc page\",\n+\t\t\t   __func__, inode->i_ino);\n+\t\treturn;\n+\t}\n \tdesc = nilfs_palloc_block_get_group_desc(inode, group,\n \t\t\t\t\t\t req->pr_desc_bh, desc_kaddr);\n \tbitmap_kaddr = kmap(req->pr_bitmap_bh->b_page);\n+\tif (!bitmap_kaddr) {\n+\t\tkunmap(req->pr_desc_bh->b_page);\n+\t\tnilfs_warn(inode->i_sb, \"%s (ino=%lu): failed to map bitmap page\",\n+\t\t\t   __func__, inode->i_ino);\n+\t\treturn;\n+\t}\n \tbitmap = bitmap_kaddr + bh_offset(req->pr_bitmap_bh);\n \tlock = nilfs_mdt_bgl_lock(inode, group);\n \n-\tif (!nilfs_clear_bit_atomic(lock, group_offset, bitmap))\n+\tif (!nilfs_clear_bit_atomic(lock, group_offset, bitmap)) {\n+\t\tkunmap(req->pr_bitmap_bh->b_page);\n+\t\tkunmap(req->pr_desc_bh->b_page);\n \t\tnilfs_warn(inode->i_sb,\n \t\t\t   \"%s (ino=%lu): entry number %llu already freed\",\n \t\t\t   __func__, inode->i_ino,\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "d2ad6548d6f4f8f52f8fa250310fb027f04cfd18": {
        "non_crash": [
            "diff --git a/net/ieee802154/nl802154.c b/net/ieee802154/nl802154.c\nindex 2215f576ee37..80802517a2d2 100644\n--- a/net/ieee802154/nl802154.c\n+++ b/net/ieee802154/nl802154.c\n@@ -1412,7 +1412,7 @@ static int nl802154_trigger_scan(struct sk_buff *skb, struct genl_info *info)\n \t\treturn -EOPNOTSUPP;\n \t}\n \n-\tif (!nla_get_u8(info->attrs[NL802154_ATTR_SCAN_TYPE])) {\n+\tif (!info->attrs[NL802154_ATTR_SCAN_TYPE] || !nla_get_u8(info->attrs[NL802154_ATTR_SCAN_TYPE])) {\n \t\tNL_SET_ERR_MSG(info->extack, \"Malformed request, missing scan type\");\n \t\treturn -EINVAL;\n \t}\n@@ -1424,13 +1424,19 @@ static int nl802154_trigger_scan(struct sk_buff *skb, struct genl_info *info)\n \trequest->wpan_dev = wpan_dev;\n \trequest->wpan_phy = wpan_phy;\n \n-\ttype = nla_get_u8(info->attrs[NL802154_ATTR_SCAN_TYPE]);\n-\tswitch (type) {\n-\tcase NL802154_SCAN_PASSIVE:\n-\t\trequest->type = type;\n-\t\tbreak;\n-\tdefault:\n-\t\tNL_SET_ERR_MSG_FMT(info->extack, \"Unsupported scan type: %d\", type);\n+\tif (info->attrs[NL802154_ATTR_SCAN_TYPE]) {\n+\t\ttype = nla_get_u8(info->attrs[NL802154_ATTR_SCAN_TYPE]);\n+\t\tswitch (type) {\n+\t\tcase NL802154_SCAN_PASSIVE:\n+\t\t\trequest->type = type;\n+\t\t\tbreak;\n+\t\tdefault:\n+\t\t\tNL_SET_ERR_MSG_FMT(info->extack, \"Unsupported scan type: %d\", type);\n+\t\t\terr = -EINVAL;\n+\t\t\tgoto free_request;\n+\t\t}\n+\t} else {\n+\t\tNL_SET_ERR_MSG(info->extack, \"Malformed request, missing scan type\");\n \t\terr = -EINVAL;\n \t\tgoto free_request;\n \t}\n",
            "diff --git a/net/ieee802154/nl802154.c b/net/ieee802154/nl802154.c\nindex 2215f576ee37..d8f4379d4fa6 100644\n--- a/net/ieee802154/nl802154.c\n+++ b/net/ieee802154/nl802154.c\n@@ -1412,7 +1412,7 @@ static int nl802154_trigger_scan(struct sk_buff *skb, struct genl_info *info)\n \t\treturn -EOPNOTSUPP;\n \t}\n \n-\tif (!nla_get_u8(info->attrs[NL802154_ATTR_SCAN_TYPE])) {\n+\tif (!info->attrs[NL802154_ATTR_SCAN_TYPE]) {\n \t\tNL_SET_ERR_MSG(info->extack, \"Malformed request, missing scan type\");\n \t\treturn -EINVAL;\n \t}\n",
            "diff --git a/net/ieee802154/nl802154.c b/net/ieee802154/nl802154.c\nindex 2215f576ee37..80802517a2d2 100644\n--- a/net/ieee802154/nl802154.c\n+++ b/net/ieee802154/nl802154.c\n@@ -1412,7 +1412,7 @@ static int nl802154_trigger_scan(struct sk_buff *skb, struct genl_info *info)\n \t\treturn -EOPNOTSUPP;\n \t}\n \n-\tif (!nla_get_u8(info->attrs[NL802154_ATTR_SCAN_TYPE])) {\n+\tif (!info->attrs[NL802154_ATTR_SCAN_TYPE] || !nla_get_u8(info->attrs[NL802154_ATTR_SCAN_TYPE])) {\n \t\tNL_SET_ERR_MSG(info->extack, \"Malformed request, missing scan type\");\n \t\treturn -EINVAL;\n \t}\n@@ -1424,13 +1424,19 @@ static int nl802154_trigger_scan(struct sk_buff *skb, struct genl_info *info)\n \trequest->wpan_dev = wpan_dev;\n \trequest->wpan_phy = wpan_phy;\n \n-\ttype = nla_get_u8(info->attrs[NL802154_ATTR_SCAN_TYPE]);\n-\tswitch (type) {\n-\tcase NL802154_SCAN_PASSIVE:\n-\t\trequest->type = type;\n-\t\tbreak;\n-\tdefault:\n-\t\tNL_SET_ERR_MSG_FMT(info->extack, \"Unsupported scan type: %d\", type);\n+\tif (info->attrs[NL802154_ATTR_SCAN_TYPE]) {\n+\t\ttype = nla_get_u8(info->attrs[NL802154_ATTR_SCAN_TYPE]);\n+\t\tswitch (type) {\n+\t\tcase NL802154_SCAN_PASSIVE:\n+\t\t\trequest->type = type;\n+\t\t\tbreak;\n+\t\tdefault:\n+\t\t\tNL_SET_ERR_MSG_FMT(info->extack, \"Unsupported scan type: %d\", type);\n+\t\t\terr = -EINVAL;\n+\t\t\tgoto free_request;\n+\t\t}\n+\t} else {\n+\t\tNL_SET_ERR_MSG(info->extack, \"Malformed request, missing scan type\");\n \t\terr = -EINVAL;\n \t\tgoto free_request;\n \t}\n",
            "diff --git a/net/ieee802154/nl802154.c b/net/ieee802154/nl802154.c\nindex 2215f576ee37..9110d60f054f 100644\n--- a/net/ieee802154/nl802154.c\n+++ b/net/ieee802154/nl802154.c\n@@ -1412,7 +1412,7 @@ static int nl802154_trigger_scan(struct sk_buff *skb, struct genl_info *info)\n \t\treturn -EOPNOTSUPP;\n \t}\n \n-\tif (!nla_get_u8(info->attrs[NL802154_ATTR_SCAN_TYPE])) {\n+\tif (!info->attrs || !info->attrs[NL802154_ATTR_SCAN_TYPE] || !nla_get_u8(info->attrs[NL802154_ATTR_SCAN_TYPE])) {\n \t\tNL_SET_ERR_MSG(info->extack, \"Malformed request, missing scan type\");\n \t\treturn -EINVAL;\n \t}\n",
            "diff --git a/net/ieee802154/nl802154.c b/net/ieee802154/nl802154.c\nindex 2215f576ee37..d8f4379d4fa6 100644\n--- a/net/ieee802154/nl802154.c\n+++ b/net/ieee802154/nl802154.c\n@@ -1412,7 +1412,7 @@ static int nl802154_trigger_scan(struct sk_buff *skb, struct genl_info *info)\n \t\treturn -EOPNOTSUPP;\n \t}\n \n-\tif (!nla_get_u8(info->attrs[NL802154_ATTR_SCAN_TYPE])) {\n+\tif (!info->attrs[NL802154_ATTR_SCAN_TYPE]) {\n \t\tNL_SET_ERR_MSG(info->extack, \"Malformed request, missing scan type\");\n \t\treturn -EINVAL;\n \t}\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "e90732b9b16086b7f6207149157d36c0faea59f1": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/crypto/api.c b/crypto/api.c\nindex 64f2d365a8e9..bc5665ba2b98 100644\n--- a/crypto/api.c\n+++ b/crypto/api.c\n@@ -524,6 +524,7 @@ void *crypto_create_tfm_node(struct crypto_alg *alg,\n \tif (err == -EAGAIN)\n \t\tcrypto_shoot_alg(alg);\n \tkfree(mem);\n+\tgoto out_err;  // Ensure mem is freed in all error paths\n out_err:\n \tmem = ERR_PTR(err);\n out:\ndiff --git a/fs/crypto/hkdf.c b/fs/crypto/hkdf.c\nindex 7607d18b35fc..ddbd4368767b 100644\n--- a/fs/crypto/hkdf.c\n+++ b/fs/crypto/hkdf.c\n@@ -97,6 +97,7 @@ int fscrypt_init_hkdf(struct fscrypt_hkdf *hkdf, const u8 *master_key,\n \n err_free_tfm:\n \tcrypto_free_shash(hmac_tfm);\n+\tkfree(hmac_tfm);  // Free the allocated memory for hmac_tfm\n out:\n \tmemzero_explicit(prk, sizeof(prk));\n \treturn err;\ndiff --git a/fs/crypto/keyring.c b/fs/crypto/keyring.c\nindex 1cca09aa43f8..f8d3c8154818 100644\n--- a/fs/crypto/keyring.c\n+++ b/fs/crypto/keyring.c\n@@ -447,6 +447,7 @@ static int add_new_master_key(struct super_block *sb,\n \n out_put:\n \tfscrypt_put_master_key(mk);\n+\tkfree(mk);  // Free the allocated memory for mk\n \treturn err;\n }\n \n",
            "diff --git a/crypto/api.c b/crypto/api.c\nindex 64f2d365a8e9..5e5edf6ffc97 100644\n--- a/crypto/api.c\n+++ b/crypto/api.c\n@@ -524,6 +524,7 @@ void *crypto_create_tfm_node(struct crypto_alg *alg,\n \tif (err == -EAGAIN)\n \t\tcrypto_shoot_alg(alg);\n \tkfree(mem);\n+\tgoto out_err;  // Ensure cleanup on error\n out_err:\n \tmem = ERR_PTR(err);\n out:\ndiff --git a/fs/crypto/hkdf.c b/fs/crypto/hkdf.c\nindex 7607d18b35fc..438f0494a824 100644\n--- a/fs/crypto/hkdf.c\n+++ b/fs/crypto/hkdf.c\n@@ -97,6 +97,7 @@ int fscrypt_init_hkdf(struct fscrypt_hkdf *hkdf, const u8 *master_key,\n \n err_free_tfm:\n \tcrypto_free_shash(hmac_tfm);\n+\tkfree(hmac_tfm);  // Free allocated memory on error\n out:\n \tmemzero_explicit(prk, sizeof(prk));\n \treturn err;\ndiff --git a/fs/crypto/keyring.c b/fs/crypto/keyring.c\nindex 1cca09aa43f8..7fbb395d2c14 100644\n--- a/fs/crypto/keyring.c\n+++ b/fs/crypto/keyring.c\n@@ -447,6 +447,7 @@ static int add_new_master_key(struct super_block *sb,\n \n out_put:\n \tfscrypt_put_master_key(mk);\n+\tkfree(mk);  // Free allocated memory on error\n \treturn err;\n }\n \n",
            "diff --git a/crypto/api.c b/crypto/api.c\nindex 64f2d365a8e9..0b8f0ec4b79c 100644\n--- a/crypto/api.c\n+++ b/crypto/api.c\n@@ -526,6 +526,7 @@ void *crypto_create_tfm_node(struct crypto_alg *alg,\n \tkfree(mem);\n out_err:\n \tmem = ERR_PTR(err);\n+\tgoto out_free_tfm;  // Ensure cleanup on error\n out:\n \treturn mem;\n }\ndiff --git a/fs/crypto/hkdf.c b/fs/crypto/hkdf.c\nindex 7607d18b35fc..03be0424b030 100644\n--- a/fs/crypto/hkdf.c\n+++ b/fs/crypto/hkdf.c\n@@ -97,6 +97,7 @@ int fscrypt_init_hkdf(struct fscrypt_hkdf *hkdf, const u8 *master_key,\n \n err_free_tfm:\n \tcrypto_free_shash(hmac_tfm);\n+\thkdf->hmac_tfm = NULL;  // Clear reference after free\n out:\n \tmemzero_explicit(prk, sizeof(prk));\n \treturn err;\ndiff --git a/fs/crypto/keyring.c b/fs/crypto/keyring.c\nindex 1cca09aa43f8..f867eac1dc8f 100644\n--- a/fs/crypto/keyring.c\n+++ b/fs/crypto/keyring.c\n@@ -447,6 +447,7 @@ static int add_new_master_key(struct super_block *sb,\n \n out_put:\n \tfscrypt_put_master_key(mk);\n+\tkfree(mk);  // Free the master key structure on error\n \treturn err;\n }\n \ndiff --git a/fs/ext4/super.c b/fs/ext4/super.c\nindex 989365b878a6..662190ba11b2 100644\n--- a/fs/ext4/super.c\n+++ b/fs/ext4/super.c\n@@ -5593,6 +5593,7 @@ static int __ext4_fill_super(struct fs_context *fc, struct super_block *sb)\n \t\t/* flush s_error_work before journal destroy. */\n \t\tflush_work(&sbi->s_error_work);\n \t\tjbd2_journal_destroy(sbi->s_journal);\n+\t\tsbi->s_journal = NULL;  // Clear reference after destroy\n \t\tsbi->s_journal = NULL;\n \t}\n failed_mount3a:\n",
            "diff --git a/crypto/api.c b/crypto/api.c\nindex 64f2d365a8e9..5e5edf6ffc97 100644\n--- a/crypto/api.c\n+++ b/crypto/api.c\n@@ -524,6 +524,7 @@ void *crypto_create_tfm_node(struct crypto_alg *alg,\n \tif (err == -EAGAIN)\n \t\tcrypto_shoot_alg(alg);\n \tkfree(mem);\n+\tgoto out_err;  // Ensure cleanup on error\n out_err:\n \tmem = ERR_PTR(err);\n out:\ndiff --git a/fs/crypto/hkdf.c b/fs/crypto/hkdf.c\nindex 7607d18b35fc..fff44a89a3d3 100644\n--- a/fs/crypto/hkdf.c\n+++ b/fs/crypto/hkdf.c\n@@ -97,6 +97,7 @@ int fscrypt_init_hkdf(struct fscrypt_hkdf *hkdf, const u8 *master_key,\n \n err_free_tfm:\n \tcrypto_free_shash(hmac_tfm);\n+\thkdf->hmac_tfm = NULL;  // Ensure hmac_tfm is cleared on error\n out:\n \tmemzero_explicit(prk, sizeof(prk));\n \treturn err;\ndiff --git a/fs/crypto/keyring.c b/fs/crypto/keyring.c\nindex 1cca09aa43f8..10eee76d2eec 100644\n--- a/fs/crypto/keyring.c\n+++ b/fs/crypto/keyring.c\n@@ -447,6 +447,7 @@ static int add_new_master_key(struct super_block *sb,\n \n out_put:\n \tfscrypt_put_master_key(mk);\n+\tmk = NULL;  // Ensure mk is cleared on error\n \treturn err;\n }\n \ndiff --git a/fs/ext4/super.c b/fs/ext4/super.c\nindex 989365b878a6..c8901fa012c3 100644\n--- a/fs/ext4/super.c\n+++ b/fs/ext4/super.c\n@@ -5593,6 +5593,7 @@ static int __ext4_fill_super(struct fs_context *fc, struct super_block *sb)\n \t\t/* flush s_error_work before journal destroy. */\n \t\tflush_work(&sbi->s_error_work);\n \t\tjbd2_journal_destroy(sbi->s_journal);\n+\t\tsbi->s_journal = NULL;  // Ensure journal is cleared on error\n \t\tsbi->s_journal = NULL;\n \t}\n failed_mount3a:\n",
            "diff --git a/crypto/api.c b/crypto/api.c\nindex 64f2d365a8e9..1d44d8572f87 100644\n--- a/crypto/api.c\n+++ b/crypto/api.c\n@@ -527,6 +527,8 @@ void *crypto_create_tfm_node(struct crypto_alg *alg,\n out_err:\n \tmem = ERR_PTR(err);\n out:\n+\tif (err)\n+\t\tkfree(mem);\n \treturn mem;\n }\n EXPORT_SYMBOL_GPL(crypto_create_tfm_node);\ndiff --git a/fs/crypto/hkdf.c b/fs/crypto/hkdf.c\nindex 7607d18b35fc..0f2e40683870 100644\n--- a/fs/crypto/hkdf.c\n+++ b/fs/crypto/hkdf.c\n@@ -99,6 +99,8 @@ int fscrypt_init_hkdf(struct fscrypt_hkdf *hkdf, const u8 *master_key,\n \tcrypto_free_shash(hmac_tfm);\n out:\n \tmemzero_explicit(prk, sizeof(prk));\n+\tif (err)\n+\t\tcrypto_free_shash(hmac_tfm);\n \treturn err;\n }\n \ndiff --git a/fs/crypto/keyring.c b/fs/crypto/keyring.c\nindex 1cca09aa43f8..0c6b075c18cb 100644\n--- a/fs/crypto/keyring.c\n+++ b/fs/crypto/keyring.c\n@@ -447,6 +447,7 @@ static int add_new_master_key(struct super_block *sb,\n \n out_put:\n \tfscrypt_put_master_key(mk);\n+\tkfree(mk);\n \treturn err;\n }\n \ndiff --git a/fs/ext4/super.c b/fs/ext4/super.c\nindex 989365b878a6..03d664f4e29f 100644\n--- a/fs/ext4/super.c\n+++ b/fs/ext4/super.c\n@@ -5593,6 +5593,7 @@ static int __ext4_fill_super(struct fs_context *fc, struct super_block *sb)\n \t\t/* flush s_error_work before journal destroy. */\n \t\tflush_work(&sbi->s_error_work);\n \t\tjbd2_journal_destroy(sbi->s_journal);\n+\t\tkfree(sbi);\n \t\tsbi->s_journal = NULL;\n \t}\n failed_mount3a:\n"
        ],
        "error": []
    },
    "d5cd7bc74de1e50a5139d45189395427cc5c3f63": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/bpf/btf.c b/kernel/bpf/btf.c\nindex cad09858a5f2..6d960167acff 100644\n--- a/kernel/bpf/btf.c\n+++ b/kernel/bpf/btf.c\n@@ -3033,6 +3033,10 @@ static int btf_resolve(struct btf_verifier_env *env,\n \tenv->resolve_mode = RESOLVE_TBD;\n \tenv_stack_push(env, t, type_id);\n \twhile (!err && (v = env_stack_peak(env))) {\n+\t\tif (!v || !v->t) {\n+\t\t\terr = -EINVAL;\n+\t\t\tbreak;\n+\t\t}\n \t\tenv->log_type_id = v->type_id;\n \t\terr = btf_type_ops(v->t)->resolve(env, v);\n \t}\n",
            "diff --git a/kernel/bpf/btf.c b/kernel/bpf/btf.c\nindex cad09858a5f2..6d960167acff 100644\n--- a/kernel/bpf/btf.c\n+++ b/kernel/bpf/btf.c\n@@ -3033,6 +3033,10 @@ static int btf_resolve(struct btf_verifier_env *env,\n \tenv->resolve_mode = RESOLVE_TBD;\n \tenv_stack_push(env, t, type_id);\n \twhile (!err && (v = env_stack_peak(env))) {\n+\t\tif (!v || !v->t) {\n+\t\t\terr = -EINVAL;\n+\t\t\tbreak;\n+\t\t}\n \t\tenv->log_type_id = v->type_id;\n \t\terr = btf_type_ops(v->t)->resolve(env, v);\n \t}\n",
            "diff --git a/kernel/bpf/btf.c b/kernel/bpf/btf.c\nindex cad09858a5f2..1b18baa4893b 100644\n--- a/kernel/bpf/btf.c\n+++ b/kernel/bpf/btf.c\n@@ -3034,6 +3034,11 @@ static int btf_resolve(struct btf_verifier_env *env,\n \tenv_stack_push(env, t, type_id);\n \twhile (!err && (v = env_stack_peak(env))) {\n \t\tenv->log_type_id = v->type_id;\n+\t\tif (!v->t) {\n+\t\t\tbtf_verifier_log_type(env, t, \"Invalid type encountered\");\n+\t\t\terr = -EINVAL;\n+\t\t\tbreak;\n+\t\t}\n \t\terr = btf_type_ops(v->t)->resolve(env, v);\n \t}\n \n@@ -3070,6 +3075,11 @@ static int btf_check_all_types(struct btf_verifier_env *env)\n \tfor (type_id = 1; type_id <= btf->nr_types; type_id++) {\n \t\tconst struct btf_type *t = btf_type_by_id(btf, type_id);\n \n+\t\tif (!t) {\n+\t\t\tbtf_verifier_log_type(env, NULL, \"Invalid type ID encountered\");\n+\t\t\treturn -EINVAL;\n+\t\t}\n+\n \t\tenv->log_type_id = type_id;\n \t\tif (btf_type_needs_resolve(t) &&\n \t\t    !env_type_is_resolved(env, type_id)) {\n",
            "diff --git a/kernel/bpf/btf.c b/kernel/bpf/btf.c\nindex cad09858a5f2..bbe245d274cd 100644\n--- a/kernel/bpf/btf.c\n+++ b/kernel/bpf/btf.c\n@@ -3033,6 +3033,10 @@ static int btf_resolve(struct btf_verifier_env *env,\n \tenv->resolve_mode = RESOLVE_TBD;\n \tenv_stack_push(env, t, type_id);\n \twhile (!err && (v = env_stack_peak(env))) {\n+\t\tif (!v || !v->t) {\n+\t\t\terr = -EINVAL;\n+\t\t\tbreak;\n+\t\t}\n \t\tenv->log_type_id = v->type_id;\n \t\terr = btf_type_ops(v->t)->resolve(env, v);\n \t}\n@@ -3073,6 +3077,10 @@ static int btf_check_all_types(struct btf_verifier_env *env)\n \t\tenv->log_type_id = type_id;\n \t\tif (btf_type_needs_resolve(t) &&\n \t\t    !env_type_is_resolved(env, type_id)) {\n+\t\t\tif (!t) {\n+\t\t\t\terr = -EINVAL;\n+\t\t\t\tbreak;\n+\t\t\t}\n \t\t\terr = btf_resolve(env, t, type_id);\n \t\t\tif (err)\n \t\t\t\treturn err;\n"
        ],
        "error": []
    },
    "5091eca677b6821339a9491de5b4151c5be85ae7": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/ipv6/mcast.c b/net/ipv6/mcast.c\nindex 87c699d57b36..bc62f196b627 100644\n--- a/net/ipv6/mcast.c\n+++ b/net/ipv6/mcast.c\n@@ -1849,8 +1849,10 @@ static struct sk_buff *add_grhead(struct sk_buff *skb, struct ifmcaddr6 *pmc,\n \n \tif (!skb) {\n \t\tskb = mld_newpack(pmc->idev, mtu);\n-\t\tif (!skb)\n+\t\tif (!skb) {\n+\t\t\tkfree_skb(skb);\n \t\t\treturn NULL;\n+\t\t}\n \t}\n \tpgr = skb_put(skb, sizeof(struct mld2_grec));\n \tpgr->grec_type = type;\n@@ -2116,8 +2118,10 @@ static void mld_send_cr(struct inet6_dev *idev)\n \t\t\tpmc->mca_crcount--;\n \t\t}\n \t}\n-\tif (!skb)\n+\tif (!skb) {\n+\t\tkfree_skb(skb);\n \t\treturn;\n+\t}\n \t(void) mld_sendpack(skb);\n }\n \n",
            "diff --git a/net/ipv6/mcast.c b/net/ipv6/mcast.c\nindex 87c699d57b36..4f66c70d7daa 100644\n--- a/net/ipv6/mcast.c\n+++ b/net/ipv6/mcast.c\n@@ -1746,8 +1746,10 @@ static struct sk_buff *mld_newpack(struct inet6_dev *idev, unsigned int mtu)\n \t */\n \tsize = min_t(int, mtu, PAGE_SIZE / 2) + hlen + tlen;\n \tskb = sock_alloc_send_skb(sk, size, 1, &err);\n-\tif (!skb)\n+\tif (!skb) {\n+\t\tkfree_skb(skb);\n \t\treturn NULL;\n+\t}\n \n \tskb->priority = TC_PRIO_CONTROL;\n \tskb_reserve(skb, hlen);\n@@ -1949,7 +1951,12 @@ static struct sk_buff *add_grec(struct sk_buff *skb, struct ifmcaddr6 *pmc,\n \t\t\tscount = 0;\n \t\t}\n \t\tif (first) {\n-\t\t\tskb = add_grhead(skb, pmc, type, &pgr, mtu);\n+\t\t\tstruct sk_buff *new_skb = add_grhead(skb, pmc, type, &pgr, mtu);\n+\t\t\tif (!new_skb) {\n+\t\t\t\tkfree_skb(skb);\n+\t\t\t\treturn NULL;\n+\t\t\t}\n+\t\t\tskb = new_skb;\n \t\t\tfirst = 0;\n \t\t}\n \t\tif (!skb)\n",
            "diff --git a/net/ipv6/mcast.c b/net/ipv6/mcast.c\nindex 87c699d57b36..d08eb5671098 100644\n--- a/net/ipv6/mcast.c\n+++ b/net/ipv6/mcast.c\n@@ -2116,8 +2116,10 @@ static void mld_send_cr(struct inet6_dev *idev)\n \t\t\tpmc->mca_crcount--;\n \t\t}\n \t}\n-\tif (!skb)\n+\tif (!skb) {\n+\t\tkfree_skb(skb);\n \t\treturn;\n+\t}\n \t(void) mld_sendpack(skb);\n }\n \n",
            "diff --git a/net/ipv6/mcast.c b/net/ipv6/mcast.c\nindex 87c699d57b36..1ee0855af29d 100644\n--- a/net/ipv6/mcast.c\n+++ b/net/ipv6/mcast.c\n@@ -1746,8 +1746,10 @@ static struct sk_buff *mld_newpack(struct inet6_dev *idev, unsigned int mtu)\n \t */\n \tsize = min_t(int, mtu, PAGE_SIZE / 2) + hlen + tlen;\n \tskb = sock_alloc_send_skb(sk, size, 1, &err);\n-\tif (!skb)\n+\tif (!skb) {\n+\t\tkfree_skb(skb);\n \t\treturn NULL;\n+\t}\n \n \tskb->priority = TC_PRIO_CONTROL;\n \tskb_reserve(skb, hlen);\n@@ -1849,8 +1851,10 @@ static struct sk_buff *add_grhead(struct sk_buff *skb, struct ifmcaddr6 *pmc,\n \n \tif (!skb) {\n \t\tskb = mld_newpack(pmc->idev, mtu);\n-\t\tif (!skb)\n+\t\tif (!skb) {\n+\t\t\tkfree_skb(skb);\n \t\t\treturn NULL;\n+\t\t}\n \t}\n \tpgr = skb_put(skb, sizeof(struct mld2_grec));\n \tpgr->grec_type = type;\n",
            "diff --git a/net/ipv6/mcast.c b/net/ipv6/mcast.c\nindex 87c699d57b36..4f66c70d7daa 100644\n--- a/net/ipv6/mcast.c\n+++ b/net/ipv6/mcast.c\n@@ -1746,8 +1746,10 @@ static struct sk_buff *mld_newpack(struct inet6_dev *idev, unsigned int mtu)\n \t */\n \tsize = min_t(int, mtu, PAGE_SIZE / 2) + hlen + tlen;\n \tskb = sock_alloc_send_skb(sk, size, 1, &err);\n-\tif (!skb)\n+\tif (!skb) {\n+\t\tkfree_skb(skb);\n \t\treturn NULL;\n+\t}\n \n \tskb->priority = TC_PRIO_CONTROL;\n \tskb_reserve(skb, hlen);\n@@ -1949,7 +1951,12 @@ static struct sk_buff *add_grec(struct sk_buff *skb, struct ifmcaddr6 *pmc,\n \t\t\tscount = 0;\n \t\t}\n \t\tif (first) {\n-\t\t\tskb = add_grhead(skb, pmc, type, &pgr, mtu);\n+\t\t\tstruct sk_buff *new_skb = add_grhead(skb, pmc, type, &pgr, mtu);\n+\t\t\tif (!new_skb) {\n+\t\t\t\tkfree_skb(skb);\n+\t\t\t\treturn NULL;\n+\t\t\t}\n+\t\t\tskb = new_skb;\n \t\t\tfirst = 0;\n \t\t}\n \t\tif (!skb)\n"
        ],
        "error": []
    },
    "3f5d1a7de17359e085f9a912eae7bf7e89dc7435": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 2c351765c409..436682255888 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -218,6 +218,9 @@ void __post_watch_notification(struct watch_list *wlist,\n \t\tn->info |= watch->info_id;\n \n \t\twqueue = rcu_dereference(watch->queue);\n+\t\tif (!wqueue)\n+\t\t\tcontinue; // Ensure wqueue is valid before accessing\n+\n \t\twf = rcu_dereference(wqueue->filter);\n \t\tif (wf && !filter_watch_notification(wf, n))\n \t\t\tcontinue;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 2c351765c409..fe8af2efad2f 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -202,6 +202,7 @@ void __post_watch_notification(struct watch_list *wlist,\n {\n \tconst struct watch_filter *wf;\n \tstruct watch_queue *wqueue;\n+\tstruct kref refcount;\n \tstruct watch *watch;\n \n \tif (((n->info & WATCH_INFO_LENGTH) >> WATCH_INFO_LENGTH__SHIFT) == 0) {\n@@ -217,17 +218,29 @@ void __post_watch_notification(struct watch_list *wlist,\n \t\tn->info &= ~WATCH_INFO_ID;\n \t\tn->info |= watch->info_id;\n \n+\t\t/* Increment reference count to prevent use-after-free */\n+\t\tif (!kref_get_unless_zero(&watch->refcount))\n+\t\t\tcontinue;\n+\n \t\twqueue = rcu_dereference(watch->queue);\n \t\twf = rcu_dereference(wqueue->filter);\n-\t\tif (wf && !filter_watch_notification(wf, n))\n+\t\tif (wf && !filter_watch_notification(wf, n)) {\n+\t\t\tkref_put(&watch->refcount, watch_release);\n \t\t\tcontinue;\n+\t\t}\n \n-\t\tif (security_post_notification(watch->cred, cred, n) < 0)\n+\t\tif (security_post_notification(watch->cred, cred, n) < 0) {\n+\t\t\tkref_put(&watch->refcount, watch_release);\n \t\t\tcontinue;\n+\t\t}\n \n \t\tif (lock_wqueue(wqueue)) {\n \t\t\tpost_one_notification(wqueue, n);\n \t\t\tunlock_wqueue(wqueue);\n+\t\t\tkref_put(&watch->refcount, watch_release);\n+\t\t} else {\n+\t\t\tkref_put(&watch->refcount, watch_release);\n+\t\t}\n \t\t}\n \t}\n \n@@ -551,6 +564,7 @@ int remove_watch_from_object(struct watch_list *wlist, struct watch_queue *wq,\n \n \t\tif (!hlist_unhashed(&watch->queue_node)) {\n \t\t\thlist_del_init_rcu(&watch->queue_node);\n+\t\tkref_put(&watch->refcount, watch_release);\n \t\t\tput_watch(watch);\n \t\t}\n \n@@ -573,7 +587,11 @@ int remove_watch_from_object(struct watch_list *wlist, struct watch_queue *wq,\n \trcu_read_unlock();\n \treturn ret;\n }\n-EXPORT_SYMBOL(remove_watch_from_object);\n+static void watch_release(struct kref *ref)\n+{\n+\tstruct watch *watch = container_of(ref, struct watch, refcount);\n+\tkfree(watch);\n+}\n \n /*\n  * Remove all the watches that are contributory to a queue.  This has the\n@@ -680,6 +698,7 @@ int watch_queue_init(struct pipe_inode_info *pipe)\n \tkref_init(&wqueue->usage);\n \tspin_lock_init(&wqueue->lock);\n \tINIT_HLIST_HEAD(&wqueue->watches);\n+\tkref_init(&wqueue->refcount);\n \n \tpipe->watch_queue = wqueue;\n \treturn 0;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 2c351765c409..70eac4e560ce 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -217,17 +217,28 @@ void __post_watch_notification(struct watch_list *wlist,\n \t\tn->info &= ~WATCH_INFO_ID;\n \t\tn->info |= watch->info_id;\n \n+\t\tif (!kref_get_unless_zero(&watch->usage))\n+\t\t\tcontinue;\n+\n \t\twqueue = rcu_dereference(watch->queue);\n \t\twf = rcu_dereference(wqueue->filter);\n-\t\tif (wf && !filter_watch_notification(wf, n))\n+\t\tif (wf && !filter_watch_notification(wf, n)) {\n+\t\t\tkref_put(&watch->usage, watch_release);\n \t\t\tcontinue;\n+\t\t}\n \n-\t\tif (security_post_notification(watch->cred, cred, n) < 0)\n+\t\tif (security_post_notification(watch->cred, cred, n) < 0) {\n+\t\t\tkref_put(&watch->usage, watch_release);\n \t\t\tcontinue;\n+\t\t}\n \n \t\tif (lock_wqueue(wqueue)) {\n \t\t\tpost_one_notification(wqueue, n);\n \t\t\tunlock_wqueue(wqueue);\n+\t\t\tkref_put(&watch->usage, watch_release);\n+\t\t} else {\n+\t\t\tkref_put(&watch->usage, watch_release);\n+\t\t}\n \t\t}\n \t}\n \n@@ -595,9 +606,10 @@ void watch_queue_clear(struct watch_queue *wqueue)\n \twhile (!hlist_empty(&wqueue->watches)) {\n \t\twatch = hlist_entry(wqueue->watches.first, struct watch, queue_node);\n \t\thlist_del_init_rcu(&watch->queue_node);\n-\t\t/* We now own a ref on the watch. */\n \t\tspin_unlock_bh(&wqueue->lock);\n \n+\t\tkref_put(&watch->usage, watch_release);\n+\n \t\t/* We can't do the next bit under the queue lock as we need to\n \t\t * get the list lock - which would cause a deadlock if someone\n \t\t * was removing from the opposite direction at the same time or\n@@ -675,6 +687,8 @@ int watch_queue_init(struct pipe_inode_info *pipe)\n \twqueue = kzalloc(sizeof(*wqueue), GFP_KERNEL);\n \tif (!wqueue)\n \t\treturn -ENOMEM;\n+\tif (!wqueue)\n+\t\treturn -ENOMEM;\n \n \twqueue->pipe = pipe;\n \tkref_init(&wqueue->usage);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 2c351765c409..9f8d05eada21 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -217,18 +217,29 @@ void __post_watch_notification(struct watch_list *wlist,\n \t\tn->info &= ~WATCH_INFO_ID;\n \t\tn->info |= watch->info_id;\n \n+\t\t/* Increment reference count to ensure watch is not freed */\n+\t\tkref_get(&watch->refcount);\n+\n \t\twqueue = rcu_dereference(watch->queue);\n \t\twf = rcu_dereference(wqueue->filter);\n-\t\tif (wf && !filter_watch_notification(wf, n))\n+\t\tif (wf && !filter_watch_notification(wf, n)) {\n+\t\t\tkref_put(&watch->refcount, watch_release);\n \t\t\tcontinue;\n+\t\t}\n \n-\t\tif (security_post_notification(watch->cred, cred, n) < 0)\n+\t\tif (security_post_notification(watch->cred, cred, n) < 0) {\n+\t\t\tkref_put(&watch->refcount, watch_release);\n \t\t\tcontinue;\n+\t\t}\n \n \t\tif (lock_wqueue(wqueue)) {\n \t\t\tpost_one_notification(wqueue, n);\n \t\t\tunlock_wqueue(wqueue);\n \t\t}\n+\n+\t\t/* Decrement reference count after use */\n+\t\tkref_put(&watch->refcount, watch_release);\n+\t\t}\n \t}\n \n \trcu_read_unlock();\n@@ -598,6 +609,9 @@ void watch_queue_clear(struct watch_queue *wqueue)\n \t\t/* We now own a ref on the watch. */\n \t\tspin_unlock_bh(&wqueue->lock);\n \n+\t\t/* Decrement reference count as watch is removed from the list */\n+\t\tkref_put(&watch->refcount, watch_release);\n+\n \t\t/* We can't do the next bit under the queue lock as we need to\n \t\t * get the list lock - which would cause a deadlock if someone\n \t\t * was removing from the opposite direction at the same time or\n@@ -680,6 +694,8 @@ int watch_queue_init(struct pipe_inode_info *pipe)\n \tkref_init(&wqueue->usage);\n \tspin_lock_init(&wqueue->lock);\n \tINIT_HLIST_HEAD(&wqueue->watches);\n+\t/* Initialize reference count for watch objects */\n+\tkref_init(&watch->refcount);\n \n \tpipe->watch_queue = wqueue;\n \treturn 0;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 2c351765c409..a929df982b76 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -217,18 +217,30 @@ void __post_watch_notification(struct watch_list *wlist,\n \t\tn->info &= ~WATCH_INFO_ID;\n \t\tn->info |= watch->info_id;\n \n+\t\t/* Take a reference on the watch object */\n+\t\tif (!kref_get_unless_zero(&watch->usage))\n+\t\t\tcontinue;\n+\n \t\twqueue = rcu_dereference(watch->queue);\n \t\twf = rcu_dereference(wqueue->filter);\n-\t\tif (wf && !filter_watch_notification(wf, n))\n+\t\tif (wf && !filter_watch_notification(wf, n)) {\n+\t\t\tkref_put(&watch->usage, watch_release);\n \t\t\tcontinue;\n+\t\t}\n \n-\t\tif (security_post_notification(watch->cred, cred, n) < 0)\n+\t\tif (security_post_notification(watch->cred, cred, n) < 0) {\n+\t\t\tkref_put(&watch->usage, watch_release);\n \t\t\tcontinue;\n+\t\t}\n \n \t\tif (lock_wqueue(wqueue)) {\n \t\t\tpost_one_notification(wqueue, n);\n \t\t\tunlock_wqueue(wqueue);\n \t\t}\n+\n+\t\t/* Release the reference on the watch object */\n+\t\tkref_put(&watch->usage, watch_release);\n+\t\t}\n \t}\n \n \trcu_read_unlock();\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "5c8b4f0ea10c23945625f4187bac8e6e471d732c": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/proc/task_mmu.c b/fs/proc/task_mmu.c\nindex 18f8c3acbb85..8d72c20174f4 100644\n--- a/fs/proc/task_mmu.c\n+++ b/fs/proc/task_mmu.c\n@@ -478,6 +478,11 @@ static void smaps_account(struct mem_size_stats *mss, struct page *page,\n \t\tunsigned long pss = PAGE_SIZE << PSS_SHIFT;\n \t\tif (mapcount >= 2)\n \t\t\tpss /= mapcount;\n+\t\t/* Ensure mapcount is correctly handled for compound pages */\n+\t\tif (PageCompound(page) && PageDoubleMap(page)) {\n+\t\t\tif (mapcount > 1)\n+\t\t\t\tmapcount--;\n+\t\t}\n \t\tsmaps_page_accumulate(mss, page, PAGE_SIZE, pss, dirty, locked,\n \t\t\t\t      mapcount < 2);\n \t}\ndiff --git a/mm/util.c b/mm/util.c\nindex 7e43369064c8..46187b184d94 100644\n--- a/mm/util.c\n+++ b/mm/util.c\n@@ -734,8 +734,11 @@ int __page_mapcount(struct page *page)\n \t\treturn ret;\n \tpage = compound_head(page);\n \tret += atomic_read(compound_mapcount_ptr(page)) + 1;\n-\tif (PageDoubleMap(page))\n-\t\tret--;\n+\tif (PageDoubleMap(page)) {\n+\t\t/* Ensure PageDoubleMap is handled correctly */\n+\t\tif (ret > 1)\n+\t\t\tret--;\n+\t}\n \treturn ret;\n }\n EXPORT_SYMBOL_GPL(__page_mapcount);\n",
            "diff --git a/mm/util.c b/mm/util.c\nindex 7e43369064c8..a2900668657a 100644\n--- a/mm/util.c\n+++ b/mm/util.c\n@@ -734,8 +734,11 @@ int __page_mapcount(struct page *page)\n \t\treturn ret;\n \tpage = compound_head(page);\n \tret += atomic_read(compound_mapcount_ptr(page)) + 1;\n-\tif (PageDoubleMap(page))\n-\t\tret--;\n+\tif (PageDoubleMap(page)) {\n+\t\t// Ensure the mapcount is not decremented below zero\n+\t\tif (ret > 0)\n+\t\t\tret--;\n+\t}\n \treturn ret;\n }\n EXPORT_SYMBOL_GPL(__page_mapcount);\n",
            "diff --git a/mm/util.c b/mm/util.c\nindex 7e43369064c8..087b6bbe20ac 100644\n--- a/mm/util.c\n+++ b/mm/util.c\n@@ -734,7 +734,11 @@ int __page_mapcount(struct page *page)\n \t\treturn ret;\n \tpage = compound_head(page);\n \tret += atomic_read(compound_mapcount_ptr(page)) + 1;\n-\tif (PageDoubleMap(page))\n+\t/*\n+\t * Ensure PageDoubleMap is handled correctly.\n+\t * Only decrement mapcount if the page is indeed double mapped.\n+\t */\n+\tif (PageDoubleMap(page) && ret > 1)\n \t\tret--;\n \treturn ret;\n }\n",
            "diff --git a/mm/util.c b/mm/util.c\nindex 7e43369064c8..fe2805d23548 100644\n--- a/mm/util.c\n+++ b/mm/util.c\n@@ -734,7 +734,11 @@ int __page_mapcount(struct page *page)\n \t\treturn ret;\n \tpage = compound_head(page);\n \tret += atomic_read(compound_mapcount_ptr(page)) + 1;\n-\tif (PageDoubleMap(page))\n+\t/*\n+\t * Ensure PageDoubleMap logic is correctly applied only for\n+\t * compound pages that are anonymous or huge.\n+\t */\n+\tif (PageDoubleMap(page) && (PageAnon(page) || PageHuge(page)))\n \t\tret--;\n \treturn ret;\n }\n",
            "diff --git a/mm/util.c b/mm/util.c\nindex 7e43369064c8..a2baef2f8017 100644\n--- a/mm/util.c\n+++ b/mm/util.c\n@@ -734,7 +734,7 @@ int __page_mapcount(struct page *page)\n \t\treturn ret;\n \tpage = compound_head(page);\n \tret += atomic_read(compound_mapcount_ptr(page)) + 1;\n-\tif (PageDoubleMap(page))\n+\tif (PageDoubleMap(page) && ret > 0)\n \t\tret--;\n \treturn ret;\n }\n"
        ],
        "error": []
    },
    "01383b29d139cf9c9f9d9bd6e9947474ffe657a6": {
        "non_crash": [
            "diff --git a/mm/gup.c b/mm/gup.c\nindex ef29641671c7..7317de2c7bd3 100644\n--- a/mm/gup.c\n+++ b/mm/gup.c\n@@ -1170,8 +1170,9 @@ static long __get_user_pages(struct mm_struct *mm,\n \t\tif (!vma || start >= vma->vm_end) {\n \t\t\tvma = find_vma(mm, start);\n \t\t\tif (vma && (start < vma->vm_start)) {\n-\t\t\t\tWARN_ON_ONCE(vma->vm_flags & VM_GROWSDOWN);\n-\t\t\t\tvma = NULL;\n+\t\t\t\tif (!(vma->vm_flags & VM_GROWSDOWN)) {\n+\t\t\t\t\tvma = NULL;\n+\t\t\t\t}\n \t\t\t}\n \t\t\tif (!vma && in_gate_area(mm, start)) {\n \t\t\t\tret = get_gate_page(mm, start & PAGE_MASK,\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/lib/iov_iter.c b/lib/iov_iter.c\nindex b667b1e2f688..550d19d1339c 100644\n--- a/lib/iov_iter.c\n+++ b/lib/iov_iter.c\n@@ -1108,6 +1108,9 @@ static ssize_t __iov_iter_get_pages_alloc(struct iov_iter *i,\n \t\tn = want_pages_array(pages, maxsize, *start, maxpages);\n \t\tif (!n)\n \t\t\treturn -ENOMEM;\n+\t\t/* Ensure FOLL_PIN is set when FOLL_LONGTERM is used */\n+\t\tif (gup_flags & FOLL_LONGTERM)\n+\t\t\tgup_flags |= FOLL_PIN;\n \t\tres = get_user_pages_fast(addr, n, gup_flags, *pages);\n \t\tif (unlikely(res <= 0))\n \t\t\treturn res;\ndiff --git a/mm/gup.c b/mm/gup.c\nindex ef29641671c7..5ff186d6a719 100644\n--- a/mm/gup.c\n+++ b/mm/gup.c\n@@ -2160,7 +2160,9 @@ static long __gup_longterm_locked(struct mm_struct *mm,\n \t\t\tbreak;\n \t\t}\n \n-\t\t/* FOLL_LONGTERM implies FOLL_PIN */\n+\t\t/* Ensure FOLL_PIN is set when FOLL_LONGTERM is used */\n+\t\tif (gup_flags & FOLL_LONGTERM)\n+\t\t\tgup_flags |= FOLL_PIN;\n \t\trc = check_and_migrate_movable_pages(nr_pinned_pages, pages);\n \t} while (rc == -EAGAIN);\n \tmemalloc_pin_restore(flags);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/mm/gup.c b/mm/gup.c\nindex ef29641671c7..f08d0f7243e7 100644\n--- a/mm/gup.c\n+++ b/mm/gup.c\n@@ -2161,7 +2161,13 @@ static long __gup_longterm_locked(struct mm_struct *mm,\n \t\t}\n \n \t\t/* FOLL_LONGTERM implies FOLL_PIN */\n-\t\trc = check_and_migrate_movable_pages(nr_pinned_pages, pages);\n+\t\tif (gup_flags & FOLL_LONGTERM) {\n+\t\t\trc = check_and_migrate_movable_pages(nr_pinned_pages, pages);\n+\t\t\tif (rc) {\n+\t\t\t\tpr_warn(\"Failed to migrate movable pages for long-term pinning\\n\");\n+\t\t\t\tgoto out_unpin;\n+\t\t\t}\n+\t\t}\n \t} while (rc == -EAGAIN);\n \tmemalloc_pin_restore(flags);\n \treturn rc ? rc : nr_pinned_pages;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/lib/iov_iter.c b/lib/iov_iter.c\nindex b667b1e2f688..c043467fb297 100644\n--- a/lib/iov_iter.c\n+++ b/lib/iov_iter.c\n@@ -1108,7 +1108,7 @@ static ssize_t __iov_iter_get_pages_alloc(struct iov_iter *i,\n \t\tn = want_pages_array(pages, maxsize, *start, maxpages);\n \t\tif (!n)\n \t\t\treturn -ENOMEM;\n-\t\tres = get_user_pages_fast(addr, n, gup_flags, *pages);\n+\t\tres = internal_get_user_pages_fast(addr, n, gup_flags, *pages);\n \t\tif (unlikely(res <= 0))\n \t\t\treturn res;\n \t\tmaxsize = min_t(size_t, maxsize, res * PAGE_SIZE - *start);\ndiff --git a/mm/gup.c b/mm/gup.c\nindex ef29641671c7..8695934deeb5 100644\n--- a/mm/gup.c\n+++ b/mm/gup.c\n@@ -2161,7 +2161,13 @@ static long __gup_longterm_locked(struct mm_struct *mm,\n \t\t}\n \n \t\t/* FOLL_LONGTERM implies FOLL_PIN */\n-\t\trc = check_and_migrate_movable_pages(nr_pinned_pages, pages);\n+\t\tif (gup_flags & FOLL_LONGTERM) {\n+\t\t\trc = check_and_migrate_movable_pages(nr_pinned_pages, pages);\n+\t\t\tif (rc) {\n+\t\t\t\tmemalloc_pin_restore(flags);\n+\t\t\t\treturn rc;\n+\t\t\t}\n+\t\t}\n \t} while (rc == -EAGAIN);\n \tmemalloc_pin_restore(flags);\n \treturn rc ? rc : nr_pinned_pages;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/lib/iov_iter.c b/lib/iov_iter.c\nindex b667b1e2f688..ec60e7510d9d 100644\n--- a/lib/iov_iter.c\n+++ b/lib/iov_iter.c\n@@ -1108,7 +1108,11 @@ static ssize_t __iov_iter_get_pages_alloc(struct iov_iter *i,\n \t\tn = want_pages_array(pages, maxsize, *start, maxpages);\n \t\tif (!n)\n \t\t\treturn -ENOMEM;\n-\t\tres = get_user_pages_fast(addr, n, gup_flags, *pages);\n+\t\tif (gup_flags & FOLL_LONGTERM) {\n+\t\t\tres = __gup_longterm_locked(current->mm, addr, n, *pages, NULL, gup_flags);\n+\t\t} else {\n+\t\t\tres = get_user_pages_fast(addr, n, gup_flags, *pages);\n+\t\t}\n \t\tif (unlikely(res <= 0))\n \t\t\treturn res;\n \t\tmaxsize = min_t(size_t, maxsize, res * PAGE_SIZE - *start);\ndiff --git a/mm/gup.c b/mm/gup.c\nindex ef29641671c7..5605750551dd 100644\n--- a/mm/gup.c\n+++ b/mm/gup.c\n@@ -2161,10 +2161,16 @@ static long __gup_longterm_locked(struct mm_struct *mm,\n \t\t}\n \n \t\t/* FOLL_LONGTERM implies FOLL_PIN */\n-\t\trc = check_and_migrate_movable_pages(nr_pinned_pages, pages);\n+\t\tif (gup_flags & FOLL_LONGTERM) {\n+\t\t\trc = check_and_migrate_movable_pages(nr_pinned_pages, pages);\n+\t\t\tif (rc) {\n+\t\t\t\tmemalloc_pin_restore(flags);\n+\t\t\t\treturn rc;\n+\t\t\t}\n+\t\t}\n \t} while (rc == -EAGAIN);\n \tmemalloc_pin_restore(flags);\n-\treturn rc ? rc : nr_pinned_pages;\n+\treturn nr_pinned_pages;\n }\n \n /*\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "1a201ce4f0f4ab2f165b93d0ce5c15ebe1a5b321": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/sys.c b/kernel/sys.c\nindex 5fd54bf0e886..59003ad68cc6 100644\n--- a/kernel/sys.c\n+++ b/kernel/sys.c\n@@ -2331,7 +2331,8 @@ static int prctl_set_vma(unsigned long opt, unsigned long addr,\n \t\tmmap_write_lock(mm);\n \t\terror = madvise_set_anon_name(mm, addr, size, anon_name);\n \t\tmmap_write_unlock(mm);\n-\t\tanon_vma_name_put(anon_name);\n+\t\tif (error)\n+\t\t\tanon_vma_name_put(anon_name);\n \t\tbreak;\n \tdefault:\n \t\terror = -EINVAL;\n",
            "diff --git a/kernel/sys.c b/kernel/sys.c\nindex 5fd54bf0e886..59003ad68cc6 100644\n--- a/kernel/sys.c\n+++ b/kernel/sys.c\n@@ -2331,7 +2331,8 @@ static int prctl_set_vma(unsigned long opt, unsigned long addr,\n \t\tmmap_write_lock(mm);\n \t\terror = madvise_set_anon_name(mm, addr, size, anon_name);\n \t\tmmap_write_unlock(mm);\n-\t\tanon_vma_name_put(anon_name);\n+\t\tif (error)\n+\t\t\tanon_vma_name_put(anon_name);\n \t\tbreak;\n \tdefault:\n \t\terror = -EINVAL;\n",
            "diff --git a/kernel/sys.c b/kernel/sys.c\nindex 5fd54bf0e886..59003ad68cc6 100644\n--- a/kernel/sys.c\n+++ b/kernel/sys.c\n@@ -2331,7 +2331,8 @@ static int prctl_set_vma(unsigned long opt, unsigned long addr,\n \t\tmmap_write_lock(mm);\n \t\terror = madvise_set_anon_name(mm, addr, size, anon_name);\n \t\tmmap_write_unlock(mm);\n-\t\tanon_vma_name_put(anon_name);\n+\t\tif (error)\n+\t\t\tanon_vma_name_put(anon_name);\n \t\tbreak;\n \tdefault:\n \t\terror = -EINVAL;\n",
            "diff --git a/kernel/sys.c b/kernel/sys.c\nindex 5fd54bf0e886..5bd9b2428165 100644\n--- a/kernel/sys.c\n+++ b/kernel/sys.c\n@@ -2331,7 +2331,10 @@ static int prctl_set_vma(unsigned long opt, unsigned long addr,\n \t\tmmap_write_lock(mm);\n \t\terror = madvise_set_anon_name(mm, addr, size, anon_name);\n \t\tmmap_write_unlock(mm);\n-\t\tanon_vma_name_put(anon_name);\n+\t\tif (error)\n+\t\t\tanon_vma_name_put(anon_name);\n+\t\telse\n+\t\t\tanon_vma_name_put(anon_name);\n \t\tbreak;\n \tdefault:\n \t\terror = -EINVAL;\n",
            "diff --git a/kernel/sys.c b/kernel/sys.c\nindex 5fd54bf0e886..5bd9b2428165 100644\n--- a/kernel/sys.c\n+++ b/kernel/sys.c\n@@ -2331,7 +2331,10 @@ static int prctl_set_vma(unsigned long opt, unsigned long addr,\n \t\tmmap_write_lock(mm);\n \t\terror = madvise_set_anon_name(mm, addr, size, anon_name);\n \t\tmmap_write_unlock(mm);\n-\t\tanon_vma_name_put(anon_name);\n+\t\tif (error)\n+\t\t\tanon_vma_name_put(anon_name);\n+\t\telse\n+\t\t\tanon_vma_name_put(anon_name);\n \t\tbreak;\n \tdefault:\n \t\terror = -EINVAL;\n"
        ],
        "error": []
    },
    "4157935be2e32fae6b62aa95bb0a08b07160b986": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ntfs3/fsntfs.c b/fs/ntfs3/fsntfs.c\nindex 3de5700a9b83..7cb5624f2efe 100644\n--- a/fs/ntfs3/fsntfs.c\n+++ b/fs/ntfs3/fsntfs.c\n@@ -863,7 +863,14 @@ int ntfs_update_mftmirr(struct ntfs_sb_info *sbi, int wait)\n \t\t\t__wait_on_buffer(bh2);\n \n \t\tlock_buffer(bh2);\n-\t\tmemcpy(bh2->b_data, bh1->b_data, blocksize);\n+\t\tif (bh1->b_data && bh2->b_data) {\n+\t\t\tmemcpy(bh2->b_data, bh1->b_data, blocksize);\n+\t\t} else {\n+\t\t\terr = -EIO;\n+\t\t\tput_bh(bh1);\n+\t\t\tput_bh(bh2);\n+\t\t\tgoto out;\n+\t\t}\n \t\tset_buffer_uptodate(bh2);\n \t\tmark_buffer_dirty(bh2);\n \t\tunlock_buffer(bh2);\n",
            "diff --git a/fs/ntfs3/fsntfs.c b/fs/ntfs3/fsntfs.c\nindex 3de5700a9b83..1d45739e127d 100644\n--- a/fs/ntfs3/fsntfs.c\n+++ b/fs/ntfs3/fsntfs.c\n@@ -863,7 +863,13 @@ int ntfs_update_mftmirr(struct ntfs_sb_info *sbi, int wait)\n \t\t\t__wait_on_buffer(bh2);\n \n \t\tlock_buffer(bh2);\n-\t\tmemcpy(bh2->b_data, bh1->b_data, blocksize);\n+\t\tif (bh1) {\n+\t\t\tmemcpy(bh2->b_data, bh1->b_data, blocksize);\n+\t\t} else {\n+\t\t\terr = -EIO;\n+\t\t\tput_bh(bh2);\n+\t\t\tgoto out;\n+\t\t}\n \t\tset_buffer_uptodate(bh2);\n \t\tmark_buffer_dirty(bh2);\n \t\tunlock_buffer(bh2);\n",
            "diff --git a/fs/ntfs3/fsntfs.c b/fs/ntfs3/fsntfs.c\nindex 3de5700a9b83..29825df260ce 100644\n--- a/fs/ntfs3/fsntfs.c\n+++ b/fs/ntfs3/fsntfs.c\n@@ -863,20 +863,29 @@ int ntfs_update_mftmirr(struct ntfs_sb_info *sbi, int wait)\n \t\t\t__wait_on_buffer(bh2);\n \n \t\tlock_buffer(bh2);\n-\t\tmemcpy(bh2->b_data, bh1->b_data, blocksize);\n-\t\tset_buffer_uptodate(bh2);\n-\t\tmark_buffer_dirty(bh2);\n-\t\tunlock_buffer(bh2);\n+\t\tif (bh1 && bh2) {\n+\t\t\tmemcpy(bh2->b_data, bh1->b_data, blocksize);\n+\t\t\tset_buffer_uptodate(bh2);\n+\t\t\tmark_buffer_dirty(bh2);\n+\t\t\tunlock_buffer(bh2);\n \n-\t\tput_bh(bh1);\n-\t\tbh1 = NULL;\n+\t\t\tput_bh(bh1);\n+\t\t\tbh1 = NULL;\n \n-\t\tif (wait)\n-\t\t\terr = sync_dirty_buffer(bh2);\n+\t\t\tif (wait)\n+\t\t\t\terr = sync_dirty_buffer(bh2);\n \n-\t\tput_bh(bh2);\n-\t\tif (err)\n+\t\t\tput_bh(bh2);\n+\t\t\tif (err)\n+\t\t\t\tgoto out;\n+\t\t} else {\n+\t\t\tif (bh1)\n+\t\t\t\tput_bh(bh1);\n+\t\t\tif (bh2)\n+\t\t\t\tput_bh(bh2);\n+\t\t\terr = -EIO;\n \t\t\tgoto out;\n+\t\t}\n \t}\n \n \tsbi->flags &= ~NTFS_FLAGS_MFTMIRR;\n",
            "diff --git a/fs/ntfs3/fsntfs.c b/fs/ntfs3/fsntfs.c\nindex 3de5700a9b83..b01e8269a50c 100644\n--- a/fs/ntfs3/fsntfs.c\n+++ b/fs/ntfs3/fsntfs.c\n@@ -863,7 +863,14 @@ int ntfs_update_mftmirr(struct ntfs_sb_info *sbi, int wait)\n \t\t\t__wait_on_buffer(bh2);\n \n \t\tlock_buffer(bh2);\n-\t\tmemcpy(bh2->b_data, bh1->b_data, blocksize);\n+\t\tif (bh1->b_data) {\n+\t\t\tmemcpy(bh2->b_data, bh1->b_data, blocksize);\n+\t\t} else {\n+\t\t\terr = -EIO;\n+\t\t\tput_bh(bh1);\n+\t\t\tput_bh(bh2);\n+\t\t\tgoto out;\n+\t\t}\n \t\tset_buffer_uptodate(bh2);\n \t\tmark_buffer_dirty(bh2);\n \t\tunlock_buffer(bh2);\n",
            "diff --git a/fs/ntfs3/fsntfs.c b/fs/ntfs3/fsntfs.c\nindex 3de5700a9b83..c5f341312578 100644\n--- a/fs/ntfs3/fsntfs.c\n+++ b/fs/ntfs3/fsntfs.c\n@@ -863,7 +863,16 @@ int ntfs_update_mftmirr(struct ntfs_sb_info *sbi, int wait)\n \t\t\t__wait_on_buffer(bh2);\n \n \t\tlock_buffer(bh2);\n-\t\tmemcpy(bh2->b_data, bh1->b_data, blocksize);\n+\t\tif (bh1 && bh2) {\n+\t\t\tmemcpy(bh2->b_data, bh1->b_data, blocksize);\n+\t\t} else {\n+\t\t\tif (bh1)\n+\t\t\t\tput_bh(bh1);\n+\t\t\tif (bh2)\n+\t\t\t\tput_bh(bh2);\n+\t\t\terr = -EIO;\n+\t\t\tgoto out;\n+\t\t}\n \t\tset_buffer_uptodate(bh2);\n \t\tmark_buffer_dirty(bh2);\n \t\tunlock_buffer(bh2);\n"
        ],
        "error": []
    },
    "731e35eeed762019e385baa96953d9ec8eb63c10": {
        "non_crash": [
            "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex d3dfc51a43c5..a0c51f2b6054 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -65,6 +65,14 @@ static int get_max_inline_xattr_value_size(struct inode *inode,\n \t\t\tif (offs < min_offs)\n \t\t\t\tmin_offs = offs;\n \t\t}\n+\t\tif ((void *)entry >= (void *)raw_inode + iloc->bh->b_size) {\n+\t\t\tprintk(KERN_ERR \"ext4: xattr entry out of bounds\\n\");\n+\t\t\treturn -EFSCORRUPTED;\n+\t\t}\n+\t}\n+\tif (min_offs < ((void *)entry - (void *)IFIRST(header)) + sizeof(__u32)) {\n+\t\tprintk(KERN_ERR \"ext4: min_offs calculation error\\n\");\n+\t\treturn -EFSCORRUPTED;\n \t}\n \tfree = min_offs -\n \t\t((void *)entry - (void *)IFIRST(header)) - sizeof(__u32);\n",
            "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex d3dfc51a43c5..467c5ac05d7b 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -59,7 +59,7 @@ static int get_max_inline_xattr_value_size(struct inode *inode,\n \tentry = IFIRST(header);\n \n \t/* Compute min_offs. */\n-\tfor (; !IS_LAST_ENTRY(entry); entry = EXT4_XATTR_NEXT(entry)) {\n+\tfor (; !IS_LAST_ENTRY(entry) && (void *)entry < (void *)raw_inode + iloc->bh->b_size; entry = EXT4_XATTR_NEXT(entry)) {\n \t\tif (!entry->e_value_inum && entry->e_value_size) {\n \t\t\tsize_t offs = le16_to_cpu(entry->e_value_offs);\n \t\t\tif (offs < min_offs)\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex d3dfc51a43c5..4203f4aaf7fb 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -66,6 +66,10 @@ static int get_max_inline_xattr_value_size(struct inode *inode,\n \t\t\t\tmin_offs = offs;\n \t\t}\n \t}\n+\tif ((void *)entry > (void *)raw_inode + iloc->bh->b_size) {\n+\t\tpr_err(\"ext4: entry out of bounds\\n\");\n+\t\treturn -EIO;\n+\t}\n \tfree = min_offs -\n \t\t((void *)entry - (void *)IFIRST(header)) - sizeof(__u32);\n \n",
            "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex d3dfc51a43c5..a6f278049dbf 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -62,12 +62,16 @@ static int get_max_inline_xattr_value_size(struct inode *inode,\n \tfor (; !IS_LAST_ENTRY(entry); entry = EXT4_XATTR_NEXT(entry)) {\n \t\tif (!entry->e_value_inum && entry->e_value_size) {\n \t\t\tsize_t offs = le16_to_cpu(entry->e_value_offs);\n-\t\t\tif (offs < min_offs)\n+\t\t\tif (offs < min_offs && offs >= sizeof(struct ext4_xattr_entry))\n \t\t\t\tmin_offs = offs;\n \t\t}\n \t}\n-\tfree = min_offs -\n-\t\t((void *)entry - (void *)IFIRST(header)) - sizeof(__u32);\n+\tif ((void *)entry > (void *)IFIRST(header)) {\n+\t\tfree = min_offs -\n+\t\t\t((void *)entry - (void *)IFIRST(header)) - sizeof(__u32);\n+\t} else {\n+\t\tfree = 0;\n+\t}\n \n \tif (EXT4_I(inode)->i_inline_off) {\n \t\tentry = (struct ext4_xattr_entry *)\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex d3dfc51a43c5..29c140f33521 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -65,6 +65,11 @@ static int get_max_inline_xattr_value_size(struct inode *inode,\n \t\t\tif (offs < min_offs)\n \t\t\t\tmin_offs = offs;\n \t\t}\n+\t\t// Ensure offs is within bounds\n+\t\tif ((void *)entry + le16_to_cpu(entry->e_value_offs) + entry->e_value_size > (void *)raw_inode + iloc->inode_size) {\n+\t\t\tpr_err(\"ext4: xattr entry exceeds inode size\\n\");\n+\t\t\treturn -EFSCORRUPTED;\n+\t\t}\n \t}\n \tfree = min_offs -\n \t\t((void *)entry - (void *)IFIRST(header)) - sizeof(__u32);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "6bb7224cd01f8742533b486573005f65d512fdf6": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/sctp/stream.c b/net/sctp/stream.c\nindex ef9fceadef8d..8b67f539f4c7 100644\n--- a/net/sctp/stream.c\n+++ b/net/sctp/stream.c\n@@ -175,8 +175,12 @@ void sctp_stream_free(struct sctp_stream *stream)\n \tint i;\n \n \tsched->free(stream);\n-\tfor (i = 0; i < stream->outcnt; i++)\n-\t\tkfree(SCTP_SO(stream, i)->ext);\n+\tfor (i = 0; i < stream->outcnt; i++) {\n+\t\tif (SCTP_SO(stream, i)->ext) {\n+\t\t\tkfree(SCTP_SO(stream, i)->ext->prio_head);\n+\t\t\tkfree(SCTP_SO(stream, i)->ext);\n+\t\t}\n+\t}\n \tgenradix_free(&stream->out);\n \tgenradix_free(&stream->in);\n }\ndiff --git a/net/sctp/stream_sched_prio.c b/net/sctp/stream_sched_prio.c\nindex 80b5a2c4cbc7..1c253f4732de 100644\n--- a/net/sctp/stream_sched_prio.c\n+++ b/net/sctp/stream_sched_prio.c\n@@ -178,7 +178,8 @@ static int sctp_sched_prio_set(struct sctp_stream *stream, __u16 sid,\n \t}\n \n \t/* No hits, we are good to free it. */\n-\tkfree(old);\n+\tif (old)\n+\t\tkfree(old);\n \n \treturn 0;\n }\n",
            "diff --git a/net/sctp/stream_sched_prio.c b/net/sctp/stream_sched_prio.c\nindex 80b5a2c4cbc7..1c253f4732de 100644\n--- a/net/sctp/stream_sched_prio.c\n+++ b/net/sctp/stream_sched_prio.c\n@@ -178,7 +178,8 @@ static int sctp_sched_prio_set(struct sctp_stream *stream, __u16 sid,\n \t}\n \n \t/* No hits, we are good to free it. */\n-\tkfree(old);\n+\tif (old)\n+\t\tkfree(old);\n \n \treturn 0;\n }\n",
            "diff --git a/net/sctp/stream_sched_prio.c b/net/sctp/stream_sched_prio.c\nindex 80b5a2c4cbc7..1c253f4732de 100644\n--- a/net/sctp/stream_sched_prio.c\n+++ b/net/sctp/stream_sched_prio.c\n@@ -178,7 +178,8 @@ static int sctp_sched_prio_set(struct sctp_stream *stream, __u16 sid,\n \t}\n \n \t/* No hits, we are good to free it. */\n-\tkfree(old);\n+\tif (old)\n+\t\tkfree(old);\n \n \treturn 0;\n }\n",
            "diff --git a/net/sctp/stream_sched_prio.c b/net/sctp/stream_sched_prio.c\nindex 80b5a2c4cbc7..3311c08119d7 100644\n--- a/net/sctp/stream_sched_prio.c\n+++ b/net/sctp/stream_sched_prio.c\n@@ -172,13 +172,16 @@ static int sctp_sched_prio_set(struct sctp_stream *stream, __u16 sid,\n \n \tfor (i = 0; i < stream->outcnt; i++) {\n \t\tsoute = SCTP_SO(stream, i)->ext;\n-\t\tif (soute && soute->prio_head == old)\n+\t\tif (soute && soute->prio_head == old) {\n \t\t\t/* It's still in use, nothing else to do here. */\n \t\t\treturn 0;\n+\t\t}\n \t}\n \n \t/* No hits, we are good to free it. */\n-\tkfree(old);\n+\tif (old) {\n+\t\tkfree(old);\n+\t}\n \n \treturn 0;\n }\n",
            "diff --git a/net/sctp/stream_sched_prio.c b/net/sctp/stream_sched_prio.c\nindex 80b5a2c4cbc7..1e1b50aa49d6 100644\n--- a/net/sctp/stream_sched_prio.c\n+++ b/net/sctp/stream_sched_prio.c\n@@ -172,14 +172,23 @@ static int sctp_sched_prio_set(struct sctp_stream *stream, __u16 sid,\n \n \tfor (i = 0; i < stream->outcnt; i++) {\n \t\tsoute = SCTP_SO(stream, i)->ext;\n-\t\tif (soute && soute->prio_head == old)\n+\t\tif (soute && soute->prio_head == old) {\n \t\t\t/* It's still in use, nothing else to do here. */\n \t\t\treturn 0;\n+\t\t}\n \t}\n \n \t/* No hits, we are good to free it. */\n \tkfree(old);\n \n+\t/* Ensure all references are cleared */\n+\tfor (i = 0; i < stream->outcnt; i++) {\n+\t\tsoute = SCTP_SO(stream, i)->ext;\n+\t\tif (soute && soute->prio_head == old) {\n+\t\t\tsoute->prio_head = NULL;\n+\t\t}\n+\t}\n+\n \treturn 0;\n }\n \n"
        ],
        "error": []
    },
    "fe36c362e30b849dad0ab99e2d1f09b82fc72883": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/sched/act_pedit.c b/net/sched/act_pedit.c\nindex fb93d4c1faca..ba38129df309 100644\n--- a/net/sched/act_pedit.c\n+++ b/net/sched/act_pedit.c\n@@ -245,7 +245,7 @@ static int tcf_pedit_init(struct net *net, struct nlattr *nla,\n \tnparms->tcfp_keys = kmalloc(ksize, GFP_KERNEL);\n \tif (!nparms->tcfp_keys) {\n \t\tret = -ENOMEM;\n-\t\tgoto put_chain;\n+\t\tgoto out_free_ex;\n \t}\n \n \tmemcpy(nparms->tcfp_keys, parm->keys, ksize);\n@@ -258,7 +258,7 @@ static int tcf_pedit_init(struct net *net, struct nlattr *nla,\n \t\tif (!offmask && cur % 4) {\n \t\t\tNL_SET_ERR_MSG_MOD(extack, \"Offsets must be on 32bit boundaries\");\n \t\t\tret = -EINVAL;\n-\t\t\tgoto put_chain;\n+\t\t\tgoto out_free_ex;\n \t\t}\n \n \t\t/* sanitize the shift value for any later use */\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/sched/act_pedit.c b/net/sched/act_pedit.c\nindex fb93d4c1faca..0ad153968e95 100644\n--- a/net/sched/act_pedit.c\n+++ b/net/sched/act_pedit.c\n@@ -229,7 +229,7 @@ static int tcf_pedit_init(struct net *net, struct nlattr *nla,\n \t\ttcf_pedit_keys_ex_parse(tb[TCA_PEDIT_KEYS_EX], parm->nkeys, extack);\n \tif (IS_ERR(nparms->tcfp_keys_ex)) {\n \t\tret = PTR_ERR(nparms->tcfp_keys_ex);\n-\t\tgoto out_free;\n+\t\tgoto out_free_nparms;\n \t}\n \n \terr = tcf_action_check_ctrlact(parm->action, tp, &goto_ch, extack);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/sched/act_pedit.c b/net/sched/act_pedit.c\nindex fb93d4c1faca..0ad153968e95 100644\n--- a/net/sched/act_pedit.c\n+++ b/net/sched/act_pedit.c\n@@ -229,7 +229,7 @@ static int tcf_pedit_init(struct net *net, struct nlattr *nla,\n \t\ttcf_pedit_keys_ex_parse(tb[TCA_PEDIT_KEYS_EX], parm->nkeys, extack);\n \tif (IS_ERR(nparms->tcfp_keys_ex)) {\n \t\tret = PTR_ERR(nparms->tcfp_keys_ex);\n-\t\tgoto out_free;\n+\t\tgoto out_free_nparms;\n \t}\n \n \terr = tcf_action_check_ctrlact(parm->action, tp, &goto_ch, extack);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "0784eb04ffd5b9955880826669badef2ffb32285": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/btrfs/ordered-data.c b/fs/btrfs/ordered-data.c\nindex a629532283bc..6d47cb0d4b6f 100644\n--- a/fs/btrfs/ordered-data.c\n+++ b/fs/btrfs/ordered-data.c\n@@ -372,6 +372,9 @@ bool btrfs_finish_ordered_extent(struct btrfs_ordered_extent *ordered,\n \t\t\t\t struct page *page, u64 file_offset, u64 len,\n \t\t\t\t bool uptodate)\n {\n+\tif (!ordered)\n+\t\treturn false;\n+\n \tstruct btrfs_inode *inode = BTRFS_I(ordered->inode);\n \tunsigned long flags;\n \tbool ret;\n",
            "diff --git a/fs/btrfs/ordered-data.c b/fs/btrfs/ordered-data.c\nindex a629532283bc..6d47cb0d4b6f 100644\n--- a/fs/btrfs/ordered-data.c\n+++ b/fs/btrfs/ordered-data.c\n@@ -372,6 +372,9 @@ bool btrfs_finish_ordered_extent(struct btrfs_ordered_extent *ordered,\n \t\t\t\t struct page *page, u64 file_offset, u64 len,\n \t\t\t\t bool uptodate)\n {\n+\tif (!ordered)\n+\t\treturn false;\n+\n \tstruct btrfs_inode *inode = BTRFS_I(ordered->inode);\n \tunsigned long flags;\n \tbool ret;\n",
            "diff --git a/fs/btrfs/ordered-data.c b/fs/btrfs/ordered-data.c\nindex a629532283bc..6d47cb0d4b6f 100644\n--- a/fs/btrfs/ordered-data.c\n+++ b/fs/btrfs/ordered-data.c\n@@ -372,6 +372,9 @@ bool btrfs_finish_ordered_extent(struct btrfs_ordered_extent *ordered,\n \t\t\t\t struct page *page, u64 file_offset, u64 len,\n \t\t\t\t bool uptodate)\n {\n+\tif (!ordered)\n+\t\treturn false;\n+\n \tstruct btrfs_inode *inode = BTRFS_I(ordered->inode);\n \tunsigned long flags;\n \tbool ret;\n",
            "diff --git a/fs/btrfs/ordered-data.c b/fs/btrfs/ordered-data.c\nindex a629532283bc..6d47cb0d4b6f 100644\n--- a/fs/btrfs/ordered-data.c\n+++ b/fs/btrfs/ordered-data.c\n@@ -372,6 +372,9 @@ bool btrfs_finish_ordered_extent(struct btrfs_ordered_extent *ordered,\n \t\t\t\t struct page *page, u64 file_offset, u64 len,\n \t\t\t\t bool uptodate)\n {\n+\tif (!ordered)\n+\t\treturn false;\n+\n \tstruct btrfs_inode *inode = BTRFS_I(ordered->inode);\n \tunsigned long flags;\n \tbool ret;\n",
            "diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c\nindex 1f58debb9a04..eac472d3ee87 100644\n--- a/fs/btrfs/inode.c\n+++ b/fs/btrfs/inode.c\n@@ -7831,9 +7831,16 @@ static void btrfs_dio_end_io(struct btrfs_bio *bbio)\n \t}\n \n \tif (btrfs_op(bio) == BTRFS_MAP_WRITE) {\n-\t\tbtrfs_finish_ordered_extent(bbio->ordered, NULL,\n-\t\t\t\t\t    dip->file_offset, dip->bytes,\n-\t\t\t\t\t    !bio->bi_status);\n+\t\tif (bbio->ordered) {\n+\t\t\tbtrfs_finish_ordered_extent(bbio->ordered, NULL,\n+\t\t\t\t\t\t    dip->file_offset, dip->bytes,\n+\t\t\t\t\t\t    !bio->bi_status);\n+\t\t} else {\n+\t\t\tbtrfs_warn(inode->root->fs_info,\n+\t\t\t\"ordered extent is NULL ino %llu op 0x%0x offset %#llx len %u\",\n+\t\t\t\t   btrfs_ino(inode), bio->bi_opf,\n+\t\t\t\t   dip->file_offset, dip->bytes);\n+\t\t}\n \t} else {\n \t\tunlock_extent(&inode->io_tree, dip->file_offset,\n \t\t\t      dip->file_offset + dip->bytes - 1, NULL);\n"
        ],
        "error": []
    },
    "544afab64e441605326c54f7c2d4aa9bab2419ff": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netrom/af_netrom.c b/net/netrom/af_netrom.c\nindex 6f7f4392cffb..cea69ee2d624 100644\n--- a/net/netrom/af_netrom.c\n+++ b/net/netrom/af_netrom.c\n@@ -434,6 +434,11 @@ static int nr_create(struct net *net, struct socket *sock, int protocol,\n \tif (sk  == NULL)\n \t\treturn -ENOMEM;\n \n+\tif (security_sk_alloc(sk, PF_NETROM, GFP_ATOMIC)) {\n+\t\tsk_free(sk);\n+\t\treturn -ENOMEM;\n+\t}\n+\n \tnr = nr_sk(sk);\n \n \tsock_init_data(sock, sk);\n",
            "diff --git a/net/netrom/af_netrom.c b/net/netrom/af_netrom.c\nindex 6f7f4392cffb..e2200aced874 100644\n--- a/net/netrom/af_netrom.c\n+++ b/net/netrom/af_netrom.c\n@@ -431,14 +431,19 @@ static int nr_create(struct net *net, struct socket *sock, int protocol,\n \t\treturn -ESOCKTNOSUPPORT;\n \n \tsk = sk_alloc(net, PF_NETROM, GFP_ATOMIC, &nr_proto, kern);\n-\tif (sk  == NULL)\n+\tif (sk == NULL)\n \t\treturn -ENOMEM;\n \n \tnr = nr_sk(sk);\n \n+\tif (!nr) {\n+\t\tsock_put(sk);\n+\t\treturn -ENOMEM;\n+\t}\n+\n \tsock_init_data(sock, sk);\n \n-\tsock->ops    = &nr_proto_ops;\n+\tsock->ops = &nr_proto_ops;\n \tsk->sk_protocol = protocol;\n \n \tskb_queue_head_init(&nr->ack_queue);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/core/sock.c b/net/core/sock.c\nindex f954d5893e79..8489e75f82e3 100644\n--- a/net/core/sock.c\n+++ b/net/core/sock.c\n@@ -2038,11 +2038,16 @@ static struct sock *sk_prot_alloc(struct proto *prot, gfp_t priority,\n \t\tsk = kmalloc(prot->obj_size, priority);\n \n \tif (sk != NULL) {\n-\t\tif (security_sk_alloc(sk, family, priority))\n-\t\t\tgoto out_free;\n+\t\tif (security_sk_alloc(sk, family, priority)) {\n+\t\t\tsk_free(sk);\n+\t\t\treturn NULL;\n+\t\t}\n \n-\t\tif (!try_module_get(prot->owner))\n-\t\t\tgoto out_free_sec;\n+\t\tif (!try_module_get(prot->owner)) {\n+\t\t\tsecurity_sk_free(sk);\n+\t\t\tsk_free(sk);\n+\t\t\treturn NULL;\n+\t\t}\n \t}\n \n \treturn sk;\ndiff --git a/net/netrom/af_netrom.c b/net/netrom/af_netrom.c\nindex 6f7f4392cffb..b2946ded5428 100644\n--- a/net/netrom/af_netrom.c\n+++ b/net/netrom/af_netrom.c\n@@ -431,14 +431,17 @@ static int nr_create(struct net *net, struct socket *sock, int protocol,\n \t\treturn -ESOCKTNOSUPPORT;\n \n \tsk = sk_alloc(net, PF_NETROM, GFP_ATOMIC, &nr_proto, kern);\n-\tif (sk  == NULL)\n+\tif (sk == NULL)\n \t\treturn -ENOMEM;\n \n \tnr = nr_sk(sk);\n \n-\tsock_init_data(sock, sk);\n+\tif (sock_init_data(sock, sk)) {\n+\t\tsk_free(sk);\n+\t\treturn -EINVAL;\n+\t}\n \n-\tsock->ops    = &nr_proto_ops;\n+\tsock->ops = &nr_proto_ops;\n \tsk->sk_protocol = protocol;\n \n \tskb_queue_head_init(&nr->ack_queue);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/core/sock.c b/net/core/sock.c\nindex f954d5893e79..9332e901f547 100644\n--- a/net/core/sock.c\n+++ b/net/core/sock.c\n@@ -2039,10 +2039,14 @@ static struct sock *sk_prot_alloc(struct proto *prot, gfp_t priority,\n \n \tif (sk != NULL) {\n \t\tif (security_sk_alloc(sk, family, priority))\n-\t\t\tgoto out_free;\n+\t\t\tgoto out_free_sk;\n \n \t\tif (!try_module_get(prot->owner))\n \t\t\tgoto out_free_sec;\n+\n+out_free_sk:\n+\t\tkmem_cache_free(slab, sk);\n+\t\treturn NULL;\n \t}\n \n \treturn sk;\n",
                "error_message": "Failed to set up instance"
            },
            {
                "patch": "diff --git a/net/netrom/af_netrom.c b/net/netrom/af_netrom.c\nindex 6f7f4392cffb..fd7a66595ede 100644\n--- a/net/netrom/af_netrom.c\n+++ b/net/netrom/af_netrom.c\n@@ -443,6 +443,13 @@ static int nr_create(struct net *net, struct socket *sock, int protocol,\n \n \tskb_queue_head_init(&nr->ack_queue);\n \tskb_queue_head_init(&nr->reseq_queue);\n+\n+\t// Ensure cleanup on error\n+\tif (some_error_condition) {\n+\t\tsock_orphan(sk);\n+\t\tsock_put(sk);\n+\t\treturn -EINVAL;\n+\t}\n \tskb_queue_head_init(&nr->frag_queue);\n \n \tnr_init_timers(sk);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "032c91d1b0189a2a36f47141f9c3331f8c09d7b1": {
        "non_crash": [
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 816052089b33..207c070008ab 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -1877,7 +1877,8 @@ void nf_tables_chain_destroy(struct nft_ctx *ctx)\n \t\t}\n \t\tmodule_put(basechain->type->owner);\n \t\tif (rcu_access_pointer(basechain->stats)) {\n-\t\t\tstatic_branch_dec(&nft_counters_enabled);\n+\t\t\tif (static_key_enabled(&nft_counters_enabled))\n+\t\t\t\tstatic_branch_dec(&nft_counters_enabled);\n \t\t\tfree_percpu(rcu_dereference_raw(basechain->stats));\n \t\t}\n \t\tkfree(chain->name);\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 816052089b33..532a73936929 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -1879,6 +1879,8 @@ void nf_tables_chain_destroy(struct nft_ctx *ctx)\n \t\tif (rcu_access_pointer(basechain->stats)) {\n \t\t\tstatic_branch_dec(&nft_counters_enabled);\n \t\t\tfree_percpu(rcu_dereference_raw(basechain->stats));\n+\t\t} else {\n+\t\t\tstatic_branch_inc(&nft_counters_enabled);\n \t\t}\n \t\tkfree(chain->name);\n \t\tkfree(chain->udata);\n"
        ],
        "error": []
    },
    "80b047eb9aff0254f4adc620c6891c0ca3276309": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/tipc/node.c b/net/tipc/node.c\nindex a4c2816c3746..3ebdb8b6bb58 100644\n--- a/net/tipc/node.c\n+++ b/net/tipc/node.c\n@@ -234,8 +234,8 @@ bool tipc_node_get_id(struct net *net, u32 addr, u8 *id)\n \tif (!n)\n \t\treturn false;\n \n-\tmemcpy(id, &n->peer_id, TIPC_NODEID_LEN);\n \ttipc_node_put(n);\n+\tmemcpy(id, &n->peer_id, TIPC_NODEID_LEN);\n \treturn true;\n }\n \n",
            "diff --git a/net/tipc/node.c b/net/tipc/node.c\nindex a4c2816c3746..817eb15e2f35 100644\n--- a/net/tipc/node.c\n+++ b/net/tipc/node.c\n@@ -2618,10 +2618,9 @@ int tipc_nl_node_dump_link(struct sk_buff *skb, struct netlink_callback *cb)\n \t\t\tcb->prev_seq = 1;\n \t\t\tgoto out;\n \t\t}\n-\t\ttipc_node_put(node);\n-\n \t\tlist_for_each_entry_continue_rcu(node, &tn->node_list,\n \t\t\t\t\t\t list) {\n+\t\t\ttipc_node_put(node);\n \t\t\ttipc_node_read_lock(node);\n \t\t\terr = __tipc_nl_add_node_links(net, &msg, node,\n \t\t\t\t\t\t       &prev_link, bc_link);\n",
            "diff --git a/net/tipc/node.c b/net/tipc/node.c\nindex a4c2816c3746..3ebdb8b6bb58 100644\n--- a/net/tipc/node.c\n+++ b/net/tipc/node.c\n@@ -234,8 +234,8 @@ bool tipc_node_get_id(struct net *net, u32 addr, u8 *id)\n \tif (!n)\n \t\treturn false;\n \n-\tmemcpy(id, &n->peer_id, TIPC_NODEID_LEN);\n \ttipc_node_put(n);\n+\tmemcpy(id, &n->peer_id, TIPC_NODEID_LEN);\n \treturn true;\n }\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/tipc/node.c b/net/tipc/node.c\nindex a4c2816c3746..2644e54998cb 100644\n--- a/net/tipc/node.c\n+++ b/net/tipc/node.c\n@@ -234,7 +234,9 @@ bool tipc_node_get_id(struct net *net, u32 addr, u8 *id)\n \tif (!n)\n \t\treturn false;\n \n+\ttipc_node_read_lock(n);\n \tmemcpy(id, &n->peer_id, TIPC_NODEID_LEN);\n+\ttipc_node_read_unlock(n);\n \ttipc_node_put(n);\n \treturn true;\n }\n@@ -247,7 +249,9 @@ u16 tipc_node_get_capabilities(struct net *net, u32 addr)\n \tn = tipc_node_find(net, addr);\n \tif (unlikely(!n))\n \t\treturn TIPC_NODE_CAPABILITIES;\n+\ttipc_node_read_lock(n);\n \tcaps = n->capabilities;\n+\ttipc_node_read_unlock(n);\n \ttipc_node_put(n);\n \treturn caps;\n }\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/tipc/node.c b/net/tipc/node.c\nindex a4c2816c3746..2644e54998cb 100644\n--- a/net/tipc/node.c\n+++ b/net/tipc/node.c\n@@ -234,7 +234,9 @@ bool tipc_node_get_id(struct net *net, u32 addr, u8 *id)\n \tif (!n)\n \t\treturn false;\n \n+\ttipc_node_read_lock(n);\n \tmemcpy(id, &n->peer_id, TIPC_NODEID_LEN);\n+\ttipc_node_read_unlock(n);\n \ttipc_node_put(n);\n \treturn true;\n }\n@@ -247,7 +249,9 @@ u16 tipc_node_get_capabilities(struct net *net, u32 addr)\n \tn = tipc_node_find(net, addr);\n \tif (unlikely(!n))\n \t\treturn TIPC_NODE_CAPABILITIES;\n+\ttipc_node_read_lock(n);\n \tcaps = n->capabilities;\n+\ttipc_node_read_unlock(n);\n \ttipc_node_put(n);\n \treturn caps;\n }\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "ca2299cf11b3e3d3d0f44ac479410a14eecbd326": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/qrtr/qrtr.c b/net/qrtr/qrtr.c\nindex b4c0db0b7d31..47d8c4655f98 100644\n--- a/net/qrtr/qrtr.c\n+++ b/net/qrtr/qrtr.c\n@@ -698,15 +698,15 @@ static int qrtr_port_assign(struct qrtr_sock *ipc, int *port)\n \tif (!*port) {\n \t\trc = idr_alloc(&qrtr_ports, ipc,\n \t\t\t       QRTR_MIN_EPH_SOCKET, QRTR_MAX_EPH_SOCKET + 1,\n-\t\t\t       GFP_ATOMIC);\n+\t\t\t       GFP_KERNEL);\n \t\tif (rc >= 0)\n \t\t\t*port = rc;\n \t} else if (*port < QRTR_MIN_EPH_SOCKET && !capable(CAP_NET_ADMIN)) {\n \t\trc = -EACCES;\n \t} else if (*port == QRTR_PORT_CTRL) {\n-\t\trc = idr_alloc(&qrtr_ports, ipc, 0, 1, GFP_ATOMIC);\n+\t\trc = idr_alloc(&qrtr_ports, ipc, 0, 1, GFP_KERNEL);\n \t} else {\n-\t\trc = idr_alloc(&qrtr_ports, ipc, *port, *port + 1, GFP_ATOMIC);\n+\t\trc = idr_alloc(&qrtr_ports, ipc, *port, *port + 1, GFP_KERNEL);\n \t\tif (rc >= 0)\n \t\t\t*port = rc;\n \t}\n",
            "diff --git a/net/qrtr/qrtr.c b/net/qrtr/qrtr.c\nindex b4c0db0b7d31..5e6df17f392e 100644\n--- a/net/qrtr/qrtr.c\n+++ b/net/qrtr/qrtr.c\n@@ -698,7 +698,7 @@ static int qrtr_port_assign(struct qrtr_sock *ipc, int *port)\n \tif (!*port) {\n \t\trc = idr_alloc(&qrtr_ports, ipc,\n \t\t\t       QRTR_MIN_EPH_SOCKET, QRTR_MAX_EPH_SOCKET + 1,\n-\t\t\t       GFP_ATOMIC);\n+\t\t\t       GFP_KERNEL);\n \t\tif (rc >= 0)\n \t\t\t*port = rc;\n \t} else if (*port < QRTR_MIN_EPH_SOCKET && !capable(CAP_NET_ADMIN)) {\n",
            "diff --git a/net/qrtr/qrtr.c b/net/qrtr/qrtr.c\nindex b4c0db0b7d31..5e6df17f392e 100644\n--- a/net/qrtr/qrtr.c\n+++ b/net/qrtr/qrtr.c\n@@ -698,7 +698,7 @@ static int qrtr_port_assign(struct qrtr_sock *ipc, int *port)\n \tif (!*port) {\n \t\trc = idr_alloc(&qrtr_ports, ipc,\n \t\t\t       QRTR_MIN_EPH_SOCKET, QRTR_MAX_EPH_SOCKET + 1,\n-\t\t\t       GFP_ATOMIC);\n+\t\t\t       GFP_KERNEL);\n \t\tif (rc >= 0)\n \t\t\t*port = rc;\n \t} else if (*port < QRTR_MIN_EPH_SOCKET && !capable(CAP_NET_ADMIN)) {\n",
            "diff --git a/net/qrtr/qrtr.c b/net/qrtr/qrtr.c\nindex b4c0db0b7d31..47d8c4655f98 100644\n--- a/net/qrtr/qrtr.c\n+++ b/net/qrtr/qrtr.c\n@@ -698,15 +698,15 @@ static int qrtr_port_assign(struct qrtr_sock *ipc, int *port)\n \tif (!*port) {\n \t\trc = idr_alloc(&qrtr_ports, ipc,\n \t\t\t       QRTR_MIN_EPH_SOCKET, QRTR_MAX_EPH_SOCKET + 1,\n-\t\t\t       GFP_ATOMIC);\n+\t\t\t       GFP_KERNEL);\n \t\tif (rc >= 0)\n \t\t\t*port = rc;\n \t} else if (*port < QRTR_MIN_EPH_SOCKET && !capable(CAP_NET_ADMIN)) {\n \t\trc = -EACCES;\n \t} else if (*port == QRTR_PORT_CTRL) {\n-\t\trc = idr_alloc(&qrtr_ports, ipc, 0, 1, GFP_ATOMIC);\n+\t\trc = idr_alloc(&qrtr_ports, ipc, 0, 1, GFP_KERNEL);\n \t} else {\n-\t\trc = idr_alloc(&qrtr_ports, ipc, *port, *port + 1, GFP_ATOMIC);\n+\t\trc = idr_alloc(&qrtr_ports, ipc, *port, *port + 1, GFP_KERNEL);\n \t\tif (rc >= 0)\n \t\t\t*port = rc;\n \t}\n",
            "diff --git a/net/qrtr/qrtr.c b/net/qrtr/qrtr.c\nindex b4c0db0b7d31..47d8c4655f98 100644\n--- a/net/qrtr/qrtr.c\n+++ b/net/qrtr/qrtr.c\n@@ -698,15 +698,15 @@ static int qrtr_port_assign(struct qrtr_sock *ipc, int *port)\n \tif (!*port) {\n \t\trc = idr_alloc(&qrtr_ports, ipc,\n \t\t\t       QRTR_MIN_EPH_SOCKET, QRTR_MAX_EPH_SOCKET + 1,\n-\t\t\t       GFP_ATOMIC);\n+\t\t\t       GFP_KERNEL);\n \t\tif (rc >= 0)\n \t\t\t*port = rc;\n \t} else if (*port < QRTR_MIN_EPH_SOCKET && !capable(CAP_NET_ADMIN)) {\n \t\trc = -EACCES;\n \t} else if (*port == QRTR_PORT_CTRL) {\n-\t\trc = idr_alloc(&qrtr_ports, ipc, 0, 1, GFP_ATOMIC);\n+\t\trc = idr_alloc(&qrtr_ports, ipc, 0, 1, GFP_KERNEL);\n \t} else {\n-\t\trc = idr_alloc(&qrtr_ports, ipc, *port, *port + 1, GFP_ATOMIC);\n+\t\trc = idr_alloc(&qrtr_ports, ipc, *port, *port + 1, GFP_KERNEL);\n \t\tif (rc >= 0)\n \t\t\t*port = rc;\n \t}\n"
        ],
        "error": []
    },
    "fea1767458f80cd02b783a4a317e76c229ffddab": {
        "non_crash": [
            "diff --git a/net/netfilter/nf_conntrack_proto_icmp.c b/net/netfilter/nf_conntrack_proto_icmp.c\nindex de64d8a5fdfd..8276c3c808d2 100644\n--- a/net/netfilter/nf_conntrack_proto_icmp.c\n+++ b/net/netfilter/nf_conntrack_proto_icmp.c\n@@ -289,6 +289,9 @@ icmp_timeout_obj_to_nlattr(struct sk_buff *skb, const void *data)\n {\n \tconst unsigned int *timeout = data;\n \n+\tif (!timeout)\n+\t\treturn -EINVAL;\n+\n \tif (nla_put_be32(skb, CTA_TIMEOUT_ICMP_TIMEOUT, htonl(*timeout / HZ)))\n \t\tgoto nla_put_failure;\n \treturn 0;\n",
            "diff --git a/net/netfilter/nf_conntrack_proto_icmp.c b/net/netfilter/nf_conntrack_proto_icmp.c\nindex de64d8a5fdfd..8276c3c808d2 100644\n--- a/net/netfilter/nf_conntrack_proto_icmp.c\n+++ b/net/netfilter/nf_conntrack_proto_icmp.c\n@@ -289,6 +289,9 @@ icmp_timeout_obj_to_nlattr(struct sk_buff *skb, const void *data)\n {\n \tconst unsigned int *timeout = data;\n \n+\tif (!timeout)\n+\t\treturn -EINVAL;\n+\n \tif (nla_put_be32(skb, CTA_TIMEOUT_ICMP_TIMEOUT, htonl(*timeout / HZ)))\n \t\tgoto nla_put_failure;\n \treturn 0;\n",
            "diff --git a/net/netfilter/nf_conntrack_proto_icmp.c b/net/netfilter/nf_conntrack_proto_icmp.c\nindex de64d8a5fdfd..8276c3c808d2 100644\n--- a/net/netfilter/nf_conntrack_proto_icmp.c\n+++ b/net/netfilter/nf_conntrack_proto_icmp.c\n@@ -289,6 +289,9 @@ icmp_timeout_obj_to_nlattr(struct sk_buff *skb, const void *data)\n {\n \tconst unsigned int *timeout = data;\n \n+\tif (!timeout)\n+\t\treturn -EINVAL;\n+\n \tif (nla_put_be32(skb, CTA_TIMEOUT_ICMP_TIMEOUT, htonl(*timeout / HZ)))\n \t\tgoto nla_put_failure;\n \treturn 0;\n",
            "diff --git a/net/netfilter/nf_conntrack_proto_icmp.c b/net/netfilter/nf_conntrack_proto_icmp.c\nindex de64d8a5fdfd..8276c3c808d2 100644\n--- a/net/netfilter/nf_conntrack_proto_icmp.c\n+++ b/net/netfilter/nf_conntrack_proto_icmp.c\n@@ -289,6 +289,9 @@ icmp_timeout_obj_to_nlattr(struct sk_buff *skb, const void *data)\n {\n \tconst unsigned int *timeout = data;\n \n+\tif (!timeout)\n+\t\treturn -EINVAL;\n+\n \tif (nla_put_be32(skb, CTA_TIMEOUT_ICMP_TIMEOUT, htonl(*timeout / HZ)))\n \t\tgoto nla_put_failure;\n \treturn 0;\n",
            "diff --git a/net/netfilter/nf_conntrack_proto_icmp.c b/net/netfilter/nf_conntrack_proto_icmp.c\nindex de64d8a5fdfd..8276c3c808d2 100644\n--- a/net/netfilter/nf_conntrack_proto_icmp.c\n+++ b/net/netfilter/nf_conntrack_proto_icmp.c\n@@ -289,6 +289,9 @@ icmp_timeout_obj_to_nlattr(struct sk_buff *skb, const void *data)\n {\n \tconst unsigned int *timeout = data;\n \n+\tif (!timeout)\n+\t\treturn -EINVAL;\n+\n \tif (nla_put_be32(skb, CTA_TIMEOUT_ICMP_TIMEOUT, htonl(*timeout / HZ)))\n \t\tgoto nla_put_failure;\n \treturn 0;\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "d905b9cf668a6fd23e8268008fff061b302d6fb5": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex afe2b64b14f1..e735b2042d87 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -1230,9 +1230,15 @@ static void mntput_no_expire(struct mount *mnt)\n \t * mount_lock, we'll see their refcount increment here.\n \t */\n \tsmp_mb();\n-\tmnt_add_count(mnt, -1);\n \tcount = mnt_get_count(mnt);\n-\tif (count != 0) {\n+\tif (count > 0) {\n+\t\tmnt_add_count(mnt, -1);\n+\t\tif (mnt_get_count(mnt) != 0) {\n+\t\t\trcu_read_unlock();\n+\t\t\tunlock_mount_hash();\n+\t\t\treturn;\n+\t\t}\n+\t} else {\n \t\tWARN_ON(count < 0);\n \t\trcu_read_unlock();\n \t\tunlock_mount_hash();\n",
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex afe2b64b14f1..9002a6069873 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -1232,8 +1232,13 @@ static void mntput_no_expire(struct mount *mnt)\n \tsmp_mb();\n \tmnt_add_count(mnt, -1);\n \tcount = mnt_get_count(mnt);\n+\tif (count < 0) {\n+\t\tWARN_ON(1);\n+\t\trcu_read_unlock();\n+\t\tunlock_mount_hash();\n+\t\treturn;\n+\t}\n \tif (count != 0) {\n-\t\tWARN_ON(count < 0);\n \t\trcu_read_unlock();\n \t\tunlock_mount_hash();\n \t\treturn;\n",
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex afe2b64b14f1..9002a6069873 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -1232,8 +1232,13 @@ static void mntput_no_expire(struct mount *mnt)\n \tsmp_mb();\n \tmnt_add_count(mnt, -1);\n \tcount = mnt_get_count(mnt);\n+\tif (count < 0) {\n+\t\tWARN_ON(1);\n+\t\trcu_read_unlock();\n+\t\tunlock_mount_hash();\n+\t\treturn;\n+\t}\n \tif (count != 0) {\n-\t\tWARN_ON(count < 0);\n \t\trcu_read_unlock();\n \t\tunlock_mount_hash();\n \t\treturn;\n",
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex afe2b64b14f1..0f420c3f4e82 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -1230,13 +1230,16 @@ static void mntput_no_expire(struct mount *mnt)\n \t * mount_lock, we'll see their refcount increment here.\n \t */\n \tsmp_mb();\n-\tmnt_add_count(mnt, -1);\n \tcount = mnt_get_count(mnt);\n-\tif (count != 0) {\n-\t\tWARN_ON(count < 0);\n-\t\trcu_read_unlock();\n-\t\tunlock_mount_hash();\n-\t\treturn;\n+\tif (count > 0) {\n+\t\tmnt_add_count(mnt, -1);\n+\t\tcount = mnt_get_count(mnt);\n+\t\tif (count != 0) {\n+\t\t\tWARN_ON(count < 0);\n+\t\t\trcu_read_unlock();\n+\t\t\tunlock_mount_hash();\n+\t\t\treturn;\n+\t\t}\n \t}\n \tif (unlikely(mnt->mnt.mnt_flags & MNT_DOOMED)) {\n \t\trcu_read_unlock();\n",
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex afe2b64b14f1..0e3fc4cf83de 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -1232,13 +1232,19 @@ static void mntput_no_expire(struct mount *mnt)\n \tsmp_mb();\n \tmnt_add_count(mnt, -1);\n \tcount = mnt_get_count(mnt);\n+\tif (count < 0) {\n+\t\tWARN_ON(1);\n+\t\trcu_read_unlock();\n+\t\tunlock_mount_hash();\n+\t\treturn;\n+\t}\n \tif (count != 0) {\n-\t\tWARN_ON(count < 0);\n \t\trcu_read_unlock();\n \t\tunlock_mount_hash();\n \t\treturn;\n \t}\n \tif (unlikely(mnt->mnt.mnt_flags & MNT_DOOMED)) {\n+\t\tWARN_ON(mnt_get_count(mnt) != 0);\n \t\trcu_read_unlock();\n \t\tunlock_mount_hash();\n \t\treturn;\n"
        ],
        "error": []
    },
    "766aad2609c9a3742436a3e25518eba8f5c6ddc8": {
        "non_crash": [
            "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 73f419adce61..529d43e5fe1f 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -1944,13 +1944,23 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \t\t}\n \t}\n \n-\trv = usb_control_msg(data->usb_dev,\n-\t\t\tusb_rcvctrlpipe(data->usb_dev, 0),\n-\t\t\trequest.req.bRequest,\n-\t\t\trequest.req.bRequestType,\n-\t\t\trequest.req.wValue,\n-\t\t\trequest.req.wIndex,\n-\t\t\tbuffer, request.req.wLength, USB_CTRL_GET_TIMEOUT);\n+\tif (request.req.bRequestType & USB_DIR_IN) {\n+\t\trv = usb_control_msg(data->usb_dev,\n+\t\t\t\tusb_rcvctrlpipe(data->usb_dev, 0),\n+\t\t\t\trequest.req.bRequest,\n+\t\t\t\trequest.req.bRequestType,\n+\t\t\t\trequest.req.wValue,\n+\t\t\t\trequest.req.wIndex,\n+\t\t\t\tbuffer, request.req.wLength, USB_CTRL_GET_TIMEOUT);\n+\t} else {\n+\t\trv = usb_control_msg(data->usb_dev,\n+\t\t\t\tusb_sndctrlpipe(data->usb_dev, 0),\n+\t\t\t\trequest.req.bRequest,\n+\t\t\t\trequest.req.bRequestType,\n+\t\t\t\trequest.req.wValue,\n+\t\t\t\trequest.req.wIndex,\n+\t\t\t\tbuffer, request.req.wLength, USB_CTRL_GET_TIMEOUT);\n+\t}\n \n \tif (rv < 0) {\n \t\tdev_err(dev, \"%s failed %d\\n\", __func__, rv);\n",
            "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 73f419adce61..529d43e5fe1f 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -1944,13 +1944,23 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \t\t}\n \t}\n \n-\trv = usb_control_msg(data->usb_dev,\n-\t\t\tusb_rcvctrlpipe(data->usb_dev, 0),\n-\t\t\trequest.req.bRequest,\n-\t\t\trequest.req.bRequestType,\n-\t\t\trequest.req.wValue,\n-\t\t\trequest.req.wIndex,\n-\t\t\tbuffer, request.req.wLength, USB_CTRL_GET_TIMEOUT);\n+\tif (request.req.bRequestType & USB_DIR_IN) {\n+\t\trv = usb_control_msg(data->usb_dev,\n+\t\t\t\tusb_rcvctrlpipe(data->usb_dev, 0),\n+\t\t\t\trequest.req.bRequest,\n+\t\t\t\trequest.req.bRequestType,\n+\t\t\t\trequest.req.wValue,\n+\t\t\t\trequest.req.wIndex,\n+\t\t\t\tbuffer, request.req.wLength, USB_CTRL_GET_TIMEOUT);\n+\t} else {\n+\t\trv = usb_control_msg(data->usb_dev,\n+\t\t\t\tusb_sndctrlpipe(data->usb_dev, 0),\n+\t\t\t\trequest.req.bRequest,\n+\t\t\t\trequest.req.bRequestType,\n+\t\t\t\trequest.req.wValue,\n+\t\t\t\trequest.req.wIndex,\n+\t\t\t\tbuffer, request.req.wLength, USB_CTRL_GET_TIMEOUT);\n+\t}\n \n \tif (rv < 0) {\n \t\tdev_err(dev, \"%s failed %d\\n\", __func__, rv);\n",
            "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 73f419adce61..529d43e5fe1f 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -1944,13 +1944,23 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \t\t}\n \t}\n \n-\trv = usb_control_msg(data->usb_dev,\n-\t\t\tusb_rcvctrlpipe(data->usb_dev, 0),\n-\t\t\trequest.req.bRequest,\n-\t\t\trequest.req.bRequestType,\n-\t\t\trequest.req.wValue,\n-\t\t\trequest.req.wIndex,\n-\t\t\tbuffer, request.req.wLength, USB_CTRL_GET_TIMEOUT);\n+\tif (request.req.bRequestType & USB_DIR_IN) {\n+\t\trv = usb_control_msg(data->usb_dev,\n+\t\t\t\tusb_rcvctrlpipe(data->usb_dev, 0),\n+\t\t\t\trequest.req.bRequest,\n+\t\t\t\trequest.req.bRequestType,\n+\t\t\t\trequest.req.wValue,\n+\t\t\t\trequest.req.wIndex,\n+\t\t\t\tbuffer, request.req.wLength, USB_CTRL_GET_TIMEOUT);\n+\t} else {\n+\t\trv = usb_control_msg(data->usb_dev,\n+\t\t\t\tusb_sndctrlpipe(data->usb_dev, 0),\n+\t\t\t\trequest.req.bRequest,\n+\t\t\t\trequest.req.bRequestType,\n+\t\t\t\trequest.req.wValue,\n+\t\t\t\trequest.req.wIndex,\n+\t\t\t\tbuffer, request.req.wLength, USB_CTRL_GET_TIMEOUT);\n+\t}\n \n \tif (rv < 0) {\n \t\tdev_err(dev, \"%s failed %d\\n\", __func__, rv);\n",
            "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 73f419adce61..41dbc513d7c8 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -1945,7 +1945,7 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \t}\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\tusb_rcvctrlpipe(data->usb_dev, 0),\n+\t\t\t(request.req.bRequestType & USB_DIR_IN) ? usb_rcvctrlpipe(data->usb_dev, 0) : usb_sndctrlpipe(data->usb_dev, 0),\n \t\t\trequest.req.bRequest,\n \t\t\trequest.req.bRequestType,\n \t\t\trequest.req.wValue,\n",
            "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 73f419adce61..2457e24de95b 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -1945,7 +1945,9 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \t}\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\tusb_rcvctrlpipe(data->usb_dev, 0),\n+\t\t\t(request.req.bRequestType & USB_DIR_IN) ? \n+\t\t\tusb_rcvctrlpipe(data->usb_dev, 0) : \n+\t\t\tusb_sndctrlpipe(data->usb_dev, 0),\n \t\t\trequest.req.bRequest,\n \t\t\trequest.req.bRequestType,\n \t\t\trequest.req.wValue,\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "384b9a05e5d4c3e74e31427e43a08f40f71db54a": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/afs/super.c b/fs/afs/super.c\nindex 95d713074dc8..db14183f3027 100644\n--- a/fs/afs/super.c\n+++ b/fs/afs/super.c\n@@ -431,6 +431,9 @@ static int afs_dynroot_test_super(struct super_block *sb, struct fs_context *fc)\n {\n \tstruct afs_super_info *as = AFS_FS_S(sb);\n \n+\tif (!as)\n+\t\treturn 0;\n+\n \treturn (as->net_ns == fc->net_ns &&\n \t\tas->dyn_root);\n }\n",
            "diff --git a/fs/afs/super.c b/fs/afs/super.c\nindex 95d713074dc8..db14183f3027 100644\n--- a/fs/afs/super.c\n+++ b/fs/afs/super.c\n@@ -431,6 +431,9 @@ static int afs_dynroot_test_super(struct super_block *sb, struct fs_context *fc)\n {\n \tstruct afs_super_info *as = AFS_FS_S(sb);\n \n+\tif (!as)\n+\t\treturn 0;\n+\n \treturn (as->net_ns == fc->net_ns &&\n \t\tas->dyn_root);\n }\n",
            "diff --git a/fs/afs/super.c b/fs/afs/super.c\nindex 95d713074dc8..79d3ec2f172a 100644\n--- a/fs/afs/super.c\n+++ b/fs/afs/super.c\n@@ -610,7 +610,13 @@ static void afs_free_fc(struct fs_context *fc)\n {\n \tstruct afs_fs_context *ctx = fc->fs_private;\n \n-\tafs_destroy_sbi(fc->s_fs_info);\n+\t// Delay the destruction of afs_super_info until it's safe\n+\tif (fc->s_fs_info) {\n+\t\t// Ensure the superblock is deactivated before freeing\n+\t\tdeactivate_locked_super(fc->s_fs_info);\n+\t\tafs_destroy_sbi(fc->s_fs_info);\n+\t}\n+\n \tafs_put_volume(ctx->net, ctx->volume, afs_volume_trace_put_free_fc);\n \tafs_unuse_cell(ctx->net, ctx->cell, afs_cell_trace_unuse_fc);\n \tkey_put(ctx->key);\n",
            "diff --git a/fs/afs/super.c b/fs/afs/super.c\nindex 95d713074dc8..db14183f3027 100644\n--- a/fs/afs/super.c\n+++ b/fs/afs/super.c\n@@ -431,6 +431,9 @@ static int afs_dynroot_test_super(struct super_block *sb, struct fs_context *fc)\n {\n \tstruct afs_super_info *as = AFS_FS_S(sb);\n \n+\tif (!as)\n+\t\treturn 0;\n+\n \treturn (as->net_ns == fc->net_ns &&\n \t\tas->dyn_root);\n }\n",
            "diff --git a/fs/afs/super.c b/fs/afs/super.c\nindex 95d713074dc8..db14183f3027 100644\n--- a/fs/afs/super.c\n+++ b/fs/afs/super.c\n@@ -431,6 +431,9 @@ static int afs_dynroot_test_super(struct super_block *sb, struct fs_context *fc)\n {\n \tstruct afs_super_info *as = AFS_FS_S(sb);\n \n+\tif (!as)\n+\t\treturn 0;\n+\n \treturn (as->net_ns == fc->net_ns &&\n \t\tas->dyn_root);\n }\n"
        ],
        "error": []
    },
    "75a2a727e4636c7a34dbd49197b15c3de92a8f7f": {
        "non_crash": [
            "diff --git a/mm/hugetlb.c b/mm/hugetlb.c\nindex 9d97c9a2a15d..e57c0e6d8630 100644\n--- a/mm/hugetlb.c\n+++ b/mm/hugetlb.c\n@@ -5320,8 +5320,10 @@ static vm_fault_t hugetlb_wp(struct mm_struct *mm, struct vm_area_struct *vma,\n \t * hugetlb does not support FOLL_FORCE-style write faults that keep the\n \t * PTE mapped R/O such as maybe_mkwrite() would do.\n \t */\n-\tif (WARN_ON_ONCE(!unshare && !(vma->vm_flags & VM_WRITE)))\n+\tif (!unshare && !(vma->vm_flags & VM_WRITE)) {\n+\t\tpr_warn(\"hugetlb_wp: unexpected write fault without VM_WRITE\\n\");\n \t\treturn VM_FAULT_SIGSEGV;\n+\t}\n \n \t/* Let's take out MAP_SHARED mappings first. */\n \tif (vma->vm_flags & VM_MAYSHARE) {\n",
            "diff --git a/mm/hugetlb.c b/mm/hugetlb.c\nindex 9d97c9a2a15d..1c6f08d53db8 100644\n--- a/mm/hugetlb.c\n+++ b/mm/hugetlb.c\n@@ -5320,8 +5320,10 @@ static vm_fault_t hugetlb_wp(struct mm_struct *mm, struct vm_area_struct *vma,\n \t * hugetlb does not support FOLL_FORCE-style write faults that keep the\n \t * PTE mapped R/O such as maybe_mkwrite() would do.\n \t */\n-\tif (WARN_ON_ONCE(!unshare && !(vma->vm_flags & VM_WRITE)))\n+\tif (!unshare && !(vma->vm_flags & VM_WRITE)) {\n+\t\tpr_warn(\"hugetlb_wp: unexpected call without VM_WRITE\\n\");\n \t\treturn VM_FAULT_SIGSEGV;\n+\t}\n \n \t/* Let's take out MAP_SHARED mappings first. */\n \tif (vma->vm_flags & VM_MAYSHARE) {\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/hugetlb.c b/mm/hugetlb.c\nindex 9d97c9a2a15d..7bfa6a5311e8 100644\n--- a/mm/hugetlb.c\n+++ b/mm/hugetlb.c\n@@ -5320,8 +5320,10 @@ static vm_fault_t hugetlb_wp(struct mm_struct *mm, struct vm_area_struct *vma,\n \t * hugetlb does not support FOLL_FORCE-style write faults that keep the\n \t * PTE mapped R/O such as maybe_mkwrite() would do.\n \t */\n-\tif (WARN_ON_ONCE(!unshare && !(vma->vm_flags & VM_WRITE)))\n-\t\treturn VM_FAULT_SIGSEGV;\n+\tif (WARN_ON_ONCE(!unshare && !(vma->vm_flags & VM_WRITE))) {\n+\t\tif (!(flags & FAULT_FLAG_WRITE))\n+\t\t\treturn VM_FAULT_SIGSEGV;\n+\t}\n \n \t/* Let's take out MAP_SHARED mappings first. */\n \tif (vma->vm_flags & VM_MAYSHARE) {\n",
            "diff --git a/mm/hugetlb.c b/mm/hugetlb.c\nindex 9d97c9a2a15d..b6038af33d3e 100644\n--- a/mm/hugetlb.c\n+++ b/mm/hugetlb.c\n@@ -5899,15 +5899,19 @@ vm_fault_t hugetlb_fault(struct mm_struct *mm, struct vm_area_struct *vma,\n \t * determine if a reservation has been consumed.\n \t */\n \tif ((flags & (FAULT_FLAG_WRITE|FAULT_FLAG_UNSHARE)) &&\n-\t    !(vma->vm_flags & VM_MAYSHARE) && !huge_pte_write(entry)) {\n-\t\tif (vma_needs_reservation(h, vma, haddr) < 0) {\n-\t\t\tret = VM_FAULT_OOM;\n-\t\t\tgoto out_mutex;\n-\t\t}\n-\t\t/* Just decrements count, does not deallocate */\n-\t\tvma_end_reservation(h, vma, haddr);\n+\t    !(vma->vm_flags & VM_MAYSHARE)) {\n+\t\tif (!huge_pte_write(entry)) {\n+\t\t\tif (vma_needs_reservation(h, vma, haddr) < 0) {\n+\t\t\t\tret = VM_FAULT_OOM;\n+\t\t\t\tgoto out_mutex;\n+\t\t\t}\n+\t\t\t/* Just decrements count, does not deallocate */\n+\t\t\tvma_end_reservation(h, vma, haddr);\n \n-\t\tpagecache_page = find_lock_page(mapping, idx);\n+\t\t\tpagecache_page = find_lock_page(mapping, idx);\n+\t\t} else {\n+\t\t\tentry = huge_pte_mkdirty(entry);\n+\t\t}\n \t}\n \n \tptl = huge_pte_lock(h, mm, ptep);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/mm/hugetlb.c b/mm/hugetlb.c\nindex 9d97c9a2a15d..8c24e7269487 100644\n--- a/mm/hugetlb.c\n+++ b/mm/hugetlb.c\n@@ -5952,9 +5952,14 @@ vm_fault_t hugetlb_fault(struct mm_struct *mm, struct vm_area_struct *vma,\n \n \tif (flags & (FAULT_FLAG_WRITE|FAULT_FLAG_UNSHARE)) {\n \t\tif (!huge_pte_write(entry)) {\n-\t\t\tret = hugetlb_wp(mm, vma, address, ptep, flags,\n-\t\t\t\t\t pagecache_page, ptl);\n-\t\t\tgoto out_put_page;\n+\t\t\tif (unshare || (vma->vm_flags & VM_WRITE)) {\n+\t\t\t\tret = hugetlb_wp(mm, vma, address, ptep, flags,\n+\t\t\t\t\t\t pagecache_page, ptl);\n+\t\t\t\tgoto out_put_page;\n+\t\t\t} else {\n+\t\t\t\tret = VM_FAULT_SIGSEGV;\n+\t\t\t\tgoto out_put_page;\n+\t\t\t}\n \t\t} else if (likely(flags & FAULT_FLAG_WRITE)) {\n \t\t\tentry = huge_pte_mkdirty(entry);\n \t\t}\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "72c3096dbc86cdffde7afa178a39dc1a29dec67a": {
        "non_crash": [
            "diff --git a/fs/exfat/dir.c b/fs/exfat/dir.c\nindex bc48f3329921..b0f6345695f0 100644\n--- a/fs/exfat/dir.c\n+++ b/fs/exfat/dir.c\n@@ -233,11 +233,11 @@ static int exfat_iterate(struct file *file, struct dir_context *ctx)\n \tint err = 0, fake_offset = 0;\n \n \texfat_init_namebuf(nb);\n-\tmutex_lock(&EXFAT_SB(sb)->s_lock);\n-\n \tcpos = ctx->pos;\n-\tif (!dir_emit_dots(file, ctx))\n+\tif (!dir_emit_dots(file, ctx)) {\n+\t\tmutex_lock(&EXFAT_SB(sb)->s_lock);\n \t\tgoto unlock;\n+\t}\n \n \tif (ctx->pos == ITER_POS_FILLED_DOTS) {\n \t\tcpos = 0;\n",
            "diff --git a/fs/exfat/dir.c b/fs/exfat/dir.c\nindex bc48f3329921..7c1449279888 100644\n--- a/fs/exfat/dir.c\n+++ b/fs/exfat/dir.c\n@@ -233,11 +233,12 @@ static int exfat_iterate(struct file *file, struct dir_context *ctx)\n \tint err = 0, fake_offset = 0;\n \n \texfat_init_namebuf(nb);\n-\tmutex_lock(&EXFAT_SB(sb)->s_lock);\n-\n \tcpos = ctx->pos;\n-\tif (!dir_emit_dots(file, ctx))\n+\tif (!dir_emit_dots(file, ctx)) {\n+\t\tmutex_lock(&EXFAT_SB(sb)->s_lock);\n \t\tgoto unlock;\n+\t}\n+\tmutex_lock(&EXFAT_SB(sb)->s_lock);\n \n \tif (ctx->pos == ITER_POS_FILLED_DOTS) {\n \t\tcpos = 0;\n",
            "diff --git a/fs/exfat/dir.c b/fs/exfat/dir.c\nindex bc48f3329921..4ab274d2cdeb 100644\n--- a/fs/exfat/dir.c\n+++ b/fs/exfat/dir.c\n@@ -233,11 +233,11 @@ static int exfat_iterate(struct file *file, struct dir_context *ctx)\n \tint err = 0, fake_offset = 0;\n \n \texfat_init_namebuf(nb);\n-\tmutex_lock(&EXFAT_SB(sb)->s_lock);\n+\tif (!dir_emit_dots(file, ctx))\n+\t\treturn -EINVAL;\n \n+\tmutex_lock(&EXFAT_SB(sb)->s_lock);\n \tcpos = ctx->pos;\n-\tif (!dir_emit_dots(file, ctx))\n-\t\tgoto unlock;\n \n \tif (ctx->pos == ITER_POS_FILLED_DOTS) {\n \t\tcpos = 0;\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/fs/exfat/dir.c b/fs/exfat/dir.c\nindex bc48f3329921..f44484cbcf37 100644\n--- a/fs/exfat/dir.c\n+++ b/fs/exfat/dir.c\n@@ -233,11 +233,11 @@ static int exfat_iterate(struct file *file, struct dir_context *ctx)\n \tint err = 0, fake_offset = 0;\n \n \texfat_init_namebuf(nb);\n-\tmutex_lock(&EXFAT_SB(sb)->s_lock);\n-\n \tcpos = ctx->pos;\n-\tif (!dir_emit_dots(file, ctx))\n-\t\tgoto unlock;\n+\tif (!dir_emit_dots(file, ctx)) {\n+\t\tmutex_unlock(&EXFAT_SB(sb)->s_lock);\n+\t\treturn -EINVAL;\n+\t}\n \n \tif (ctx->pos == ITER_POS_FILLED_DOTS) {\n \t\tcpos = 0;\ndiff --git a/mm/memory.c b/mm/memory.c\nindex 01f39e8144ef..21838e1de4c4 100644\n--- a/mm/memory.c\n+++ b/mm/memory.c\n@@ -5320,8 +5320,10 @@ struct vm_area_struct *lock_mm_and_find_vma(struct mm_struct *mm,\n {\n \tstruct vm_area_struct *vma;\n \n-\tif (!get_mmap_lock_carefully(mm, regs))\n+\tif (!get_mmap_lock_carefully(mm, regs)) {\n+\t\tmutex_unlock(&EXFAT_SB(sb)->s_lock);\n \t\treturn NULL;\n+\t}\n \n \tvma = find_vma(mm, addr);\n \tif (likely(vma && (vma->vm_start <= addr)))\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/exfat/dir.c b/fs/exfat/dir.c\nindex bc48f3329921..4ce6985b04c9 100644\n--- a/fs/exfat/dir.c\n+++ b/fs/exfat/dir.c\n@@ -233,11 +233,18 @@ static int exfat_iterate(struct file *file, struct dir_context *ctx)\n \tint err = 0, fake_offset = 0;\n \n \texfat_init_namebuf(nb);\n+\tif (!mmap_read_lock_killable(mm)) {\n+\t\treturn -EINTR;\n+\t}\n+\n \tmutex_lock(&EXFAT_SB(sb)->s_lock);\n \n \tcpos = ctx->pos;\n-\tif (!dir_emit_dots(file, ctx))\n-\t\tgoto unlock;\n+\tif (!dir_emit_dots(file, ctx)) {\n+\t\tmutex_unlock(&EXFAT_SB(sb)->s_lock);\n+\t\tmmap_read_unlock(mm);\n+\t\treturn -EFAULT;\n+\t}\n \n \tif (ctx->pos == ITER_POS_FILLED_DOTS) {\n \t\tcpos = 0;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "d58fe2a53afa4ffbfaf3df368acb70d137e46c9f": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h\nindex a52830927cb4..96d2549951c4 100644\n--- a/fs/f2fs/f2fs.h\n+++ b/fs/f2fs/f2fs.h\n@@ -3272,6 +3272,10 @@ static inline void *inline_data_addr(struct inode *inode, struct page *page)\n \tstruct f2fs_inode *ri = F2FS_INODE(page);\n \tint extra_size = get_extra_isize(inode);\n \n+\tif (extra_size + DEF_INLINE_RESERVED_SIZE >= ARRAY_SIZE(ri->i_addr)) {\n+\t\tpr_err(\"f2fs: inline_data_addr index out of bounds\\n\");\n+\t\treturn NULL;\n+\t}\n \treturn (void *)&(ri->i_addr[extra_size + DEF_INLINE_RESERVED_SIZE]);\n }\n \n",
            "diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h\nindex a52830927cb4..d91716f16e5b 100644\n--- a/fs/f2fs/f2fs.h\n+++ b/fs/f2fs/f2fs.h\n@@ -3272,6 +3272,10 @@ static inline void *inline_data_addr(struct inode *inode, struct page *page)\n \tstruct f2fs_inode *ri = F2FS_INODE(page);\n \tint extra_size = get_extra_isize(inode);\n \n+\tif (extra_size + DEF_INLINE_RESERVED_SIZE >= 923) {\n+\t\tpr_err(\"inline_data_addr: index out of bounds\\n\");\n+\t\treturn NULL;\n+\t}\n \treturn (void *)&(ri->i_addr[extra_size + DEF_INLINE_RESERVED_SIZE]);\n }\n \n",
            "diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h\nindex a52830927cb4..d91716f16e5b 100644\n--- a/fs/f2fs/f2fs.h\n+++ b/fs/f2fs/f2fs.h\n@@ -3272,6 +3272,10 @@ static inline void *inline_data_addr(struct inode *inode, struct page *page)\n \tstruct f2fs_inode *ri = F2FS_INODE(page);\n \tint extra_size = get_extra_isize(inode);\n \n+\tif (extra_size + DEF_INLINE_RESERVED_SIZE >= 923) {\n+\t\tpr_err(\"inline_data_addr: index out of bounds\\n\");\n+\t\treturn NULL;\n+\t}\n \treturn (void *)&(ri->i_addr[extra_size + DEF_INLINE_RESERVED_SIZE]);\n }\n \n",
            "diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h\nindex a52830927cb4..cc5d63819dcd 100644\n--- a/fs/f2fs/f2fs.h\n+++ b/fs/f2fs/f2fs.h\n@@ -3272,7 +3272,12 @@ static inline void *inline_data_addr(struct inode *inode, struct page *page)\n \tstruct f2fs_inode *ri = F2FS_INODE(page);\n \tint extra_size = get_extra_isize(inode);\n \n-\treturn (void *)&(ri->i_addr[extra_size + DEF_INLINE_RESERVED_SIZE]);\n+\tif (extra_size + DEF_INLINE_RESERVED_SIZE < ARRAY_SIZE(ri->i_addr)) {\n+\t\treturn (void *)&(ri->i_addr[extra_size + DEF_INLINE_RESERVED_SIZE]);\n+\t} else {\n+\t\t// Handle the error case, e.g., return NULL or handle appropriately\n+\t\treturn NULL;\n+\t}\n }\n \n static inline int f2fs_has_inline_dentry(struct inode *inode)\n",
            "diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h\nindex a52830927cb4..b838fafbced2 100644\n--- a/fs/f2fs/f2fs.h\n+++ b/fs/f2fs/f2fs.h\n@@ -3272,7 +3272,12 @@ static inline void *inline_data_addr(struct inode *inode, struct page *page)\n \tstruct f2fs_inode *ri = F2FS_INODE(page);\n \tint extra_size = get_extra_isize(inode);\n \n-\treturn (void *)&(ri->i_addr[extra_size + DEF_INLINE_RESERVED_SIZE]);\n+\tif (extra_size + DEF_INLINE_RESERVED_SIZE < 923) {\n+\t\treturn (void *)&(ri->i_addr[extra_size + DEF_INLINE_RESERVED_SIZE]);\n+\t} else {\n+\t\t// Handle the error case, e.g., return NULL or handle appropriately\n+\t\treturn NULL;\n+\t}\n }\n \n static inline int f2fs_has_inline_dentry(struct inode *inode)\n"
        ],
        "error": []
    },
    "6408a8ba0fa0e3940c5c2dfa40e808cbf4228689": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/aio.c b/fs/aio.c\nindex c1e581dd32f5..9675e67956e4 100644\n--- a/fs/aio.c\n+++ b/fs/aio.c\n@@ -617,7 +617,7 @@ static void free_ioctx_users(struct percpu_ref *ref)\n \tstruct kioctx *ctx = container_of(ref, struct kioctx, users);\n \tstruct aio_kiocb *req;\n \n-\tspin_lock_irq(&ctx->ctx_lock);\n+\tspin_lock(&ctx->ctx_lock);\n \n \twhile (!list_empty(&ctx->active_reqs)) {\n \t\treq = list_first_entry(&ctx->active_reqs,\n",
            "diff --git a/fs/aio.c b/fs/aio.c\nindex c1e581dd32f5..9675e67956e4 100644\n--- a/fs/aio.c\n+++ b/fs/aio.c\n@@ -617,7 +617,7 @@ static void free_ioctx_users(struct percpu_ref *ref)\n \tstruct kioctx *ctx = container_of(ref, struct kioctx, users);\n \tstruct aio_kiocb *req;\n \n-\tspin_lock_irq(&ctx->ctx_lock);\n+\tspin_lock(&ctx->ctx_lock);\n \n \twhile (!list_empty(&ctx->active_reqs)) {\n \t\treq = list_first_entry(&ctx->active_reqs,\ndiff --git a/fs/userfaultfd.c b/fs/userfaultfd.c\nindex ae0b8b5f69e6..d1ee520329fa 100644\n--- a/fs/userfaultfd.c\n+++ b/fs/userfaultfd.c\n@@ -1038,7 +1038,7 @@ static ssize_t userfaultfd_ctx_read(struct userfaultfd_ctx *ctx, int no_wait,\n \tstruct userfaultfd_ctx *fork_nctx = NULL;\n \n \t/* always take the fd_wqh lock before the fault_pending_wqh lock */\n-\tspin_lock_irq(&ctx->fd_wqh.lock);\n+\tspin_lock(&ctx->fd_wqh.lock);\n \t__add_wait_queue(&ctx->fd_wqh, &wait);\n \tfor (;;) {\n \t\tset_current_state(TASK_INTERRUPTIBLE);\n",
            "diff --git a/fs/aio.c b/fs/aio.c\nindex c1e581dd32f5..9675e67956e4 100644\n--- a/fs/aio.c\n+++ b/fs/aio.c\n@@ -617,7 +617,7 @@ static void free_ioctx_users(struct percpu_ref *ref)\n \tstruct kioctx *ctx = container_of(ref, struct kioctx, users);\n \tstruct aio_kiocb *req;\n \n-\tspin_lock_irq(&ctx->ctx_lock);\n+\tspin_lock(&ctx->ctx_lock);\n \n \twhile (!list_empty(&ctx->active_reqs)) {\n \t\treq = list_first_entry(&ctx->active_reqs,\ndiff --git a/fs/userfaultfd.c b/fs/userfaultfd.c\nindex ae0b8b5f69e6..d1ee520329fa 100644\n--- a/fs/userfaultfd.c\n+++ b/fs/userfaultfd.c\n@@ -1038,7 +1038,7 @@ static ssize_t userfaultfd_ctx_read(struct userfaultfd_ctx *ctx, int no_wait,\n \tstruct userfaultfd_ctx *fork_nctx = NULL;\n \n \t/* always take the fd_wqh lock before the fault_pending_wqh lock */\n-\tspin_lock_irq(&ctx->fd_wqh.lock);\n+\tspin_lock(&ctx->fd_wqh.lock);\n \t__add_wait_queue(&ctx->fd_wqh, &wait);\n \tfor (;;) {\n \t\tset_current_state(TASK_INTERRUPTIBLE);\n",
            "diff --git a/fs/aio.c b/fs/aio.c\nindex c1e581dd32f5..9675e67956e4 100644\n--- a/fs/aio.c\n+++ b/fs/aio.c\n@@ -617,7 +617,7 @@ static void free_ioctx_users(struct percpu_ref *ref)\n \tstruct kioctx *ctx = container_of(ref, struct kioctx, users);\n \tstruct aio_kiocb *req;\n \n-\tspin_lock_irq(&ctx->ctx_lock);\n+\tspin_lock(&ctx->ctx_lock);\n \n \twhile (!list_empty(&ctx->active_reqs)) {\n \t\treq = list_first_entry(&ctx->active_reqs,\ndiff --git a/fs/userfaultfd.c b/fs/userfaultfd.c\nindex ae0b8b5f69e6..d1ee520329fa 100644\n--- a/fs/userfaultfd.c\n+++ b/fs/userfaultfd.c\n@@ -1038,7 +1038,7 @@ static ssize_t userfaultfd_ctx_read(struct userfaultfd_ctx *ctx, int no_wait,\n \tstruct userfaultfd_ctx *fork_nctx = NULL;\n \n \t/* always take the fd_wqh lock before the fault_pending_wqh lock */\n-\tspin_lock_irq(&ctx->fd_wqh.lock);\n+\tspin_lock(&ctx->fd_wqh.lock);\n \t__add_wait_queue(&ctx->fd_wqh, &wait);\n \tfor (;;) {\n \t\tset_current_state(TASK_INTERRUPTIBLE);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/aio.c b/fs/aio.c\nindex c1e581dd32f5..b02a77e54455 100644\n--- a/fs/aio.c\n+++ b/fs/aio.c\n@@ -617,7 +617,8 @@ static void free_ioctx_users(struct percpu_ref *ref)\n \tstruct kioctx *ctx = container_of(ref, struct kioctx, users);\n \tstruct aio_kiocb *req;\n \n-\tspin_lock_irq(&ctx->ctx_lock);\n+\tspin_lock_irq(&ctx->fd_wqh.lock);\n+\tspin_lock(&ctx->ctx_lock);\n \n \twhile (!list_empty(&ctx->active_reqs)) {\n \t\treq = list_first_entry(&ctx->active_reqs,\n@@ -626,7 +627,8 @@ static void free_ioctx_users(struct percpu_ref *ref)\n \t\tlist_del_init(&req->ki_list);\n \t}\n \n-\tspin_unlock_irq(&ctx->ctx_lock);\n+\tspin_unlock(&ctx->ctx_lock);\n+\tspin_unlock_irq(&ctx->fd_wqh.lock);\n \n \tpercpu_ref_kill(&ctx->reqs);\n \tpercpu_ref_put(&ctx->reqs);\ndiff --git a/fs/userfaultfd.c b/fs/userfaultfd.c\nindex ae0b8b5f69e6..94be20bc767c 100644\n--- a/fs/userfaultfd.c\n+++ b/fs/userfaultfd.c\n@@ -918,10 +918,12 @@ static int userfaultfd_release(struct inode *inode, struct file *file)\n \t * the last page faults that may have been already waiting on\n \t * the fault_*wqh.\n \t */\n+\tspin_lock_irq(&ctx->fd_wqh.lock);\n \tspin_lock(&ctx->fault_pending_wqh.lock);\n \t__wake_up_locked_key(&ctx->fault_pending_wqh, TASK_NORMAL, &range);\n \t__wake_up(&ctx->fault_wqh, TASK_NORMAL, 1, &range);\n \tspin_unlock(&ctx->fault_pending_wqh.lock);\n+\tspin_unlock_irq(&ctx->fd_wqh.lock);\n \n \t/* Flush pending events that may still wait on event_wqh */\n \twake_up_all(&ctx->event_wqh);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "11acaa6d5c31d0b655997957f725da4a3cc05435": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex d1f1da6820fb..ebbebe0e73a7 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -2525,10 +2525,12 @@ int btrfs_commit_transaction(struct btrfs_trans_handle *trans)\n \tbtrfs_cleanup_pending_block_groups(trans);\n \tbtrfs_trans_release_chunk_metadata(trans);\n \ttrans->block_rsv = NULL;\n-\tbtrfs_warn(fs_info, \"Skipping commit of aborted transaction.\");\n-\tif (current->journal_info == trans)\n-\t\tcurrent->journal_info = NULL;\n-\tcleanup_transaction(trans, ret);\n+\tif (!TRANS_ABORTED(trans->transaction)) {\n+\t\tbtrfs_warn(fs_info, \"Skipping commit of aborted transaction.\");\n+\t\tif (current->journal_info == trans)\n+\t\t\tcurrent->journal_info = NULL;\n+\t\tcleanup_transaction(trans, ret);\n+\t}\n \n \treturn ret;\n \n",
            "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex d1f1da6820fb..73ffdfdee861 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -2521,14 +2521,17 @@ int btrfs_commit_transaction(struct btrfs_trans_handle *trans)\n \tbtrfs_trans_state_lockdep_release(fs_info, BTRFS_LOCKDEP_TRANS_COMPLETED);\n \tbtrfs_scrub_continue(fs_info);\n cleanup_transaction:\n-\tbtrfs_trans_release_metadata(trans);\n-\tbtrfs_cleanup_pending_block_groups(trans);\n-\tbtrfs_trans_release_chunk_metadata(trans);\n-\ttrans->block_rsv = NULL;\n-\tbtrfs_warn(fs_info, \"Skipping commit of aborted transaction.\");\n-\tif (current->journal_info == trans)\n-\t\tcurrent->journal_info = NULL;\n-\tcleanup_transaction(trans, ret);\n+\tif (!TRANS_ABORTED(cur_trans)) {\n+\t\tbtrfs_trans_release_metadata(trans);\n+\t\tbtrfs_cleanup_pending_block_groups(trans);\n+\t\tbtrfs_trans_release_chunk_metadata(trans);\n+\t\ttrans->block_rsv = NULL;\n+\t\tif (current->journal_info == trans)\n+\t\t\tcurrent->journal_info = NULL;\n+\t\tcleanup_transaction(trans, ret);\n+\t} else {\n+\t\tbtrfs_warn(fs_info, \"Skipping commit of aborted transaction.\");\n+\t}\n \n \treturn ret;\n \n",
            "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex d1f1da6820fb..73ffdfdee861 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -2521,14 +2521,17 @@ int btrfs_commit_transaction(struct btrfs_trans_handle *trans)\n \tbtrfs_trans_state_lockdep_release(fs_info, BTRFS_LOCKDEP_TRANS_COMPLETED);\n \tbtrfs_scrub_continue(fs_info);\n cleanup_transaction:\n-\tbtrfs_trans_release_metadata(trans);\n-\tbtrfs_cleanup_pending_block_groups(trans);\n-\tbtrfs_trans_release_chunk_metadata(trans);\n-\ttrans->block_rsv = NULL;\n-\tbtrfs_warn(fs_info, \"Skipping commit of aborted transaction.\");\n-\tif (current->journal_info == trans)\n-\t\tcurrent->journal_info = NULL;\n-\tcleanup_transaction(trans, ret);\n+\tif (!TRANS_ABORTED(cur_trans)) {\n+\t\tbtrfs_trans_release_metadata(trans);\n+\t\tbtrfs_cleanup_pending_block_groups(trans);\n+\t\tbtrfs_trans_release_chunk_metadata(trans);\n+\t\ttrans->block_rsv = NULL;\n+\t\tif (current->journal_info == trans)\n+\t\t\tcurrent->journal_info = NULL;\n+\t\tcleanup_transaction(trans, ret);\n+\t} else {\n+\t\tbtrfs_warn(fs_info, \"Skipping commit of aborted transaction.\");\n+\t}\n \n \treturn ret;\n \n",
            "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex d1f1da6820fb..3245b57db104 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -2525,7 +2525,8 @@ int btrfs_commit_transaction(struct btrfs_trans_handle *trans)\n \tbtrfs_cleanup_pending_block_groups(trans);\n \tbtrfs_trans_release_chunk_metadata(trans);\n \ttrans->block_rsv = NULL;\n-\tbtrfs_warn(fs_info, \"Skipping commit of aborted transaction.\");\n+\tif (!TRANS_ABORTED(cur_trans))\n+\t\tbtrfs_warn(fs_info, \"Skipping commit of aborted transaction.\");\n \tif (current->journal_info == trans)\n \t\tcurrent->journal_info = NULL;\n \tcleanup_transaction(trans, ret);\n",
            "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex d1f1da6820fb..d805968644fa 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -2103,8 +2103,9 @@ int btrfs_commit_transaction(struct btrfs_trans_handle *trans)\n \n \t/* Stop the commit early if ->aborted is set */\n \tif (TRANS_ABORTED(cur_trans)) {\n+\t\tbtrfs_warn(fs_info, \"Transaction aborted, skipping commit.\");\n \t\tret = cur_trans->aborted;\n-\t\tgoto lockdep_trans_commit_start_release;\n+\t\tgoto cleanup_transaction;\n \t}\n \n \tbtrfs_trans_release_metadata(trans);\n"
        ],
        "error": []
    },
    "8db097bf9d28642881b6dee785166885150fbd86": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 9930fa901039..1e899d1dfa31 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -155,7 +155,9 @@ int nilfs_dat_prepare_end(struct inode *dat, struct nilfs_palloc_req *req)\n \n \tret = nilfs_dat_prepare_entry(dat, req, 0);\n \tif (ret < 0) {\n-\t\tWARN_ON(ret == -ENOENT);\n+\t\tif (ret != -ENOENT) {\n+\t\t\tWARN_ON(1);\n+\t\t}\n \t\treturn ret;\n \t}\n \n",
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 9930fa901039..3b288c442f8f 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -153,9 +153,17 @@ int nilfs_dat_prepare_end(struct inode *dat, struct nilfs_palloc_req *req)\n \tvoid *kaddr;\n \tint ret;\n \n+\tif (!req->pr_entry_bh) {\n+\t\tpr_err(\"nilfs_dat_prepare_end: pr_entry_bh is NULL\\n\");\n+\t\treturn -EINVAL;\n+\t}\n+\n \tret = nilfs_dat_prepare_entry(dat, req, 0);\n \tif (ret < 0) {\n-\t\tWARN_ON(ret == -ENOENT);\n+\t\tif (ret == -ENOENT) {\n+\t\t\tpr_warn(\"nilfs_dat_prepare_end: Entry not found\\n\");\n+\t\t\tnilfs_dat_abort_entry(dat, req);\n+\t\t}\n \t\treturn ret;\n \t}\n \n",
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 9930fa901039..2de62f34e49e 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -155,7 +155,11 @@ int nilfs_dat_prepare_end(struct inode *dat, struct nilfs_palloc_req *req)\n \n \tret = nilfs_dat_prepare_entry(dat, req, 0);\n \tif (ret < 0) {\n-\t\tWARN_ON(ret == -ENOENT);\n+\t\tif (ret == -ENOENT) {\n+\t\t\t/* Handle the case where the entry does not exist */\n+\t\t\tnilfs_dat_abort_entry(dat, req);\n+\t\t\treturn -ENOENT;\n+\t\t}\n \t\treturn ret;\n \t}\n \n",
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 9930fa901039..7885eeba30e6 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -155,7 +155,11 @@ int nilfs_dat_prepare_end(struct inode *dat, struct nilfs_palloc_req *req)\n \n \tret = nilfs_dat_prepare_entry(dat, req, 0);\n \tif (ret < 0) {\n-\t\tWARN_ON(ret == -ENOENT);\n+\t\tif (ret == -ENOENT) {\n+\t\t\t// Handle the -ENOENT case appropriately\n+\t\t\tnilfs_dat_abort_entry(dat, req);\n+\t\t\treturn ret;\n+\t\t}\n \t\treturn ret;\n \t}\n \n",
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 9930fa901039..d16b9ade79a1 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -155,7 +155,11 @@ int nilfs_dat_prepare_end(struct inode *dat, struct nilfs_palloc_req *req)\n \n \tret = nilfs_dat_prepare_entry(dat, req, 0);\n \tif (ret < 0) {\n-\t\tWARN_ON(ret == -ENOENT);\n+\t\tif (ret == -ENOENT) {\n+\t\t\t// Handle the -ENOENT case appropriately\n+\t\t\tnilfs_dat_abort_entry(dat, req);\n+\t\t\treturn -ENOENT;\n+\t\t}\n \t\treturn ret;\n \t}\n \n"
        ],
        "error": []
    },
    "f9cfa5c5564ffc453258d835293bf6e9881c5b1c": {
        "non_crash": [
            "diff --git a/net/sctp/stream_sched_rr.c b/net/sctp/stream_sched_rr.c\nindex 52ba743fa7a7..282ba052e0a4 100644\n--- a/net/sctp/stream_sched_rr.c\n+++ b/net/sctp/stream_sched_rr.c\n@@ -138,6 +138,10 @@ static struct sctp_chunk *sctp_sched_rr_dequeue(struct sctp_outq *q)\n \t\tsoute = stream->out_curr->ext;\n \telse\n \t\tsoute = stream->rr_next;\n+\n+\tif (!soute)\n+\t\tgoto out;\n+\n \tch = list_entry(soute->outq.next, struct sctp_chunk, stream_list);\n \n \tsctp_sched_dequeue_common(q, ch);\n",
            "diff --git a/net/sctp/stream_sched_rr.c b/net/sctp/stream_sched_rr.c\nindex 52ba743fa7a7..f440e75f1ad7 100644\n--- a/net/sctp/stream_sched_rr.c\n+++ b/net/sctp/stream_sched_rr.c\n@@ -138,9 +138,10 @@ static struct sctp_chunk *sctp_sched_rr_dequeue(struct sctp_outq *q)\n \t\tsoute = stream->out_curr->ext;\n \telse\n \t\tsoute = stream->rr_next;\n-\tch = list_entry(soute->outq.next, struct sctp_chunk, stream_list);\n-\n-\tsctp_sched_dequeue_common(q, ch);\n+\tif (soute) {\n+\t\tch = list_entry(soute->outq.next, struct sctp_chunk, stream_list);\n+\t\tsctp_sched_dequeue_common(q, ch);\n+\t}\n \n out:\n \treturn ch;\n",
            "diff --git a/net/sctp/stream_sched_rr.c b/net/sctp/stream_sched_rr.c\nindex 52ba743fa7a7..282ba052e0a4 100644\n--- a/net/sctp/stream_sched_rr.c\n+++ b/net/sctp/stream_sched_rr.c\n@@ -138,6 +138,10 @@ static struct sctp_chunk *sctp_sched_rr_dequeue(struct sctp_outq *q)\n \t\tsoute = stream->out_curr->ext;\n \telse\n \t\tsoute = stream->rr_next;\n+\n+\tif (!soute)\n+\t\tgoto out;\n+\n \tch = list_entry(soute->outq.next, struct sctp_chunk, stream_list);\n \n \tsctp_sched_dequeue_common(q, ch);\n",
            "diff --git a/net/sctp/stream_sched_rr.c b/net/sctp/stream_sched_rr.c\nindex 52ba743fa7a7..c1082b256c70 100644\n--- a/net/sctp/stream_sched_rr.c\n+++ b/net/sctp/stream_sched_rr.c\n@@ -138,7 +138,10 @@ static struct sctp_chunk *sctp_sched_rr_dequeue(struct sctp_outq *q)\n \t\tsoute = stream->out_curr->ext;\n \telse\n \t\tsoute = stream->rr_next;\n-\tch = list_entry(soute->outq.next, struct sctp_chunk, stream_list);\n+\tif (soute)\n+\t\tch = list_entry(soute->outq.next, struct sctp_chunk, stream_list);\n+\telse\n+\t\tgoto out;\n \n \tsctp_sched_dequeue_common(q, ch);\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/sctp/stream_sched_rr.c b/net/sctp/stream_sched_rr.c\nindex 52ba743fa7a7..282ba052e0a4 100644\n--- a/net/sctp/stream_sched_rr.c\n+++ b/net/sctp/stream_sched_rr.c\n@@ -138,6 +138,10 @@ static struct sctp_chunk *sctp_sched_rr_dequeue(struct sctp_outq *q)\n \t\tsoute = stream->out_curr->ext;\n \telse\n \t\tsoute = stream->rr_next;\n+\n+\tif (!soute)\n+\t\tgoto out;\n+\n \tch = list_entry(soute->outq.next, struct sctp_chunk, stream_list);\n \n \tsctp_sched_dequeue_common(q, ch);\n"
        ],
        "error": []
    },
    "0084fd109a7a10011e183a357715c91cff2cacb0": {
        "non_crash": [
            "diff --git a/mm/mempolicy.c b/mm/mempolicy.c\nindex 69e278b469ef..368d740fce34 100644\n--- a/mm/mempolicy.c\n+++ b/mm/mempolicy.c\n@@ -1742,7 +1742,9 @@ static int policy_node(gfp_t gfp, struct mempolicy *policy,\n \t\t * because we might easily break the expectation to stay on the\n \t\t * requested node and not break the policy.\n \t\t */\n-\t\tWARN_ON_ONCE(policy->mode == MPOL_BIND && (gfp & __GFP_THISNODE));\n+\t\tif (policy->mode == MPOL_BIND && (gfp & __GFP_THISNODE)) {\n+\t\t\tgfp &= ~__GFP_THISNODE; // Remove __GFP_THISNODE flag\n+\t\t}\n \t}\n \n \treturn nd;\n",
            "diff --git a/mm/mempolicy.c b/mm/mempolicy.c\nindex 69e278b469ef..368d740fce34 100644\n--- a/mm/mempolicy.c\n+++ b/mm/mempolicy.c\n@@ -1742,7 +1742,9 @@ static int policy_node(gfp_t gfp, struct mempolicy *policy,\n \t\t * because we might easily break the expectation to stay on the\n \t\t * requested node and not break the policy.\n \t\t */\n-\t\tWARN_ON_ONCE(policy->mode == MPOL_BIND && (gfp & __GFP_THISNODE));\n+\t\tif (policy->mode == MPOL_BIND && (gfp & __GFP_THISNODE)) {\n+\t\t\tgfp &= ~__GFP_THISNODE; // Remove __GFP_THISNODE flag\n+\t\t}\n \t}\n \n \treturn nd;\n",
            "diff --git a/mm/mempolicy.c b/mm/mempolicy.c\nindex 69e278b469ef..368d740fce34 100644\n--- a/mm/mempolicy.c\n+++ b/mm/mempolicy.c\n@@ -1742,7 +1742,9 @@ static int policy_node(gfp_t gfp, struct mempolicy *policy,\n \t\t * because we might easily break the expectation to stay on the\n \t\t * requested node and not break the policy.\n \t\t */\n-\t\tWARN_ON_ONCE(policy->mode == MPOL_BIND && (gfp & __GFP_THISNODE));\n+\t\tif (policy->mode == MPOL_BIND && (gfp & __GFP_THISNODE)) {\n+\t\t\tgfp &= ~__GFP_THISNODE; // Remove __GFP_THISNODE flag\n+\t\t}\n \t}\n \n \treturn nd;\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/mempolicy.c b/mm/mempolicy.c\nindex 69e278b469ef..251e8228857e 100644\n--- a/mm/mempolicy.c\n+++ b/mm/mempolicy.c\n@@ -1742,7 +1742,11 @@ static int policy_node(gfp_t gfp, struct mempolicy *policy,\n \t\t * because we might easily break the expectation to stay on the\n \t\t * requested node and not break the policy.\n \t\t */\n-\t\tWARN_ON_ONCE(policy->mode == MPOL_BIND && (gfp & __GFP_THISNODE));\n+\t\tif (policy->mode == MPOL_BIND && (gfp & __GFP_THISNODE)) {\n+\t\t\tnd = policy->v.preferred_node;\n+\t\t} else {\n+\t\t\tWARN_ON_ONCE(policy->mode == MPOL_BIND && (gfp & __GFP_THISNODE));\n+\t\t}\n \t}\n \n \treturn nd;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/mm/mempolicy.c b/mm/mempolicy.c\nindex 69e278b469ef..5472f40f0e82 100644\n--- a/mm/mempolicy.c\n+++ b/mm/mempolicy.c\n@@ -1734,15 +1734,16 @@ static nodemask_t *policy_nodemask(gfp_t gfp, struct mempolicy *policy)\n static int policy_node(gfp_t gfp, struct mempolicy *policy,\n \t\t\t\t\t\t\t\tint nd)\n {\n-\tif (policy->mode == MPOL_PREFERRED && !(policy->flags & MPOL_F_LOCAL))\n+\tif (policy->mode == MPOL_PREFERRED && !(policy->flags & MPOL_F_LOCAL)) {\n \t\tnd = policy->v.preferred_node;\n-\telse {\n+\t} else if (policy->mode == MPOL_BIND && (gfp & __GFP_THISNODE)) {\n \t\t/*\n-\t\t * __GFP_THISNODE shouldn't even be used with the bind policy\n-\t\t * because we might easily break the expectation to stay on the\n-\t\t * requested node and not break the policy.\n+\t\t * Avoid using __GFP_THISNODE with MPOL_BIND to prevent breaking\n+\t\t * the policy expectation. Default to the requested node.\n \t\t */\n-\t\tWARN_ON_ONCE(policy->mode == MPOL_BIND && (gfp & __GFP_THISNODE));\n+\t\tnd = node;\n+\t} else {\n+\t\tnd = node; // Default to the requested node if no specific policy applies\n \t}\n \n \treturn nd;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "cdc284a3166b0aa5c8797071e971fd0606769e61": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/core/neighbour.c b/net/core/neighbour.c\nindex 952a54763358..4fff5f5beeb5 100644\n--- a/net/core/neighbour.c\n+++ b/net/core/neighbour.c\n@@ -671,23 +671,26 @@ ___neigh_create(struct neigh_table *tbl, const void *pkey,\n \n \t/* Protocol specific setup. */\n \tif (tbl->constructor &&\t(error = tbl->constructor(n)) < 0) {\n+\t\tkfree(n);\n \t\trc = ERR_PTR(error);\n-\t\tgoto out_neigh_release;\n+\t\tgoto out;\n \t}\n \n \tif (dev->netdev_ops->ndo_neigh_construct) {\n \t\terror = dev->netdev_ops->ndo_neigh_construct(dev, n);\n \t\tif (error < 0) {\n+\t\t\tkfree(n);\n \t\t\trc = ERR_PTR(error);\n-\t\t\tgoto out_neigh_release;\n+\t\t\tgoto out;\n \t\t}\n \t}\n \n \t/* Device specific setup. */\n \tif (n->parms->neigh_setup &&\n \t    (error = n->parms->neigh_setup(n)) < 0) {\n+\t\tkfree(n);\n \t\trc = ERR_PTR(error);\n-\t\tgoto out_neigh_release;\n+\t\tgoto out;\n \t}\n \n \tn->confirmed = jiffies - (NEIGH_VAR(n->parms, BASE_REACHABLE_TIME) << 1);\n",
            "diff --git a/net/core/neighbour.c b/net/core/neighbour.c\nindex 952a54763358..4fff5f5beeb5 100644\n--- a/net/core/neighbour.c\n+++ b/net/core/neighbour.c\n@@ -671,23 +671,26 @@ ___neigh_create(struct neigh_table *tbl, const void *pkey,\n \n \t/* Protocol specific setup. */\n \tif (tbl->constructor &&\t(error = tbl->constructor(n)) < 0) {\n+\t\tkfree(n);\n \t\trc = ERR_PTR(error);\n-\t\tgoto out_neigh_release;\n+\t\tgoto out;\n \t}\n \n \tif (dev->netdev_ops->ndo_neigh_construct) {\n \t\terror = dev->netdev_ops->ndo_neigh_construct(dev, n);\n \t\tif (error < 0) {\n+\t\t\tkfree(n);\n \t\t\trc = ERR_PTR(error);\n-\t\t\tgoto out_neigh_release;\n+\t\t\tgoto out;\n \t\t}\n \t}\n \n \t/* Device specific setup. */\n \tif (n->parms->neigh_setup &&\n \t    (error = n->parms->neigh_setup(n)) < 0) {\n+\t\tkfree(n);\n \t\trc = ERR_PTR(error);\n-\t\tgoto out_neigh_release;\n+\t\tgoto out;\n \t}\n \n \tn->confirmed = jiffies - (NEIGH_VAR(n->parms, BASE_REACHABLE_TIME) << 1);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/core/neighbour.c b/net/core/neighbour.c\nindex 952a54763358..5214e712757e 100644\n--- a/net/core/neighbour.c\n+++ b/net/core/neighbour.c\n@@ -665,6 +665,9 @@ ___neigh_create(struct neigh_table *tbl, const void *pkey,\n \t\tgoto out;\n \t}\n \n+out_neigh_release:\n+\tneigh_release(n);\n+\n \tmemcpy(n->primary_key, pkey, key_len);\n \tn->dev = dev;\n \tnetdev_hold(dev, &n->dev_tracker, GFP_ATOMIC);\n@@ -675,6 +678,14 @@ ___neigh_create(struct neigh_table *tbl, const void *pkey,\n \t\tgoto out_neigh_release;\n \t}\n \n+out_neigh_release:\n+\tneigh_release(n);\n+\t}\n+\n+out_neigh_release:\n+\tneigh_release(n);\n+\t}\n+\n \tif (dev->netdev_ops->ndo_neigh_construct) {\n \t\terror = dev->netdev_ops->ndo_neigh_construct(dev, n);\n \t\tif (error < 0) {\n@@ -703,7 +714,7 @@ ___neigh_create(struct neigh_table *tbl, const void *pkey,\n \n \tif (n->parms->dead) {\n \t\trc = ERR_PTR(-EINVAL);\n-\t\tgoto out_tbl_unlock;\n+\t\tgoto out_neigh_release;\n \t}\n \n \tfor (n1 = rcu_dereference_protected(nht->hash_buckets[hash_val],\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/core/neighbour.c b/net/core/neighbour.c\nindex 952a54763358..c6f0cb455a81 100644\n--- a/net/core/neighbour.c\n+++ b/net/core/neighbour.c\n@@ -690,6 +690,10 @@ ___neigh_create(struct neigh_table *tbl, const void *pkey,\n \t\tgoto out_neigh_release;\n \t}\n \n+\t/* Ensure neighbor object is released on error */\n+out_neigh_release:\n+\tneigh_release(n);\n+\n \tn->confirmed = jiffies - (NEIGH_VAR(n->parms, BASE_REACHABLE_TIME) << 1);\n \n \twrite_lock_bh(&tbl->lock);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "641c688b5c5a0c80d5d5832c5cd9f361c1cbb0a9": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/drivers/usb/gadget/legacy/raw_gadget.c b/drivers/usb/gadget/legacy/raw_gadget.c\nindex 2acece16b890..49bb907e1649 100644\n--- a/drivers/usb/gadget/legacy/raw_gadget.c\n+++ b/drivers/usb/gadget/legacy/raw_gadget.c\n@@ -395,6 +395,13 @@ static int raw_release(struct inode *inode, struct file *fd)\n {\n \tint ret = 0;\n \tstruct raw_dev *dev = fd->private_data;\n+\n+\tif (dev) {\n+\t\tkfree(dev->driver_driver_name);\n+\t\tkfree(dev->udc_driver_name);\n+\t\tkfree(dev->udc_device_name);\n+\t\tkfree(dev);\n+\t}\n \tunsigned long flags;\n \tbool unregister = false;\n \n@@ -487,6 +494,15 @@ static int raw_ioctl_init(struct raw_dev *dev, unsigned long value)\n \t\tgoto out_free_udc_device_name;\n \tret = 0;\n \n+out_free_udc_device_name:\n+\tkfree(udc_device_name);\n+out_free_udc_driver_name:\n+\tkfree(udc_driver_name);\n+out_free_driver_driver_name:\n+\tkfree(driver_driver_name);\n+out_free_driver_id_number:\n+\tida_free(&driver_id_numbers, driver_id_number);\n+\n \tspin_lock_irqsave(&dev->lock, flags);\n \tif (dev->state != STATE_DEV_OPENED) {\n \t\tdev_dbg(dev->dev, \"fail, device is not opened\\n\");\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/usb/gadget/legacy/raw_gadget.c b/drivers/usb/gadget/legacy/raw_gadget.c\nindex 2acece16b890..a410a40b3aac 100644\n--- a/drivers/usb/gadget/legacy/raw_gadget.c\n+++ b/drivers/usb/gadget/legacy/raw_gadget.c\n@@ -388,6 +388,13 @@ static int raw_open(struct inode *inode, struct file *fd)\n \tfd->private_data = dev;\n \tdev->state = STATE_DEV_OPENED;\n \tdev->dev = raw_misc_device.this_device;\n+\n+\t/* Initialize driver_id_number and driver_driver_name */\n+\tdev->driver_id_number = -1;\n+\tdev->driver_driver_name = NULL;\n+\tdev->udc_driver_name = NULL;\n+\tdev->udc_device_name = NULL;\n+\n \treturn 0;\n }\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/usb/gadget/legacy/raw_gadget.c b/drivers/usb/gadget/legacy/raw_gadget.c\nindex 2acece16b890..49bb907e1649 100644\n--- a/drivers/usb/gadget/legacy/raw_gadget.c\n+++ b/drivers/usb/gadget/legacy/raw_gadget.c\n@@ -395,6 +395,13 @@ static int raw_release(struct inode *inode, struct file *fd)\n {\n \tint ret = 0;\n \tstruct raw_dev *dev = fd->private_data;\n+\n+\tif (dev) {\n+\t\tkfree(dev->driver_driver_name);\n+\t\tkfree(dev->udc_driver_name);\n+\t\tkfree(dev->udc_device_name);\n+\t\tkfree(dev);\n+\t}\n \tunsigned long flags;\n \tbool unregister = false;\n \n@@ -487,6 +494,15 @@ static int raw_ioctl_init(struct raw_dev *dev, unsigned long value)\n \t\tgoto out_free_udc_device_name;\n \tret = 0;\n \n+out_free_udc_device_name:\n+\tkfree(udc_device_name);\n+out_free_udc_driver_name:\n+\tkfree(udc_driver_name);\n+out_free_driver_driver_name:\n+\tkfree(driver_driver_name);\n+out_free_driver_id_number:\n+\tida_free(&driver_id_numbers, driver_id_number);\n+\n \tspin_lock_irqsave(&dev->lock, flags);\n \tif (dev->state != STATE_DEV_OPENED) {\n \t\tdev_dbg(dev->dev, \"fail, device is not opened\\n\");\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/usb/gadget/legacy/raw_gadget.c b/drivers/usb/gadget/legacy/raw_gadget.c\nindex 2acece16b890..bad55f921b13 100644\n--- a/drivers/usb/gadget/legacy/raw_gadget.c\n+++ b/drivers/usb/gadget/legacy/raw_gadget.c\n@@ -395,6 +395,15 @@ static int raw_release(struct inode *inode, struct file *fd)\n {\n \tint ret = 0;\n \tstruct raw_dev *dev = fd->private_data;\n+\n+\tif (dev->req) {\n+\t\tusb_ep_free_request(dev->gadget->ep0, dev->req);\n+\t\tdev->req = NULL;\n+\t}\n+\n+\tkfree(dev->driver_driver_name);\n+\tkfree(dev->udc_driver_name);\n+\tkfree(dev->udc_device_name);\n \tunsigned long flags;\n \tbool unregister = false;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/usb/gadget/legacy/raw_gadget.c b/drivers/usb/gadget/legacy/raw_gadget.c\nindex 2acece16b890..1c2dcbf99770 100644\n--- a/drivers/usb/gadget/legacy/raw_gadget.c\n+++ b/drivers/usb/gadget/legacy/raw_gadget.c\n@@ -395,6 +395,17 @@ static int raw_release(struct inode *inode, struct file *fd)\n {\n \tint ret = 0;\n \tstruct raw_dev *dev = fd->private_data;\n+\n+\tif (dev->req) {\n+\t\tusb_ep_free_request(dev->gadget->ep0, dev->req);\n+\t\tdev->req = NULL;\n+\t}\n+\n+\tkfree(dev->driver_driver_name);\n+\tkfree(dev->udc_driver_name);\n+\tkfree(dev->udc_device_name);\n+\n+\tfd->private_data = NULL;\n \tunsigned long flags;\n \tbool unregister = false;\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "f1d54f488af5e3967ea8e664e514cb1c2820db45": {
        "non_crash": [
            "diff --git a/fs/btrfs/extent-io-tree.c b/fs/btrfs/extent-io-tree.c\nindex a630c771d25c..878a3f529b23 100644\n--- a/fs/btrfs/extent-io-tree.c\n+++ b/fs/btrfs/extent-io-tree.c\n@@ -636,14 +636,17 @@ int __clear_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \n \tif (state->start < start) {\n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+\t\t\terr = -ENOMEM;\n+\t\t\tgoto out;\n+\t\t}\n \t\terr = split_state(tree, state, prealloc, start);\n-\t\tif (err)\n+\t\tif (err) {\n \t\t\textent_io_tree_panic(tree, err);\n+\t\t\tgoto out;\n+\t\t}\n \n \t\tprealloc = NULL;\n-\t\tif (err)\n-\t\t\tgoto out;\n \t\tif (state->end <= end) {\n \t\t\tstate = clear_state_bit(tree, state, bits, wake, changeset);\n \t\t\tgoto next;\n@@ -657,10 +660,15 @@ int __clear_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \t */\n \tif (state->start <= end && state->end > end) {\n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+\t\t\terr = -ENOMEM;\n+\t\t\tgoto out;\n+\t\t}\n \t\terr = split_state(tree, state, prealloc, end + 1);\n-\t\tif (err)\n+\t\tif (err) {\n \t\t\textent_io_tree_panic(tree, err);\n+\t\t\tgoto out;\n+\t\t}\n \n \t\tif (wake)\n \t\t\twake_up(&state->wq);\n",
            "diff --git a/fs/btrfs/extent-io-tree.c b/fs/btrfs/extent-io-tree.c\nindex a630c771d25c..878a3f529b23 100644\n--- a/fs/btrfs/extent-io-tree.c\n+++ b/fs/btrfs/extent-io-tree.c\n@@ -636,14 +636,17 @@ int __clear_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \n \tif (state->start < start) {\n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+\t\t\terr = -ENOMEM;\n+\t\t\tgoto out;\n+\t\t}\n \t\terr = split_state(tree, state, prealloc, start);\n-\t\tif (err)\n+\t\tif (err) {\n \t\t\textent_io_tree_panic(tree, err);\n+\t\t\tgoto out;\n+\t\t}\n \n \t\tprealloc = NULL;\n-\t\tif (err)\n-\t\t\tgoto out;\n \t\tif (state->end <= end) {\n \t\t\tstate = clear_state_bit(tree, state, bits, wake, changeset);\n \t\t\tgoto next;\n@@ -657,10 +660,15 @@ int __clear_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \t */\n \tif (state->start <= end && state->end > end) {\n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+\t\t\terr = -ENOMEM;\n+\t\t\tgoto out;\n+\t\t}\n \t\terr = split_state(tree, state, prealloc, end + 1);\n-\t\tif (err)\n+\t\tif (err) {\n \t\t\textent_io_tree_panic(tree, err);\n+\t\t\tgoto out;\n+\t\t}\n \n \t\tif (wake)\n \t\t\twake_up(&state->wq);\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/btrfs/extent-io-tree.c b/fs/btrfs/extent-io-tree.c\nindex a630c771d25c..124f9a6fe2c9 100644\n--- a/fs/btrfs/extent-io-tree.c\n+++ b/fs/btrfs/extent-io-tree.c\n@@ -636,7 +636,10 @@ int __clear_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \n \tif (state->start < start) {\n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+\t\t\terr = -ENOMEM;\n+\t\t\tgoto out;\n+\t\t}\n \t\terr = split_state(tree, state, prealloc, start);\n \t\tif (err)\n \t\t\textent_io_tree_panic(tree, err);\n",
            "diff --git a/fs/btrfs/extent-io-tree.c b/fs/btrfs/extent-io-tree.c\nindex a630c771d25c..124f9a6fe2c9 100644\n--- a/fs/btrfs/extent-io-tree.c\n+++ b/fs/btrfs/extent-io-tree.c\n@@ -636,7 +636,10 @@ int __clear_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \n \tif (state->start < start) {\n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+\t\t\terr = -ENOMEM;\n+\t\t\tgoto out;\n+\t\t}\n \t\terr = split_state(tree, state, prealloc, start);\n \t\tif (err)\n \t\t\textent_io_tree_panic(tree, err);\n",
            "diff --git a/fs/btrfs/extent-io-tree.c b/fs/btrfs/extent-io-tree.c\nindex a630c771d25c..124f9a6fe2c9 100644\n--- a/fs/btrfs/extent-io-tree.c\n+++ b/fs/btrfs/extent-io-tree.c\n@@ -636,7 +636,10 @@ int __clear_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \n \tif (state->start < start) {\n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+\t\t\terr = -ENOMEM;\n+\t\t\tgoto out;\n+\t\t}\n \t\terr = split_state(tree, state, prealloc, start);\n \t\tif (err)\n \t\t\textent_io_tree_panic(tree, err);\n"
        ],
        "error": []
    },
    "4f4531908efc47fa22cc64aacbb920d7afb4e222": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 718ef3987f94..62b348e60678 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2025,8 +2025,8 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\t\t * stable so we can check the additional\n \t\t\t\t * reference fits.\n \t\t\t\t */\n-\t\t\t\tref = le32_to_cpu(BHDR(new_bh)->h_refcount) + 1;\n-\t\t\t\tif (ref > EXT4_XATTR_REFCOUNT_MAX) {\n+\t\t\t\tref = le32_to_cpu(BHDR(new_bh)->h_refcount);\n+\t\t\t\tif (ref >= EXT4_XATTR_REFCOUNT_MAX) {\n \t\t\t\t\t/*\n \t\t\t\t\t * Undo everything and check mbcache\n \t\t\t\t\t * again.\n@@ -2041,6 +2041,7 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\t\t\tnew_bh = NULL;\n \t\t\t\t\tgoto inserted;\n \t\t\t\t}\n+\t\t\t\tref++;\n \t\t\t\tBHDR(new_bh)->h_refcount = cpu_to_le32(ref);\n \t\t\t\tif (ref == EXT4_XATTR_REFCOUNT_MAX)\n \t\t\t\t\tce->e_reusable = 0;\n",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 718ef3987f94..7742609302df 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2025,6 +2025,7 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\t\t * stable so we can check the additional\n \t\t\t\t * reference fits.\n \t\t\t\t */\n+\t\t\t\tlock_buffer(new_bh);\n \t\t\t\tref = le32_to_cpu(BHDR(new_bh)->h_refcount) + 1;\n \t\t\t\tif (ref > EXT4_XATTR_REFCOUNT_MAX) {\n \t\t\t\t\t/*\n",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 718ef3987f94..6117d59338ea 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2025,34 +2025,31 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\t\t * stable so we can check the additional\n \t\t\t\t * reference fits.\n \t\t\t\t */\n-\t\t\t\tref = le32_to_cpu(BHDR(new_bh)->h_refcount) + 1;\n-\t\t\t\tif (ref > EXT4_XATTR_REFCOUNT_MAX) {\n+\t\t\t\tref = le32_to_cpu(BHDR(new_bh)->h_refcount);\n+\t\t\t\tif (ref < EXT4_XATTR_REFCOUNT_MAX) {\n+\t\t\t\t\tref++;\n+\t\t\t\t\tBHDR(new_bh)->h_refcount = cpu_to_le32(ref);\n+\t\t\t\t\tif (ref == EXT4_XATTR_REFCOUNT_MAX)\n+\t\t\t\t\t\tce->e_reusable = 0;\n+\t\t\t\t\tea_bdebug(new_bh, \"reusing; refcount now=%d\", ref);\n+\t\t\t\t\text4_xattr_block_csum_set(inode, new_bh);\n+\t\t\t\t\tunlock_buffer(new_bh);\n+\t\t\t\t\terror = ext4_handle_dirty_metadata(handle, inode, new_bh);\n+\t\t\t\t\tif (error)\n+\t\t\t\t\t\tgoto cleanup_dquot;\n+\t\t\t\t} else {\n \t\t\t\t\t/*\n \t\t\t\t\t * Undo everything and check mbcache\n \t\t\t\t\t * again.\n \t\t\t\t\t */\n \t\t\t\t\tunlock_buffer(new_bh);\n-\t\t\t\t\tdquot_free_block(inode,\n-\t\t\t\t\t\t\t EXT4_C2B(EXT4_SB(sb),\n-\t\t\t\t\t\t\t\t  1));\n+\t\t\t\t\tdquot_free_block(inode, EXT4_C2B(EXT4_SB(sb), 1));\n \t\t\t\t\tbrelse(new_bh);\n \t\t\t\t\tmb_cache_entry_put(ea_block_cache, ce);\n \t\t\t\t\tce = NULL;\n \t\t\t\t\tnew_bh = NULL;\n \t\t\t\t\tgoto inserted;\n \t\t\t\t}\n-\t\t\t\tBHDR(new_bh)->h_refcount = cpu_to_le32(ref);\n-\t\t\t\tif (ref == EXT4_XATTR_REFCOUNT_MAX)\n-\t\t\t\t\tce->e_reusable = 0;\n-\t\t\t\tea_bdebug(new_bh, \"reusing; refcount now=%d\",\n-\t\t\t\t\t  ref);\n-\t\t\t\text4_xattr_block_csum_set(inode, new_bh);\n-\t\t\t\tunlock_buffer(new_bh);\n-\t\t\t\terror = ext4_handle_dirty_metadata(handle,\n-\t\t\t\t\t\t\t\t   inode,\n-\t\t\t\t\t\t\t\t   new_bh);\n-\t\t\t\tif (error)\n-\t\t\t\t\tgoto cleanup_dquot;\n \t\t\t}\n \t\t\tmb_cache_entry_touch(ea_block_cache, ce);\n \t\t\tmb_cache_entry_put(ea_block_cache, ce);\n",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 718ef3987f94..e77b8616a808 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -1875,9 +1875,8 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\t\t\t\t      EXT4_JTR_NONE);\n \t\tif (error)\n \t\t\tgoto cleanup;\n-\t\tlock_buffer(bs->bh);\n-\n \t\tif (header(s->base)->h_refcount == cpu_to_le32(1)) {\n+\t\t\tlock_buffer(bs->bh);\n \t\t\t__u32 hash = le32_to_cpu(BHDR(bs->bh)->h_hash);\n \n \t\t\t/*\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 718ef3987f94..7113bb316579 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -1875,18 +1875,19 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\t\t\t\t      EXT4_JTR_NONE);\n \t\tif (error)\n \t\t\tgoto cleanup;\n-\t\tlock_buffer(bs->bh);\n+\t\tif (bs->bh) {\n+\t\t\tlock_buffer(bs->bh);\n \n-\t\tif (header(s->base)->h_refcount == cpu_to_le32(1)) {\n-\t\t\t__u32 hash = le32_to_cpu(BHDR(bs->bh)->h_hash);\n+\t\t\tif (header(s->base)->h_refcount == cpu_to_le32(1)) {\n+\t\t\t\t__u32 hash = le32_to_cpu(BHDR(bs->bh)->h_hash);\n \n-\t\t\t/*\n-\t\t\t * This must happen under buffer lock for\n-\t\t\t * ext4_xattr_block_set() to reliably detect modified\n-\t\t\t * block\n-\t\t\t */\n-\t\t\tif (ea_block_cache) {\n-\t\t\t\tstruct mb_cache_entry *oe;\n+\t\t\t\t/*\n+\t\t\t\t * This must happen under buffer lock for\n+\t\t\t\t * ext4_xattr_block_set() to reliably detect modified\n+\t\t\t\t * block\n+\t\t\t\t */\n+\t\t\t\tif (ea_block_cache) {\n+\t\t\t\t\tstruct mb_cache_entry *oe;\n \n \t\t\t\toe = mb_cache_entry_delete_or_get(ea_block_cache,\n \t\t\t\t\thash, bs->bh->b_blocknr);\n@@ -2025,23 +2026,29 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\t\t * stable so we can check the additional\n \t\t\t\t * reference fits.\n \t\t\t\t */\n-\t\t\t\tref = le32_to_cpu(BHDR(new_bh)->h_refcount) + 1;\n-\t\t\t\tif (ref > EXT4_XATTR_REFCOUNT_MAX) {\n+\t\t\t\tref = le32_to_cpu(BHDR(new_bh)->h_refcount);\n+\t\t\t\tif (ref < EXT4_XATTR_REFCOUNT_MAX) {\n+\t\t\t\t\tref++;\n+\t\t\t\t\tBHDR(new_bh)->h_refcount = cpu_to_le32(ref);\n+\t\t\t\t\tif (ref == EXT4_XATTR_REFCOUNT_MAX)\n+\t\t\t\t\t\tce->e_reusable = 0;\n+\t\t\t\t\tea_bdebug(new_bh, \"reusing; refcount now=%d\", ref);\n+\t\t\t\t\text4_xattr_block_csum_set(inode, new_bh);\n+\t\t\t\t} else {\n \t\t\t\t\t/*\n \t\t\t\t\t * Undo everything and check mbcache\n \t\t\t\t\t * again.\n \t\t\t\t\t */\n \t\t\t\t\tunlock_buffer(new_bh);\n \t\t\t\t\tdquot_free_block(inode,\n-\t\t\t\t\t\t\t EXT4_C2B(EXT4_SB(sb),\n-\t\t\t\t\t\t\t\t  1));\n+\t\t\t\t\t\t\t\t EXT4_C2B(EXT4_SB(sb),\n+\t\t\t\t\t\t\t\t\t\t  1));\n \t\t\t\t\tbrelse(new_bh);\n \t\t\t\t\tmb_cache_entry_put(ea_block_cache, ce);\n \t\t\t\t\tce = NULL;\n \t\t\t\t\tnew_bh = NULL;\n \t\t\t\t\tgoto inserted;\n \t\t\t\t}\n-\t\t\t\tBHDR(new_bh)->h_refcount = cpu_to_le32(ref);\n \t\t\t\tif (ref == EXT4_XATTR_REFCOUNT_MAX)\n \t\t\t\t\tce->e_reusable = 0;\n \t\t\t\tea_bdebug(new_bh, \"reusing; refcount now=%d\",\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "96e0ffd75bd9a59edf367decb7583c8994e48cd6": {
        "non_crash": [
            "diff --git a/fs/ntfs3/bitmap.c b/fs/ntfs3/bitmap.c\nindex 629c1ee97268..8a11ff0a1458 100644\n--- a/fs/ntfs3/bitmap.c\n+++ b/fs/ntfs3/bitmap.c\n@@ -656,7 +656,12 @@ int wnd_init(struct wnd_bitmap *wnd, struct super_block *sb, size_t nbits)\n \twnd->total_zeroes = nbits;\n \twnd->extent_max = MINUS_ONE_T;\n \twnd->zone_bit = wnd->zone_end = 0;\n+\tu32 max_nwnd = 1024; // Define a reasonable maximum value for nwnd\n \twnd->nwnd = bytes_to_block(sb, bitmap_size(nbits));\n+\tif (wnd->nwnd > max_nwnd) {\n+\t\tpr_warn(\"wnd->nwnd exceeds maximum allowed value\\n\");\n+\t\treturn -EINVAL;\n+\t}\n \twnd->bits_last = nbits & (wbits - 1);\n \tif (!wnd->bits_last)\n \t\twnd->bits_last = wbits;\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ntfs3/bitmap.c b/fs/ntfs3/bitmap.c\nindex 629c1ee97268..1c7ebf87f4b2 100644\n--- a/fs/ntfs3/bitmap.c\n+++ b/fs/ntfs3/bitmap.c\n@@ -661,6 +661,9 @@ int wnd_init(struct wnd_bitmap *wnd, struct super_block *sb, size_t nbits)\n \tif (!wnd->bits_last)\n \t\twnd->bits_last = wbits;\n \n+\tif (wnd->nwnd == 0)\n+\t\treturn -EINVAL;\n+\n \twnd->free_bits = kcalloc(wnd->nwnd, sizeof(u16), GFP_NOFS);\n \tif (!wnd->free_bits)\n \t\treturn -ENOMEM;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/ntfs3/bitmap.c b/fs/ntfs3/bitmap.c\nindex 629c1ee97268..8a0a092ddfe6 100644\n--- a/fs/ntfs3/bitmap.c\n+++ b/fs/ntfs3/bitmap.c\n@@ -661,6 +661,11 @@ int wnd_init(struct wnd_bitmap *wnd, struct super_block *sb, size_t nbits)\n \tif (!wnd->bits_last)\n \t\twnd->bits_last = wbits;\n \n+\tif (wnd->nwnd > MAX_NWND) {\n+\t\tpr_warn(\"wnd->nwnd exceeds maximum allowable size\\n\");\n+\t\treturn -EINVAL;\n+\t}\n+\n \twnd->free_bits = kcalloc(wnd->nwnd, sizeof(u16), GFP_NOFS);\n \tif (!wnd->free_bits)\n \t\treturn -ENOMEM;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/ntfs3/bitmap.c b/fs/ntfs3/bitmap.c\nindex 629c1ee97268..38994202243e 100644\n--- a/fs/ntfs3/bitmap.c\n+++ b/fs/ntfs3/bitmap.c\n@@ -656,7 +656,11 @@ int wnd_init(struct wnd_bitmap *wnd, struct super_block *sb, size_t nbits)\n \twnd->total_zeroes = nbits;\n \twnd->extent_max = MINUS_ONE_T;\n \twnd->zone_bit = wnd->zone_end = 0;\n-\twnd->nwnd = bytes_to_block(sb, bitmap_size(nbits));\n+\tu32 bitmap_bytes = bitmap_size(nbits);\n+\tif (bitmap_bytes == 0 || bitmap_bytes > MAX_BITMAP_SIZE) {\n+\t\treturn -EINVAL;\n+\t}\n+\twnd->nwnd = bytes_to_block(sb, bitmap_bytes);\n \twnd->bits_last = nbits & (wbits - 1);\n \tif (!wnd->bits_last)\n \t\twnd->bits_last = wbits;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/ntfs3/bitmap.c b/fs/ntfs3/bitmap.c\nindex 629c1ee97268..6eb756ce9691 100644\n--- a/fs/ntfs3/bitmap.c\n+++ b/fs/ntfs3/bitmap.c\n@@ -657,6 +657,10 @@ int wnd_init(struct wnd_bitmap *wnd, struct super_block *sb, size_t nbits)\n \twnd->extent_max = MINUS_ONE_T;\n \twnd->zone_bit = wnd->zone_end = 0;\n \twnd->nwnd = bytes_to_block(sb, bitmap_size(nbits));\n+\tif (wnd->nwnd > MAX_NWND) {\n+\t\tpr_warn(\"wnd_init: nwnd exceeds maximum allowed size\\n\");\n+\t\treturn -EINVAL;\n+\t}\n \twnd->bits_last = nbits & (wbits - 1);\n \tif (!wnd->bits_last)\n \t\twnd->bits_last = wbits;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "4d37ad3f55c09b663fe33db0a19fc9684e805a81": {
        "non_crash": [
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 1e7f653c1df7..15da9ba42781 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -194,10 +194,15 @@ void nilfs_dat_commit_end(struct inode *dat, struct nilfs_palloc_req *req,\n \tkaddr = kmap_atomic(req->pr_entry_bh->b_page);\n \tentry = nilfs_palloc_block_get_entry(dat, req->pr_entry_nr,\n \t\t\t\t\t     req->pr_entry_bh, kaddr);\n-\tend = start = le64_to_cpu(entry->de_start);\n+\tstart = le64_to_cpu(entry->de_start);\n \tif (!dead) {\n \t\tend = nilfs_mdt_cno(dat);\n-\t\tWARN_ON(start > end);\n+\t\tif (start > end) {\n+\t\t\tpr_warn(\"nilfs_dat_commit_end: start > end, adjusting start\\n\");\n+\t\t\tstart = end;\n+\t\t}\n+\t} else {\n+\t\tend = start;\n \t}\n \tentry->de_end = cpu_to_le64(end);\n \tblocknr = le64_to_cpu(entry->de_blocknr);\n",
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 1e7f653c1df7..c8c601f1386c 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -197,7 +197,10 @@ void nilfs_dat_commit_end(struct inode *dat, struct nilfs_palloc_req *req,\n \tend = start = le64_to_cpu(entry->de_start);\n \tif (!dead) {\n \t\tend = nilfs_mdt_cno(dat);\n-\t\tWARN_ON(start > end);\n+\t\tif (start > end) {\n+\t\t\tpr_warn(\"nilfs_dat_commit_end: start (%llu) > end (%llu)\\n\", start, end);\n+\t\t\tstart = end; // Adjust start to prevent warning\n+\t\t}\n \t}\n \tentry->de_end = cpu_to_le64(end);\n \tblocknr = le64_to_cpu(entry->de_blocknr);\n",
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 1e7f653c1df7..ea0d8a5070cf 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -194,10 +194,15 @@ void nilfs_dat_commit_end(struct inode *dat, struct nilfs_palloc_req *req,\n \tkaddr = kmap_atomic(req->pr_entry_bh->b_page);\n \tentry = nilfs_palloc_block_get_entry(dat, req->pr_entry_nr,\n \t\t\t\t\t     req->pr_entry_bh, kaddr);\n-\tend = start = le64_to_cpu(entry->de_start);\n+\tstart = le64_to_cpu(entry->de_start);\n \tif (!dead) {\n \t\tend = nilfs_mdt_cno(dat);\n-\t\tWARN_ON(start > end);\n+\t\tif (start > end) {\n+\t\t\tpr_warn(\"nilfs_dat_commit_end: start > end, adjusting end to start\\n\");\n+\t\t\tend = start;\n+\t\t}\n+\t} else {\n+\t\tend = start;\n \t}\n \tentry->de_end = cpu_to_le64(end);\n \tblocknr = le64_to_cpu(entry->de_blocknr);\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "3443d3a1fa6d964dd7310a0cb1696d165a3e07c4": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/video/fbdev/core/sysfillrect.c b/drivers/video/fbdev/core/sysfillrect.c\nindex bcdcaeae6538..2ec0db4c5610 100644\n--- a/drivers/video/fbdev/core/sysfillrect.c\n+++ b/drivers/video/fbdev/core/sysfillrect.c\n@@ -250,9 +250,12 @@ void sys_fillrect(struct fb_info *p, const struct fb_fillrect *rect)\n \n \tpat = pixel_to_pat( bpp, fg);\n \n-\tdst = (unsigned long *)((unsigned long)p->screen_base & ~(bytes-1));\n-\tdst_idx = ((unsigned long)p->screen_base & (bytes - 1))*8;\n-\tdst_idx += rect->dy*p->fix.line_length*8+rect->dx*bpp;\n+\tdst = (unsigned long *)(p->screen_base);\n+\tdst_idx = rect->dy * p->fix.line_length * 8 + rect->dx * bpp;\n+\tif ((dst_idx / 8) >= p->fix.smem_len) {\n+\t\tprintk(KERN_ERR \"cfb_fillrect(): dst_idx out of bounds\\n\");\n+\t\treturn;\n+\t}\n \t/* FIXME For now we support 1-32 bpp only */\n \tleft = bits % bpp;\n \tif (p->fbops->fb_sync)\n",
            "diff --git a/drivers/video/fbdev/core/sysfillrect.c b/drivers/video/fbdev/core/sysfillrect.c\nindex bcdcaeae6538..7b4f336bc8b0 100644\n--- a/drivers/video/fbdev/core/sysfillrect.c\n+++ b/drivers/video/fbdev/core/sysfillrect.c\n@@ -250,9 +250,12 @@ void sys_fillrect(struct fb_info *p, const struct fb_fillrect *rect)\n \n \tpat = pixel_to_pat( bpp, fg);\n \n-\tdst = (unsigned long *)((unsigned long)p->screen_base & ~(bytes-1));\n-\tdst_idx = ((unsigned long)p->screen_base & (bytes - 1))*8;\n-\tdst_idx += rect->dy*p->fix.line_length*8+rect->dx*bpp;\n+\tdst = (unsigned long *)p->screen_base;\n+\tdst_idx = rect->dy * p->fix.line_length * 8 + rect->dx * bpp;\n+\tif ((unsigned long)dst + (dst_idx >> 3) >= (unsigned long)p->screen_base + p->fix.smem_len) {\n+\t\tprintk(KERN_ERR \"cfb_fillrect(): dst out of bounds\\n\");\n+\t\treturn;\n+\t}\n \t/* FIXME For now we support 1-32 bpp only */\n \tleft = bits % bpp;\n \tif (p->fbops->fb_sync)\n",
            "diff --git a/drivers/video/fbdev/core/sysfillrect.c b/drivers/video/fbdev/core/sysfillrect.c\nindex bcdcaeae6538..9f5e2d32289e 100644\n--- a/drivers/video/fbdev/core/sysfillrect.c\n+++ b/drivers/video/fbdev/core/sysfillrect.c\n@@ -250,6 +250,10 @@ void sys_fillrect(struct fb_info *p, const struct fb_fillrect *rect)\n \n \tpat = pixel_to_pat( bpp, fg);\n \n+\tif (!p->screen_base) {\n+\t\tprintk(KERN_ERR \"cfb_fillrect(): screen_base is NULL\\n\");\n+\t\treturn;\n+\t}\n \tdst = (unsigned long *)((unsigned long)p->screen_base & ~(bytes-1));\n \tdst_idx = ((unsigned long)p->screen_base & (bytes - 1))*8;\n \tdst_idx += rect->dy*p->fix.line_length*8+rect->dx*bpp;\n",
            "diff --git a/drivers/video/fbdev/core/sysfillrect.c b/drivers/video/fbdev/core/sysfillrect.c\nindex bcdcaeae6538..52a95cc507c6 100644\n--- a/drivers/video/fbdev/core/sysfillrect.c\n+++ b/drivers/video/fbdev/core/sysfillrect.c\n@@ -250,9 +250,12 @@ void sys_fillrect(struct fb_info *p, const struct fb_fillrect *rect)\n \n \tpat = pixel_to_pat( bpp, fg);\n \n-\tdst = (unsigned long *)((unsigned long)p->screen_base & ~(bytes-1));\n-\tdst_idx = ((unsigned long)p->screen_base & (bytes - 1))*8;\n-\tdst_idx += rect->dy*p->fix.line_length*8+rect->dx*bpp;\n+\tdst = (unsigned long *)((unsigned long)p->screen_base);\n+\tif (!dst) {\n+\t\tprintk(KERN_ERR \"cfb_fillrect(): invalid screen base\\n\");\n+\t\treturn;\n+\t}\n+\tdst_idx = rect->dy * p->fix.line_length * 8 + rect->dx * bpp;\n \t/* FIXME For now we support 1-32 bpp only */\n \tleft = bits % bpp;\n \tif (p->fbops->fb_sync)\n",
            "diff --git a/drivers/video/fbdev/core/sysfillrect.c b/drivers/video/fbdev/core/sysfillrect.c\nindex bcdcaeae6538..c9b111be3d61 100644\n--- a/drivers/video/fbdev/core/sysfillrect.c\n+++ b/drivers/video/fbdev/core/sysfillrect.c\n@@ -250,9 +250,8 @@ void sys_fillrect(struct fb_info *p, const struct fb_fillrect *rect)\n \n \tpat = pixel_to_pat( bpp, fg);\n \n-\tdst = (unsigned long *)((unsigned long)p->screen_base & ~(bytes-1));\n-\tdst_idx = ((unsigned long)p->screen_base & (bytes - 1))*8;\n-\tdst_idx += rect->dy*p->fix.line_length*8+rect->dx*bpp;\n+\tdst = (unsigned long *)((unsigned long)p->screen_base);\n+\tdst_idx = rect->dy * p->fix.line_length + rect->dx * (bpp / 8);\n \t/* FIXME For now we support 1-32 bpp only */\n \tleft = bits % bpp;\n \tif (p->fbops->fb_sync)\n"
        ],
        "error": []
    },
    "b5ecc684bb9e49db213e88f69d4ce80f7e20238d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/nfc/virtual_ncidev.c b/drivers/nfc/virtual_ncidev.c\nindex 85c06dbb2c44..e417dadd4cfd 100644\n--- a/drivers/nfc/virtual_ncidev.c\n+++ b/drivers/nfc/virtual_ncidev.c\n@@ -41,10 +41,12 @@ static int virtual_nci_open(struct nci_dev *ndev)\n \n static int virtual_nci_close(struct nci_dev *ndev)\n {\n+\tmutex_lock(&ndev->req_lock);\n \tmutex_lock(&nci_mutex);\n \tkfree_skb(send_buff);\n \tsend_buff = NULL;\n \tmutex_unlock(&nci_mutex);\n+\tmutex_unlock(&ndev->req_lock);\n \n \treturn 0;\n }\n",
            "diff --git a/drivers/nfc/virtual_ncidev.c b/drivers/nfc/virtual_ncidev.c\nindex 85c06dbb2c44..82fbbe1370eb 100644\n--- a/drivers/nfc/virtual_ncidev.c\n+++ b/drivers/nfc/virtual_ncidev.c\n@@ -41,10 +41,8 @@ static int virtual_nci_open(struct nci_dev *ndev)\n \n static int virtual_nci_close(struct nci_dev *ndev)\n {\n-\tmutex_lock(&nci_mutex);\n \tkfree_skb(send_buff);\n \tsend_buff = NULL;\n-\tmutex_unlock(&nci_mutex);\n \n \treturn 0;\n }\ndiff --git a/net/nfc/nci/core.c b/net/nfc/nci/core.c\nindex dbe5258e13ff..2345b2cefff2 100644\n--- a/net/nfc/nci/core.c\n+++ b/net/nfc/nci/core.c\n@@ -558,8 +558,6 @@ static int nci_close_device(struct nci_dev *ndev)\n \t/* This mutex needs to be held as a barrier for\n \t * caller nci_unregister_device\n \t */\n-\tmutex_lock(&ndev->req_lock);\n-\n \tif (!test_and_clear_bit(NCI_UP, &ndev->flags)) {\n \t\t/* Need to flush the cmd wq in case\n \t\t * there is a queued/running cmd_work\n@@ -567,7 +565,6 @@ static int nci_close_device(struct nci_dev *ndev)\n \t\tflush_workqueue(ndev->cmd_wq);\n \t\tdel_timer_sync(&ndev->cmd_timer);\n \t\tdel_timer_sync(&ndev->data_timer);\n-\t\tmutex_unlock(&ndev->req_lock);\n \t\treturn 0;\n \t}\n \n",
            "diff --git a/drivers/nfc/virtual_ncidev.c b/drivers/nfc/virtual_ncidev.c\nindex 85c06dbb2c44..e417dadd4cfd 100644\n--- a/drivers/nfc/virtual_ncidev.c\n+++ b/drivers/nfc/virtual_ncidev.c\n@@ -41,10 +41,12 @@ static int virtual_nci_open(struct nci_dev *ndev)\n \n static int virtual_nci_close(struct nci_dev *ndev)\n {\n+\tmutex_lock(&ndev->req_lock);\n \tmutex_lock(&nci_mutex);\n \tkfree_skb(send_buff);\n \tsend_buff = NULL;\n \tmutex_unlock(&nci_mutex);\n+\tmutex_unlock(&ndev->req_lock);\n \n \treturn 0;\n }\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/nfc/virtual_ncidev.c b/drivers/nfc/virtual_ncidev.c\nindex 85c06dbb2c44..99f451818b16 100644\n--- a/drivers/nfc/virtual_ncidev.c\n+++ b/drivers/nfc/virtual_ncidev.c\n@@ -41,10 +41,9 @@ static int virtual_nci_open(struct nci_dev *ndev)\n \n static int virtual_nci_close(struct nci_dev *ndev)\n {\n-\tmutex_lock(&nci_mutex);\n+\t/* Ensure nci_mutex is not held while holding &ndev->req_lock */\n \tkfree_skb(send_buff);\n \tsend_buff = NULL;\n-\tmutex_unlock(&nci_mutex);\n \n \treturn 0;\n }\ndiff --git a/net/nfc/nci/core.c b/net/nfc/nci/core.c\nindex dbe5258e13ff..e10158e42b39 100644\n--- a/net/nfc/nci/core.c\n+++ b/net/nfc/nci/core.c\n@@ -568,6 +568,7 @@ static int nci_close_device(struct nci_dev *ndev)\n \t\tdel_timer_sync(&ndev->cmd_timer);\n \t\tdel_timer_sync(&ndev->data_timer);\n \t\tmutex_unlock(&ndev->req_lock);\n+\t\tvirtual_nci_close(ndev); /* Call after releasing req_lock */\n \t\treturn 0;\n \t}\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/nfc/virtual_ncidev.c b/drivers/nfc/virtual_ncidev.c\nindex 85c06dbb2c44..82fbbe1370eb 100644\n--- a/drivers/nfc/virtual_ncidev.c\n+++ b/drivers/nfc/virtual_ncidev.c\n@@ -41,10 +41,8 @@ static int virtual_nci_open(struct nci_dev *ndev)\n \n static int virtual_nci_close(struct nci_dev *ndev)\n {\n-\tmutex_lock(&nci_mutex);\n \tkfree_skb(send_buff);\n \tsend_buff = NULL;\n-\tmutex_unlock(&nci_mutex);\n \n \treturn 0;\n }\ndiff --git a/net/nfc/nci/core.c b/net/nfc/nci/core.c\nindex dbe5258e13ff..2aee858f0e75 100644\n--- a/net/nfc/nci/core.c\n+++ b/net/nfc/nci/core.c\n@@ -568,6 +568,7 @@ static int nci_close_device(struct nci_dev *ndev)\n \t\tdel_timer_sync(&ndev->cmd_timer);\n \t\tdel_timer_sync(&ndev->data_timer);\n \t\tmutex_unlock(&ndev->req_lock);\n+\t\tvirtual_nci_close(ndev); // Call virtual_nci_close after releasing req_lock\n \t\treturn 0;\n \t}\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "2ebf4e2ffdaf022d2aac190c391ecb56689b6fc4": {
        "non_crash": [
            "diff --git a/fs/udf/namei.c b/fs/udf/namei.c\nindex fb4c30e05245..8e186d654783 100644\n--- a/fs/udf/namei.c\n+++ b/fs/udf/namei.c\n@@ -233,12 +233,11 @@ static struct fileIdentDesc *udf_find_entry(struct inode *dir,\n \t\t\tint poffset;\t/* Unpaded ending offset */\n \n \t\t\tpoffset = fibh->soffset + sizeof(struct fileIdentDesc) +\n-\t\t\t\t\tliu + lfi;\n+\t\t\t\t\tliu;\n \n-\t\t\tif (poffset >= lfi)\n-\t\t\t\tnameptr = (uint8_t *)(fibh->ebh->b_data +\n-\t\t\t\t\t\t      poffset - lfi);\n-\t\t\telse {\n+\t\t\tif (poffset + lfi <= fibh->ebh->b_size) {\n+\t\t\t\tnameptr = (uint8_t *)(fibh->ebh->b_data + poffset);\n+\t\t\t} else {\n \t\t\t\tif (!copy_name) {\n \t\t\t\t\tcopy_name = kmalloc(UDF_NAME_LEN,\n \t\t\t\t\t\t\t    GFP_NOFS);\n@@ -249,9 +248,7 @@ static struct fileIdentDesc *udf_find_entry(struct inode *dir,\n \t\t\t\t}\n \t\t\t\tnameptr = copy_name;\n \t\t\t\tmemcpy(nameptr, udf_get_fi_ident(fi),\n-\t\t\t\t\tlfi - poffset);\n-\t\t\t\tmemcpy(nameptr + lfi - poffset,\n-\t\t\t\t\tfibh->ebh->b_data, poffset);\n+\t\t\t\t\tlfi);\n \t\t\t}\n \t\t}\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/udf/namei.c b/fs/udf/namei.c\nindex fb4c30e05245..464be13357b9 100644\n--- a/fs/udf/namei.c\n+++ b/fs/udf/namei.c\n@@ -235,9 +235,9 @@ static struct fileIdentDesc *udf_find_entry(struct inode *dir,\n \t\t\tpoffset = fibh->soffset + sizeof(struct fileIdentDesc) +\n \t\t\t\t\tliu + lfi;\n \n-\t\t\tif (poffset >= lfi)\n+\t\t\tif (poffset >= liu + lfi)\n \t\t\t\tnameptr = (uint8_t *)(fibh->ebh->b_data +\n-\t\t\t\t\t\t      poffset - lfi);\n+\t\t\t\t\t\t      poffset - liu - lfi);\n \t\t\telse {\n \t\t\t\tif (!copy_name) {\n \t\t\t\t\tcopy_name = kmalloc(UDF_NAME_LEN,\n@@ -249,8 +249,8 @@ static struct fileIdentDesc *udf_find_entry(struct inode *dir,\n \t\t\t\t}\n \t\t\t\tnameptr = copy_name;\n \t\t\t\tmemcpy(nameptr, udf_get_fi_ident(fi),\n-\t\t\t\t\tlfi - poffset);\n-\t\t\t\tmemcpy(nameptr + lfi - poffset,\n+\t\t\t\t\tliu + lfi - poffset);\n+\t\t\t\tmemcpy(nameptr + liu + lfi - poffset,\n \t\t\t\t\tfibh->ebh->b_data, poffset);\n \t\t\t}\n \t\t}\n",
            "diff --git a/fs/udf/namei.c b/fs/udf/namei.c\nindex fb4c30e05245..2b7b7972898a 100644\n--- a/fs/udf/namei.c\n+++ b/fs/udf/namei.c\n@@ -235,10 +235,7 @@ static struct fileIdentDesc *udf_find_entry(struct inode *dir,\n \t\t\tpoffset = fibh->soffset + sizeof(struct fileIdentDesc) +\n \t\t\t\t\tliu + lfi;\n \n-\t\t\tif (poffset >= lfi)\n-\t\t\t\tnameptr = (uint8_t *)(fibh->ebh->b_data +\n-\t\t\t\t\t\t      poffset - lfi);\n-\t\t\telse {\n+\t\t\tif (poffset < lfi) {\n \t\t\t\tif (!copy_name) {\n \t\t\t\t\tcopy_name = kmalloc(UDF_NAME_LEN,\n \t\t\t\t\t\t\t    GFP_NOFS);\n@@ -252,6 +249,9 @@ static struct fileIdentDesc *udf_find_entry(struct inode *dir,\n \t\t\t\t\tlfi - poffset);\n \t\t\t\tmemcpy(nameptr + lfi - poffset,\n \t\t\t\t\tfibh->ebh->b_data, poffset);\n+\t\t\t} else {\n+\t\t\t\tnameptr = (uint8_t *)(fibh->ebh->b_data +\n+\t\t\t\t\t\t      poffset - lfi);\n \t\t\t}\n \t\t}\n \n",
            "diff --git a/fs/udf/namei.c b/fs/udf/namei.c\nindex fb4c30e05245..4d5201e6d637 100644\n--- a/fs/udf/namei.c\n+++ b/fs/udf/namei.c\n@@ -235,10 +235,7 @@ static struct fileIdentDesc *udf_find_entry(struct inode *dir,\n \t\t\tpoffset = fibh->soffset + sizeof(struct fileIdentDesc) +\n \t\t\t\t\tliu + lfi;\n \n-\t\t\tif (poffset >= lfi)\n-\t\t\t\tnameptr = (uint8_t *)(fibh->ebh->b_data +\n-\t\t\t\t\t\t      poffset - lfi);\n-\t\t\telse {\n+\t\t\tif (poffset < UDF_NAME_LEN) {\n \t\t\t\tif (!copy_name) {\n \t\t\t\t\tcopy_name = kmalloc(UDF_NAME_LEN,\n \t\t\t\t\t\t\t    GFP_NOFS);\n@@ -249,9 +246,12 @@ static struct fileIdentDesc *udf_find_entry(struct inode *dir,\n \t\t\t\t}\n \t\t\t\tnameptr = copy_name;\n \t\t\t\tmemcpy(nameptr, udf_get_fi_ident(fi),\n-\t\t\t\t\tlfi - poffset);\n-\t\t\t\tmemcpy(nameptr + lfi - poffset,\n+\t\t\t\t\tUDF_NAME_LEN - poffset);\n+\t\t\t\tmemcpy(nameptr + UDF_NAME_LEN - poffset,\n \t\t\t\t\tfibh->ebh->b_data, poffset);\n+\t\t\t} else {\n+\t\t\t\tnameptr = (uint8_t *)(fibh->ebh->b_data +\n+\t\t\t\t\t\t      poffset - UDF_NAME_LEN);\n \t\t\t}\n \t\t}\n \n",
            "diff --git a/fs/udf/namei.c b/fs/udf/namei.c\nindex fb4c30e05245..5f4549ae8a11 100644\n--- a/fs/udf/namei.c\n+++ b/fs/udf/namei.c\n@@ -235,10 +235,15 @@ static struct fileIdentDesc *udf_find_entry(struct inode *dir,\n \t\t\tpoffset = fibh->soffset + sizeof(struct fileIdentDesc) +\n \t\t\t\t\tliu + lfi;\n \n-\t\t\tif (poffset >= lfi)\n-\t\t\t\tnameptr = (uint8_t *)(fibh->ebh->b_data +\n-\t\t\t\t\t\t      poffset - lfi);\n-\t\t\telse {\n+\t\t\tif (poffset >= lfi) {\n+\t\t\t\tif (poffset - lfi < fibh->ebh->b_size) {\n+\t\t\t\t\tnameptr = (uint8_t *)(fibh->ebh->b_data +\n+\t\t\t\t\t\t\t      poffset - lfi);\n+\t\t\t\t} else {\n+\t\t\t\t\tfi = ERR_PTR(-EFAULT);\n+\t\t\t\t\tgoto out_err;\n+\t\t\t\t}\n+\t\t\t} else {\n \t\t\t\tif (!copy_name) {\n \t\t\t\t\tcopy_name = kmalloc(UDF_NAME_LEN,\n \t\t\t\t\t\t\t    GFP_NOFS);\n@@ -247,11 +252,16 @@ static struct fileIdentDesc *udf_find_entry(struct inode *dir,\n \t\t\t\t\t\tgoto out_err;\n \t\t\t\t\t}\n \t\t\t\t}\n-\t\t\t\tnameptr = copy_name;\n-\t\t\t\tmemcpy(nameptr, udf_get_fi_ident(fi),\n-\t\t\t\t\tlfi - poffset);\n-\t\t\t\tmemcpy(nameptr + lfi - poffset,\n-\t\t\t\t\tfibh->ebh->b_data, poffset);\n+\t\t\t\tif (lfi - poffset <= UDF_NAME_LEN) {\n+\t\t\t\t\tnameptr = copy_name;\n+\t\t\t\t\tmemcpy(nameptr, udf_get_fi_ident(fi),\n+\t\t\t\t\t\tlfi - poffset);\n+\t\t\t\t\tmemcpy(nameptr + lfi - poffset,\n+\t\t\t\t\t\tfibh->ebh->b_data, poffset);\n+\t\t\t\t} else {\n+\t\t\t\t\tfi = ERR_PTR(-EFAULT);\n+\t\t\t\t\tgoto out_err;\n+\t\t\t\t}\n \t\t\t}\n \t\t}\n \n"
        ],
        "error": []
    },
    "7ba391f8e821454d748011f0dbd3ed0f862dfb78": {
        "non_crash": [
            "diff --git a/io_uring/cancel.c b/io_uring/cancel.c\nindex 2291a53cdabd..5bb7c72e3876 100644\n--- a/io_uring/cancel.c\n+++ b/io_uring/cancel.c\n@@ -291,6 +291,7 @@ int io_sync_cancel(struct io_ring_ctx *ctx, void __user *arg)\n \t\tif (ret != -EALREADY)\n \t\t\tbreak;\n \n+\t\t__set_current_state(TASK_RUNNING);\n \t\tmutex_unlock(&ctx->uring_lock);\n \t\tret = io_run_task_work_sig(ctx);\n \t\tif (ret < 0) {\n",
            "diff --git a/io_uring/cancel.c b/io_uring/cancel.c\nindex 2291a53cdabd..1463f0a5520d 100644\n--- a/io_uring/cancel.c\n+++ b/io_uring/cancel.c\n@@ -284,7 +284,7 @@ int io_sync_cancel(struct io_ring_ctx *ctx, void __user *arg)\n \tdo {\n \t\tcd.seq = atomic_inc_return(&ctx->cancel_seq);\n \n-\t\tprepare_to_wait(&ctx->cq_wait, &wait, TASK_INTERRUPTIBLE);\n+\t\tprepare_to_wait(&ctx->cq_wait, &wait, TASK_RUNNING);\n \n \t\tret = __io_sync_cancel(current->io_uring, &cd, sc.fd);\n \n",
            "diff --git a/io_uring/cancel.c b/io_uring/cancel.c\nindex 2291a53cdabd..c70567157632 100644\n--- a/io_uring/cancel.c\n+++ b/io_uring/cancel.c\n@@ -286,6 +286,7 @@ int io_sync_cancel(struct io_ring_ctx *ctx, void __user *arg)\n \n \t\tprepare_to_wait(&ctx->cq_wait, &wait, TASK_INTERRUPTIBLE);\n \n+\t\t__set_current_state(TASK_RUNNING);\n \t\tret = __io_sync_cancel(current->io_uring, &cd, sc.fd);\n \n \t\tif (ret != -EALREADY)\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/io_uring/cancel.c b/io_uring/cancel.c\nindex 2291a53cdabd..5d8872cb8bf2 100644\n--- a/io_uring/cancel.c\n+++ b/io_uring/cancel.c\n@@ -297,6 +297,7 @@ int io_sync_cancel(struct io_ring_ctx *ctx, void __user *arg)\n \t\t\tmutex_lock(&ctx->uring_lock);\n \t\t\tbreak;\n \t\t}\n+\t\t__set_current_state(TASK_RUNNING);\n \t\tret = schedule_hrtimeout(&timeout, HRTIMER_MODE_ABS);\n \t\tmutex_lock(&ctx->uring_lock);\n \t\tif (!ret) {\n",
            "diff --git a/io_uring/cancel.c b/io_uring/cancel.c\nindex 2291a53cdabd..813a016b277f 100644\n--- a/io_uring/cancel.c\n+++ b/io_uring/cancel.c\n@@ -262,7 +262,8 @@ int io_sync_cancel(struct io_ring_ctx *ctx, void __user *arg)\n \t\tcd.file = f.file;\n \t}\n \n-\tret = __io_sync_cancel(current->io_uring, &cd, sc.fd);\n+\tset_current_state(TASK_RUNNING);\n+\t\tret = __io_sync_cancel(current->io_uring, &cd, sc.fd);\n \n \t/* found something, done! */\n \tif (ret != -EALREADY)\n"
        ],
        "error": []
    },
    "1f07634f79ac1436ec38e2e71d73392404b17bbb": {
        "non_crash": [
            "diff --git a/fs/quota/quota.c b/fs/quota/quota.c\nindex 052f143e2e0e..ad7dab83f8f1 100644\n--- a/fs/quota/quota.c\n+++ b/fs/quota/quota.c\n@@ -986,18 +986,23 @@ SYSCALL_DEFINE4(quotactl_fd, unsigned int, fd, unsigned int, cmd,\n \tif (type >= MAXQUOTAS)\n \t\tgoto out;\n \n-\tif (quotactl_cmd_write(cmds)) {\n-\t\tret = mnt_want_write(f.file->f_path.mnt);\n-\t\tif (ret)\n-\t\t\tgoto out;\n-\t}\n-\n \tsb = f.file->f_path.mnt->mnt_sb;\n \tif (quotactl_cmd_onoff(cmds))\n \t\tdown_write(&sb->s_umount);\n \telse\n \t\tdown_read(&sb->s_umount);\n \n+\tif (quotactl_cmd_write(cmds)) {\n+\t\tret = mnt_want_write(f.file->f_path.mnt);\n+\t\tif (ret) {\n+\t\t\tif (quotactl_cmd_onoff(cmds))\n+\t\t\t\tup_write(&sb->s_umount);\n+\t\t\telse\n+\t\t\t\tup_read(&sb->s_umount);\n+\t\t\tgoto out;\n+\t\t}\n+\t}\n+\n \tret = do_quotactl(sb, type, cmds, id, addr, ERR_PTR(-EINVAL));\n \n \tif (quotactl_cmd_onoff(cmds))\n",
            "diff --git a/fs/quota/quota.c b/fs/quota/quota.c\nindex 052f143e2e0e..ad7dab83f8f1 100644\n--- a/fs/quota/quota.c\n+++ b/fs/quota/quota.c\n@@ -986,18 +986,23 @@ SYSCALL_DEFINE4(quotactl_fd, unsigned int, fd, unsigned int, cmd,\n \tif (type >= MAXQUOTAS)\n \t\tgoto out;\n \n-\tif (quotactl_cmd_write(cmds)) {\n-\t\tret = mnt_want_write(f.file->f_path.mnt);\n-\t\tif (ret)\n-\t\t\tgoto out;\n-\t}\n-\n \tsb = f.file->f_path.mnt->mnt_sb;\n \tif (quotactl_cmd_onoff(cmds))\n \t\tdown_write(&sb->s_umount);\n \telse\n \t\tdown_read(&sb->s_umount);\n \n+\tif (quotactl_cmd_write(cmds)) {\n+\t\tret = mnt_want_write(f.file->f_path.mnt);\n+\t\tif (ret) {\n+\t\t\tif (quotactl_cmd_onoff(cmds))\n+\t\t\t\tup_write(&sb->s_umount);\n+\t\t\telse\n+\t\t\t\tup_read(&sb->s_umount);\n+\t\t\tgoto out;\n+\t\t}\n+\t}\n+\n \tret = do_quotactl(sb, type, cmds, id, addr, ERR_PTR(-EINVAL));\n \n \tif (quotactl_cmd_onoff(cmds))\n",
            "diff --git a/fs/quota/quota.c b/fs/quota/quota.c\nindex 052f143e2e0e..d297043e9a5c 100644\n--- a/fs/quota/quota.c\n+++ b/fs/quota/quota.c\n@@ -986,18 +986,24 @@ SYSCALL_DEFINE4(quotactl_fd, unsigned int, fd, unsigned int, cmd,\n \tif (type >= MAXQUOTAS)\n \t\tgoto out;\n \n-\tif (quotactl_cmd_write(cmds)) {\n-\t\tret = mnt_want_write(f.file->f_path.mnt);\n-\t\tif (ret)\n-\t\t\tgoto out;\n-\t}\n-\n \tsb = f.file->f_path.mnt->mnt_sb;\n+\n \tif (quotactl_cmd_onoff(cmds))\n \t\tdown_write(&sb->s_umount);\n \telse\n \t\tdown_read(&sb->s_umount);\n \n+\tif (quotactl_cmd_write(cmds)) {\n+\t\tret = mnt_want_write(f.file->f_path.mnt);\n+\t\tif (ret) {\n+\t\t\tif (quotactl_cmd_onoff(cmds))\n+\t\t\t\tup_write(&sb->s_umount);\n+\t\t\telse\n+\t\t\t\tup_read(&sb->s_umount);\n+\t\t\tgoto out;\n+\t\t}\n+\t}\n+\n \tret = do_quotactl(sb, type, cmds, id, addr, ERR_PTR(-EINVAL));\n \n \tif (quotactl_cmd_onoff(cmds))\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/quota/quota.c b/fs/quota/quota.c\nindex 052f143e2e0e..514cfbb1e9ef 100644\n--- a/fs/quota/quota.c\n+++ b/fs/quota/quota.c\n@@ -993,17 +993,21 @@ SYSCALL_DEFINE4(quotactl_fd, unsigned int, fd, unsigned int, cmd,\n \t}\n \n \tsb = f.file->f_path.mnt->mnt_sb;\n-\tif (quotactl_cmd_onoff(cmds))\n-\t\tdown_write(&sb->s_umount);\n-\telse\n-\t\tdown_read(&sb->s_umount);\n-\n-\tret = do_quotactl(sb, type, cmds, id, addr, ERR_PTR(-EINVAL));\n+\tif (quotactl_cmd_write(cmds)) {\n+\t\tret = mnt_want_write(f.file->f_path.mnt);\n+\t\tif (ret)\n+\t\t\tgoto out;\n+\t}\n \n-\tif (quotactl_cmd_onoff(cmds))\n+\tif (quotactl_cmd_onoff(cmds)) {\n+\t\tdown_write(&sb->s_umount);\n+\t\tret = do_quotactl(sb, type, cmds, id, addr, ERR_PTR(-EINVAL));\n \t\tup_write(&sb->s_umount);\n-\telse\n+\t} else {\n+\t\tdown_read(&sb->s_umount);\n+\t\tret = do_quotactl(sb, type, cmds, id, addr, ERR_PTR(-EINVAL));\n \t\tup_read(&sb->s_umount);\n+\t}\n \n \tif (quotactl_cmd_write(cmds))\n \t\tmnt_drop_write(f.file->f_path.mnt);\n",
            "diff --git a/fs/quota/quota.c b/fs/quota/quota.c\nindex 052f143e2e0e..ee2dad34abc3 100644\n--- a/fs/quota/quota.c\n+++ b/fs/quota/quota.c\n@@ -993,6 +993,12 @@ SYSCALL_DEFINE4(quotactl_fd, unsigned int, fd, unsigned int, cmd,\n \t}\n \n \tsb = f.file->f_path.mnt->mnt_sb;\n+\tif (quotactl_cmd_write(cmds)) {\n+\t\tret = mnt_want_write(f.file->f_path.mnt);\n+\t\tif (ret)\n+\t\t\tgoto out;\n+\t}\n+\n \tif (quotactl_cmd_onoff(cmds))\n \t\tdown_write(&sb->s_umount);\n \telse\n"
        ],
        "error": []
    },
    "dad6a582c4d54162ae8d096210ca126b659fd8c0": {
        "non_crash": [
            "diff --git a/fs/hfs/bfind.c b/fs/hfs/bfind.c\nindex ef9498a6e88a..f549d9b1cb48 100644\n--- a/fs/hfs/bfind.c\n+++ b/fs/hfs/bfind.c\n@@ -20,6 +20,7 @@ int hfs_find_init(struct hfs_btree *tree, struct hfs_find_data *fd)\n \tfd->bnode = NULL;\n \tptr = kmalloc(tree->max_key_len * 2 + 4, GFP_KERNEL);\n \tif (!ptr)\n+\t\tmutex_unlock(&tree->tree_lock);\n \t\treturn -ENOMEM;\n \tfd->search_key = ptr;\n \tfd->key = ptr + tree->max_key_len + 2;\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/hfs/bfind.c b/fs/hfs/bfind.c\nindex ef9498a6e88a..67c434ef0326 100644\n--- a/fs/hfs/bfind.c\n+++ b/fs/hfs/bfind.c\n@@ -38,6 +38,11 @@ int hfs_find_init(struct hfs_btree *tree, struct hfs_find_data *fd)\n \tdefault:\n \t\treturn -EINVAL;\n \t}\n+\t// Release the lock before workqueue operation\n+\tmutex_unlock(&tree->tree_lock);\n+\t// Perform workqueue operation here\n+\t// Reacquire the lock if necessary\n+\tmutex_lock(&tree->tree_lock);\n \treturn 0;\n }\n \n",
            "diff --git a/fs/hfs/bfind.c b/fs/hfs/bfind.c\nindex ef9498a6e88a..f9cd23bbe9b2 100644\n--- a/fs/hfs/bfind.c\n+++ b/fs/hfs/bfind.c\n@@ -27,13 +27,13 @@ int hfs_find_init(struct hfs_btree *tree, struct hfs_find_data *fd)\n \t\ttree->cnid, __builtin_return_address(0));\n \tswitch (tree->cnid) {\n \tcase HFS_CAT_CNID:\n-\t\tmutex_lock_nested(&tree->tree_lock, CATALOG_BTREE_MUTEX);\n+\t\tmutex_lock(&tree->tree_lock);\n \t\tbreak;\n \tcase HFS_EXT_CNID:\n-\t\tmutex_lock_nested(&tree->tree_lock, EXTENTS_BTREE_MUTEX);\n+\t\tmutex_lock(&tree->tree_lock);\n \t\tbreak;\n \tcase HFS_ATTR_CNID:\n-\t\tmutex_lock_nested(&tree->tree_lock, ATTR_BTREE_MUTEX);\n+\t\tmutex_lock(&tree->tree_lock);\n \t\tbreak;\n \tdefault:\n \t\treturn -EINVAL;\ndiff --git a/kernel/workqueue.c b/kernel/workqueue.c\nindex 7cd5f5e7e0a1..0a30bed4b7f7 100644\n--- a/kernel/workqueue.c\n+++ b/kernel/workqueue.c\n@@ -2257,10 +2257,10 @@ __acquires(&pool->lock)\n \t * PENDING and queued state changes happen together while IRQ is\n \t * disabled.\n \t */\n-\tset_work_pool_and_clear_pending(work, pool->id);\n-\n \traw_spin_unlock_irq(&pool->lock);\n \n+\tset_work_pool_and_clear_pending(work, pool->id);\n+\n \tlock_map_acquire(&pwq->wq->lockdep_map);\n \tlock_map_acquire(&lockdep_map);\n \t/*\n",
            "diff --git a/fs/hfs/bfind.c b/fs/hfs/bfind.c\nindex ef9498a6e88a..f9cd23bbe9b2 100644\n--- a/fs/hfs/bfind.c\n+++ b/fs/hfs/bfind.c\n@@ -27,13 +27,13 @@ int hfs_find_init(struct hfs_btree *tree, struct hfs_find_data *fd)\n \t\ttree->cnid, __builtin_return_address(0));\n \tswitch (tree->cnid) {\n \tcase HFS_CAT_CNID:\n-\t\tmutex_lock_nested(&tree->tree_lock, CATALOG_BTREE_MUTEX);\n+\t\tmutex_lock(&tree->tree_lock);\n \t\tbreak;\n \tcase HFS_EXT_CNID:\n-\t\tmutex_lock_nested(&tree->tree_lock, EXTENTS_BTREE_MUTEX);\n+\t\tmutex_lock(&tree->tree_lock);\n \t\tbreak;\n \tcase HFS_ATTR_CNID:\n-\t\tmutex_lock_nested(&tree->tree_lock, ATTR_BTREE_MUTEX);\n+\t\tmutex_lock(&tree->tree_lock);\n \t\tbreak;\n \tdefault:\n \t\treturn -EINVAL;\ndiff --git a/kernel/workqueue.c b/kernel/workqueue.c\nindex 7cd5f5e7e0a1..0a30bed4b7f7 100644\n--- a/kernel/workqueue.c\n+++ b/kernel/workqueue.c\n@@ -2257,10 +2257,10 @@ __acquires(&pool->lock)\n \t * PENDING and queued state changes happen together while IRQ is\n \t * disabled.\n \t */\n-\tset_work_pool_and_clear_pending(work, pool->id);\n-\n \traw_spin_unlock_irq(&pool->lock);\n \n+\tset_work_pool_and_clear_pending(work, pool->id);\n+\n \tlock_map_acquire(&pwq->wq->lockdep_map);\n \tlock_map_acquire(&lockdep_map);\n \t/*\n",
            "diff --git a/fs/hfs/bfind.c b/fs/hfs/bfind.c\nindex ef9498a6e88a..f9cd23bbe9b2 100644\n--- a/fs/hfs/bfind.c\n+++ b/fs/hfs/bfind.c\n@@ -27,13 +27,13 @@ int hfs_find_init(struct hfs_btree *tree, struct hfs_find_data *fd)\n \t\ttree->cnid, __builtin_return_address(0));\n \tswitch (tree->cnid) {\n \tcase HFS_CAT_CNID:\n-\t\tmutex_lock_nested(&tree->tree_lock, CATALOG_BTREE_MUTEX);\n+\t\tmutex_lock(&tree->tree_lock);\n \t\tbreak;\n \tcase HFS_EXT_CNID:\n-\t\tmutex_lock_nested(&tree->tree_lock, EXTENTS_BTREE_MUTEX);\n+\t\tmutex_lock(&tree->tree_lock);\n \t\tbreak;\n \tcase HFS_ATTR_CNID:\n-\t\tmutex_lock_nested(&tree->tree_lock, ATTR_BTREE_MUTEX);\n+\t\tmutex_lock(&tree->tree_lock);\n \t\tbreak;\n \tdefault:\n \t\treturn -EINVAL;\ndiff --git a/kernel/workqueue.c b/kernel/workqueue.c\nindex 7cd5f5e7e0a1..dae3f4ce60a9 100644\n--- a/kernel/workqueue.c\n+++ b/kernel/workqueue.c\n@@ -2257,12 +2257,12 @@ __acquires(&pool->lock)\n \t * PENDING and queued state changes happen together while IRQ is\n \t * disabled.\n \t */\n-\tset_work_pool_and_clear_pending(work, pool->id);\n-\n \traw_spin_unlock_irq(&pool->lock);\n \n \tlock_map_acquire(&pwq->wq->lockdep_map);\n \tlock_map_acquire(&lockdep_map);\n+\n+\tset_work_pool_and_clear_pending(work, pool->id);\n \t/*\n \t * Strictly speaking we should mark the invariant state without holding\n \t * any locks, that is, before these two lock_map_acquire()'s.\n"
        ],
        "error": []
    },
    "17535f4bf5b322437f7c639b59161ce343fc55a9": {
        "non_crash": [
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex 2fcab61b8ff5..e40ceae71a1a 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -239,9 +239,11 @@ static void __vb2_buf_mem_free(struct vb2_buffer *vb)\n \tunsigned int plane;\n \n \tfor (plane = 0; plane < vb->num_planes; ++plane) {\n-\t\tcall_void_memop(vb, put, vb->planes[plane].mem_priv);\n-\t\tvb->planes[plane].mem_priv = NULL;\n-\t\tdprintk(3, \"freed plane %d of buffer %d\\n\", plane, vb->index);\n+\t\tif (vb->planes[plane].mem_priv) {\n+\t\t\tcall_void_memop(vb, put, vb->planes[plane].mem_priv);\n+\t\t\tvb->planes[plane].mem_priv = NULL;\n+\t\t\tdprintk(3, \"freed plane %d of buffer %d\\n\", plane, vb->index);\n+\t\t}\n \t}\n }\n \n",
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex 2fcab61b8ff5..e40ceae71a1a 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -239,9 +239,11 @@ static void __vb2_buf_mem_free(struct vb2_buffer *vb)\n \tunsigned int plane;\n \n \tfor (plane = 0; plane < vb->num_planes; ++plane) {\n-\t\tcall_void_memop(vb, put, vb->planes[plane].mem_priv);\n-\t\tvb->planes[plane].mem_priv = NULL;\n-\t\tdprintk(3, \"freed plane %d of buffer %d\\n\", plane, vb->index);\n+\t\tif (vb->planes[plane].mem_priv) {\n+\t\t\tcall_void_memop(vb, put, vb->planes[plane].mem_priv);\n+\t\t\tvb->planes[plane].mem_priv = NULL;\n+\t\t\tdprintk(3, \"freed plane %d of buffer %d\\n\", plane, vb->index);\n+\t\t}\n \t}\n }\n \n",
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex 2fcab61b8ff5..e40ceae71a1a 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -239,9 +239,11 @@ static void __vb2_buf_mem_free(struct vb2_buffer *vb)\n \tunsigned int plane;\n \n \tfor (plane = 0; plane < vb->num_planes; ++plane) {\n-\t\tcall_void_memop(vb, put, vb->planes[plane].mem_priv);\n-\t\tvb->planes[plane].mem_priv = NULL;\n-\t\tdprintk(3, \"freed plane %d of buffer %d\\n\", plane, vb->index);\n+\t\tif (vb->planes[plane].mem_priv) {\n+\t\t\tcall_void_memop(vb, put, vb->planes[plane].mem_priv);\n+\t\t\tvb->planes[plane].mem_priv = NULL;\n+\t\t\tdprintk(3, \"freed plane %d of buffer %d\\n\", plane, vb->index);\n+\t\t}\n \t}\n }\n \n",
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex 2fcab61b8ff5..e40ceae71a1a 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -239,9 +239,11 @@ static void __vb2_buf_mem_free(struct vb2_buffer *vb)\n \tunsigned int plane;\n \n \tfor (plane = 0; plane < vb->num_planes; ++plane) {\n-\t\tcall_void_memop(vb, put, vb->planes[plane].mem_priv);\n-\t\tvb->planes[plane].mem_priv = NULL;\n-\t\tdprintk(3, \"freed plane %d of buffer %d\\n\", plane, vb->index);\n+\t\tif (vb->planes[plane].mem_priv) {\n+\t\t\tcall_void_memop(vb, put, vb->planes[plane].mem_priv);\n+\t\t\tvb->planes[plane].mem_priv = NULL;\n+\t\t\tdprintk(3, \"freed plane %d of buffer %d\\n\", plane, vb->index);\n+\t\t}\n \t}\n }\n \n",
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex 2fcab61b8ff5..e40ceae71a1a 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -239,9 +239,11 @@ static void __vb2_buf_mem_free(struct vb2_buffer *vb)\n \tunsigned int plane;\n \n \tfor (plane = 0; plane < vb->num_planes; ++plane) {\n-\t\tcall_void_memop(vb, put, vb->planes[plane].mem_priv);\n-\t\tvb->planes[plane].mem_priv = NULL;\n-\t\tdprintk(3, \"freed plane %d of buffer %d\\n\", plane, vb->index);\n+\t\tif (vb->planes[plane].mem_priv) {\n+\t\t\tcall_void_memop(vb, put, vb->planes[plane].mem_priv);\n+\t\t\tvb->planes[plane].mem_priv = NULL;\n+\t\t\tdprintk(3, \"freed plane %d of buffer %d\\n\", plane, vb->index);\n+\t\t}\n \t}\n }\n \n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "0b6b2d6d6cefa8b462930e55be699efba635788f": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 63d032191e62..938379e3dfa3 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -470,12 +470,14 @@ static void __nf_unregister_net_hook(struct net *net, int pf,\n \t\treturn;\n \t}\n \n-\tif (nf_remove_net_hook(p, reg)) {\n+\tif (p && nf_remove_net_hook(p, reg)) {\n #ifdef CONFIG_NETFILTER_INGRESS\n \t\tif (nf_ingress_hook(reg, pf))\n \t\t\tnet_dec_ingress_queue();\n #endif\n \t\tnf_static_key_dec(reg, pf);\n+\t} else if (!p) {\n+\t\tWARN_ONCE(1, \"hook entries not found, pf %d num %d\", pf, reg->hooknum);\n \t} else {\n \t\tWARN_ONCE(1, \"hook not found, pf %d num %d\", pf, reg->hooknum);\n \t}\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 63d032191e62..aadf2f00a0a4 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -465,7 +465,8 @@ static void __nf_unregister_net_hook(struct net *net, int pf,\n \tmutex_lock(&nf_hook_mutex);\n \n \tp = nf_entry_dereference(*pp);\n-\tif (WARN_ON_ONCE(!p)) {\n+\tif (!p) {\n+\t\tWARN_ON_ONCE(1, \"hook list is empty or hook not found, pf %d num %d\", pf, reg->hooknum);\n \t\tmutex_unlock(&nf_hook_mutex);\n \t\treturn;\n \t}\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 63d032191e62..7463f679469a 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -465,7 +465,8 @@ static void __nf_unregister_net_hook(struct net *net, int pf,\n \tmutex_lock(&nf_hook_mutex);\n \n \tp = nf_entry_dereference(*pp);\n-\tif (WARN_ON_ONCE(!p)) {\n+\tif (!p) {\n+\t\tWARN_ON_ONCE(1, \"hook not found, pf %d num %d\", pf, reg->hooknum);\n \t\tmutex_unlock(&nf_hook_mutex);\n \t\treturn;\n \t}\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 63d032191e62..7463f679469a 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -465,7 +465,8 @@ static void __nf_unregister_net_hook(struct net *net, int pf,\n \tmutex_lock(&nf_hook_mutex);\n \n \tp = nf_entry_dereference(*pp);\n-\tif (WARN_ON_ONCE(!p)) {\n+\tif (!p) {\n+\t\tWARN_ON_ONCE(1, \"hook not found, pf %d num %d\", pf, reg->hooknum);\n \t\tmutex_unlock(&nf_hook_mutex);\n \t\treturn;\n \t}\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 63d032191e62..46078d5dc00a 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -465,12 +465,13 @@ static void __nf_unregister_net_hook(struct net *net, int pf,\n \tmutex_lock(&nf_hook_mutex);\n \n \tp = nf_entry_dereference(*pp);\n-\tif (WARN_ON_ONCE(!p)) {\n+\tif (!p) {\n+\t\tWARN_ON_ONCE(1, \"hook list is empty, pf %d num %d\", pf, reg->hooknum);\n \t\tmutex_unlock(&nf_hook_mutex);\n \t\treturn;\n \t}\n \n-\tif (nf_remove_net_hook(p, reg)) {\n+\tif (p && nf_remove_net_hook(p, reg)) {\n #ifdef CONFIG_NETFILTER_INGRESS\n \t\tif (nf_ingress_hook(reg, pf))\n \t\t\tnet_dec_ingress_queue();\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "4649ea695ca98903ae82280a3b7aa97dbeb7fd07": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/include/net/nexthop.h b/include/net/nexthop.h\nindex 3a4f9e3b91a5..14c4835cef24 100644\n--- a/include/net/nexthop.h\n+++ b/include/net/nexthop.h\n@@ -227,18 +227,21 @@ static inline bool nexthop_is_blackhole(const struct nexthop *nh)\n {\n \tconst struct nh_info *nhi;\n \n-\tif (nh->is_group) {\n+\tif (nh && nh->is_group) {\n \t\tstruct nh_group *nh_grp;\n \n \t\tnh_grp = rcu_dereference_rtnl(nh->nh_grp);\n-\t\tif (nh_grp->num_nh > 1)\n+\t\tif (nh_grp && nh_grp->num_nh > 1)\n \t\t\treturn false;\n \n \t\tnh = nh_grp->nh_entries[0].nh;\n \t}\n \n+\tif (!nh)\n+\t\treturn false;\n+\n \tnhi = rcu_dereference_rtnl(nh->nh_info);\n-\treturn nhi->reject_nh;\n+\treturn nhi ? nhi->reject_nh : false;\n }\n \n static inline void nexthop_path_fib_result(struct fib_result *res, int hash)\n",
            "diff --git a/include/net/nexthop.h b/include/net/nexthop.h\nindex 3a4f9e3b91a5..c0d858a9b769 100644\n--- a/include/net/nexthop.h\n+++ b/include/net/nexthop.h\n@@ -238,6 +238,8 @@ static inline bool nexthop_is_blackhole(const struct nexthop *nh)\n \t}\n \n \tnhi = rcu_dereference_rtnl(nh->nh_info);\n+\tif (!nhi)\n+\t\treturn false;\n \treturn nhi->reject_nh;\n }\n \n",
            "diff --git a/include/net/nexthop.h b/include/net/nexthop.h\nindex 3a4f9e3b91a5..c0d858a9b769 100644\n--- a/include/net/nexthop.h\n+++ b/include/net/nexthop.h\n@@ -238,6 +238,8 @@ static inline bool nexthop_is_blackhole(const struct nexthop *nh)\n \t}\n \n \tnhi = rcu_dereference_rtnl(nh->nh_info);\n+\tif (!nhi)\n+\t\treturn false;\n \treturn nhi->reject_nh;\n }\n \n",
            "diff --git a/include/net/nexthop.h b/include/net/nexthop.h\nindex 3a4f9e3b91a5..c0d858a9b769 100644\n--- a/include/net/nexthop.h\n+++ b/include/net/nexthop.h\n@@ -238,6 +238,8 @@ static inline bool nexthop_is_blackhole(const struct nexthop *nh)\n \t}\n \n \tnhi = rcu_dereference_rtnl(nh->nh_info);\n+\tif (!nhi)\n+\t\treturn false;\n \treturn nhi->reject_nh;\n }\n \n",
            "diff --git a/include/net/nexthop.h b/include/net/nexthop.h\nindex 3a4f9e3b91a5..3edf1b275dbc 100644\n--- a/include/net/nexthop.h\n+++ b/include/net/nexthop.h\n@@ -237,6 +237,9 @@ static inline bool nexthop_is_blackhole(const struct nexthop *nh)\n \t\tnh = nh_grp->nh_entries[0].nh;\n \t}\n \n+\tif (!nh)\n+\t\treturn false;\n+\n \tnhi = rcu_dereference_rtnl(nh->nh_info);\n \treturn nhi->reject_nh;\n }\n"
        ],
        "error": []
    },
    "d21cb12ee03822236d82ba4e83a1f8968e7832fb": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/filemap.c b/mm/filemap.c\nindex a34abfe8c654..7499b152cd56 100644\n--- a/mm/filemap.c\n+++ b/mm/filemap.c\n@@ -3245,8 +3245,14 @@ vm_fault_t filemap_fault(struct vm_fault *vmf)\n \tint error;\n \tstruct file *file = vmf->vma->vm_file;\n \tstruct file *fpin = NULL;\n-\tstruct address_space *mapping = file->f_mapping;\n-\tstruct inode *inode = mapping->host;\n+\tstruct address_space *mapping;\n+\tstruct inode *inode;\n+\n+\tif (!file)\n+\t\treturn VM_FAULT_SIGBUS;\n+\n+\tmapping = file->f_mapping;\n+\tinode = mapping->host;\n \tpgoff_t max_idx, index = vmf->pgoff;\n \tstruct folio *folio;\n \tvm_fault_t ret = 0;\n",
            "diff --git a/mm/filemap.c b/mm/filemap.c\nindex a34abfe8c654..b43e7b29a433 100644\n--- a/mm/filemap.c\n+++ b/mm/filemap.c\n@@ -3245,8 +3245,14 @@ vm_fault_t filemap_fault(struct vm_fault *vmf)\n \tint error;\n \tstruct file *file = vmf->vma->vm_file;\n \tstruct file *fpin = NULL;\n-\tstruct address_space *mapping = file->f_mapping;\n-\tstruct inode *inode = mapping->host;\n+\tstruct address_space *mapping;\n+\tstruct inode *inode;\n+\n+\tif (unlikely(!file))\n+\t\treturn VM_FAULT_SIGBUS;\n+\n+\tmapping = file->f_mapping;\n+\tinode = mapping->host;\n \tpgoff_t max_idx, index = vmf->pgoff;\n \tstruct folio *folio;\n \tvm_fault_t ret = 0;\n",
            "diff --git a/mm/filemap.c b/mm/filemap.c\nindex a34abfe8c654..7499b152cd56 100644\n--- a/mm/filemap.c\n+++ b/mm/filemap.c\n@@ -3245,8 +3245,14 @@ vm_fault_t filemap_fault(struct vm_fault *vmf)\n \tint error;\n \tstruct file *file = vmf->vma->vm_file;\n \tstruct file *fpin = NULL;\n-\tstruct address_space *mapping = file->f_mapping;\n-\tstruct inode *inode = mapping->host;\n+\tstruct address_space *mapping;\n+\tstruct inode *inode;\n+\n+\tif (!file)\n+\t\treturn VM_FAULT_SIGBUS;\n+\n+\tmapping = file->f_mapping;\n+\tinode = mapping->host;\n \tpgoff_t max_idx, index = vmf->pgoff;\n \tstruct folio *folio;\n \tvm_fault_t ret = 0;\n",
            "diff --git a/mm/filemap.c b/mm/filemap.c\nindex a34abfe8c654..43238750916e 100644\n--- a/mm/filemap.c\n+++ b/mm/filemap.c\n@@ -3244,6 +3244,8 @@ vm_fault_t filemap_fault(struct vm_fault *vmf)\n {\n \tint error;\n \tstruct file *file = vmf->vma->vm_file;\n+\tif (unlikely(!file))\n+\t\treturn VM_FAULT_SIGBUS;\n \tstruct file *fpin = NULL;\n \tstruct address_space *mapping = file->f_mapping;\n \tstruct inode *inode = mapping->host;\n",
            "diff --git a/mm/filemap.c b/mm/filemap.c\nindex a34abfe8c654..7499b152cd56 100644\n--- a/mm/filemap.c\n+++ b/mm/filemap.c\n@@ -3245,8 +3245,14 @@ vm_fault_t filemap_fault(struct vm_fault *vmf)\n \tint error;\n \tstruct file *file = vmf->vma->vm_file;\n \tstruct file *fpin = NULL;\n-\tstruct address_space *mapping = file->f_mapping;\n-\tstruct inode *inode = mapping->host;\n+\tstruct address_space *mapping;\n+\tstruct inode *inode;\n+\n+\tif (!file)\n+\t\treturn VM_FAULT_SIGBUS;\n+\n+\tmapping = file->f_mapping;\n+\tinode = mapping->host;\n \tpgoff_t max_idx, index = vmf->pgoff;\n \tstruct folio *folio;\n \tvm_fault_t ret = 0;\n"
        ],
        "error": []
    },
    "9e03d0567a2ff908a4bcf8bc378c03be4afdd75d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/rcu/tree.c b/kernel/rcu/tree.c\nindex cf34a961821a..1c3f0d897bfd 100644\n--- a/kernel/rcu/tree.c\n+++ b/kernel/rcu/tree.c\n@@ -1494,7 +1494,7 @@ static noinline_for_stack bool rcu_gp_init(void)\n \t\trnp->qsmaskinit = rnp->qsmaskinitnext;\n \n \t\t/* If zero-ness of ->qsmaskinit changed, propagate up tree. */\n-\t\tif (!oldmask != !rnp->qsmaskinit) {\n+\t\tif (!!oldmask != !!rnp->qsmaskinit) {\n \t\t\tif (!oldmask) { /* First online CPU for rcu_node. */\n \t\t\t\tif (!rnp->wait_blkd_tasks) /* Ever offline? */\n \t\t\t\t\trcu_init_new_rnp(rnp);\n",
            "diff --git a/kernel/rcu/tree.c b/kernel/rcu/tree.c\nindex cf34a961821a..1c3f0d897bfd 100644\n--- a/kernel/rcu/tree.c\n+++ b/kernel/rcu/tree.c\n@@ -1494,7 +1494,7 @@ static noinline_for_stack bool rcu_gp_init(void)\n \t\trnp->qsmaskinit = rnp->qsmaskinitnext;\n \n \t\t/* If zero-ness of ->qsmaskinit changed, propagate up tree. */\n-\t\tif (!oldmask != !rnp->qsmaskinit) {\n+\t\tif (!!oldmask != !!rnp->qsmaskinit) {\n \t\t\tif (!oldmask) { /* First online CPU for rcu_node. */\n \t\t\t\tif (!rnp->wait_blkd_tasks) /* Ever offline? */\n \t\t\t\t\trcu_init_new_rnp(rnp);\n",
            "diff --git a/kernel/rcu/tree.c b/kernel/rcu/tree.c\nindex cf34a961821a..1c3f0d897bfd 100644\n--- a/kernel/rcu/tree.c\n+++ b/kernel/rcu/tree.c\n@@ -1494,7 +1494,7 @@ static noinline_for_stack bool rcu_gp_init(void)\n \t\trnp->qsmaskinit = rnp->qsmaskinitnext;\n \n \t\t/* If zero-ness of ->qsmaskinit changed, propagate up tree. */\n-\t\tif (!oldmask != !rnp->qsmaskinit) {\n+\t\tif (!!oldmask != !!rnp->qsmaskinit) {\n \t\t\tif (!oldmask) { /* First online CPU for rcu_node. */\n \t\t\t\tif (!rnp->wait_blkd_tasks) /* Ever offline? */\n \t\t\t\t\trcu_init_new_rnp(rnp);\n",
            "diff --git a/kernel/rcu/tree.c b/kernel/rcu/tree.c\nindex cf34a961821a..1c3f0d897bfd 100644\n--- a/kernel/rcu/tree.c\n+++ b/kernel/rcu/tree.c\n@@ -1494,7 +1494,7 @@ static noinline_for_stack bool rcu_gp_init(void)\n \t\trnp->qsmaskinit = rnp->qsmaskinitnext;\n \n \t\t/* If zero-ness of ->qsmaskinit changed, propagate up tree. */\n-\t\tif (!oldmask != !rnp->qsmaskinit) {\n+\t\tif (!!oldmask != !!rnp->qsmaskinit) {\n \t\t\tif (!oldmask) { /* First online CPU for rcu_node. */\n \t\t\t\tif (!rnp->wait_blkd_tasks) /* Ever offline? */\n \t\t\t\t\trcu_init_new_rnp(rnp);\n",
            "diff --git a/kernel/rcu/tree.c b/kernel/rcu/tree.c\nindex cf34a961821a..01adb2a704eb 100644\n--- a/kernel/rcu/tree.c\n+++ b/kernel/rcu/tree.c\n@@ -1494,7 +1494,7 @@ static noinline_for_stack bool rcu_gp_init(void)\n \t\trnp->qsmaskinit = rnp->qsmaskinitnext;\n \n \t\t/* If zero-ness of ->qsmaskinit changed, propagate up tree. */\n-\t\tif (!oldmask != !rnp->qsmaskinit) {\n+\t\tif ((!oldmask && rnp->qsmaskinit) || (oldmask && !rnp->qsmaskinit)) {\n \t\t\tif (!oldmask) { /* First online CPU for rcu_node. */\n \t\t\t\tif (!rnp->wait_blkd_tasks) /* Ever offline? */\n \t\t\t\t\trcu_init_new_rnp(rnp);\n"
        ],
        "error": []
    },
    "cdaf5ed409125df023889aefe50b4cc4a41c0973": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/namei.c b/fs/namei.c\nindex edfedfbccaef..d1d57dc61977 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -3855,7 +3855,8 @@ EXPORT_SYMBOL(kern_path_create);\n void done_path_create(struct path *path, struct dentry *dentry)\n {\n \tdput(dentry);\n-\tinode_unlock(path->dentry->d_inode);\n+\tif (inode_is_locked(path->dentry->d_inode))\n+\t\tinode_unlock(path->dentry->d_inode);\n \tmnt_drop_write(path->mnt);\n \tpath_put(path);\n }\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/namei.c b/fs/namei.c\nindex edfedfbccaef..8c6eec7fa2f8 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -4420,9 +4420,12 @@ int do_symlinkat(struct filename *from, int newdfd, struct filename *to)\n \t\tgoto out_putnames;\n \n \terror = security_path_symlink(&path, dentry, from->name);\n-\tif (!error)\n+\tif (!error) {\n+\t\tinode_lock(path.dentry->d_inode);  // Acquire the lock before symlink creation\n \t\terror = vfs_symlink(mnt_idmap(path.mnt), path.dentry->d_inode,\n \t\t\t\t    dentry, from->name);\n+\t\tinode_unlock(path.dentry->d_inode);  // Release the lock after symlink creation\n+\t}\n \tdone_path_create(&path, dentry);\n \tif (retry_estale(error, lookup_flags)) {\n \t\tlookup_flags |= LOOKUP_REVAL;\n",
                "error_message": "Failed to set up instance"
            },
            {
                "patch": "diff --git a/fs/namei.c b/fs/namei.c\nindex edfedfbccaef..d52527d67b1d 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -3852,10 +3852,11 @@ struct dentry *kern_path_create(int dfd, const char *pathname,\n }\n EXPORT_SYMBOL(kern_path_create);\n \n-void done_path_create(struct path *path, struct dentry *dentry)\n+void done_path_create(struct path *path, struct dentry *dentry, bool inode_locked)\n {\n \tdput(dentry);\n-\tinode_unlock(path->dentry->d_inode);\n+\tif (inode_locked)\n+\t\tinode_unlock(path->dentry->d_inode);\n \tmnt_drop_write(path->mnt);\n \tpath_put(path);\n }\n@@ -4421,9 +4422,12 @@ int do_symlinkat(struct filename *from, int newdfd, struct filename *to)\n \n \terror = security_path_symlink(&path, dentry, from->name);\n \tif (!error)\n-\t\terror = vfs_symlink(mnt_idmap(path.mnt), path.dentry->d_inode,\n+\t\tbool inode_locked = false;\n+\terror = vfs_symlink(mnt_idmap(path.mnt), path.dentry->d_inode,\n \t\t\t\t    dentry, from->name);\n-\tdone_path_create(&path, dentry);\n+\tif (!error)\n+\t\tinode_locked = true;\n+\tdone_path_create(&path, dentry, inode_locked);\n \tif (retry_estale(error, lookup_flags)) {\n \t\tlookup_flags |= LOOKUP_REVAL;\n \t\tgoto retry;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/namei.c b/fs/namei.c\nindex edfedfbccaef..dcefd6eacc7b 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -3855,7 +3855,9 @@ EXPORT_SYMBOL(kern_path_create);\n void done_path_create(struct path *path, struct dentry *dentry)\n {\n \tdput(dentry);\n-\tinode_unlock(path->dentry->d_inode);\n+\tif (rwsem_owner(&path->dentry->d_inode->i_rwsem) == current) {\n+\t\tinode_unlock(path->dentry->d_inode);\n+\t}\n \tmnt_drop_write(path->mnt);\n \tpath_put(path);\n }\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/namei.c b/fs/namei.c\nindex edfedfbccaef..2ac2dd3069d1 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -4420,10 +4420,12 @@ int do_symlinkat(struct filename *from, int newdfd, struct filename *to)\n \t\tgoto out_putnames;\n \n \terror = security_path_symlink(&path, dentry, from->name);\n-\tif (!error)\n+\tif (!error) {\n+\t\tinode_lock(path.dentry->d_inode); // Ensure semaphore is acquired\n \t\terror = vfs_symlink(mnt_idmap(path.mnt), path.dentry->d_inode,\n \t\t\t\t    dentry, from->name);\n-\tdone_path_create(&path, dentry);\n+\t\tdone_path_create(&path, dentry);\n+\t}\n \tif (retry_estale(error, lookup_flags)) {\n \t\tlookup_flags |= LOOKUP_REVAL;\n \t\tgoto retry;\n",
                "error_message": "Failed to set up instance"
            }
        ]
    },
    "2e1943a94647f7732dd6fc60368642d6e8dc91b1": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c\nindex b0d9c36acc03..f739f80c6be4 100644\n--- a/net/bluetooth/hci_core.c\n+++ b/net/bluetooth/hci_core.c\n@@ -4370,6 +4370,11 @@ static void hci_queue_acl(struct hci_chan *chan, struct sk_buff_head *queue,\n \n void hci_send_acl(struct hci_chan *chan, struct sk_buff *skb, __u16 flags)\n {\n+\tif (!chan || !chan->conn) {\n+\t\tBT_ERR(\"Invalid hci_chan or hci_conn\");\n+\t\treturn;\n+\t}\n+\n \tstruct hci_dev *hdev = chan->conn->hdev;\n \n \tBT_DBG(\"%s chan %p flags 0x%4.4x\", hdev->name, chan, flags);\n",
            "diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c\nindex b0d9c36acc03..de100d301031 100644\n--- a/net/bluetooth/hci_core.c\n+++ b/net/bluetooth/hci_core.c\n@@ -4370,6 +4370,11 @@ static void hci_queue_acl(struct hci_chan *chan, struct sk_buff_head *queue,\n \n void hci_send_acl(struct hci_chan *chan, struct sk_buff *skb, __u16 flags)\n {\n+\tif (!chan || !chan->conn) {\n+\t\tpr_err(\"Invalid hci_chan or hci_conn\\n\");\n+\t\treturn;\n+\t}\n+\n \tstruct hci_dev *hdev = chan->conn->hdev;\n \n \tBT_DBG(\"%s chan %p flags 0x%4.4x\", hdev->name, chan, flags);\n",
            "diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c\nindex b0d9c36acc03..f739f80c6be4 100644\n--- a/net/bluetooth/hci_core.c\n+++ b/net/bluetooth/hci_core.c\n@@ -4370,6 +4370,11 @@ static void hci_queue_acl(struct hci_chan *chan, struct sk_buff_head *queue,\n \n void hci_send_acl(struct hci_chan *chan, struct sk_buff *skb, __u16 flags)\n {\n+\tif (!chan || !chan->conn) {\n+\t\tBT_ERR(\"Invalid hci_chan or hci_conn\");\n+\t\treturn;\n+\t}\n+\n \tstruct hci_dev *hdev = chan->conn->hdev;\n \n \tBT_DBG(\"%s chan %p flags 0x%4.4x\", hdev->name, chan, flags);\n",
            "diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c\nindex b0d9c36acc03..f739f80c6be4 100644\n--- a/net/bluetooth/hci_core.c\n+++ b/net/bluetooth/hci_core.c\n@@ -4370,6 +4370,11 @@ static void hci_queue_acl(struct hci_chan *chan, struct sk_buff_head *queue,\n \n void hci_send_acl(struct hci_chan *chan, struct sk_buff *skb, __u16 flags)\n {\n+\tif (!chan || !chan->conn) {\n+\t\tBT_ERR(\"Invalid hci_chan or hci_conn\");\n+\t\treturn;\n+\t}\n+\n \tstruct hci_dev *hdev = chan->conn->hdev;\n \n \tBT_DBG(\"%s chan %p flags 0x%4.4x\", hdev->name, chan, flags);\n",
            "diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c\nindex b0d9c36acc03..f739f80c6be4 100644\n--- a/net/bluetooth/hci_core.c\n+++ b/net/bluetooth/hci_core.c\n@@ -4370,6 +4370,11 @@ static void hci_queue_acl(struct hci_chan *chan, struct sk_buff_head *queue,\n \n void hci_send_acl(struct hci_chan *chan, struct sk_buff *skb, __u16 flags)\n {\n+\tif (!chan || !chan->conn) {\n+\t\tBT_ERR(\"Invalid hci_chan or hci_conn\");\n+\t\treturn;\n+\t}\n+\n \tstruct hci_dev *hdev = chan->conn->hdev;\n \n \tBT_DBG(\"%s chan %p flags 0x%4.4x\", hdev->name, chan, flags);\n"
        ],
        "error": []
    },
    "4b5b6bdc090752dbcdd7e220a4703fed752cdfe7": {
        "non_crash": [
            "diff --git a/fs/nilfs2/page.c b/fs/nilfs2/page.c\nindex 5cf30827f244..44a13fcb75ba 100644\n--- a/fs/nilfs2/page.c\n+++ b/fs/nilfs2/page.c\n@@ -385,6 +385,11 @@ void nilfs_clear_dirty_pages(struct address_space *mapping, bool silent)\n  */\n void nilfs_clear_dirty_page(struct page *page, bool silent)\n {\n+\tif (!page->mapping || !page->mapping->host) {\n+\t\tif (!silent)\n+\t\t\tpr_warn(\"nilfs_clear_dirty_page: page mapping or host is null\\n\");\n+\t\treturn;\n+\t}\n \tstruct inode *inode = page->mapping->host;\n \tstruct super_block *sb = inode->i_sb;\n \n",
            "diff --git a/fs/nilfs2/page.c b/fs/nilfs2/page.c\nindex 5cf30827f244..2a7b51bdd4db 100644\n--- a/fs/nilfs2/page.c\n+++ b/fs/nilfs2/page.c\n@@ -385,6 +385,11 @@ void nilfs_clear_dirty_pages(struct address_space *mapping, bool silent)\n  */\n void nilfs_clear_dirty_page(struct page *page, bool silent)\n {\n+\tif (!page->mapping) {\n+\t\tif (!silent)\n+\t\t\tpr_warn(\"nilfs_clear_dirty_page: page->mapping is NULL\\n\");\n+\t\treturn;\n+\t}\n \tstruct inode *inode = page->mapping->host;\n \tstruct super_block *sb = inode->i_sb;\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/page.c b/fs/nilfs2/page.c\nindex 5cf30827f244..b70c4febc248 100644\n--- a/fs/nilfs2/page.c\n+++ b/fs/nilfs2/page.c\n@@ -385,6 +385,12 @@ void nilfs_clear_dirty_pages(struct address_space *mapping, bool silent)\n  */\n void nilfs_clear_dirty_page(struct page *page, bool silent)\n {\n+\tif (!page->mapping) {\n+\t\tif (!silent)\n+\t\t\tpr_warn(\"nilfs: page mapping is null, cannot clear dirty page\\n\");\n+\t\treturn;\n+\t}\n+\n \tstruct inode *inode = page->mapping->host;\n \tstruct super_block *sb = inode->i_sb;\n \n",
            "diff --git a/fs/nilfs2/page.c b/fs/nilfs2/page.c\nindex 5cf30827f244..2a7b51bdd4db 100644\n--- a/fs/nilfs2/page.c\n+++ b/fs/nilfs2/page.c\n@@ -385,6 +385,11 @@ void nilfs_clear_dirty_pages(struct address_space *mapping, bool silent)\n  */\n void nilfs_clear_dirty_page(struct page *page, bool silent)\n {\n+\tif (!page->mapping) {\n+\t\tif (!silent)\n+\t\t\tpr_warn(\"nilfs_clear_dirty_page: page->mapping is NULL\\n\");\n+\t\treturn;\n+\t}\n \tstruct inode *inode = page->mapping->host;\n \tstruct super_block *sb = inode->i_sb;\n \n",
            "diff --git a/fs/nilfs2/page.c b/fs/nilfs2/page.c\nindex 5cf30827f244..f8a66839bb76 100644\n--- a/fs/nilfs2/page.c\n+++ b/fs/nilfs2/page.c\n@@ -385,6 +385,11 @@ void nilfs_clear_dirty_pages(struct address_space *mapping, bool silent)\n  */\n void nilfs_clear_dirty_page(struct page *page, bool silent)\n {\n+\tif (!page->mapping || !page->mapping->host) {\n+\t\tif (!silent)\n+\t\t\tpr_warn(\"nilfs_clear_dirty_page: null mapping or host\\n\");\n+\t\treturn;\n+\t}\n \tstruct inode *inode = page->mapping->host;\n \tstruct super_block *sb = inode->i_sb;\n \n"
        ],
        "error": []
    },
    "2e1c26930cc57edee80734ae71bf020493b32306": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/ipv6/exthdrs.c b/net/ipv6/exthdrs.c\nindex 5a8bbcdcaf2b..f63c0d35fa04 100644\n--- a/net/ipv6/exthdrs.c\n+++ b/net/ipv6/exthdrs.c\n@@ -1343,6 +1343,9 @@ struct in6_addr *fl6_update_dst(struct flowi6 *fl6,\n \n \t*orig = fl6->daddr;\n \n+\tif (!opt->srcrt)\n+\t\treturn NULL;\n+\n \tswitch (opt->srcrt->type) {\n \tcase IPV6_SRCRT_TYPE_0:\n \tcase IPV6_SRCRT_STRICT:\n",
            "diff --git a/net/ipv6/exthdrs.c b/net/ipv6/exthdrs.c\nindex 5a8bbcdcaf2b..f63c0d35fa04 100644\n--- a/net/ipv6/exthdrs.c\n+++ b/net/ipv6/exthdrs.c\n@@ -1343,6 +1343,9 @@ struct in6_addr *fl6_update_dst(struct flowi6 *fl6,\n \n \t*orig = fl6->daddr;\n \n+\tif (!opt->srcrt)\n+\t\treturn NULL;\n+\n \tswitch (opt->srcrt->type) {\n \tcase IPV6_SRCRT_TYPE_0:\n \tcase IPV6_SRCRT_STRICT:\n",
            "diff --git a/net/ipv6/exthdrs.c b/net/ipv6/exthdrs.c\nindex 5a8bbcdcaf2b..3420660e5315 100644\n--- a/net/ipv6/exthdrs.c\n+++ b/net/ipv6/exthdrs.c\n@@ -1343,21 +1343,23 @@ struct in6_addr *fl6_update_dst(struct flowi6 *fl6,\n \n \t*orig = fl6->daddr;\n \n-\tswitch (opt->srcrt->type) {\n-\tcase IPV6_SRCRT_TYPE_0:\n-\tcase IPV6_SRCRT_STRICT:\n-\tcase IPV6_SRCRT_TYPE_2:\n-\t\tfl6->daddr = *((struct rt0_hdr *)opt->srcrt)->addr;\n-\t\tbreak;\n-\tcase IPV6_SRCRT_TYPE_4:\n-\t{\n-\t\tstruct ipv6_sr_hdr *srh = (struct ipv6_sr_hdr *)opt->srcrt;\n+\tif (opt->srcrt) {\n+\t\tswitch (opt->srcrt->type) {\n+\t\tcase IPV6_SRCRT_TYPE_0:\n+\t\tcase IPV6_SRCRT_STRICT:\n+\t\tcase IPV6_SRCRT_TYPE_2:\n+\t\t\tfl6->daddr = *((struct rt0_hdr *)opt->srcrt)->addr;\n+\t\t\tbreak;\n+\t\tcase IPV6_SRCRT_TYPE_4:\n+\t\t{\n+\t\t\tstruct ipv6_sr_hdr *srh = (struct ipv6_sr_hdr *)opt->srcrt;\n \n-\t\tfl6->daddr = srh->segments[srh->segments_left];\n-\t\tbreak;\n-\t}\n-\tdefault:\n-\t\treturn NULL;\n+\t\t\tfl6->daddr = srh->segments[srh->segments_left];\n+\t\t\tbreak;\n+\t\t}\n+\t\tdefault:\n+\t\t\treturn NULL;\n+\t\t}\n \t}\n \n \treturn orig;\n",
            "diff --git a/net/ipv6/exthdrs.c b/net/ipv6/exthdrs.c\nindex 5a8bbcdcaf2b..3420660e5315 100644\n--- a/net/ipv6/exthdrs.c\n+++ b/net/ipv6/exthdrs.c\n@@ -1343,21 +1343,23 @@ struct in6_addr *fl6_update_dst(struct flowi6 *fl6,\n \n \t*orig = fl6->daddr;\n \n-\tswitch (opt->srcrt->type) {\n-\tcase IPV6_SRCRT_TYPE_0:\n-\tcase IPV6_SRCRT_STRICT:\n-\tcase IPV6_SRCRT_TYPE_2:\n-\t\tfl6->daddr = *((struct rt0_hdr *)opt->srcrt)->addr;\n-\t\tbreak;\n-\tcase IPV6_SRCRT_TYPE_4:\n-\t{\n-\t\tstruct ipv6_sr_hdr *srh = (struct ipv6_sr_hdr *)opt->srcrt;\n+\tif (opt->srcrt) {\n+\t\tswitch (opt->srcrt->type) {\n+\t\tcase IPV6_SRCRT_TYPE_0:\n+\t\tcase IPV6_SRCRT_STRICT:\n+\t\tcase IPV6_SRCRT_TYPE_2:\n+\t\t\tfl6->daddr = *((struct rt0_hdr *)opt->srcrt)->addr;\n+\t\t\tbreak;\n+\t\tcase IPV6_SRCRT_TYPE_4:\n+\t\t{\n+\t\t\tstruct ipv6_sr_hdr *srh = (struct ipv6_sr_hdr *)opt->srcrt;\n \n-\t\tfl6->daddr = srh->segments[srh->segments_left];\n-\t\tbreak;\n-\t}\n-\tdefault:\n-\t\treturn NULL;\n+\t\t\tfl6->daddr = srh->segments[srh->segments_left];\n+\t\t\tbreak;\n+\t\t}\n+\t\tdefault:\n+\t\t\treturn NULL;\n+\t\t}\n \t}\n \n \treturn orig;\n",
            "diff --git a/net/ipv6/exthdrs.c b/net/ipv6/exthdrs.c\nindex 5a8bbcdcaf2b..3420660e5315 100644\n--- a/net/ipv6/exthdrs.c\n+++ b/net/ipv6/exthdrs.c\n@@ -1343,21 +1343,23 @@ struct in6_addr *fl6_update_dst(struct flowi6 *fl6,\n \n \t*orig = fl6->daddr;\n \n-\tswitch (opt->srcrt->type) {\n-\tcase IPV6_SRCRT_TYPE_0:\n-\tcase IPV6_SRCRT_STRICT:\n-\tcase IPV6_SRCRT_TYPE_2:\n-\t\tfl6->daddr = *((struct rt0_hdr *)opt->srcrt)->addr;\n-\t\tbreak;\n-\tcase IPV6_SRCRT_TYPE_4:\n-\t{\n-\t\tstruct ipv6_sr_hdr *srh = (struct ipv6_sr_hdr *)opt->srcrt;\n+\tif (opt->srcrt) {\n+\t\tswitch (opt->srcrt->type) {\n+\t\tcase IPV6_SRCRT_TYPE_0:\n+\t\tcase IPV6_SRCRT_STRICT:\n+\t\tcase IPV6_SRCRT_TYPE_2:\n+\t\t\tfl6->daddr = *((struct rt0_hdr *)opt->srcrt)->addr;\n+\t\t\tbreak;\n+\t\tcase IPV6_SRCRT_TYPE_4:\n+\t\t{\n+\t\t\tstruct ipv6_sr_hdr *srh = (struct ipv6_sr_hdr *)opt->srcrt;\n \n-\t\tfl6->daddr = srh->segments[srh->segments_left];\n-\t\tbreak;\n-\t}\n-\tdefault:\n-\t\treturn NULL;\n+\t\t\tfl6->daddr = srh->segments[srh->segments_left];\n+\t\t\tbreak;\n+\t\t}\n+\t\tdefault:\n+\t\t\treturn NULL;\n+\t\t}\n \t}\n \n \treturn orig;\n"
        ],
        "error": []
    },
    "1bb19c23cbf08cedbc6bbe5d4b7e07f6403fa35e": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex 9e2735cbc2b4..97c58281bdaf 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -853,7 +853,7 @@ static inline void *mas_slot(struct ma_state *mas, void __rcu **slots,\n  */\n static inline void *mas_root(struct ma_state *mas)\n {\n-\treturn rcu_dereference_check(mas->tree->ma_root, mt_locked(mas->tree));\n+\treturn rcu_dereference_protected(mas->tree->ma_root, mt_locked(mas->tree));\n }\n \n static inline void *mt_root_locked(struct maple_tree *mt)\n",
            "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex 9e2735cbc2b4..97c58281bdaf 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -853,7 +853,7 @@ static inline void *mas_slot(struct ma_state *mas, void __rcu **slots,\n  */\n static inline void *mas_root(struct ma_state *mas)\n {\n-\treturn rcu_dereference_check(mas->tree->ma_root, mt_locked(mas->tree));\n+\treturn rcu_dereference_protected(mas->tree->ma_root, mt_locked(mas->tree));\n }\n \n static inline void *mt_root_locked(struct maple_tree *mt)\n",
            "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex 9e2735cbc2b4..d7e15cabfe13 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -853,7 +853,7 @@ static inline void *mas_slot(struct ma_state *mas, void __rcu **slots,\n  */\n static inline void *mas_root(struct ma_state *mas)\n {\n-\treturn rcu_dereference_check(mas->tree->ma_root, mt_locked(mas->tree));\n+\treturn rcu_dereference_check(mas->tree->ma_root, rcu_read_lock_held() || mt_locked(mas->tree));\n }\n \n static inline void *mt_root_locked(struct maple_tree *mt)\n",
            "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex 9e2735cbc2b4..97c58281bdaf 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -853,7 +853,7 @@ static inline void *mas_slot(struct ma_state *mas, void __rcu **slots,\n  */\n static inline void *mas_root(struct ma_state *mas)\n {\n-\treturn rcu_dereference_check(mas->tree->ma_root, mt_locked(mas->tree));\n+\treturn rcu_dereference_protected(mas->tree->ma_root, mt_locked(mas->tree));\n }\n \n static inline void *mt_root_locked(struct maple_tree *mt)\n"
        ],
        "error": [
            {
                "patch": "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex 9e2735cbc2b4..93654020345c 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -853,7 +853,7 @@ static inline void *mas_slot(struct ma_state *mas, void __rcu **slots,\n  */\n static inline void *mas_root(struct ma_state *mas)\n {\n-\treturn rcu_dereference_check(mas->tree->ma_root, mt_locked(mas->tree));\n+\treturn rcu_dereference_check(mas->tree->ma_root, lockdep_is_held(&mas->tree->lock));\n }\n \n static inline void *mt_root_locked(struct maple_tree *mt)\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "f080ff8eb73ae6a29960594307de8e732db389d3": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/f2fs/extent_cache.c b/fs/f2fs/extent_cache.c\nindex 0e2d49140c07..a7e54323c9c9 100644\n--- a/fs/f2fs/extent_cache.c\n+++ b/fs/f2fs/extent_cache.c\n@@ -1097,8 +1097,10 @@ static void __drop_extent_tree(struct inode *inode, enum extent_type type)\n \tif (!__may_extent_tree(inode, type))\n \t\treturn;\n \n-\twrite_lock(&et->lock);\n-\t__free_extent_tree(sbi, et);\n+\tif (et) {\n+\t\twrite_lock(&et->lock);\n+\t\t__free_extent_tree(sbi, et);\n+\t}\n \tif (type == EX_READ) {\n \t\tset_inode_flag(inode, FI_NO_EXTENT);\n \t\tif (et->largest.len) {\n",
            "diff --git a/fs/f2fs/extent_cache.c b/fs/f2fs/extent_cache.c\nindex 0e2d49140c07..a7e54323c9c9 100644\n--- a/fs/f2fs/extent_cache.c\n+++ b/fs/f2fs/extent_cache.c\n@@ -1097,8 +1097,10 @@ static void __drop_extent_tree(struct inode *inode, enum extent_type type)\n \tif (!__may_extent_tree(inode, type))\n \t\treturn;\n \n-\twrite_lock(&et->lock);\n-\t__free_extent_tree(sbi, et);\n+\tif (et) {\n+\t\twrite_lock(&et->lock);\n+\t\t__free_extent_tree(sbi, et);\n+\t}\n \tif (type == EX_READ) {\n \t\tset_inode_flag(inode, FI_NO_EXTENT);\n \t\tif (et->largest.len) {\n",
            "diff --git a/fs/f2fs/extent_cache.c b/fs/f2fs/extent_cache.c\nindex 0e2d49140c07..a7e54323c9c9 100644\n--- a/fs/f2fs/extent_cache.c\n+++ b/fs/f2fs/extent_cache.c\n@@ -1097,8 +1097,10 @@ static void __drop_extent_tree(struct inode *inode, enum extent_type type)\n \tif (!__may_extent_tree(inode, type))\n \t\treturn;\n \n-\twrite_lock(&et->lock);\n-\t__free_extent_tree(sbi, et);\n+\tif (et) {\n+\t\twrite_lock(&et->lock);\n+\t\t__free_extent_tree(sbi, et);\n+\t}\n \tif (type == EX_READ) {\n \t\tset_inode_flag(inode, FI_NO_EXTENT);\n \t\tif (et->largest.len) {\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/f2fs/extent_cache.c b/fs/f2fs/extent_cache.c\nindex 0e2d49140c07..2084dd5295de 100644\n--- a/fs/f2fs/extent_cache.c\n+++ b/fs/f2fs/extent_cache.c\n@@ -421,7 +421,17 @@ void f2fs_init_read_extent_tree(struct inode *inode, struct page *ipage)\n \n \tget_read_extent_info(&ei, i_ext);\n \n-\twrite_lock(&et->lock);\n+\tif (et) {\n+\t\twrite_lock(&et->lock);\n+\t\t__free_extent_tree(sbi, et);\n+\t\tif (type == EX_READ) {\n+\t\t\tset_inode_flag(inode, FI_NO_EXTENT);\n+\t\t\tif (et->largest.len) {\n+\t\t\t\tupdated = true;\n+\t\t\t}\n+\t\t}\n+\t\twrite_unlock(&et->lock);\n+\t}\n \tif (atomic_read(&et->node_cnt))\n \t\tgoto unlock_out;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/f2fs/extent_cache.c b/fs/f2fs/extent_cache.c\nindex 0e2d49140c07..2084dd5295de 100644\n--- a/fs/f2fs/extent_cache.c\n+++ b/fs/f2fs/extent_cache.c\n@@ -421,7 +421,17 @@ void f2fs_init_read_extent_tree(struct inode *inode, struct page *ipage)\n \n \tget_read_extent_info(&ei, i_ext);\n \n-\twrite_lock(&et->lock);\n+\tif (et) {\n+\t\twrite_lock(&et->lock);\n+\t\t__free_extent_tree(sbi, et);\n+\t\tif (type == EX_READ) {\n+\t\t\tset_inode_flag(inode, FI_NO_EXTENT);\n+\t\t\tif (et->largest.len) {\n+\t\t\t\tupdated = true;\n+\t\t\t}\n+\t\t}\n+\t\twrite_unlock(&et->lock);\n+\t}\n \tif (atomic_read(&et->node_cnt))\n \t\tgoto unlock_out;\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "37f68bc0a80819d1509e1b024c413389ae877175": {
        "non_crash": [
            "diff --git a/fs/xfs/xfs_bmap_util.c b/fs/xfs/xfs_bmap_util.c\nindex f032d3a4b727..a1def647bc19 100644\n--- a/fs/xfs/xfs_bmap_util.c\n+++ b/fs/xfs/xfs_bmap_util.c\n@@ -558,7 +558,9 @@ xfs_getbmap(\n \t\tif (!xfs_iext_next_extent(ifp, &icur, &got)) {\n \t\t\txfs_fileoff_t\tend = XFS_B_TO_FSB(mp, XFS_ISIZE(ip));\n \n-\t\t\tout[bmv->bmv_entries - 1].bmv_oflags |= BMV_OF_LAST;\n+\t\t\tif (bmv->bmv_entries > 0) {\n+\t\t\t\tout[bmv->bmv_entries - 1].bmv_oflags |= BMV_OF_LAST;\n+\t\t\t}\n \n \t\t\tif (whichfork != XFS_ATTR_FORK && bno < end &&\n \t\t\t    !xfs_getbmap_full(bmv)) {\n",
            "diff --git a/fs/xfs/xfs_bmap_util.c b/fs/xfs/xfs_bmap_util.c\nindex f032d3a4b727..a1def647bc19 100644\n--- a/fs/xfs/xfs_bmap_util.c\n+++ b/fs/xfs/xfs_bmap_util.c\n@@ -558,7 +558,9 @@ xfs_getbmap(\n \t\tif (!xfs_iext_next_extent(ifp, &icur, &got)) {\n \t\t\txfs_fileoff_t\tend = XFS_B_TO_FSB(mp, XFS_ISIZE(ip));\n \n-\t\t\tout[bmv->bmv_entries - 1].bmv_oflags |= BMV_OF_LAST;\n+\t\t\tif (bmv->bmv_entries > 0) {\n+\t\t\t\tout[bmv->bmv_entries - 1].bmv_oflags |= BMV_OF_LAST;\n+\t\t\t}\n \n \t\t\tif (whichfork != XFS_ATTR_FORK && bno < end &&\n \t\t\t    !xfs_getbmap_full(bmv)) {\n",
            "diff --git a/fs/xfs/xfs_bmap_util.c b/fs/xfs/xfs_bmap_util.c\nindex f032d3a4b727..a1def647bc19 100644\n--- a/fs/xfs/xfs_bmap_util.c\n+++ b/fs/xfs/xfs_bmap_util.c\n@@ -558,7 +558,9 @@ xfs_getbmap(\n \t\tif (!xfs_iext_next_extent(ifp, &icur, &got)) {\n \t\t\txfs_fileoff_t\tend = XFS_B_TO_FSB(mp, XFS_ISIZE(ip));\n \n-\t\t\tout[bmv->bmv_entries - 1].bmv_oflags |= BMV_OF_LAST;\n+\t\t\tif (bmv->bmv_entries > 0) {\n+\t\t\t\tout[bmv->bmv_entries - 1].bmv_oflags |= BMV_OF_LAST;\n+\t\t\t}\n \n \t\t\tif (whichfork != XFS_ATTR_FORK && bno < end &&\n \t\t\t    !xfs_getbmap_full(bmv)) {\n",
            "diff --git a/fs/xfs/xfs_bmap_util.c b/fs/xfs/xfs_bmap_util.c\nindex f032d3a4b727..a1def647bc19 100644\n--- a/fs/xfs/xfs_bmap_util.c\n+++ b/fs/xfs/xfs_bmap_util.c\n@@ -558,7 +558,9 @@ xfs_getbmap(\n \t\tif (!xfs_iext_next_extent(ifp, &icur, &got)) {\n \t\t\txfs_fileoff_t\tend = XFS_B_TO_FSB(mp, XFS_ISIZE(ip));\n \n-\t\t\tout[bmv->bmv_entries - 1].bmv_oflags |= BMV_OF_LAST;\n+\t\t\tif (bmv->bmv_entries > 0) {\n+\t\t\t\tout[bmv->bmv_entries - 1].bmv_oflags |= BMV_OF_LAST;\n+\t\t\t}\n \n \t\t\tif (whichfork != XFS_ATTR_FORK && bno < end &&\n \t\t\t    !xfs_getbmap_full(bmv)) {\n",
            "diff --git a/fs/xfs/xfs_bmap_util.c b/fs/xfs/xfs_bmap_util.c\nindex f032d3a4b727..a1def647bc19 100644\n--- a/fs/xfs/xfs_bmap_util.c\n+++ b/fs/xfs/xfs_bmap_util.c\n@@ -558,7 +558,9 @@ xfs_getbmap(\n \t\tif (!xfs_iext_next_extent(ifp, &icur, &got)) {\n \t\t\txfs_fileoff_t\tend = XFS_B_TO_FSB(mp, XFS_ISIZE(ip));\n \n-\t\t\tout[bmv->bmv_entries - 1].bmv_oflags |= BMV_OF_LAST;\n+\t\t\tif (bmv->bmv_entries > 0) {\n+\t\t\t\tout[bmv->bmv_entries - 1].bmv_oflags |= BMV_OF_LAST;\n+\t\t\t}\n \n \t\t\tif (whichfork != XFS_ATTR_FORK && bno < end &&\n \t\t\t    !xfs_getbmap_full(bmv)) {\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "6513f6cb5cd6b5fc9f37e3bb70d273b94be9c34c": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dfc2e223bd10..2b3d6914720c 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -1985,16 +1985,20 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\tgoto inserted;\n \t\t}\n clone_block:\n-\t\tunlock_buffer(bs->bh);\n+\t\t/* Ensure buffer is locked before cloning */\n+\t\tlock_buffer(bs->bh);\n \t\tea_bdebug(bs->bh, \"cloning\");\n \t\ts->base = kmemdup(BHDR(bs->bh), bs->bh->b_size, GFP_NOFS);\n \t\terror = -ENOMEM;\n-\t\tif (s->base == NULL)\n+\t\tif (s->base == NULL) {\n+\t\t\tunlock_buffer(bs->bh);\n \t\t\tgoto cleanup;\n+\t\t}\n \t\ts->first = ENTRY(header(s->base)+1);\n \t\theader(s->base)->h_refcount = cpu_to_le32(1);\n \t\ts->here = ENTRY(s->base + offset);\n \t\ts->end = s->base + bs->bh->b_size;\n+\t\tunlock_buffer(bs->bh);\n \n \t\t/*\n \t\t * If existing entry points to an xattr inode, we need\n",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dfc2e223bd10..4868bb721f70 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -1985,7 +1985,8 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\tgoto inserted;\n \t\t}\n clone_block:\n-\t\tunlock_buffer(bs->bh);\n+\t\tif (!buffer_locked(bs->bh))\n+\t\t\tunlock_buffer(bs->bh);\n \t\tea_bdebug(bs->bh, \"cloning\");\n \t\ts->base = kmemdup(BHDR(bs->bh), bs->bh->b_size, GFP_NOFS);\n \t\terror = -ENOMEM;\n",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dfc2e223bd10..2ff535685f5f 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -1988,9 +1988,10 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\tunlock_buffer(bs->bh);\n \t\tea_bdebug(bs->bh, \"cloning\");\n \t\ts->base = kmemdup(BHDR(bs->bh), bs->bh->b_size, GFP_NOFS);\n-\t\terror = -ENOMEM;\n-\t\tif (s->base == NULL)\n+\t\tif (s->base == NULL) {\n+\t\t\terror = -ENOMEM;\n \t\t\tgoto cleanup;\n+\t\t}\n \t\ts->first = ENTRY(header(s->base)+1);\n \t\theader(s->base)->h_refcount = cpu_to_le32(1);\n \t\ts->here = ENTRY(s->base + offset);\n",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dfc2e223bd10..16b3b08d3993 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -1988,13 +1988,16 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\tunlock_buffer(bs->bh);\n \t\tea_bdebug(bs->bh, \"cloning\");\n \t\ts->base = kmemdup(BHDR(bs->bh), bs->bh->b_size, GFP_NOFS);\n-\t\terror = -ENOMEM;\n-\t\tif (s->base == NULL)\n+\t\tif (s->base == NULL) {\n+\t\t\terror = -ENOMEM;\n \t\t\tgoto cleanup;\n+\t\t}\n \t\ts->first = ENTRY(header(s->base)+1);\n \t\theader(s->base)->h_refcount = cpu_to_le32(1);\n \t\ts->here = ENTRY(s->base + offset);\n \t\ts->end = s->base + bs->bh->b_size;\n+\t\t/* Ensure buffer is marked dirty after cloning */\n+\t\tmark_buffer_dirty(bs->bh);\n \n \t\t/*\n \t\t * If existing entry points to an xattr inode, we need\n"
        ],
        "error": []
    },
    "33e08264ba252fcf3ed89b69fd088ac976363535": {
        "non_crash": [
            "diff --git a/fs/udf/inode.c b/fs/udf/inode.c\nindex 31965c3798f2..e6faccc3c264 100644\n--- a/fs/udf/inode.c\n+++ b/fs/udf/inode.c\n@@ -556,8 +556,11 @@ static int udf_extend_file(struct inode *inode, loff_t newsize)\n \tetype = inode_bmap(inode, first_block, &epos, &eloc, &elen, &offset);\n \twithin_last_ext = (etype != -1);\n \t/* We don't expect extents past EOF... */\n-\tWARN_ON_ONCE(within_last_ext &&\n-\t\t     elen > ((loff_t)offset + 1) << inode->i_blkbits);\n+\tif (within_last_ext &&\n+\t    elen > ((loff_t)offset + 1) << inode->i_blkbits) {\n+\t\tpr_warn(\"udf_extend_file: extent length exceeds expected value\\n\");\n+\t\treturn -EINVAL;\n+\t}\n \n \tif ((!epos.bh && epos.offset == udf_file_entry_alloc_offset(inode)) ||\n \t    (epos.bh && epos.offset == sizeof(struct allocExtDesc))) {\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/udf/inode.c b/fs/udf/inode.c\nindex 31965c3798f2..57e46f3997fc 100644\n--- a/fs/udf/inode.c\n+++ b/fs/udf/inode.c\n@@ -554,7 +554,7 @@ static int udf_extend_file(struct inode *inode, loff_t newsize)\n \tudf_discard_prealloc(inode);\n \n \tetype = inode_bmap(inode, first_block, &epos, &eloc, &elen, &offset);\n-\twithin_last_ext = (etype != -1);\n+\twithin_last_ext = (etype != -1 && offset < elen);\n \t/* We don't expect extents past EOF... */\n \tWARN_ON_ONCE(within_last_ext &&\n \t\t     elen > ((loff_t)offset + 1) << inode->i_blkbits);\n",
            "diff --git a/fs/udf/inode.c b/fs/udf/inode.c\nindex 31965c3798f2..288b4b50b0ab 100644\n--- a/fs/udf/inode.c\n+++ b/fs/udf/inode.c\n@@ -557,7 +557,7 @@ static int udf_extend_file(struct inode *inode, loff_t newsize)\n \twithin_last_ext = (etype != -1);\n \t/* We don't expect extents past EOF... */\n \tWARN_ON_ONCE(within_last_ext &&\n-\t\t     elen > ((loff_t)offset + 1) << inode->i_blkbits);\n+\t\t     elen > (((loff_t)offset + 1) << inode->i_blkbits));\n \n \tif ((!epos.bh && epos.offset == udf_file_entry_alloc_offset(inode)) ||\n \t    (epos.bh && epos.offset == sizeof(struct allocExtDesc))) {\n",
            "diff --git a/fs/udf/inode.c b/fs/udf/inode.c\nindex 31965c3798f2..8b22535f91c3 100644\n--- a/fs/udf/inode.c\n+++ b/fs/udf/inode.c\n@@ -556,8 +556,12 @@ static int udf_extend_file(struct inode *inode, loff_t newsize)\n \tetype = inode_bmap(inode, first_block, &epos, &eloc, &elen, &offset);\n \twithin_last_ext = (etype != -1);\n \t/* We don't expect extents past EOF... */\n-\tWARN_ON_ONCE(within_last_ext &&\n-\t\t     elen > ((loff_t)offset + 1) << inode->i_blkbits);\n+\tif (within_last_ext &&\n+\t    elen > ((loff_t)offset + 1) << inode->i_blkbits) {\n+\t\t/* Handle unexpected extent past EOF gracefully */\n+\t\textent.extLength = ((loff_t)offset + 1) << inode->i_blkbits;\n+\t\tWARN_ON_ONCE(1);\n+\t}\n \n \tif ((!epos.bh && epos.offset == udf_file_entry_alloc_offset(inode)) ||\n \t    (epos.bh && epos.offset == sizeof(struct allocExtDesc))) {\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/udf/inode.c b/fs/udf/inode.c\nindex 31965c3798f2..032e5addb9c1 100644\n--- a/fs/udf/inode.c\n+++ b/fs/udf/inode.c\n@@ -557,7 +557,7 @@ static int udf_extend_file(struct inode *inode, loff_t newsize)\n \twithin_last_ext = (etype != -1);\n \t/* We don't expect extents past EOF... */\n \tWARN_ON_ONCE(within_last_ext &&\n-\t\t     elen > ((loff_t)offset + 1) << inode->i_blkbits);\n+\t\t     elen > (((loff_t)offset + 1) << inode->i_blkbits));\n \n \tif ((!epos.bh && epos.offset == udf_file_entry_alloc_offset(inode)) ||\n \t    (epos.bh && epos.offset == sizeof(struct allocExtDesc))) {\n@@ -567,8 +567,12 @@ static int udf_extend_file(struct inode *inode, loff_t newsize)\n \t\textent.extLocation.partitionReferenceNum = 0;\n \t\textent.extLength = EXT_NOT_RECORDED_NOT_ALLOCATED;\n \t} else {\n-\t\tepos.offset -= adsize;\n-\t\tetype = udf_next_aext(inode, &epos, &extent.extLocation,\n+\t\tif (epos.offset >= adsize) {\n+\t\t\tepos.offset -= adsize;\n+\t\t\tetype = udf_next_aext(inode, &epos, &extent.extLocation,\n+\t\t} else {\n+\t\t\tetype = -1; // Invalid extent position\n+\t\t}\n \t\t\t\t      &extent.extLength, 0);\n \t\textent.extLength |= etype << 30;\n \t}\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "ad6e459b5804609befe3e5c24001b25185b073fc": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/core/dev.c b/net/core/dev.c\nindex 90b59fc50dc9..f1e56a5e46d2 100644\n--- a/net/core/dev.c\n+++ b/net/core/dev.c\n@@ -239,7 +239,11 @@ static struct netdev_name_node *netdev_name_node_alloc(struct net_device *dev,\n \t\treturn NULL;\n \tINIT_HLIST_NODE(&name_node->hlist);\n \tname_node->dev = dev;\n-\tname_node->name = name;\n+\tname_node->name = kstrdup(name, GFP_KERNEL);\n+\tif (!name_node->name) {\n+\t\tkfree(name_node);\n+\t\treturn NULL;\n+\t}\n \treturn name_node;\n }\n \n",
                "error_message": "Failed to set up instance"
            },
            {
                "patch": "diff --git a/net/core/dev.c b/net/core/dev.c\nindex 90b59fc50dc9..f1e56a5e46d2 100644\n--- a/net/core/dev.c\n+++ b/net/core/dev.c\n@@ -239,7 +239,11 @@ static struct netdev_name_node *netdev_name_node_alloc(struct net_device *dev,\n \t\treturn NULL;\n \tINIT_HLIST_NODE(&name_node->hlist);\n \tname_node->dev = dev;\n-\tname_node->name = name;\n+\tname_node->name = kstrdup(name, GFP_KERNEL);\n+\tif (!name_node->name) {\n+\t\tkfree(name_node);\n+\t\treturn NULL;\n+\t}\n \treturn name_node;\n }\n \n",
                "error_message": "Failed to set up instance"
            },
            {
                "patch": "diff --git a/net/core/dev.c b/net/core/dev.c\nindex 90b59fc50dc9..50eba87cb479 100644\n--- a/net/core/dev.c\n+++ b/net/core/dev.c\n@@ -239,7 +239,11 @@ static struct netdev_name_node *netdev_name_node_alloc(struct net_device *dev,\n \t\treturn NULL;\n \tINIT_HLIST_NODE(&name_node->hlist);\n \tname_node->dev = dev;\n-\tname_node->name = name;\n+\tname_node->name = kstrdup(name, GFP_KERNEL);\n+\tif (!name_node->name) {\n+\t\tkfree(name_node);\n+\t\treturn NULL;\n+\t}\n \treturn name_node;\n }\n \n@@ -860,7 +864,12 @@ struct net_device *__dev_get_by_name(struct net *net, const char *name)\n \tstruct netdev_name_node *node_name;\n \n \tnode_name = netdev_name_node_lookup(net, name);\n-\treturn node_name ? node_name->dev : NULL;\n+\tif (node_name) {\n+\t\tstruct net_device *dev = node_name->dev;\n+\t\tkfree(node_name->name);\n+\t\treturn dev;\n+\t}\n+\treturn NULL;\n }\n EXPORT_SYMBOL(__dev_get_by_name);\n \n",
                "error_message": "Failed to set up instance"
            },
            {
                "patch": "diff --git a/net/core/dev.c b/net/core/dev.c\nindex 90b59fc50dc9..f1e56a5e46d2 100644\n--- a/net/core/dev.c\n+++ b/net/core/dev.c\n@@ -239,7 +239,11 @@ static struct netdev_name_node *netdev_name_node_alloc(struct net_device *dev,\n \t\treturn NULL;\n \tINIT_HLIST_NODE(&name_node->hlist);\n \tname_node->dev = dev;\n-\tname_node->name = name;\n+\tname_node->name = kstrdup(name, GFP_KERNEL);\n+\tif (!name_node->name) {\n+\t\tkfree(name_node);\n+\t\treturn NULL;\n+\t}\n \treturn name_node;\n }\n \n",
                "error_message": "Failed to set up instance"
            },
            {
                "patch": "diff --git a/net/core/dev.c b/net/core/dev.c\nindex 90b59fc50dc9..f1e56a5e46d2 100644\n--- a/net/core/dev.c\n+++ b/net/core/dev.c\n@@ -239,7 +239,11 @@ static struct netdev_name_node *netdev_name_node_alloc(struct net_device *dev,\n \t\treturn NULL;\n \tINIT_HLIST_NODE(&name_node->hlist);\n \tname_node->dev = dev;\n-\tname_node->name = name;\n+\tname_node->name = kstrdup(name, GFP_KERNEL);\n+\tif (!name_node->name) {\n+\t\tkfree(name_node);\n+\t\treturn NULL;\n+\t}\n \treturn name_node;\n }\n \n",
                "error_message": "Failed to set up instance"
            }
        ]
    },
    "ac6fc97113de554dc57614c3ffa4c6a2c2668a97": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c\nindex 9c1d31f63f85..50b435c98067 100644\n--- a/drivers/hid/hid-core.c\n+++ b/drivers/hid/hid-core.c\n@@ -1363,7 +1363,9 @@ static u32 __extract(u8 *report, unsigned offset, int n)\n \tu32 mask = n < 32 ? (1U << n) - 1 : ~0U;\n \n \twhile (n > 0) {\n-\t\tvalue |= ((u32)report[idx] >> bit_shift) << bit_nr;\n+\t\tif (bit_shift < 32) {\n+\t\t\tvalue |= ((u32)report[idx] >> bit_shift) << bit_nr;\n+\t\t}\n \t\tn -= bits_to_copy;\n \t\tbit_nr += bits_to_copy;\n \t\tbits_to_copy = 8;\n",
            "diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c\nindex 9c1d31f63f85..f0f4a62737b2 100644\n--- a/drivers/hid/hid-core.c\n+++ b/drivers/hid/hid-core.c\n@@ -1362,6 +1362,10 @@ static u32 __extract(u8 *report, unsigned offset, int n)\n \tu32 value = 0;\n \tu32 mask = n < 32 ? (1U << n) - 1 : ~0U;\n \n+\tif (n > 32) {\n+\t\tn = 32;\n+\t}\n+\n \twhile (n > 0) {\n \t\tvalue |= ((u32)report[idx] >> bit_shift) << bit_nr;\n \t\tn -= bits_to_copy;\n",
            "diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c\nindex 9c1d31f63f85..0fcb6074ac15 100644\n--- a/drivers/hid/hid-core.c\n+++ b/drivers/hid/hid-core.c\n@@ -1360,7 +1360,7 @@ static u32 __extract(u8 *report, unsigned offset, int n)\n \tunsigned int bit_shift = offset % 8;\n \tint bits_to_copy = 8 - bit_shift;\n \tu32 value = 0;\n-\tu32 mask = n < 32 ? (1U << n) - 1 : ~0U;\n+\tu32 mask = n <= 32 ? (1U << n) - 1 : ~0U;\n \n \twhile (n > 0) {\n \t\tvalue |= ((u32)report[idx] >> bit_shift) << bit_nr;\n",
            "diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c\nindex 9c1d31f63f85..0ad2b0a5d08b 100644\n--- a/drivers/hid/hid-core.c\n+++ b/drivers/hid/hid-core.c\n@@ -1355,6 +1355,9 @@ static u32 s32ton(__s32 value, unsigned n)\n \n static u32 __extract(u8 *report, unsigned offset, int n)\n {\n+\tif (n > 32) {\n+\t\tn = 32;\n+\t}\n \tunsigned int idx = offset / 8;\n \tunsigned int bit_nr = 0;\n \tunsigned int bit_shift = offset % 8;\n"
        ],
        "error": []
    },
    "6cd217d3878763ebef28a8fd279c88e791c1c9ef": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/fork.c b/kernel/fork.c\nindex f68954d05e89..595abfa2505a 100644\n--- a/kernel/fork.c\n+++ b/kernel/fork.c\n@@ -2298,6 +2298,7 @@ static __latent_entropy struct task_struct *copy_process(\n \tif (clone_flags & CLONE_PIDFD) {\n \t\tretval = get_unused_fd_flags(O_RDWR | O_CLOEXEC);\n \t\tif (retval < 0)\n+\t\t\tput_pid(pid);\n \t\t\tgoto bad_fork_free_pid;\n \n \t\tpidfd = retval;\n",
            "diff --git a/kernel/fork.c b/kernel/fork.c\nindex f68954d05e89..595abfa2505a 100644\n--- a/kernel/fork.c\n+++ b/kernel/fork.c\n@@ -2298,6 +2298,7 @@ static __latent_entropy struct task_struct *copy_process(\n \tif (clone_flags & CLONE_PIDFD) {\n \t\tretval = get_unused_fd_flags(O_RDWR | O_CLOEXEC);\n \t\tif (retval < 0)\n+\t\t\tput_pid(pid);\n \t\t\tgoto bad_fork_free_pid;\n \n \t\tpidfd = retval;\n",
            "diff --git a/kernel/fork.c b/kernel/fork.c\nindex f68954d05e89..59643694a9bc 100644\n--- a/kernel/fork.c\n+++ b/kernel/fork.c\n@@ -2286,7 +2286,7 @@ static __latent_entropy struct task_struct *copy_process(\n \t\t\t\targs->set_tid_size);\n \t\tif (IS_ERR(pid)) {\n \t\t\tretval = PTR_ERR(pid);\n-\t\t\tgoto bad_fork_cleanup_thread;\n+\t\t\tgoto bad_fork_free_pid;\n \t\t}\n \t}\n \n",
            "diff --git a/kernel/fork.c b/kernel/fork.c\nindex f68954d05e89..59643694a9bc 100644\n--- a/kernel/fork.c\n+++ b/kernel/fork.c\n@@ -2286,7 +2286,7 @@ static __latent_entropy struct task_struct *copy_process(\n \t\t\t\targs->set_tid_size);\n \t\tif (IS_ERR(pid)) {\n \t\t\tretval = PTR_ERR(pid);\n-\t\t\tgoto bad_fork_cleanup_thread;\n+\t\t\tgoto bad_fork_free_pid;\n \t\t}\n \t}\n \n",
            "diff --git a/kernel/fork.c b/kernel/fork.c\nindex f68954d05e89..4a20261197ab 100644\n--- a/kernel/fork.c\n+++ b/kernel/fork.c\n@@ -2298,7 +2298,8 @@ static __latent_entropy struct task_struct *copy_process(\n \tif (clone_flags & CLONE_PIDFD) {\n \t\tretval = get_unused_fd_flags(O_RDWR | O_CLOEXEC);\n \t\tif (retval < 0)\n-\t\t\tgoto bad_fork_free_pid;\n+\t\t\tfree_pid(pid);\n+\t\t\tgoto bad_fork_cleanup_thread;\n \n \t\tpidfd = retval;\n \n"
        ],
        "error": []
    },
    "36a409539269df8733aaba8c3b36cf2fc7091cf7": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/sched/cls_tcindex.c b/net/sched/cls_tcindex.c\nindex eb0e9458e722..7389c9143138 100644\n--- a/net/sched/cls_tcindex.c\n+++ b/net/sched/cls_tcindex.c\n@@ -521,6 +521,7 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \telse if (balloc == 2)\n \t\tkfree(cp->h);\n \ttcf_exts_destroy(&new_filter_result.exts);\n+\ttcf_exts_destroy(&e);  // Ensure tcf_exts is destroyed in all error paths\n errout:\n \tkfree(cp);\n \ttcf_exts_destroy(&e);\n",
            "diff --git a/net/sched/cls_tcindex.c b/net/sched/cls_tcindex.c\nindex eb0e9458e722..ed103357cd01 100644\n--- a/net/sched/cls_tcindex.c\n+++ b/net/sched/cls_tcindex.c\n@@ -520,6 +520,8 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \t\ttcindex_free_perfect_hash(cp);\n \telse if (balloc == 2)\n \t\tkfree(cp->h);\n+\tif (f)\n+\t\tkfree(f);\n \ttcf_exts_destroy(&new_filter_result.exts);\n errout:\n \tkfree(cp);\n",
            "diff --git a/net/sched/cls_tcindex.c b/net/sched/cls_tcindex.c\nindex eb0e9458e722..ed103357cd01 100644\n--- a/net/sched/cls_tcindex.c\n+++ b/net/sched/cls_tcindex.c\n@@ -520,6 +520,8 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \t\ttcindex_free_perfect_hash(cp);\n \telse if (balloc == 2)\n \t\tkfree(cp->h);\n+\tif (f)\n+\t\tkfree(f);\n \ttcf_exts_destroy(&new_filter_result.exts);\n errout:\n \tkfree(cp);\n",
            "diff --git a/net/sched/cls_tcindex.c b/net/sched/cls_tcindex.c\nindex eb0e9458e722..ed103357cd01 100644\n--- a/net/sched/cls_tcindex.c\n+++ b/net/sched/cls_tcindex.c\n@@ -520,6 +520,8 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \t\ttcindex_free_perfect_hash(cp);\n \telse if (balloc == 2)\n \t\tkfree(cp->h);\n+\tif (f)\n+\t\tkfree(f);\n \ttcf_exts_destroy(&new_filter_result.exts);\n errout:\n \tkfree(cp);\n",
            "diff --git a/net/sched/cls_tcindex.c b/net/sched/cls_tcindex.c\nindex eb0e9458e722..ed103357cd01 100644\n--- a/net/sched/cls_tcindex.c\n+++ b/net/sched/cls_tcindex.c\n@@ -520,6 +520,8 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \t\ttcindex_free_perfect_hash(cp);\n \telse if (balloc == 2)\n \t\tkfree(cp->h);\n+\tif (f)\n+\t\tkfree(f);\n \ttcf_exts_destroy(&new_filter_result.exts);\n errout:\n \tkfree(cp);\n"
        ],
        "error": []
    },
    "9d6af32008ffd651175d152c5bea92cf767ae38c": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/io_uring/io_uring.c b/io_uring/io_uring.c\nindex 2ac1cd8d23ea..9691fc986ef0 100644\n--- a/io_uring/io_uring.c\n+++ b/io_uring/io_uring.c\n@@ -2387,6 +2387,7 @@ int io_submit_sqes(struct io_ring_ctx *ctx, unsigned int nr)\n \t\tsqe = io_get_sqe(ctx);\n \t\tif (unlikely(!sqe)) {\n \t\t\tio_req_add_to_cache(req, ctx);\n+\t\t\tio_free_req(req); // Free the request if SQE is not available\n \t\t\tbreak;\n \t\t}\n \ndiff --git a/io_uring/poll.c b/io_uring/poll.c\nindex ee7da6150ec4..b1dba48393de 100644\n--- a/io_uring/poll.c\n+++ b/io_uring/poll.c\n@@ -692,8 +692,10 @@ int io_arm_poll_handler(struct io_kiocb *req, unsigned issue_flags)\n \t\tmask |= EPOLLEXCLUSIVE;\n \n \tapoll = io_req_alloc_apoll(req, issue_flags);\n-\tif (!apoll)\n+\tif (!apoll) {\n+\t\tio_free_req(req); // Free the request if apoll allocation fails\n \t\treturn IO_APOLL_ABORTED;\n+\t}\n \treq->flags |= REQ_F_POLLED;\n \tipt.pt._qproc = io_async_queue_proc;\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/io_uring/io_uring.c b/io_uring/io_uring.c\nindex 2ac1cd8d23ea..aa0d934d9279 100644\n--- a/io_uring/io_uring.c\n+++ b/io_uring/io_uring.c\n@@ -2386,7 +2386,7 @@ int io_submit_sqes(struct io_ring_ctx *ctx, unsigned int nr)\n \t\treq = io_alloc_req(ctx);\n \t\tsqe = io_get_sqe(ctx);\n \t\tif (unlikely(!sqe)) {\n-\t\t\tio_req_add_to_cache(req, ctx);\n+\t\t\tio_req_free(req); // Free the request if sqe is not available\n \t\t\tbreak;\n \t\t}\n \n@@ -2396,6 +2396,7 @@ int io_submit_sqes(struct io_ring_ctx *ctx, unsigned int nr)\n \t\t */\n \t\tif (unlikely(io_submit_sqe(ctx, req, sqe)) &&\n \t\t    !(ctx->flags & IORING_SETUP_SUBMIT_ALL)) {\n+\t\t\tio_req_free(req); // Free the request if submission fails\n \t\t\tleft--;\n \t\t\tbreak;\n \t\t}\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/io_uring/io_uring.c b/io_uring/io_uring.c\nindex 2ac1cd8d23ea..366b103614b7 100644\n--- a/io_uring/io_uring.c\n+++ b/io_uring/io_uring.c\n@@ -2386,7 +2386,7 @@ int io_submit_sqes(struct io_ring_ctx *ctx, unsigned int nr)\n \t\treq = io_alloc_req(ctx);\n \t\tsqe = io_get_sqe(ctx);\n \t\tif (unlikely(!sqe)) {\n-\t\t\tio_req_add_to_cache(req, ctx);\n+\t\t\tio_req_free(req); // Free the request if sqe is NULL\n \t\t\tbreak;\n \t\t}\n \ndiff --git a/io_uring/poll.c b/io_uring/poll.c\nindex ee7da6150ec4..aaa4b4fc71f3 100644\n--- a/io_uring/poll.c\n+++ b/io_uring/poll.c\n@@ -692,8 +692,10 @@ int io_arm_poll_handler(struct io_kiocb *req, unsigned issue_flags)\n \t\tmask |= EPOLLEXCLUSIVE;\n \n \tapoll = io_req_alloc_apoll(req, issue_flags);\n-\tif (!apoll)\n+\tif (!apoll) {\n+\t\tio_req_free(req); // Free the request if apoll allocation fails\n \t\treturn IO_APOLL_ABORTED;\n+\t}\n \treq->flags |= REQ_F_POLLED;\n \tipt.pt._qproc = io_async_queue_proc;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/io_uring/io_uring.c b/io_uring/io_uring.c\nindex 2ac1cd8d23ea..aa0d934d9279 100644\n--- a/io_uring/io_uring.c\n+++ b/io_uring/io_uring.c\n@@ -2386,7 +2386,7 @@ int io_submit_sqes(struct io_ring_ctx *ctx, unsigned int nr)\n \t\treq = io_alloc_req(ctx);\n \t\tsqe = io_get_sqe(ctx);\n \t\tif (unlikely(!sqe)) {\n-\t\t\tio_req_add_to_cache(req, ctx);\n+\t\t\tio_req_free(req); // Free the request if sqe is not available\n \t\t\tbreak;\n \t\t}\n \n@@ -2396,6 +2396,7 @@ int io_submit_sqes(struct io_ring_ctx *ctx, unsigned int nr)\n \t\t */\n \t\tif (unlikely(io_submit_sqe(ctx, req, sqe)) &&\n \t\t    !(ctx->flags & IORING_SETUP_SUBMIT_ALL)) {\n+\t\t\tio_req_free(req); // Free the request if submission fails\n \t\t\tleft--;\n \t\t\tbreak;\n \t\t}\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/io_uring/io_uring.c b/io_uring/io_uring.c\nindex 2ac1cd8d23ea..0a941777f81d 100644\n--- a/io_uring/io_uring.c\n+++ b/io_uring/io_uring.c\n@@ -2386,7 +2386,7 @@ int io_submit_sqes(struct io_ring_ctx *ctx, unsigned int nr)\n \t\treq = io_alloc_req(ctx);\n \t\tsqe = io_get_sqe(ctx);\n \t\tif (unlikely(!sqe)) {\n-\t\t\tio_req_add_to_cache(req, ctx);\n+\t\t\tio_req_free(req); // Free the request on failure\n \t\t\tbreak;\n \t\t}\n \n@@ -2396,6 +2396,7 @@ int io_submit_sqes(struct io_ring_ctx *ctx, unsigned int nr)\n \t\t */\n \t\tif (unlikely(io_submit_sqe(ctx, req, sqe)) &&\n \t\t    !(ctx->flags & IORING_SETUP_SUBMIT_ALL)) {\n+\t\t\tio_req_free(req); // Free the request on failure\n \t\t\tleft--;\n \t\t\tbreak;\n \t\t}\ndiff --git a/io_uring/poll.c b/io_uring/poll.c\nindex ee7da6150ec4..aabee1870d25 100644\n--- a/io_uring/poll.c\n+++ b/io_uring/poll.c\n@@ -692,8 +692,10 @@ int io_arm_poll_handler(struct io_kiocb *req, unsigned issue_flags)\n \t\tmask |= EPOLLEXCLUSIVE;\n \n \tapoll = io_req_alloc_apoll(req, issue_flags);\n-\tif (!apoll)\n+\tif (!apoll) {\n+\t\tio_req_free(req); // Free the request on failure\n \t\treturn IO_APOLL_ABORTED;\n+\t}\n \treq->flags |= REQ_F_POLLED;\n \tipt.pt._qproc = io_async_queue_proc;\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "392ce929bb0e269e6782a4d0586e5f187b9e4d92": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c\nindex d4b75a6cfeee..1164538c0f94 100644\n--- a/net/bluetooth/hci_event.c\n+++ b/net/bluetooth/hci_event.c\n@@ -5906,7 +5906,7 @@ static void hci_le_adv_report_evt(struct hci_dev *hdev, struct sk_buff *skb)\n \t\tstruct hci_ev_le_advertising_info *ev = ptr;\n \t\ts8 rssi;\n \n-\t\tif (ev->length <= HCI_MAX_AD_LENGTH) {\n+\t\tif (ev->length < HCI_MAX_AD_LENGTH) {\n \t\t\trssi = ev->data[ev->length];\n \t\t\tprocess_adv_report(hdev, ev->evt_type, &ev->bdaddr,\n \t\t\t\t\t   ev->bdaddr_type, NULL, 0, rssi,\n",
            "diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c\nindex d4b75a6cfeee..1164538c0f94 100644\n--- a/net/bluetooth/hci_event.c\n+++ b/net/bluetooth/hci_event.c\n@@ -5906,7 +5906,7 @@ static void hci_le_adv_report_evt(struct hci_dev *hdev, struct sk_buff *skb)\n \t\tstruct hci_ev_le_advertising_info *ev = ptr;\n \t\ts8 rssi;\n \n-\t\tif (ev->length <= HCI_MAX_AD_LENGTH) {\n+\t\tif (ev->length < HCI_MAX_AD_LENGTH) {\n \t\t\trssi = ev->data[ev->length];\n \t\t\tprocess_adv_report(hdev, ev->evt_type, &ev->bdaddr,\n \t\t\t\t\t   ev->bdaddr_type, NULL, 0, rssi,\n",
            "diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c\nindex d4b75a6cfeee..1164538c0f94 100644\n--- a/net/bluetooth/hci_event.c\n+++ b/net/bluetooth/hci_event.c\n@@ -5906,7 +5906,7 @@ static void hci_le_adv_report_evt(struct hci_dev *hdev, struct sk_buff *skb)\n \t\tstruct hci_ev_le_advertising_info *ev = ptr;\n \t\ts8 rssi;\n \n-\t\tif (ev->length <= HCI_MAX_AD_LENGTH) {\n+\t\tif (ev->length < HCI_MAX_AD_LENGTH) {\n \t\t\trssi = ev->data[ev->length];\n \t\t\tprocess_adv_report(hdev, ev->evt_type, &ev->bdaddr,\n \t\t\t\t\t   ev->bdaddr_type, NULL, 0, rssi,\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c\nindex d4b75a6cfeee..1e7ca264eede 100644\n--- a/net/bluetooth/hci_event.c\n+++ b/net/bluetooth/hci_event.c\n@@ -5906,13 +5906,17 @@ static void hci_le_adv_report_evt(struct hci_dev *hdev, struct sk_buff *skb)\n \t\tstruct hci_ev_le_advertising_info *ev = ptr;\n \t\ts8 rssi;\n \n-\t\tif (ev->length <= HCI_MAX_AD_LENGTH) {\n-\t\t\trssi = ev->data[ev->length];\n-\t\t\tprocess_adv_report(hdev, ev->evt_type, &ev->bdaddr,\n-\t\t\t\t\t   ev->bdaddr_type, NULL, 0, rssi,\n-\t\t\t\t\t   ev->data, ev->length, false);\n+\t\tif (ev->length < HCI_MAX_AD_LENGTH) {\n+\t\t\tif (ev->length < sizeof(ev->data)) {\n+\t\t\t\trssi = ev->data[ev->length];\n+\t\t\t\tprocess_adv_report(hdev, ev->evt_type, &ev->bdaddr,\n+\t\t\t\t\t\t   ev->bdaddr_type, NULL, 0, rssi,\n+\t\t\t\t\t\t   ev->data, ev->length, false);\n+\t\t\t} else {\n+\t\t\t\tbt_dev_err(hdev, \"Dropping invalid advertising data due to length exceeding buffer size\");\n+\t\t\t}\n \t\t} else {\n-\t\t\tbt_dev_err(hdev, \"Dropping invalid advertising data\");\n+\t\t\tbt_dev_err(hdev, \"Dropping invalid advertising data due to length exceeding max allowed\");\n \t\t}\n \n \t\tptr += sizeof(*ev) + ev->length + 1;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c\nindex d4b75a6cfeee..8910764cda78 100644\n--- a/net/bluetooth/hci_event.c\n+++ b/net/bluetooth/hci_event.c\n@@ -5907,10 +5907,14 @@ static void hci_le_adv_report_evt(struct hci_dev *hdev, struct sk_buff *skb)\n \t\ts8 rssi;\n \n \t\tif (ev->length <= HCI_MAX_AD_LENGTH) {\n-\t\t\trssi = ev->data[ev->length];\n-\t\t\tprocess_adv_report(hdev, ev->evt_type, &ev->bdaddr,\n-\t\t\t\t\t   ev->bdaddr_type, NULL, 0, rssi,\n-\t\t\t\t\t   ev->data, ev->length, false);\n+\t\t\tif (ev->length < sizeof(ev->data)) {\n+\t\t\t\trssi = ev->data[ev->length];\n+\t\t\t\tprocess_adv_report(hdev, ev->evt_type, &ev->bdaddr,\n+\t\t\t\t\t\t   ev->bdaddr_type, NULL, 0, rssi,\n+\t\t\t\t\t\t   ev->data, ev->length, false);\n+\t\t\t} else {\n+\t\t\t\tbt_dev_err(hdev, \"Dropping invalid advertising data due to length\");\n+\t\t\t}\n \t\t} else {\n \t\t\tbt_dev_err(hdev, \"Dropping invalid advertising data\");\n \t\t}\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "4f6ce6f5223c2c8e75c92ce8cb619b227a8b0277": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/tipc/node.c b/net/tipc/node.c\nindex a4c2816c3746..74773103f019 100644\n--- a/net/tipc/node.c\n+++ b/net/tipc/node.c\n@@ -2587,7 +2587,7 @@ int tipc_nl_node_dump_link(struct sk_buff *skb, struct netlink_callback *cb)\n \n \tif (!prev_node) {\n \t\t/* Check if broadcast-receiver links dumping is needed */\n-\t\tif (attrs && attrs[TIPC_NLA_LINK]) {\n+\t\tif (attrs && attrs[TIPC_NLA_LINK] && !kasan_check_free(attrs[TIPC_NLA_LINK])) {\n \t\t\terr = nla_parse_nested_deprecated(link,\n \t\t\t\t\t\t\t  TIPC_NLA_LINK_MAX,\n \t\t\t\t\t\t\t  attrs[TIPC_NLA_LINK],\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "f7649aa07ffca82dc93dc5cebc00c665849f5138": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/security/keys/request_key.c b/security/keys/request_key.c\nindex 3f56a312dd35..042d26846299 100644\n--- a/security/keys/request_key.c\n+++ b/security/keys/request_key.c\n@@ -371,7 +371,7 @@ static int construct_alloc_key(struct keyring_search_context *ctx,\n \n \tset_bit(KEY_FLAG_USER_CONSTRUCT, &key->flags);\n \n-\tif (dest_keyring) {\n+\tif (dest_keyring && ctx->index_key.description) {\n \t\tret = __key_link_begin(dest_keyring, &ctx->index_key, &edit);\n \t\tif (ret < 0)\n \t\t\tgoto link_prealloc_failed;\n",
            "diff --git a/security/keys/request_key.c b/security/keys/request_key.c\nindex 3f56a312dd35..9fdb762f04a9 100644\n--- a/security/keys/request_key.c\n+++ b/security/keys/request_key.c\n@@ -371,10 +371,13 @@ static int construct_alloc_key(struct keyring_search_context *ctx,\n \n \tset_bit(KEY_FLAG_USER_CONSTRUCT, &key->flags);\n \n-\tif (dest_keyring) {\n+\tif (dest_keyring && dest_keyring->type) { // Ensure dest_keyring is valid\n \t\tret = __key_link_begin(dest_keyring, &ctx->index_key, &edit);\n \t\tif (ret < 0)\n \t\t\tgoto link_prealloc_failed;\n+\t} else {\n+\t\tret = -EINVAL; // Return an error if dest_keyring is invalid\n+\t\tgoto link_prealloc_failed;\n \t}\n \n \t/* attach the key to the destination keyring under lock, but we do need\n"
        ],
        "error": [
            {
                "patch": "diff --git a/security/keys/request_key.c b/security/keys/request_key.c\nindex 3f56a312dd35..2a9eedd738e8 100644\n--- a/security/keys/request_key.c\n+++ b/security/keys/request_key.c\n@@ -371,10 +371,13 @@ static int construct_alloc_key(struct keyring_search_context *ctx,\n \n \tset_bit(KEY_FLAG_USER_CONSTRUCT, &key->flags);\n \n-\tif (dest_keyring) {\n+\tif (dest_keyring && ctx->index_key.type && ctx->index_key.description) {\n \t\tret = __key_link_begin(dest_keyring, &ctx->index_key, &edit);\n \t\tif (ret < 0)\n \t\t\tgoto link_prealloc_failed;\n+\t} else {\n+\t\tret = -EINVAL;\n+\t\tgoto error;\n \t}\n \n \t/* attach the key to the destination keyring under lock, but we do need\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/security/keys/request_key.c b/security/keys/request_key.c\nindex 3f56a312dd35..d0b82ff65cb8 100644\n--- a/security/keys/request_key.c\n+++ b/security/keys/request_key.c\n@@ -373,8 +373,13 @@ static int construct_alloc_key(struct keyring_search_context *ctx,\n \n \tif (dest_keyring) {\n \t\tret = __key_link_begin(dest_keyring, &ctx->index_key, &edit);\n-\t\tif (ret < 0)\n+\t\tif (ret < 0) {\n+\t\t\tif (ret == -EINVAL) {\n+\t\t\t\t/* Handle invalid argument error */\n+\t\t\t\tgoto error_put_dest_keyring;\n+\t\t\t}\n \t\t\tgoto link_prealloc_failed;\n+\t\t}\n \t}\n \n \t/* attach the key to the destination keyring under lock, but we do need\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "bb3342477c4669ef082c7056b6e2be4f903e646e": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/bmap.c b/fs/nilfs2/bmap.c\nindex 798a2c1b38c6..b1f0eaf0c397 100644\n--- a/fs/nilfs2/bmap.c\n+++ b/fs/nilfs2/bmap.c\n@@ -59,6 +59,11 @@ static int nilfs_bmap_convert_error(struct nilfs_bmap *bmap,\n  *\n  * %-ENOENT - A record associated with @key does not exist.\n  */\n+void nilfs_bmap_init(struct nilfs_bmap *bmap)\n+{\n+\tinit_rwsem(&bmap->b_sem);\n+}\n+\n int nilfs_bmap_lookup_at_level(struct nilfs_bmap *bmap, __u64 key, int level,\n \t\t\t       __u64 *ptrp)\n {\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/nilfs2/bmap.c b/fs/nilfs2/bmap.c\nindex 798a2c1b38c6..32d8736dc14d 100644\n--- a/fs/nilfs2/bmap.c\n+++ b/fs/nilfs2/bmap.c\n@@ -65,6 +65,11 @@ int nilfs_bmap_lookup_at_level(struct nilfs_bmap *bmap, __u64 key, int level,\n \tsector_t blocknr;\n \tint ret;\n \n+\tif (!bmap->b_sem.initialized) {\n+\t\tinit_rwsem(&bmap->b_sem);\n+\t\tbmap->b_sem.initialized = true;\n+\t}\n+\n \tdown_read(&bmap->b_sem);\n \tret = bmap->b_ops->bop_lookup(bmap, key, level, ptrp);\n \tif (ret < 0) {\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/nilfs2/bmap.c b/fs/nilfs2/bmap.c\nindex 798a2c1b38c6..83cd924309a1 100644\n--- a/fs/nilfs2/bmap.c\n+++ b/fs/nilfs2/bmap.c\n@@ -65,6 +65,10 @@ int nilfs_bmap_lookup_at_level(struct nilfs_bmap *bmap, __u64 key, int level,\n \tsector_t blocknr;\n \tint ret;\n \n+\tif (!bmap->b_sem.initialized) {\n+\t\tinit_rwsem(&bmap->b_sem);\n+\t\tbmap->b_sem.initialized = true;\n+\t}\n \tdown_read(&bmap->b_sem);\n \tret = bmap->b_ops->bop_lookup(bmap, key, level, ptrp);\n \tif (ret < 0) {\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/nilfs2/bmap.c b/fs/nilfs2/bmap.c\nindex 798a2c1b38c6..8316180a5fab 100644\n--- a/fs/nilfs2/bmap.c\n+++ b/fs/nilfs2/bmap.c\n@@ -65,6 +65,10 @@ int nilfs_bmap_lookup_at_level(struct nilfs_bmap *bmap, __u64 key, int level,\n \tsector_t blocknr;\n \tint ret;\n \n+\tif (!bmap->b_sem.initialized) {\n+\t\tinit_rwsem(&bmap->b_sem);\n+\t}\n+\n \tdown_read(&bmap->b_sem);\n \tret = bmap->b_ops->bop_lookup(bmap, key, level, ptrp);\n \tif (ret < 0) {\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/nilfs2/bmap.c b/fs/nilfs2/bmap.c\nindex 798a2c1b38c6..83cd924309a1 100644\n--- a/fs/nilfs2/bmap.c\n+++ b/fs/nilfs2/bmap.c\n@@ -65,6 +65,10 @@ int nilfs_bmap_lookup_at_level(struct nilfs_bmap *bmap, __u64 key, int level,\n \tsector_t blocknr;\n \tint ret;\n \n+\tif (!bmap->b_sem.initialized) {\n+\t\tinit_rwsem(&bmap->b_sem);\n+\t\tbmap->b_sem.initialized = true;\n+\t}\n \tdown_read(&bmap->b_sem);\n \tret = bmap->b_ops->bop_lookup(bmap, key, level, ptrp);\n \tif (ret < 0) {\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "e0623166295289b0b91d327386331328f3f2505d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/core/dev.c b/net/core/dev.c\nindex 90b59fc50dc9..12ce80e6eb3d 100644\n--- a/net/core/dev.c\n+++ b/net/core/dev.c\n@@ -7476,7 +7476,9 @@ static void netdev_adjacent_sysfs_del(struct net_device *dev,\n \n \tsprintf(linkname, dev_list == &dev->adj_list.upper ?\n \t\t\"upper_%s\" : \"lower_%s\", name);\n-\tsysfs_remove_link(&(dev->dev.kobj), linkname);\n+\tif (kobject_name(&(dev->dev.kobj))) {\n+        sysfs_remove_link(&(dev->dev.kobj), linkname);\n+    }\n }\n \n static inline bool netdev_adjacent_is_neigh_list(struct net_device *dev,\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/core/dev.c b/net/core/dev.c\nindex 90b59fc50dc9..2945a8ffa021 100644\n--- a/net/core/dev.c\n+++ b/net/core/dev.c\n@@ -7476,7 +7476,8 @@ static void netdev_adjacent_sysfs_del(struct net_device *dev,\n \n \tsprintf(linkname, dev_list == &dev->adj_list.upper ?\n \t\t\"upper_%s\" : \"lower_%s\", name);\n-\tsysfs_remove_link(&(dev->dev.kobj), linkname);\n+\tif (sysfs_link_exists(&(dev->dev.kobj), linkname))\n+\t\tsysfs_remove_link(&(dev->dev.kobj), linkname);\n }\n \n static inline bool netdev_adjacent_is_neigh_list(struct net_device *dev,\ndiff --git a/net/hsr/hsr_device.c b/net/hsr/hsr_device.c\nindex 478852ef98ef..4f47f200ce72 100644\n--- a/net/hsr/hsr_device.c\n+++ b/net/hsr/hsr_device.c\n@@ -480,10 +480,9 @@ int hsr_dev_finalize(struct net_device *hsr_dev, struct net_device *slave[2],\n \treturn 0;\n \n err_add_slaves:\n+\thsr_del_ports(hsr);\n \tunregister_netdevice(hsr_dev);\n err_unregister:\n-\thsr_del_ports(hsr);\n-err_add_master:\n \thsr_del_self_node(hsr);\n \n \treturn res;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/core/dev.c b/net/core/dev.c\nindex 90b59fc50dc9..d3d6d22fbe77 100644\n--- a/net/core/dev.c\n+++ b/net/core/dev.c\n@@ -7476,7 +7476,8 @@ static void netdev_adjacent_sysfs_del(struct net_device *dev,\n \n \tsprintf(linkname, dev_list == &dev->adj_list.upper ?\n \t\t\"upper_%s\" : \"lower_%s\", name);\n-\tsysfs_remove_link(&(dev->dev.kobj), linkname);\n+\tif (sysfs_link_exists(&(dev->dev.kobj), linkname))\n+\t\tsysfs_remove_link(&(dev->dev.kobj), linkname);\n }\n \n static inline bool netdev_adjacent_is_neigh_list(struct net_device *dev,\n@@ -8988,8 +8989,10 @@ static void rollback_registered_many(struct list_head *head)\n \t\t\trtmsg_ifinfo_send(skb, dev, GFP_KERNEL);\n \n \t\t/* Notifier chain MUST detach us all upper devices. */\n-\t\tWARN_ON(netdev_has_any_upper_dev(dev));\n-\t\tWARN_ON(netdev_has_any_lower_dev(dev));\n+\t\tif (netdev_has_any_upper_dev(dev))\n+\t\t\tpr_warn(\"Device %s still has upper devices\\n\", dev->name);\n+\t\tif (netdev_has_any_lower_dev(dev))\n+\t\t\tpr_warn(\"Device %s still has lower devices\\n\", dev->name);\n \n \t\t/* Remove entries from kobject tree */\n \t\tnetdev_unregister_kobject(dev);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/core/dev.c b/net/core/dev.c\nindex 90b59fc50dc9..2945a8ffa021 100644\n--- a/net/core/dev.c\n+++ b/net/core/dev.c\n@@ -7476,7 +7476,8 @@ static void netdev_adjacent_sysfs_del(struct net_device *dev,\n \n \tsprintf(linkname, dev_list == &dev->adj_list.upper ?\n \t\t\"upper_%s\" : \"lower_%s\", name);\n-\tsysfs_remove_link(&(dev->dev.kobj), linkname);\n+\tif (sysfs_link_exists(&(dev->dev.kobj), linkname))\n+\t\tsysfs_remove_link(&(dev->dev.kobj), linkname);\n }\n \n static inline bool netdev_adjacent_is_neigh_list(struct net_device *dev,\ndiff --git a/net/hsr/hsr_device.c b/net/hsr/hsr_device.c\nindex 478852ef98ef..e25270b67bf4 100644\n--- a/net/hsr/hsr_device.c\n+++ b/net/hsr/hsr_device.c\n@@ -480,9 +480,8 @@ int hsr_dev_finalize(struct net_device *hsr_dev, struct net_device *slave[2],\n \treturn 0;\n \n err_add_slaves:\n-\tunregister_netdevice(hsr_dev);\n-err_unregister:\n \thsr_del_ports(hsr);\n+\tunregister_netdevice(hsr_dev);\n err_add_master:\n \thsr_del_self_node(hsr);\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/core/dev.c b/net/core/dev.c\nindex 90b59fc50dc9..2945a8ffa021 100644\n--- a/net/core/dev.c\n+++ b/net/core/dev.c\n@@ -7476,7 +7476,8 @@ static void netdev_adjacent_sysfs_del(struct net_device *dev,\n \n \tsprintf(linkname, dev_list == &dev->adj_list.upper ?\n \t\t\"upper_%s\" : \"lower_%s\", name);\n-\tsysfs_remove_link(&(dev->dev.kobj), linkname);\n+\tif (sysfs_link_exists(&(dev->dev.kobj), linkname))\n+\t\tsysfs_remove_link(&(dev->dev.kobj), linkname);\n }\n \n static inline bool netdev_adjacent_is_neigh_list(struct net_device *dev,\ndiff --git a/net/hsr/hsr_device.c b/net/hsr/hsr_device.c\nindex 478852ef98ef..e25270b67bf4 100644\n--- a/net/hsr/hsr_device.c\n+++ b/net/hsr/hsr_device.c\n@@ -480,9 +480,8 @@ int hsr_dev_finalize(struct net_device *hsr_dev, struct net_device *slave[2],\n \treturn 0;\n \n err_add_slaves:\n-\tunregister_netdevice(hsr_dev);\n-err_unregister:\n \thsr_del_ports(hsr);\n+\tunregister_netdevice(hsr_dev);\n err_add_master:\n \thsr_del_self_node(hsr);\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "35dd38010e383ee37d27b39f6b50eb25b4c92dd2": {
        "non_crash": [
            "diff --git a/drivers/media/usb/siano/smsusb.c b/drivers/media/usb/siano/smsusb.c\nindex 6f443c542c6d..dcda1b8a8aab 100644\n--- a/drivers/media/usb/siano/smsusb.c\n+++ b/drivers/media/usb/siano/smsusb.c\n@@ -179,7 +179,8 @@ static void smsusb_stop_streaming(struct smsusb_device_t *dev)\n \n \tfor (i = 0; i < MAX_URBS; i++) {\n \t\tusb_kill_urb(&dev->surbs[i].urb);\n-\t\tcancel_work_sync(&dev->surbs[i].wq);\n+\t\tif (work_pending(&dev->surbs[i].wq))\n+\t\t\tcancel_work_sync(&dev->surbs[i].wq);\n \n \t\tif (dev->surbs[i].cb) {\n \t\t\tsmscore_putbuffer(dev->coredev, dev->surbs[i].cb);\n",
            "diff --git a/drivers/media/usb/siano/smsusb.c b/drivers/media/usb/siano/smsusb.c\nindex 6f443c542c6d..640737d3b8ae 100644\n--- a/drivers/media/usb/siano/smsusb.c\n+++ b/drivers/media/usb/siano/smsusb.c\n@@ -179,7 +179,8 @@ static void smsusb_stop_streaming(struct smsusb_device_t *dev)\n \n \tfor (i = 0; i < MAX_URBS; i++) {\n \t\tusb_kill_urb(&dev->surbs[i].urb);\n-\t\tcancel_work_sync(&dev->surbs[i].wq);\n+\t\tif (dev->surbs[i].wq.func)\n+\t\t\tcancel_work_sync(&dev->surbs[i].wq);\n \n \t\tif (dev->surbs[i].cb) {\n \t\t\tsmscore_putbuffer(dev->coredev, dev->surbs[i].cb);\n",
            "diff --git a/drivers/media/usb/siano/smsusb.c b/drivers/media/usb/siano/smsusb.c\nindex 6f443c542c6d..640737d3b8ae 100644\n--- a/drivers/media/usb/siano/smsusb.c\n+++ b/drivers/media/usb/siano/smsusb.c\n@@ -179,7 +179,8 @@ static void smsusb_stop_streaming(struct smsusb_device_t *dev)\n \n \tfor (i = 0; i < MAX_URBS; i++) {\n \t\tusb_kill_urb(&dev->surbs[i].urb);\n-\t\tcancel_work_sync(&dev->surbs[i].wq);\n+\t\tif (dev->surbs[i].wq.func)\n+\t\t\tcancel_work_sync(&dev->surbs[i].wq);\n \n \t\tif (dev->surbs[i].cb) {\n \t\t\tsmscore_putbuffer(dev->coredev, dev->surbs[i].cb);\n",
            "diff --git a/drivers/media/usb/siano/smsusb.c b/drivers/media/usb/siano/smsusb.c\nindex 6f443c542c6d..640737d3b8ae 100644\n--- a/drivers/media/usb/siano/smsusb.c\n+++ b/drivers/media/usb/siano/smsusb.c\n@@ -179,7 +179,8 @@ static void smsusb_stop_streaming(struct smsusb_device_t *dev)\n \n \tfor (i = 0; i < MAX_URBS; i++) {\n \t\tusb_kill_urb(&dev->surbs[i].urb);\n-\t\tcancel_work_sync(&dev->surbs[i].wq);\n+\t\tif (dev->surbs[i].wq.func)\n+\t\t\tcancel_work_sync(&dev->surbs[i].wq);\n \n \t\tif (dev->surbs[i].cb) {\n \t\t\tsmscore_putbuffer(dev->coredev, dev->surbs[i].cb);\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/media/usb/siano/smsusb.c b/drivers/media/usb/siano/smsusb.c\nindex 6f443c542c6d..d63a1d61d509 100644\n--- a/drivers/media/usb/siano/smsusb.c\n+++ b/drivers/media/usb/siano/smsusb.c\n@@ -178,8 +178,8 @@ static void smsusb_stop_streaming(struct smsusb_device_t *dev)\n \tint i;\n \n \tfor (i = 0; i < MAX_URBS; i++) {\n-\t\tusb_kill_urb(&dev->surbs[i].urb);\n \t\tcancel_work_sync(&dev->surbs[i].wq);\n+\t\tusb_kill_urb(&dev->surbs[i].urb);\n \n \t\tif (dev->surbs[i].cb) {\n \t\t\tsmscore_putbuffer(dev->coredev, dev->surbs[i].cb);\n"
        ],
        "error": []
    },
    "f07cf3e7df6d272b92ccdabfeef07ae06c014ca5": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/namei.c b/fs/ext4/namei.c\nindex e8f429330f3c..0068399b872b 100644\n--- a/fs/ext4/namei.c\n+++ b/fs/ext4/namei.c\n@@ -3877,12 +3877,16 @@ static int ext4_rename(struct user_namespace *mnt_userns, struct inode *old_dir,\n \t\t * We need to protect against old.inode directory getting\n \t\t * converted from inline directory format into a normal one.\n \t\t */\n-\t\tinode_lock_nested(old.inode, I_MUTEX_NONDIR2);\n+\t\t/*\n+\t\t * Avoid holding i_mutex while waiting for journal commit\n+\t\t * to prevent deadlock with jbd2_handle lock.\n+\t\t */\n+\t\tinode_unlock(old.inode);\n \t\tretval = ext4_rename_dir_prepare(handle, &old);\n \t\tif (retval) {\n-\t\t\tinode_unlock(old.inode);\n \t\t\tgoto end_rename;\n \t\t}\n+\t\tinode_lock_nested(old.inode, I_MUTEX_NONDIR2);\n \t}\n \t/*\n \t * If we're renaming a file within an inline_data dir and adding or\n",
            "diff --git a/fs/ext4/namei.c b/fs/ext4/namei.c\nindex e8f429330f3c..9330c5cea7a1 100644\n--- a/fs/ext4/namei.c\n+++ b/fs/ext4/namei.c\n@@ -3877,12 +3877,11 @@ static int ext4_rename(struct user_namespace *mnt_userns, struct inode *old_dir,\n \t\t * We need to protect against old.inode directory getting\n \t\t * converted from inline directory format into a normal one.\n \t\t */\n-\t\tinode_lock_nested(old.inode, I_MUTEX_NONDIR2);\n \t\tretval = ext4_rename_dir_prepare(handle, &old);\n \t\tif (retval) {\n-\t\t\tinode_unlock(old.inode);\n \t\t\tgoto end_rename;\n \t\t}\n+\t\tinode_lock_nested(old.inode, I_MUTEX_NONDIR2);\n \t}\n \t/*\n \t * If we're renaming a file within an inline_data dir and adding or\n",
            "diff --git a/fs/ext4/namei.c b/fs/ext4/namei.c\nindex e8f429330f3c..b60a47edafb2 100644\n--- a/fs/ext4/namei.c\n+++ b/fs/ext4/namei.c\n@@ -3877,12 +3877,15 @@ static int ext4_rename(struct user_namespace *mnt_userns, struct inode *old_dir,\n \t\t * We need to protect against old.inode directory getting\n \t\t * converted from inline directory format into a normal one.\n \t\t */\n-\t\tinode_lock_nested(old.inode, I_MUTEX_NONDIR2);\n+\t\t/*\n+\t\t * Release i_mutex before waiting for commit to avoid deadlock.\n+\t\t */\n+\t\tinode_unlock(old.inode);\n \t\tretval = ext4_rename_dir_prepare(handle, &old);\n \t\tif (retval) {\n-\t\t\tinode_unlock(old.inode);\n \t\t\tgoto end_rename;\n \t\t}\n+\t\tinode_lock_nested(old.inode, I_MUTEX_NONDIR2);\n \t}\n \t/*\n \t * If we're renaming a file within an inline_data dir and adding or\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/namei.c b/fs/ext4/namei.c\nindex e8f429330f3c..40909e420bac 100644\n--- a/fs/ext4/namei.c\n+++ b/fs/ext4/namei.c\n@@ -3877,13 +3877,10 @@ static int ext4_rename(struct user_namespace *mnt_userns, struct inode *old_dir,\n \t\t * We need to protect against old.inode directory getting\n \t\t * converted from inline directory format into a normal one.\n \t\t */\n-\t\tinode_lock_nested(old.inode, I_MUTEX_NONDIR2);\n \t\tretval = ext4_rename_dir_prepare(handle, &old);\n-\t\tif (retval) {\n-\t\t\tinode_unlock(old.inode);\n+\t\tif (retval)\n \t\t\tgoto end_rename;\n-\t\t}\n-\t}\n+\t\tinode_lock_nested(old.inode, I_MUTEX_NONDIR2);\n \t/*\n \t * If we're renaming a file within an inline_data dir and adding or\n \t * setting the new dirent causes a conversion from inline_data to\ndiff --git a/fs/jbd2/journal.c b/fs/jbd2/journal.c\nindex 2696f43e7239..bcdc4c4434da 100644\n--- a/fs/jbd2/journal.c\n+++ b/fs/jbd2/journal.c\n@@ -538,7 +538,9 @@ static int __jbd2_journal_force_commit(journal_t *journal)\n \ttid_t tid;\n \tint need_to_start = 0, ret = 0;\n \n+\tinode_unlock(old.inode);\n \tread_lock(&journal->j_state_lock);\n+\tinode_lock_nested(old.inode, I_MUTEX_NONDIR2);\n \tif (journal->j_running_transaction && !current->journal_info) {\n \t\ttransaction = journal->j_running_transaction;\n \t\tif (!tid_geq(journal->j_commit_request, transaction->t_tid))\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/ext4/namei.c b/fs/ext4/namei.c\nindex e8f429330f3c..574abb6e9af9 100644\n--- a/fs/ext4/namei.c\n+++ b/fs/ext4/namei.c\n@@ -2818,7 +2818,9 @@ static int ext4_create(struct user_namespace *mnt_userns, struct inode *dir,\n \t\t\text4_fc_track_create(handle, dentry);\n \t}\n \tif (handle)\n+\t\tinode_unlock(old.inode);\n \t\text4_journal_stop(handle);\n+\t\tinode_lock_nested(old.inode, I_MUTEX_NONDIR2);\n \tif (!IS_ERR_OR_NULL(inode))\n \t\tiput(inode);\n \tif (err == -ENOSPC && ext4_should_retry_alloc(dir->i_sb, &retries))\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "0d0ea881c98701d8dcee7f48b634a84962689fa1": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/net/wireless/virtual/mac80211_hwsim.c b/drivers/net/wireless/virtual/mac80211_hwsim.c\nindex 9a8faaf4c6b6..ae8c3cb45b93 100644\n--- a/drivers/net/wireless/virtual/mac80211_hwsim.c\n+++ b/drivers/net/wireless/virtual/mac80211_hwsim.c\n@@ -5971,10 +5971,12 @@ static int hwsim_new_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \t}\n \n \tret = mac80211_hwsim_new_radio(info, &param);\n+\tif (ret) {\n+\t\tkfree(param.pmsr_capa);\n+\t}\n \n out_free:\n \tkfree(hwname);\n-\tkfree(param.pmsr_capa);\n \treturn ret;\n }\n \n",
            "diff --git a/drivers/net/wireless/virtual/mac80211_hwsim.c b/drivers/net/wireless/virtual/mac80211_hwsim.c\nindex 9a8faaf4c6b6..ae8c3cb45b93 100644\n--- a/drivers/net/wireless/virtual/mac80211_hwsim.c\n+++ b/drivers/net/wireless/virtual/mac80211_hwsim.c\n@@ -5971,10 +5971,12 @@ static int hwsim_new_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \t}\n \n \tret = mac80211_hwsim_new_radio(info, &param);\n+\tif (ret) {\n+\t\tkfree(param.pmsr_capa);\n+\t}\n \n out_free:\n \tkfree(hwname);\n-\tkfree(param.pmsr_capa);\n \treturn ret;\n }\n \n",
            "diff --git a/drivers/net/wireless/virtual/mac80211_hwsim.c b/drivers/net/wireless/virtual/mac80211_hwsim.c\nindex 9a8faaf4c6b6..ae8c3cb45b93 100644\n--- a/drivers/net/wireless/virtual/mac80211_hwsim.c\n+++ b/drivers/net/wireless/virtual/mac80211_hwsim.c\n@@ -5971,10 +5971,12 @@ static int hwsim_new_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \t}\n \n \tret = mac80211_hwsim_new_radio(info, &param);\n+\tif (ret) {\n+\t\tkfree(param.pmsr_capa);\n+\t}\n \n out_free:\n \tkfree(hwname);\n-\tkfree(param.pmsr_capa);\n \treturn ret;\n }\n \n",
            "diff --git a/drivers/net/wireless/virtual/mac80211_hwsim.c b/drivers/net/wireless/virtual/mac80211_hwsim.c\nindex 9a8faaf4c6b6..acd439085201 100644\n--- a/drivers/net/wireless/virtual/mac80211_hwsim.c\n+++ b/drivers/net/wireless/virtual/mac80211_hwsim.c\n@@ -5971,6 +5971,8 @@ static int hwsim_new_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \t}\n \n \tret = mac80211_hwsim_new_radio(info, &param);\n+\tif (ret)\n+\t\tgoto out_free;\n \n out_free:\n \tkfree(hwname);\n",
            "diff --git a/drivers/net/wireless/virtual/mac80211_hwsim.c b/drivers/net/wireless/virtual/mac80211_hwsim.c\nindex 9a8faaf4c6b6..acd439085201 100644\n--- a/drivers/net/wireless/virtual/mac80211_hwsim.c\n+++ b/drivers/net/wireless/virtual/mac80211_hwsim.c\n@@ -5971,6 +5971,8 @@ static int hwsim_new_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \t}\n \n \tret = mac80211_hwsim_new_radio(info, &param);\n+\tif (ret)\n+\t\tgoto out_free;\n \n out_free:\n \tkfree(hwname);\n"
        ],
        "error": []
    },
    "8dba39eccdf108d625bf6acb2bea1aa0c7e1fd61": {
        "non_crash": [
            "diff --git a/net/netfilter/xt_RATEEST.c b/net/netfilter/xt_RATEEST.c\nindex 37253d399c6b..caa88bddd326 100644\n--- a/net/netfilter/xt_RATEEST.c\n+++ b/net/netfilter/xt_RATEEST.c\n@@ -74,6 +74,9 @@ EXPORT_SYMBOL_GPL(xt_rateest_lookup);\n \n void xt_rateest_put(struct net *net, struct xt_rateest *est)\n {\n+\tif (!net)\n+\t\treturn;\n+\n \tstruct xt_rateest_net *xn = net_generic(net, xt_rateest_id);\n \n \tmutex_lock(&xn->hash_lock);\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netfilter/xt_RATEEST.c b/net/netfilter/xt_RATEEST.c\nindex 37253d399c6b..87c59093d25f 100644\n--- a/net/netfilter/xt_RATEEST.c\n+++ b/net/netfilter/xt_RATEEST.c\n@@ -76,6 +76,9 @@ void xt_rateest_put(struct net *net, struct xt_rateest *est)\n {\n \tstruct xt_rateest_net *xn = net_generic(net, xt_rateest_id);\n \n+\tif (!xn)\n+\t\treturn;\n+\n \tmutex_lock(&xn->hash_lock);\n \tif (--est->refcnt == 0) {\n \t\thlist_del(&est->list);\n",
            "diff --git a/net/netfilter/xt_RATEEST.c b/net/netfilter/xt_RATEEST.c\nindex 37253d399c6b..250322e4cb9a 100644\n--- a/net/netfilter/xt_RATEEST.c\n+++ b/net/netfilter/xt_RATEEST.c\n@@ -76,6 +76,11 @@ void xt_rateest_put(struct net *net, struct xt_rateest *est)\n {\n \tstruct xt_rateest_net *xn = net_generic(net, xt_rateest_id);\n \n+\tif (!xn) {\n+\t\tpr_err(\"xt_rateest_put: net_generic returned NULL\\n\");\n+\t\treturn;\n+\t}\n+\n \tmutex_lock(&xn->hash_lock);\n \tif (--est->refcnt == 0) {\n \t\thlist_del(&est->list);\n",
            "diff --git a/net/netfilter/xt_RATEEST.c b/net/netfilter/xt_RATEEST.c\nindex 37253d399c6b..41db539dfce8 100644\n--- a/net/netfilter/xt_RATEEST.c\n+++ b/net/netfilter/xt_RATEEST.c\n@@ -74,10 +74,13 @@ EXPORT_SYMBOL_GPL(xt_rateest_lookup);\n \n void xt_rateest_put(struct net *net, struct xt_rateest *est)\n {\n+\tif (!est)\n+\t\treturn;\n+\n \tstruct xt_rateest_net *xn = net_generic(net, xt_rateest_id);\n \n \tmutex_lock(&xn->hash_lock);\n-\tif (--est->refcnt == 0) {\n+\tif (est->refcnt > 0 && --est->refcnt == 0) {\n \t\thlist_del(&est->list);\n \t\tgen_kill_estimator(&est->rate_est);\n \t\t/*\n",
            "diff --git a/net/netfilter/xt_RATEEST.c b/net/netfilter/xt_RATEEST.c\nindex 37253d399c6b..7ad06bd842f4 100644\n--- a/net/netfilter/xt_RATEEST.c\n+++ b/net/netfilter/xt_RATEEST.c\n@@ -74,7 +74,11 @@ EXPORT_SYMBOL_GPL(xt_rateest_lookup);\n \n void xt_rateest_put(struct net *net, struct xt_rateest *est)\n {\n-\tstruct xt_rateest_net *xn = net_generic(net, xt_rateest_id);\n+\tstruct xt_rateest_net *xn;\n+\n+\txn = net_generic(net, xt_rateest_id);\n+\tif (!xn)\n+\t\treturn;\n \n \tmutex_lock(&xn->hash_lock);\n \tif (--est->refcnt == 0) {\n"
        ],
        "error": []
    },
    "41a6b5d4917c0412eb3b3c3c604965bed7d7420b": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dadad29bd81b..7535093fc362 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -552,7 +552,9 @@ ext4_xattr_inode_get(struct inode *inode, struct ext4_xattr_entry *entry,\n \t\t\t\t    le32_to_cpu(entry->e_hash), &ea_inode);\n \tif (err) {\n \t\tea_inode = NULL;\n-\t\tgoto out;\n+\t\tkvfree(buffer);\n+\t\tkvfree(buffer);\n+\t\t\tgoto out;\n \t}\n \n \tif (i_size_read(ea_inode) != size) {\n",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dadad29bd81b..e45719fe7324 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2638,8 +2638,10 @@ static int ext4_xattr_move_to_block(handle_t *handle, struct inode *inode,\n \t\t}\n \n \t\terror = ext4_xattr_inode_get(inode, entry, buffer, value_size);\n-\t\tif (error)\n+\t\tif (error) {\n+\t\t\tkvfree(buffer);\n \t\t\tgoto out;\n+\t\t}\n \t} else {\n \t\tsize_t value_offs = le16_to_cpu(entry->e_value_offs);\n \t\tbuffer = (void *)IFIRST(header) + value_offs;\n",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dadad29bd81b..06d8dc60bbc4 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -552,7 +552,8 @@ ext4_xattr_inode_get(struct inode *inode, struct ext4_xattr_entry *entry,\n \t\t\t\t    le32_to_cpu(entry->e_hash), &ea_inode);\n \tif (err) {\n \t\tea_inode = NULL;\n-\t\tgoto out;\n+\t\tkvfree(buffer);\n+\t\t\tgoto out;\n \t}\n \n \tif (i_size_read(ea_inode) != size) {\n@@ -643,7 +644,8 @@ ext4_xattr_block_get(struct inode *inode, int name_index, const char *name,\n \n cleanup:\n \tbrelse(bh);\n-\treturn error;\n+\tkvfree(buffer);\n+\t\t\treturn error;\n }\n \n int\n",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dadad29bd81b..7535093fc362 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -552,7 +552,9 @@ ext4_xattr_inode_get(struct inode *inode, struct ext4_xattr_entry *entry,\n \t\t\t\t    le32_to_cpu(entry->e_hash), &ea_inode);\n \tif (err) {\n \t\tea_inode = NULL;\n-\t\tgoto out;\n+\t\tkvfree(buffer);\n+\t\tkvfree(buffer);\n+\t\t\tgoto out;\n \t}\n \n \tif (i_size_read(ea_inode) != size) {\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dadad29bd81b..2035f8eca1b3 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -552,7 +552,7 @@ ext4_xattr_inode_get(struct inode *inode, struct ext4_xattr_entry *entry,\n \t\t\t\t    le32_to_cpu(entry->e_hash), &ea_inode);\n \tif (err) {\n \t\tea_inode = NULL;\n-\t\tgoto out;\n+\t\tgoto cleanup;\n \t}\n \n \tif (i_size_read(ea_inode) != size) {\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "39b560f8c5d46a5c107b83c6a1e8ae4051826de0": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/ethtool/pse-pd.c b/net/ethtool/pse-pd.c\nindex 5a471e115b66..2dadbe016d1b 100644\n--- a/net/ethtool/pse-pd.c\n+++ b/net/ethtool/pse-pd.c\n@@ -56,10 +56,18 @@ static int pse_prepare_data(const struct ethnl_req_info *req_base,\n \t\t\t       struct ethnl_reply_data *reply_base,\n \t\t\t       struct genl_info *info)\n {\n-\tstruct pse_reply_data *data = PSE_REPDATA(reply_base);\n-\tstruct net_device *dev = reply_base->dev;\n+\tstruct pse_reply_data *data;\n+\tstruct net_device *dev;\n \tint ret;\n \n+\tif (!reply_base)\n+\t\treturn -EINVAL;\n+\n+\tdata = PSE_REPDATA(reply_base);\n+\tdev = reply_base->dev;\n+\tif (!data || !dev)\n+\t\treturn -EINVAL;\n+\n \tret = ethnl_ops_begin(dev);\n \tif (ret < 0)\n \t\treturn ret;\n",
            "diff --git a/net/ethtool/pse-pd.c b/net/ethtool/pse-pd.c\nindex 5a471e115b66..1efe68eca333 100644\n--- a/net/ethtool/pse-pd.c\n+++ b/net/ethtool/pse-pd.c\n@@ -56,8 +56,20 @@ static int pse_prepare_data(const struct ethnl_req_info *req_base,\n \t\t\t       struct ethnl_reply_data *reply_base,\n \t\t\t       struct genl_info *info)\n {\n+\tif (!reply_base) {\n+\t\treturn -EINVAL;\n+\t}\n+\n \tstruct pse_reply_data *data = PSE_REPDATA(reply_base);\n+\tif (!data) {\n+\t\treturn -ENOMEM;\n+\t}\n+\n \tstruct net_device *dev = reply_base->dev;\n+\tif (!dev) {\n+\t\treturn -ENODEV;\n+\t}\n+\n \tint ret;\n \n \tret = ethnl_ops_begin(dev);\n",
            "diff --git a/net/ethtool/pse-pd.c b/net/ethtool/pse-pd.c\nindex 5a471e115b66..1efe68eca333 100644\n--- a/net/ethtool/pse-pd.c\n+++ b/net/ethtool/pse-pd.c\n@@ -56,8 +56,20 @@ static int pse_prepare_data(const struct ethnl_req_info *req_base,\n \t\t\t       struct ethnl_reply_data *reply_base,\n \t\t\t       struct genl_info *info)\n {\n+\tif (!reply_base) {\n+\t\treturn -EINVAL;\n+\t}\n+\n \tstruct pse_reply_data *data = PSE_REPDATA(reply_base);\n+\tif (!data) {\n+\t\treturn -ENOMEM;\n+\t}\n+\n \tstruct net_device *dev = reply_base->dev;\n+\tif (!dev) {\n+\t\treturn -ENODEV;\n+\t}\n+\n \tint ret;\n \n \tret = ethnl_ops_begin(dev);\n",
            "diff --git a/net/ethtool/pse-pd.c b/net/ethtool/pse-pd.c\nindex 5a471e115b66..2dadbe016d1b 100644\n--- a/net/ethtool/pse-pd.c\n+++ b/net/ethtool/pse-pd.c\n@@ -56,10 +56,18 @@ static int pse_prepare_data(const struct ethnl_req_info *req_base,\n \t\t\t       struct ethnl_reply_data *reply_base,\n \t\t\t       struct genl_info *info)\n {\n-\tstruct pse_reply_data *data = PSE_REPDATA(reply_base);\n-\tstruct net_device *dev = reply_base->dev;\n+\tstruct pse_reply_data *data;\n+\tstruct net_device *dev;\n \tint ret;\n \n+\tif (!reply_base)\n+\t\treturn -EINVAL;\n+\n+\tdata = PSE_REPDATA(reply_base);\n+\tdev = reply_base->dev;\n+\tif (!data || !dev)\n+\t\treturn -EINVAL;\n+\n \tret = ethnl_ops_begin(dev);\n \tif (ret < 0)\n \t\treturn ret;\n",
            "diff --git a/net/ethtool/pse-pd.c b/net/ethtool/pse-pd.c\nindex 5a471e115b66..2dadbe016d1b 100644\n--- a/net/ethtool/pse-pd.c\n+++ b/net/ethtool/pse-pd.c\n@@ -56,10 +56,18 @@ static int pse_prepare_data(const struct ethnl_req_info *req_base,\n \t\t\t       struct ethnl_reply_data *reply_base,\n \t\t\t       struct genl_info *info)\n {\n-\tstruct pse_reply_data *data = PSE_REPDATA(reply_base);\n-\tstruct net_device *dev = reply_base->dev;\n+\tstruct pse_reply_data *data;\n+\tstruct net_device *dev;\n \tint ret;\n \n+\tif (!reply_base)\n+\t\treturn -EINVAL;\n+\n+\tdata = PSE_REPDATA(reply_base);\n+\tdev = reply_base->dev;\n+\tif (!data || !dev)\n+\t\treturn -EINVAL;\n+\n \tret = ethnl_ops_begin(dev);\n \tif (ret < 0)\n \t\treturn ret;\n"
        ],
        "error": []
    },
    "507c1be447a4c69f108a0b8cd281fcab44eaf774": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 928446fe1319..907162de4d47 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -9456,8 +9456,14 @@ static __cold void io_ring_ctx_free(struct io_ring_ctx *ctx)\n \tflush_delayed_work(&ctx->rsrc_put_work);\n \tflush_delayed_work(&ctx->fallback_work);\n \n-\tWARN_ON_ONCE(!list_empty(&ctx->rsrc_ref_list));\n-\tWARN_ON_ONCE(!llist_empty(&ctx->rsrc_put_llist));\n+\tif (!list_empty(&ctx->rsrc_ref_list)) {\n+\t\t// Properly handle non-empty rsrc_ref_list\n+\t\t// Add code to clean up or log the issue\n+\t}\n+\tif (!llist_empty(&ctx->rsrc_put_llist)) {\n+\t\t// Properly handle non-empty rsrc_put_llist\n+\t\t// Add code to clean up or log the issue\n+\t}\n \n #if defined(CONFIG_UNIX)\n \tif (ctx->ring_sock) {\n@@ -9465,7 +9471,10 @@ static __cold void io_ring_ctx_free(struct io_ring_ctx *ctx)\n \t\tsock_release(ctx->ring_sock);\n \t}\n #endif\n-\tWARN_ON_ONCE(!list_empty(&ctx->ltimeout_list));\n+\tif (!list_empty(&ctx->ltimeout_list)) {\n+\t\t// Properly handle non-empty ltimeout_list\n+\t\t// Add code to clean up or log the issue\n+\t}\n \n \tio_mem_free(ctx->rings);\n \tio_mem_free(ctx->sq_sqes);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 928446fe1319..aaa82b07ca75 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -9456,8 +9456,15 @@ static __cold void io_ring_ctx_free(struct io_ring_ctx *ctx)\n \tflush_delayed_work(&ctx->rsrc_put_work);\n \tflush_delayed_work(&ctx->fallback_work);\n \n-\tWARN_ON_ONCE(!list_empty(&ctx->rsrc_ref_list));\n-\tWARN_ON_ONCE(!llist_empty(&ctx->rsrc_put_llist));\n+\twhile (!list_empty(&ctx->rsrc_ref_list)) {\n+\t\tstruct io_rsrc_ref_node *node = list_first_entry(&ctx->rsrc_ref_list, struct io_rsrc_ref_node, list);\n+\t\tlist_del(&node->list);\n+\t\tkfree(node);\n+\t}\n+\twhile (!llist_empty(&ctx->rsrc_put_llist)) {\n+\t\tstruct llist_node *node = llist_del_first(&ctx->rsrc_put_llist);\n+\t\tkfree(node);\n+\t}\n \n #if defined(CONFIG_UNIX)\n \tif (ctx->ring_sock) {\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 928446fe1319..130bd2422567 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -9456,6 +9456,15 @@ static __cold void io_ring_ctx_free(struct io_ring_ctx *ctx)\n \tflush_delayed_work(&ctx->rsrc_put_work);\n \tflush_delayed_work(&ctx->fallback_work);\n \n+\twhile (!list_empty(&ctx->rsrc_ref_list)) {\n+\t\tstruct io_rsrc_ref_node *node = list_first_entry(&ctx->rsrc_ref_list, struct io_rsrc_ref_node, list);\n+\t\tlist_del(&node->list);\n+\t\tkfree(node);\n+\t}\n+\twhile (!llist_empty(&ctx->rsrc_put_llist)) {\n+\t\tstruct llist_node *node = llist_del_first(&ctx->rsrc_put_llist);\n+\t\tkfree(node);\n+\t}\n \tWARN_ON_ONCE(!list_empty(&ctx->rsrc_ref_list));\n \tWARN_ON_ONCE(!llist_empty(&ctx->rsrc_put_llist));\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 928446fe1319..ec1314f174d0 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -9456,8 +9456,16 @@ static __cold void io_ring_ctx_free(struct io_ring_ctx *ctx)\n \tflush_delayed_work(&ctx->rsrc_put_work);\n \tflush_delayed_work(&ctx->fallback_work);\n \n-\tWARN_ON_ONCE(!list_empty(&ctx->rsrc_ref_list));\n-\tWARN_ON_ONCE(!llist_empty(&ctx->rsrc_put_llist));\n+\t/* Ensure all resources are released before freeing the context */\n+\twhile (!list_empty(&ctx->rsrc_ref_list)) {\n+\t\tstruct io_rsrc_ref_node *node = list_first_entry(&ctx->rsrc_ref_list, struct io_rsrc_ref_node, list);\n+\t\tlist_del(&node->list);\n+\t\tkfree(node);\n+\t}\n+\twhile (!llist_empty(&ctx->rsrc_put_llist)) {\n+\t\tstruct llist_node *node = llist_del_first(&ctx->rsrc_put_llist);\n+\t\tkfree(node);\n+\t}\n \n #if defined(CONFIG_UNIX)\n \tif (ctx->ring_sock) {\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 928446fe1319..2a3d75143c2f 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -9456,6 +9456,21 @@ static __cold void io_ring_ctx_free(struct io_ring_ctx *ctx)\n \tflush_delayed_work(&ctx->rsrc_put_work);\n \tflush_delayed_work(&ctx->fallback_work);\n \n+\t/* Ensure the resource reference list is empty */\n+\twhile (!list_empty(&ctx->rsrc_ref_list)) {\n+\t\tstruct io_rsrc_ref_node *node;\n+\t\tnode = list_first_entry(&ctx->rsrc_ref_list, struct io_rsrc_ref_node, list);\n+\t\tlist_del(&node->list);\n+\t\tkfree(node);\n+\t}\n+\n+\t/* Ensure the resource put list is empty */\n+\twhile (!llist_empty(&ctx->rsrc_put_llist)) {\n+\t\tstruct llist_node *node;\n+\t\tnode = llist_del_first(&ctx->rsrc_put_llist);\n+\t\tkfree(node);\n+\t}\n+\n \tWARN_ON_ONCE(!list_empty(&ctx->rsrc_ref_list));\n \tWARN_ON_ONCE(!llist_empty(&ctx->rsrc_put_llist));\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "d92cc44e8c8ce5af6d2bea9f7a73cee791989fc8": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex ff7ab63c5b4f..24f7772e5dc8 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -121,7 +121,7 @@ ext4_expand_inode_array(struct ext4_xattr_inode_array **ea_inode_array,\n #ifdef CONFIG_LOCKDEP\n void ext4_xattr_inode_set_class(struct inode *ea_inode)\n {\n-\tlockdep_set_subclass(&ea_inode->i_rwsem, 1);\n+\tlockdep_set_subclass(&ea_inode->i_rwsem, 0);\n }\n #endif\n \n",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex ff7ab63c5b4f..9cd30d5649ee 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -121,7 +121,8 @@ ext4_expand_inode_array(struct ext4_xattr_inode_array **ea_inode_array,\n #ifdef CONFIG_LOCKDEP\n void ext4_xattr_inode_set_class(struct inode *ea_inode)\n {\n-\tlockdep_set_subclass(&ea_inode->i_rwsem, 1);\n+\t/* Remove subclass assignment to avoid lock class key conflict */\n+\tlockdep_set_subclass(&ea_inode->i_rwsem, 0);\n }\n #endif\n \n",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex ff7ab63c5b4f..db0677bb8a7a 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -121,6 +121,8 @@ ext4_expand_inode_array(struct ext4_xattr_inode_array **ea_inode_array,\n #ifdef CONFIG_LOCKDEP\n void ext4_xattr_inode_set_class(struct inode *ea_inode)\n {\n+\tstatic struct lock_class_key ea_inode_rwsem_key;\n+\tlockdep_init_map_type(&ea_inode->i_rwsem.dep_map, \"ea_inode->i_rwsem\", &ea_inode_rwsem_key, 1, 0, 0, 0);\n \tlockdep_set_subclass(&ea_inode->i_rwsem, 1);\n }\n #endif\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex ff7ab63c5b4f..c1717b21245d 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -121,7 +121,7 @@ ext4_expand_inode_array(struct ext4_xattr_inode_array **ea_inode_array,\n #ifdef CONFIG_LOCKDEP\n void ext4_xattr_inode_set_class(struct inode *ea_inode)\n {\n-\tlockdep_set_subclass(&ea_inode->i_rwsem, 1);\n+\tlockdep_set_class_and_subclass(&ea_inode->i_rwsem, &ext4_xattr_inode_key, 1);\n }\n #endif\n \ndiff --git a/kernel/locking/lockdep.c b/kernel/locking/lockdep.c\nindex 4dfd2f3e09b2..d35d591e0ee5 100644\n--- a/kernel/locking/lockdep.c\n+++ b/kernel/locking/lockdep.c\n@@ -4842,6 +4842,7 @@ void lockdep_init_map_type(struct lockdep_map *lock, const char *name,\n \n #ifdef CONFIG_LOCK_STAT\n \tlock->cpu = raw_smp_processor_id();\n+\tlock->key = key;\n #endif\n \n \t/*\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex ff7ab63c5b4f..44d601aa4945 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -121,6 +121,8 @@ ext4_expand_inode_array(struct ext4_xattr_inode_array **ea_inode_array,\n #ifdef CONFIG_LOCKDEP\n void ext4_xattr_inode_set_class(struct inode *ea_inode)\n {\n+\tstruct lock_class_key *key = &ea_inode->i_rwsem_key;\n+\tlockdep_init_map_type(&ea_inode->i_rwsem.dep_map, \"i_rwsem\", key, 1, 0, 0, 0);\n \tlockdep_set_subclass(&ea_inode->i_rwsem, 1);\n }\n #endif\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "b0932be9507e30fc4cbd16bf05cd3bea03b325d7": {
        "non_crash": [
            "diff --git a/block/disk-events.c b/block/disk-events.c\nindex 8d5496e7592a..05b1249650ab 100644\n--- a/block/disk-events.c\n+++ b/block/disk-events.c\n@@ -501,4 +501,5 @@ void disk_release_events(struct gendisk *disk)\n \t/* the block count should be 1 from disk_del_events() */\n \tWARN_ON_ONCE(disk->ev && disk->ev->block != 1);\n \tkfree(disk->ev);\n+\tdisk->ev = NULL;\n }\n",
            "diff --git a/block/disk-events.c b/block/disk-events.c\nindex 8d5496e7592a..3112984850c3 100644\n--- a/block/disk-events.c\n+++ b/block/disk-events.c\n@@ -499,6 +499,9 @@ void disk_del_events(struct gendisk *disk)\n void disk_release_events(struct gendisk *disk)\n {\n \t/* the block count should be 1 from disk_del_events() */\n-\tWARN_ON_ONCE(disk->ev && disk->ev->block != 1);\n-\tkfree(disk->ev);\n+\tif (disk->ev) {\n+\t\tWARN_ON_ONCE(disk->ev->block != 1);\n+\t\tkfree(disk->ev);\n+\t\tdisk->ev = NULL;\n+\t}\n }\n",
            "diff --git a/block/disk-events.c b/block/disk-events.c\nindex 8d5496e7592a..05b1249650ab 100644\n--- a/block/disk-events.c\n+++ b/block/disk-events.c\n@@ -501,4 +501,5 @@ void disk_release_events(struct gendisk *disk)\n \t/* the block count should be 1 from disk_del_events() */\n \tWARN_ON_ONCE(disk->ev && disk->ev->block != 1);\n \tkfree(disk->ev);\n+\tdisk->ev = NULL;\n }\n",
            "diff --git a/block/disk-events.c b/block/disk-events.c\nindex 8d5496e7592a..ac28e409d553 100644\n--- a/block/disk-events.c\n+++ b/block/disk-events.c\n@@ -500,5 +500,8 @@ void disk_release_events(struct gendisk *disk)\n {\n \t/* the block count should be 1 from disk_del_events() */\n \tWARN_ON_ONCE(disk->ev && disk->ev->block != 1);\n-\tkfree(disk->ev);\n+\tif (disk->ev) {\n+\t\tkfree(disk->ev);\n+\t\tdisk->ev = NULL;\n+\t}\n }\n",
            "diff --git a/block/disk-events.c b/block/disk-events.c\nindex 8d5496e7592a..3112984850c3 100644\n--- a/block/disk-events.c\n+++ b/block/disk-events.c\n@@ -499,6 +499,9 @@ void disk_del_events(struct gendisk *disk)\n void disk_release_events(struct gendisk *disk)\n {\n \t/* the block count should be 1 from disk_del_events() */\n-\tWARN_ON_ONCE(disk->ev && disk->ev->block != 1);\n-\tkfree(disk->ev);\n+\tif (disk->ev) {\n+\t\tWARN_ON_ONCE(disk->ev->block != 1);\n+\t\tkfree(disk->ev);\n+\t\tdisk->ev = NULL;\n+\t}\n }\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "5d48b50ed679f22d7d4a4b578da8559d34b104ac": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/include/linux/percpu-refcount.h b/include/linux/percpu-refcount.h\nindex ae16a9856305..52c61c250d06 100644\n--- a/include/linux/percpu-refcount.h\n+++ b/include/linux/percpu-refcount.h\n@@ -316,10 +316,11 @@ static inline void percpu_ref_put_many(struct percpu_ref *ref, unsigned long nr)\n \n \trcu_read_lock();\n \n-\tif (__ref_is_percpu(ref, &percpu_count))\n+\tif (ref && __ref_is_percpu(ref, &percpu_count)) {\n \t\tthis_cpu_sub(*percpu_count, nr);\n-\telse if (unlikely(atomic_long_sub_and_test(nr, &ref->data->count)))\n+\t} else if (ref && unlikely(atomic_long_sub_and_test(nr, &ref->data->count))) {\n \t\tref->data->release(ref);\n+\t}\n \n \trcu_read_unlock();\n }\n",
            "diff --git a/include/linux/percpu-refcount.h b/include/linux/percpu-refcount.h\nindex ae16a9856305..6a75f892f1eb 100644\n--- a/include/linux/percpu-refcount.h\n+++ b/include/linux/percpu-refcount.h\n@@ -316,9 +316,9 @@ static inline void percpu_ref_put_many(struct percpu_ref *ref, unsigned long nr)\n \n \trcu_read_lock();\n \n-\tif (__ref_is_percpu(ref, &percpu_count))\n+\tif (ref && __ref_is_percpu(ref, &percpu_count))\n \t\tthis_cpu_sub(*percpu_count, nr);\n-\telse if (unlikely(atomic_long_sub_and_test(nr, &ref->data->count)))\n+\telse if (ref && unlikely(atomic_long_sub_and_test(nr, &ref->data->count)))\n \t\tref->data->release(ref);\n \n \trcu_read_unlock();\n",
            "diff --git a/include/linux/percpu-refcount.h b/include/linux/percpu-refcount.h\nindex ae16a9856305..20b2b0c23457 100644\n--- a/include/linux/percpu-refcount.h\n+++ b/include/linux/percpu-refcount.h\n@@ -314,6 +314,11 @@ static inline void percpu_ref_put_many(struct percpu_ref *ref, unsigned long nr)\n {\n \tunsigned long __percpu *percpu_count;\n \n+\tif (!ref || !ref->data) {\n+\t\tWARN_ONCE(1, \"percpu_ref_put_many: ref or ref->data is NULL\\n\");\n+\t\treturn;\n+\t}\n+\n \trcu_read_lock();\n \n \tif (__ref_is_percpu(ref, &percpu_count))\n",
            "diff --git a/include/linux/percpu-refcount.h b/include/linux/percpu-refcount.h\nindex ae16a9856305..7e9e2403c050 100644\n--- a/include/linux/percpu-refcount.h\n+++ b/include/linux/percpu-refcount.h\n@@ -314,14 +314,16 @@ static inline void percpu_ref_put_many(struct percpu_ref *ref, unsigned long nr)\n {\n \tunsigned long __percpu *percpu_count;\n \n-\trcu_read_lock();\n+\tif (ref) {\n+\t\trcu_read_lock();\n \n-\tif (__ref_is_percpu(ref, &percpu_count))\n-\t\tthis_cpu_sub(*percpu_count, nr);\n-\telse if (unlikely(atomic_long_sub_and_test(nr, &ref->data->count)))\n-\t\tref->data->release(ref);\n+\t\tif (__ref_is_percpu(ref, &percpu_count))\n+\t\t\tthis_cpu_sub(*percpu_count, nr);\n+\t\telse if (unlikely(atomic_long_sub_and_test(nr, &ref->data->count)))\n+\t\t\tref->data->release(ref);\n \n-\trcu_read_unlock();\n+\t\trcu_read_unlock();\n+\t}\n }\n \n /**\ndiff --git a/kernel/cgroup/cgroup.c b/kernel/cgroup/cgroup.c\nindex 8afa8690d288..b7b2fcd2e094 100644\n--- a/kernel/cgroup/cgroup.c\n+++ b/kernel/cgroup/cgroup.c\n@@ -5523,10 +5523,9 @@ static void kill_css(struct cgroup_subsys_state *css)\n {\n \tlockdep_assert_held(&cgroup_mutex);\n \n-\tif (css->flags & CSS_DYING)\n-\t\treturn;\n-\n-\tcss->flags |= CSS_DYING;\n+\tif (css && !(css->flags & CSS_DYING)) {\n+\t\tcss->flags |= CSS_DYING;\n+\t}\n \n \t/*\n \t * This must happen before css is disassociated with its cgroup.\ndiff --git a/net/core/sock.c b/net/core/sock.c\nindex 62627e868e03..d7dcd87b5712 100644\n--- a/net/core/sock.c\n+++ b/net/core/sock.c\n@@ -1849,9 +1849,11 @@ static void sk_prot_free(struct proto *prot, struct sock *sk)\n \towner = prot->owner;\n \tslab = prot->slab;\n \n-\tcgroup_sk_free(&sk->sk_cgrp_data);\n-\tmem_cgroup_sk_free(sk);\n-\tsecurity_sk_free(sk);\n+\tif (sk) {\n+\t\tcgroup_sk_free(&sk->sk_cgrp_data);\n+\t\tmem_cgroup_sk_free(sk);\n+\t\tsecurity_sk_free(sk);\n+\t}\n \tif (slab != NULL)\n \t\tkmem_cache_free(slab, sk);\n \telse\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/core/sock.c b/net/core/sock.c\nindex 62627e868e03..d51684502074 100644\n--- a/net/core/sock.c\n+++ b/net/core/sock.c\n@@ -1849,7 +1849,9 @@ static void sk_prot_free(struct proto *prot, struct sock *sk)\n \towner = prot->owner;\n \tslab = prot->slab;\n \n-\tcgroup_sk_free(&sk->sk_cgrp_data);\n+\tif (sk->sk_cgrp_data) {\n+\t\tcgroup_sk_free(&sk->sk_cgrp_data);\n+\t}\n \tmem_cgroup_sk_free(sk);\n \tsecurity_sk_free(sk);\n \tif (slab != NULL)\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "802aba2422de4218ad0c01b46c9525cc9d4e4aa3": {
        "non_crash": [
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 76bd4d03dbda..bd5390ca40dc 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -10094,6 +10094,17 @@ static void __net_exit nf_tables_exit_net(struct net *net)\n \t\t__nf_tables_abort(net, NFNL_ABORT_NONE);\n \t__nft_release_tables(net);\n \tmutex_unlock(&nft_net->commit_mutex);\n+\n+\t/* Ensure all lists are empty before exiting */\n+\tmutex_lock(&nft_net->commit_mutex);\n+\tif (!list_empty(&nft_net->tables))\n+\t\t__nft_release_tables(net);\n+\tif (!list_empty(&nft_net->module_list))\n+\t\tnf_tables_module_autoload_cleanup(net);\n+\tif (!list_empty(&nft_net->notify_list))\n+\t\tnft_commit_notify(net, 0);\n+\tmutex_unlock(&nft_net->commit_mutex);\n+\n \tWARN_ON_ONCE(!list_empty(&nft_net->tables));\n \tWARN_ON_ONCE(!list_empty(&nft_net->module_list));\n \tWARN_ON_ONCE(!list_empty(&nft_net->notify_list));\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 76bd4d03dbda..18efd5b2c864 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -10090,8 +10090,9 @@ static void __net_exit nf_tables_exit_net(struct net *net)\n \tstruct nftables_pernet *nft_net = nft_pernet(net);\n \n \tmutex_lock(&nft_net->commit_mutex);\n-\tif (!list_empty(&nft_net->commit_list))\n+\twhile (!list_empty(&nft_net->commit_list)) {\n \t\t__nf_tables_abort(net, NFNL_ABORT_NONE);\n+\t}\n \t__nft_release_tables(net);\n \tmutex_unlock(&nft_net->commit_mutex);\n \tWARN_ON_ONCE(!list_empty(&nft_net->tables));\n",
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 76bd4d03dbda..d12cb90d4e3c 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -10090,10 +10090,20 @@ static void __net_exit nf_tables_exit_net(struct net *net)\n \tstruct nftables_pernet *nft_net = nft_pernet(net);\n \n \tmutex_lock(&nft_net->commit_mutex);\n-\tif (!list_empty(&nft_net->commit_list))\n+\tif (!list_empty(&nft_net->commit_list)) {\n \t\t__nf_tables_abort(net, NFNL_ABORT_NONE);\n+\t\t/* Ensure all transactions are properly cleaned up */\n+\t\tnf_tables_commit_release(net);\n+\t}\n \t__nft_release_tables(net);\n \tmutex_unlock(&nft_net->commit_mutex);\n+\t/* Ensure all lists are empty before exiting */\n+\tif (!list_empty(&nft_net->tables) ||\n+\t    !list_empty(&nft_net->module_list) ||\n+\t    !list_empty(&nft_net->notify_list)) {\n+\t\t__nf_tables_abort(net, NFNL_ABORT_NONE);\n+\t\tnf_tables_commit_release(net);\n+\t}\n \tWARN_ON_ONCE(!list_empty(&nft_net->tables));\n \tWARN_ON_ONCE(!list_empty(&nft_net->module_list));\n \tWARN_ON_ONCE(!list_empty(&nft_net->notify_list));\n",
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 76bd4d03dbda..18efd5b2c864 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -10090,8 +10090,9 @@ static void __net_exit nf_tables_exit_net(struct net *net)\n \tstruct nftables_pernet *nft_net = nft_pernet(net);\n \n \tmutex_lock(&nft_net->commit_mutex);\n-\tif (!list_empty(&nft_net->commit_list))\n+\twhile (!list_empty(&nft_net->commit_list)) {\n \t\t__nf_tables_abort(net, NFNL_ABORT_NONE);\n+\t}\n \t__nft_release_tables(net);\n \tmutex_unlock(&nft_net->commit_mutex);\n \tWARN_ON_ONCE(!list_empty(&nft_net->tables));\n",
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 76bd4d03dbda..18efd5b2c864 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -10090,8 +10090,9 @@ static void __net_exit nf_tables_exit_net(struct net *net)\n \tstruct nftables_pernet *nft_net = nft_pernet(net);\n \n \tmutex_lock(&nft_net->commit_mutex);\n-\tif (!list_empty(&nft_net->commit_list))\n+\twhile (!list_empty(&nft_net->commit_list)) {\n \t\t__nf_tables_abort(net, NFNL_ABORT_NONE);\n+\t}\n \t__nft_release_tables(net);\n \tmutex_unlock(&nft_net->commit_mutex);\n \tWARN_ON_ONCE(!list_empty(&nft_net->tables));\n"
        ],
        "error": []
    },
    "19526c104e66c633a05949201c4c09a3ec8c5644": {
        "non_crash": [
            "diff --git a/fs/ext4/ext4_jbd2.c b/fs/ext4/ext4_jbd2.c\nindex 760b9ee49dc0..dc5d07b221e5 100644\n--- a/fs/ext4/ext4_jbd2.c\n+++ b/fs/ext4/ext4_jbd2.c\n@@ -224,10 +224,10 @@ int __ext4_journal_get_write_access(const char *where, unsigned int line,\n \n \tmight_sleep();\n \n-\tif (bh->b_bdev->bd_super)\n+\tif (bh && bh->b_bdev && bh->b_bdev->bd_super)\n \t\text4_check_bdev_write_error(bh->b_bdev->bd_super);\n \n-\tif (ext4_handle_valid(handle)) {\n+\tif (bh && ext4_handle_valid(handle)) {\n \t\terr = jbd2_journal_get_write_access(handle, bh);\n \t\tif (err)\n \t\t\text4_journal_abort_handle(where, line, __func__, bh,\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/ext4_jbd2.c b/fs/ext4/ext4_jbd2.c\nindex 760b9ee49dc0..3c9f9537ec4e 100644\n--- a/fs/ext4/ext4_jbd2.c\n+++ b/fs/ext4/ext4_jbd2.c\n@@ -224,6 +224,11 @@ int __ext4_journal_get_write_access(const char *where, unsigned int line,\n \n \tmight_sleep();\n \n+\tif (!bh) {\n+\t\tpr_err(\"%s: buffer_head is null\\n\", __func__);\n+\t\treturn -EINVAL;\n+\t}\n+\n \tif (bh->b_bdev->bd_super)\n \t\text4_check_bdev_write_error(bh->b_bdev->bd_super);\n \n",
            "diff --git a/fs/ext4/ext4_jbd2.c b/fs/ext4/ext4_jbd2.c\nindex 760b9ee49dc0..ff5bd205baaa 100644\n--- a/fs/ext4/ext4_jbd2.c\n+++ b/fs/ext4/ext4_jbd2.c\n@@ -224,6 +224,11 @@ int __ext4_journal_get_write_access(const char *where, unsigned int line,\n \n \tmight_sleep();\n \n+\tif (!bh) {\n+\t\text4_journal_abort_handle(where, line, __func__, bh, handle, -EINVAL);\n+\t\treturn -EINVAL;\n+\t}\n+\n \tif (bh->b_bdev->bd_super)\n \t\text4_check_bdev_write_error(bh->b_bdev->bd_super);\n \n",
            "diff --git a/fs/ext4/ext4_jbd2.c b/fs/ext4/ext4_jbd2.c\nindex 760b9ee49dc0..5a0777962aa4 100644\n--- a/fs/ext4/ext4_jbd2.c\n+++ b/fs/ext4/ext4_jbd2.c\n@@ -224,7 +224,7 @@ int __ext4_journal_get_write_access(const char *where, unsigned int line,\n \n \tmight_sleep();\n \n-\tif (bh->b_bdev->bd_super)\n+\tif (bh && bh->b_bdev->bd_super)\n \t\text4_check_bdev_write_error(bh->b_bdev->bd_super);\n \n \tif (ext4_handle_valid(handle)) {\n",
            "diff --git a/fs/ext4/ext4_jbd2.c b/fs/ext4/ext4_jbd2.c\nindex 760b9ee49dc0..8ffe83e88f68 100644\n--- a/fs/ext4/ext4_jbd2.c\n+++ b/fs/ext4/ext4_jbd2.c\n@@ -224,7 +224,7 @@ int __ext4_journal_get_write_access(const char *where, unsigned int line,\n \n \tmight_sleep();\n \n-\tif (bh->b_bdev->bd_super)\n+\tif (bh && bh->b_bdev && bh->b_bdev->bd_super)\n \t\text4_check_bdev_write_error(bh->b_bdev->bd_super);\n \n \tif (ext4_handle_valid(handle)) {\n"
        ],
        "error": []
    },
    "9b857c714d3e890900acbe48172866a93ab8589a": {
        "non_crash": [
            "diff --git a/sound/core/oss/mulaw.c b/sound/core/oss/mulaw.c\nindex 3788906421a7..7122da9d1ae7 100644\n--- a/sound/core/oss/mulaw.c\n+++ b/sound/core/oss/mulaw.c\n@@ -326,11 +326,14 @@ int snd_pcm_plugin_build_mulaw(struct snd_pcm_substream *plug,\n \t\tfunc = mulaw_decode;\n \t}\n \telse {\n-\t\tsnd_BUG();\n+\t\t// Handle unexpected format gracefully\n \t\treturn -EINVAL;\n \t}\n-\tif (snd_BUG_ON(!snd_pcm_format_linear(format->format)))\n+\tif (!snd_pcm_format_linear(format->format)) {\n+\t\t// Log a warning instead of triggering a bug\n+\t\tpr_warn(\"Unexpected non-linear format in snd_pcm_plugin_build_mulaw\\n\");\n \t\treturn -ENXIO;\n+\t}\n \n \terr = snd_pcm_plugin_build(plug, \"Mu-Law<->linear conversion\",\n \t\t\t\t   src_format, dst_format,\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/sound/core/oss/mulaw.c b/sound/core/oss/mulaw.c\nindex 3788906421a7..775e5507a3dd 100644\n--- a/sound/core/oss/mulaw.c\n+++ b/sound/core/oss/mulaw.c\n@@ -325,8 +325,10 @@ int snd_pcm_plugin_build_mulaw(struct snd_pcm_substream *plug,\n \t\tformat = dst_format;\n \t\tfunc = mulaw_decode;\n \t}\n-\telse {\n-\t\tsnd_BUG();\n+\telse if (snd_pcm_format_linear(src_format->format) || snd_pcm_format_linear(dst_format->format)) {\n+\t\tformat = src_format->format == SNDRV_PCM_FORMAT_MU_LAW ? dst_format : src_format;\n+\t\tfunc = src_format->format == SNDRV_PCM_FORMAT_MU_LAW ? mulaw_decode : mulaw_encode;\n+\t} else {\n \t\treturn -EINVAL;\n \t}\n \tif (snd_BUG_ON(!snd_pcm_format_linear(format->format)))\n",
            "diff --git a/sound/core/oss/mulaw.c b/sound/core/oss/mulaw.c\nindex 3788906421a7..bc94acf4485e 100644\n--- a/sound/core/oss/mulaw.c\n+++ b/sound/core/oss/mulaw.c\n@@ -325,7 +325,10 @@ int snd_pcm_plugin_build_mulaw(struct snd_pcm_substream *plug,\n \t\tformat = dst_format;\n \t\tfunc = mulaw_decode;\n \t}\n-\telse {\n+\telse if (snd_pcm_format_linear(src_format->format) && snd_pcm_format_linear(dst_format->format)) {\n+\t\tformat = dst_format;\n+\t\tfunc = mulaw_encode; // Assuming linear to Mu-Law conversion\n+\t} else {\n \t\tsnd_BUG();\n \t\treturn -EINVAL;\n \t}\n",
            "diff --git a/sound/core/oss/mulaw.c b/sound/core/oss/mulaw.c\nindex 3788906421a7..d2bc4ff8b7c5 100644\n--- a/sound/core/oss/mulaw.c\n+++ b/sound/core/oss/mulaw.c\n@@ -326,11 +326,17 @@ int snd_pcm_plugin_build_mulaw(struct snd_pcm_substream *plug,\n \t\tfunc = mulaw_decode;\n \t}\n \telse {\n-\t\tsnd_BUG();\n-\t\treturn -EINVAL;\n+\t\t// Ensure that the source and destination formats are valid\n+\t\tif (src_format->format != SNDRV_PCM_FORMAT_MU_LAW &&\n+\t\t    dst_format->format != SNDRV_PCM_FORMAT_MU_LAW) {\n+\t\t\tsnd_BUG();\n+\t\t\treturn -EINVAL;\n+\t\t}\n+\t\tformat = (src_format->format == SNDRV_PCM_FORMAT_MU_LAW) ? dst_format : src_format;\n \t}\n-\tif (snd_BUG_ON(!snd_pcm_format_linear(format->format)))\n+\tif (snd_BUG_ON(!snd_pcm_format_linear(format->format))) {\n \t\treturn -ENXIO;\n+\t}\n \n \terr = snd_pcm_plugin_build(plug, \"Mu-Law<->linear conversion\",\n \t\t\t\t   src_format, dst_format,\n",
            "diff --git a/sound/core/oss/pcm_plugin.c b/sound/core/oss/pcm_plugin.c\nindex d5ca161d588c..dc9801c70e84 100644\n--- a/sound/core/oss/pcm_plugin.c\n+++ b/sound/core/oss/pcm_plugin.c\n@@ -489,8 +489,10 @@ int snd_pcm_plug_format_plugins(struct snd_pcm_substream *plug,\n \t/* format change */\n \tif (srcformat.format != dstformat.format) {\n \t\ttmpformat.format = dstformat.format;\n-\t\tif (srcformat.format == SNDRV_PCM_FORMAT_MU_LAW ||\n-\t\t    tmpformat.format == SNDRV_PCM_FORMAT_MU_LAW) {\n+\t\tif ((srcformat.format == SNDRV_PCM_FORMAT_MU_LAW &&\n+\t\t     tmpformat.format != SNDRV_PCM_FORMAT_MU_LAW) ||\n+\t\t    (srcformat.format != SNDRV_PCM_FORMAT_MU_LAW &&\n+\t\t     tmpformat.format == SNDRV_PCM_FORMAT_MU_LAW)) {\n \t\t\terr = snd_pcm_plugin_build_mulaw(plug,\n \t\t\t\t\t\t\t &srcformat, &tmpformat,\n \t\t\t\t\t\t\t &plugin);\n"
        ],
        "error": []
    },
    "6fe3c93209dfd48301d1cad0ab1efd53c87462e1": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/module/main.c b/kernel/module/main.c\nindex 834de86ebe35..ab1e31aec321 100644\n--- a/kernel/module/main.c\n+++ b/kernel/module/main.c\n@@ -1895,6 +1895,9 @@ static int elf_validity_cache_copy(struct load_info *info, int flags)\n \n static int copy_chunked_from_user(void *dst, const void __user *usrc, unsigned long len)\n {\n+\tif (!access_ok(usrc, len))\n+\t\treturn -EFAULT;\n+\n \tdo {\n \t\tunsigned long n = min(len, COPY_CHUNK_SIZE);\n \n",
            "diff --git a/kernel/module/main.c b/kernel/module/main.c\nindex 834de86ebe35..edb932d8a499 100644\n--- a/kernel/module/main.c\n+++ b/kernel/module/main.c\n@@ -3069,6 +3069,10 @@ static bool idempotent(struct idempotent *u, const void *cookie)\n \tbool first;\n \n \tu->ret = 0;\n+\tif (!cookie) {\n+\t\treturn false;\n+\t}\n+\n \tu->cookie = cookie;\n \tinit_completion(&u->complete);\n \n",
            "diff --git a/kernel/module/main.c b/kernel/module/main.c\nindex 834de86ebe35..ab1e31aec321 100644\n--- a/kernel/module/main.c\n+++ b/kernel/module/main.c\n@@ -1895,6 +1895,9 @@ static int elf_validity_cache_copy(struct load_info *info, int flags)\n \n static int copy_chunked_from_user(void *dst, const void __user *usrc, unsigned long len)\n {\n+\tif (!access_ok(usrc, len))\n+\t\treturn -EFAULT;\n+\n \tdo {\n \t\tunsigned long n = min(len, COPY_CHUNK_SIZE);\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/kernel/module/main.c b/kernel/module/main.c\nindex 834de86ebe35..9dd551f23a07 100644\n--- a/kernel/module/main.c\n+++ b/kernel/module/main.c\n@@ -1895,6 +1895,9 @@ static int elf_validity_cache_copy(struct load_info *info, int flags)\n \n static int copy_chunked_from_user(void *dst, const void __user *usrc, unsigned long len)\n {\n+\tif (!access_ok(VERIFY_READ, usrc, len))\n+\t\treturn -EFAULT;\n+\n \tdo {\n \t\tunsigned long n = min(len, COPY_CHUNK_SIZE);\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/kernel/module/main.c b/kernel/module/main.c\nindex 834de86ebe35..9dd551f23a07 100644\n--- a/kernel/module/main.c\n+++ b/kernel/module/main.c\n@@ -1895,6 +1895,9 @@ static int elf_validity_cache_copy(struct load_info *info, int flags)\n \n static int copy_chunked_from_user(void *dst, const void __user *usrc, unsigned long len)\n {\n+\tif (!access_ok(VERIFY_READ, usrc, len))\n+\t\treturn -EFAULT;\n+\n \tdo {\n \t\tunsigned long n = min(len, COPY_CHUNK_SIZE);\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "c434e401d70d584f408424099090ddebe2076705": {
        "non_crash": [
            "diff --git a/fs/ntfs3/super.c b/fs/ntfs3/super.c\nindex 278dcf502410..5e0529d10e6d 100644\n--- a/fs/ntfs3/super.c\n+++ b/fs/ntfs3/super.c\n@@ -668,9 +668,13 @@ static u32 format_size_gb(const u64 bytes, u32 *mb)\n \n static u32 true_sectors_per_clst(const struct NTFS_BOOT *boot)\n {\n+\tif (boot->sectors_per_clusters < 0 || boot->sectors_per_clusters > 0x80) {\n+\t\tpr_err(\"Invalid sectors_per_clusters value: %d\\n\", boot->sectors_per_clusters);\n+\t\treturn 0; // Return a safe default value or handle error appropriately\n+\t}\n \treturn boot->sectors_per_clusters <= 0x80\n \t\t       ? boot->sectors_per_clusters\n-\t\t       : (1u << (0 - boot->sectors_per_clusters));\n+\t\t       : (1u << (boot->sectors_per_clusters - 0x80));\n }\n \n /*\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ntfs3/super.c b/fs/ntfs3/super.c\nindex 278dcf502410..efa4efdd490e 100644\n--- a/fs/ntfs3/super.c\n+++ b/fs/ntfs3/super.c\n@@ -670,7 +670,7 @@ static u32 true_sectors_per_clst(const struct NTFS_BOOT *boot)\n {\n \treturn boot->sectors_per_clusters <= 0x80\n \t\t       ? boot->sectors_per_clusters\n-\t\t       : (1u << (0 - boot->sectors_per_clusters));\n+\t\t       : (boot->sectors_per_clusters > 0 ? (1u << (0 - boot->sectors_per_clusters)) : 0);\n }\n \n /*\n",
            "diff --git a/fs/ntfs3/super.c b/fs/ntfs3/super.c\nindex 278dcf502410..a3612f72fb58 100644\n--- a/fs/ntfs3/super.c\n+++ b/fs/ntfs3/super.c\n@@ -668,9 +668,12 @@ static u32 format_size_gb(const u64 bytes, u32 *mb)\n \n static u32 true_sectors_per_clst(const struct NTFS_BOOT *boot)\n {\n-\treturn boot->sectors_per_clusters <= 0x80\n-\t\t       ? boot->sectors_per_clusters\n-\t\t       : (1u << (0 - boot->sectors_per_clusters));\n+\tif (boot->sectors_per_clusters <= 0x80) {\n+\t\treturn boot->sectors_per_clusters;\n+\t} else {\n+\t\t/* Handle cases where sectors_per_clusters is greater than 0x80 */\n+\t\treturn 1u << (boot->sectors_per_clusters - 0x80);\n+\t}\n }\n \n /*\n",
            "diff --git a/fs/ntfs3/super.c b/fs/ntfs3/super.c\nindex 278dcf502410..31565b47db8a 100644\n--- a/fs/ntfs3/super.c\n+++ b/fs/ntfs3/super.c\n@@ -668,9 +668,15 @@ static u32 format_size_gb(const u64 bytes, u32 *mb)\n \n static u32 true_sectors_per_clst(const struct NTFS_BOOT *boot)\n {\n-\treturn boot->sectors_per_clusters <= 0x80\n-\t\t       ? boot->sectors_per_clusters\n-\t\t       : (1u << (0 - boot->sectors_per_clusters));\n+\tif (boot->sectors_per_clusters <= 0x80) {\n+\t\treturn boot->sectors_per_clusters;\n+\t} else if (boot->sectors_per_clusters > 0) {\n+\t\treturn (1u << boot->sectors_per_clusters);\n+\t} else {\n+\t\t/* Handle invalid sectors_per_clusters value */\n+\t\tpr_err(\"Invalid sectors_per_clusters value: %d\\n\", boot->sectors_per_clusters);\n+\t\treturn 0; /* or appropriate error handling */\n+\t}\n }\n \n /*\n",
            "diff --git a/fs/ntfs3/super.c b/fs/ntfs3/super.c\nindex 278dcf502410..efa4efdd490e 100644\n--- a/fs/ntfs3/super.c\n+++ b/fs/ntfs3/super.c\n@@ -670,7 +670,7 @@ static u32 true_sectors_per_clst(const struct NTFS_BOOT *boot)\n {\n \treturn boot->sectors_per_clusters <= 0x80\n \t\t       ? boot->sectors_per_clusters\n-\t\t       : (1u << (0 - boot->sectors_per_clusters));\n+\t\t       : (boot->sectors_per_clusters > 0 ? (1u << (0 - boot->sectors_per_clusters)) : 0);\n }\n \n /*\n"
        ],
        "error": []
    },
    "ef9605001826ed9db7e9ae5b0c08ec9b347a5148": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 300455b4bc12..15be2acce7d1 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -53,6 +53,10 @@ static __cold int io_uring_show_cred(struct seq_file *m, unsigned int id,\n __cold void io_uring_show_fdinfo(struct seq_file *m, struct file *f)\n {\n \tstruct io_ring_ctx *ctx = f->private_data;\n+\tif (!ctx || !ctx->rings) {\n+\t\tseq_puts(m, \"Invalid io_uring context\\n\");\n+\t\treturn;\n+\t}\n \tstruct io_sq_data *sq = NULL;\n \tstruct io_overflow_cqe *ocqe;\n \tstruct io_rings *r = ctx->rings;\n",
            "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 300455b4bc12..a35d3adf2b73 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -53,6 +53,8 @@ static __cold int io_uring_show_cred(struct seq_file *m, unsigned int id,\n __cold void io_uring_show_fdinfo(struct seq_file *m, struct file *f)\n {\n \tstruct io_ring_ctx *ctx = f->private_data;\n+\tif (!ctx || !ctx->rings)\n+\t\treturn;\n \tstruct io_sq_data *sq = NULL;\n \tstruct io_overflow_cqe *ocqe;\n \tstruct io_rings *r = ctx->rings;\n",
            "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 300455b4bc12..12141b2179f9 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -56,6 +56,8 @@ __cold void io_uring_show_fdinfo(struct seq_file *m, struct file *f)\n \tstruct io_sq_data *sq = NULL;\n \tstruct io_overflow_cqe *ocqe;\n \tstruct io_rings *r = ctx->rings;\n+\tif (!r)\n+\t\treturn;\n \tunsigned int sq_mask = ctx->sq_entries - 1, cq_mask = ctx->cq_entries - 1;\n \tunsigned int sq_head = READ_ONCE(r->sq.head);\n \tunsigned int sq_tail = READ_ONCE(r->sq.tail);\n",
            "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 300455b4bc12..abbcf40ff823 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -53,6 +53,8 @@ static __cold int io_uring_show_cred(struct seq_file *m, unsigned int id,\n __cold void io_uring_show_fdinfo(struct seq_file *m, struct file *f)\n {\n \tstruct io_ring_ctx *ctx = f->private_data;\n+\tif (!ctx)\n+\t\treturn;\n \tstruct io_sq_data *sq = NULL;\n \tstruct io_overflow_cqe *ocqe;\n \tstruct io_rings *r = ctx->rings;\n",
            "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 300455b4bc12..12141b2179f9 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -56,6 +56,8 @@ __cold void io_uring_show_fdinfo(struct seq_file *m, struct file *f)\n \tstruct io_sq_data *sq = NULL;\n \tstruct io_overflow_cqe *ocqe;\n \tstruct io_rings *r = ctx->rings;\n+\tif (!r)\n+\t\treturn;\n \tunsigned int sq_mask = ctx->sq_entries - 1, cq_mask = ctx->cq_entries - 1;\n \tunsigned int sq_head = READ_ONCE(r->sq.head);\n \tunsigned int sq_tail = READ_ONCE(r->sq.tail);\n"
        ],
        "error": []
    },
    "bf7780df648105d40e1fdbb0566defda3605ed93": {
        "non_crash": [
            "diff --git a/net/core/gro.c b/net/core/gro.c\nindex b4190eb08467..178cd0b07942 100644\n--- a/net/core/gro.c\n+++ b/net/core/gro.c\n@@ -133,7 +133,11 @@ struct sk_buff *skb_mac_gso_segment(struct sk_buff *skb,\n \tif (unlikely(!type))\n \t\treturn ERR_PTR(-EINVAL);\n \n-\t__skb_pull(skb, vlan_depth);\n+\tif (vlan_depth > 0 && vlan_depth <= skb_headlen(skb)) {\n+\t\t__skb_pull(skb, vlan_depth);\n+\t} else {\n+\t\treturn ERR_PTR(-EINVAL);\n+\t}\n \n \trcu_read_lock();\n \tlist_for_each_entry_rcu(ptype, &offload_base, list) {\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/core/gro.c b/net/core/gro.c\nindex b4190eb08467..e296977dbaff 100644\n--- a/net/core/gro.c\n+++ b/net/core/gro.c\n@@ -133,6 +133,10 @@ struct sk_buff *skb_mac_gso_segment(struct sk_buff *skb,\n \tif (unlikely(!type))\n \t\treturn ERR_PTR(-EINVAL);\n \n+\tif (unlikely(vlan_depth > skb->len)) {\n+\t\tpr_err(\"Invalid vlan_depth: %d, skb->len: %d\\n\", vlan_depth, skb->len);\n+\t\treturn ERR_PTR(-EINVAL);\n+\t}\n \t__skb_pull(skb, vlan_depth);\n \n \trcu_read_lock();\n",
            "diff --git a/net/core/gro.c b/net/core/gro.c\nindex b4190eb08467..360e22cd9c74 100644\n--- a/net/core/gro.c\n+++ b/net/core/gro.c\n@@ -133,6 +133,10 @@ struct sk_buff *skb_mac_gso_segment(struct sk_buff *skb,\n \tif (unlikely(!type))\n \t\treturn ERR_PTR(-EINVAL);\n \n+\tif (vlan_depth > skb->len) {\n+\t\tpr_err(\"Invalid VLAN depth: %d exceeds skb length: %d\\n\", vlan_depth, skb->len);\n+\t\treturn ERR_PTR(-EINVAL);\n+\t}\n \t__skb_pull(skb, vlan_depth);\n \n \trcu_read_lock();\n",
            "diff --git a/net/core/gro.c b/net/core/gro.c\nindex b4190eb08467..dae7b6dafa4d 100644\n--- a/net/core/gro.c\n+++ b/net/core/gro.c\n@@ -133,6 +133,10 @@ struct sk_buff *skb_mac_gso_segment(struct sk_buff *skb,\n \tif (unlikely(!type))\n \t\treturn ERR_PTR(-EINVAL);\n \n+\tif (unlikely(vlan_depth > skb->len)) {\n+\t\tpr_err(\"Invalid VLAN depth: %d exceeds skb length: %d\\n\", vlan_depth, skb->len);\n+\t\treturn ERR_PTR(-EINVAL);\n+\t}\n \t__skb_pull(skb, vlan_depth);\n \n \trcu_read_lock();\n",
            "diff --git a/net/core/gro.c b/net/core/gro.c\nindex b4190eb08467..e63efffd8de6 100644\n--- a/net/core/gro.c\n+++ b/net/core/gro.c\n@@ -133,6 +133,10 @@ struct sk_buff *skb_mac_gso_segment(struct sk_buff *skb,\n \tif (unlikely(!type))\n \t\treturn ERR_PTR(-EINVAL);\n \n+\tif (vlan_depth > skb->len) {\n+\t\tpr_err(\"Invalid VLAN depth: %d\\n\", vlan_depth);\n+\t\treturn ERR_PTR(-EINVAL);\n+\t}\n \t__skb_pull(skb, vlan_depth);\n \n \trcu_read_lock();\n"
        ],
        "error": []
    },
    "daa1858cc0258eb026f89eecf342f6b3fdad7b05": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/sched/em_cmp.c b/net/sched/em_cmp.c\nindex f17b049ea530..83320c124a74 100644\n--- a/net/sched/em_cmp.c\n+++ b/net/sched/em_cmp.c\n@@ -25,7 +25,7 @@ static int em_cmp_match(struct sk_buff *skb, struct tcf_ematch *em,\n \tunsigned char *ptr = tcf_get_base_ptr(skb, cmp->layer) + cmp->off;\n \tu32 val = 0;\n \n-\tif (!tcf_valid_offset(skb, ptr, cmp->align))\n+\tif (!ptr || !tcf_valid_offset(skb, ptr, cmp->align))\n \t\treturn 0;\n \n \tswitch (cmp->align) {\n",
            "diff --git a/net/sched/em_cmp.c b/net/sched/em_cmp.c\nindex f17b049ea530..b7635d3524ee 100644\n--- a/net/sched/em_cmp.c\n+++ b/net/sched/em_cmp.c\n@@ -22,7 +22,11 @@ static int em_cmp_match(struct sk_buff *skb, struct tcf_ematch *em,\n \t\t\tstruct tcf_pkt_info *info)\n {\n \tstruct tcf_em_cmp *cmp = (struct tcf_em_cmp *) em->data;\n-\tunsigned char *ptr = tcf_get_base_ptr(skb, cmp->layer) + cmp->off;\n+\tunsigned char *base_ptr = tcf_get_base_ptr(skb, cmp->layer);\n+\tif (!base_ptr)\n+\t\treturn 0;\n+\n+\tunsigned char *ptr = base_ptr + cmp->off;\n \tu32 val = 0;\n \n \tif (!tcf_valid_offset(skb, ptr, cmp->align))\n@@ -30,6 +34,8 @@ static int em_cmp_match(struct sk_buff *skb, struct tcf_ematch *em,\n \n \tswitch (cmp->align) {\n \tcase TCF_EM_ALIGN_U8:\n+\t\tif (!ptr)\n+\t\t\treturn 0;\n \t\tval = *ptr;\n \t\tbreak;\n \n",
            "diff --git a/net/sched/em_cmp.c b/net/sched/em_cmp.c\nindex f17b049ea530..616c9a90a72c 100644\n--- a/net/sched/em_cmp.c\n+++ b/net/sched/em_cmp.c\n@@ -25,7 +25,7 @@ static int em_cmp_match(struct sk_buff *skb, struct tcf_ematch *em,\n \tunsigned char *ptr = tcf_get_base_ptr(skb, cmp->layer) + cmp->off;\n \tu32 val = 0;\n \n-\tif (!tcf_valid_offset(skb, ptr, cmp->align))\n+\tif (!tcf_valid_offset(skb, ptr, cmp->align) || !ptr)\n \t\treturn 0;\n \n \tswitch (cmp->align) {\n",
            "diff --git a/net/sched/em_cmp.c b/net/sched/em_cmp.c\nindex f17b049ea530..83320c124a74 100644\n--- a/net/sched/em_cmp.c\n+++ b/net/sched/em_cmp.c\n@@ -25,7 +25,7 @@ static int em_cmp_match(struct sk_buff *skb, struct tcf_ematch *em,\n \tunsigned char *ptr = tcf_get_base_ptr(skb, cmp->layer) + cmp->off;\n \tu32 val = 0;\n \n-\tif (!tcf_valid_offset(skb, ptr, cmp->align))\n+\tif (!ptr || !tcf_valid_offset(skb, ptr, cmp->align))\n \t\treturn 0;\n \n \tswitch (cmp->align) {\n",
            "diff --git a/net/sched/em_cmp.c b/net/sched/em_cmp.c\nindex f17b049ea530..83320c124a74 100644\n--- a/net/sched/em_cmp.c\n+++ b/net/sched/em_cmp.c\n@@ -25,7 +25,7 @@ static int em_cmp_match(struct sk_buff *skb, struct tcf_ematch *em,\n \tunsigned char *ptr = tcf_get_base_ptr(skb, cmp->layer) + cmp->off;\n \tu32 val = 0;\n \n-\tif (!tcf_valid_offset(skb, ptr, cmp->align))\n+\tif (!ptr || !tcf_valid_offset(skb, ptr, cmp->align))\n \t\treturn 0;\n \n \tswitch (cmp->align) {\n"
        ],
        "error": []
    },
    "e675fbaf856bd1465eed8b8f51ae182b58b8d656": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex bc0f15257b49..ea1006be5045 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -157,8 +157,10 @@ static int mnt_alloc_group_id(struct mount *mnt)\n  */\n void mnt_release_group_id(struct mount *mnt)\n {\n-\tida_free(&mnt_group_ida, mnt->mnt_group_id);\n-\tmnt->mnt_group_id = 0;\n+\tif (mnt->mnt_group_id) {\n+\t\tida_free(&mnt_group_ida, mnt->mnt_group_id);\n+\t\tmnt->mnt_group_id = 0;\n+\t}\n }\n \n /*\n",
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex bc0f15257b49..ea1006be5045 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -157,8 +157,10 @@ static int mnt_alloc_group_id(struct mount *mnt)\n  */\n void mnt_release_group_id(struct mount *mnt)\n {\n-\tida_free(&mnt_group_ida, mnt->mnt_group_id);\n-\tmnt->mnt_group_id = 0;\n+\tif (mnt->mnt_group_id) {\n+\t\tida_free(&mnt_group_ida, mnt->mnt_group_id);\n+\t\tmnt->mnt_group_id = 0;\n+\t}\n }\n \n /*\n",
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex bc0f15257b49..ea1006be5045 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -157,8 +157,10 @@ static int mnt_alloc_group_id(struct mount *mnt)\n  */\n void mnt_release_group_id(struct mount *mnt)\n {\n-\tida_free(&mnt_group_ida, mnt->mnt_group_id);\n-\tmnt->mnt_group_id = 0;\n+\tif (mnt->mnt_group_id) {\n+\t\tida_free(&mnt_group_ida, mnt->mnt_group_id);\n+\t\tmnt->mnt_group_id = 0;\n+\t}\n }\n \n /*\n",
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex bc0f15257b49..e95525be08ca 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -157,8 +157,10 @@ static int mnt_alloc_group_id(struct mount *mnt)\n  */\n void mnt_release_group_id(struct mount *mnt)\n {\n-\tida_free(&mnt_group_ida, mnt->mnt_group_id);\n-\tmnt->mnt_group_id = 0;\n+\tif (mnt->mnt_group_id != 0) {\n+\t\tida_free(&mnt_group_ida, mnt->mnt_group_id);\n+\t\tmnt->mnt_group_id = 0;\n+\t}\n }\n \n /*\n",
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex bc0f15257b49..ea1006be5045 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -157,8 +157,10 @@ static int mnt_alloc_group_id(struct mount *mnt)\n  */\n void mnt_release_group_id(struct mount *mnt)\n {\n-\tida_free(&mnt_group_ida, mnt->mnt_group_id);\n-\tmnt->mnt_group_id = 0;\n+\tif (mnt->mnt_group_id) {\n+\t\tida_free(&mnt_group_ida, mnt->mnt_group_id);\n+\t\tmnt->mnt_group_id = 0;\n+\t}\n }\n \n /*\n"
        ],
        "error": []
    },
    "8137f770127ad3ae80cc615fbb3b3bdf71c5e17e": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/bluetooth/hci_sync.c b/net/bluetooth/hci_sync.c\nindex 286d6767f017..04f3533e5d8b 100644\n--- a/net/bluetooth/hci_sync.c\n+++ b/net/bluetooth/hci_sync.c\n@@ -4089,10 +4089,11 @@ int hci_dev_close_sync(struct hci_dev *hdev)\n \tbt_dev_dbg(hdev, \"\");\n \n \tcancel_work_sync(&hdev->power_on);\n-\tcancel_delayed_work(&hdev->power_off);\n-\tcancel_delayed_work(&hdev->ncmd_timer);\n+\tcancel_delayed_work_sync(&hdev->power_off);\n+\tcancel_delayed_work_sync(&hdev->ncmd_timer);\n \n \thci_request_cancel_all(hdev);\n+\tdrain_workqueue(hdev->workqueue);\n \n \tif (!hci_dev_test_flag(hdev, HCI_UNREGISTER) &&\n \t    !hci_dev_test_flag(hdev, HCI_USER_CHANNEL) &&\n@@ -4134,8 +4135,6 @@ int hci_dev_close_sync(struct hci_dev *hdev)\n \t/* Avoid potential lockdep warnings from the *_flush() calls by\n \t * ensuring the workqueue is empty up front.\n \t */\n-\tdrain_workqueue(hdev->workqueue);\n-\n \thci_dev_lock(hdev);\n \n \thci_discovery_set_state(hdev, DISCOVERY_STOPPED);\n",
            "diff --git a/net/bluetooth/hci_sync.c b/net/bluetooth/hci_sync.c\nindex 286d6767f017..e62d29a1ce18 100644\n--- a/net/bluetooth/hci_sync.c\n+++ b/net/bluetooth/hci_sync.c\n@@ -4088,9 +4088,9 @@ int hci_dev_close_sync(struct hci_dev *hdev)\n \n \tbt_dev_dbg(hdev, \"\");\n \n+\tcancel_delayed_work_sync(&hdev->power_off);\n+\tcancel_delayed_work_sync(&hdev->ncmd_timer);\n \tcancel_work_sync(&hdev->power_on);\n-\tcancel_delayed_work(&hdev->power_off);\n-\tcancel_delayed_work(&hdev->ncmd_timer);\n \n \thci_request_cancel_all(hdev);\n \n"
        ],
        "error": []
    },
    "7d3c28ba3d4bf4b26e89ed1f1ca146e0223a2d36": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/security/keys/keyctl.c b/security/keys/keyctl.c\nindex 96a92a645216..be7092626087 100644\n--- a/security/keys/keyctl.c\n+++ b/security/keys/keyctl.c\n@@ -1818,8 +1818,10 @@ long keyctl_watch_key(key_serial_t id, int watch_queue_fd, int watch_id)\n \t\tret = add_watch_to_object(watch, key->watchers);\n \t\tup_write(&key->sem);\n \n-\t\tif (ret == 0)\n+\t\tif (ret == 0) {\n+\t\t\tkfree(watch);\n \t\t\twatch = NULL;\n+\t\t}\n \t} else {\n \t\tret = -EBADSLT;\n \t\tif (key->watchers) {\n",
            "diff --git a/security/keys/keyctl.c b/security/keys/keyctl.c\nindex 96a92a645216..be7092626087 100644\n--- a/security/keys/keyctl.c\n+++ b/security/keys/keyctl.c\n@@ -1818,8 +1818,10 @@ long keyctl_watch_key(key_serial_t id, int watch_queue_fd, int watch_id)\n \t\tret = add_watch_to_object(watch, key->watchers);\n \t\tup_write(&key->sem);\n \n-\t\tif (ret == 0)\n+\t\tif (ret == 0) {\n+\t\t\tkfree(watch);\n \t\t\twatch = NULL;\n+\t\t}\n \t} else {\n \t\tret = -EBADSLT;\n \t\tif (key->watchers) {\n",
            "diff --git a/security/keys/keyctl.c b/security/keys/keyctl.c\nindex 96a92a645216..be7092626087 100644\n--- a/security/keys/keyctl.c\n+++ b/security/keys/keyctl.c\n@@ -1818,8 +1818,10 @@ long keyctl_watch_key(key_serial_t id, int watch_queue_fd, int watch_id)\n \t\tret = add_watch_to_object(watch, key->watchers);\n \t\tup_write(&key->sem);\n \n-\t\tif (ret == 0)\n+\t\tif (ret == 0) {\n+\t\t\tkfree(watch);\n \t\t\twatch = NULL;\n+\t\t}\n \t} else {\n \t\tret = -EBADSLT;\n \t\tif (key->watchers) {\n",
            "diff --git a/security/keys/keyctl.c b/security/keys/keyctl.c\nindex 96a92a645216..dc345eb68dd2 100644\n--- a/security/keys/keyctl.c\n+++ b/security/keys/keyctl.c\n@@ -1818,8 +1818,12 @@ long keyctl_watch_key(key_serial_t id, int watch_queue_fd, int watch_id)\n \t\tret = add_watch_to_object(watch, key->watchers);\n \t\tup_write(&key->sem);\n \n-\t\tif (ret == 0)\n+\t\tif (ret == 0) {\n+\t\t\tkfree(watch);\n \t\t\twatch = NULL;\n+\t\t} else {\n+\t\t\tkfree(wlist);\n+\t\t}\n \t} else {\n \t\tret = -EBADSLT;\n \t\tif (key->watchers) {\n",
            "diff --git a/security/keys/keyctl.c b/security/keys/keyctl.c\nindex 96a92a645216..6f4d170582e8 100644\n--- a/security/keys/keyctl.c\n+++ b/security/keys/keyctl.c\n@@ -1818,8 +1818,11 @@ long keyctl_watch_key(key_serial_t id, int watch_queue_fd, int watch_id)\n \t\tret = add_watch_to_object(watch, key->watchers);\n \t\tup_write(&key->sem);\n \n-\t\tif (ret == 0)\n+\t\tif (ret == 0) {\n \t\t\twatch = NULL;\n+\t\t} else {\n+\t\t\tgoto err_watch;\n+\t\t}\n \t} else {\n \t\tret = -EBADSLT;\n \t\tif (key->watchers) {\n"
        ],
        "error": []
    },
    "e9f526f59d5b25decd3b91d4270b5da2aa23c8f6": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/media/common/videobuf2/videobuf2-vmalloc.c b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\nindex 6dfbd5b05907..ca725fada55f 100644\n--- a/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n+++ b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n@@ -128,6 +128,9 @@ static void *vb2_vmalloc_get_userptr(struct device *dev, unsigned long vaddr,\n static void vb2_vmalloc_put_userptr(void *buf_priv)\n {\n \tstruct vb2_vmalloc_buf *buf = buf_priv;\n+\tif (!buf || !buf->vaddr)\n+\t\treturn;\n+\n \tunsigned long vaddr = (unsigned long)buf->vaddr & PAGE_MASK;\n \tunsigned int i;\n \tstruct page **pages;\n",
            "diff --git a/drivers/media/common/videobuf2/videobuf2-vmalloc.c b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\nindex 6dfbd5b05907..70d8cb36d6cb 100644\n--- a/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n+++ b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n@@ -127,6 +127,9 @@ static void *vb2_vmalloc_get_userptr(struct device *dev, unsigned long vaddr,\n \n static void vb2_vmalloc_put_userptr(void *buf_priv)\n {\n+\tif (!buf_priv)\n+\t\treturn;\n+\n \tstruct vb2_vmalloc_buf *buf = buf_priv;\n \tunsigned long vaddr = (unsigned long)buf->vaddr & PAGE_MASK;\n \tunsigned int i;\n",
            "diff --git a/drivers/media/common/videobuf2/videobuf2-vmalloc.c b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\nindex 6dfbd5b05907..3e4cd51d4f3d 100644\n--- a/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n+++ b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n@@ -128,16 +128,19 @@ static void *vb2_vmalloc_get_userptr(struct device *dev, unsigned long vaddr,\n static void vb2_vmalloc_put_userptr(void *buf_priv)\n {\n \tstruct vb2_vmalloc_buf *buf = buf_priv;\n-\tunsigned long vaddr = (unsigned long)buf->vaddr & PAGE_MASK;\n+\tunsigned long vaddr;\n \tunsigned int i;\n \tstruct page **pages;\n \tunsigned int n_pages;\n \n+\tif (!buf->vaddr)\n+\t\treturn;\n+\n+\tvaddr = (unsigned long)buf->vaddr & PAGE_MASK;\n \tif (!buf->vec->is_pfns) {\n \t\tn_pages = frame_vector_count(buf->vec);\n \t\tpages = frame_vector_pages(buf->vec);\n-\t\tif (vaddr)\n-\t\t\tvm_unmap_ram((void *)vaddr, n_pages);\n+\t\tvm_unmap_ram((void *)vaddr, n_pages);\n \t\tif (buf->dma_dir == DMA_FROM_DEVICE ||\n \t\t    buf->dma_dir == DMA_BIDIRECTIONAL)\n \t\t\tfor (i = 0; i < n_pages; i++)\n",
            "diff --git a/drivers/media/common/videobuf2/videobuf2-vmalloc.c b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\nindex 6dfbd5b05907..e675f22c9dc8 100644\n--- a/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n+++ b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n@@ -128,16 +128,20 @@ static void *vb2_vmalloc_get_userptr(struct device *dev, unsigned long vaddr,\n static void vb2_vmalloc_put_userptr(void *buf_priv)\n {\n \tstruct vb2_vmalloc_buf *buf = buf_priv;\n-\tunsigned long vaddr = (unsigned long)buf->vaddr & PAGE_MASK;\n+\tunsigned long vaddr;\n \tunsigned int i;\n \tstruct page **pages;\n \tunsigned int n_pages;\n \n+\tif (!buf->vaddr) {\n+\t\treturn;\n+\t}\n+\n+\tvaddr = (unsigned long)buf->vaddr & PAGE_MASK;\n \tif (!buf->vec->is_pfns) {\n \t\tn_pages = frame_vector_count(buf->vec);\n \t\tpages = frame_vector_pages(buf->vec);\n-\t\tif (vaddr)\n-\t\t\tvm_unmap_ram((void *)vaddr, n_pages);\n+\t\tvm_unmap_ram((void *)vaddr, n_pages);\n \t\tif (buf->dma_dir == DMA_FROM_DEVICE ||\n \t\t    buf->dma_dir == DMA_BIDIRECTIONAL)\n \t\t\tfor (i = 0; i < n_pages; i++)\n",
            "diff --git a/drivers/media/common/videobuf2/videobuf2-vmalloc.c b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\nindex 6dfbd5b05907..ca725fada55f 100644\n--- a/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n+++ b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n@@ -128,6 +128,9 @@ static void *vb2_vmalloc_get_userptr(struct device *dev, unsigned long vaddr,\n static void vb2_vmalloc_put_userptr(void *buf_priv)\n {\n \tstruct vb2_vmalloc_buf *buf = buf_priv;\n+\tif (!buf || !buf->vaddr)\n+\t\treturn;\n+\n \tunsigned long vaddr = (unsigned long)buf->vaddr & PAGE_MASK;\n \tunsigned int i;\n \tstruct page **pages;\n"
        ],
        "error": []
    },
    "67d3719a7490d99812faae7f9c2c26e9f386c1a6": {
        "non_crash": [
            "diff --git a/fs/hfs/trans.c b/fs/hfs/trans.c\nindex 39f5e343bf4d..8ef3610317b5 100644\n--- a/fs/hfs/trans.c\n+++ b/fs/hfs/trans.c\n@@ -127,11 +127,19 @@ void hfs_asc2mac(struct super_block *sb, struct hfs_name *out, const struct qstr\n \t\t\t\t\t*dst = '?';\n \t\t\t\t\tsize = 1;\n \t\t\t\t}\n-\t\t\t\tdst += size;\n-\t\t\t\tdstlen -= size;\n+\t\t\t\tif (dstlen >= size) {\n+\t\t\t\t\tdst += size;\n+\t\t\t\t\tdstlen -= size;\n+\t\t\t\t} else {\n+\t\t\t\t\tgoto out;\n+\t\t\t\t}\n \t\t\t} else {\n-\t\t\t\t*dst++ = ch > 0xff ? '?' : ch;\n-\t\t\t\tdstlen--;\n+\t\t\t\tif (dstlen > 0) {\n+\t\t\t\t\t*dst++ = ch > 0xff ? '?' : ch;\n+\t\t\t\t\tdstlen--;\n+\t\t\t\t} else {\n+\t\t\t\t\tgoto out;\n+\t\t\t\t}\n \t\t\t}\n \t\t}\n \t} else {\n",
            "diff --git a/fs/hfs/trans.c b/fs/hfs/trans.c\nindex 39f5e343bf4d..1af35aa43ada 100644\n--- a/fs/hfs/trans.c\n+++ b/fs/hfs/trans.c\n@@ -130,8 +130,10 @@ void hfs_asc2mac(struct super_block *sb, struct hfs_name *out, const struct qstr\n \t\t\t\tdst += size;\n \t\t\t\tdstlen -= size;\n \t\t\t} else {\n-\t\t\t\t*dst++ = ch > 0xff ? '?' : ch;\n-\t\t\t\tdstlen--;\n+\t\t\t\tif (dstlen > 0) {\n+\t\t\t\t\t*dst++ = ch > 0xff ? '?' : ch;\n+\t\t\t\t\tdstlen--;\n+\t\t\t\t}\n \t\t\t}\n \t\t}\n \t} else {\n@@ -139,8 +141,10 @@ void hfs_asc2mac(struct super_block *sb, struct hfs_name *out, const struct qstr\n \n \t\tif (dstlen > srclen)\n \t\t\tdstlen = srclen;\n-\t\twhile (--dstlen >= 0)\n+\t\twhile (dstlen > 0) {\n \t\t\t*dst++ = (ch = *src++) == ':' ? '/' : ch;\n+\t\t\tdstlen--;\n+\t\t}\n \t}\n out:\n \tout->len = dst - (char *)out->name;\n",
            "diff --git a/fs/hfs/trans.c b/fs/hfs/trans.c\nindex 39f5e343bf4d..92adaf029c95 100644\n--- a/fs/hfs/trans.c\n+++ b/fs/hfs/trans.c\n@@ -120,18 +120,22 @@ void hfs_asc2mac(struct super_block *sb, struct hfs_name *out, const struct qstr\n \t\t\tif (ch == ':')\n \t\t\t\tch = '/';\n \t\t\tif (nls_disk) {\n-\t\t\t\tsize = nls_disk->uni2char(ch, dst, dstlen);\n-\t\t\t\tif (size < 0) {\n-\t\t\t\t\tif (size == -ENAMETOOLONG)\n-\t\t\t\t\t\tgoto out;\n-\t\t\t\t\t*dst = '?';\n-\t\t\t\t\tsize = 1;\n+\t\t\t\tif (dstlen > 0) {\n+\t\t\t\t\tsize = nls_disk->uni2char(ch, dst, dstlen);\n+\t\t\t\t\tif (size < 0) {\n+\t\t\t\t\t\tif (size == -ENAMETOOLONG)\n+\t\t\t\t\t\t\tgoto out;\n+\t\t\t\t\t\t*dst = '?';\n+\t\t\t\t\t\tsize = 1;\n+\t\t\t\t\t}\n+\t\t\t\t\tdst += size;\n+\t\t\t\t\tdstlen -= size;\n \t\t\t\t}\n-\t\t\t\tdst += size;\n-\t\t\t\tdstlen -= size;\n \t\t\t} else {\n-\t\t\t\t*dst++ = ch > 0xff ? '?' : ch;\n-\t\t\t\tdstlen--;\n+\t\t\t\tif (dstlen > 0) {\n+\t\t\t\t\t*dst++ = ch > 0xff ? '?' : ch;\n+\t\t\t\t\tdstlen--;\n+\t\t\t\t}\n \t\t\t}\n \t\t}\n \t} else {\n",
            "diff --git a/fs/hfs/trans.c b/fs/hfs/trans.c\nindex 39f5e343bf4d..8ef3610317b5 100644\n--- a/fs/hfs/trans.c\n+++ b/fs/hfs/trans.c\n@@ -127,11 +127,19 @@ void hfs_asc2mac(struct super_block *sb, struct hfs_name *out, const struct qstr\n \t\t\t\t\t*dst = '?';\n \t\t\t\t\tsize = 1;\n \t\t\t\t}\n-\t\t\t\tdst += size;\n-\t\t\t\tdstlen -= size;\n+\t\t\t\tif (dstlen >= size) {\n+\t\t\t\t\tdst += size;\n+\t\t\t\t\tdstlen -= size;\n+\t\t\t\t} else {\n+\t\t\t\t\tgoto out;\n+\t\t\t\t}\n \t\t\t} else {\n-\t\t\t\t*dst++ = ch > 0xff ? '?' : ch;\n-\t\t\t\tdstlen--;\n+\t\t\t\tif (dstlen > 0) {\n+\t\t\t\t\t*dst++ = ch > 0xff ? '?' : ch;\n+\t\t\t\t\tdstlen--;\n+\t\t\t\t} else {\n+\t\t\t\t\tgoto out;\n+\t\t\t\t}\n \t\t\t}\n \t\t}\n \t} else {\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "19a04b43c75ed1092021010419b5e560a8172c4f": {
        "non_crash": [
            "diff --git a/drivers/hid/hidraw.c b/drivers/hid/hidraw.c\nindex 681614a8302a..8e732f50cac7 100644\n--- a/drivers/hid/hidraw.c\n+++ b/drivers/hid/hidraw.c\n@@ -516,6 +516,7 @@ int hidraw_report_event(struct hid_device *hid, u8 *data, int len)\n \t\tint new_head = (list->head + 1) & (HIDRAW_BUFFER_SIZE - 1);\n \n \t\tif (new_head == list->tail)\n+\t\t\tkfree(list->buffer[list->head].value);\n \t\t\tcontinue;\n \n \t\tif (!(list->buffer[list->head].value = kmemdup(data, len, GFP_ATOMIC))) {\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/hid/hidraw.c b/drivers/hid/hidraw.c\nindex 681614a8302a..c61cd0b4e5dd 100644\n--- a/drivers/hid/hidraw.c\n+++ b/drivers/hid/hidraw.c\n@@ -52,7 +52,8 @@ static ssize_t hidraw_read(struct file *file, char __user *buffer, size_t count,\n \t\t\twhile (list->head == list->tail) {\n \t\t\t\tif (signal_pending(current)) {\n \t\t\t\t\tret = -ERESTARTSYS;\n-\t\t\t\t\tbreak;\n+\t\t\t\t\tkfree(list->buffer[list->head].value);\n+\t\t\tbreak;\n \t\t\t\t}\n \t\t\t\tif (!list->hidraw->exist) {\n \t\t\t\t\tret = -EIO;\n",
            "diff --git a/drivers/hid/hidraw.c b/drivers/hid/hidraw.c\nindex 681614a8302a..c61cd0b4e5dd 100644\n--- a/drivers/hid/hidraw.c\n+++ b/drivers/hid/hidraw.c\n@@ -52,7 +52,8 @@ static ssize_t hidraw_read(struct file *file, char __user *buffer, size_t count,\n \t\t\twhile (list->head == list->tail) {\n \t\t\t\tif (signal_pending(current)) {\n \t\t\t\t\tret = -ERESTARTSYS;\n-\t\t\t\t\tbreak;\n+\t\t\t\t\tkfree(list->buffer[list->head].value);\n+\t\t\tbreak;\n \t\t\t\t}\n \t\t\t\tif (!list->hidraw->exist) {\n \t\t\t\t\tret = -EIO;\n",
            "diff --git a/drivers/hid/hidraw.c b/drivers/hid/hidraw.c\nindex 681614a8302a..c61cd0b4e5dd 100644\n--- a/drivers/hid/hidraw.c\n+++ b/drivers/hid/hidraw.c\n@@ -52,7 +52,8 @@ static ssize_t hidraw_read(struct file *file, char __user *buffer, size_t count,\n \t\t\twhile (list->head == list->tail) {\n \t\t\t\tif (signal_pending(current)) {\n \t\t\t\t\tret = -ERESTARTSYS;\n-\t\t\t\t\tbreak;\n+\t\t\t\t\tkfree(list->buffer[list->head].value);\n+\t\t\tbreak;\n \t\t\t\t}\n \t\t\t\tif (!list->hidraw->exist) {\n \t\t\t\t\tret = -EIO;\n",
            "diff --git a/drivers/hid/hidraw.c b/drivers/hid/hidraw.c\nindex 681614a8302a..c61cd0b4e5dd 100644\n--- a/drivers/hid/hidraw.c\n+++ b/drivers/hid/hidraw.c\n@@ -52,7 +52,8 @@ static ssize_t hidraw_read(struct file *file, char __user *buffer, size_t count,\n \t\t\twhile (list->head == list->tail) {\n \t\t\t\tif (signal_pending(current)) {\n \t\t\t\t\tret = -ERESTARTSYS;\n-\t\t\t\t\tbreak;\n+\t\t\t\t\tkfree(list->buffer[list->head].value);\n+\t\t\tbreak;\n \t\t\t\t}\n \t\t\t\tif (!list->hidraw->exist) {\n \t\t\t\t\tret = -EIO;\n"
        ],
        "error": []
    },
    "cd95cb722bfa1234ac4c78345c8953ee2e7170d0": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c\nindex e79c767cc5e0..53b642eece98 100644\n--- a/fs/ext4/extents.c\n+++ b/fs/ext4/extents.c\n@@ -960,9 +960,9 @@ ext4_find_extent(struct inode *inode, ext4_lblk_t block,\n \treturn path;\n \n err:\n-\text4_free_ext_path(path);\n \tif (orig_path)\n \t\t*orig_path = NULL;\n+\text4_free_ext_path(path);\n \treturn ERR_PTR(ret);\n }\n \n@@ -6022,8 +6022,8 @@ int ext4_ext_replay_set_iblocks(struct inode *inode)\n \tif (IS_ERR(path))\n \t\tgoto out;\n \tnumblks += path->p_depth;\n-\text4_free_ext_path(path);\n \twhile (cur < end) {\n+\t\text4_free_ext_path(path);\n \t\tpath = ext4_find_extent(inode, cur, NULL, 0);\n \t\tif (IS_ERR(path))\n \t\t\tbreak;\n",
            "diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c\nindex e79c767cc5e0..5c2617fb95f0 100644\n--- a/fs/ext4/extents.c\n+++ b/fs/ext4/extents.c\n@@ -656,6 +656,7 @@ int ext4_ext_precache(struct inode *inode)\n out:\n \tup_read(&ei->i_data_sem);\n \text4_free_ext_path(path);\n+\tpath = NULL;\n \treturn ret;\n }\n \n",
            "diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c\nindex e79c767cc5e0..347458faf1a2 100644\n--- a/fs/ext4/extents.c\n+++ b/fs/ext4/extents.c\n@@ -960,9 +960,12 @@ ext4_find_extent(struct inode *inode, ext4_lblk_t block,\n \treturn path;\n \n err:\n-\text4_free_ext_path(path);\n-\tif (orig_path)\n+\tif (orig_path) {\n+\t\text4_free_ext_path(path);\n \t\t*orig_path = NULL;\n+\t} else {\n+\t\text4_free_ext_path(path);\n+\t}\n \treturn ERR_PTR(ret);\n }\n \n",
            "diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c\nindex e79c767cc5e0..767d0f9e9398 100644\n--- a/fs/ext4/extents.c\n+++ b/fs/ext4/extents.c\n@@ -5993,6 +5993,7 @@ int ext4_ext_replay_set_iblocks(struct inode *inode)\n \t}\n \tend = le32_to_cpu(ex->ee_block) + ext4_ext_get_actual_len(ex);\n \text4_free_ext_path(path);\n+\tpath = NULL; // Ensure path is not used after being freed\n \n \t/* Count the number of data blocks */\n \tcur = 0;\n",
            "diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c\nindex e79c767cc5e0..36a8aa9f82d5 100644\n--- a/fs/ext4/extents.c\n+++ b/fs/ext4/extents.c\n@@ -656,6 +656,10 @@ int ext4_ext_precache(struct inode *inode)\n out:\n \tup_read(&ei->i_data_sem);\n \text4_free_ext_path(path);\n+\tpath = NULL;\n+\tpath = NULL;\n+\tpath = NULL;\n+\tpath = NULL;\n \treturn ret;\n }\n \n"
        ],
        "error": []
    },
    "17ba20e86ace8566cff1a3ace9042a779bd8bb7c": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/char/hw_random/core.c b/drivers/char/hw_random/core.c\nindex a3db27916256..ffab40866756 100644\n--- a/drivers/char/hw_random/core.c\n+++ b/drivers/char/hw_random/core.c\n@@ -487,6 +487,7 @@ int hwrng_register(struct hwrng *rng)\n \t\tif (tmp->quality < rng->quality)\n \t\t\tbreak;\n \t}\n+\trng_list_ptr = &rng_list;\n \tlist_add_tail(&rng->list, rng_list_ptr);\n \n \tif (!current_rng ||\n",
            "diff --git a/drivers/char/hw_random/core.c b/drivers/char/hw_random/core.c\nindex a3db27916256..854787c98fbc 100644\n--- a/drivers/char/hw_random/core.c\n+++ b/drivers/char/hw_random/core.c\n@@ -467,7 +467,7 @@ int hwrng_register(struct hwrng *rng)\n \tbool is_new_current = false;\n \n \tif (!rng->name || (!rng->data_read && !rng->read))\n-\t\tgoto out;\n+\t\treturn err;\n \n \tmutex_lock(&rng_mutex);\n \n@@ -497,8 +497,10 @@ int hwrng_register(struct hwrng *rng)\n \t\t * chosen by userspace.\n \t\t */\n \t\terr = set_current_rng(rng);\n-\t\tif (err)\n+\t\tif (err) {\n+\t\t\tkref_put(&rng->ref, cleanup_rng);\n \t\t\tgoto out_unlock;\n+\t\t}\n \t\t/* to use current_rng in add_early_randomness() we need\n \t\t * to take a ref\n \t\t */\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/char/hw_random/core.c b/drivers/char/hw_random/core.c\nindex a3db27916256..43ad52dd2c70 100644\n--- a/drivers/char/hw_random/core.c\n+++ b/drivers/char/hw_random/core.c\n@@ -496,16 +496,16 @@ int hwrng_register(struct hwrng *rng)\n \t\t * provides better entropy quality and was not\n \t\t * chosen by userspace.\n \t\t */\n+\t\tmutex_unlock(&rng_mutex);\n \t\terr = set_current_rng(rng);\n \t\tif (err)\n-\t\t\tgoto out_unlock;\n+\t\t\treturn err;\n \t\t/* to use current_rng in add_early_randomness() we need\n \t\t * to take a ref\n \t\t */\n \t\tis_new_current = true;\n \t\tkref_get(&rng->ref);\n \t}\n-\tmutex_unlock(&rng_mutex);\n \tif (is_new_current || !rng->init) {\n \t\t/*\n \t\t * Use a new device's input to add some randomness to\n",
                "error_message": "Failed to set up instance"
            }
        ]
    },
    "46dd655664a8b38dbf7234683b294171a4e0142b": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/base/class.c b/drivers/base/class.c\nindex ac1808d1a2e8..29278699875c 100644\n--- a/drivers/base/class.c\n+++ b/drivers/base/class.c\n@@ -203,8 +203,10 @@ int class_register(const struct class *cls)\n \tcp->class = cls;\n \n \terror = kset_register(&cp->subsys);\n-\tif (error)\n-\t\tgoto err_out;\n+\tif (error) {\n+\t\tkfree(cp);\n+\t\treturn error;\n+\t}\n \n \terror = sysfs_create_groups(&cp->subsys.kobj, cls->class_groups);\n \tif (error) {\n",
            "diff --git a/drivers/base/class.c b/drivers/base/class.c\nindex ac1808d1a2e8..ec19f3c936cc 100644\n--- a/drivers/base/class.c\n+++ b/drivers/base/class.c\n@@ -194,6 +194,7 @@ int class_register(const struct class *cls)\n \t__mutex_init(&cp->mutex, \"subsys mutex\", key);\n \terror = kobject_set_name(&cp->subsys.kobj, \"%s\", cls->name);\n \tif (error) {\n+\t\tkobject_put(&cp->subsys.kobj);\n \t\tkfree(cp);\n \t\treturn error;\n \t}\n",
            "diff --git a/drivers/base/class.c b/drivers/base/class.c\nindex ac1808d1a2e8..9a41ef10103a 100644\n--- a/drivers/base/class.c\n+++ b/drivers/base/class.c\n@@ -203,20 +203,20 @@ int class_register(const struct class *cls)\n \tcp->class = cls;\n \n \terror = kset_register(&cp->subsys);\n-\tif (error)\n-\t\tgoto err_out;\n+\tif (error) {\n+\t\tkfree_const(cp->subsys.kobj.name);\n+\t\tkfree(cp);\n+\t\treturn error;\n+\t}\n \n \terror = sysfs_create_groups(&cp->subsys.kobj, cls->class_groups);\n \tif (error) {\n \t\tkobject_del(&cp->subsys.kobj);\n \t\tkfree_const(cp->subsys.kobj.name);\n-\t\tgoto err_out;\n+\t\tkfree(cp);\n+\t\treturn error;\n \t}\n \treturn 0;\n-\n-err_out:\n-\tkfree(cp);\n-\treturn error;\n }\n EXPORT_SYMBOL_GPL(class_register);\n \n",
            "diff --git a/drivers/base/class.c b/drivers/base/class.c\nindex ac1808d1a2e8..5b87a771264c 100644\n--- a/drivers/base/class.c\n+++ b/drivers/base/class.c\n@@ -194,6 +194,7 @@ int class_register(const struct class *cls)\n \t__mutex_init(&cp->mutex, \"subsys mutex\", key);\n \terror = kobject_set_name(&cp->subsys.kobj, \"%s\", cls->name);\n \tif (error) {\n+\t\tkobject_put(&cp->subsys.kobj);\n \t\tkfree(cp);\n \t\treturn error;\n \t}\n@@ -203,20 +204,21 @@ int class_register(const struct class *cls)\n \tcp->class = cls;\n \n \terror = kset_register(&cp->subsys);\n-\tif (error)\n-\t\tgoto err_out;\n+\tif (error) {\n+\t\tkobject_put(&cp->subsys.kobj);\n+\t\tkfree(cp);\n+\t\treturn error;\n+\t}\n \n \terror = sysfs_create_groups(&cp->subsys.kobj, cls->class_groups);\n \tif (error) {\n \t\tkobject_del(&cp->subsys.kobj);\n \t\tkfree_const(cp->subsys.kobj.name);\n-\t\tgoto err_out;\n+\t\tkobject_put(&cp->subsys.kobj);\n+\t\tkfree(cp);\n+\t\treturn error;\n \t}\n \treturn 0;\n-\n-err_out:\n-\tkfree(cp);\n-\treturn error;\n }\n EXPORT_SYMBOL_GPL(class_register);\n \n@@ -268,8 +270,11 @@ struct class *class_create(const char *name)\n \tcls->class_release = class_create_release;\n \n \tretval = class_register(cls);\n-\tif (retval)\n-\t\tgoto error;\n+\tif (retval) {\n+\t\tclass_unregister(cls);\n+\t\tkfree(cls);\n+\t\treturn ERR_PTR(retval);\n+\t}\n \n \treturn cls;\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/base/class.c b/drivers/base/class.c\nindex ac1808d1a2e8..134b1790452e 100644\n--- a/drivers/base/class.c\n+++ b/drivers/base/class.c\n@@ -203,20 +203,20 @@ int class_register(const struct class *cls)\n \tcp->class = cls;\n \n \terror = kset_register(&cp->subsys);\n-\tif (error)\n-\t\tgoto err_out;\n+\tif (error) {\n+\t\tkfree_const(cp->subsys.kobj.name);\n+\t\tkfree(cp);\n+\t\treturn error;\n+\t}\n \n \terror = sysfs_create_groups(&cp->subsys.kobj, cls->class_groups);\n \tif (error) {\n \t\tkobject_del(&cp->subsys.kobj);\n \t\tkfree_const(cp->subsys.kobj.name);\n-\t\tgoto err_out;\n+\t\tkfree(cp);\n+\t\treturn error;\n \t}\n \treturn 0;\n-\n-err_out:\n-\tkfree(cp);\n-\treturn error;\n }\n EXPORT_SYMBOL_GPL(class_register);\n \n@@ -268,14 +268,13 @@ struct class *class_create(const char *name)\n \tcls->class_release = class_create_release;\n \n \tretval = class_register(cls);\n-\tif (retval)\n-\t\tgoto error;\n+\tif (retval) {\n+\t\tkfree(cls->name);\n+\t\tkfree(cls);\n+\t\treturn ERR_PTR(retval);\n+\t}\n \n \treturn cls;\n-\n-error:\n-\tkfree(cls);\n-\treturn ERR_PTR(retval);\n }\n EXPORT_SYMBOL_GPL(class_create);\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "724cf869d3bb512081588651530d8071a4b61ceb": {
        "non_crash": [
            "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex b8c52e89688c..ea04c6f08eff 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -561,6 +561,9 @@ start_transaction(struct btrfs_root *root, unsigned int num_items,\n \t\t  unsigned int type, enum btrfs_reserve_flush_enum flush,\n \t\t  bool enforce_qgroups)\n {\n+\tif (!root)\n+\t\treturn ERR_PTR(-EINVAL);\n+\n \tstruct btrfs_fs_info *fs_info = root->fs_info;\n \tstruct btrfs_block_rsv *delayed_refs_rsv = &fs_info->delayed_refs_rsv;\n \tstruct btrfs_trans_handle *h;\n",
            "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex b8c52e89688c..ea04c6f08eff 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -561,6 +561,9 @@ start_transaction(struct btrfs_root *root, unsigned int num_items,\n \t\t  unsigned int type, enum btrfs_reserve_flush_enum flush,\n \t\t  bool enforce_qgroups)\n {\n+\tif (!root)\n+\t\treturn ERR_PTR(-EINVAL);\n+\n \tstruct btrfs_fs_info *fs_info = root->fs_info;\n \tstruct btrfs_block_rsv *delayed_refs_rsv = &fs_info->delayed_refs_rsv;\n \tstruct btrfs_trans_handle *h;\n",
            "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex b8c52e89688c..ea04c6f08eff 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -561,6 +561,9 @@ start_transaction(struct btrfs_root *root, unsigned int num_items,\n \t\t  unsigned int type, enum btrfs_reserve_flush_enum flush,\n \t\t  bool enforce_qgroups)\n {\n+\tif (!root)\n+\t\treturn ERR_PTR(-EINVAL);\n+\n \tstruct btrfs_fs_info *fs_info = root->fs_info;\n \tstruct btrfs_block_rsv *delayed_refs_rsv = &fs_info->delayed_refs_rsv;\n \tstruct btrfs_trans_handle *h;\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex b8c52e89688c..400a8cbdc4ba 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -400,6 +400,8 @@ static int record_root_in_trans(struct btrfs_trans_handle *trans,\n \t\t\t       struct btrfs_root *root,\n \t\t\t       int force)\n {\n+\tif (!root)\n+\t\treturn ERR_PTR(-EINVAL);\n \tstruct btrfs_fs_info *fs_info = root->fs_info;\n \tint ret = 0;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex b8c52e89688c..400a8cbdc4ba 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -400,6 +400,8 @@ static int record_root_in_trans(struct btrfs_trans_handle *trans,\n \t\t\t       struct btrfs_root *root,\n \t\t\t       int force)\n {\n+\tif (!root)\n+\t\treturn ERR_PTR(-EINVAL);\n \tstruct btrfs_fs_info *fs_info = root->fs_info;\n \tint ret = 0;\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "37556d70764e226e660023fad17c9c0316cb6f1d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/fs-writeback.c b/fs/fs-writeback.c\nindex 443f83382b9b..53c36010a85f 100644\n--- a/fs/fs-writeback.c\n+++ b/fs/fs-writeback.c\n@@ -1367,9 +1367,11 @@ static int move_expired_inodes(struct list_head *delaying_queue,\n \t\tif (inode_dirtied_after(inode, dirtied_before))\n \t\t\tbreak;\n \t\tspin_lock(&inode->i_lock);\n-\t\tlist_move(&inode->i_io_list, &tmp);\n-\t\tmoved++;\n-\t\tinode->i_state |= I_SYNC_QUEUED;\n+\t\tif (!list_empty(&inode->i_io_list)) {\n+\t\t\tlist_move(&inode->i_io_list, &tmp);\n+\t\t\tmoved++;\n+\t\t\tinode->i_state |= I_SYNC_QUEUED;\n+\t\t}\n \t\tspin_unlock(&inode->i_lock);\n \t\tif (sb_is_blkdev_sb(inode->i_sb))\n \t\t\tcontinue;\n",
            "diff --git a/fs/fs-writeback.c b/fs/fs-writeback.c\nindex 443f83382b9b..43a1381abde6 100644\n--- a/fs/fs-writeback.c\n+++ b/fs/fs-writeback.c\n@@ -1366,11 +1366,13 @@ static int move_expired_inodes(struct list_head *delaying_queue,\n \t\tinode = wb_inode(delaying_queue->prev);\n \t\tif (inode_dirtied_after(inode, dirtied_before))\n \t\t\tbreak;\n+\t\tihold(inode);  // Increment reference count\n \t\tspin_lock(&inode->i_lock);\n \t\tlist_move(&inode->i_io_list, &tmp);\n \t\tmoved++;\n \t\tinode->i_state |= I_SYNC_QUEUED;\n \t\tspin_unlock(&inode->i_lock);\n+\t\tiput(inode);  // Decrement reference count after use\n \t\tif (sb_is_blkdev_sb(inode->i_sb))\n \t\t\tcontinue;\n \t\tif (sb && sb != inode->i_sb)\n",
            "diff --git a/fs/fs-writeback.c b/fs/fs-writeback.c\nindex 443f83382b9b..5dd42aab3b0f 100644\n--- a/fs/fs-writeback.c\n+++ b/fs/fs-writeback.c\n@@ -1367,6 +1367,10 @@ static int move_expired_inodes(struct list_head *delaying_queue,\n \t\tif (inode_dirtied_after(inode, dirtied_before))\n \t\t\tbreak;\n \t\tspin_lock(&inode->i_lock);\n+\t\tif (inode->i_state & I_FREEING) {\n+\t\t\tspin_unlock(&inode->i_lock);\n+\t\t\tcontinue;\n+\t\t}\n \t\tlist_move(&inode->i_io_list, &tmp);\n \t\tmoved++;\n \t\tinode->i_state |= I_SYNC_QUEUED;\n",
            "diff --git a/fs/fs-writeback.c b/fs/fs-writeback.c\nindex 443f83382b9b..161238d48aea 100644\n--- a/fs/fs-writeback.c\n+++ b/fs/fs-writeback.c\n@@ -1364,13 +1364,18 @@ static int move_expired_inodes(struct list_head *delaying_queue,\n \n \twhile (!list_empty(delaying_queue)) {\n \t\tinode = wb_inode(delaying_queue->prev);\n-\t\tif (inode_dirtied_after(inode, dirtied_before))\n+\t\tif (!igrab(inode))  // Ensure inode is not freed\n+\t\t\tcontinue;\n+\t\tif (inode_dirtied_after(inode, dirtied_before)) {\n+\t\t\tiput(inode);  // Release reference if not moved\n \t\t\tbreak;\n+\t\t}\n \t\tspin_lock(&inode->i_lock);\n \t\tlist_move(&inode->i_io_list, &tmp);\n \t\tmoved++;\n \t\tinode->i_state |= I_SYNC_QUEUED;\n \t\tspin_unlock(&inode->i_lock);\n+\t\tiput(inode);  // Release reference after moving\n \t\tif (sb_is_blkdev_sb(inode->i_sb))\n \t\t\tcontinue;\n \t\tif (sb && sb != inode->i_sb)\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/fs-writeback.c b/fs/fs-writeback.c\nindex 443f83382b9b..29faa081d544 100644\n--- a/fs/fs-writeback.c\n+++ b/fs/fs-writeback.c\n@@ -1363,10 +1363,12 @@ static int move_expired_inodes(struct list_head *delaying_queue,\n \tint moved = 0;\n \n \twhile (!list_empty(delaying_queue)) {\n+\t\tspin_lock(&inode->i_lock);\n \t\tinode = wb_inode(delaying_queue->prev);\n-\t\tif (inode_dirtied_after(inode, dirtied_before))\n+\t\tif (inode_dirtied_after(inode, dirtied_before)) {\n+\t\t\tspin_unlock(&inode->i_lock);\n \t\t\tbreak;\n-\t\tspin_lock(&inode->i_lock);\n+\t\t}\n \t\tlist_move(&inode->i_io_list, &tmp);\n \t\tmoved++;\n \t\tinode->i_state |= I_SYNC_QUEUED;\n",
                "error_message": "Failed to set up instance"
            }
        ]
    },
    "a8afc55e6cd0cac79fd97a5c0d2272751dc558fc": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/media/platform/vim2m.c b/drivers/media/platform/vim2m.c\nindex 035c7b7c8d87..f8c833a96398 100644\n--- a/drivers/media/platform/vim2m.c\n+++ b/drivers/media/platform/vim2m.c\n@@ -806,7 +806,9 @@ static void vim2m_stop_streaming(struct vb2_queue *q)\n \tstruct vb2_v4l2_buffer *vbuf;\n \tunsigned long flags;\n \n+\tspin_lock_irqsave(&ctx->dev->irqlock, flags);\n \tflush_scheduled_work();\n+\tspin_unlock_irqrestore(&ctx->dev->irqlock, flags);\n \tfor (;;) {\n \t\tif (V4L2_TYPE_IS_OUTPUT(q->type))\n \t\t\tvbuf = v4l2_m2m_src_buf_remove(ctx->fh.m2m_ctx);\n@@ -816,7 +818,6 @@ static void vim2m_stop_streaming(struct vb2_queue *q)\n \t\t\treturn;\n \t\tv4l2_ctrl_request_complete(vbuf->vb2_buf.req_obj.req,\n \t\t\t\t\t   &ctx->hdl);\n-\t\tspin_lock_irqsave(&ctx->dev->irqlock, flags);\n \t\tv4l2_m2m_buf_done(vbuf, VB2_BUF_STATE_ERROR);\n \t\tspin_unlock_irqrestore(&ctx->dev->irqlock, flags);\n \t}\n",
            "diff --git a/drivers/media/platform/vim2m.c b/drivers/media/platform/vim2m.c\nindex 035c7b7c8d87..fb00a85302d1 100644\n--- a/drivers/media/platform/vim2m.c\n+++ b/drivers/media/platform/vim2m.c\n@@ -806,7 +806,7 @@ static void vim2m_stop_streaming(struct vb2_queue *q)\n \tstruct vb2_v4l2_buffer *vbuf;\n \tunsigned long flags;\n \n-\tflush_scheduled_work();\n+\tv4l2_m2m_ctx_release(ctx->fh.m2m_ctx);\n \tfor (;;) {\n \t\tif (V4L2_TYPE_IS_OUTPUT(q->type))\n \t\t\tvbuf = v4l2_m2m_src_buf_remove(ctx->fh.m2m_ctx);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex 2fcab61b8ff5..7b943e3aea4b 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -1461,7 +1461,8 @@ static int vb2_start_streaming(struct vb2_queue *q)\n \t * documentation in videobuf2-core.h for more information how buffers\n \t * should be returned to vb2 in start_streaming().\n \t */\n-\tif (WARN_ON(atomic_read(&q->owned_by_drv_count))) {\n+\tif (atomic_read(&q->owned_by_drv_count)) {\n+\t\tpr_warn(\"vb2: buffers not cleaned up properly in stop_streaming\\n\");\n \t\tunsigned i;\n \n \t\t/*\ndiff --git a/drivers/media/platform/vim2m.c b/drivers/media/platform/vim2m.c\nindex 035c7b7c8d87..039b6ef6f588 100644\n--- a/drivers/media/platform/vim2m.c\n+++ b/drivers/media/platform/vim2m.c\n@@ -806,7 +806,9 @@ static void vim2m_stop_streaming(struct vb2_queue *q)\n \tstruct vb2_v4l2_buffer *vbuf;\n \tunsigned long flags;\n \n-\tflush_scheduled_work();\n+\tif (!flush_scheduled_work_timeout(HZ * 10)) {\n+\t\tpr_warn(\"vim2m: flush_scheduled_work timeout\\n\");\n+\t}\n \tfor (;;) {\n \t\tif (V4L2_TYPE_IS_OUTPUT(q->type))\n \t\t\tvbuf = v4l2_m2m_src_buf_remove(ctx->fh.m2m_ctx);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/media/platform/vim2m.c b/drivers/media/platform/vim2m.c\nindex 035c7b7c8d87..33f56a335724 100644\n--- a/drivers/media/platform/vim2m.c\n+++ b/drivers/media/platform/vim2m.c\n@@ -806,17 +806,20 @@ static void vim2m_stop_streaming(struct vb2_queue *q)\n \tstruct vb2_v4l2_buffer *vbuf;\n \tunsigned long flags;\n \n-\tflush_scheduled_work();\n \tfor (;;) {\n \t\tif (V4L2_TYPE_IS_OUTPUT(q->type))\n \t\t\tvbuf = v4l2_m2m_src_buf_remove(ctx->fh.m2m_ctx);\n \t\telse\n \t\t\tvbuf = v4l2_m2m_dst_buf_remove(ctx->fh.m2m_ctx);\n \t\tif (vbuf == NULL)\n-\t\t\treturn;\n+\t\t\tbreak;\n \t\tv4l2_ctrl_request_complete(vbuf->vb2_buf.req_obj.req,\n \t\t\t\t\t   &ctx->hdl);\n \t\tspin_lock_irqsave(&ctx->dev->irqlock, flags);\n+\t\t// Additional buffer handling code here\n+\t\tspin_unlock_irqrestore(&ctx->dev->irqlock, flags);\n+\t}\n+\tflush_scheduled_work();\n \t\tv4l2_m2m_buf_done(vbuf, VB2_BUF_STATE_ERROR);\n \t\tspin_unlock_irqrestore(&ctx->dev->irqlock, flags);\n \t}\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/media/platform/vim2m.c b/drivers/media/platform/vim2m.c\nindex 035c7b7c8d87..5500f73ea5f3 100644\n--- a/drivers/media/platform/vim2m.c\n+++ b/drivers/media/platform/vim2m.c\n@@ -806,17 +806,18 @@ static void vim2m_stop_streaming(struct vb2_queue *q)\n \tstruct vb2_v4l2_buffer *vbuf;\n \tunsigned long flags;\n \n-\tflush_scheduled_work();\n \tfor (;;) {\n \t\tif (V4L2_TYPE_IS_OUTPUT(q->type))\n \t\t\tvbuf = v4l2_m2m_src_buf_remove(ctx->fh.m2m_ctx);\n \t\telse\n \t\t\tvbuf = v4l2_m2m_dst_buf_remove(ctx->fh.m2m_ctx);\n \t\tif (vbuf == NULL)\n-\t\t\treturn;\n+\t\t\tbreak;\n \t\tv4l2_ctrl_request_complete(vbuf->vb2_buf.req_obj.req,\n \t\t\t\t\t   &ctx->hdl);\n \t\tspin_lock_irqsave(&ctx->dev->irqlock, flags);\n+\t}\n+\tflush_scheduled_work();\n \t\tv4l2_m2m_buf_done(vbuf, VB2_BUF_STATE_ERROR);\n \t\tspin_unlock_irqrestore(&ctx->dev->irqlock, flags);\n \t}\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "b929091c762f0a3060a9941dcacfed0c3b4a903d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/can/j1939/socket.c b/net/can/j1939/socket.c\nindex 7e90f9e61d9b..2b3c9c2a0df7 100644\n--- a/net/can/j1939/socket.c\n+++ b/net/can/j1939/socket.c\n@@ -1078,12 +1078,14 @@ void j1939_sk_errqueue(struct j1939_session *session,\n \t}\n \n \t/* spread RX notifications to all sockets subscribed to this session */\n+\tspin_lock_bh(&priv->active_session_list_lock);\n \tspin_lock_bh(&priv->j1939_socks_lock);\n \tlist_for_each_entry(jsk, &priv->j1939_socks, list) {\n \t\tif (j1939_sk_recv_match_one(jsk, &session->skcb))\n \t\t\t__j1939_sk_errqueue(session, &jsk->sk, type);\n \t}\n \tspin_unlock_bh(&priv->j1939_socks_lock);\n+\tspin_unlock_bh(&priv->active_session_list_lock);\n };\n \n void j1939_sk_send_loop_abort(struct sock *sk, int err)\n",
            "diff --git a/net/can/j1939/socket.c b/net/can/j1939/socket.c\nindex 7e90f9e61d9b..2b3c9c2a0df7 100644\n--- a/net/can/j1939/socket.c\n+++ b/net/can/j1939/socket.c\n@@ -1078,12 +1078,14 @@ void j1939_sk_errqueue(struct j1939_session *session,\n \t}\n \n \t/* spread RX notifications to all sockets subscribed to this session */\n+\tspin_lock_bh(&priv->active_session_list_lock);\n \tspin_lock_bh(&priv->j1939_socks_lock);\n \tlist_for_each_entry(jsk, &priv->j1939_socks, list) {\n \t\tif (j1939_sk_recv_match_one(jsk, &session->skcb))\n \t\t\t__j1939_sk_errqueue(session, &jsk->sk, type);\n \t}\n \tspin_unlock_bh(&priv->j1939_socks_lock);\n+\tspin_unlock_bh(&priv->active_session_list_lock);\n };\n \n void j1939_sk_send_loop_abort(struct sock *sk, int err)\ndiff --git a/net/can/j1939/transport.c b/net/can/j1939/transport.c\nindex fce9b9ebf13f..9d658280d1a1 100644\n--- a/net/can/j1939/transport.c\n+++ b/net/can/j1939/transport.c\n@@ -1241,6 +1241,7 @@ static enum hrtimer_restart j1939_tp_rxtimer(struct hrtimer *hrtimer)\n \t\tsession->err = -ETIME;\n \t\tj1939_session_deactivate(session);\n \t} else {\n+\t\tspin_lock_bh(&session->priv->active_session_list_lock);\n \t\tj1939_session_list_lock(session->priv);\n \t\tif (session->state >= J1939_SESSION_ACTIVE &&\n \t\t    session->state < J1939_SESSION_ACTIVE_MAX) {\n@@ -1252,6 +1253,7 @@ static enum hrtimer_restart j1939_tp_rxtimer(struct hrtimer *hrtimer)\n \t\t\t\t      HRTIMER_MODE_REL_SOFT);\n \t\t\t__j1939_session_cancel(session, J1939_XTP_ABORT_TIMEOUT);\n \t\t}\n+\t\tspin_unlock_bh(&session->priv->active_session_list_lock);\n \t\tj1939_session_list_unlock(session->priv);\n \t}\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/can/j1939/socket.c b/net/can/j1939/socket.c\nindex 7e90f9e61d9b..d1f66240fb3f 100644\n--- a/net/can/j1939/socket.c\n+++ b/net/can/j1939/socket.c\n@@ -1078,12 +1078,14 @@ void j1939_sk_errqueue(struct j1939_session *session,\n \t}\n \n \t/* spread RX notifications to all sockets subscribed to this session */\n+\tj1939_session_list_lock(priv);\n \tspin_lock_bh(&priv->j1939_socks_lock);\n \tlist_for_each_entry(jsk, &priv->j1939_socks, list) {\n \t\tif (j1939_sk_recv_match_one(jsk, &session->skcb))\n \t\t\t__j1939_sk_errqueue(session, &jsk->sk, type);\n \t}\n \tspin_unlock_bh(&priv->j1939_socks_lock);\n+\tj1939_session_list_unlock(priv);\n };\n \n void j1939_sk_send_loop_abort(struct sock *sk, int err)\ndiff --git a/net/can/j1939/transport.c b/net/can/j1939/transport.c\nindex fce9b9ebf13f..c4cb40c2841a 100644\n--- a/net/can/j1939/transport.c\n+++ b/net/can/j1939/transport.c\n@@ -1241,6 +1241,7 @@ static enum hrtimer_restart j1939_tp_rxtimer(struct hrtimer *hrtimer)\n \t\tsession->err = -ETIME;\n \t\tj1939_session_deactivate(session);\n \t} else {\n+\t\tspin_lock_bh(&priv->j1939_socks_lock);\n \t\tj1939_session_list_lock(session->priv);\n \t\tif (session->state >= J1939_SESSION_ACTIVE &&\n \t\t    session->state < J1939_SESSION_ACTIVE_MAX) {\n@@ -1253,6 +1254,8 @@ static enum hrtimer_restart j1939_tp_rxtimer(struct hrtimer *hrtimer)\n \t\t\t__j1939_session_cancel(session, J1939_XTP_ABORT_TIMEOUT);\n \t\t}\n \t\tj1939_session_list_unlock(session->priv);\n+\t\tspin_unlock_bh(&priv->j1939_socks_lock);\n+\t\tj1939_session_list_unlock(session->priv);\n \t}\n \n \tj1939_session_put(session);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/can/j1939/socket.c b/net/can/j1939/socket.c\nindex 7e90f9e61d9b..d1f66240fb3f 100644\n--- a/net/can/j1939/socket.c\n+++ b/net/can/j1939/socket.c\n@@ -1078,12 +1078,14 @@ void j1939_sk_errqueue(struct j1939_session *session,\n \t}\n \n \t/* spread RX notifications to all sockets subscribed to this session */\n+\tj1939_session_list_lock(priv);\n \tspin_lock_bh(&priv->j1939_socks_lock);\n \tlist_for_each_entry(jsk, &priv->j1939_socks, list) {\n \t\tif (j1939_sk_recv_match_one(jsk, &session->skcb))\n \t\t\t__j1939_sk_errqueue(session, &jsk->sk, type);\n \t}\n \tspin_unlock_bh(&priv->j1939_socks_lock);\n+\tj1939_session_list_unlock(priv);\n };\n \n void j1939_sk_send_loop_abort(struct sock *sk, int err)\ndiff --git a/net/can/j1939/transport.c b/net/can/j1939/transport.c\nindex fce9b9ebf13f..db60b18105a6 100644\n--- a/net/can/j1939/transport.c\n+++ b/net/can/j1939/transport.c\n@@ -1241,9 +1241,9 @@ static enum hrtimer_restart j1939_tp_rxtimer(struct hrtimer *hrtimer)\n \t\tsession->err = -ETIME;\n \t\tj1939_session_deactivate(session);\n \t} else {\n-\t\tj1939_session_list_lock(session->priv);\n \t\tif (session->state >= J1939_SESSION_ACTIVE &&\n \t\t    session->state < J1939_SESSION_ACTIVE_MAX) {\n+\t\t\tj1939_session_list_lock(session->priv);\n \t\t\tnetdev_alert(priv->ndev, \"%s: 0x%p: rx timeout, send abort\\n\",\n \t\t\t\t     __func__, session);\n \t\t\tj1939_session_get(session);\n@@ -1251,6 +1251,7 @@ static enum hrtimer_restart j1939_tp_rxtimer(struct hrtimer *hrtimer)\n \t\t\t\t      ms_to_ktime(J1939_XTP_ABORT_TIMEOUT_MS),\n \t\t\t\t      HRTIMER_MODE_REL_SOFT);\n \t\t\t__j1939_session_cancel(session, J1939_XTP_ABORT_TIMEOUT);\n+\t\t\tj1939_session_list_unlock(session->priv);\n \t\t}\n \t\tj1939_session_list_unlock(session->priv);\n \t}\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/can/j1939/socket.c b/net/can/j1939/socket.c\nindex 7e90f9e61d9b..d1f66240fb3f 100644\n--- a/net/can/j1939/socket.c\n+++ b/net/can/j1939/socket.c\n@@ -1078,12 +1078,14 @@ void j1939_sk_errqueue(struct j1939_session *session,\n \t}\n \n \t/* spread RX notifications to all sockets subscribed to this session */\n+\tj1939_session_list_lock(priv);\n \tspin_lock_bh(&priv->j1939_socks_lock);\n \tlist_for_each_entry(jsk, &priv->j1939_socks, list) {\n \t\tif (j1939_sk_recv_match_one(jsk, &session->skcb))\n \t\t\t__j1939_sk_errqueue(session, &jsk->sk, type);\n \t}\n \tspin_unlock_bh(&priv->j1939_socks_lock);\n+\tj1939_session_list_unlock(priv);\n };\n \n void j1939_sk_send_loop_abort(struct sock *sk, int err)\ndiff --git a/net/can/j1939/transport.c b/net/can/j1939/transport.c\nindex fce9b9ebf13f..71bb66b29d42 100644\n--- a/net/can/j1939/transport.c\n+++ b/net/can/j1939/transport.c\n@@ -1241,6 +1241,7 @@ static enum hrtimer_restart j1939_tp_rxtimer(struct hrtimer *hrtimer)\n \t\tsession->err = -ETIME;\n \t\tj1939_session_deactivate(session);\n \t} else {\n+\t\tspin_lock_bh(&session->priv->j1939_socks_lock);\n \t\tj1939_session_list_lock(session->priv);\n \t\tif (session->state >= J1939_SESSION_ACTIVE &&\n \t\t    session->state < J1939_SESSION_ACTIVE_MAX) {\n@@ -1253,6 +1254,8 @@ static enum hrtimer_restart j1939_tp_rxtimer(struct hrtimer *hrtimer)\n \t\t\t__j1939_session_cancel(session, J1939_XTP_ABORT_TIMEOUT);\n \t\t}\n \t\tj1939_session_list_unlock(session->priv);\n+\t\tspin_unlock_bh(&session->priv->j1939_socks_lock);\n+\t\tj1939_session_list_unlock(session->priv);\n \t}\n \n \tj1939_session_put(session);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "e58343393efd3e0657ca37cf4466fc38d1f4d4df": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/dma-buf/udmabuf.c b/drivers/dma-buf/udmabuf.c\nindex 38e8767ec371..ddffaba212cd 100644\n--- a/drivers/dma-buf/udmabuf.c\n+++ b/drivers/dma-buf/udmabuf.c\n@@ -107,11 +107,14 @@ static void unmap_udmabuf(struct dma_buf_attachment *at,\n static void release_udmabuf(struct dma_buf *buf)\n {\n \tstruct udmabuf *ubuf = buf->priv;\n-\tstruct device *dev = ubuf->device->this_device;\n+\tstruct device *dev;\n \tpgoff_t pg;\n \n-\tif (ubuf->sg)\n-\t\tput_sg_table(dev, ubuf->sg, DMA_BIDIRECTIONAL);\n+\tif (ubuf->device && ubuf->device->this_device) {\n+\t\tdev = ubuf->device->this_device;\n+\t\tif (ubuf->sg)\n+\t\t\tput_sg_table(dev, ubuf->sg, DMA_BIDIRECTIONAL);\n+\t}\n \n \tfor (pg = 0; pg < ubuf->pagecount; pg++)\n \t\tput_page(ubuf->pages[pg]);\n",
            "diff --git a/drivers/dma-buf/udmabuf.c b/drivers/dma-buf/udmabuf.c\nindex 38e8767ec371..ba894a4464a9 100644\n--- a/drivers/dma-buf/udmabuf.c\n+++ b/drivers/dma-buf/udmabuf.c\n@@ -107,11 +107,14 @@ static void unmap_udmabuf(struct dma_buf_attachment *at,\n static void release_udmabuf(struct dma_buf *buf)\n {\n \tstruct udmabuf *ubuf = buf->priv;\n-\tstruct device *dev = ubuf->device->this_device;\n+\tstruct device *dev;\n \tpgoff_t pg;\n \n-\tif (ubuf->sg)\n-\t\tput_sg_table(dev, ubuf->sg, DMA_BIDIRECTIONAL);\n+\tif (ubuf->device) {\n+\t\tdev = ubuf->device->this_device;\n+\t\tif (ubuf->sg)\n+\t\t\tput_sg_table(dev, ubuf->sg, DMA_BIDIRECTIONAL);\n+\t}\n \n \tfor (pg = 0; pg < ubuf->pagecount; pg++)\n \t\tput_page(ubuf->pages[pg]);\n",
            "diff --git a/drivers/dma-buf/udmabuf.c b/drivers/dma-buf/udmabuf.c\nindex 38e8767ec371..3ba0e6a20128 100644\n--- a/drivers/dma-buf/udmabuf.c\n+++ b/drivers/dma-buf/udmabuf.c\n@@ -110,8 +110,10 @@ static void release_udmabuf(struct dma_buf *buf)\n \tstruct device *dev = ubuf->device->this_device;\n \tpgoff_t pg;\n \n-\tif (ubuf->sg)\n+\tif (ubuf->sg) {\n \t\tput_sg_table(dev, ubuf->sg, DMA_BIDIRECTIONAL);\n+\t\tubuf->sg = NULL; // Ensure sg is set to NULL after freeing\n+\t}\n \n \tfor (pg = 0; pg < ubuf->pagecount; pg++)\n \t\tput_page(ubuf->pages[pg]);\n",
            "diff --git a/drivers/dma-buf/udmabuf.c b/drivers/dma-buf/udmabuf.c\nindex 38e8767ec371..2d7c92f6b008 100644\n--- a/drivers/dma-buf/udmabuf.c\n+++ b/drivers/dma-buf/udmabuf.c\n@@ -110,7 +110,7 @@ static void release_udmabuf(struct dma_buf *buf)\n \tstruct device *dev = ubuf->device->this_device;\n \tpgoff_t pg;\n \n-\tif (ubuf->sg)\n+\tif (ubuf->sg != NULL)\n \t\tput_sg_table(dev, ubuf->sg, DMA_BIDIRECTIONAL);\n \n \tfor (pg = 0; pg < ubuf->pagecount; pg++)\n",
            "diff --git a/drivers/dma-buf/udmabuf.c b/drivers/dma-buf/udmabuf.c\nindex 38e8767ec371..ddffaba212cd 100644\n--- a/drivers/dma-buf/udmabuf.c\n+++ b/drivers/dma-buf/udmabuf.c\n@@ -107,11 +107,14 @@ static void unmap_udmabuf(struct dma_buf_attachment *at,\n static void release_udmabuf(struct dma_buf *buf)\n {\n \tstruct udmabuf *ubuf = buf->priv;\n-\tstruct device *dev = ubuf->device->this_device;\n+\tstruct device *dev;\n \tpgoff_t pg;\n \n-\tif (ubuf->sg)\n-\t\tput_sg_table(dev, ubuf->sg, DMA_BIDIRECTIONAL);\n+\tif (ubuf->device && ubuf->device->this_device) {\n+\t\tdev = ubuf->device->this_device;\n+\t\tif (ubuf->sg)\n+\t\t\tput_sg_table(dev, ubuf->sg, DMA_BIDIRECTIONAL);\n+\t}\n \n \tfor (pg = 0; pg < ubuf->pagecount; pg++)\n \t\tput_page(ubuf->pages[pg]);\n"
        ],
        "error": []
    },
    "67d5dc5f84651b05fc3c2cb3d163037f414a10f4": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/qrtr/tun.c b/net/qrtr/tun.c\nindex 15ce9b642b25..0bbe2ee78c1e 100644\n--- a/net/qrtr/tun.c\n+++ b/net/qrtr/tun.c\n@@ -80,6 +80,9 @@ static ssize_t qrtr_tun_write_iter(struct kiocb *iocb, struct iov_iter *from)\n \tssize_t ret;\n \tvoid *kbuf;\n \n+\tif (len > MAX_KBUF_SIZE)\n+\t\treturn -EINVAL;\n+\n \tkbuf = kzalloc(len, GFP_KERNEL);\n \tif (!kbuf)\n \t\treturn -ENOMEM;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/qrtr/tun.c b/net/qrtr/tun.c\nindex 15ce9b642b25..a2e82948e68b 100644\n--- a/net/qrtr/tun.c\n+++ b/net/qrtr/tun.c\n@@ -80,6 +80,9 @@ static ssize_t qrtr_tun_write_iter(struct kiocb *iocb, struct iov_iter *from)\n \tssize_t ret;\n \tvoid *kbuf;\n \n+\tif (len > MAX_ALLOWED_LENGTH)\n+\t\treturn -EINVAL;\n+\n \tkbuf = kzalloc(len, GFP_KERNEL);\n \tif (!kbuf)\n \t\treturn -ENOMEM;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/qrtr/tun.c b/net/qrtr/tun.c\nindex 15ce9b642b25..0bbe2ee78c1e 100644\n--- a/net/qrtr/tun.c\n+++ b/net/qrtr/tun.c\n@@ -80,6 +80,9 @@ static ssize_t qrtr_tun_write_iter(struct kiocb *iocb, struct iov_iter *from)\n \tssize_t ret;\n \tvoid *kbuf;\n \n+\tif (len > MAX_KBUF_SIZE)\n+\t\treturn -EINVAL;\n+\n \tkbuf = kzalloc(len, GFP_KERNEL);\n \tif (!kbuf)\n \t\treturn -ENOMEM;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/qrtr/tun.c b/net/qrtr/tun.c\nindex 15ce9b642b25..205007c25277 100644\n--- a/net/qrtr/tun.c\n+++ b/net/qrtr/tun.c\n@@ -80,6 +80,9 @@ static ssize_t qrtr_tun_write_iter(struct kiocb *iocb, struct iov_iter *from)\n \tssize_t ret;\n \tvoid *kbuf;\n \n+\tif (len > MAX_ALLOWED_SIZE)  // Define a reasonable maximum size\n+\t\treturn -EINVAL;\n+\n \tkbuf = kzalloc(len, GFP_KERNEL);\n \tif (!kbuf)\n \t\treturn -ENOMEM;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/qrtr/tun.c b/net/qrtr/tun.c\nindex 15ce9b642b25..c13c0514e4ee 100644\n--- a/net/qrtr/tun.c\n+++ b/net/qrtr/tun.c\n@@ -80,6 +80,10 @@ static ssize_t qrtr_tun_write_iter(struct kiocb *iocb, struct iov_iter *from)\n \tssize_t ret;\n \tvoid *kbuf;\n \n+\tif (len > MAX_ALLOWED_LEN) {\n+\t\treturn -EINVAL;\n+\t}\n+\n \tkbuf = kzalloc(len, GFP_KERNEL);\n \tif (!kbuf)\n \t\treturn -ENOMEM;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "64bdab02654a9c43c1009be0bd3d7e992ba2eab2": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/core/devlink.c b/net/core/devlink.c\nindex 2cafbc808b09..8a9112639c17 100644\n--- a/net/core/devlink.c\n+++ b/net/core/devlink.c\n@@ -130,6 +130,8 @@ static struct devlink *devlink_get_from_attrs(struct net *net,\n \tlockdep_assert_held(&devlink_mutex);\n \n \tlist_for_each_entry(devlink, &devlink_list, list) {\n+\t\tif (!devlink->dev || !devlink->dev->bus)\n+\t\t\tcontinue;\n \t\tif (strcmp(devlink->dev->bus->name, busname) == 0 &&\n \t\t    strcmp(dev_name(devlink->dev), devname) == 0 &&\n \t\t    net_eq(devlink_net(devlink), net))\n",
            "diff --git a/net/core/devlink.c b/net/core/devlink.c\nindex 2cafbc808b09..1073f2aee5bf 100644\n--- a/net/core/devlink.c\n+++ b/net/core/devlink.c\n@@ -130,6 +130,8 @@ static struct devlink *devlink_get_from_attrs(struct net *net,\n \tlockdep_assert_held(&devlink_mutex);\n \n \tlist_for_each_entry(devlink, &devlink_list, list) {\n+\t\tif (!devlink || !devlink->dev || !devlink->dev->bus)\n+\t\t\tcontinue;\n \t\tif (strcmp(devlink->dev->bus->name, busname) == 0 &&\n \t\t    strcmp(dev_name(devlink->dev), devname) == 0 &&\n \t\t    net_eq(devlink_net(devlink), net))\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/core/devlink.c b/net/core/devlink.c\nindex 2cafbc808b09..59628fbf9e7a 100644\n--- a/net/core/devlink.c\n+++ b/net/core/devlink.c\n@@ -132,8 +132,10 @@ static struct devlink *devlink_get_from_attrs(struct net *net,\n \tlist_for_each_entry(devlink, &devlink_list, list) {\n \t\tif (strcmp(devlink->dev->bus->name, busname) == 0 &&\n \t\t    strcmp(dev_name(devlink->dev), devname) == 0 &&\n-\t\t    net_eq(devlink_net(devlink), net))\n+\t\t    net_eq(devlink_net(devlink), net)) {\n+\t\t\tdevlink_get(devlink); // Increment reference count\n \t\t\treturn devlink;\n+\t\t}\n \t}\n \n \treturn ERR_PTR(-ENODEV);\n@@ -433,6 +435,7 @@ static int devlink_nl_pre_doit(const struct genl_ops *ops,\n unlock:\n \tif (~ops->internal_flags & DEVLINK_NL_FLAG_NO_LOCK)\n \t\tmutex_unlock(&devlink->lock);\n+\tdevlink_put(devlink); // Decrement reference count\n \tmutex_unlock(&devlink_mutex);\n \treturn err;\n }\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/core/devlink.c b/net/core/devlink.c\nindex 2cafbc808b09..59628fbf9e7a 100644\n--- a/net/core/devlink.c\n+++ b/net/core/devlink.c\n@@ -132,8 +132,10 @@ static struct devlink *devlink_get_from_attrs(struct net *net,\n \tlist_for_each_entry(devlink, &devlink_list, list) {\n \t\tif (strcmp(devlink->dev->bus->name, busname) == 0 &&\n \t\t    strcmp(dev_name(devlink->dev), devname) == 0 &&\n-\t\t    net_eq(devlink_net(devlink), net))\n+\t\t    net_eq(devlink_net(devlink), net)) {\n+\t\t\tdevlink_get(devlink); // Increment reference count\n \t\t\treturn devlink;\n+\t\t}\n \t}\n \n \treturn ERR_PTR(-ENODEV);\n@@ -433,6 +435,7 @@ static int devlink_nl_pre_doit(const struct genl_ops *ops,\n unlock:\n \tif (~ops->internal_flags & DEVLINK_NL_FLAG_NO_LOCK)\n \t\tmutex_unlock(&devlink->lock);\n+\tdevlink_put(devlink); // Decrement reference count\n \tmutex_unlock(&devlink_mutex);\n \treturn err;\n }\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/core/devlink.c b/net/core/devlink.c\nindex 2cafbc808b09..59628fbf9e7a 100644\n--- a/net/core/devlink.c\n+++ b/net/core/devlink.c\n@@ -132,8 +132,10 @@ static struct devlink *devlink_get_from_attrs(struct net *net,\n \tlist_for_each_entry(devlink, &devlink_list, list) {\n \t\tif (strcmp(devlink->dev->bus->name, busname) == 0 &&\n \t\t    strcmp(dev_name(devlink->dev), devname) == 0 &&\n-\t\t    net_eq(devlink_net(devlink), net))\n+\t\t    net_eq(devlink_net(devlink), net)) {\n+\t\t\tdevlink_get(devlink); // Increment reference count\n \t\t\treturn devlink;\n+\t\t}\n \t}\n \n \treturn ERR_PTR(-ENODEV);\n@@ -433,6 +435,7 @@ static int devlink_nl_pre_doit(const struct genl_ops *ops,\n unlock:\n \tif (~ops->internal_flags & DEVLINK_NL_FLAG_NO_LOCK)\n \t\tmutex_unlock(&devlink->lock);\n+\tdevlink_put(devlink); // Decrement reference count\n \tmutex_unlock(&devlink_mutex);\n \treturn err;\n }\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "5e2e50e2c145ca06459e9e0900c20eefd1a0877e": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/9p/client.c b/net/9p/client.c\nindex aaa37b07e30a..8cbf57778e67 100644\n--- a/net/9p/client.c\n+++ b/net/9p/client.c\n@@ -720,8 +720,12 @@ p9_client_rpc(struct p9_client *c, int8_t type, const char *fmt, ...)\n \t\tsigpending = 1;\n \t\tclear_thread_flag(TIF_SIGPENDING);\n \n-\t\tif (c->trans_mod->cancel(c, req))\n+\t\tif (c->trans_mod->cancel(c, req)) {\n+\t\t\t/* Ensure the request is not already removed from the list */\n+\t\t\tif (!list_empty(&req->req_list))\n+\t\t\t\tlist_del(&req->req_list);\n \t\t\tp9_client_flush(c, req);\n+\t\t}\n \n \t\t/* if we received the response anyway, don't signal error */\n \t\tif (req->status == REQ_STATUS_RCVD)\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/9p/client.c b/net/9p/client.c\nindex aaa37b07e30a..1be6392b8194 100644\n--- a/net/9p/client.c\n+++ b/net/9p/client.c\n@@ -720,8 +720,11 @@ p9_client_rpc(struct p9_client *c, int8_t type, const char *fmt, ...)\n \t\tsigpending = 1;\n \t\tclear_thread_flag(TIF_SIGPENDING);\n \n-\t\tif (c->trans_mod->cancel(c, req))\n+\t\tif (c->trans_mod->cancel(c, req)) {\n+\t\t\tif (!list_empty(&req->list))\n+\t\t\t\tlist_del(&req->list);\n \t\t\tp9_client_flush(c, req);\n+\t\t}\n \n \t\t/* if we received the response anyway, don't signal error */\n \t\tif (req->status == REQ_STATUS_RCVD)\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "212130bd8af05df1d923b02f9a71db6e8208e40d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/block/bdev.c b/block/bdev.c\nindex 7bf88e591aaf..d55bca904e8a 100644\n--- a/block/bdev.c\n+++ b/block/bdev.c\n@@ -902,7 +902,6 @@ void blkdev_put(struct block_device *bdev, fmode_t mode)\n \tif (atomic_read(&bdev->bd_openers) == 1)\n \t\tsync_blockdev(bdev);\n \n-\tmutex_lock(&disk->open_mutex);\n \tif (mode & FMODE_EXCL) {\n \t\tstruct block_device *whole = bdev_whole(bdev);\n \t\tbool bdev_free;\n@@ -913,6 +912,7 @@ void blkdev_put(struct block_device *bdev, fmode_t mode)\n \t\t * synchronize disk_holder unlinking.\n \t\t */\n \t\tspin_lock(&bdev_lock);\n+\t\tmutex_lock(&disk->open_mutex);\n \n \t\tWARN_ON_ONCE(--bdev->bd_holders < 0);\n \t\tWARN_ON_ONCE(--whole->bd_holders < 0);\ndiff --git a/drivers/block/loop.c b/drivers/block/loop.c\nindex 204558d7a81d..a5ac81161fb6 100644\n--- a/drivers/block/loop.c\n+++ b/drivers/block/loop.c\n@@ -1143,10 +1143,6 @@ static void __loop_clr_fd(struct loop_device *lo, bool release)\n \tif (!release)\n \t\tblk_mq_freeze_queue(lo->lo_queue);\n \n-\tdestroy_workqueue(lo->workqueue);\n-\tloop_free_idle_workers(lo, true);\n-\tdel_timer_sync(&lo->timer);\n-\n \tspin_lock_irq(&lo->lo_lock);\n \tfilp = lo->lo_backing_file;\n \tlo->lo_backing_file = NULL;\n@@ -1154,6 +1150,10 @@ static void __loop_clr_fd(struct loop_device *lo, bool release)\n \n \tlo->lo_device = NULL;\n \tlo->lo_offset = 0;\n+\n+\tdestroy_workqueue(lo->workqueue);\n+\tloop_free_idle_workers(lo, true);\n+\tdel_timer_sync(&lo->timer);\n \tlo->lo_sizelimit = 0;\n \tmemset(lo->lo_file_name, 0, LO_NAME_SIZE);\n \tblk_queue_logical_block_size(lo->lo_queue, 512);\n"
        ],
        "error": []
    },
    "5eb8a5d29d77f8a364cf3270bf9625eb4d4ffc52": {
        "non_crash": [
            "diff --git a/fs/jfs/jfs_dmap.c b/fs/jfs/jfs_dmap.c\nindex 765838578a72..f18a97f2bc38 100644\n--- a/fs/jfs/jfs_dmap.c\n+++ b/fs/jfs/jfs_dmap.c\n@@ -193,12 +193,12 @@ int dbMount(struct inode *ipbmap)\n \tbmp->db_agwidth = le32_to_cpu(dbmp_le->dn_agwidth);\n \tbmp->db_agstart = le32_to_cpu(dbmp_le->dn_agstart);\n \tbmp->db_agl2size = le32_to_cpu(dbmp_le->dn_agl2size);\n-\tif (bmp->db_agl2size > L2MAXL2SIZE - L2MAXAG) {\n+\tif (bmp->db_agl2size < 0 || bmp->db_agl2size > L2MAXL2SIZE - L2MAXAG) {\n \t\terr = -EINVAL;\n \t\tgoto err_release_metapage;\n \t}\n \n-\tif (((bmp->db_mapsize - 1) >> bmp->db_agl2size) > MAXAG) {\n+\tif (bmp->db_agl2size >= 0 && ((bmp->db_mapsize - 1) >> bmp->db_agl2size) > MAXAG) {\n \t\terr = -EINVAL;\n \t\tgoto err_release_metapage;\n \t}\n",
            "diff --git a/fs/jfs/jfs_dmap.c b/fs/jfs/jfs_dmap.c\nindex 765838578a72..ec856a4fb01e 100644\n--- a/fs/jfs/jfs_dmap.c\n+++ b/fs/jfs/jfs_dmap.c\n@@ -198,7 +198,7 @@ int dbMount(struct inode *ipbmap)\n \t\tgoto err_release_metapage;\n \t}\n \n-\tif (((bmp->db_mapsize - 1) >> bmp->db_agl2size) > MAXAG) {\n+\tif (bmp->db_agl2size < 0 || ((bmp->db_mapsize - 1) >> bmp->db_agl2size) > MAXAG) {\n \t\terr = -EINVAL;\n \t\tgoto err_release_metapage;\n \t}\n",
            "diff --git a/fs/jfs/jfs_dmap.c b/fs/jfs/jfs_dmap.c\nindex 765838578a72..f18a97f2bc38 100644\n--- a/fs/jfs/jfs_dmap.c\n+++ b/fs/jfs/jfs_dmap.c\n@@ -193,12 +193,12 @@ int dbMount(struct inode *ipbmap)\n \tbmp->db_agwidth = le32_to_cpu(dbmp_le->dn_agwidth);\n \tbmp->db_agstart = le32_to_cpu(dbmp_le->dn_agstart);\n \tbmp->db_agl2size = le32_to_cpu(dbmp_le->dn_agl2size);\n-\tif (bmp->db_agl2size > L2MAXL2SIZE - L2MAXAG) {\n+\tif (bmp->db_agl2size < 0 || bmp->db_agl2size > L2MAXL2SIZE - L2MAXAG) {\n \t\terr = -EINVAL;\n \t\tgoto err_release_metapage;\n \t}\n \n-\tif (((bmp->db_mapsize - 1) >> bmp->db_agl2size) > MAXAG) {\n+\tif (bmp->db_agl2size >= 0 && ((bmp->db_mapsize - 1) >> bmp->db_agl2size) > MAXAG) {\n \t\terr = -EINVAL;\n \t\tgoto err_release_metapage;\n \t}\n",
            "diff --git a/fs/jfs/jfs_dmap.c b/fs/jfs/jfs_dmap.c\nindex 765838578a72..8bc85feafa43 100644\n--- a/fs/jfs/jfs_dmap.c\n+++ b/fs/jfs/jfs_dmap.c\n@@ -193,12 +193,12 @@ int dbMount(struct inode *ipbmap)\n \tbmp->db_agwidth = le32_to_cpu(dbmp_le->dn_agwidth);\n \tbmp->db_agstart = le32_to_cpu(dbmp_le->dn_agstart);\n \tbmp->db_agl2size = le32_to_cpu(dbmp_le->dn_agl2size);\n-\tif (bmp->db_agl2size > L2MAXL2SIZE - L2MAXAG) {\n+\tif (bmp->db_agl2size < 0 || bmp->db_agl2size > L2MAXL2SIZE - L2MAXAG) {\n \t\terr = -EINVAL;\n \t\tgoto err_release_metapage;\n \t}\n \n-\tif (((bmp->db_mapsize - 1) >> bmp->db_agl2size) > MAXAG) {\n+\tif (bmp->db_mapsize <= 0 || bmp->db_agl2size < 0 || ((bmp->db_mapsize - 1) >> bmp->db_agl2size) > MAXAG) {\n \t\terr = -EINVAL;\n \t\tgoto err_release_metapage;\n \t}\n",
            "diff --git a/fs/jfs/jfs_dmap.c b/fs/jfs/jfs_dmap.c\nindex 765838578a72..f18a97f2bc38 100644\n--- a/fs/jfs/jfs_dmap.c\n+++ b/fs/jfs/jfs_dmap.c\n@@ -193,12 +193,12 @@ int dbMount(struct inode *ipbmap)\n \tbmp->db_agwidth = le32_to_cpu(dbmp_le->dn_agwidth);\n \tbmp->db_agstart = le32_to_cpu(dbmp_le->dn_agstart);\n \tbmp->db_agl2size = le32_to_cpu(dbmp_le->dn_agl2size);\n-\tif (bmp->db_agl2size > L2MAXL2SIZE - L2MAXAG) {\n+\tif (bmp->db_agl2size < 0 || bmp->db_agl2size > L2MAXL2SIZE - L2MAXAG) {\n \t\terr = -EINVAL;\n \t\tgoto err_release_metapage;\n \t}\n \n-\tif (((bmp->db_mapsize - 1) >> bmp->db_agl2size) > MAXAG) {\n+\tif (bmp->db_agl2size >= 0 && ((bmp->db_mapsize - 1) >> bmp->db_agl2size) > MAXAG) {\n \t\terr = -EINVAL;\n \t\tgoto err_release_metapage;\n \t}\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "59174b68c3c9d5d3ecc323e0b0a0c5466b0e7d18": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/sufile.c b/fs/nilfs2/sufile.c\nindex dc359b56fdfa..e450c65e7b2d 100644\n--- a/fs/nilfs2/sufile.c\n+++ b/fs/nilfs2/sufile.c\n@@ -269,15 +269,15 @@ int nilfs_sufile_set_alloc_range(struct inode *sufile, __u64 start, __u64 end)\n \t__u64 nsegs;\n \tint ret = -ERANGE;\n \n-\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n \tnsegs = nilfs_sufile_get_nsegments(sufile);\n \n \tif (start <= end && end < nsegs) {\n+\t\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n \t\tsui->allocmin = start;\n \t\tsui->allocmax = end;\n \t\tret = 0;\n+\t\tup_write(&NILFS_MDT(sufile)->mi_sem);\n \t}\n-\tup_write(&NILFS_MDT(sufile)->mi_sem);\n \treturn ret;\n }\n \n",
            "diff --git a/fs/nilfs2/sufile.c b/fs/nilfs2/sufile.c\nindex dc359b56fdfa..c14f557ec730 100644\n--- a/fs/nilfs2/sufile.c\n+++ b/fs/nilfs2/sufile.c\n@@ -269,9 +269,9 @@ int nilfs_sufile_set_alloc_range(struct inode *sufile, __u64 start, __u64 end)\n \t__u64 nsegs;\n \tint ret = -ERANGE;\n \n-\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n \tnsegs = nilfs_sufile_get_nsegments(sufile);\n \n+\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n \tif (start <= end && end < nsegs) {\n \t\tsui->allocmin = start;\n \t\tsui->allocmax = end;\ndiff --git a/fs/nilfs2/super.c b/fs/nilfs2/super.c\nindex 6edb6e0dd61f..514186036d99 100644\n--- a/fs/nilfs2/super.c\n+++ b/fs/nilfs2/super.c\n@@ -413,12 +413,11 @@ int nilfs_resize_fs(struct super_block *sb, __u64 newsize)\n \t * on the number of segments, the number of reserved segments,\n \t * and so forth.\n \t */\n-\tdown_write(&nilfs->ns_segctor_sem);\n-\n \tsb2off = NILFS_SB2_OFFSET_BYTES(newsize);\n \tnewnsegs = sb2off >> nilfs->ns_blocksize_bits;\n \tdo_div(newnsegs, nilfs->ns_blocks_per_segment);\n \n+\tdown_write(&nilfs->ns_segctor_sem);\n \tret = nilfs_sufile_resize(nilfs->ns_sufile, newnsegs);\n \tup_write(&nilfs->ns_segctor_sem);\n \tif (ret < 0)\n",
            "diff --git a/fs/nilfs2/sufile.c b/fs/nilfs2/sufile.c\nindex dc359b56fdfa..dadc5ecc2bfa 100644\n--- a/fs/nilfs2/sufile.c\n+++ b/fs/nilfs2/sufile.c\n@@ -269,15 +269,15 @@ int nilfs_sufile_set_alloc_range(struct inode *sufile, __u64 start, __u64 end)\n \t__u64 nsegs;\n \tint ret = -ERANGE;\n \n-\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n \tnsegs = nilfs_sufile_get_nsegments(sufile);\n \n \tif (start <= end && end < nsegs) {\n+\t\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n \t\tsui->allocmin = start;\n \t\tsui->allocmax = end;\n+\t\tup_write(&NILFS_MDT(sufile)->mi_sem);\n \t\tret = 0;\n \t}\n-\tup_write(&NILFS_MDT(sufile)->mi_sem);\n \treturn ret;\n }\n \n",
            "diff --git a/fs/nilfs2/sufile.c b/fs/nilfs2/sufile.c\nindex dc359b56fdfa..a64f06b58faf 100644\n--- a/fs/nilfs2/sufile.c\n+++ b/fs/nilfs2/sufile.c\n@@ -269,15 +269,19 @@ int nilfs_sufile_set_alloc_range(struct inode *sufile, __u64 start, __u64 end)\n \t__u64 nsegs;\n \tint ret = -ERANGE;\n \n-\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n-\tnsegs = nilfs_sufile_get_nsegments(sufile);\n+\tif (down_write_trylock(&NILFS_MDT(sufile)->mi_sem)) {\n+\t\tnsegs = nilfs_sufile_get_nsegments(sufile);\n \n-\tif (start <= end && end < nsegs) {\n-\t\tsui->allocmin = start;\n-\t\tsui->allocmax = end;\n-\t\tret = 0;\n+\t\tif (start <= end && end < nsegs) {\n+\t\t\tsui->allocmin = start;\n+\t\t\tsui->allocmax = end;\n+\t\t\tret = 0;\n+\t\t}\n+\t\tup_write(&NILFS_MDT(sufile)->mi_sem);\n+\t} else {\n+\t\t// Handle the case where the lock is already held\n+\t\tret = -EAGAIN;\n \t}\n-\tup_write(&NILFS_MDT(sufile)->mi_sem);\n \treturn ret;\n }\n \n",
            "diff --git a/fs/nilfs2/super.c b/fs/nilfs2/super.c\nindex 6edb6e0dd61f..86325d93b9ac 100644\n--- a/fs/nilfs2/super.c\n+++ b/fs/nilfs2/super.c\n@@ -414,6 +414,13 @@ int nilfs_resize_fs(struct super_block *sb, __u64 newsize)\n \t * and so forth.\n \t */\n \tdown_write(&nilfs->ns_segctor_sem);\n+\t// Ensure no deadlock with mi_sem\n+\tif (down_write_trylock(&NILFS_MDT(nilfs->ns_sufile)->mi_sem)) {\n+\t\tup_write(&NILFS_MDT(nilfs->ns_sufile)->mi_sem);\n+\t} else {\n+\t\tup_write(&nilfs->ns_segctor_sem);\n+\t\treturn -EDEADLK;\n+\t}\n \n \tsb2off = NILFS_SB2_OFFSET_BYTES(newsize);\n \tnewnsegs = sb2off >> nilfs->ns_blocksize_bits;\n"
        ],
        "error": []
    },
    "9a58b47cdbbb40f7679a00991cac436716c70192": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/udf/directory.c b/fs/udf/directory.c\nindex e7e8b30876d9..7f35ba12def6 100644\n--- a/fs/udf/directory.c\n+++ b/fs/udf/directory.c\n@@ -505,7 +505,7 @@ struct long_ad *udf_get_filelongad(uint8_t *ptr, int maxoffset, uint32_t *offset\n \tif ((*offset + sizeof(struct long_ad)) > maxoffset)\n \t\treturn NULL;\n \telse {\n-\t\tla = (struct long_ad *)ptr;\n+\t\tla = (struct long_ad *)(ptr + *offset);\n \t\tif (la->extLength == 0)\n \t\t\treturn NULL;\n \t}\n",
            "diff --git a/fs/udf/directory.c b/fs/udf/directory.c\nindex e7e8b30876d9..52caf6a6cb88 100644\n--- a/fs/udf/directory.c\n+++ b/fs/udf/directory.c\n@@ -504,11 +504,10 @@ struct long_ad *udf_get_filelongad(uint8_t *ptr, int maxoffset, uint32_t *offset\n \n \tif ((*offset + sizeof(struct long_ad)) > maxoffset)\n \t\treturn NULL;\n-\telse {\n-\t\tla = (struct long_ad *)ptr;\n-\t\tif (la->extLength == 0)\n-\t\t\treturn NULL;\n-\t}\n+\n+\tla = (struct long_ad *)(ptr + *offset);\n+\tif (la->extLength == 0)\n+\t\treturn NULL;\n \n \tif (inc)\n \t\t*offset += sizeof(struct long_ad);\n",
            "diff --git a/fs/udf/directory.c b/fs/udf/directory.c\nindex e7e8b30876d9..7f35ba12def6 100644\n--- a/fs/udf/directory.c\n+++ b/fs/udf/directory.c\n@@ -505,7 +505,7 @@ struct long_ad *udf_get_filelongad(uint8_t *ptr, int maxoffset, uint32_t *offset\n \tif ((*offset + sizeof(struct long_ad)) > maxoffset)\n \t\treturn NULL;\n \telse {\n-\t\tla = (struct long_ad *)ptr;\n+\t\tla = (struct long_ad *)(ptr + *offset);\n \t\tif (la->extLength == 0)\n \t\t\treturn NULL;\n \t}\n",
            "diff --git a/fs/udf/directory.c b/fs/udf/directory.c\nindex e7e8b30876d9..7f35ba12def6 100644\n--- a/fs/udf/directory.c\n+++ b/fs/udf/directory.c\n@@ -505,7 +505,7 @@ struct long_ad *udf_get_filelongad(uint8_t *ptr, int maxoffset, uint32_t *offset\n \tif ((*offset + sizeof(struct long_ad)) > maxoffset)\n \t\treturn NULL;\n \telse {\n-\t\tla = (struct long_ad *)ptr;\n+\t\tla = (struct long_ad *)(ptr + *offset);\n \t\tif (la->extLength == 0)\n \t\t\treturn NULL;\n \t}\n",
            "diff --git a/fs/udf/directory.c b/fs/udf/directory.c\nindex e7e8b30876d9..7f35ba12def6 100644\n--- a/fs/udf/directory.c\n+++ b/fs/udf/directory.c\n@@ -505,7 +505,7 @@ struct long_ad *udf_get_filelongad(uint8_t *ptr, int maxoffset, uint32_t *offset\n \tif ((*offset + sizeof(struct long_ad)) > maxoffset)\n \t\treturn NULL;\n \telse {\n-\t\tla = (struct long_ad *)ptr;\n+\t\tla = (struct long_ad *)(ptr + *offset);\n \t\tif (la->extLength == 0)\n \t\t\treturn NULL;\n \t}\n"
        ],
        "error": []
    },
    "c7c63c2548579c7e4718d2f8bc079a6e152e4ac8": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 354cb472f386..b5292d4bf507 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -134,15 +134,17 @@ nf_hook_entries_grow(const struct nf_hook_entries *old,\n \ti = 0;\n \tnhooks = 0;\n \twhile (i < old_entries) {\n-\t\tif (orig_ops[i] == &dummy_ops) {\n+\t\tif (orig_ops[i] == &dummy_ops || !orig_ops[i]) {\n \t\t\t++i;\n \t\t\tcontinue;\n \t\t}\n \n \t\tif (inserted || reg->priority > orig_ops[i]->priority) {\n-\t\t\tnew_ops[nhooks] = (void *)orig_ops[i];\n-\t\t\tnew->hooks[nhooks] = old->hooks[i];\n-\t\t\ti++;\n+\t\t\tif (orig_ops[i]) {\n+\t\t\t\tnew_ops[nhooks] = (void *)orig_ops[i];\n+\t\t\t\tnew->hooks[nhooks] = old->hooks[i];\n+\t\t\t\ti++;\n+\t\t\t}\n \t\t} else {\n \t\t\tnew_ops[nhooks] = (void *)reg;\n \t\t\tnew->hooks[nhooks].hook = reg->hook;\ndiff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 5fa16990da95..9527bdb268f0 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -7828,10 +7828,12 @@ static void nf_tables_flowtable_destroy(struct nft_flowtable *flowtable)\n \n \tflowtable->data.type->free(&flowtable->data);\n \tlist_for_each_entry_safe(hook, next, &flowtable->hook_list, list) {\n-\t\tflowtable->data.type->setup(&flowtable->data, hook->ops.dev,\n-\t\t\t\t\t    FLOW_BLOCK_UNBIND);\n-\t\tlist_del_rcu(&hook->list);\n-\t\tkfree(hook);\n+\t\tif (hook->ops.dev) {\n+\t\t\tflowtable->data.type->setup(&flowtable->data, hook->ops.dev,\n+\t\t\t\t\t\t    FLOW_BLOCK_UNBIND);\n+\t\t\tlist_del_rcu(&hook->list);\n+\t\t\tkfree(hook);\n+\t\t}\n \t}\n \tkfree(flowtable->name);\n \tmodule_put(flowtable->data.type->owner);\n",
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 354cb472f386..712d11e6e536 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -134,7 +134,7 @@ nf_hook_entries_grow(const struct nf_hook_entries *old,\n \ti = 0;\n \tnhooks = 0;\n \twhile (i < old_entries) {\n-\t\tif (orig_ops[i] == &dummy_ops) {\n+\t\tif (orig_ops[i] == &dummy_ops || !orig_ops[i]) {\n \t\t\t++i;\n \t\t\tcontinue;\n \t\t}\n",
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 354cb472f386..84f6c714e17d 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -140,8 +140,10 @@ nf_hook_entries_grow(const struct nf_hook_entries *old,\n \t\t}\n \n \t\tif (inserted || reg->priority > orig_ops[i]->priority) {\n-\t\t\tnew_ops[nhooks] = (void *)orig_ops[i];\n-\t\t\tnew->hooks[nhooks] = old->hooks[i];\n+\t\t\tif (orig_ops[i] != &dummy_ops) {\n+\t\t\t\tnew_ops[nhooks] = (void *)orig_ops[i];\n+\t\t\t\tnew->hooks[nhooks] = old->hooks[i];\n+\t\t\t}\n \t\t\ti++;\n \t\t} else {\n \t\t\tnew_ops[nhooks] = (void *)reg;\n",
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 354cb472f386..a39bc5fb16a9 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -134,12 +134,12 @@ nf_hook_entries_grow(const struct nf_hook_entries *old,\n \ti = 0;\n \tnhooks = 0;\n \twhile (i < old_entries) {\n-\t\tif (orig_ops[i] == &dummy_ops) {\n+\t\tif (orig_ops && orig_ops[i] == &dummy_ops) {\n \t\t\t++i;\n \t\t\tcontinue;\n \t\t}\n \n-\t\tif (inserted || reg->priority > orig_ops[i]->priority) {\n+\t\tif (orig_ops && (inserted || reg->priority > orig_ops[i]->priority)) {\n \t\t\tnew_ops[nhooks] = (void *)orig_ops[i];\n \t\t\tnew->hooks[nhooks] = old->hooks[i];\n \t\t\ti++;\n",
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 354cb472f386..a39bc5fb16a9 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -134,12 +134,12 @@ nf_hook_entries_grow(const struct nf_hook_entries *old,\n \ti = 0;\n \tnhooks = 0;\n \twhile (i < old_entries) {\n-\t\tif (orig_ops[i] == &dummy_ops) {\n+\t\tif (orig_ops && orig_ops[i] == &dummy_ops) {\n \t\t\t++i;\n \t\t\tcontinue;\n \t\t}\n \n-\t\tif (inserted || reg->priority > orig_ops[i]->priority) {\n+\t\tif (orig_ops && (inserted || reg->priority > orig_ops[i]->priority)) {\n \t\t\tnew_ops[nhooks] = (void *)orig_ops[i];\n \t\t\tnew->hooks[nhooks] = old->hooks[i];\n \t\t\ti++;\n"
        ],
        "error": []
    },
    "ee9018bd8989530a2dbdd62436efd8b1c3ecd3e5": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/bluetooth/rfcomm/core.c b/net/bluetooth/rfcomm/core.c\nindex 8d6fce9005bd..8fd64d261ae6 100644\n--- a/net/bluetooth/rfcomm/core.c\n+++ b/net/bluetooth/rfcomm/core.c\n@@ -484,10 +484,9 @@ static int __rfcomm_dlc_close(struct rfcomm_dlc *d, int err)\n \tdefault:\n \t\trfcomm_dlc_clear_timer(d);\n \n-\t\trfcomm_dlc_lock(d);\n \t\td->state = BT_CLOSED;\n-\t\td->state_change(d, err);\n \t\trfcomm_dlc_unlock(d);\n+\t\td->state_change(d, err);\n \n \t\tskb_queue_purge(&d->tx_queue);\n \t\trfcomm_dlc_unlink(d);\n@@ -504,12 +503,12 @@ int rfcomm_dlc_close(struct rfcomm_dlc *d, int err)\n \n \tBT_DBG(\"dlc %p state %ld dlci %d err %d\", d, d->state, d->dlci, err);\n \n-\trfcomm_lock();\n-\n \ts = d->session;\n \tif (!s)\n \t\tgoto no_session;\n \n+\trfcomm_lock();\n+\n \t/* after waiting on the mutex check the session still exists\n \t * then check the dlc still exists\n \t */\ndiff --git a/net/bluetooth/rfcomm/sock.c b/net/bluetooth/rfcomm/sock.c\nindex 21e24da4847f..afe0a90e3bd1 100644\n--- a/net/bluetooth/rfcomm/sock.c\n+++ b/net/bluetooth/rfcomm/sock.c\n@@ -70,8 +70,6 @@ static void rfcomm_sk_state_change(struct rfcomm_dlc *d, int err)\n \n \tBT_DBG(\"dlc %p state %ld err %d\", d, d->state, err);\n \n-\tlock_sock(sk);\n-\n \tif (err)\n \t\tsk->sk_err = err;\n \n@@ -79,6 +77,7 @@ static void rfcomm_sk_state_change(struct rfcomm_dlc *d, int err)\n \n \tparent = bt_sk(sk)->parent;\n \tif (parent) {\n+\t\tlock_sock(sk);\n \t\tif (d->state == BT_CLOSED) {\n \t\t\tsock_set_flag(sk, SOCK_ZAPPED);\n \t\t\tbt_accept_unlink(sk);\n",
            "diff --git a/net/bluetooth/rfcomm/core.c b/net/bluetooth/rfcomm/core.c\nindex 8d6fce9005bd..92a0efe34c31 100644\n--- a/net/bluetooth/rfcomm/core.c\n+++ b/net/bluetooth/rfcomm/core.c\n@@ -484,10 +484,10 @@ static int __rfcomm_dlc_close(struct rfcomm_dlc *d, int err)\n \tdefault:\n \t\trfcomm_dlc_clear_timer(d);\n \n-\t\trfcomm_dlc_lock(d);\n \t\td->state = BT_CLOSED;\n+\t\trfcomm_dlc_unlock(d);  // Release &d->lock before state change\n \t\td->state_change(d, err);\n-\t\trfcomm_dlc_unlock(d);\n+\t\trfcomm_dlc_lock(d);  // Reacquire &d->lock if necessary\n \n \t\tskb_queue_purge(&d->tx_queue);\n \t\trfcomm_dlc_unlink(d);\ndiff --git a/net/bluetooth/rfcomm/sock.c b/net/bluetooth/rfcomm/sock.c\nindex 21e24da4847f..33f70ee803fd 100644\n--- a/net/bluetooth/rfcomm/sock.c\n+++ b/net/bluetooth/rfcomm/sock.c\n@@ -70,6 +70,7 @@ static void rfcomm_sk_state_change(struct rfcomm_dlc *d, int err)\n \n \tBT_DBG(\"dlc %p state %ld err %d\", d, d->state, err);\n \n+\trfcomm_dlc_unlock(d);  // Release &d->lock before acquiring sk_lock\n \tlock_sock(sk);\n \n \tif (err)\n",
            "diff --git a/net/bluetooth/rfcomm/core.c b/net/bluetooth/rfcomm/core.c\nindex 8d6fce9005bd..6bd573bca809 100644\n--- a/net/bluetooth/rfcomm/core.c\n+++ b/net/bluetooth/rfcomm/core.c\n@@ -486,8 +486,8 @@ static int __rfcomm_dlc_close(struct rfcomm_dlc *d, int err)\n \n \t\trfcomm_dlc_lock(d);\n \t\td->state = BT_CLOSED;\n-\t\td->state_change(d, err);\n \t\trfcomm_dlc_unlock(d);\n+\t\td->state_change(d, err);\n \n \t\tskb_queue_purge(&d->tx_queue);\n \t\trfcomm_dlc_unlink(d);\n",
            "diff --git a/net/bluetooth/rfcomm/core.c b/net/bluetooth/rfcomm/core.c\nindex 8d6fce9005bd..6bd573bca809 100644\n--- a/net/bluetooth/rfcomm/core.c\n+++ b/net/bluetooth/rfcomm/core.c\n@@ -486,8 +486,8 @@ static int __rfcomm_dlc_close(struct rfcomm_dlc *d, int err)\n \n \t\trfcomm_dlc_lock(d);\n \t\td->state = BT_CLOSED;\n-\t\td->state_change(d, err);\n \t\trfcomm_dlc_unlock(d);\n+\t\td->state_change(d, err);\n \n \t\tskb_queue_purge(&d->tx_queue);\n \t\trfcomm_dlc_unlink(d);\ndiff --git a/net/bluetooth/rfcomm/sock.c b/net/bluetooth/rfcomm/sock.c\nindex 21e24da4847f..5d2f49e8123e 100644\n--- a/net/bluetooth/rfcomm/sock.c\n+++ b/net/bluetooth/rfcomm/sock.c\n@@ -70,13 +70,13 @@ static void rfcomm_sk_state_change(struct rfcomm_dlc *d, int err)\n \n \tBT_DBG(\"dlc %p state %ld err %d\", d, d->state, err);\n \n-\tlock_sock(sk);\n-\n \tif (err)\n \t\tsk->sk_err = err;\n \n \tsk->sk_state = d->state;\n \n+\tlock_sock(sk);\n+\n \tparent = bt_sk(sk)->parent;\n \tif (parent) {\n \t\tif (d->state == BT_CLOSED) {\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/bluetooth/rfcomm/core.c b/net/bluetooth/rfcomm/core.c\nindex 8d6fce9005bd..0ab9f861b9f3 100644\n--- a/net/bluetooth/rfcomm/core.c\n+++ b/net/bluetooth/rfcomm/core.c\n@@ -486,7 +486,10 @@ static int __rfcomm_dlc_close(struct rfcomm_dlc *d, int err)\n \n \t\trfcomm_dlc_lock(d);\n \t\td->state = BT_CLOSED;\n+\t\t// Release &d->lock before calling state_change to avoid deadlock\n+\t\trfcomm_dlc_unlock(d);\n \t\td->state_change(d, err);\n+\t\trfcomm_dlc_lock(d);\n \t\trfcomm_dlc_unlock(d);\n \n \t\tskb_queue_purge(&d->tx_queue);\ndiff --git a/net/bluetooth/rfcomm/sock.c b/net/bluetooth/rfcomm/sock.c\nindex 21e24da4847f..17d782e3fa12 100644\n--- a/net/bluetooth/rfcomm/sock.c\n+++ b/net/bluetooth/rfcomm/sock.c\n@@ -70,8 +70,6 @@ static void rfcomm_sk_state_change(struct rfcomm_dlc *d, int err)\n \n \tBT_DBG(\"dlc %p state %ld err %d\", d, d->state, err);\n \n-\tlock_sock(sk);\n-\n \tif (err)\n \t\tsk->sk_err = err;\n \n@@ -81,6 +79,10 @@ static void rfcomm_sk_state_change(struct rfcomm_dlc *d, int err)\n \tif (parent) {\n \t\tif (d->state == BT_CLOSED) {\n \t\t\tsock_set_flag(sk, SOCK_ZAPPED);\n+\t\t}\n+\t}\n+\n+\tlock_sock(sk);\n \t\t\tbt_accept_unlink(sk);\n \t\t}\n \t\tparent->sk_data_ready(parent);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "31a3f2ad09a571fb7a5212efc400ce6bfc82e04c": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c\nindex 474479ce76e0..bfd4fb91ae43 100644\n--- a/fs/ext4/extents.c\n+++ b/fs/ext4/extents.c\n@@ -509,14 +509,17 @@ static void ext4_cache_extents(struct inode *inode,\n \t\text4_lblk_t lblk = le32_to_cpu(ex->ee_block);\n \t\tint len = ext4_ext_get_actual_len(ex);\n \n-\t\tif (prev && (prev != lblk))\n-\t\t\text4_es_cache_extent(inode, prev, lblk - prev, ~0,\n-\t\t\t\t\t     EXTENT_STATUS_HOLE);\n+\t\tif (prev && (prev != lblk)) {\n+\t\t\tif (lblk > prev)  // Ensure positive length\n+\t\t\t\text4_es_cache_extent(inode, prev, lblk - prev, ~0,\n+\t\t\t\t\t\t     EXTENT_STATUS_HOLE);\n+\t\t}\n \n \t\tif (ext4_ext_is_unwritten(ex))\n \t\t\tstatus = EXTENT_STATUS_UNWRITTEN;\n-\t\text4_es_cache_extent(inode, lblk, len,\n-\t\t\t\t     ext4_ext_pblock(ex), status);\n+\t\tif (len > 0)  // Ensure positive length\n+\t\t\text4_es_cache_extent(inode, lblk, len,\n+\t\t\t\t\t     ext4_ext_pblock(ex), status);\n \t\tprev = lblk + len;\n \t}\n }\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/extents_status.c b/fs/ext4/extents_status.c\nindex 9a3a8996aacf..1a412e188a29 100644\n--- a/fs/ext4/extents_status.c\n+++ b/fs/ext4/extents_status.c\n@@ -830,7 +830,10 @@ int ext4_es_insert_extent(struct inode *inode, ext4_lblk_t lblk,\n \tif (!len)\n \t\treturn 0;\n \n-\tBUG_ON(end < lblk);\n+\tif (end < lblk) {\n+        printk(KERN_ERR \"ext4_es_cache_extent: invalid extent range: end=%u, lblk=%u\\n\", end, lblk);\n+        return;\n+    }\n \n \tif ((status & EXTENT_STATUS_DELAYED) &&\n \t    (status & EXTENT_STATUS_WRITTEN)) {\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "ec324fb855382395411b32d87a6eafd5da721ecc": {
        "non_crash": [
            "diff --git a/net/sctp/socket.c b/net/sctp/socket.c\nindex fc0386e8ff23..dc48393b4f6b 100644\n--- a/net/sctp/socket.c\n+++ b/net/sctp/socket.c\n@@ -7162,16 +7162,21 @@ static int sctp_getsockopt_pr_streamstatus(struct sock *sk, int len,\n \t\tparams.sprstat_abandoned_unsent = 0;\n \t\tparams.sprstat_abandoned_sent = 0;\n \t\tfor (policy = 0; policy <= SCTP_PR_INDEX(MAX); policy++) {\n-\t\t\tparams.sprstat_abandoned_unsent +=\n-\t\t\t\tstreamoute->abandoned_unsent[policy];\n-\t\t\tparams.sprstat_abandoned_sent +=\n-\t\t\t\tstreamoute->abandoned_sent[policy];\n+\t\t\tif (policy < ARRAY_SIZE(streamoute->abandoned_unsent)) {\n+\t\t\t\tparams.sprstat_abandoned_unsent +=\n+\t\t\t\t\tstreamoute->abandoned_unsent[policy];\n+\t\t\t\tparams.sprstat_abandoned_sent +=\n+\t\t\t\t\tstreamoute->abandoned_sent[policy];\n+\t\t\t}\n \t\t}\n \t} else {\n-\t\tparams.sprstat_abandoned_unsent =\n-\t\t\tstreamoute->abandoned_unsent[__SCTP_PR_INDEX(policy)];\n-\t\tparams.sprstat_abandoned_sent =\n-\t\t\tstreamoute->abandoned_sent[__SCTP_PR_INDEX(policy)];\n+\t\tint index = __SCTP_PR_INDEX(policy);\n+\t\tif (index < ARRAY_SIZE(streamoute->abandoned_unsent)) {\n+\t\t\tparams.sprstat_abandoned_unsent =\n+\t\t\t\tstreamoute->abandoned_unsent[index];\n+\t\t\tparams.sprstat_abandoned_sent =\n+\t\t\t\tstreamoute->abandoned_sent[index];\n+\t\t}\n \t}\n \n \tif (put_user(len, optlen) || copy_to_user(optval, &params, len)) {\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/sctp/socket.c b/net/sctp/socket.c\nindex fc0386e8ff23..c0d8165b9ce4 100644\n--- a/net/sctp/socket.c\n+++ b/net/sctp/socket.c\n@@ -7093,7 +7093,7 @@ static int sctp_getsockopt_pr_assocstatus(struct sock *sk, int len,\n \tif (policy & SCTP_PR_SCTP_ALL) {\n \t\tparams.sprstat_abandoned_unsent = 0;\n \t\tparams.sprstat_abandoned_sent = 0;\n-\t\tfor (policy = 0; policy <= SCTP_PR_INDEX(MAX); policy++) {\n+\t\tfor (policy = 0; policy < SCTP_PR_INDEX(MAX); policy++) {\n \t\t\tparams.sprstat_abandoned_unsent +=\n \t\t\t\tasoc->abandoned_unsent[policy];\n \t\t\tparams.sprstat_abandoned_sent +=\n",
            "diff --git a/net/sctp/socket.c b/net/sctp/socket.c\nindex fc0386e8ff23..c0d8165b9ce4 100644\n--- a/net/sctp/socket.c\n+++ b/net/sctp/socket.c\n@@ -7093,7 +7093,7 @@ static int sctp_getsockopt_pr_assocstatus(struct sock *sk, int len,\n \tif (policy & SCTP_PR_SCTP_ALL) {\n \t\tparams.sprstat_abandoned_unsent = 0;\n \t\tparams.sprstat_abandoned_sent = 0;\n-\t\tfor (policy = 0; policy <= SCTP_PR_INDEX(MAX); policy++) {\n+\t\tfor (policy = 0; policy < SCTP_PR_INDEX(MAX); policy++) {\n \t\t\tparams.sprstat_abandoned_unsent +=\n \t\t\t\tasoc->abandoned_unsent[policy];\n \t\t\tparams.sprstat_abandoned_sent +=\n",
            "diff --git a/net/sctp/socket.c b/net/sctp/socket.c\nindex fc0386e8ff23..c0d8165b9ce4 100644\n--- a/net/sctp/socket.c\n+++ b/net/sctp/socket.c\n@@ -7093,7 +7093,7 @@ static int sctp_getsockopt_pr_assocstatus(struct sock *sk, int len,\n \tif (policy & SCTP_PR_SCTP_ALL) {\n \t\tparams.sprstat_abandoned_unsent = 0;\n \t\tparams.sprstat_abandoned_sent = 0;\n-\t\tfor (policy = 0; policy <= SCTP_PR_INDEX(MAX); policy++) {\n+\t\tfor (policy = 0; policy < SCTP_PR_INDEX(MAX); policy++) {\n \t\t\tparams.sprstat_abandoned_unsent +=\n \t\t\t\tasoc->abandoned_unsent[policy];\n \t\t\tparams.sprstat_abandoned_sent +=\n",
            "diff --git a/net/sctp/socket.c b/net/sctp/socket.c\nindex fc0386e8ff23..2c103dcd1948 100644\n--- a/net/sctp/socket.c\n+++ b/net/sctp/socket.c\n@@ -7161,7 +7161,7 @@ static int sctp_getsockopt_pr_streamstatus(struct sock *sk, int len,\n \tif (policy == SCTP_PR_SCTP_ALL) {\n \t\tparams.sprstat_abandoned_unsent = 0;\n \t\tparams.sprstat_abandoned_sent = 0;\n-\t\tfor (policy = 0; policy <= SCTP_PR_INDEX(MAX); policy++) {\n+\t\tfor (policy = 0; policy < SCTP_PR_INDEX(MAX); policy++) {\n \t\t\tparams.sprstat_abandoned_unsent +=\n \t\t\t\tstreamoute->abandoned_unsent[policy];\n \t\t\tparams.sprstat_abandoned_sent +=\n"
        ],
        "error": []
    },
    "75b0feac9a3f9e361fd60605e261f8a4ffef1c40": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/truncate.c b/mm/truncate.c\nindex ab50d0d59a2a..d3ea3d7a9b7b 100644\n--- a/mm/truncate.c\n+++ b/mm/truncate.c\n@@ -234,7 +234,12 @@ bool truncate_inode_partial_folio(struct folio *folio, loff_t start, loff_t end)\n \t * doing a complex calculation here, and then doing the zeroing\n \t * anyway if the page split fails.\n \t */\n-\tfolio_zero_range(folio, offset, length);\n+\tif (offset + length <= folio_size(folio)) {\n+\t\tfolio_zero_range(folio, offset, length);\n+\t} else {\n+\t\tpr_err(\"Attempt to zero range beyond folio size\\n\");\n+\t\treturn false;\n+\t}\n \n \tif (folio_has_private(folio))\n \t\tfolio_invalidate(folio, offset, length);\n",
            "diff --git a/mm/truncate.c b/mm/truncate.c\nindex ab50d0d59a2a..bbdd92efff65 100644\n--- a/mm/truncate.c\n+++ b/mm/truncate.c\n@@ -234,7 +234,13 @@ bool truncate_inode_partial_folio(struct folio *folio, loff_t start, loff_t end)\n \t * doing a complex calculation here, and then doing the zeroing\n \t * anyway if the page split fails.\n \t */\n-\tfolio_zero_range(folio, offset, length);\n+\tif (folio_test_uptodate(folio)) {\n+\t\tfolio_zero_range(folio, offset, length);\n+\t} else {\n+\t\t// Handle the error or initialize the folio as needed\n+\t\tpr_err(\"Attempting to zero an uninitialized folio\\n\");\n+\t\treturn false;\n+\t}\n \n \tif (folio_has_private(folio))\n \t\tfolio_invalidate(folio, offset, length);\n",
            "diff --git a/mm/truncate.c b/mm/truncate.c\nindex ab50d0d59a2a..5a8544bf8120 100644\n--- a/mm/truncate.c\n+++ b/mm/truncate.c\n@@ -234,7 +234,13 @@ bool truncate_inode_partial_folio(struct folio *folio, loff_t start, loff_t end)\n \t * doing a complex calculation here, and then doing the zeroing\n \t * anyway if the page split fails.\n \t */\n-\tfolio_zero_range(folio, offset, length);\n+\tif (offset + length <= folio_size(folio)) {\n+\t\tfolio_zero_range(folio, offset, length);\n+\t} else {\n+\t\tpr_err(\"Invalid folio range: offset=%zu, length=%zu, folio_size=%zu\\n\",\n+\t\t       offset, length, folio_size(folio));\n+\t\treturn false;\n+\t}\n \n \tif (folio_has_private(folio))\n \t\tfolio_invalidate(folio, offset, length);\n",
            "diff --git a/include/linux/highmem.h b/include/linux/highmem.h\nindex 56d6a0196534..80eb0f445d91 100644\n--- a/include/linux/highmem.h\n+++ b/include/linux/highmem.h\n@@ -425,7 +425,12 @@ static inline void folio_zero_segment(struct folio *folio,\n static inline void folio_zero_range(struct folio *folio,\n \t\tsize_t start, size_t length)\n {\n-\tzero_user_segments(&folio->page, start, start + length, 0, 0);\n+\tif (start + length <= folio_size(folio)) {\n+\t\tzero_user_segments(&folio->page, start, start + length, 0, 0);\n+\t} else {\n+\t\tpr_err(\"Invalid range for zero_user_segments: start=%zu, length=%zu, folio_size=%zu\\n\",\n+\t\t       start, length, folio_size(folio));\n+\t}\n }\n \n #endif /* _LINUX_HIGHMEM_H */\ndiff --git a/mm/truncate.c b/mm/truncate.c\nindex ab50d0d59a2a..bac2124e644e 100644\n--- a/mm/truncate.c\n+++ b/mm/truncate.c\n@@ -234,7 +234,13 @@ bool truncate_inode_partial_folio(struct folio *folio, loff_t start, loff_t end)\n \t * doing a complex calculation here, and then doing the zeroing\n \t * anyway if the page split fails.\n \t */\n-\tfolio_zero_range(folio, offset, length);\n+\tif (offset + length <= folio_size(folio)) {\n+\t\tfolio_zero_range(folio, offset, length);\n+\t} else {\n+\t\tpr_err(\"Invalid range for folio zeroing: offset=%zu, length=%zu, folio_size=%zu\\n\",\n+\t\t       offset, length, folio_size(folio));\n+\t\treturn false;\n+\t}\n \n \tif (folio_has_private(folio))\n \t\tfolio_invalidate(folio, offset, length);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/include/linux/highmem.h b/include/linux/highmem.h\nindex 56d6a0196534..7579aa271936 100644\n--- a/include/linux/highmem.h\n+++ b/include/linux/highmem.h\n@@ -425,6 +425,9 @@ static inline void folio_zero_segment(struct folio *folio,\n static inline void folio_zero_range(struct folio *folio,\n \t\tsize_t start, size_t length)\n {\n+\tsize_t folio_size = folio_size(folio);\n+\tif (start + length > folio_size)\n+\t\tlength = folio_size - start;\n \tzero_user_segments(&folio->page, start, start + length, 0, 0);\n }\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "cfec079d55325bc20e929c60cc2dca149448f9b1": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 3990e4df3d7b..c465914175e5 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -274,8 +274,10 @@ long watch_queue_set_size(struct pipe_inode_info *pipe, unsigned int nr_notes)\n \twhile (--i >= 0)\n \t\t__free_page(pages[i]);\n \tkfree(pages);\n+\tkfree(bitmap);\n error:\n \t(void) account_pipe_buffers(pipe->user, nr_pages, pipe->nr_accounted);\n+\tkfree(bitmap);\n \treturn ret;\n }\n \n",
            "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 3990e4df3d7b..ae0e0a7292b2 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -274,7 +274,9 @@ long watch_queue_set_size(struct pipe_inode_info *pipe, unsigned int nr_notes)\n \twhile (--i >= 0)\n \t\t__free_page(pages[i]);\n \tkfree(pages);\n+\tkfree(bitmap);\n error:\n+\tkfree(bitmap);\n \t(void) account_pipe_buffers(pipe->user, nr_pages, pipe->nr_accounted);\n \treturn ret;\n }\n",
            "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 3990e4df3d7b..ae0e0a7292b2 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -274,7 +274,9 @@ long watch_queue_set_size(struct pipe_inode_info *pipe, unsigned int nr_notes)\n \twhile (--i >= 0)\n \t\t__free_page(pages[i]);\n \tkfree(pages);\n+\tkfree(bitmap);\n error:\n+\tkfree(bitmap);\n \t(void) account_pipe_buffers(pipe->user, nr_pages, pipe->nr_accounted);\n \treturn ret;\n }\n",
            "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 3990e4df3d7b..5138d9a69627 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -275,6 +275,7 @@ long watch_queue_set_size(struct pipe_inode_info *pipe, unsigned int nr_notes)\n \t\t__free_page(pages[i]);\n \tkfree(pages);\n error:\n+\tkfree(bitmap);  // Free the bitmap if it was allocated\n \t(void) account_pipe_buffers(pipe->user, nr_pages, pipe->nr_accounted);\n \treturn ret;\n }\n",
            "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 3990e4df3d7b..ae0e0a7292b2 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -274,7 +274,9 @@ long watch_queue_set_size(struct pipe_inode_info *pipe, unsigned int nr_notes)\n \twhile (--i >= 0)\n \t\t__free_page(pages[i]);\n \tkfree(pages);\n+\tkfree(bitmap);\n error:\n+\tkfree(bitmap);\n \t(void) account_pipe_buffers(pipe->user, nr_pages, pipe->nr_accounted);\n \treturn ret;\n }\n"
        ],
        "error": []
    },
    "1bc76a5779300075e3466a0e2abcd753df212779": {
        "non_crash": [
            "diff --git a/drivers/bluetooth/hci_h5.c b/drivers/bluetooth/hci_h5.c\nindex 0c0dedece59c..eb0099a21288 100644\n--- a/drivers/bluetooth/hci_h5.c\n+++ b/drivers/bluetooth/hci_h5.c\n@@ -587,9 +587,11 @@ static int h5_recv(struct hci_uart *hu, const void *data, int count)\n \t\tcount -= processed;\n \t}\n \n-\tpm_runtime_get(&hu->serdev->dev);\n-\tpm_runtime_mark_last_busy(&hu->serdev->dev);\n-\tpm_runtime_put_autosuspend(&hu->serdev->dev);\n+\tif (hu->serdev) {\n+\t\tpm_runtime_get(&hu->serdev->dev);\n+\t\tpm_runtime_mark_last_busy(&hu->serdev->dev);\n+\t\tpm_runtime_put_autosuspend(&hu->serdev->dev);\n+\t}\n \n \treturn 0;\n }\n",
            "diff --git a/drivers/bluetooth/hci_h5.c b/drivers/bluetooth/hci_h5.c\nindex 0c0dedece59c..eb0099a21288 100644\n--- a/drivers/bluetooth/hci_h5.c\n+++ b/drivers/bluetooth/hci_h5.c\n@@ -587,9 +587,11 @@ static int h5_recv(struct hci_uart *hu, const void *data, int count)\n \t\tcount -= processed;\n \t}\n \n-\tpm_runtime_get(&hu->serdev->dev);\n-\tpm_runtime_mark_last_busy(&hu->serdev->dev);\n-\tpm_runtime_put_autosuspend(&hu->serdev->dev);\n+\tif (hu->serdev) {\n+\t\tpm_runtime_get(&hu->serdev->dev);\n+\t\tpm_runtime_mark_last_busy(&hu->serdev->dev);\n+\t\tpm_runtime_put_autosuspend(&hu->serdev->dev);\n+\t}\n \n \treturn 0;\n }\n",
            "diff --git a/drivers/bluetooth/hci_h5.c b/drivers/bluetooth/hci_h5.c\nindex 0c0dedece59c..eb0099a21288 100644\n--- a/drivers/bluetooth/hci_h5.c\n+++ b/drivers/bluetooth/hci_h5.c\n@@ -587,9 +587,11 @@ static int h5_recv(struct hci_uart *hu, const void *data, int count)\n \t\tcount -= processed;\n \t}\n \n-\tpm_runtime_get(&hu->serdev->dev);\n-\tpm_runtime_mark_last_busy(&hu->serdev->dev);\n-\tpm_runtime_put_autosuspend(&hu->serdev->dev);\n+\tif (hu->serdev) {\n+\t\tpm_runtime_get(&hu->serdev->dev);\n+\t\tpm_runtime_mark_last_busy(&hu->serdev->dev);\n+\t\tpm_runtime_put_autosuspend(&hu->serdev->dev);\n+\t}\n \n \treturn 0;\n }\n",
            "diff --git a/drivers/bluetooth/hci_h5.c b/drivers/bluetooth/hci_h5.c\nindex 0c0dedece59c..eb0099a21288 100644\n--- a/drivers/bluetooth/hci_h5.c\n+++ b/drivers/bluetooth/hci_h5.c\n@@ -587,9 +587,11 @@ static int h5_recv(struct hci_uart *hu, const void *data, int count)\n \t\tcount -= processed;\n \t}\n \n-\tpm_runtime_get(&hu->serdev->dev);\n-\tpm_runtime_mark_last_busy(&hu->serdev->dev);\n-\tpm_runtime_put_autosuspend(&hu->serdev->dev);\n+\tif (hu->serdev) {\n+\t\tpm_runtime_get(&hu->serdev->dev);\n+\t\tpm_runtime_mark_last_busy(&hu->serdev->dev);\n+\t\tpm_runtime_put_autosuspend(&hu->serdev->dev);\n+\t}\n \n \treturn 0;\n }\n",
            "diff --git a/drivers/bluetooth/hci_h5.c b/drivers/bluetooth/hci_h5.c\nindex 0c0dedece59c..eb0099a21288 100644\n--- a/drivers/bluetooth/hci_h5.c\n+++ b/drivers/bluetooth/hci_h5.c\n@@ -587,9 +587,11 @@ static int h5_recv(struct hci_uart *hu, const void *data, int count)\n \t\tcount -= processed;\n \t}\n \n-\tpm_runtime_get(&hu->serdev->dev);\n-\tpm_runtime_mark_last_busy(&hu->serdev->dev);\n-\tpm_runtime_put_autosuspend(&hu->serdev->dev);\n+\tif (hu->serdev) {\n+\t\tpm_runtime_get(&hu->serdev->dev);\n+\t\tpm_runtime_mark_last_busy(&hu->serdev->dev);\n+\t\tpm_runtime_put_autosuspend(&hu->serdev->dev);\n+\t}\n \n \treturn 0;\n }\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "1fbd9fd0ef463a9811d2c5b7d206f119cf259601": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/smc/smc_sysctl.c b/net/smc/smc_sysctl.c\nindex bae19419e755..0159dcca3596 100644\n--- a/net/smc/smc_sysctl.c\n+++ b/net/smc/smc_sysctl.c\n@@ -53,8 +53,7 @@ int __net_init smc_sysctl_net_init(struct net *net)\n \treturn 0;\n \n err_reg:\n-\tif (!net_eq(net, &init_net))\n-\t\tkfree(table);\n+\tkfree(table);\n err_alloc:\n \treturn -ENOMEM;\n }\n",
            "diff --git a/net/smc/smc_sysctl.c b/net/smc/smc_sysctl.c\nindex bae19419e755..0159dcca3596 100644\n--- a/net/smc/smc_sysctl.c\n+++ b/net/smc/smc_sysctl.c\n@@ -53,8 +53,7 @@ int __net_init smc_sysctl_net_init(struct net *net)\n \treturn 0;\n \n err_reg:\n-\tif (!net_eq(net, &init_net))\n-\t\tkfree(table);\n+\tkfree(table);\n err_alloc:\n \treturn -ENOMEM;\n }\n",
            "diff --git a/net/smc/smc_sysctl.c b/net/smc/smc_sysctl.c\nindex bae19419e755..cbf5121a75ea 100644\n--- a/net/smc/smc_sysctl.c\n+++ b/net/smc/smc_sysctl.c\n@@ -56,6 +56,8 @@ int __net_init smc_sysctl_net_init(struct net *net)\n \tif (!net_eq(net, &init_net))\n \t\tkfree(table);\n err_alloc:\n+\tif (!net_eq(net, &init_net))\n+\t\tkfree(table);\n \treturn -ENOMEM;\n }\n \n",
            "diff --git a/net/smc/smc_sysctl.c b/net/smc/smc_sysctl.c\nindex bae19419e755..0159dcca3596 100644\n--- a/net/smc/smc_sysctl.c\n+++ b/net/smc/smc_sysctl.c\n@@ -53,8 +53,7 @@ int __net_init smc_sysctl_net_init(struct net *net)\n \treturn 0;\n \n err_reg:\n-\tif (!net_eq(net, &init_net))\n-\t\tkfree(table);\n+\tkfree(table);\n err_alloc:\n \treturn -ENOMEM;\n }\n",
            "diff --git a/net/smc/smc_sysctl.c b/net/smc/smc_sysctl.c\nindex bae19419e755..0159dcca3596 100644\n--- a/net/smc/smc_sysctl.c\n+++ b/net/smc/smc_sysctl.c\n@@ -53,8 +53,7 @@ int __net_init smc_sysctl_net_init(struct net *net)\n \treturn 0;\n \n err_reg:\n-\tif (!net_eq(net, &init_net))\n-\t\tkfree(table);\n+\tkfree(table);\n err_alloc:\n \treturn -ENOMEM;\n }\n"
        ],
        "error": []
    },
    "0987d64a09e1eb9642824a088eb331dbdb2db644": {
        "non_crash": [
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 0194a36d0b36..12fb0881c90d 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -12641,16 +12641,8 @@ static int check_map_prog_compatibility(struct bpf_verifier_env *env,\n \t * the unsafety and can fix their programs before this is enforced.\n \t */\n \tif (is_tracing_prog_type(prog_type) && !is_preallocated_map(map)) {\n-\t\tif (prog_type == BPF_PROG_TYPE_PERF_EVENT) {\n-\t\t\tverbose(env, \"perf_event programs can only use preallocated hash map\\n\");\n-\t\t\treturn -EINVAL;\n-\t\t}\n-\t\tif (IS_ENABLED(CONFIG_PREEMPT_RT)) {\n-\t\t\tverbose(env, \"trace type programs can only use preallocated hash map\\n\");\n-\t\t\treturn -EINVAL;\n-\t\t}\n-\t\tWARN_ONCE(1, \"trace type BPF program uses run-time allocation\\n\");\n-\t\tverbose(env, \"trace type programs with run-time allocated hash maps are unsafe. Switch to preallocated hash maps.\\n\");\n+\t\tverbose(env, \"trace type programs can only use preallocated hash map\\n\");\n+\t\treturn -EINVAL;\n \t}\n \n \tif (map_value_has_spin_lock(map)) {\n",
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 0194a36d0b36..12fb0881c90d 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -12641,16 +12641,8 @@ static int check_map_prog_compatibility(struct bpf_verifier_env *env,\n \t * the unsafety and can fix their programs before this is enforced.\n \t */\n \tif (is_tracing_prog_type(prog_type) && !is_preallocated_map(map)) {\n-\t\tif (prog_type == BPF_PROG_TYPE_PERF_EVENT) {\n-\t\t\tverbose(env, \"perf_event programs can only use preallocated hash map\\n\");\n-\t\t\treturn -EINVAL;\n-\t\t}\n-\t\tif (IS_ENABLED(CONFIG_PREEMPT_RT)) {\n-\t\t\tverbose(env, \"trace type programs can only use preallocated hash map\\n\");\n-\t\t\treturn -EINVAL;\n-\t\t}\n-\t\tWARN_ONCE(1, \"trace type BPF program uses run-time allocation\\n\");\n-\t\tverbose(env, \"trace type programs with run-time allocated hash maps are unsafe. Switch to preallocated hash maps.\\n\");\n+\t\tverbose(env, \"trace type programs can only use preallocated hash map\\n\");\n+\t\treturn -EINVAL;\n \t}\n \n \tif (map_value_has_spin_lock(map)) {\n",
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 0194a36d0b36..12fb0881c90d 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -12641,16 +12641,8 @@ static int check_map_prog_compatibility(struct bpf_verifier_env *env,\n \t * the unsafety and can fix their programs before this is enforced.\n \t */\n \tif (is_tracing_prog_type(prog_type) && !is_preallocated_map(map)) {\n-\t\tif (prog_type == BPF_PROG_TYPE_PERF_EVENT) {\n-\t\t\tverbose(env, \"perf_event programs can only use preallocated hash map\\n\");\n-\t\t\treturn -EINVAL;\n-\t\t}\n-\t\tif (IS_ENABLED(CONFIG_PREEMPT_RT)) {\n-\t\t\tverbose(env, \"trace type programs can only use preallocated hash map\\n\");\n-\t\t\treturn -EINVAL;\n-\t\t}\n-\t\tWARN_ONCE(1, \"trace type BPF program uses run-time allocation\\n\");\n-\t\tverbose(env, \"trace type programs with run-time allocated hash maps are unsafe. Switch to preallocated hash maps.\\n\");\n+\t\tverbose(env, \"trace type programs can only use preallocated hash map\\n\");\n+\t\treturn -EINVAL;\n \t}\n \n \tif (map_value_has_spin_lock(map)) {\n",
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 0194a36d0b36..c9b97311258d 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -12649,8 +12649,10 @@ static int check_map_prog_compatibility(struct bpf_verifier_env *env,\n \t\t\tverbose(env, \"trace type programs can only use preallocated hash map\\n\");\n \t\t\treturn -EINVAL;\n \t\t}\n-\t\tWARN_ONCE(1, \"trace type BPF program uses run-time allocation\\n\");\n-\t\tverbose(env, \"trace type programs with run-time allocated hash maps are unsafe. Switch to preallocated hash maps.\\n\");\n+\t\tif (IS_ENABLED(CONFIG_PREEMPT_RT)) {\n+\t\t\tWARN_ONCE(1, \"trace type BPF program uses run-time allocation\\n\");\n+\t\t\tverbose(env, \"trace type programs with run-time allocated hash maps are unsafe. Switch to preallocated hash maps.\\n\");\n+\t\t}\n \t}\n \n \tif (map_value_has_spin_lock(map)) {\n",
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 0194a36d0b36..12fb0881c90d 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -12641,16 +12641,8 @@ static int check_map_prog_compatibility(struct bpf_verifier_env *env,\n \t * the unsafety and can fix their programs before this is enforced.\n \t */\n \tif (is_tracing_prog_type(prog_type) && !is_preallocated_map(map)) {\n-\t\tif (prog_type == BPF_PROG_TYPE_PERF_EVENT) {\n-\t\t\tverbose(env, \"perf_event programs can only use preallocated hash map\\n\");\n-\t\t\treturn -EINVAL;\n-\t\t}\n-\t\tif (IS_ENABLED(CONFIG_PREEMPT_RT)) {\n-\t\t\tverbose(env, \"trace type programs can only use preallocated hash map\\n\");\n-\t\t\treturn -EINVAL;\n-\t\t}\n-\t\tWARN_ONCE(1, \"trace type BPF program uses run-time allocation\\n\");\n-\t\tverbose(env, \"trace type programs with run-time allocated hash maps are unsafe. Switch to preallocated hash maps.\\n\");\n+\t\tverbose(env, \"trace type programs can only use preallocated hash map\\n\");\n+\t\treturn -EINVAL;\n \t}\n \n \tif (map_value_has_spin_lock(map)) {\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "1a351beaed9d438481f1fc96aa336a25f71a2ae1": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex fbde494444b8..13bee751087c 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -4746,6 +4746,10 @@ static inline void *mas_next_entry(struct ma_state *mas, unsigned long limit)\n \toffset = mas->offset;\n \tprev_node = mas->node;\n \tnode = mas_mn(mas);\n+\tif (unlikely(ma_dead_node(node))) {\n+\t\tmas_rewalk(mas, last);\n+\t\tgoto retry;\n+\t}\n \tmt = mte_node_type(mas->node);\n \tmas->offset++;\n \tif (unlikely(mas->offset >= mt_slots[mt])) {\n@@ -4755,10 +4759,6 @@ static inline void *mas_next_entry(struct ma_state *mas, unsigned long limit)\n \n \twhile (!mas_is_none(mas)) {\n \t\tentry = mas_next_nentry(mas, node, limit, mt);\n-\t\tif (unlikely(ma_dead_node(node))) {\n-\t\t\tmas_rewalk(mas, last);\n-\t\t\tgoto retry;\n-\t\t}\n \n \t\tif (likely(entry))\n \t\t\treturn entry;\n",
            "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex fbde494444b8..13bee751087c 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -4746,6 +4746,10 @@ static inline void *mas_next_entry(struct ma_state *mas, unsigned long limit)\n \toffset = mas->offset;\n \tprev_node = mas->node;\n \tnode = mas_mn(mas);\n+\tif (unlikely(ma_dead_node(node))) {\n+\t\tmas_rewalk(mas, last);\n+\t\tgoto retry;\n+\t}\n \tmt = mte_node_type(mas->node);\n \tmas->offset++;\n \tif (unlikely(mas->offset >= mt_slots[mt])) {\n@@ -4755,10 +4759,6 @@ static inline void *mas_next_entry(struct ma_state *mas, unsigned long limit)\n \n \twhile (!mas_is_none(mas)) {\n \t\tentry = mas_next_nentry(mas, node, limit, mt);\n-\t\tif (unlikely(ma_dead_node(node))) {\n-\t\t\tmas_rewalk(mas, last);\n-\t\t\tgoto retry;\n-\t\t}\n \n \t\tif (likely(entry))\n \t\t\treturn entry;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex fbde494444b8..07df2ba3746b 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -4746,6 +4746,10 @@ static inline void *mas_next_entry(struct ma_state *mas, unsigned long limit)\n \toffset = mas->offset;\n \tprev_node = mas->node;\n \tnode = mas_mn(mas);\n+\tif (unlikely(ma_dead_node(node))) {\n+\t\tmas_rewalk(mas, last);\n+\t\tgoto retry;\n+\t}\n \tmt = mte_node_type(mas->node);\n \tmas->offset++;\n \tif (unlikely(mas->offset >= mt_slots[mt])) {\n@@ -4775,6 +4779,10 @@ static inline void *mas_next_entry(struct ma_state *mas, unsigned long limit)\n \t\t}\n \t\tmas->offset = 0;\n \t\tnode = mas_mn(mas);\n+\t\tif (unlikely(ma_dead_node(node))) {\n+\t\t\tmas_rewalk(mas, last);\n+\t\t\tgoto retry;\n+\t\t}\n \t\tmt = mte_node_type(mas->node);\n \t}\n \n",
                "error_message": "Failed to set up instance"
            }
        ]
    },
    "e8fc405587520f9442d64d47321fd53cef0f9bde": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/drivers/block/zram/zram_drv.c b/drivers/block/zram/zram_drv.c\nindex f6d90f1ba5cf..e0d8851d98eb 100644\n--- a/drivers/block/zram/zram_drv.c\n+++ b/drivers/block/zram/zram_drv.c\n@@ -1359,17 +1359,23 @@ static int zram_read_page(struct zram *zram, struct page *page, u32 index,\n {\n \tint ret;\n \n-\tzram_slot_lock(zram, index);\n-\tif (!zram_test_flag(zram, index, ZRAM_WB)) {\n-\t\t/* Slot should be locked through out the function call */\n-\t\tret = zram_read_from_zspool(zram, page, index);\n-\t\tzram_slot_unlock(zram, index);\n+\tif (index < zram->num_slots) {\n+\t\tzram_slot_lock(zram, index);\n+\t\tif (!zram_test_flag(zram, index, ZRAM_WB)) {\n+\t\t\t/* Slot should be locked through out the function call */\n+\t\t\tret = zram_read_from_zspool(zram, page, index);\n+\t\t\tzram_slot_unlock(zram, index);\n+\t\t} else {\n+\t\t\t/*\n+\t\t\t * The slot should be unlocked before reading from the backing\n+\t\t\t * device.\n+\t\t\t */\n+\t\t\tzram_slot_unlock(zram, index);\n+\t\t}\n \t} else {\n-\t\t/*\n-\t\t * The slot should be unlocked before reading from the backing\n-\t\t * device.\n-\t\t */\n-\t\tzram_slot_unlock(zram, index);\n+\t\tpr_err(\"zram: Invalid index %u\\n\", index);\n+\t\tret = -EINVAL;\n+\t}\n \n \t\tret = read_from_bdev(zram, page, zram_get_element(zram, index),\n \t\t\t\t     parent);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/block/zram/zram_drv.c b/drivers/block/zram/zram_drv.c\nindex f6d90f1ba5cf..1881fe500f6b 100644\n--- a/drivers/block/zram/zram_drv.c\n+++ b/drivers/block/zram/zram_drv.c\n@@ -290,7 +290,15 @@ static void mark_idle(struct zram *zram, ktime_t cutoff)\n \t\t * Do not mark ZRAM_UNDER_WB slot as ZRAM_IDLE to close race.\n \t\t * See the comment in writeback_store.\n \t\t */\n-\t\tzram_slot_lock(zram, index);\n+\t\tif (index >= zram->disksize) {\n+\t\tpr_err(\"zram: Invalid index %u\\n\", index);\n+\t\treturn -EINVAL;\n+\t}\n+\tif (!zram->table) {\n+\t\tpr_err(\"zram: Uninitialized zram table\\n\");\n+\t\treturn -EIO;\n+\t}\n+\tzram_slot_lock(zram, index);\n \t\tif (zram_allocated(zram, index) &&\n \t\t\t\t!zram_test_flag(zram, index, ZRAM_UNDER_WB)) {\n #ifdef CONFIG_ZRAM_MEMORY_TRACKING\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/block/zram/zram_drv.c b/drivers/block/zram/zram_drv.c\nindex f6d90f1ba5cf..a7dda994c953 100644\n--- a/drivers/block/zram/zram_drv.c\n+++ b/drivers/block/zram/zram_drv.c\n@@ -290,7 +290,11 @@ static void mark_idle(struct zram *zram, ktime_t cutoff)\n \t\t * Do not mark ZRAM_UNDER_WB slot as ZRAM_IDLE to close race.\n \t\t * See the comment in writeback_store.\n \t\t */\n-\t\tzram_slot_lock(zram, index);\n+\t\tif (index >= zram->disksize >> PAGE_SHIFT) {\n+\t\tpr_err(\"zram: invalid index %u\\n\", index);\n+\t\treturn -EINVAL;\n+\t}\n+\tzram_slot_lock(zram, index);\n \t\tif (zram_allocated(zram, index) &&\n \t\t\t\t!zram_test_flag(zram, index, ZRAM_UNDER_WB)) {\n #ifdef CONFIG_ZRAM_MEMORY_TRACKING\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/block/zram/zram_drv.c b/drivers/block/zram/zram_drv.c\nindex f6d90f1ba5cf..89780ba7b8c7 100644\n--- a/drivers/block/zram/zram_drv.c\n+++ b/drivers/block/zram/zram_drv.c\n@@ -1359,9 +1359,14 @@ static int zram_read_page(struct zram *zram, struct page *page, u32 index,\n {\n \tint ret;\n \n+\tif (index >= zram->num_devices) {\n+\t\tpr_err(\"zram: Invalid index %u\\n\", index);\n+\t\treturn -EINVAL;\n+\t}\n+\n \tzram_slot_lock(zram, index);\n \tif (!zram_test_flag(zram, index, ZRAM_WB)) {\n-\t\t/* Slot should be locked through out the function call */\n+\t\t/* Slot should be locked throughout the function call */\n \t\tret = zram_read_from_zspool(zram, page, index);\n \t\tzram_slot_unlock(zram, index);\n \t} else {\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "637351e3088fc2aed419d941674f2774f4162ea2": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/tty/vt/vt.c b/drivers/tty/vt/vt.c\nindex 57a5c23b51d4..afc1af00019a 100644\n--- a/drivers/tty/vt/vt.c\n+++ b/drivers/tty/vt/vt.c\n@@ -4577,8 +4577,13 @@ static int con_font_get(struct vc_data *vc, struct console_font_op *op)\n \top->width = font.width;\n \top->charcount = font.charcount;\n \n-\tif (op->data && copy_to_user(op->data, font.data, c))\n+\t/* Ensure the size does not exceed the allocated size of font.data */\n+\tif (op->data && c <= (font.width+7)/8 * font.height * font.charcount) {\n+\t\tif (copy_to_user(op->data, font.data, c))\n+\t\t\trc = -EFAULT;\n+\t} else {\n \t\trc = -EFAULT;\n+\t}\n \n out:\n \tkvfree(font.data);\n",
            "diff --git a/drivers/tty/vt/vt.c b/drivers/tty/vt/vt.c\nindex 57a5c23b51d4..a0ff2b87151b 100644\n--- a/drivers/tty/vt/vt.c\n+++ b/drivers/tty/vt/vt.c\n@@ -4577,8 +4577,13 @@ static int con_font_get(struct vc_data *vc, struct console_font_op *op)\n \top->width = font.width;\n \top->charcount = font.charcount;\n \n-\tif (op->data && copy_to_user(op->data, font.data, c))\n-\t\trc = -EFAULT;\n+\tif (op->data) {\n+\t\tif (c > op->charcount * ((op->width + 7) / 8) * vpitch) {\n+\t\t\trc = -EFAULT;\n+\t\t} else if (copy_to_user(op->data, font.data, c)) {\n+\t\t\trc = -EFAULT;\n+\t\t}\n+\t}\n \n out:\n \tkvfree(font.data);\n",
            "diff --git a/drivers/tty/vt/vt.c b/drivers/tty/vt/vt.c\nindex 57a5c23b51d4..f2ddf7c32dd3 100644\n--- a/drivers/tty/vt/vt.c\n+++ b/drivers/tty/vt/vt.c\n@@ -4570,6 +4570,8 @@ static int con_font_get(struct vc_data *vc, struct console_font_op *op)\n \t\trc = -ENOSPC;\n \tif (font.width > op->width || font.height > op->height)\n \t\trc = -ENOSPC;\n+\tif (c > op->charcount * op->width * op->height / 8)\n+\t\trc = -ENOSPC;\n \tif (rc)\n \t\tgoto out;\n \n",
            "diff --git a/drivers/tty/vt/vt.c b/drivers/tty/vt/vt.c\nindex 57a5c23b51d4..2950f8d667e8 100644\n--- a/drivers/tty/vt/vt.c\n+++ b/drivers/tty/vt/vt.c\n@@ -4577,8 +4577,13 @@ static int con_font_get(struct vc_data *vc, struct console_font_op *op)\n \top->width = font.width;\n \top->charcount = font.charcount;\n \n-\tif (op->data && copy_to_user(op->data, font.data, c))\n-\t\trc = -EFAULT;\n+\tif (op->data) {\n+\t\tif (c > op->charcount * ((op->width + 7) / 8) * op->height) {\n+\t\t\trc = -EFAULT;\n+\t\t} else if (copy_to_user(op->data, font.data, c)) {\n+\t\t\trc = -EFAULT;\n+\t\t}\n+\t}\n \n out:\n \tkvfree(font.data);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/tty/vt/vt.c b/drivers/tty/vt/vt.c\nindex 57a5c23b51d4..192a3064a7e1 100644\n--- a/drivers/tty/vt/vt.c\n+++ b/drivers/tty/vt/vt.c\n@@ -4577,7 +4577,10 @@ static int con_font_get(struct vc_data *vc, struct console_font_op *op)\n \top->width = font.width;\n \top->charcount = font.charcount;\n \n-\tif (op->data && copy_to_user(op->data, font.data, c))\n+\t/* Ensure the size does not exceed the maximum allowable size for usercopy */\n+\tif (c > MAX_USERCOPY_SIZE)\n+\t\trc = -E2BIG;\n+\telse if (op->data && copy_to_user(op->data, font.data, c))\n \t\trc = -EFAULT;\n \n out:\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "4a547542bb29dc957c096f0c95ef9154e93d68d3": {
        "non_crash": [
            "diff --git a/fs/ext4/indirect.c b/fs/ext4/indirect.c\nindex 07a8c75b65ed..10b857baa100 100644\n--- a/fs/ext4/indirect.c\n+++ b/fs/ext4/indirect.c\n@@ -1241,7 +1241,10 @@ int ext4_ind_remove_space(handle_t *handle, struct inode *inode,\n \tn = ext4_block_to_path(inode, start, offsets, NULL);\n \tn2 = ext4_block_to_path(inode, end, offsets2, NULL);\n \n-\tBUG_ON(n > n2);\n+\tif (n > n2) {\n+\t\tpr_warn(\"ext4: block path conversion error: n > n2\\n\");\n+\t\treturn -EINVAL;\n+\t}\n \n \tif ((n == 1) && (n == n2)) {\n \t\t/* We're punching only within direct block range */\n",
            "diff --git a/fs/ext4/indirect.c b/fs/ext4/indirect.c\nindex 07a8c75b65ed..5e479e6c348f 100644\n--- a/fs/ext4/indirect.c\n+++ b/fs/ext4/indirect.c\n@@ -1238,6 +1238,11 @@ int ext4_ind_remove_space(handle_t *handle, struct inode *inode,\n \tif ((start >= end) || (start > max_block))\n \t\treturn 0;\n \n+\tif (start >= max_block || end >= max_block) {\n+\t\tpr_warn(\"ext4: block number out of range in inode %lu\\n\", inode->i_ino);\n+\t\treturn -EINVAL;\n+\t}\n+\n \tn = ext4_block_to_path(inode, start, offsets, NULL);\n \tn2 = ext4_block_to_path(inode, end, offsets2, NULL);\n \n",
            "diff --git a/fs/ext4/indirect.c b/fs/ext4/indirect.c\nindex 07a8c75b65ed..cc96362b2eb5 100644\n--- a/fs/ext4/indirect.c\n+++ b/fs/ext4/indirect.c\n@@ -1238,10 +1238,18 @@ int ext4_ind_remove_space(handle_t *handle, struct inode *inode,\n \tif ((start >= end) || (start > max_block))\n \t\treturn 0;\n \n+\tif (start >= max_block || end >= max_block) {\n+\t\tpr_warn(\"ext4: block number out of bounds in inode %lu\\n\", inode->i_ino);\n+\t\treturn -EINVAL;\n+\t}\n+\n \tn = ext4_block_to_path(inode, start, offsets, NULL);\n \tn2 = ext4_block_to_path(inode, end, offsets2, NULL);\n \n-\tBUG_ON(n > n2);\n+\tif (n > n2) {\n+\t\tpr_warn(\"ext4: inconsistent path depth in inode %lu\\n\", inode->i_ino);\n+\t\treturn -EIO;\n+\t}\n \n \tif ((n == 1) && (n == n2)) {\n \t\t/* We're punching only within direct block range */\n",
            "diff --git a/fs/ext4/indirect.c b/fs/ext4/indirect.c\nindex 07a8c75b65ed..463c863a441a 100644\n--- a/fs/ext4/indirect.c\n+++ b/fs/ext4/indirect.c\n@@ -1238,10 +1238,18 @@ int ext4_ind_remove_space(handle_t *handle, struct inode *inode,\n \tif ((start >= end) || (start > max_block))\n \t\treturn 0;\n \n+\tif (start >= max_block || end >= max_block) {\n+\t\tpr_warn(\"ext4: block number exceeds maximum allowed value\\n\");\n+\t\treturn -EINVAL;\n+\t}\n+\n \tn = ext4_block_to_path(inode, start, offsets, NULL);\n \tn2 = ext4_block_to_path(inode, end, offsets2, NULL);\n \n-\tBUG_ON(n > n2);\n+\tif (n > n2) {\n+\t\tpr_warn(\"ext4: invalid block path calculation\\n\");\n+\t\treturn -EINVAL;\n+\t}\n \n \tif ((n == 1) && (n == n2)) {\n \t\t/* We're punching only within direct block range */\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/indirect.c b/fs/ext4/indirect.c\nindex 07a8c75b65ed..8b91b141ce2f 100644\n--- a/fs/ext4/indirect.c\n+++ b/fs/ext4/indirect.c\n@@ -1235,7 +1235,9 @@ int ext4_ind_remove_space(handle_t *handle, struct inode *inode,\n \t\t\t\t\t>> EXT4_BLOCK_SIZE_BITS(inode->i_sb);\n \tif (end >= max_block)\n \t\tend = max_block;\n-\tif ((start >= end) || (start > max_block))\n+\tif (start >= max_block)\n+\t\tstart = max_block - 1;\n+\tif (start >= end)\n \t\treturn 0;\n \n \tn = ext4_block_to_path(inode, start, offsets, NULL);\n"
        ],
        "error": []
    },
    "92a742e993c8b9e769f8502a0497c88c0afa78af": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/net/can/usb/gs_usb.c b/drivers/net/can/usb/gs_usb.c\nindex 67408e316062..66b4eb4714c0 100644\n--- a/drivers/net/can/usb/gs_usb.c\n+++ b/drivers/net/can/usb/gs_usb.c\n@@ -1199,6 +1199,10 @@ static int gs_usb_probe(struct usb_interface *intf,\n \t\t\t\tgs_destroy_candev(dev->canch[i]);\n \n \t\t\tusb_kill_anchored_urbs(&dev->rx_submitted);\n+\t\t\tfor (i = 0; i < icount; i++) {\n+\t\t\t\tif (dev->canch[i])\n+\t\t\t\t\tgs_destroy_candev(dev->canch[i]);\n+\t\t\t}\n \t\t\tkfree(dconf);\n \t\t\tkfree(dev);\n \t\t\treturn rc;\n",
            "diff --git a/drivers/net/can/usb/gs_usb.c b/drivers/net/can/usb/gs_usb.c\nindex 67408e316062..a813e5a8c24e 100644\n--- a/drivers/net/can/usb/gs_usb.c\n+++ b/drivers/net/can/usb/gs_usb.c\n@@ -1199,6 +1199,8 @@ static int gs_usb_probe(struct usb_interface *intf,\n \t\t\t\tgs_destroy_candev(dev->canch[i]);\n \n \t\t\tusb_kill_anchored_urbs(&dev->rx_submitted);\n+\t\t\tfor (int j = 0; j < i; j++)\n+\t\t\t\tgs_destroy_candev(dev->canch[j]);\n \t\t\tkfree(dconf);\n \t\t\tkfree(dev);\n \t\t\treturn rc;\n",
            "diff --git a/drivers/net/can/usb/gs_usb.c b/drivers/net/can/usb/gs_usb.c\nindex 67408e316062..a813e5a8c24e 100644\n--- a/drivers/net/can/usb/gs_usb.c\n+++ b/drivers/net/can/usb/gs_usb.c\n@@ -1199,6 +1199,8 @@ static int gs_usb_probe(struct usb_interface *intf,\n \t\t\t\tgs_destroy_candev(dev->canch[i]);\n \n \t\t\tusb_kill_anchored_urbs(&dev->rx_submitted);\n+\t\t\tfor (int j = 0; j < i; j++)\n+\t\t\t\tgs_destroy_candev(dev->canch[j]);\n \t\t\tkfree(dconf);\n \t\t\tkfree(dev);\n \t\t\treturn rc;\n",
            "diff --git a/drivers/net/can/usb/gs_usb.c b/drivers/net/can/usb/gs_usb.c\nindex 67408e316062..a813e5a8c24e 100644\n--- a/drivers/net/can/usb/gs_usb.c\n+++ b/drivers/net/can/usb/gs_usb.c\n@@ -1199,6 +1199,8 @@ static int gs_usb_probe(struct usb_interface *intf,\n \t\t\t\tgs_destroy_candev(dev->canch[i]);\n \n \t\t\tusb_kill_anchored_urbs(&dev->rx_submitted);\n+\t\t\tfor (int j = 0; j < i; j++)\n+\t\t\t\tgs_destroy_candev(dev->canch[j]);\n \t\t\tkfree(dconf);\n \t\t\tkfree(dev);\n \t\t\treturn rc;\n",
            "diff --git a/drivers/net/can/usb/gs_usb.c b/drivers/net/can/usb/gs_usb.c\nindex 67408e316062..a813e5a8c24e 100644\n--- a/drivers/net/can/usb/gs_usb.c\n+++ b/drivers/net/can/usb/gs_usb.c\n@@ -1199,6 +1199,8 @@ static int gs_usb_probe(struct usb_interface *intf,\n \t\t\t\tgs_destroy_candev(dev->canch[i]);\n \n \t\t\tusb_kill_anchored_urbs(&dev->rx_submitted);\n+\t\t\tfor (int j = 0; j < i; j++)\n+\t\t\t\tgs_destroy_candev(dev->canch[j]);\n \t\t\tkfree(dconf);\n \t\t\tkfree(dev);\n \t\t\treturn rc;\n"
        ],
        "error": []
    },
    "e0640a911365faa499433155c3d5d5b674b36a83": {
        "non_crash": [
            "diff --git a/net/netfilter/nfnetlink_cttimeout.c b/net/netfilter/nfnetlink_cttimeout.c\nindex a518eb162344..04470e08882b 100644\n--- a/net/netfilter/nfnetlink_cttimeout.c\n+++ b/net/netfilter/nfnetlink_cttimeout.c\n@@ -475,8 +475,9 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \t\ttimeouts = &nf_generic_pernet(net)->timeout;\n \t\tbreak;\n \tdefault:\n-\t\tWARN_ON_ONCE(1);\n-\t\tbreak;\n+\t\tpr_warn(\"Unsupported protocol number: %u\\n\", l4proto->l4proto);\n+\t\terr = -EOPNOTSUPP;\n+\t\tgoto err;\n \t}\n \n \tif (!timeouts)\n",
            "diff --git a/net/netfilter/nfnetlink_cttimeout.c b/net/netfilter/nfnetlink_cttimeout.c\nindex a518eb162344..b6b9b79e58d0 100644\n--- a/net/netfilter/nfnetlink_cttimeout.c\n+++ b/net/netfilter/nfnetlink_cttimeout.c\n@@ -475,7 +475,7 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \t\ttimeouts = &nf_generic_pernet(net)->timeout;\n \t\tbreak;\n \tdefault:\n-\t\tWARN_ON_ONCE(1);\n+\t\ttimeouts = &nf_generic_pernet(net)->timeout;\n \t\tbreak;\n \t}\n \n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "e1306831b0c04a2ee7705d93be9747c870cadfd5": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/rcu/tree.c b/kernel/rcu/tree.c\nindex a4b8189455d5..4bd29e72a2cb 100644\n--- a/kernel/rcu/tree.c\n+++ b/kernel/rcu/tree.c\n@@ -2624,6 +2624,10 @@ void rcu_sched_clock_irq(int user)\n \trcu_flavor_sched_clock_irq(user);\n \tif (rcu_pending(user))\n \t\tinvoke_rcu_core();\n+\t\n+\t/* Add a preemption point to allow quiescent state reporting */\n+\tcond_resched();\n+\n \tlockdep_assert_irqs_disabled();\n \n \ttrace_rcu_utilization(TPS(\"End scheduler-tick\"));\n",
            "diff --git a/kernel/rcu/tree.c b/kernel/rcu/tree.c\nindex a4b8189455d5..d3d27b06bbf6 100644\n--- a/kernel/rcu/tree.c\n+++ b/kernel/rcu/tree.c\n@@ -2615,7 +2615,7 @@ void rcu_sched_clock_irq(int user)\n \t/* The load-acquire pairs with the store-release setting to true. */\n \tif (smp_load_acquire(this_cpu_ptr(&rcu_data.rcu_urgent_qs))) {\n \t\t/* Idle and userspace execution already are quiescent states. */\n-\t\tif (!rcu_is_cpu_rrupt_from_idle() && !user) {\n+\t\tif (!rcu_is_cpu_rrupt_from_idle() || !user) {\n \t\t\tset_tsk_need_resched(current);\n \t\t\tset_preempt_need_resched();\n \t\t}\n",
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex a0a36bfa3aa0..9c6831d8bc1b 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -348,6 +348,7 @@ int __mnt_want_write(struct vfsmount *m)\n \twhile (READ_ONCE(mnt->mnt.mnt_flags) & MNT_WRITE_HOLD) {\n \t\tif (!IS_ENABLED(CONFIG_PREEMPT_RT)) {\n \t\t\tcpu_relax();\n+\t\t\tcond_resched(); // Add conditional rescheduling to avoid long stalls\n \t\t} else {\n \t\t\t/*\n \t\t\t * This prevents priority inversion, if the task\ndiff --git a/kernel/rcu/tree.c b/kernel/rcu/tree.c\nindex a4b8189455d5..96b920f323aa 100644\n--- a/kernel/rcu/tree.c\n+++ b/kernel/rcu/tree.c\n@@ -2618,6 +2618,7 @@ void rcu_sched_clock_irq(int user)\n \t\tif (!rcu_is_cpu_rrupt_from_idle() && !user) {\n \t\t\tset_tsk_need_resched(current);\n \t\t\tset_preempt_need_resched();\n+\t\t\tcond_resched(); // Add conditional rescheduling to avoid long stalls\n \t\t}\n \t\t__this_cpu_write(rcu_data.rcu_urgent_qs, false);\n \t}\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/namespace.c b/fs/namespace.c\nindex a0a36bfa3aa0..92bcdcef3b14 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -336,7 +336,7 @@ int __mnt_want_write(struct vfsmount *m)\n \tstruct mount *mnt = real_mount(m);\n \tint ret = 0;\n \n-\tpreempt_disable();\n+\trcu_read_lock(); // Use RCU read lock to avoid blocking RCU processing\n \tmnt_inc_writers(mnt);\n \t/*\n \t * The store to mnt_inc_writers must be visible before we pass\ndiff --git a/kernel/rcu/tree.c b/kernel/rcu/tree.c\nindex a4b8189455d5..e0f3654ed016 100644\n--- a/kernel/rcu/tree.c\n+++ b/kernel/rcu/tree.c\n@@ -2618,6 +2618,7 @@ void rcu_sched_clock_irq(int user)\n \t\tif (!rcu_is_cpu_rrupt_from_idle() && !user) {\n \t\t\tset_tsk_need_resched(current);\n \t\t\tset_preempt_need_resched();\n+\t\t\tcond_resched(); // Add conditional rescheduling to avoid starvation\n \t\t}\n \t\t__this_cpu_write(rcu_data.rcu_urgent_qs, false);\n \t}\n",
                "error_message": "Failed to set up instance"
            },
            {
                "patch": "diff --git a/fs/namespace.c b/fs/namespace.c\nindex a0a36bfa3aa0..dd0513596d1e 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -336,7 +336,7 @@ int __mnt_want_write(struct vfsmount *m)\n \tstruct mount *mnt = real_mount(m);\n \tint ret = 0;\n \n-\tpreempt_disable();\n+\trcu_read_lock(); // Use RCU read lock to avoid blocking\n \tmnt_inc_writers(mnt);\n \t/*\n \t * The store to mnt_inc_writers must be visible before we pass\ndiff --git a/kernel/rcu/tree.c b/kernel/rcu/tree.c\nindex a4b8189455d5..d1a70a4de245 100644\n--- a/kernel/rcu/tree.c\n+++ b/kernel/rcu/tree.c\n@@ -2618,6 +2618,7 @@ void rcu_sched_clock_irq(int user)\n \t\tif (!rcu_is_cpu_rrupt_from_idle() && !user) {\n \t\t\tset_tsk_need_resched(current);\n \t\t\tset_preempt_need_resched();\n+\t\t\tcond_resched(); // Force a reschedule to report quiescent state\n \t\t}\n \t\t__this_cpu_write(rcu_data.rcu_urgent_qs, false);\n \t}\n",
                "error_message": "Failed to set up instance"
            }
        ]
    },
    "0264f823322ea8600fbe3fb7e9e016569ca542d8": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex b98ec6e1a222..b2788729dc9d 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -2596,6 +2596,14 @@ static size_t __vb2_perform_fileio(struct vb2_queue *q, char __user *data, size_\n \t}\n \tfileio = q->fileio;\n \n+\t/*\n+\t * Ensure fileio is valid before proceeding.\n+\t */\n+\tif (!fileio) {\n+\t\tdprintk(1, \"fileio is NULL, aborting operation\\n\");\n+\t\treturn -EINVAL;\n+\t}\n+\n \t/*\n \t * Check if we need to dequeue the buffer.\n \t */\n",
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex b98ec6e1a222..f809b83f6489 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -2596,6 +2596,11 @@ static size_t __vb2_perform_fileio(struct vb2_queue *q, char __user *data, size_\n \t}\n \tfileio = q->fileio;\n \n+\tif (!fileio) {\n+\t\tdprintk(3, \"fileio is NULL, aborting operation\\n\");\n+\t\treturn -EINVAL;\n+\t}\n+\n \t/*\n \t * Check if we need to dequeue the buffer.\n \t */\n",
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex b98ec6e1a222..dadf358e68cd 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -2596,6 +2596,11 @@ static size_t __vb2_perform_fileio(struct vb2_queue *q, char __user *data, size_\n \t}\n \tfileio = q->fileio;\n \n+\tif (!fileio) {\n+\t\tdprintk(1, \"fileio is NULL, operation cannot proceed\\n\");\n+\t\treturn -EINVAL;\n+\t}\n+\n \t/*\n \t * Check if we need to dequeue the buffer.\n \t */\n",
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex b98ec6e1a222..196f5122ecfc 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -2542,6 +2542,9 @@ static int __vb2_init_fileio(struct vb2_queue *q, int read)\n static int __vb2_cleanup_fileio(struct vb2_queue *q)\n {\n \tstruct vb2_fileio_data *fileio = q->fileio;\n+\tif (!fileio) {\n+\t\treturn -EINVAL; // Return an error if fileio is not initialized\n+\t}\n \n \tif (fileio) {\n \t\tvb2_core_streamoff(q, q->type);\n",
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex b98ec6e1a222..2f2988acc863 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -2596,6 +2596,11 @@ static size_t __vb2_perform_fileio(struct vb2_queue *q, char __user *data, size_\n \t}\n \tfileio = q->fileio;\n \n+\tif (!fileio) {\n+\t\tdprintk(1, \"fileio is NULL, aborting operation\\n\");\n+\t\treturn -EINVAL;\n+\t}\n+\n \t/*\n \t * Check if we need to dequeue the buffer.\n \t */\n"
        ],
        "error": []
    },
    "6e96f5bd56bfecdaa0bfeaf2695a25cc80bfbd9a": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netfilter/ipset/ip_set_core.c b/net/netfilter/ipset/ip_set_core.c\nindex 8dd17589217d..b6daa410e23b 100644\n--- a/net/netfilter/ipset/ip_set_core.c\n+++ b/net/netfilter/ipset/ip_set_core.c\n@@ -399,7 +399,8 @@ ip_set_comment_free(struct ip_set *set, void *ptr)\n \tc = rcu_dereference_protected(comment->c, 1);\n \tif (unlikely(!c))\n \t\treturn;\n-\tset->ext_size -= sizeof(*c) + strlen(c->str) + 1;\n+\tif (likely(c->str))\n+\t\tset->ext_size -= sizeof(*c) + strlen(c->str) + 1;\n \tkfree_rcu(c, rcu);\n \trcu_assign_pointer(comment->c, NULL);\n }\n",
            "diff --git a/net/netfilter/ipset/ip_set_core.c b/net/netfilter/ipset/ip_set_core.c\nindex 8dd17589217d..b6daa410e23b 100644\n--- a/net/netfilter/ipset/ip_set_core.c\n+++ b/net/netfilter/ipset/ip_set_core.c\n@@ -399,7 +399,8 @@ ip_set_comment_free(struct ip_set *set, void *ptr)\n \tc = rcu_dereference_protected(comment->c, 1);\n \tif (unlikely(!c))\n \t\treturn;\n-\tset->ext_size -= sizeof(*c) + strlen(c->str) + 1;\n+\tif (likely(c->str))\n+\t\tset->ext_size -= sizeof(*c) + strlen(c->str) + 1;\n \tkfree_rcu(c, rcu);\n \trcu_assign_pointer(comment->c, NULL);\n }\n",
            "diff --git a/net/netfilter/ipset/ip_set_core.c b/net/netfilter/ipset/ip_set_core.c\nindex 8dd17589217d..f26b103ac6db 100644\n--- a/net/netfilter/ipset/ip_set_core.c\n+++ b/net/netfilter/ipset/ip_set_core.c\n@@ -397,7 +397,7 @@ ip_set_comment_free(struct ip_set *set, void *ptr)\n \tstruct ip_set_comment_rcu *c;\n \n \tc = rcu_dereference_protected(comment->c, 1);\n-\tif (unlikely(!c))\n+\tif (unlikely(!c || !c->str))\n \t\treturn;\n \tset->ext_size -= sizeof(*c) + strlen(c->str) + 1;\n \tkfree_rcu(c, rcu);\n",
            "diff --git a/net/netfilter/ipset/ip_set_core.c b/net/netfilter/ipset/ip_set_core.c\nindex 8dd17589217d..689dbaba893a 100644\n--- a/net/netfilter/ipset/ip_set_core.c\n+++ b/net/netfilter/ipset/ip_set_core.c\n@@ -399,7 +399,9 @@ ip_set_comment_free(struct ip_set *set, void *ptr)\n \tc = rcu_dereference_protected(comment->c, 1);\n \tif (unlikely(!c))\n \t\treturn;\n-\tset->ext_size -= sizeof(*c) + strlen(c->str) + 1;\n+\tif (c->str) {\n+\t\tset->ext_size -= sizeof(*c) + strlen(c->str) + 1;\n+\t}\n \tkfree_rcu(c, rcu);\n \trcu_assign_pointer(comment->c, NULL);\n }\n",
            "diff --git a/net/netfilter/ipset/ip_set_core.c b/net/netfilter/ipset/ip_set_core.c\nindex 8dd17589217d..689dbaba893a 100644\n--- a/net/netfilter/ipset/ip_set_core.c\n+++ b/net/netfilter/ipset/ip_set_core.c\n@@ -399,7 +399,9 @@ ip_set_comment_free(struct ip_set *set, void *ptr)\n \tc = rcu_dereference_protected(comment->c, 1);\n \tif (unlikely(!c))\n \t\treturn;\n-\tset->ext_size -= sizeof(*c) + strlen(c->str) + 1;\n+\tif (c->str) {\n+\t\tset->ext_size -= sizeof(*c) + strlen(c->str) + 1;\n+\t}\n \tkfree_rcu(c, rcu);\n \trcu_assign_pointer(comment->c, NULL);\n }\n"
        ],
        "error": []
    },
    "32577e96d88447ded2d3b76d71254fb855245837": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/video/fbdev/core/bitblit.c b/drivers/video/fbdev/core/bitblit.c\nindex 9725ecd1255b..263140b9cb52 100644\n--- a/drivers/video/fbdev/core/bitblit.c\n+++ b/drivers/video/fbdev/core/bitblit.c\n@@ -87,17 +87,31 @@ static inline void bit_putcs_aligned(struct vc_data *vc, struct fb_info *info,\n \t\tsrc = vc->vc_font.data + (scr_readw(s++)&\n \t\t\t\t\t  charmask)*cellsize;\n \n+\t\tif (!src) {\n+\t\t\tpr_err(\"bit_putcs: src pointer is NULL\\n\");\n+\t\t\treturn;\n+\t\t}\n+\n \t\tif (attr) {\n \t\t\tupdate_attr(buf, src, attr, vc);\n \t\t\tsrc = buf;\n \t\t}\n \n-\t\tif (likely(idx == 1))\n+\t\tif (likely(idx == 1)) {\n+\t\t\tif (!dst) {\n+\t\t\t\tpr_err(\"bit_putcs: dst pointer is NULL\\n\");\n+\t\t\t\treturn;\n+\t\t\t}\n \t\t\t__fb_pad_aligned_buffer(dst, d_pitch, src, idx,\n \t\t\t\t\t\timage->height);\n-\t\telse\n+\t\t} else {\n+\t\t\tif (!dst) {\n+\t\t\t\tpr_err(\"bit_putcs: dst pointer is NULL\\n\");\n+\t\t\t\treturn;\n+\t\t\t}\n \t\t\tfb_pad_aligned_buffer(dst, d_pitch, src, idx,\n \t\t\t\t\t      image->height);\n+\t\t}\n \n \t\tdst += s_pitch;\n \t}\n",
            "diff --git a/drivers/video/fbdev/core/bitblit.c b/drivers/video/fbdev/core/bitblit.c\nindex 9725ecd1255b..3eb3304fa746 100644\n--- a/drivers/video/fbdev/core/bitblit.c\n+++ b/drivers/video/fbdev/core/bitblit.c\n@@ -179,6 +179,10 @@ static void bit_putcs(struct vc_data *vc, struct fb_info *info,\n \t\tsize = pitch * image.height + buf_align;\n \t\tsize &= ~buf_align;\n \t\tdst = fb_get_buffer_offset(info, &info->pixmap, size);\n+\t\tif (!dst) {\n+\t\t\tpr_err(\"Failed to get buffer offset\\n\");\n+\t\t\treturn;\n+\t\t}\n \t\timage.data = dst;\n \n \t\tif (!mod)\n",
            "diff --git a/drivers/video/fbdev/core/bitblit.c b/drivers/video/fbdev/core/bitblit.c\nindex 9725ecd1255b..3eb3304fa746 100644\n--- a/drivers/video/fbdev/core/bitblit.c\n+++ b/drivers/video/fbdev/core/bitblit.c\n@@ -179,6 +179,10 @@ static void bit_putcs(struct vc_data *vc, struct fb_info *info,\n \t\tsize = pitch * image.height + buf_align;\n \t\tsize &= ~buf_align;\n \t\tdst = fb_get_buffer_offset(info, &info->pixmap, size);\n+\t\tif (!dst) {\n+\t\t\tpr_err(\"Failed to get buffer offset\\n\");\n+\t\t\treturn;\n+\t\t}\n \t\timage.data = dst;\n \n \t\tif (!mod)\n",
            "diff --git a/drivers/video/fbdev/core/bitblit.c b/drivers/video/fbdev/core/bitblit.c\nindex 9725ecd1255b..fc23d85c43fb 100644\n--- a/drivers/video/fbdev/core/bitblit.c\n+++ b/drivers/video/fbdev/core/bitblit.c\n@@ -87,6 +87,11 @@ static inline void bit_putcs_aligned(struct vc_data *vc, struct fb_info *info,\n \t\tsrc = vc->vc_font.data + (scr_readw(s++)&\n \t\t\t\t\t  charmask)*cellsize;\n \n+\t\tif (!src) {\n+\t\t\tpr_err(\"Invalid source pointer\\n\");\n+\t\t\treturn;\n+\t\t}\n+\n \t\tif (attr) {\n \t\t\tupdate_attr(buf, src, attr, vc);\n \t\t\tsrc = buf;\n",
            "diff --git a/drivers/video/fbdev/core/bitblit.c b/drivers/video/fbdev/core/bitblit.c\nindex 9725ecd1255b..aed9a5e97792 100644\n--- a/drivers/video/fbdev/core/bitblit.c\n+++ b/drivers/video/fbdev/core/bitblit.c\n@@ -92,14 +92,18 @@ static inline void bit_putcs_aligned(struct vc_data *vc, struct fb_info *info,\n \t\t\tsrc = buf;\n \t\t}\n \n-\t\tif (likely(idx == 1))\n-\t\t\t__fb_pad_aligned_buffer(dst, d_pitch, src, idx,\n-\t\t\t\t\t\timage->height);\n-\t\telse\n-\t\t\tfb_pad_aligned_buffer(dst, d_pitch, src, idx,\n-\t\t\t\t\t      image->height);\n+\t\tif (likely(idx == 1)) {\n+\t\t\tif (src && dst) // Ensure src and dst are valid\n+\t\t\t\t__fb_pad_aligned_buffer(dst, d_pitch, src, idx,\n+\t\t\t\t\t\t\timage->height);\n+\t\t} else {\n+\t\t\tif (src && dst) // Ensure src and dst are valid\n+\t\t\t\tfb_pad_aligned_buffer(dst, d_pitch, src, idx,\n+\t\t\t\t\t\t      image->height);\n+\t\t}\n \n-\t\tdst += s_pitch;\n+\t\tif (dst) // Ensure dst is valid before incrementing\n+\t\t\tdst += s_pitch;\n \t}\n \n \tinfo->fbops->fb_imageblit(info, image);\n"
        ],
        "error": []
    },
    "5b79a616feb996279758323aba4031c57f80a8bc": {
        "non_crash": [
            "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex 9a0ae59cdc50..d5ed0a47aac6 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1147,8 +1147,11 @@ static int do_replace(struct net *net, sockptr_t arg, unsigned int len)\n \t}\n \n \tret = do_replace_finish(net, &tmp, newinfo);\n-\tif (ret == 0)\n+\tif (ret == 0) {\n+\t\tvfree(newinfo->entries);\n+\t\tvfree(newinfo);\n \t\treturn ret;\n+\t}\n free_entries:\n \tvfree(newinfo->entries);\n free_newinfo:\n",
            "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex 9a0ae59cdc50..d5ed0a47aac6 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1147,8 +1147,11 @@ static int do_replace(struct net *net, sockptr_t arg, unsigned int len)\n \t}\n \n \tret = do_replace_finish(net, &tmp, newinfo);\n-\tif (ret == 0)\n+\tif (ret == 0) {\n+\t\tvfree(newinfo->entries);\n+\t\tvfree(newinfo);\n \t\treturn ret;\n+\t}\n free_entries:\n \tvfree(newinfo->entries);\n free_newinfo:\n",
            "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex 9a0ae59cdc50..d5ed0a47aac6 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1147,8 +1147,11 @@ static int do_replace(struct net *net, sockptr_t arg, unsigned int len)\n \t}\n \n \tret = do_replace_finish(net, &tmp, newinfo);\n-\tif (ret == 0)\n+\tif (ret == 0) {\n+\t\tvfree(newinfo->entries);\n+\t\tvfree(newinfo);\n \t\treturn ret;\n+\t}\n free_entries:\n \tvfree(newinfo->entries);\n free_newinfo:\n",
            "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex 9a0ae59cdc50..d5ed0a47aac6 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1147,8 +1147,11 @@ static int do_replace(struct net *net, sockptr_t arg, unsigned int len)\n \t}\n \n \tret = do_replace_finish(net, &tmp, newinfo);\n-\tif (ret == 0)\n+\tif (ret == 0) {\n+\t\tvfree(newinfo->entries);\n+\t\tvfree(newinfo);\n \t\treturn ret;\n+\t}\n free_entries:\n \tvfree(newinfo->entries);\n free_newinfo:\n",
            "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex 9a0ae59cdc50..d5ed0a47aac6 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1147,8 +1147,11 @@ static int do_replace(struct net *net, sockptr_t arg, unsigned int len)\n \t}\n \n \tret = do_replace_finish(net, &tmp, newinfo);\n-\tif (ret == 0)\n+\tif (ret == 0) {\n+\t\tvfree(newinfo->entries);\n+\t\tvfree(newinfo);\n \t\treturn ret;\n+\t}\n free_entries:\n \tvfree(newinfo->entries);\n free_newinfo:\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "362b5b49fced29361c0ba3007a2b3e5cd13776b5": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c\nindex c447526288f4..2535eb62d7ae 100644\n--- a/drivers/infiniband/core/cma.c\n+++ b/drivers/infiniband/core/cma.c\n@@ -2597,6 +2597,7 @@ static int cma_listen_on_all(struct rdma_id_private *id_priv)\n \t\t\t/* Prevent racing with cma_process_remove() */\n \t\t\tif (to_destroy)\n \t\t\t\tlist_del_init(&to_destroy->device_item);\n+\t\t\tlist_del_init(&id_priv->listen_any_item); // Ensure id_priv is removed from listen_any_list\n \t\t\tgoto err_listen;\n \t\t}\n \t}\n@@ -2604,6 +2605,7 @@ static int cma_listen_on_all(struct rdma_id_private *id_priv)\n \treturn 0;\n \n err_listen:\n+\tlist_del_init(&id_priv->listen_any_item); // Ensure id_priv is removed from listen_any_list\n \t_cma_cancel_listens(id_priv);\n \tmutex_unlock(&lock);\n \tif (to_destroy)\n",
            "diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c\nindex c447526288f4..6876f22583cc 100644\n--- a/drivers/infiniband/core/cma.c\n+++ b/drivers/infiniband/core/cma.c\n@@ -2574,7 +2574,9 @@ static int cma_listen_on_dev(struct rdma_id_private *id_priv,\n \tret = rdma_listen(&dev_id_priv->id, id_priv->backlog);\n \tif (ret)\n \t\tgoto err_listen;\n-\tlist_add_tail(&dev_id_priv->listen_item, &id_priv->listen_list);\n+\tif (dev_id_priv) {\n+\t\tlist_add_tail(&dev_id_priv->listen_item, &id_priv->listen_list);\n+\t}\n \treturn 0;\n err_listen:\n \t/* Caller must destroy this after releasing lock */\ndiff --git a/drivers/infiniband/core/ucma.c b/drivers/infiniband/core/ucma.c\nindex 9d6ac9dff39a..b47d7e45fc18 100644\n--- a/drivers/infiniband/core/ucma.c\n+++ b/drivers/infiniband/core/ucma.c\n@@ -184,7 +184,10 @@ static void ucma_close_id(struct work_struct *work)\n \tucma_put_ctx(ctx);\n \twait_for_completion(&ctx->comp);\n \t/* No new events will be generated after destroying the id. */\n-\trdma_destroy_id(ctx->cm_id);\n+\tif (ctx->cm_id) {\n+\t\trdma_destroy_id(ctx->cm_id);\n+\t\tctx->cm_id = NULL;\n+\t}\n \n \t/* Reading the cm_id without holding a positive ref is not allowed */\n \tctx->cm_id = NULL;\n",
            "diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c\nindex c447526288f4..4337d02a0d2b 100644\n--- a/drivers/infiniband/core/cma.c\n+++ b/drivers/infiniband/core/cma.c\n@@ -2590,6 +2590,11 @@ static int cma_listen_on_all(struct rdma_id_private *id_priv)\n \tint ret;\n \n \tmutex_lock(&lock);\n+\tif (!id_priv || id_priv->state == RDMA_CM_DESTROYING) {\n+\t\tmutex_unlock(&lock);\n+\t\treturn -EINVAL;\n+\t}\n+\n \tlist_add_tail(&id_priv->listen_any_item, &listen_any_list);\n \tlist_for_each_entry(cma_dev, &dev_list, list) {\n \t\tret = cma_listen_on_dev(id_priv, cma_dev, &to_destroy);\n",
            "diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c\nindex c447526288f4..cd70ae3c2a98 100644\n--- a/drivers/infiniband/core/cma.c\n+++ b/drivers/infiniband/core/cma.c\n@@ -2595,8 +2595,11 @@ static int cma_listen_on_all(struct rdma_id_private *id_priv)\n \t\tret = cma_listen_on_dev(id_priv, cma_dev, &to_destroy);\n \t\tif (ret) {\n \t\t\t/* Prevent racing with cma_process_remove() */\n-\t\t\tif (to_destroy)\n+\t\t\tif (to_destroy) {\n \t\t\t\tlist_del_init(&to_destroy->device_item);\n+\t\t\t\trdma_destroy_id(&to_destroy->id);\n+\t\t\t\tto_destroy = NULL;\n+\t\t\t}\n \t\t\tgoto err_listen;\n \t\t}\n \t}\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c\nindex c447526288f4..0339356b2fd8 100644\n--- a/drivers/infiniband/core/cma.c\n+++ b/drivers/infiniband/core/cma.c\n@@ -2575,11 +2575,15 @@ static int cma_listen_on_dev(struct rdma_id_private *id_priv,\n \tif (ret)\n \t\tgoto err_listen;\n \tlist_add_tail(&dev_id_priv->listen_item, &id_priv->listen_list);\n+\t/* Increment reference count to prevent premature free */\n+\trefcount_inc(&dev_id_priv->refcount);\n \treturn 0;\n err_listen:\n \t/* Caller must destroy this after releasing lock */\n \t*to_destroy = dev_id_priv;\n \tdev_warn(&cma_dev->device->dev, \"RDMA CMA: %s, error %d\\n\", __func__, ret);\n+\t/* Decrement reference count as listen failed */\n+\trefcount_dec(&dev_id_priv->refcount);\n \treturn ret;\n }\n \ndiff --git a/drivers/infiniband/core/ucma.c b/drivers/infiniband/core/ucma.c\nindex 9d6ac9dff39a..a5d39eb3b61c 100644\n--- a/drivers/infiniband/core/ucma.c\n+++ b/drivers/infiniband/core/ucma.c\n@@ -184,10 +184,11 @@ static void ucma_close_id(struct work_struct *work)\n \tucma_put_ctx(ctx);\n \twait_for_completion(&ctx->comp);\n \t/* No new events will be generated after destroying the id. */\n-\trdma_destroy_id(ctx->cm_id);\n-\n-\t/* Reading the cm_id without holding a positive ref is not allowed */\n-\tctx->cm_id = NULL;\n+\t/* Ensure cm_id is not destroyed prematurely */\n+\tif (refcount_dec_and_test(&ctx->cm_id->refcount)) {\n+\t\trdma_destroy_id(ctx->cm_id);\n+\t\tctx->cm_id = NULL;\n+\t}\n }\n \n static struct ucma_context *ucma_alloc_ctx(struct ucma_file *file)\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "1860a98f3556d97065ad773d095aa1d7eb5fbafa": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/smc/af_smc.c b/net/smc/af_smc.c\nindex 14ddc40149e8..96b9a892ad2d 100644\n--- a/net/smc/af_smc.c\n+++ b/net/smc/af_smc.c\n@@ -3085,8 +3085,10 @@ static int __smc_create(struct net *net, struct socket *sock, int protocol,\n \trc = -ENOBUFS;\n \tsock->ops = &smc_sock_ops;\n \tsk = smc_sock_alloc(net, sock, protocol);\n-\tif (!sk)\n+\tif (!sk) {\n+\t\tsk_common_release(sock->sk);\n \t\tgoto out;\n+\t}\n \n \t/* create internal TCP socket for CLC handshake and fallback */\n \tsmc = smc_sk(sk);\n",
            "diff --git a/net/smc/af_smc.c b/net/smc/af_smc.c\nindex 14ddc40149e8..d749815a70cc 100644\n--- a/net/smc/af_smc.c\n+++ b/net/smc/af_smc.c\n@@ -3102,7 +3102,7 @@ static int __smc_create(struct net *net, struct socket *sock, int protocol,\n \t\t\t\t      &smc->clcsock);\n \t\tif (rc) {\n \t\t\tsk_common_release(sk);\n-\t\t\tgoto out;\n+\t\t\tgoto cleanup_sk;\n \t\t}\n \t} else {\n \t\tsmc->clcsock = clcsock;\n@@ -3111,6 +3111,8 @@ static int __smc_create(struct net *net, struct socket *sock, int protocol,\n \tsmc->sk.sk_sndbuf = max(smc->clcsock->sk->sk_sndbuf, SMC_BUF_MIN_SIZE);\n \tsmc->sk.sk_rcvbuf = max(smc->clcsock->sk->sk_rcvbuf, SMC_BUF_MIN_SIZE);\n \n+cleanup_sk:\n+\tsk_common_release(sk);\n out:\n \treturn rc;\n }\n",
            "diff --git a/net/smc/af_smc.c b/net/smc/af_smc.c\nindex 14ddc40149e8..8106f2677f2d 100644\n--- a/net/smc/af_smc.c\n+++ b/net/smc/af_smc.c\n@@ -297,8 +297,10 @@ static int smc_release(struct socket *sock)\n \tstruct smc_sock *smc;\n \tint old_state, rc = 0;\n \n-\tif (!sk)\n+\tif (!sk) {\n+\t\tsk_common_release(sock->sk);\n \t\tgoto out;\n+\t}\n \n \tsock_hold(sk); /* sock_put below */\n \tsmc = smc_sk(sk);\n",
            "diff --git a/net/smc/af_smc.c b/net/smc/af_smc.c\nindex 14ddc40149e8..8287d8e31a37 100644\n--- a/net/smc/af_smc.c\n+++ b/net/smc/af_smc.c\n@@ -3101,6 +3101,7 @@ static int __smc_create(struct net *net, struct socket *sock, int protocol,\n \t\trc = sock_create_kern(net, family, SOCK_STREAM, IPPROTO_TCP,\n \t\t\t\t      &smc->clcsock);\n \t\tif (rc) {\n+\t\t\tsock->ops = NULL;\n \t\t\tsk_common_release(sk);\n \t\t\tgoto out;\n \t\t}\n",
            "diff --git a/net/smc/af_smc.c b/net/smc/af_smc.c\nindex 14ddc40149e8..899218c448f1 100644\n--- a/net/smc/af_smc.c\n+++ b/net/smc/af_smc.c\n@@ -297,8 +297,10 @@ static int smc_release(struct socket *sock)\n \tstruct smc_sock *smc;\n \tint old_state, rc = 0;\n \n-\tif (!sk)\n+\tif (!sk) {\n+\t\tsk_common_release(sk);\n \t\tgoto out;\n+\t}\n \n \tsock_hold(sk); /* sock_put below */\n \tsmc = smc_sk(sk);\n"
        ],
        "error": []
    },
    "848057f402cb7a9107901060c07f48cd2e00e0e9": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/drivers/scsi/scsi_proc.c b/drivers/scsi/scsi_proc.c\nindex 4a6eb1741be0..427f10b36a8a 100644\n--- a/drivers/scsi/scsi_proc.c\n+++ b/drivers/scsi/scsi_proc.c\n@@ -203,6 +203,10 @@ void scsi_proc_hostdir_rm(const struct scsi_host_template *sht)\n \tmutex_lock(&global_host_template_mutex);\n \te = __scsi_lookup_proc_entry(sht);\n \tif (e && !--e->present) {\n+\t\tstruct proc_dir_entry *child, *tmp;\n+\t\tlist_for_each_entry_safe(child, tmp, &e->entry.children, sibling) {\n+\t\t\tremove_proc_entry(child->name, child->parent);\n+\t\t}\n \t\tremove_proc_entry(sht->proc_name, proc_scsi);\n \t\tlist_del(&e->entry);\n \t\tkfree(e);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/scsi/scsi_proc.c b/drivers/scsi/scsi_proc.c\nindex 4a6eb1741be0..b021aea317ec 100644\n--- a/drivers/scsi/scsi_proc.c\n+++ b/drivers/scsi/scsi_proc.c\n@@ -203,6 +203,11 @@ void scsi_proc_hostdir_rm(const struct scsi_host_template *sht)\n \tmutex_lock(&global_host_template_mutex);\n \te = __scsi_lookup_proc_entry(sht);\n \tif (e && !--e->present) {\n+\t\t// Remove all entries within the directory first\n+\t\tstruct proc_dir_entry *child, *tmp;\n+\t\tlist_for_each_entry_safe(child, tmp, &e->entry.children, sibling) {\n+\t\t\tremove_proc_entry(child->name, child->parent);\n+\t\t}\n \t\tremove_proc_entry(sht->proc_name, proc_scsi);\n \t\tlist_del(&e->entry);\n \t\tkfree(e);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/scsi/scsi_proc.c b/drivers/scsi/scsi_proc.c\nindex 4a6eb1741be0..427f10b36a8a 100644\n--- a/drivers/scsi/scsi_proc.c\n+++ b/drivers/scsi/scsi_proc.c\n@@ -203,6 +203,10 @@ void scsi_proc_hostdir_rm(const struct scsi_host_template *sht)\n \tmutex_lock(&global_host_template_mutex);\n \te = __scsi_lookup_proc_entry(sht);\n \tif (e && !--e->present) {\n+\t\tstruct proc_dir_entry *child, *tmp;\n+\t\tlist_for_each_entry_safe(child, tmp, &e->entry.children, sibling) {\n+\t\t\tremove_proc_entry(child->name, child->parent);\n+\t\t}\n \t\tremove_proc_entry(sht->proc_name, proc_scsi);\n \t\tlist_del(&e->entry);\n \t\tkfree(e);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/scsi/scsi_proc.c b/drivers/scsi/scsi_proc.c\nindex 4a6eb1741be0..af66d6f7fc4d 100644\n--- a/drivers/scsi/scsi_proc.c\n+++ b/drivers/scsi/scsi_proc.c\n@@ -203,6 +203,10 @@ void scsi_proc_hostdir_rm(const struct scsi_host_template *sht)\n \tmutex_lock(&global_host_template_mutex);\n \te = __scsi_lookup_proc_entry(sht);\n \tif (e && !--e->present) {\n+\t\tstruct proc_dir_entry *child, *tmp;\n+\t\tlist_for_each_entry_safe(child, tmp, &e->entry->subdir, subdir) {\n+\t\t\tremove_proc_entry(child->name, e->entry);\n+\t\t}\n \t\tremove_proc_entry(sht->proc_name, proc_scsi);\n \t\tlist_del(&e->entry);\n \t\tkfree(e);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "1bb51491ca5df96a5f724899d1dbb87afda61419": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/bluetooth/hci_conn.c b/net/bluetooth/hci_conn.c\nindex 44d0643fc681..0842334c4963 100644\n--- a/net/bluetooth/hci_conn.c\n+++ b/net/bluetooth/hci_conn.c\n@@ -2481,6 +2481,9 @@ void hci_conn_hash_flush(struct hci_dev *hdev)\n \t\t */\n \t\thci_conn_unlink(c);\n \t\thci_conn_del(c);\n+\n+\t\t/* Ensure no further access to 'c' after deletion */\n+\t\tc = NULL;\n \t}\n }\n \n",
            "diff --git a/net/bluetooth/hci_conn.c b/net/bluetooth/hci_conn.c\nindex 44d0643fc681..753b9892e1d2 100644\n--- a/net/bluetooth/hci_conn.c\n+++ b/net/bluetooth/hci_conn.c\n@@ -2480,7 +2480,10 @@ void hci_conn_hash_flush(struct hci_dev *hdev)\n \t\t * contain items already freed.\n \t\t */\n \t\thci_conn_unlink(c);\n-\t\thci_conn_del(c);\n+\t\t/* Ensure the connection is not accessed after deletion */\n+\t\tif (!list_empty(&c->list)) {\n+\t\t\thci_conn_del(c);\n+\t\t}\n \t}\n }\n \n",
            "diff --git a/net/bluetooth/hci_conn.c b/net/bluetooth/hci_conn.c\nindex 44d0643fc681..c38ca41debb3 100644\n--- a/net/bluetooth/hci_conn.c\n+++ b/net/bluetooth/hci_conn.c\n@@ -2479,7 +2479,6 @@ void hci_conn_hash_flush(struct hci_dev *hdev)\n \t\t * hci_conn_del removes the link which may cause the list to\n \t\t * contain items already freed.\n \t\t */\n-\t\thci_conn_unlink(c);\n \t\thci_conn_del(c);\n \t}\n }\n",
            "diff --git a/net/bluetooth/hci_conn.c b/net/bluetooth/hci_conn.c\nindex 44d0643fc681..c38ca41debb3 100644\n--- a/net/bluetooth/hci_conn.c\n+++ b/net/bluetooth/hci_conn.c\n@@ -2479,7 +2479,6 @@ void hci_conn_hash_flush(struct hci_dev *hdev)\n \t\t * hci_conn_del removes the link which may cause the list to\n \t\t * contain items already freed.\n \t\t */\n-\t\thci_conn_unlink(c);\n \t\thci_conn_del(c);\n \t}\n }\n",
            "diff --git a/net/bluetooth/hci_conn.c b/net/bluetooth/hci_conn.c\nindex 44d0643fc681..7269731f6dd0 100644\n--- a/net/bluetooth/hci_conn.c\n+++ b/net/bluetooth/hci_conn.c\n@@ -2479,8 +2479,8 @@ void hci_conn_hash_flush(struct hci_dev *hdev)\n \t\t * hci_conn_del removes the link which may cause the list to\n \t\t * contain items already freed.\n \t\t */\n-\t\thci_conn_unlink(c);\n \t\thci_conn_del(c);\n+\t\thci_conn_unlink(c);\n \t}\n }\n \n"
        ],
        "error": []
    },
    "bf3e592d3ed61b8f86b8ffba072adcde5485a5f6": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/include/linux/sched/mm.h b/include/linux/sched/mm.h\nindex 2a243616f222..9c3752915d52 100644\n--- a/include/linux/sched/mm.h\n+++ b/include/linux/sched/mm.h\n@@ -268,8 +268,10 @@ static inline void memalloc_retry_wait(gfp_t gfp_flags)\n  */\n static inline void might_alloc(gfp_t gfp_mask)\n {\n-\tfs_reclaim_acquire(gfp_mask);\n-\tfs_reclaim_release(gfp_mask);\n+\tif (!in_atomic() && !irqs_disabled()) {\n+\t\tfs_reclaim_acquire(gfp_mask);\n+\t\tfs_reclaim_release(gfp_mask);\n+\t}\n \n \tmight_sleep_if(gfpflags_allow_blocking(gfp_mask));\n }\n",
            "diff --git a/include/linux/sched/mm.h b/include/linux/sched/mm.h\nindex 2a243616f222..2372d3f45309 100644\n--- a/include/linux/sched/mm.h\n+++ b/include/linux/sched/mm.h\n@@ -268,8 +268,10 @@ static inline void memalloc_retry_wait(gfp_t gfp_flags)\n  */\n static inline void might_alloc(gfp_t gfp_mask)\n {\n-\tfs_reclaim_acquire(gfp_mask);\n-\tfs_reclaim_release(gfp_mask);\n+\tif (!in_softirq()) {\n+\t\tfs_reclaim_acquire(gfp_mask);\n+\t\tfs_reclaim_release(gfp_mask);\n+\t}\n \n \tmight_sleep_if(gfpflags_allow_blocking(gfp_mask));\n }\n",
            "diff --git a/include/linux/sched/mm.h b/include/linux/sched/mm.h\nindex 2a243616f222..2372d3f45309 100644\n--- a/include/linux/sched/mm.h\n+++ b/include/linux/sched/mm.h\n@@ -268,8 +268,10 @@ static inline void memalloc_retry_wait(gfp_t gfp_flags)\n  */\n static inline void might_alloc(gfp_t gfp_mask)\n {\n-\tfs_reclaim_acquire(gfp_mask);\n-\tfs_reclaim_release(gfp_mask);\n+\tif (!in_softirq()) {\n+\t\tfs_reclaim_acquire(gfp_mask);\n+\t\tfs_reclaim_release(gfp_mask);\n+\t}\n \n \tmight_sleep_if(gfpflags_allow_blocking(gfp_mask));\n }\n",
            "diff --git a/include/linux/sched/mm.h b/include/linux/sched/mm.h\nindex 2a243616f222..2372d3f45309 100644\n--- a/include/linux/sched/mm.h\n+++ b/include/linux/sched/mm.h\n@@ -268,8 +268,10 @@ static inline void memalloc_retry_wait(gfp_t gfp_flags)\n  */\n static inline void might_alloc(gfp_t gfp_mask)\n {\n-\tfs_reclaim_acquire(gfp_mask);\n-\tfs_reclaim_release(gfp_mask);\n+\tif (!in_softirq()) {\n+\t\tfs_reclaim_acquire(gfp_mask);\n+\t\tfs_reclaim_release(gfp_mask);\n+\t}\n \n \tmight_sleep_if(gfpflags_allow_blocking(gfp_mask));\n }\n",
            "diff --git a/include/linux/sched/mm.h b/include/linux/sched/mm.h\nindex 2a243616f222..4369d7fb0dfd 100644\n--- a/include/linux/sched/mm.h\n+++ b/include/linux/sched/mm.h\n@@ -268,8 +268,10 @@ static inline void memalloc_retry_wait(gfp_t gfp_flags)\n  */\n static inline void might_alloc(gfp_t gfp_mask)\n {\n-\tfs_reclaim_acquire(gfp_mask);\n-\tfs_reclaim_release(gfp_mask);\n+\tif (!in_interrupt()) {\n+\t\tfs_reclaim_acquire(gfp_mask);\n+\t\tfs_reclaim_release(gfp_mask);\n+\t}\n \n \tmight_sleep_if(gfpflags_allow_blocking(gfp_mask));\n }\ndiff --git a/mm/slab.h b/mm/slab.h\nindex 4ec82bec15ec..5a1ee5f73a2d 100644\n--- a/mm/slab.h\n+++ b/mm/slab.h\n@@ -697,7 +697,9 @@ static inline struct kmem_cache *slab_pre_alloc_hook(struct kmem_cache *s,\n {\n \tflags &= gfp_allowed_mask;\n \n-\tmight_alloc(flags);\n+\tif (!in_interrupt()) {\n+\t\tmight_alloc(flags);\n+\t}\n \n \tif (should_failslab(s, flags))\n \t\treturn NULL;\n"
        ],
        "error": []
    },
    "0be4824a86385f022a4f6f5104bcb9246032fdd9": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/sound/core/oss/pcm_plugin.c b/sound/core/oss/pcm_plugin.c\nindex 061ba06bc926..07fbfaf0f12a 100644\n--- a/sound/core/oss/pcm_plugin.c\n+++ b/sound/core/oss/pcm_plugin.c\n@@ -62,10 +62,16 @@ static int snd_pcm_plugin_alloc(struct snd_pcm_plugin *plugin, snd_pcm_uframes_t\n \twidth = snd_pcm_format_physical_width(format->format);\n \tif (width < 0)\n \t\treturn width;\n+\tif (frames <= 0 || format->channels <= 0 || width <= 0)\n+\t\treturn -EINVAL;\n+\tif (frames > SIZE_MAX / (format->channels * width))\n+\t\treturn -EINVAL;\n \tsize = frames * format->channels * width;\n \tif (snd_BUG_ON(size % 8))\n \t\treturn -ENXIO;\n \tsize /= 8;\n+\tif (size == 0)\n+\t\treturn -EINVAL;\n \tif (plugin->buf_frames < frames) {\n \t\tkvfree(plugin->buf);\n \t\tplugin->buf = kvzalloc(size, GFP_KERNEL);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/sound/core/oss/pcm_oss.c b/sound/core/oss/pcm_oss.c\nindex 3ee9edf85815..06433867b11a 100644\n--- a/sound/core/oss/pcm_oss.c\n+++ b/sound/core/oss/pcm_oss.c\n@@ -1066,6 +1066,10 @@ static int snd_pcm_oss_change_params_locked(struct snd_pcm_substream *substream)\n \truntime->oss.rate = params_rate(params);\n \n \tkvfree(runtime->oss.buffer);\n+\tif (runtime->oss.period_bytes == 0 || runtime->oss.period_bytes > MAX_ALLOWED_SIZE) {\n+\t\terr = -EINVAL;\n+\t\tgoto failure;\n+\t}\n \truntime->oss.buffer = kvzalloc(runtime->oss.period_bytes, GFP_KERNEL);\n \tif (!runtime->oss.buffer) {\n \t\terr = -ENOMEM;\ndiff --git a/sound/core/oss/pcm_plugin.c b/sound/core/oss/pcm_plugin.c\nindex 061ba06bc926..37278167aeab 100644\n--- a/sound/core/oss/pcm_plugin.c\n+++ b/sound/core/oss/pcm_plugin.c\n@@ -63,7 +63,7 @@ static int snd_pcm_plugin_alloc(struct snd_pcm_plugin *plugin, snd_pcm_uframes_t\n \tif (width < 0)\n \t\treturn width;\n \tsize = frames * format->channels * width;\n-\tif (snd_BUG_ON(size % 8))\n+\tif (snd_BUG_ON(size % 8) || size == 0 || size > MAX_ALLOWED_SIZE)\n \t\treturn -ENXIO;\n \tsize /= 8;\n \tif (plugin->buf_frames < frames) {\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/sound/core/oss/pcm_plugin.c b/sound/core/oss/pcm_plugin.c\nindex 061ba06bc926..4d8c5d113f5f 100644\n--- a/sound/core/oss/pcm_plugin.c\n+++ b/sound/core/oss/pcm_plugin.c\n@@ -63,9 +63,11 @@ static int snd_pcm_plugin_alloc(struct snd_pcm_plugin *plugin, snd_pcm_uframes_t\n \tif (width < 0)\n \t\treturn width;\n \tsize = frames * format->channels * width;\n-\tif (snd_BUG_ON(size % 8))\n+\tif (snd_BUG_ON(size % 8) || size > MAX_ALLOWED_SIZE)\n \t\treturn -ENXIO;\n \tsize /= 8;\n+\tif (size > MAX_ALLOWED_SIZE)\n+\t\treturn -ENOMEM;\n \tif (plugin->buf_frames < frames) {\n \t\tkvfree(plugin->buf);\n \t\tplugin->buf = kvzalloc(size, GFP_KERNEL);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/sound/core/oss/pcm_plugin.c b/sound/core/oss/pcm_plugin.c\nindex 061ba06bc926..28e77e3ec7d7 100644\n--- a/sound/core/oss/pcm_plugin.c\n+++ b/sound/core/oss/pcm_plugin.c\n@@ -63,9 +63,11 @@ static int snd_pcm_plugin_alloc(struct snd_pcm_plugin *plugin, snd_pcm_uframes_t\n \tif (width < 0)\n \t\treturn width;\n \tsize = frames * format->channels * width;\n-\tif (snd_BUG_ON(size % 8))\n+\tif (snd_BUG_ON(size % 8) || size > MAX_ALLOWED_SIZE)\n \t\treturn -ENXIO;\n \tsize /= 8;\n+\tif (size > MAX_ALLOWED_SIZE)\n+\t\treturn -ENOMEM;\n \tif (plugin->buf_frames < frames) {\n \t\tkvfree(plugin->buf);\n \t\tplugin->buf = kvzalloc(size, GFP_KERNEL);\n@@ -86,9 +88,11 @@ static int snd_pcm_plugin_alloc(struct snd_pcm_plugin *plugin, snd_pcm_uframes_t\n \t\t\tc->area.step = format->channels * width;\n \t\t}\n \t} else if (plugin->access == SNDRV_PCM_ACCESS_RW_NONINTERLEAVED) {\n-\t\tif (snd_BUG_ON(size % format->channels))\n+\t\tif (snd_BUG_ON(size % format->channels) || size > MAX_ALLOWED_SIZE)\n \t\t\treturn -EINVAL;\n \t\tsize /= format->channels;\n+\t\tif (size > MAX_ALLOWED_SIZE)\n+\t\t\treturn -ENOMEM;\n \t\tfor (channel = 0; channel < format->channels; channel++, c++) {\n \t\t\tc->frames = frames;\n \t\t\tc->enabled = 1;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "b5d799a2cc619607ed6e322f97f78eaf534451e1": {
        "non_crash": [
            "diff --git a/fs/namei.c b/fs/namei.c\nindex 0cab6494978c..4939cbc37125 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -215,6 +215,9 @@ struct filename *\n getname_kernel(const char * filename)\n {\n \tstruct filename *result;\n+\tif (unlikely(!filename))\n+\t\treturn ERR_PTR(-EINVAL);\n+\n \tint len = strlen(filename) + 1;\n \n \tresult = __getname();\n",
            "diff --git a/fs/namei.c b/fs/namei.c\nindex 0cab6494978c..4939cbc37125 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -215,6 +215,9 @@ struct filename *\n getname_kernel(const char * filename)\n {\n \tstruct filename *result;\n+\tif (unlikely(!filename))\n+\t\treturn ERR_PTR(-EINVAL);\n+\n \tint len = strlen(filename) + 1;\n \n \tresult = __getname();\n",
            "diff --git a/fs/namei.c b/fs/namei.c\nindex 0cab6494978c..4939cbc37125 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -215,6 +215,9 @@ struct filename *\n getname_kernel(const char * filename)\n {\n \tstruct filename *result;\n+\tif (unlikely(!filename))\n+\t\treturn ERR_PTR(-EINVAL);\n+\n \tint len = strlen(filename) + 1;\n \n \tresult = __getname();\n",
            "diff --git a/fs/namei.c b/fs/namei.c\nindex 0cab6494978c..4939cbc37125 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -215,6 +215,9 @@ struct filename *\n getname_kernel(const char * filename)\n {\n \tstruct filename *result;\n+\tif (unlikely(!filename))\n+\t\treturn ERR_PTR(-EINVAL);\n+\n \tint len = strlen(filename) + 1;\n \n \tresult = __getname();\n",
            "diff --git a/fs/namei.c b/fs/namei.c\nindex 0cab6494978c..5c5468ce6e1b 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -215,7 +215,12 @@ struct filename *\n getname_kernel(const char * filename)\n {\n \tstruct filename *result;\n-\tint len = strlen(filename) + 1;\n+\tint len;\n+\n+\tif (unlikely(!filename))\n+\t\treturn ERR_PTR(-EINVAL);\n+\n+\tlen = strlen(filename) + 1;\n \n \tresult = __getname();\n \tif (unlikely(!result))\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "699e4f546c33df9781a67891d42766bbbe3ca30b": {
        "non_crash": [
            "diff --git a/fs/fuse/dir.c b/fs/fuse/dir.c\nindex 2798fbe8d001..80a2181b402b 100644\n--- a/fs/fuse/dir.c\n+++ b/fs/fuse/dir.c\n@@ -1079,7 +1079,7 @@ int fuse_reverse_inval_entry(struct fuse_conn *fc, u64 parent_nodeid,\n \tif (!parent)\n \t\treturn -ENOENT;\n \n-\tinode_lock(parent);\n+\tinode_lock_nested(parent, I_MUTEX_PARENT);\n \tif (!S_ISDIR(parent->i_mode))\n \t\tgoto unlock;\n \n",
            "diff --git a/fs/fuse/dir.c b/fs/fuse/dir.c\nindex 2798fbe8d001..80a2181b402b 100644\n--- a/fs/fuse/dir.c\n+++ b/fs/fuse/dir.c\n@@ -1079,7 +1079,7 @@ int fuse_reverse_inval_entry(struct fuse_conn *fc, u64 parent_nodeid,\n \tif (!parent)\n \t\treturn -ENOENT;\n \n-\tinode_lock(parent);\n+\tinode_lock_nested(parent, I_MUTEX_PARENT);\n \tif (!S_ISDIR(parent->i_mode))\n \t\tgoto unlock;\n \n",
            "diff --git a/fs/fuse/dir.c b/fs/fuse/dir.c\nindex 2798fbe8d001..80a2181b402b 100644\n--- a/fs/fuse/dir.c\n+++ b/fs/fuse/dir.c\n@@ -1079,7 +1079,7 @@ int fuse_reverse_inval_entry(struct fuse_conn *fc, u64 parent_nodeid,\n \tif (!parent)\n \t\treturn -ENOENT;\n \n-\tinode_lock(parent);\n+\tinode_lock_nested(parent, I_MUTEX_PARENT);\n \tif (!S_ISDIR(parent->i_mode))\n \t\tgoto unlock;\n \n",
            "diff --git a/fs/fuse/dir.c b/fs/fuse/dir.c\nindex 2798fbe8d001..1c90671d0c89 100644\n--- a/fs/fuse/dir.c\n+++ b/fs/fuse/dir.c\n@@ -1098,7 +1098,7 @@ int fuse_reverse_inval_entry(struct fuse_conn *fc, u64 parent_nodeid,\n \tfuse_invalidate_entry(entry);\n \n \tif (child_nodeid != 0 && d_really_is_positive(entry)) {\n-\t\tinode_lock(d_inode(entry));\n+\t\tinode_lock_nested(d_inode(entry), I_MUTEX_CHILD);\n \t\tif (get_node_id(d_inode(entry)) != child_nodeid) {\n \t\t\terr = -ENOENT;\n \t\t\tgoto badentry;\n",
            "diff --git a/fs/fuse/dir.c b/fs/fuse/dir.c\nindex 2798fbe8d001..1c90671d0c89 100644\n--- a/fs/fuse/dir.c\n+++ b/fs/fuse/dir.c\n@@ -1098,7 +1098,7 @@ int fuse_reverse_inval_entry(struct fuse_conn *fc, u64 parent_nodeid,\n \tfuse_invalidate_entry(entry);\n \n \tif (child_nodeid != 0 && d_really_is_positive(entry)) {\n-\t\tinode_lock(d_inode(entry));\n+\t\tinode_lock_nested(d_inode(entry), I_MUTEX_CHILD);\n \t\tif (get_node_id(d_inode(entry)) != child_nodeid) {\n \t\t\terr = -ENOENT;\n \t\t\tgoto badentry;\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "4d35dd2768109c21f717806fb4274293758d65cf": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/mmap.c b/mm/mmap.c\nindex 51e70fa98450..3e9df9d80bf5 100644\n--- a/mm/mmap.c\n+++ b/mm/mmap.c\n@@ -3223,7 +3223,14 @@ void exit_mmap(struct mm_struct *mm)\n \t\tcond_resched();\n \t} while ((vma = mas_find(&mas, ULONG_MAX)) != NULL);\n \n-\tBUG_ON(count != mm->map_count);\n+\t/*\n+\t * Ensure count matches mm->map_count after removing VMAs.\n+\t * This is a safeguard to prevent inconsistencies.\n+\t */\n+\tif (count != mm->map_count) {\n+\t\tpr_err(\"validate_mm: VMA count mismatch: expected %d, got %d\\n\", mm->map_count, count);\n+\t\tBUG();\n+\t}\n \n \ttrace_exit_mmap(mm);\n \t__mt_destroy(&mm->mm_mt);\n",
            "diff --git a/mm/mmap.c b/mm/mmap.c\nindex 51e70fa98450..a731d06a9586 100644\n--- a/mm/mmap.c\n+++ b/mm/mmap.c\n@@ -3223,7 +3223,14 @@ void exit_mmap(struct mm_struct *mm)\n \t\tcond_resched();\n \t} while ((vma = mas_find(&mas, ULONG_MAX)) != NULL);\n \n-\tBUG_ON(count != mm->map_count);\n+\t/*\n+\t * Ensure count matches mm->map_count after VMA removal.\n+\t * This may require additional checks or updates to count.\n+\t */\n+\tif (count != mm->map_count) {\n+\t\tpr_err(\"VMA count mismatch: expected %d, got %d\\n\", mm->map_count, count);\n+\t\t/* Additional logic to correct count or handle error */\n+\t}\n \n \ttrace_exit_mmap(mm);\n \t__mt_destroy(&mm->mm_mt);\n",
            "diff --git a/mm/mmap.c b/mm/mmap.c\nindex 51e70fa98450..798c743878a3 100644\n--- a/mm/mmap.c\n+++ b/mm/mmap.c\n@@ -3223,7 +3223,11 @@ void exit_mmap(struct mm_struct *mm)\n \t\tcond_resched();\n \t} while ((vma = mas_find(&mas, ULONG_MAX)) != NULL);\n \n-\tBUG_ON(count != mm->map_count);\n+\tif (count != mm->map_count) {\n+\t\tpr_err(\"VMA count mismatch: expected %d, got %d\\n\", mm->map_count, count);\n+\t\t// Attempt to recover or log additional information\n+\t\t// This could involve additional validation or corrective actions\n+\t}\n \n \ttrace_exit_mmap(mm);\n \t__mt_destroy(&mm->mm_mt);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/mm/mmap.c b/mm/mmap.c\nindex 51e70fa98450..6eb7e9d1698e 100644\n--- a/mm/mmap.c\n+++ b/mm/mmap.c\n@@ -3216,6 +3216,9 @@ void exit_mmap(struct mm_struct *mm)\n \t * mmap_write_lock.\n \t */\n \tdo {\n+\t\tif (vma->vm_flags & VM_ACCOUNT)\n+\t\t\tnr_accounted += vma_pages(vma);\n+\t\tremove_vma(vma, true);\n \t\tif (vma->vm_flags & VM_ACCOUNT)\n \t\t\tnr_accounted += vma_pages(vma);\n \t\tremove_vma(vma, true);\n",
                "error_message": "Failed to set up instance"
            },
            {
                "patch": "diff --git a/mm/mmap.c b/mm/mmap.c\nindex 51e70fa98450..6916b3d0268d 100644\n--- a/mm/mmap.c\n+++ b/mm/mmap.c\n@@ -2541,7 +2541,7 @@ do_vmi_align_munmap(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \n \t/* Point of no return */\n \tmm->locked_vm -= locked_vm;\n-\tmm->map_count -= count;\n+\tmm->map_count = count;\n \tif (unlock)\n \t\tmmap_write_downgrade(mm);\n \n@@ -3223,7 +3223,7 @@ void exit_mmap(struct mm_struct *mm)\n \t\tcond_resched();\n \t} while ((vma = mas_find(&mas, ULONG_MAX)) != NULL);\n \n-\tBUG_ON(count != mm->map_count);\n+\tBUG_ON(count != mm->map_count + 1);\n \n \ttrace_exit_mmap(mm);\n \t__mt_destroy(&mm->mm_mt);\n",
                "error_message": "Failed to set up instance"
            }
        ]
    },
    "a49f5785c682daf283714b6695f902e5371b83d7": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/erofs/zdata.c b/fs/erofs/zdata.c\nindex a90d37c7bdd7..3a1f9f7f2f92 100644\n--- a/fs/erofs/zdata.c\n+++ b/fs/erofs/zdata.c\n@@ -1312,10 +1312,15 @@ static int z_erofs_decompress_pcluster(struct z_erofs_decompress_backend *be,\n \tif (pclusterpages + be->onstack_used <= Z_EROFS_ONSTACK_PAGES)\n \t\tbe->compressed_pages = be->onstack_pages + be->onstack_used;\n \n-\tif (!be->decompressed_pages)\n+\tif (!be->decompressed_pages) {\n \t\tbe->decompressed_pages =\n \t\t\tkvcalloc(be->nr_pages, sizeof(struct page *),\n \t\t\t\t GFP_KERNEL | __GFP_NOFAIL);\n+\t\tif (!be->decompressed_pages) {\n+\t\t\terr = -ENOMEM;\n+\t\t\tgoto out;\n+\t\t}\n+\t}\n \tif (!be->compressed_pages)\n \t\tbe->compressed_pages =\n \t\t\tkvcalloc(pclusterpages, sizeof(struct page *),\n",
            "diff --git a/fs/erofs/zdata.c b/fs/erofs/zdata.c\nindex a90d37c7bdd7..3a1f9f7f2f92 100644\n--- a/fs/erofs/zdata.c\n+++ b/fs/erofs/zdata.c\n@@ -1312,10 +1312,15 @@ static int z_erofs_decompress_pcluster(struct z_erofs_decompress_backend *be,\n \tif (pclusterpages + be->onstack_used <= Z_EROFS_ONSTACK_PAGES)\n \t\tbe->compressed_pages = be->onstack_pages + be->onstack_used;\n \n-\tif (!be->decompressed_pages)\n+\tif (!be->decompressed_pages) {\n \t\tbe->decompressed_pages =\n \t\t\tkvcalloc(be->nr_pages, sizeof(struct page *),\n \t\t\t\t GFP_KERNEL | __GFP_NOFAIL);\n+\t\tif (!be->decompressed_pages) {\n+\t\t\terr = -ENOMEM;\n+\t\t\tgoto out;\n+\t\t}\n+\t}\n \tif (!be->compressed_pages)\n \t\tbe->compressed_pages =\n \t\t\tkvcalloc(pclusterpages, sizeof(struct page *),\n",
            "diff --git a/fs/erofs/decompressor.c b/fs/erofs/decompressor.c\nindex 7021e2cf6146..aa73134c4ba9 100644\n--- a/fs/erofs/decompressor.c\n+++ b/fs/erofs/decompressor.c\n@@ -213,7 +213,10 @@ static int z_erofs_lz4_decompress_mem(struct z_erofs_lz4_decompress_ctx *ctx,\n \tu8 *headpage, *src;\n \tint ret, maptype;\n \n-\tDBG_BUGON(*rq->in == NULL);\n+\tif (!*rq->in) {\n+\t\tpr_err(\"Invalid input page in z_erofs_lz4_decompress_mem\\n\");\n+\t\treturn -EINVAL;\n+\t}\n \theadpage = kmap_atomic(*rq->in);\n \n \t/* LZ4 decompression inplace is only safe if zero_padding is enabled */\ndiff --git a/fs/erofs/zdata.c b/fs/erofs/zdata.c\nindex a90d37c7bdd7..01b810274166 100644\n--- a/fs/erofs/zdata.c\n+++ b/fs/erofs/zdata.c\n@@ -1169,6 +1169,10 @@ static void z_erofs_do_decompressed_bvec(struct z_erofs_decompress_backend *be,\n \n \t/* (cold path) one pcluster is requested multiple times */\n \titem = kmalloc(sizeof(*item), GFP_KERNEL | __GFP_NOFAIL);\n+\tif (!item) {\n+\t\tpr_err(\"Failed to allocate memory for z_erofs_bvec_item\\n\");\n+\t\treturn;\n+\t}\n \titem->bvec = *bvec;\n \tlist_add(&item->list, &be->decompressed_secondary_bvecs);\n }\n",
            "diff --git a/fs/erofs/decompressor.c b/fs/erofs/decompressor.c\nindex 7021e2cf6146..4a2662593b76 100644\n--- a/fs/erofs/decompressor.c\n+++ b/fs/erofs/decompressor.c\n@@ -213,6 +213,10 @@ static int z_erofs_lz4_decompress_mem(struct z_erofs_lz4_decompress_ctx *ctx,\n \tu8 *headpage, *src;\n \tint ret, maptype;\n \n+\tif (!*rq->in) {\n+\t\treturn -EINVAL;\n+\t}\n+\n \tDBG_BUGON(*rq->in == NULL);\n \theadpage = kmap_atomic(*rq->in);\n \ndiff --git a/fs/erofs/zdata.c b/fs/erofs/zdata.c\nindex a90d37c7bdd7..965942929fb7 100644\n--- a/fs/erofs/zdata.c\n+++ b/fs/erofs/zdata.c\n@@ -1321,6 +1321,11 @@ static int z_erofs_decompress_pcluster(struct z_erofs_decompress_backend *be,\n \t\t\tkvcalloc(pclusterpages, sizeof(struct page *),\n \t\t\t\t GFP_KERNEL | __GFP_NOFAIL);\n \n+\tif (!be->decompressed_pages || !be->compressed_pages) {\n+\t\terr = -ENOMEM;\n+\t\tgoto out;\n+\t}\n+\n \tz_erofs_parse_out_bvecs(be);\n \terr2 = z_erofs_parse_in_bvecs(be, &overlapped);\n \tif (err2)\n",
            "diff --git a/fs/erofs/zdata.c b/fs/erofs/zdata.c\nindex a90d37c7bdd7..73b27b7e19e4 100644\n--- a/fs/erofs/zdata.c\n+++ b/fs/erofs/zdata.c\n@@ -1312,10 +1312,16 @@ static int z_erofs_decompress_pcluster(struct z_erofs_decompress_backend *be,\n \tif (pclusterpages + be->onstack_used <= Z_EROFS_ONSTACK_PAGES)\n \t\tbe->compressed_pages = be->onstack_pages + be->onstack_used;\n \n-\tif (!be->decompressed_pages)\n-\t\tbe->decompressed_pages =\n-\t\t\tkvcalloc(be->nr_pages, sizeof(struct page *),\n-\t\t\t\t GFP_KERNEL | __GFP_NOFAIL);\n+\tif (!be->decompressed_pages) {\n+\t\tif (be->nr_pages > 0) {\n+\t\t\tbe->decompressed_pages =\n+\t\t\t\tkvcalloc(be->nr_pages, sizeof(struct page *),\n+\t\t\t\t\t GFP_KERNEL | __GFP_NOFAIL);\n+\t\t} else {\n+\t\t\tpr_err(\"Invalid number of pages: %u\\n\", be->nr_pages);\n+\t\t\treturn -EINVAL;\n+\t\t}\n+\t}\n \tif (!be->compressed_pages)\n \t\tbe->compressed_pages =\n \t\t\tkvcalloc(pclusterpages, sizeof(struct page *),\n"
        ],
        "error": []
    },
    "b139c306850a825c7656508c3773dbea33eb56a1": {
        "non_crash": [
            "diff --git a/fs/xfs/xfs_dquot.c b/fs/xfs/xfs_dquot.c\nindex 8fb90da89787..c0734aed8f45 100644\n--- a/fs/xfs/xfs_dquot.c\n+++ b/fs/xfs/xfs_dquot.c\n@@ -795,12 +795,17 @@ xfs_qm_dqget_cache_insert(\n \tint\t\t\terror;\n \n \tmutex_lock(&qi->qi_tree_lock);\n-\terror = radix_tree_insert(tree, id, dqp);\n-\tif (unlikely(error)) {\n+\t/* Check for existing entry before insertion */\n+\tif (radix_tree_lookup(tree, id)) {\n \t\t/* Duplicate found!  Caller must try again. */\n-\t\tWARN_ON(error != -EEXIST);\n \t\tmutex_unlock(&qi->qi_tree_lock);\n \t\ttrace_xfs_dqget_dup(dqp);\n+\t\treturn -EEXIST;\n+\t}\n+\n+\terror = radix_tree_insert(tree, id, dqp);\n+\tif (unlikely(error)) {\n+\t\tmutex_unlock(&qi->qi_tree_lock);\n \t\treturn error;\n \t}\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/xfs/xfs_dquot.c b/fs/xfs/xfs_dquot.c\nindex 8fb90da89787..7e6226a06575 100644\n--- a/fs/xfs/xfs_dquot.c\n+++ b/fs/xfs/xfs_dquot.c\n@@ -871,6 +871,14 @@ xfs_qm_dqget(\n \tif (error)\n \t\treturn error;\n \n+\tdqp = xfs_qm_dqget_cache_lookup(mp, qi, tree, id);\n+\tif (dqp) {\n+\t\t*O_dqpp = dqp;\n+\t\txfs_qm_dqdestroy(dqp); // Destroy the duplicate dquot\n+\t\tXFS_STATS_INC(mp, xs_qm_dquot_dups);\n+\t\treturn 0; // Return successfully with the existing dquot\n+\t}\n+\n \terror = xfs_qm_dqget_cache_insert(mp, qi, tree, id, dqp);\n \tif (error) {\n \t\t/*\n",
            "diff --git a/fs/xfs/xfs_dquot.c b/fs/xfs/xfs_dquot.c\nindex 8fb90da89787..d17098cff8a4 100644\n--- a/fs/xfs/xfs_dquot.c\n+++ b/fs/xfs/xfs_dquot.c\n@@ -871,16 +871,21 @@ xfs_qm_dqget(\n \tif (error)\n \t\treturn error;\n \n-\terror = xfs_qm_dqget_cache_insert(mp, qi, tree, id, dqp);\n-\tif (error) {\n-\t\t/*\n-\t\t * Duplicate found. Just throw away the new dquot and start\n-\t\t * over.\n-\t\t */\n-\t\txfs_qm_dqdestroy(dqp);\n-\t\tXFS_STATS_INC(mp, xs_qm_dquot_dups);\n-\t\tgoto restart;\n-\t}\n+\tdo {\n+\t\terror = xfs_qm_dqget_cache_insert(mp, qi, tree, id, dqp);\n+\t\tif (error == -EEXIST) {\n+\t\t\t/*\n+\t\t\t * Duplicate found. Just throw away the new dquot and start\n+\t\t\t * over.\n+\t\t\t */\n+\t\t\txfs_qm_dqdestroy(dqp);\n+\t\t\tXFS_STATS_INC(mp, xs_qm_dquot_dups);\n+\t\t\tcontinue;\n+\t\t} else if (error) {\n+\t\t\treturn error;\n+\t\t}\n+\t\tbreak;\n+\t} while (true);\n \n \ttrace_xfs_dqget_miss(dqp);\n \t*O_dqpp = dqp;\n",
            "diff --git a/fs/xfs/xfs_dquot.c b/fs/xfs/xfs_dquot.c\nindex 8fb90da89787..078f2a76361b 100644\n--- a/fs/xfs/xfs_dquot.c\n+++ b/fs/xfs/xfs_dquot.c\n@@ -798,7 +798,9 @@ xfs_qm_dqget_cache_insert(\n \terror = radix_tree_insert(tree, id, dqp);\n \tif (unlikely(error)) {\n \t\t/* Duplicate found!  Caller must try again. */\n-\t\tWARN_ON(error != -EEXIST);\n+\t\tif (error != -EEXIST) {\n+\t\t\tWARN_ON(1);\n+\t\t}\n \t\tmutex_unlock(&qi->qi_tree_lock);\n \t\ttrace_xfs_dqget_dup(dqp);\n \t\treturn error;\n",
            "diff --git a/fs/xfs/xfs_dquot.c b/fs/xfs/xfs_dquot.c\nindex 8fb90da89787..8590166fa319 100644\n--- a/fs/xfs/xfs_dquot.c\n+++ b/fs/xfs/xfs_dquot.c\n@@ -798,10 +798,16 @@ xfs_qm_dqget_cache_insert(\n \terror = radix_tree_insert(tree, id, dqp);\n \tif (unlikely(error)) {\n \t\t/* Duplicate found!  Caller must try again. */\n-\t\tWARN_ON(error != -EEXIST);\n+\t\tif (error != -EEXIST) {\n+\t\t\tWARN_ON(1);\n+\t\t\tmutex_unlock(&qi->qi_tree_lock);\n+\t\t\ttrace_xfs_dqget_dup(dqp);\n+\t\t\treturn error;\n+\t\t}\n+\t\t/* Handle duplicate entry gracefully */\n \t\tmutex_unlock(&qi->qi_tree_lock);\n \t\ttrace_xfs_dqget_dup(dqp);\n-\t\treturn error;\n+\t\treturn -EEXIST;\n \t}\n \n \t/* Return a locked dquot to the caller, with a reference taken. */\n"
        ],
        "error": []
    },
    "625eef83808cdc8a4d6775801b04e985eb32fcf7": {
        "non_crash": [
            "diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c\nindex 19c707bc8801..9b204def53e6 100644\n--- a/fs/btrfs/inode.c\n+++ b/fs/btrfs/inode.c\n@@ -2622,9 +2622,12 @@ int btrfs_extract_ordered_extent(struct btrfs_bio *bbio,\n \tif (ordered->disk_num_bytes == len)\n \t\treturn 0;\n \n-\tret = btrfs_split_ordered_extent(ordered, len);\n-\tif (ret)\n-\t\treturn ret;\n+\t/* Ensure len is less than ordered->num_bytes before splitting */\n+\tif (len < ordered->num_bytes) {\n+\t\tret = btrfs_split_ordered_extent(ordered, len);\n+\t\tif (ret)\n+\t\t\treturn ret;\n+\t}\n \n \t/*\n \t * Don't split the extent_map for NOCOW extents, as we're writing into\n",
            "diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c\nindex 19c707bc8801..f17670174589 100644\n--- a/fs/btrfs/inode.c\n+++ b/fs/btrfs/inode.c\n@@ -2618,8 +2618,8 @@ int btrfs_extract_ordered_extent(struct btrfs_bio *bbio,\n \tif (WARN_ON_ONCE(start != ordered->disk_bytenr))\n \t\treturn -EINVAL;\n \n-\t/* No need to split if the ordered extent covers the entire bio. */\n-\tif (ordered->disk_num_bytes == len)\n+\t/* Ensure len is less than ordered->num_bytes before splitting. */\n+\tif (ordered->disk_num_bytes == len || len >= ordered->num_bytes)\n \t\treturn 0;\n \n \tret = btrfs_split_ordered_extent(ordered, len);\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c\nindex 19c707bc8801..ff71956471bd 100644\n--- a/fs/btrfs/inode.c\n+++ b/fs/btrfs/inode.c\n@@ -2622,9 +2622,12 @@ int btrfs_extract_ordered_extent(struct btrfs_bio *bbio,\n \tif (ordered->disk_num_bytes == len)\n \t\treturn 0;\n \n-\tret = btrfs_split_ordered_extent(ordered, len);\n-\tif (ret)\n-\t\treturn ret;\n+\t/* Ensure the ordered extent is in a valid state before splitting */\n+\tif (ordered->bytes_left == ordered->disk_num_bytes) {\n+\t\tret = btrfs_split_ordered_extent(ordered, len);\n+\t\tif (ret)\n+\t\t\treturn ret;\n+\t}\n \n \t/*\n \t * Don't split the extent_map for NOCOW extents, as we're writing into\n",
            "diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c\nindex 19c707bc8801..24f3b9b588e3 100644\n--- a/fs/btrfs/inode.c\n+++ b/fs/btrfs/inode.c\n@@ -2622,9 +2622,18 @@ int btrfs_extract_ordered_extent(struct btrfs_bio *bbio,\n \tif (ordered->disk_num_bytes == len)\n \t\treturn 0;\n \n-\tret = btrfs_split_ordered_extent(ordered, len);\n-\tif (ret)\n-\t\treturn ret;\n+\t/* Ensure the ordered extent can be split */\n+\tif (len < ordered->num_bytes &&\n+\t    ordered->bytes_left == ordered->disk_num_bytes &&\n+\t    ordered->disk_num_bytes == ordered->num_bytes &&\n+\t    list_empty(&ordered->list)) {\n+\t\tret = btrfs_split_ordered_extent(ordered, len);\n+\t\tif (ret)\n+\t\t\treturn ret;\n+\t} else {\n+\t\tWARN_ON_ONCE(1);\n+\t\treturn -EINVAL;\n+\t}\n \n \t/*\n \t * Don't split the extent_map for NOCOW extents, as we're writing into\n",
            "diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c\nindex 19c707bc8801..45ee4aea26a8 100644\n--- a/fs/btrfs/inode.c\n+++ b/fs/btrfs/inode.c\n@@ -2622,9 +2622,17 @@ int btrfs_extract_ordered_extent(struct btrfs_bio *bbio,\n \tif (ordered->disk_num_bytes == len)\n \t\treturn 0;\n \n-\tret = btrfs_split_ordered_extent(ordered, len);\n-\tif (ret)\n-\t\treturn ret;\n+\t/* Ensure the ordered extent is in a valid state before splitting */\n+\tif (ordered->bytes_left == ordered->disk_num_bytes &&\n+\t    ordered->disk_num_bytes == ordered->num_bytes &&\n+\t    list_empty(&ordered->list)) {\n+\t\tret = btrfs_split_ordered_extent(ordered, len);\n+\t\tif (ret)\n+\t\t\treturn ret;\n+\t} else {\n+\t\tWARN_ON_ONCE(1);\n+\t\treturn -EINVAL;\n+\t}\n \n \t/*\n \t * Don't split the extent_map for NOCOW extents, as we're writing into\n"
        ],
        "error": []
    },
    "a9412f636e2d733130f8def7975897d0b57f6e37": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/autofs/waitq.c b/fs/autofs/waitq.c\nindex 54c1f8b8b075..bd4c96f52202 100644\n--- a/fs/autofs/waitq.c\n+++ b/fs/autofs/waitq.c\n@@ -475,7 +475,7 @@ int autofs_wait(struct autofs_sb_info *sbi,\n \n \t/* Are we the last process to need status? */\n \tmutex_lock(&sbi->wq_mutex);\n-\tif (!--wq->wait_ctr)\n+\tif (wq->wait_ctr > 0 && !--wq->wait_ctr)\n \t\tkfree(wq);\n \tmutex_unlock(&sbi->wq_mutex);\n \n",
            "diff --git a/fs/autofs/waitq.c b/fs/autofs/waitq.c\nindex 54c1f8b8b075..3cd378228f6f 100644\n--- a/fs/autofs/waitq.c\n+++ b/fs/autofs/waitq.c\n@@ -473,9 +473,15 @@ int autofs_wait(struct autofs_sb_info *sbi,\n \t\t\tdput(de);\n \t}\n \n+\t/* If we allocated a wait_queue and it wasn't used, free it */\n+\tif (wq && wq->wait_ctr == 0) {\n+\t\tkfree(wq->name.name - wq->offset);\n+\t\tkfree(wq);\n+\t}\n+\n \t/* Are we the last process to need status? */\n \tmutex_lock(&sbi->wq_mutex);\n-\tif (!--wq->wait_ctr)\n+\tif (wq && !--wq->wait_ctr)\n \t\tkfree(wq);\n \tmutex_unlock(&sbi->wq_mutex);\n \n",
            "diff --git a/fs/autofs/waitq.c b/fs/autofs/waitq.c\nindex 54c1f8b8b075..7cd014a68e08 100644\n--- a/fs/autofs/waitq.c\n+++ b/fs/autofs/waitq.c\n@@ -475,8 +475,11 @@ int autofs_wait(struct autofs_sb_info *sbi,\n \n \t/* Are we the last process to need status? */\n \tmutex_lock(&sbi->wq_mutex);\n-\tif (!--wq->wait_ctr)\n+\tif (!wq->wait_ctr) {\n \t\tkfree(wq);\n+\t} else {\n+\t\twq->wait_ctr--;\n+\t}\n \tmutex_unlock(&sbi->wq_mutex);\n \n \treturn status;\n@@ -504,8 +507,11 @@ int autofs_wait_release(struct autofs_sb_info *sbi,\n \twq->name.name = NULL;\t/* Do not wait on this queue */\n \twq->status = status;\n \twake_up(&wq->queue);\n-\tif (!--wq->wait_ctr)\n+\tif (!wq->wait_ctr) {\n \t\tkfree(wq);\n+\t} else {\n+\t\twq->wait_ctr--;\n+\t}\n \tmutex_unlock(&sbi->wq_mutex);\n \n \treturn 0;\n",
            "diff --git a/fs/autofs/waitq.c b/fs/autofs/waitq.c\nindex 54c1f8b8b075..b45267c7d1f5 100644\n--- a/fs/autofs/waitq.c\n+++ b/fs/autofs/waitq.c\n@@ -475,8 +475,10 @@ int autofs_wait(struct autofs_sb_info *sbi,\n \n \t/* Are we the last process to need status? */\n \tmutex_lock(&sbi->wq_mutex);\n-\tif (!--wq->wait_ctr)\n+\tif (!--wq->wait_ctr) {\n+\t\tkfree(wq->name.name - wq->offset);\n \t\tkfree(wq);\n+\t}\n \tmutex_unlock(&sbi->wq_mutex);\n \n \treturn status;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/autofs/waitq.c b/fs/autofs/waitq.c\nindex 54c1f8b8b075..192b1e9edb01 100644\n--- a/fs/autofs/waitq.c\n+++ b/fs/autofs/waitq.c\n@@ -475,8 +475,10 @@ int autofs_wait(struct autofs_sb_info *sbi,\n \n \t/* Are we the last process to need status? */\n \tmutex_lock(&sbi->wq_mutex);\n-\tif (!--wq->wait_ctr)\n+\tif (!--wq->wait_ctr) {\n+\t\tlist_del(&wq->queue); // Unlink from the list\n \t\tkfree(wq);\n+\t}\n \tmutex_unlock(&sbi->wq_mutex);\n \n \treturn status;\n@@ -504,8 +506,10 @@ int autofs_wait_release(struct autofs_sb_info *sbi,\n \twq->name.name = NULL;\t/* Do not wait on this queue */\n \twq->status = status;\n \twake_up(&wq->queue);\n-\tif (!--wq->wait_ctr)\n+\tif (!--wq->wait_ctr) {\n+\t\tlist_del(&wq->queue); // Unlink from the list\n \t\tkfree(wq);\n+\t}\n \tmutex_unlock(&sbi->wq_mutex);\n \n \treturn 0;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "64182208616de0ae5ebd9b1652cb213485d61fce": {
        "non_crash": [
            "diff --git a/net/nfc/netlink.c b/net/nfc/netlink.c\nindex 1fc339084d89..e0b9aa0c7c13 100644\n--- a/net/nfc/netlink.c\n+++ b/net/nfc/netlink.c\n@@ -1538,6 +1538,9 @@ static int nfc_genl_se_io(struct sk_buff *skb, struct genl_info *info)\n \tctx->se_idx = se_idx;\n \n \trc = nfc_se_io(dev, se_idx, apdu, apdu_len, se_io_cb, ctx);\n+\tif (rc) {\n+\t\tkfree(ctx);\n+\t}\n \n put_dev:\n \tnfc_put_device(dev);\n",
            "diff --git a/net/nfc/netlink.c b/net/nfc/netlink.c\nindex 1fc339084d89..15ea2606ee3e 100644\n--- a/net/nfc/netlink.c\n+++ b/net/nfc/netlink.c\n@@ -1539,6 +1539,10 @@ static int nfc_genl_se_io(struct sk_buff *skb, struct genl_info *info)\n \n \trc = nfc_se_io(dev, se_idx, apdu, apdu_len, se_io_cb, ctx);\n \n+\tif (rc) {\n+\t\tkfree(ctx);\n+\t}\n+\n put_dev:\n \tnfc_put_device(dev);\n \treturn rc;\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/nfc/netlink.c b/net/nfc/netlink.c\nindex 1fc339084d89..e0b9aa0c7c13 100644\n--- a/net/nfc/netlink.c\n+++ b/net/nfc/netlink.c\n@@ -1538,6 +1538,9 @@ static int nfc_genl_se_io(struct sk_buff *skb, struct genl_info *info)\n \tctx->se_idx = se_idx;\n \n \trc = nfc_se_io(dev, se_idx, apdu, apdu_len, se_io_cb, ctx);\n+\tif (rc) {\n+\t\tkfree(ctx);\n+\t}\n \n put_dev:\n \tnfc_put_device(dev);\n",
            "diff --git a/net/nfc/netlink.c b/net/nfc/netlink.c\nindex 1fc339084d89..2003e1917714 100644\n--- a/net/nfc/netlink.c\n+++ b/net/nfc/netlink.c\n@@ -1540,6 +1540,8 @@ static int nfc_genl_se_io(struct sk_buff *skb, struct genl_info *info)\n \trc = nfc_se_io(dev, se_idx, apdu, apdu_len, se_io_cb, ctx);\n \n put_dev:\n+\tif (rc)\n+\t\tkfree(ctx);\n \tnfc_put_device(dev);\n \treturn rc;\n }\n",
            "diff --git a/net/nfc/netlink.c b/net/nfc/netlink.c\nindex 1fc339084d89..15ea2606ee3e 100644\n--- a/net/nfc/netlink.c\n+++ b/net/nfc/netlink.c\n@@ -1539,6 +1539,10 @@ static int nfc_genl_se_io(struct sk_buff *skb, struct genl_info *info)\n \n \trc = nfc_se_io(dev, se_idx, apdu, apdu_len, se_io_cb, ctx);\n \n+\tif (rc) {\n+\t\tkfree(ctx);\n+\t}\n+\n put_dev:\n \tnfc_put_device(dev);\n \treturn rc;\n"
        ],
        "error": []
    },
    "49b6f675bead6969f913a3f7dcef4d28fdd13296": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/mmap.c b/mm/mmap.c\nindex 51e70fa98450..e8798405f6c3 100644\n--- a/mm/mmap.c\n+++ b/mm/mmap.c\n@@ -2531,7 +2531,10 @@ do_vmi_align_munmap(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \t\t\tvma_test = mas_next(&test, end - 1);\n \t\t}\n \t\trcu_read_unlock();\n-\t\tBUG_ON(count != test_count);\n+\t\tif (count != test_count) {\n+\t\t\tpr_err(\"validate_mm: count (%d) does not match test_count (%d)\\n\", count, test_count);\n+\t\t\treturn -EINVAL;\n+\t\t}\n \t}\n #endif\n \tvma_iter_set(vmi, start);\n",
            "diff --git a/mm/mmap.c b/mm/mmap.c\nindex 51e70fa98450..e8798405f6c3 100644\n--- a/mm/mmap.c\n+++ b/mm/mmap.c\n@@ -2531,7 +2531,10 @@ do_vmi_align_munmap(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \t\t\tvma_test = mas_next(&test, end - 1);\n \t\t}\n \t\trcu_read_unlock();\n-\t\tBUG_ON(count != test_count);\n+\t\tif (count != test_count) {\n+\t\t\tpr_err(\"validate_mm: count (%d) does not match test_count (%d)\\n\", count, test_count);\n+\t\t\treturn -EINVAL;\n+\t\t}\n \t}\n #endif\n \tvma_iter_set(vmi, start);\n",
            "diff --git a/mm/mmap.c b/mm/mmap.c\nindex 51e70fa98450..47307d595c7d 100644\n--- a/mm/mmap.c\n+++ b/mm/mmap.c\n@@ -2531,7 +2531,10 @@ do_vmi_align_munmap(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \t\t\tvma_test = mas_next(&test, end - 1);\n \t\t}\n \t\trcu_read_unlock();\n-\t\tBUG_ON(count != test_count);\n+\t\tif (count != test_count) {\n+\t\t\tpr_err(\"VMA count mismatch: expected %d, got %d\\n\", test_count, count);\n+\t\t\treturn -EINVAL;\n+\t\t}\n \t}\n #endif\n \tvma_iter_set(vmi, start);\n",
            "diff --git a/mm/mmap.c b/mm/mmap.c\nindex 51e70fa98450..004326314422 100644\n--- a/mm/mmap.c\n+++ b/mm/mmap.c\n@@ -2531,7 +2531,10 @@ do_vmi_align_munmap(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \t\t\tvma_test = mas_next(&test, end - 1);\n \t\t}\n \t\trcu_read_unlock();\n-\t\tBUG_ON(count != test_count);\n+\t\tif (count != test_count) {\n+\t\t\tpr_err(\"validate_mm: VMA count mismatch: expected %d, got %d\\n\", test_count, count);\n+\t\t\treturn -EINVAL;\n+\t\t}\n \t}\n #endif\n \tvma_iter_set(vmi, start);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/mm/mmap.c b/mm/mmap.c\nindex 51e70fa98450..1395c9afd943 100644\n--- a/mm/mmap.c\n+++ b/mm/mmap.c\n@@ -2541,7 +2541,7 @@ do_vmi_align_munmap(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \n \t/* Point of no return */\n \tmm->locked_vm -= locked_vm;\n-\tmm->map_count -= count;\n+\tmm->map_count -= test_count;\n \tif (unlock)\n \t\tmmap_write_downgrade(mm);\n \n",
                "error_message": "Failed to build"
            }
        ]
    }
}