{
    "daa1858cc0258eb026f89eecf342f6b3fdad7b05": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/sched/em_cmp.c b/net/sched/em_cmp.c\nindex f17b049ea530..18f59cc55a8f 100644\n--- a/net/sched/em_cmp.c\n+++ b/net/sched/em_cmp.c\n@@ -23,6 +23,9 @@ static int em_cmp_match(struct sk_buff *skb, struct tcf_ematch *em,\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+\n+if (!ptr)\n+return 0;\n \tu32 val = 0;\n \n \tif (!tcf_valid_offset(skb, ptr, cmp->align))\n",
            "diff --git a/net/sched/em_cmp.c b/net/sched/em_cmp.c\nindex f17b049ea530..0a0338531c09 100644\n--- a/net/sched/em_cmp.c\n+++ b/net/sched/em_cmp.c\n@@ -22,7 +22,10 @@ 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 *ptr = tcf_get_base_ptr(skb, cmp->layer);\n+    if (!ptr)\n+        return 0;\n+    ptr += cmp->off;\n \tu32 val = 0;\n \n \tif (!tcf_valid_offset(skb, ptr, cmp->align))\n",
            "diff --git a/net/sched/em_cmp.c b/net/sched/em_cmp.c\nindex f17b049ea530..30955a9af18e 100644\n--- a/net/sched/em_cmp.c\n+++ b/net/sched/em_cmp.c\n@@ -22,7 +22,9 @@ 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+    if (!base_ptr) return 0;\n+    unsigned char *ptr = base_ptr + cmp->off;\n \tu32 val = 0;\n \n \tif (!tcf_valid_offset(skb, ptr, cmp->align))\n",
            "diff --git a/net/sched/em_cmp.c b/net/sched/em_cmp.c\nindex f17b049ea530..0a0338531c09 100644\n--- a/net/sched/em_cmp.c\n+++ b/net/sched/em_cmp.c\n@@ -22,7 +22,10 @@ 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 *ptr = tcf_get_base_ptr(skb, cmp->layer);\n+    if (!ptr)\n+        return 0;\n+    ptr += cmp->off;\n \tu32 val = 0;\n \n \tif (!tcf_valid_offset(skb, ptr, cmp->align))\n",
            "diff --git a/net/sched/em_cmp.c b/net/sched/em_cmp.c\nindex f17b049ea530..30955a9af18e 100644\n--- a/net/sched/em_cmp.c\n+++ b/net/sched/em_cmp.c\n@@ -22,7 +22,9 @@ 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+    if (!base_ptr) return 0;\n+    unsigned char *ptr = base_ptr + cmp->off;\n \tu32 val = 0;\n \n \tif (!tcf_valid_offset(skb, ptr, cmp->align))\n"
        ],
        "error": []
    },
    "59174b68c3c9d5d3ecc323e0b0a0c5466b0e7d18": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/sufile.c b/fs/nilfs2/sufile.c\nindex dc359b56fdfa..c87505cc6bad 100644\n--- a/fs/nilfs2/sufile.c\n+++ b/fs/nilfs2/sufile.c\n@@ -168,7 +168,8 @@ int nilfs_sufile_updatev(struct inode *sufile, __u64 *segnumv, size_t nsegs,\n \tif (unlikely(nsegs == 0))\n \t\tgoto out;\n \n-\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+\tif (down_write_killable(&NILFS_MDT(sufile)->mi_sem))\n+        return -EINTR;\n \tfor (seg = segnumv; seg < segnumv + nsegs; seg++) {\n \t\tif (unlikely(*seg >= nilfs_sufile_get_nsegments(sufile))) {\n \t\t\tnilfs_warn(sufile->i_sb,\n@@ -234,7 +235,8 @@ int nilfs_sufile_update(struct inode *sufile, __u64 segnum, int create,\n \t\t\t   __func__, (unsigned long long)segnum);\n \t\treturn -EINVAL;\n \t}\n-\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+\tif (down_write_killable(&NILFS_MDT(sufile)->mi_sem))\n+        return -EINTR;\n \n \tret = nilfs_sufile_get_header_block(sufile, &header_bh);\n \tif (ret < 0)\n@@ -269,7 +271,8 @@ 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+\tif (down_write_killable(&NILFS_MDT(sufile)->mi_sem))\n+        return -EINTR;\n \tnsegs = nilfs_sufile_get_nsegments(sufile);\n \n \tif (start <= end && end < nsegs) {\n@@ -310,7 +313,8 @@ int nilfs_sufile_alloc(struct inode *sufile, __u64 *segnump)\n \tunsigned long nsegments, nsus, cnt;\n \tint ret, j;\n \n-\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+\tif (down_write_killable(&NILFS_MDT(sufile)->mi_sem))\n+        return -EINTR;\n \n \tret = nilfs_sufile_get_header_block(sufile, &header_bh);\n \tif (ret < 0)\n@@ -499,7 +503,8 @@ int nilfs_sufile_mark_dirty(struct inode *sufile, __u64 segnum)\n \tstruct nilfs_segment_usage *su;\n \tint ret;\n \n-\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+\tif (down_write_killable(&NILFS_MDT(sufile)->mi_sem))\n+        return -EINTR;\n \tret = nilfs_sufile_get_segment_usage_block(sufile, segnum, 0, &bh);\n \tif (!ret) {\n \t\tmark_buffer_dirty(bh);\n@@ -529,7 +534,8 @@ int nilfs_sufile_set_segment_usage(struct inode *sufile, __u64 segnum,\n \tvoid *kaddr;\n \tint ret;\n \n-\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+\tif (down_write_killable(&NILFS_MDT(sufile)->mi_sem))\n+        return -EINTR;\n \tret = nilfs_sufile_get_segment_usage_block(sufile, segnum, 0, &bh);\n \tif (ret < 0)\n \t\tgoto out_sem;\n@@ -756,7 +762,8 @@ int nilfs_sufile_resize(struct inode *sufile, __u64 newnsegs)\n \tunsigned long nsegs, nrsvsegs;\n \tint ret = 0;\n \n-\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+\tif (down_write_killable(&NILFS_MDT(sufile)->mi_sem))\n+        return -EINTR;\n \n \tnsegs = nilfs_sufile_get_nsegments(sufile);\n \tif (nsegs == newnsegs)\n@@ -918,7 +925,8 @@ ssize_t nilfs_sufile_set_suinfo(struct inode *sufile, void *buf,\n \t\t\treturn -EINVAL;\n \t}\n \n-\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+\tif (down_write_killable(&NILFS_MDT(sufile)->mi_sem))\n+        return -EINTR;\n \n \tret = nilfs_sufile_get_header_block(sufile, &header_bh);\n \tif (ret < 0)\n",
            "diff --git a/fs/nilfs2/sufile.c b/fs/nilfs2/sufile.c\nindex dc359b56fdfa..c4ab92246851 100644\n--- a/fs/nilfs2/sufile.c\n+++ b/fs/nilfs2/sufile.c\n@@ -218,7 +218,8 @@ int nilfs_sufile_updatev(struct inode *sufile, __u64 *segnumv, size_t nsegs,\n  out:\n \tif (ndone)\n \t\t*ndone = n;\n-\treturn ret;\n+\t\n+return ret;\n }\n \n int nilfs_sufile_update(struct inode *sufile, __u64 segnum, int create,\n@@ -249,7 +250,8 @@ int nilfs_sufile_update(struct inode *sufile, __u64 segnum, int create,\n \n  out_sem:\n \tup_write(&NILFS_MDT(sufile)->mi_sem);\n-\treturn ret;\n+\t\n+return ret;\n }\n \n /**\n@@ -278,7 +280,8 @@ int nilfs_sufile_set_alloc_range(struct inode *sufile, __u64 start, __u64 end)\n \t\tret = 0;\n \t}\n \tup_write(&NILFS_MDT(sufile)->mi_sem);\n-\treturn ret;\n+\t\n+return ret;\n }\n \n /**\n@@ -396,7 +399,8 @@ int nilfs_sufile_alloc(struct inode *sufile, __u64 *segnump)\n \n  out_sem:\n \tup_write(&NILFS_MDT(sufile)->mi_sem);\n-\treturn ret;\n+\t\n+return ret;\n }\n \n void nilfs_sufile_do_cancel_free(struct inode *sufile, __u64 segnum,\n@@ -511,7 +515,8 @@ int nilfs_sufile_mark_dirty(struct inode *sufile, __u64 segnum)\n \t\tbrelse(bh);\n \t}\n \tup_write(&NILFS_MDT(sufile)->mi_sem);\n-\treturn ret;\n+\t\n+return ret;\n }\n \n /**\n@@ -548,7 +553,8 @@ int nilfs_sufile_set_segment_usage(struct inode *sufile, __u64 segnum,\n \n  out_sem:\n \tup_write(&NILFS_MDT(sufile)->mi_sem);\n-\treturn ret;\n+\t\n+return ret;\n }\n \n /**\n@@ -596,7 +602,8 @@ int nilfs_sufile_get_stat(struct inode *sufile, struct nilfs_sustat *sustat)\n \n  out_sem:\n \tup_read(&NILFS_MDT(sufile)->mi_sem);\n-\treturn ret;\n+\t\n+return ret;\n }\n \n void nilfs_sufile_do_set_error(struct inode *sufile, __u64 segnum,\n@@ -727,7 +734,8 @@ static int nilfs_sufile_truncate_range(struct inode *sufile,\n \t}\n \tbrelse(header_bh);\n out:\n-\treturn ret;\n+\t\n+return ret;\n }\n \n /**\n@@ -794,7 +802,8 @@ int nilfs_sufile_resize(struct inode *sufile, __u64 newnsegs)\n \tbrelse(header_bh);\n out:\n \tup_write(&NILFS_MDT(sufile)->mi_sem);\n-\treturn ret;\n+\t\n+return ret;\n }\n \n /**\n@@ -869,7 +878,8 @@ ssize_t nilfs_sufile_get_suinfo(struct inode *sufile, __u64 segnum, void *buf,\n \n  out:\n \tup_read(&NILFS_MDT(sufile)->mi_sem);\n-\treturn ret;\n+\t\n+return ret;\n }\n \n /**\n@@ -906,7 +916,8 @@ ssize_t nilfs_sufile_set_suinfo(struct inode *sufile, void *buf,\n \tint ret = 0;\n \n \tif (unlikely(nsup == 0))\n-\t\treturn ret;\n+\t\t\n+return ret;\n \n \tfor (sup = buf; sup < supend; sup = (void *)sup + supsz) {\n \t\tif (sup->sup_segnum >= nilfs->ns_nsegments\n@@ -1000,7 +1011,8 @@ ssize_t nilfs_sufile_set_suinfo(struct inode *sufile, void *buf,\n \tput_bh(header_bh);\n  out_sem:\n \tup_write(&NILFS_MDT(sufile)->mi_sem);\n-\treturn ret;\n+\t\n+return ret;\n }\n \n /**\n@@ -1152,7 +1164,8 @@ int nilfs_sufile_trim_fs(struct inode *sufile, struct fstrim_range *range)\n \tup_read(&NILFS_MDT(sufile)->mi_sem);\n \n \trange->len = ndiscarded << nilfs->ns_blocksize_bits;\n-\treturn ret;\n+\t\n+return ret;\n }\n \n /**\n",
            "diff --git a/fs/nilfs2/segment.c b/fs/nilfs2/segment.c\nindex 76c3bd88b858..38847a52837b 100644\n--- a/fs/nilfs2/segment.c\n+++ b/fs/nilfs2/segment.c\n@@ -324,6 +324,7 @@ void nilfs_relax_pressure_in_lock(struct super_block *sb)\n \tup_read(&nilfs->ns_segctor_sem);\n \n \tdown_write(&nilfs->ns_segctor_sem);\n+down_write(&NILFS_MDT(nilfs->ns_sufile)->mi_sem);\n \tif (sci->sc_flush_request &&\n \t    test_bit(NILFS_SC_PRIOR_FLUSH, &sci->sc_flags)) {\n \t\tstruct nilfs_transaction_info *ti = current->journal_info;\n@@ -355,6 +356,7 @@ static void nilfs_transaction_lock(struct super_block *sb,\n \t\t\t    ti->ti_flags, TRACE_NILFS2_TRANSACTION_TRYLOCK);\n \n \t\tdown_write(&nilfs->ns_segctor_sem);\n+down_write(&NILFS_MDT(nilfs->ns_sufile)->mi_sem);\n \t\tif (!test_bit(NILFS_SC_PRIOR_FLUSH, &sci->sc_flags))\n \t\t\tbreak;\n \n@@ -2751,6 +2753,7 @@ static void nilfs_segctor_destroy(struct nilfs_sc_info *sci)\n \tnilfs_put_root(sci->sc_root);\n \n \tdown_write(&nilfs->ns_segctor_sem);\n+down_write(&NILFS_MDT(nilfs->ns_sufile)->mi_sem);\n \n \ttimer_shutdown_sync(&sci->sc_timer);\n \tkfree(sci);\n@@ -2810,6 +2813,7 @@ void nilfs_detach_log_writer(struct super_block *sb)\n \tLIST_HEAD(garbage_list);\n \n \tdown_write(&nilfs->ns_segctor_sem);\n+down_write(&NILFS_MDT(nilfs->ns_sufile)->mi_sem);\n \tif (nilfs->ns_writer) {\n \t\tnilfs_segctor_destroy(nilfs->ns_writer);\n \t\tnilfs->ns_writer = NULL;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/nilfs2/sufile.c b/fs/nilfs2/sufile.c\nindex dc359b56fdfa..2cff893f2812 100644\n--- a/fs/nilfs2/sufile.c\n+++ b/fs/nilfs2/sufile.c\n@@ -168,7 +168,85 @@ int nilfs_sufile_updatev(struct inode *sufile, __u64 *segnumv, size_t nsegs,\n \tif (unlikely(nsegs == 0))\n \t\tgoto out;\n \n-\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+\t// Acquire the lock only for critical sections\n+    down_write(&NILFS_MDT(sufile)->mi_sem);\n+    // Perform header block retrieval outside lock\n+    ret = nilfs_sufile_get_header_block(sufile, &header_bh);\n+    if (ret < 0)\n+        return ret;\n+\n+    kaddr = kmap_atomic(header_bh->b_page);\n+    header = kaddr + bh_offset(header_bh);\n+    last_alloc = le64_to_cpu(header->sh_last_alloc);\n+    kunmap_atomic(kaddr);\n+\n+    nsegments = nilfs_sufile_get_nsegments(sufile);\n+    maxsegnum = sui->allocmax;\n+    segnum = last_alloc + 1;\n+    if (segnum < sui->allocmin || segnum > sui->allocmax)\n+        segnum = sui->allocmin;\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+    for (cnt = 0; cnt < nsegments; cnt += nsus) {\n+        down_write(&NILFS_MDT(sufile)->mi_sem);\n+        if (segnum > maxsegnum) {\n+            if (cnt < sui->allocmax - sui->allocmin + 1) {\n+                segnum = sui->allocmin;\n+                maxsegnum = last_alloc;\n+            } else if (segnum > sui->allocmin && sui->allocmax + 1 < nsegments) {\n+                segnum = sui->allocmax + 1;\n+                maxsegnum = nsegments - 1;\n+            } else if (sui->allocmin > 0)  {\n+                segnum = 0;\n+                maxsegnum = sui->allocmin - 1;\n+            } else {\n+                break;\n+            }\n+        }\n+        trace_nilfs2_segment_usage_check(sufile, segnum, cnt);\n+        ret = nilfs_sufile_get_segment_usage_block(sufile, segnum, 1, &su_bh);\n+        if (ret < 0)\n+            goto out_header;\n+\n+        kaddr = kmap_atomic(su_bh->b_page);\n+        su = nilfs_sufile_block_get_segment_usage(sufile, segnum, su_bh, kaddr);\n+\n+        nsus = nilfs_sufile_segment_usages_in_block(sufile, segnum, maxsegnum);\n+        for (j = 0; j < nsus; j++, su = (void *)su + susz, segnum++) {\n+            if (!nilfs_segment_usage_clean(su))\n+                continue;\n+            nilfs_segment_usage_set_dirty(su);\n+            kunmap_atomic(kaddr);\n+\n+            kaddr = kmap_atomic(header_bh->b_page);\n+            header = kaddr + bh_offset(header_bh);\n+            le64_add_cpu(&header->sh_ncleansegs, -1);\n+            le64_add_cpu(&header->sh_ndirtysegs, 1);\n+            header->sh_last_alloc = cpu_to_le64(segnum);\n+            kunmap_atomic(kaddr);\n+\n+            sui->ncleansegs--;\n+            mark_buffer_dirty(header_bh);\n+            mark_buffer_dirty(su_bh);\n+            nilfs_mdt_mark_dirty(sufile);\n+            brelse(su_bh);\n+            *segnump = segnum;\n+\n+            trace_nilfs2_segment_usage_allocated(sufile, segnum);\n+            up_write(&NILFS_MDT(sufile)->mi_sem);\n+            return 0;\n+        }\n+        kunmap_atomic(kaddr);\n+        brelse(su_bh);\n+        up_write(&NILFS_MDT(sufile)->mi_sem);\n+    }\n+\n+    return -ENOSPC;\n+\n+out_header:\n+    brelse(header_bh);\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+    return ret;\n \tfor (seg = segnumv; seg < segnumv + nsegs; seg++) {\n \t\tif (unlikely(*seg >= nilfs_sufile_get_nsegments(sufile))) {\n \t\t\tnilfs_warn(sufile->i_sb,\n@@ -234,7 +312,85 @@ int nilfs_sufile_update(struct inode *sufile, __u64 segnum, int create,\n \t\t\t   __func__, (unsigned long long)segnum);\n \t\treturn -EINVAL;\n \t}\n-\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+\t// Acquire the lock only for critical sections\n+    down_write(&NILFS_MDT(sufile)->mi_sem);\n+    // Perform header block retrieval outside lock\n+    ret = nilfs_sufile_get_header_block(sufile, &header_bh);\n+    if (ret < 0)\n+        return ret;\n+\n+    kaddr = kmap_atomic(header_bh->b_page);\n+    header = kaddr + bh_offset(header_bh);\n+    last_alloc = le64_to_cpu(header->sh_last_alloc);\n+    kunmap_atomic(kaddr);\n+\n+    nsegments = nilfs_sufile_get_nsegments(sufile);\n+    maxsegnum = sui->allocmax;\n+    segnum = last_alloc + 1;\n+    if (segnum < sui->allocmin || segnum > sui->allocmax)\n+        segnum = sui->allocmin;\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+    for (cnt = 0; cnt < nsegments; cnt += nsus) {\n+        down_write(&NILFS_MDT(sufile)->mi_sem);\n+        if (segnum > maxsegnum) {\n+            if (cnt < sui->allocmax - sui->allocmin + 1) {\n+                segnum = sui->allocmin;\n+                maxsegnum = last_alloc;\n+            } else if (segnum > sui->allocmin && sui->allocmax + 1 < nsegments) {\n+                segnum = sui->allocmax + 1;\n+                maxsegnum = nsegments - 1;\n+            } else if (sui->allocmin > 0)  {\n+                segnum = 0;\n+                maxsegnum = sui->allocmin - 1;\n+            } else {\n+                break;\n+            }\n+        }\n+        trace_nilfs2_segment_usage_check(sufile, segnum, cnt);\n+        ret = nilfs_sufile_get_segment_usage_block(sufile, segnum, 1, &su_bh);\n+        if (ret < 0)\n+            goto out_header;\n+\n+        kaddr = kmap_atomic(su_bh->b_page);\n+        su = nilfs_sufile_block_get_segment_usage(sufile, segnum, su_bh, kaddr);\n+\n+        nsus = nilfs_sufile_segment_usages_in_block(sufile, segnum, maxsegnum);\n+        for (j = 0; j < nsus; j++, su = (void *)su + susz, segnum++) {\n+            if (!nilfs_segment_usage_clean(su))\n+                continue;\n+            nilfs_segment_usage_set_dirty(su);\n+            kunmap_atomic(kaddr);\n+\n+            kaddr = kmap_atomic(header_bh->b_page);\n+            header = kaddr + bh_offset(header_bh);\n+            le64_add_cpu(&header->sh_ncleansegs, -1);\n+            le64_add_cpu(&header->sh_ndirtysegs, 1);\n+            header->sh_last_alloc = cpu_to_le64(segnum);\n+            kunmap_atomic(kaddr);\n+\n+            sui->ncleansegs--;\n+            mark_buffer_dirty(header_bh);\n+            mark_buffer_dirty(su_bh);\n+            nilfs_mdt_mark_dirty(sufile);\n+            brelse(su_bh);\n+            *segnump = segnum;\n+\n+            trace_nilfs2_segment_usage_allocated(sufile, segnum);\n+            up_write(&NILFS_MDT(sufile)->mi_sem);\n+            return 0;\n+        }\n+        kunmap_atomic(kaddr);\n+        brelse(su_bh);\n+        up_write(&NILFS_MDT(sufile)->mi_sem);\n+    }\n+\n+    return -ENOSPC;\n+\n+out_header:\n+    brelse(header_bh);\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+    return ret;\n \n \tret = nilfs_sufile_get_header_block(sufile, &header_bh);\n \tif (ret < 0)\n@@ -269,7 +425,85 @@ 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+\t// Acquire the lock only for critical sections\n+    down_write(&NILFS_MDT(sufile)->mi_sem);\n+    // Perform header block retrieval outside lock\n+    ret = nilfs_sufile_get_header_block(sufile, &header_bh);\n+    if (ret < 0)\n+        return ret;\n+\n+    kaddr = kmap_atomic(header_bh->b_page);\n+    header = kaddr + bh_offset(header_bh);\n+    last_alloc = le64_to_cpu(header->sh_last_alloc);\n+    kunmap_atomic(kaddr);\n+\n+    nsegments = nilfs_sufile_get_nsegments(sufile);\n+    maxsegnum = sui->allocmax;\n+    segnum = last_alloc + 1;\n+    if (segnum < sui->allocmin || segnum > sui->allocmax)\n+        segnum = sui->allocmin;\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+    for (cnt = 0; cnt < nsegments; cnt += nsus) {\n+        down_write(&NILFS_MDT(sufile)->mi_sem);\n+        if (segnum > maxsegnum) {\n+            if (cnt < sui->allocmax - sui->allocmin + 1) {\n+                segnum = sui->allocmin;\n+                maxsegnum = last_alloc;\n+            } else if (segnum > sui->allocmin && sui->allocmax + 1 < nsegments) {\n+                segnum = sui->allocmax + 1;\n+                maxsegnum = nsegments - 1;\n+            } else if (sui->allocmin > 0)  {\n+                segnum = 0;\n+                maxsegnum = sui->allocmin - 1;\n+            } else {\n+                break;\n+            }\n+        }\n+        trace_nilfs2_segment_usage_check(sufile, segnum, cnt);\n+        ret = nilfs_sufile_get_segment_usage_block(sufile, segnum, 1, &su_bh);\n+        if (ret < 0)\n+            goto out_header;\n+\n+        kaddr = kmap_atomic(su_bh->b_page);\n+        su = nilfs_sufile_block_get_segment_usage(sufile, segnum, su_bh, kaddr);\n+\n+        nsus = nilfs_sufile_segment_usages_in_block(sufile, segnum, maxsegnum);\n+        for (j = 0; j < nsus; j++, su = (void *)su + susz, segnum++) {\n+            if (!nilfs_segment_usage_clean(su))\n+                continue;\n+            nilfs_segment_usage_set_dirty(su);\n+            kunmap_atomic(kaddr);\n+\n+            kaddr = kmap_atomic(header_bh->b_page);\n+            header = kaddr + bh_offset(header_bh);\n+            le64_add_cpu(&header->sh_ncleansegs, -1);\n+            le64_add_cpu(&header->sh_ndirtysegs, 1);\n+            header->sh_last_alloc = cpu_to_le64(segnum);\n+            kunmap_atomic(kaddr);\n+\n+            sui->ncleansegs--;\n+            mark_buffer_dirty(header_bh);\n+            mark_buffer_dirty(su_bh);\n+            nilfs_mdt_mark_dirty(sufile);\n+            brelse(su_bh);\n+            *segnump = segnum;\n+\n+            trace_nilfs2_segment_usage_allocated(sufile, segnum);\n+            up_write(&NILFS_MDT(sufile)->mi_sem);\n+            return 0;\n+        }\n+        kunmap_atomic(kaddr);\n+        brelse(su_bh);\n+        up_write(&NILFS_MDT(sufile)->mi_sem);\n+    }\n+\n+    return -ENOSPC;\n+\n+out_header:\n+    brelse(header_bh);\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+    return ret;\n \tnsegs = nilfs_sufile_get_nsegments(sufile);\n \n \tif (start <= end && end < nsegs) {\n@@ -310,7 +544,85 @@ int nilfs_sufile_alloc(struct inode *sufile, __u64 *segnump)\n \tunsigned long nsegments, nsus, cnt;\n \tint ret, j;\n \n-\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+\t// Acquire the lock only for critical sections\n+    down_write(&NILFS_MDT(sufile)->mi_sem);\n+    // Perform header block retrieval outside lock\n+    ret = nilfs_sufile_get_header_block(sufile, &header_bh);\n+    if (ret < 0)\n+        return ret;\n+\n+    kaddr = kmap_atomic(header_bh->b_page);\n+    header = kaddr + bh_offset(header_bh);\n+    last_alloc = le64_to_cpu(header->sh_last_alloc);\n+    kunmap_atomic(kaddr);\n+\n+    nsegments = nilfs_sufile_get_nsegments(sufile);\n+    maxsegnum = sui->allocmax;\n+    segnum = last_alloc + 1;\n+    if (segnum < sui->allocmin || segnum > sui->allocmax)\n+        segnum = sui->allocmin;\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+    for (cnt = 0; cnt < nsegments; cnt += nsus) {\n+        down_write(&NILFS_MDT(sufile)->mi_sem);\n+        if (segnum > maxsegnum) {\n+            if (cnt < sui->allocmax - sui->allocmin + 1) {\n+                segnum = sui->allocmin;\n+                maxsegnum = last_alloc;\n+            } else if (segnum > sui->allocmin && sui->allocmax + 1 < nsegments) {\n+                segnum = sui->allocmax + 1;\n+                maxsegnum = nsegments - 1;\n+            } else if (sui->allocmin > 0)  {\n+                segnum = 0;\n+                maxsegnum = sui->allocmin - 1;\n+            } else {\n+                break;\n+            }\n+        }\n+        trace_nilfs2_segment_usage_check(sufile, segnum, cnt);\n+        ret = nilfs_sufile_get_segment_usage_block(sufile, segnum, 1, &su_bh);\n+        if (ret < 0)\n+            goto out_header;\n+\n+        kaddr = kmap_atomic(su_bh->b_page);\n+        su = nilfs_sufile_block_get_segment_usage(sufile, segnum, su_bh, kaddr);\n+\n+        nsus = nilfs_sufile_segment_usages_in_block(sufile, segnum, maxsegnum);\n+        for (j = 0; j < nsus; j++, su = (void *)su + susz, segnum++) {\n+            if (!nilfs_segment_usage_clean(su))\n+                continue;\n+            nilfs_segment_usage_set_dirty(su);\n+            kunmap_atomic(kaddr);\n+\n+            kaddr = kmap_atomic(header_bh->b_page);\n+            header = kaddr + bh_offset(header_bh);\n+            le64_add_cpu(&header->sh_ncleansegs, -1);\n+            le64_add_cpu(&header->sh_ndirtysegs, 1);\n+            header->sh_last_alloc = cpu_to_le64(segnum);\n+            kunmap_atomic(kaddr);\n+\n+            sui->ncleansegs--;\n+            mark_buffer_dirty(header_bh);\n+            mark_buffer_dirty(su_bh);\n+            nilfs_mdt_mark_dirty(sufile);\n+            brelse(su_bh);\n+            *segnump = segnum;\n+\n+            trace_nilfs2_segment_usage_allocated(sufile, segnum);\n+            up_write(&NILFS_MDT(sufile)->mi_sem);\n+            return 0;\n+        }\n+        kunmap_atomic(kaddr);\n+        brelse(su_bh);\n+        up_write(&NILFS_MDT(sufile)->mi_sem);\n+    }\n+\n+    return -ENOSPC;\n+\n+out_header:\n+    brelse(header_bh);\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+    return ret;\n \n \tret = nilfs_sufile_get_header_block(sufile, &header_bh);\n \tif (ret < 0)\n@@ -499,7 +811,85 @@ int nilfs_sufile_mark_dirty(struct inode *sufile, __u64 segnum)\n \tstruct nilfs_segment_usage *su;\n \tint ret;\n \n-\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+\t// Acquire the lock only for critical sections\n+    down_write(&NILFS_MDT(sufile)->mi_sem);\n+    // Perform header block retrieval outside lock\n+    ret = nilfs_sufile_get_header_block(sufile, &header_bh);\n+    if (ret < 0)\n+        return ret;\n+\n+    kaddr = kmap_atomic(header_bh->b_page);\n+    header = kaddr + bh_offset(header_bh);\n+    last_alloc = le64_to_cpu(header->sh_last_alloc);\n+    kunmap_atomic(kaddr);\n+\n+    nsegments = nilfs_sufile_get_nsegments(sufile);\n+    maxsegnum = sui->allocmax;\n+    segnum = last_alloc + 1;\n+    if (segnum < sui->allocmin || segnum > sui->allocmax)\n+        segnum = sui->allocmin;\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+    for (cnt = 0; cnt < nsegments; cnt += nsus) {\n+        down_write(&NILFS_MDT(sufile)->mi_sem);\n+        if (segnum > maxsegnum) {\n+            if (cnt < sui->allocmax - sui->allocmin + 1) {\n+                segnum = sui->allocmin;\n+                maxsegnum = last_alloc;\n+            } else if (segnum > sui->allocmin && sui->allocmax + 1 < nsegments) {\n+                segnum = sui->allocmax + 1;\n+                maxsegnum = nsegments - 1;\n+            } else if (sui->allocmin > 0)  {\n+                segnum = 0;\n+                maxsegnum = sui->allocmin - 1;\n+            } else {\n+                break;\n+            }\n+        }\n+        trace_nilfs2_segment_usage_check(sufile, segnum, cnt);\n+        ret = nilfs_sufile_get_segment_usage_block(sufile, segnum, 1, &su_bh);\n+        if (ret < 0)\n+            goto out_header;\n+\n+        kaddr = kmap_atomic(su_bh->b_page);\n+        su = nilfs_sufile_block_get_segment_usage(sufile, segnum, su_bh, kaddr);\n+\n+        nsus = nilfs_sufile_segment_usages_in_block(sufile, segnum, maxsegnum);\n+        for (j = 0; j < nsus; j++, su = (void *)su + susz, segnum++) {\n+            if (!nilfs_segment_usage_clean(su))\n+                continue;\n+            nilfs_segment_usage_set_dirty(su);\n+            kunmap_atomic(kaddr);\n+\n+            kaddr = kmap_atomic(header_bh->b_page);\n+            header = kaddr + bh_offset(header_bh);\n+            le64_add_cpu(&header->sh_ncleansegs, -1);\n+            le64_add_cpu(&header->sh_ndirtysegs, 1);\n+            header->sh_last_alloc = cpu_to_le64(segnum);\n+            kunmap_atomic(kaddr);\n+\n+            sui->ncleansegs--;\n+            mark_buffer_dirty(header_bh);\n+            mark_buffer_dirty(su_bh);\n+            nilfs_mdt_mark_dirty(sufile);\n+            brelse(su_bh);\n+            *segnump = segnum;\n+\n+            trace_nilfs2_segment_usage_allocated(sufile, segnum);\n+            up_write(&NILFS_MDT(sufile)->mi_sem);\n+            return 0;\n+        }\n+        kunmap_atomic(kaddr);\n+        brelse(su_bh);\n+        up_write(&NILFS_MDT(sufile)->mi_sem);\n+    }\n+\n+    return -ENOSPC;\n+\n+out_header:\n+    brelse(header_bh);\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+    return ret;\n \tret = nilfs_sufile_get_segment_usage_block(sufile, segnum, 0, &bh);\n \tif (!ret) {\n \t\tmark_buffer_dirty(bh);\n@@ -529,7 +919,85 @@ int nilfs_sufile_set_segment_usage(struct inode *sufile, __u64 segnum,\n \tvoid *kaddr;\n \tint ret;\n \n-\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+\t// Acquire the lock only for critical sections\n+    down_write(&NILFS_MDT(sufile)->mi_sem);\n+    // Perform header block retrieval outside lock\n+    ret = nilfs_sufile_get_header_block(sufile, &header_bh);\n+    if (ret < 0)\n+        return ret;\n+\n+    kaddr = kmap_atomic(header_bh->b_page);\n+    header = kaddr + bh_offset(header_bh);\n+    last_alloc = le64_to_cpu(header->sh_last_alloc);\n+    kunmap_atomic(kaddr);\n+\n+    nsegments = nilfs_sufile_get_nsegments(sufile);\n+    maxsegnum = sui->allocmax;\n+    segnum = last_alloc + 1;\n+    if (segnum < sui->allocmin || segnum > sui->allocmax)\n+        segnum = sui->allocmin;\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+    for (cnt = 0; cnt < nsegments; cnt += nsus) {\n+        down_write(&NILFS_MDT(sufile)->mi_sem);\n+        if (segnum > maxsegnum) {\n+            if (cnt < sui->allocmax - sui->allocmin + 1) {\n+                segnum = sui->allocmin;\n+                maxsegnum = last_alloc;\n+            } else if (segnum > sui->allocmin && sui->allocmax + 1 < nsegments) {\n+                segnum = sui->allocmax + 1;\n+                maxsegnum = nsegments - 1;\n+            } else if (sui->allocmin > 0)  {\n+                segnum = 0;\n+                maxsegnum = sui->allocmin - 1;\n+            } else {\n+                break;\n+            }\n+        }\n+        trace_nilfs2_segment_usage_check(sufile, segnum, cnt);\n+        ret = nilfs_sufile_get_segment_usage_block(sufile, segnum, 1, &su_bh);\n+        if (ret < 0)\n+            goto out_header;\n+\n+        kaddr = kmap_atomic(su_bh->b_page);\n+        su = nilfs_sufile_block_get_segment_usage(sufile, segnum, su_bh, kaddr);\n+\n+        nsus = nilfs_sufile_segment_usages_in_block(sufile, segnum, maxsegnum);\n+        for (j = 0; j < nsus; j++, su = (void *)su + susz, segnum++) {\n+            if (!nilfs_segment_usage_clean(su))\n+                continue;\n+            nilfs_segment_usage_set_dirty(su);\n+            kunmap_atomic(kaddr);\n+\n+            kaddr = kmap_atomic(header_bh->b_page);\n+            header = kaddr + bh_offset(header_bh);\n+            le64_add_cpu(&header->sh_ncleansegs, -1);\n+            le64_add_cpu(&header->sh_ndirtysegs, 1);\n+            header->sh_last_alloc = cpu_to_le64(segnum);\n+            kunmap_atomic(kaddr);\n+\n+            sui->ncleansegs--;\n+            mark_buffer_dirty(header_bh);\n+            mark_buffer_dirty(su_bh);\n+            nilfs_mdt_mark_dirty(sufile);\n+            brelse(su_bh);\n+            *segnump = segnum;\n+\n+            trace_nilfs2_segment_usage_allocated(sufile, segnum);\n+            up_write(&NILFS_MDT(sufile)->mi_sem);\n+            return 0;\n+        }\n+        kunmap_atomic(kaddr);\n+        brelse(su_bh);\n+        up_write(&NILFS_MDT(sufile)->mi_sem);\n+    }\n+\n+    return -ENOSPC;\n+\n+out_header:\n+    brelse(header_bh);\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+    return ret;\n \tret = nilfs_sufile_get_segment_usage_block(sufile, segnum, 0, &bh);\n \tif (ret < 0)\n \t\tgoto out_sem;\n@@ -756,7 +1224,85 @@ int nilfs_sufile_resize(struct inode *sufile, __u64 newnsegs)\n \tunsigned long nsegs, nrsvsegs;\n \tint ret = 0;\n \n-\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+\t// Acquire the lock only for critical sections\n+    down_write(&NILFS_MDT(sufile)->mi_sem);\n+    // Perform header block retrieval outside lock\n+    ret = nilfs_sufile_get_header_block(sufile, &header_bh);\n+    if (ret < 0)\n+        return ret;\n+\n+    kaddr = kmap_atomic(header_bh->b_page);\n+    header = kaddr + bh_offset(header_bh);\n+    last_alloc = le64_to_cpu(header->sh_last_alloc);\n+    kunmap_atomic(kaddr);\n+\n+    nsegments = nilfs_sufile_get_nsegments(sufile);\n+    maxsegnum = sui->allocmax;\n+    segnum = last_alloc + 1;\n+    if (segnum < sui->allocmin || segnum > sui->allocmax)\n+        segnum = sui->allocmin;\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+    for (cnt = 0; cnt < nsegments; cnt += nsus) {\n+        down_write(&NILFS_MDT(sufile)->mi_sem);\n+        if (segnum > maxsegnum) {\n+            if (cnt < sui->allocmax - sui->allocmin + 1) {\n+                segnum = sui->allocmin;\n+                maxsegnum = last_alloc;\n+            } else if (segnum > sui->allocmin && sui->allocmax + 1 < nsegments) {\n+                segnum = sui->allocmax + 1;\n+                maxsegnum = nsegments - 1;\n+            } else if (sui->allocmin > 0)  {\n+                segnum = 0;\n+                maxsegnum = sui->allocmin - 1;\n+            } else {\n+                break;\n+            }\n+        }\n+        trace_nilfs2_segment_usage_check(sufile, segnum, cnt);\n+        ret = nilfs_sufile_get_segment_usage_block(sufile, segnum, 1, &su_bh);\n+        if (ret < 0)\n+            goto out_header;\n+\n+        kaddr = kmap_atomic(su_bh->b_page);\n+        su = nilfs_sufile_block_get_segment_usage(sufile, segnum, su_bh, kaddr);\n+\n+        nsus = nilfs_sufile_segment_usages_in_block(sufile, segnum, maxsegnum);\n+        for (j = 0; j < nsus; j++, su = (void *)su + susz, segnum++) {\n+            if (!nilfs_segment_usage_clean(su))\n+                continue;\n+            nilfs_segment_usage_set_dirty(su);\n+            kunmap_atomic(kaddr);\n+\n+            kaddr = kmap_atomic(header_bh->b_page);\n+            header = kaddr + bh_offset(header_bh);\n+            le64_add_cpu(&header->sh_ncleansegs, -1);\n+            le64_add_cpu(&header->sh_ndirtysegs, 1);\n+            header->sh_last_alloc = cpu_to_le64(segnum);\n+            kunmap_atomic(kaddr);\n+\n+            sui->ncleansegs--;\n+            mark_buffer_dirty(header_bh);\n+            mark_buffer_dirty(su_bh);\n+            nilfs_mdt_mark_dirty(sufile);\n+            brelse(su_bh);\n+            *segnump = segnum;\n+\n+            trace_nilfs2_segment_usage_allocated(sufile, segnum);\n+            up_write(&NILFS_MDT(sufile)->mi_sem);\n+            return 0;\n+        }\n+        kunmap_atomic(kaddr);\n+        brelse(su_bh);\n+        up_write(&NILFS_MDT(sufile)->mi_sem);\n+    }\n+\n+    return -ENOSPC;\n+\n+out_header:\n+    brelse(header_bh);\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+    return ret;\n \n \tnsegs = nilfs_sufile_get_nsegments(sufile);\n \tif (nsegs == newnsegs)\n@@ -918,7 +1464,85 @@ ssize_t nilfs_sufile_set_suinfo(struct inode *sufile, void *buf,\n \t\t\treturn -EINVAL;\n \t}\n \n-\tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+\t// Acquire the lock only for critical sections\n+    down_write(&NILFS_MDT(sufile)->mi_sem);\n+    // Perform header block retrieval outside lock\n+    ret = nilfs_sufile_get_header_block(sufile, &header_bh);\n+    if (ret < 0)\n+        return ret;\n+\n+    kaddr = kmap_atomic(header_bh->b_page);\n+    header = kaddr + bh_offset(header_bh);\n+    last_alloc = le64_to_cpu(header->sh_last_alloc);\n+    kunmap_atomic(kaddr);\n+\n+    nsegments = nilfs_sufile_get_nsegments(sufile);\n+    maxsegnum = sui->allocmax;\n+    segnum = last_alloc + 1;\n+    if (segnum < sui->allocmin || segnum > sui->allocmax)\n+        segnum = sui->allocmin;\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+    for (cnt = 0; cnt < nsegments; cnt += nsus) {\n+        down_write(&NILFS_MDT(sufile)->mi_sem);\n+        if (segnum > maxsegnum) {\n+            if (cnt < sui->allocmax - sui->allocmin + 1) {\n+                segnum = sui->allocmin;\n+                maxsegnum = last_alloc;\n+            } else if (segnum > sui->allocmin && sui->allocmax + 1 < nsegments) {\n+                segnum = sui->allocmax + 1;\n+                maxsegnum = nsegments - 1;\n+            } else if (sui->allocmin > 0)  {\n+                segnum = 0;\n+                maxsegnum = sui->allocmin - 1;\n+            } else {\n+                break;\n+            }\n+        }\n+        trace_nilfs2_segment_usage_check(sufile, segnum, cnt);\n+        ret = nilfs_sufile_get_segment_usage_block(sufile, segnum, 1, &su_bh);\n+        if (ret < 0)\n+            goto out_header;\n+\n+        kaddr = kmap_atomic(su_bh->b_page);\n+        su = nilfs_sufile_block_get_segment_usage(sufile, segnum, su_bh, kaddr);\n+\n+        nsus = nilfs_sufile_segment_usages_in_block(sufile, segnum, maxsegnum);\n+        for (j = 0; j < nsus; j++, su = (void *)su + susz, segnum++) {\n+            if (!nilfs_segment_usage_clean(su))\n+                continue;\n+            nilfs_segment_usage_set_dirty(su);\n+            kunmap_atomic(kaddr);\n+\n+            kaddr = kmap_atomic(header_bh->b_page);\n+            header = kaddr + bh_offset(header_bh);\n+            le64_add_cpu(&header->sh_ncleansegs, -1);\n+            le64_add_cpu(&header->sh_ndirtysegs, 1);\n+            header->sh_last_alloc = cpu_to_le64(segnum);\n+            kunmap_atomic(kaddr);\n+\n+            sui->ncleansegs--;\n+            mark_buffer_dirty(header_bh);\n+            mark_buffer_dirty(su_bh);\n+            nilfs_mdt_mark_dirty(sufile);\n+            brelse(su_bh);\n+            *segnump = segnum;\n+\n+            trace_nilfs2_segment_usage_allocated(sufile, segnum);\n+            up_write(&NILFS_MDT(sufile)->mi_sem);\n+            return 0;\n+        }\n+        kunmap_atomic(kaddr);\n+        brelse(su_bh);\n+        up_write(&NILFS_MDT(sufile)->mi_sem);\n+    }\n+\n+    return -ENOSPC;\n+\n+out_header:\n+    brelse(header_bh);\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+    return ret;\n \n \tret = nilfs_sufile_get_header_block(sufile, &header_bh);\n \tif (ret < 0)\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "89740d8d8416726adeba5953543037142b3b20be": {
        "non_crash": [
            "diff --git a/security/keys/keyctl_pkey.c b/security/keys/keyctl_pkey.c\nindex 70e65a2ff207..160de49e2a92 100644\n--- a/security/keys/keyctl_pkey.c\n+++ b/security/keys/keyctl_pkey.c\n@@ -127,7 +127,8 @@ static int keyctl_pkey_params_get_2(const struct keyctl_pkey_params __user *_par\n \tif (copy_from_user(&uparams, _params, sizeof(uparams)) != 0)\n \t\treturn -EFAULT;\n \n-\tret = keyctl_pkey_params_get(uparams.key_id, _info, params);\n+\tif (!params || !params->key) return -EINVAL;\n+ret = keyctl_pkey_params_get(uparams.key_id, _info, params);\n \tif (ret < 0)\n \t\treturn ret;\n \n"
        ],
        "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..1ce586d1036f 100644\n--- a/security/keys/keyctl_pkey.c\n+++ b/security/keys/keyctl_pkey.c\n@@ -93,7 +93,9 @@ static int keyctl_pkey_params_get(key_serial_t id,\n \t\treturn PTR_ERR(p);\n \tparams->info = p;\n \n-\tret = keyctl_pkey_params_parse(params);\n+\tif (!params->info)\n+        return -EINVAL;\n+    ret = keyctl_pkey_params_parse(params);\n \tif (ret < 0)\n \t\treturn ret;\n \n",
            "diff --git a/security/keys/keyctl_pkey.c b/security/keys/keyctl_pkey.c\nindex 70e65a2ff207..5b590aa1840f 100644\n--- a/security/keys/keyctl_pkey.c\n+++ b/security/keys/keyctl_pkey.c\n@@ -101,6 +101,8 @@ static int keyctl_pkey_params_get(key_serial_t id,\n \tif (IS_ERR(key_ref))\n \t\treturn PTR_ERR(key_ref);\n \tparams->key = key_ref_to_ptr(key_ref);\n+if (!params->key)\n+return -EINVAL;\n \n \tif (!params->key->type->asym_query)\n \t\treturn -EOPNOTSUPP;\n",
            "diff --git a/security/keys/keyctl_pkey.c b/security/keys/keyctl_pkey.c\nindex 70e65a2ff207..3ea00fbbaeff 100644\n--- a/security/keys/keyctl_pkey.c\n+++ b/security/keys/keyctl_pkey.c\n@@ -93,7 +93,10 @@ static int keyctl_pkey_params_get(key_serial_t id,\n \t\treturn PTR_ERR(p);\n \tparams->info = p;\n \n-\tret = keyctl_pkey_params_parse(params);\n+\tif (!params->info)\n+return -EINVAL;\n+\n+ret = keyctl_pkey_params_parse(params);\n \tif (ret < 0)\n \t\treturn ret;\n \n"
        ],
        "error": []
    },
    "76c0afb6e24e6dc4093c36801d0b3a61b486ec4d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/segment.c b/fs/nilfs2/segment.c\nindex ac949fd7603f..a77fe7b778bc 100644\n--- a/fs/nilfs2/segment.c\n+++ b/fs/nilfs2/segment.c\n@@ -1499,7 +1499,12 @@ 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\tif (segbuf->sb_nextnum >= 0) {\n+    ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+} else {\n+    printk(KERN_WARNING \"Invalid segment number: %ld\\n\", segbuf->sb_nextnum);\n+    ret = -EINVAL;\n+}\n \t\tWARN_ON(ret);\n \t}\n \tnilfs_truncate_logs(&sci->sc_segbufs, last);\n",
            "diff --git a/fs/nilfs2/segment.c b/fs/nilfs2/segment.c\nindex ac949fd7603f..277a8aa51c1e 100644\n--- a/fs/nilfs2/segment.c\n+++ b/fs/nilfs2/segment.c\n@@ -1409,7 +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\tif (segbuf->sb_nextnum >= 0) {\n+    ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+    WARN_ON(ret); /* never fails */\n+}\n+else {\n+    printk(KERN_WARNING \"Invalid segment number: %ld\\n\", segbuf->sb_nextnum);\n+}\n \t\tWARN_ON(ret); /* never fails */\n \t}\n \tnilfs_destroy_logs(&list);\n@@ -1425,7 +1431,13 @@ static void nilfs_free_incomplete_logs(struct list_head *logs,\n \n \tsegbuf = NILFS_FIRST_SEGBUF(logs);\n \tif (nilfs->ns_nextnum != segbuf->sb_nextnum) {\n-\t\tret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+\t\tif (segbuf->sb_nextnum >= 0) {\n+    ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+    WARN_ON(ret); /* never fails */\n+}\n+else {\n+    printk(KERN_WARNING \"Invalid segment number: %ld\\n\", segbuf->sb_nextnum);\n+}\n \t\tWARN_ON(ret); /* never fails */\n \t}\n \tif (atomic_read(&segbuf->sb_err)) {\n@@ -1444,7 +1456,13 @@ static void nilfs_free_incomplete_logs(struct list_head *logs,\n \tprev = segbuf;\n \tlist_for_each_entry_continue(segbuf, logs, sb_list) {\n \t\tif (prev->sb_nextnum != segbuf->sb_nextnum) {\n-\t\t\tret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+\t\t\tif (segbuf->sb_nextnum >= 0) {\n+    ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+    WARN_ON(ret); /* never fails */\n+}\n+else {\n+    printk(KERN_WARNING \"Invalid segment number: %ld\\n\", segbuf->sb_nextnum);\n+}\n \t\t\tWARN_ON(ret); /* never fails */\n \t\t}\n \t\tif (atomic_read(&segbuf->sb_err) &&\n@@ -1499,7 +1517,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\tif (segbuf->sb_nextnum >= 0) {\n+    ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+    WARN_ON(ret); /* never fails */\n+}\n+else {\n+    printk(KERN_WARNING \"Invalid segment number: %ld\\n\", segbuf->sb_nextnum);\n+}\n \t\tWARN_ON(ret);\n \t}\n \tnilfs_truncate_logs(&sci->sc_segbufs, last);\n",
            "diff --git a/fs/nilfs2/segment.c b/fs/nilfs2/segment.c\nindex ac949fd7603f..c3f88d4c9045 100644\n--- a/fs/nilfs2/segment.c\n+++ b/fs/nilfs2/segment.c\n@@ -1409,7 +1409,9 @@ 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\tif (segbuf->sb_nextnum >= 0) {\n+            ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+        }\n \t\tWARN_ON(ret); /* never fails */\n \t}\n \tnilfs_destroy_logs(&list);\n@@ -1425,7 +1427,9 @@ static void nilfs_free_incomplete_logs(struct list_head *logs,\n \n \tsegbuf = NILFS_FIRST_SEGBUF(logs);\n \tif (nilfs->ns_nextnum != segbuf->sb_nextnum) {\n-\t\tret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+\t\tif (segbuf->sb_nextnum >= 0) {\n+            ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+        }\n \t\tWARN_ON(ret); /* never fails */\n \t}\n \tif (atomic_read(&segbuf->sb_err)) {\n@@ -1444,7 +1448,9 @@ static void nilfs_free_incomplete_logs(struct list_head *logs,\n \tprev = segbuf;\n \tlist_for_each_entry_continue(segbuf, logs, sb_list) {\n \t\tif (prev->sb_nextnum != segbuf->sb_nextnum) {\n-\t\t\tret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+\t\t\tif (segbuf->sb_nextnum >= 0) {\n+            ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+        }\n \t\t\tWARN_ON(ret); /* never fails */\n \t\t}\n \t\tif (atomic_read(&segbuf->sb_err) &&\n@@ -1499,7 +1505,9 @@ 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\tif (segbuf->sb_nextnum >= 0) {\n+            ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+        }\n \t\tWARN_ON(ret);\n \t}\n \tnilfs_truncate_logs(&sci->sc_segbufs, last);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/nilfs2/segment.c b/fs/nilfs2/segment.c\nindex ac949fd7603f..403eaa9bbf68 100644\n--- a/fs/nilfs2/segment.c\n+++ b/fs/nilfs2/segment.c\n@@ -1409,7 +1409,12 @@ 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\tif (unlikely(segbuf->sb_nextnum < 0 || segbuf->sb_nextnum >= nilfs->ns_nsegments)) {\n+            printk(KERN_WARNING \"nilfs: invalid segment number: %lu\\n\", segbuf->sb_nextnum);\n+            ret = -EINVAL;\n+        } else {\n+            ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+        }\n \t\tWARN_ON(ret); /* never fails */\n \t}\n \tnilfs_destroy_logs(&list);\n@@ -1425,7 +1430,12 @@ static void nilfs_free_incomplete_logs(struct list_head *logs,\n \n \tsegbuf = NILFS_FIRST_SEGBUF(logs);\n \tif (nilfs->ns_nextnum != segbuf->sb_nextnum) {\n-\t\tret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+\t\tif (unlikely(segbuf->sb_nextnum < 0 || segbuf->sb_nextnum >= nilfs->ns_nsegments)) {\n+            printk(KERN_WARNING \"nilfs: invalid segment number: %lu\\n\", segbuf->sb_nextnum);\n+            ret = -EINVAL;\n+        } else {\n+            ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+        }\n \t\tWARN_ON(ret); /* never fails */\n \t}\n \tif (atomic_read(&segbuf->sb_err)) {\n@@ -1444,7 +1454,12 @@ static void nilfs_free_incomplete_logs(struct list_head *logs,\n \tprev = segbuf;\n \tlist_for_each_entry_continue(segbuf, logs, sb_list) {\n \t\tif (prev->sb_nextnum != segbuf->sb_nextnum) {\n-\t\t\tret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+\t\t\tif (unlikely(segbuf->sb_nextnum < 0 || segbuf->sb_nextnum >= nilfs->ns_nsegments)) {\n+            printk(KERN_WARNING \"nilfs: invalid segment number: %lu\\n\", segbuf->sb_nextnum);\n+            ret = -EINVAL;\n+        } else {\n+            ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+        }\n \t\t\tWARN_ON(ret); /* never fails */\n \t\t}\n \t\tif (atomic_read(&segbuf->sb_err) &&\n@@ -1499,7 +1514,12 @@ 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\tif (unlikely(segbuf->sb_nextnum < 0 || segbuf->sb_nextnum >= nilfs->ns_nsegments)) {\n+            printk(KERN_WARNING \"nilfs: invalid segment number: %lu\\n\", segbuf->sb_nextnum);\n+            ret = -EINVAL;\n+        } else {\n+            ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+        }\n \t\tWARN_ON(ret);\n \t}\n \tnilfs_truncate_logs(&sci->sc_segbufs, last);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/nilfs2/segment.c b/fs/nilfs2/segment.c\nindex ac949fd7603f..3a0214163559 100644\n--- a/fs/nilfs2/segment.c\n+++ b/fs/nilfs2/segment.c\n@@ -1409,7 +1409,11 @@ 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\tret = if (segbuf->sb_nextnum >= 0) {\n+            ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+        } else {\n+            ret = -EINVAL;\n+        }\n \t\tWARN_ON(ret); /* never fails */\n \t}\n \tnilfs_destroy_logs(&list);\n@@ -1425,7 +1429,11 @@ static void nilfs_free_incomplete_logs(struct list_head *logs,\n \n \tsegbuf = NILFS_FIRST_SEGBUF(logs);\n \tif (nilfs->ns_nextnum != segbuf->sb_nextnum) {\n-\t\tret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+\t\tret = if (segbuf->sb_nextnum >= 0) {\n+            ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+        } else {\n+            ret = -EINVAL;\n+        }\n \t\tWARN_ON(ret); /* never fails */\n \t}\n \tif (atomic_read(&segbuf->sb_err)) {\n@@ -1444,7 +1452,11 @@ static void nilfs_free_incomplete_logs(struct list_head *logs,\n \tprev = segbuf;\n \tlist_for_each_entry_continue(segbuf, logs, sb_list) {\n \t\tif (prev->sb_nextnum != segbuf->sb_nextnum) {\n-\t\t\tret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+\t\t\tret = if (segbuf->sb_nextnum >= 0) {\n+            ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+        } else {\n+            ret = -EINVAL;\n+        }\n \t\t\tWARN_ON(ret); /* never fails */\n \t\t}\n \t\tif (atomic_read(&segbuf->sb_err) &&\n@@ -1499,7 +1511,11 @@ 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\tret = if (segbuf->sb_nextnum >= 0) {\n+            ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+        } else {\n+            ret = -EINVAL;\n+        }\n \t\tWARN_ON(ret);\n \t}\n \tnilfs_truncate_logs(&sci->sc_segbufs, last);\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..2e44477ac612 100644\n--- a/fs/nilfs2/bmap.c\n+++ b/fs/nilfs2/bmap.c\n@@ -501,6 +501,7 @@ int nilfs_bmap_read(struct nilfs_bmap *bmap, struct nilfs_inode *raw_inode)\n \t\tmemcpy(bmap->b_u.u_data, raw_inode->i_bmap, NILFS_BMAP_SIZE);\n \n \tinit_rwsem(&bmap->b_sem);\n+    lockdep_set_class(&bmap->b_sem, &nilfs_bmap_mdt_lock_key);\n \tbmap->b_state = 0;\n \tbmap->b_inode = &NILFS_BMAP_I(bmap)->vfs_inode;\n \tswitch (bmap->b_inode->i_ino) {\n@@ -553,6 +554,7 @@ void nilfs_bmap_init_gc(struct nilfs_bmap *bmap)\n {\n \tmemset(&bmap->b_u, 0, NILFS_BMAP_SIZE);\n \tinit_rwsem(&bmap->b_sem);\n+    lockdep_set_class(&bmap->b_sem, &nilfs_bmap_mdt_lock_key);\n \tbmap->b_inode = &NILFS_BMAP_I(bmap)->vfs_inode;\n \tbmap->b_ptr_type = NILFS_BMAP_PTR_U;\n \tbmap->b_last_allocated_key = 0;\n",
            "diff --git a/fs/nilfs2/bmap.c b/fs/nilfs2/bmap.c\nindex 798a2c1b38c6..2e44477ac612 100644\n--- a/fs/nilfs2/bmap.c\n+++ b/fs/nilfs2/bmap.c\n@@ -501,6 +501,7 @@ int nilfs_bmap_read(struct nilfs_bmap *bmap, struct nilfs_inode *raw_inode)\n \t\tmemcpy(bmap->b_u.u_data, raw_inode->i_bmap, NILFS_BMAP_SIZE);\n \n \tinit_rwsem(&bmap->b_sem);\n+    lockdep_set_class(&bmap->b_sem, &nilfs_bmap_mdt_lock_key);\n \tbmap->b_state = 0;\n \tbmap->b_inode = &NILFS_BMAP_I(bmap)->vfs_inode;\n \tswitch (bmap->b_inode->i_ino) {\n@@ -553,6 +554,7 @@ void nilfs_bmap_init_gc(struct nilfs_bmap *bmap)\n {\n \tmemset(&bmap->b_u, 0, NILFS_BMAP_SIZE);\n \tinit_rwsem(&bmap->b_sem);\n+    lockdep_set_class(&bmap->b_sem, &nilfs_bmap_mdt_lock_key);\n \tbmap->b_inode = &NILFS_BMAP_I(bmap)->vfs_inode;\n \tbmap->b_ptr_type = NILFS_BMAP_PTR_U;\n \tbmap->b_last_allocated_key = 0;\n",
            "diff --git a/fs/nilfs2/bmap.c b/fs/nilfs2/bmap.c\nindex 798a2c1b38c6..b4d4e158133c 100644\n--- a/fs/nilfs2/bmap.c\n+++ b/fs/nilfs2/bmap.c\n@@ -501,6 +501,7 @@ int nilfs_bmap_read(struct nilfs_bmap *bmap, struct nilfs_inode *raw_inode)\n \t\tmemcpy(bmap->b_u.u_data, raw_inode->i_bmap, NILFS_BMAP_SIZE);\n \n \tinit_rwsem(&bmap->b_sem);\n+    lockdep_set_class(&bmap->b_sem, &nilfs_bmap_dat_lock_key);\n \tbmap->b_state = 0;\n \tbmap->b_inode = &NILFS_BMAP_I(bmap)->vfs_inode;\n \tswitch (bmap->b_inode->i_ino) {\n@@ -553,6 +554,7 @@ void nilfs_bmap_init_gc(struct nilfs_bmap *bmap)\n {\n \tmemset(&bmap->b_u, 0, NILFS_BMAP_SIZE);\n \tinit_rwsem(&bmap->b_sem);\n+    lockdep_set_class(&bmap->b_sem, &nilfs_bmap_dat_lock_key);\n \tbmap->b_inode = &NILFS_BMAP_I(bmap)->vfs_inode;\n \tbmap->b_ptr_type = NILFS_BMAP_PTR_U;\n \tbmap->b_last_allocated_key = 0;\n",
            "diff --git a/fs/nilfs2/bmap.c b/fs/nilfs2/bmap.c\nindex 798a2c1b38c6..af116d9a66a3 100644\n--- a/fs/nilfs2/bmap.c\n+++ b/fs/nilfs2/bmap.c\n@@ -65,7 +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-\tdown_read(&bmap->b_sem);\n+\tif (!lockdep_is_held(&bmap->b_sem)) {\n+        init_rwsem(&bmap->b_sem);\n+    }\n+    down_read(&bmap->b_sem);\n \tret = bmap->b_ops->bop_lookup(bmap, key, level, ptrp);\n \tif (ret < 0) {\n \t\tret = nilfs_bmap_convert_error(bmap, __func__, ret);\n@@ -88,7 +91,10 @@ int nilfs_bmap_lookup_contig(struct nilfs_bmap *bmap, __u64 key, __u64 *ptrp,\n {\n \tint ret;\n \n-\tdown_read(&bmap->b_sem);\n+\tif (!lockdep_is_held(&bmap->b_sem)) {\n+        init_rwsem(&bmap->b_sem);\n+    }\n+    down_read(&bmap->b_sem);\n \tret = bmap->b_ops->bop_lookup_contig(bmap, key, ptrp, maxblocks);\n \tup_read(&bmap->b_sem);\n \n@@ -198,7 +204,10 @@ int nilfs_bmap_seek_key(struct nilfs_bmap *bmap, __u64 start, __u64 *keyp)\n {\n \tint ret;\n \n-\tdown_read(&bmap->b_sem);\n+\tif (!lockdep_is_held(&bmap->b_sem)) {\n+        init_rwsem(&bmap->b_sem);\n+    }\n+    down_read(&bmap->b_sem);\n \tret = bmap->b_ops->bop_seek_key(bmap, start, keyp);\n \tup_read(&bmap->b_sem);\n \n@@ -211,7 +220,10 @@ int nilfs_bmap_last_key(struct nilfs_bmap *bmap, __u64 *keyp)\n {\n \tint ret;\n \n-\tdown_read(&bmap->b_sem);\n+\tif (!lockdep_is_held(&bmap->b_sem)) {\n+        init_rwsem(&bmap->b_sem);\n+    }\n+    down_read(&bmap->b_sem);\n \tret = bmap->b_ops->bop_last_key(bmap, keyp);\n \tup_read(&bmap->b_sem);\n \n"
        ],
        "error": []
    },
    "a59816f87c8e514d1b5ed891ae85341fbef1e553": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/iomap/direct-io.c b/fs/iomap/direct-io.c\nindex 62da020d02a1..b9d630ffd478 100644\n--- a/fs/iomap/direct-io.c\n+++ b/fs/iomap/direct-io.c\n@@ -653,8 +653,10 @@ __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\trcu_read_lock();\n+            if (!dio->submit.poll_bio ||\n \t\t\t    !bio_poll(dio->submit.poll_bio, NULL, 0))\n+                rcu_read_unlock();\n \t\t\t\tblk_io_schedule();\n \t\t}\n \t\t__set_current_state(TASK_RUNNING);\n",
            "diff --git a/block/blk-core.c b/block/blk-core.c\nindex f305cb66c72a..348b2245cefb 100644\n--- a/block/blk-core.c\n+++ b/block/blk-core.c\n@@ -999,6 +999,8 @@ int iocb_bio_iopoll(struct kiocb *kiocb, struct io_comp_batch *iob,\n \t */\n \trcu_read_lock();\n \tbio = READ_ONCE(kiocb->private);\n+if (!bio || !rcu_access_pointer(bio->bi_bdev))\n+return 0;\n \tif (bio && bio->bi_bdev)\n \t\tret = bio_poll(bio, iob, flags);\n \trcu_read_unlock();\n"
        ],
        "error": [
            {
                "patch": "diff --git a/block/blk-core.c b/block/blk-core.c\nindex f305cb66c72a..bb7b606ddf64 100644\n--- a/block/blk-core.c\n+++ b/block/blk-core.c\n@@ -941,6 +941,37 @@ EXPORT_SYMBOL(submit_bio);\n  * be in a RCU critical section to prevent freeing of @bio.\n  */\n int bio_poll(struct bio *bio, struct io_comp_batch *iob, unsigned int flags)\n+{\n+    rcu_read_lock();\n+    struct request_queue *q = bdev_get_queue(bio->bi_bdev);\n+    blk_qc_t cookie = READ_ONCE(bio->bi_cookie);\n+    int ret = 0;\n+\n+    if (cookie == BLK_QC_T_NONE ||\n+        !test_bit(QUEUE_FLAG_POLL, &q->queue_flags)) {\n+        rcu_read_unlock();\n+        return 0;\n+    }\n+\n+    blk_flush_plug(current->plug, false);\n+\n+    if (blk_queue_enter(q, BLK_MQ_REQ_NOWAIT)) {\n+        rcu_read_unlock();\n+        return 0;\n+    }\n+    if (queue_is_mq(q)) {\n+        ret = blk_mq_poll(q, cookie, iob, flags);\n+    } else {\n+        struct gendisk *disk = q->disk;\n+\n+        if (disk && disk->fops->poll_bio)\n+            ret = disk->fops->poll_bio(bio, iob, flags);\n+    }\n+    blk_queue_exit(q);\n+    rcu_read_unlock();\n+\n+    return ret;\n+}\n {\n \tstruct request_queue *q = bdev_get_queue(bio->bi_bdev);\n \tblk_qc_t cookie = READ_ONCE(bio->bi_cookie);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/block/blk-core.c b/block/blk-core.c\nindex f305cb66c72a..618d0577f36f 100644\n--- a/block/blk-core.c\n+++ b/block/blk-core.c\n@@ -941,6 +941,10 @@ EXPORT_SYMBOL(submit_bio);\n  * be in a RCU critical section to prevent freeing of @bio.\n  */\n int bio_poll(struct bio *bio, struct io_comp_batch *iob, unsigned int flags)\n+{\n+/* Ensure the bio is not freed while being accessed */\n+if (!atomic_inc_not_zero(&bio->bi_refs))\n+return 0;\n {\n \tstruct request_queue *q = bdev_get_queue(bio->bi_bdev);\n \tblk_qc_t cookie = READ_ONCE(bio->bi_cookie);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/block/blk-core.c b/block/blk-core.c\nindex f305cb66c72a..7cd383f09976 100644\n--- a/block/blk-core.c\n+++ b/block/blk-core.c\n@@ -941,6 +941,11 @@ EXPORT_SYMBOL(submit_bio);\n  * be in a RCU critical section to prevent freeing of @bio.\n  */\n int bio_poll(struct bio *bio, struct io_comp_batch *iob, unsigned int flags)\n+{\n+if (!bio || atomic_read(&bio->__bi_cnt) <= 0) {\n+return 0;\n+}\n+\n {\n \tstruct request_queue *q = bdev_get_queue(bio->bi_bdev);\n \tblk_qc_t cookie = READ_ONCE(bio->bi_cookie);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "67d3719a7490d99812faae7f9c2c26e9f386c1a6": {
        "non_crash": [
            "diff --git a/fs/hfs/trans.c b/fs/hfs/trans.c\nindex 39f5e343bf4d..7ec782ff28fd 100644\n--- a/fs/hfs/trans.c\n+++ b/fs/hfs/trans.c\n@@ -130,7 +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\tif (dstlen > 0) {\n+*dst++ = ch > 0xff ? '?' : ch;\n+dstlen--;\n+}\n \t\t\t\tdstlen--;\n \t\t\t}\n \t\t}\n",
            "diff --git a/fs/hfs/trans.c b/fs/hfs/trans.c\nindex 39f5e343bf4d..733e0c786fae 100644\n--- a/fs/hfs/trans.c\n+++ b/fs/hfs/trans.c\n@@ -130,7 +130,7 @@ 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\tif (dstlen > 0) *dst++ = ch > 0xff ? '?' : ch;\n \t\t\t\tdstlen--;\n \t\t\t}\n \t\t}\n",
            "diff --git a/fs/hfs/trans.c b/fs/hfs/trans.c\nindex 39f5e343bf4d..8a76788877bd 100644\n--- a/fs/hfs/trans.c\n+++ b/fs/hfs/trans.c\n@@ -130,7 +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\tif (dstlen > 0) {\n+    *dst++ = ch > 0xff ? '?' : ch;\n+    dstlen--;\n+}\n \t\t\t\tdstlen--;\n \t\t\t}\n \t\t}\n",
            "diff --git a/fs/hfs/trans.c b/fs/hfs/trans.c\nindex 39f5e343bf4d..733e0c786fae 100644\n--- a/fs/hfs/trans.c\n+++ b/fs/hfs/trans.c\n@@ -130,7 +130,7 @@ 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\tif (dstlen > 0) *dst++ = ch > 0xff ? '?' : ch;\n \t\t\t\tdstlen--;\n \t\t\t}\n \t\t}\n",
            "diff --git a/fs/hfs/trans.c b/fs/hfs/trans.c\nindex 39f5e343bf4d..ca4d4fcd93c9 100644\n--- a/fs/hfs/trans.c\n+++ b/fs/hfs/trans.c\n@@ -130,7 +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\tif (dstlen > 0) {\n+*dst++ = ch > 0xff ? '?' : ch;\n+--dstlen;\n+}\n \t\t\t\tdstlen--;\n \t\t\t}\n \t\t}\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "1bb19c23cbf08cedbc6bbe5d4b7e07f6403fa35e": {
        "non_crash": [
            "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex 9e2735cbc2b4..01298fa81eeb 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -1354,7 +1354,9 @@ static inline struct maple_enode *mas_start(struct ma_state *mas)\n \t\tmas->max = ULONG_MAX;\n \t\tmas->depth = 0;\n \n-\t\troot = mas_root(mas);\n+\t\trcu_read_lock();\n+        root = mas_root(mas);\n+        rcu_read_unlock();\n \t\t/* Tree with nodes */\n \t\tif (likely(xa_is_node(root))) {\n \t\t\tmas->depth = 1;\n",
            "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex 9e2735cbc2b4..01298fa81eeb 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -1354,7 +1354,9 @@ static inline struct maple_enode *mas_start(struct ma_state *mas)\n \t\tmas->max = ULONG_MAX;\n \t\tmas->depth = 0;\n \n-\t\troot = mas_root(mas);\n+\t\trcu_read_lock();\n+        root = mas_root(mas);\n+        rcu_read_unlock();\n \t\t/* Tree with nodes */\n \t\tif (likely(xa_is_node(root))) {\n \t\t\tmas->depth = 1;\n",
            "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex 9e2735cbc2b4..41ef2a3ca1ba 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -1354,7 +1354,9 @@ static inline struct maple_enode *mas_start(struct ma_state *mas)\n \t\tmas->max = ULONG_MAX;\n \t\tmas->depth = 0;\n \n-\t\troot = mas_root(mas);\n+\t\trcu_read_lock();\n+root = mas_root(mas);\n+rcu_read_unlock();\n \t\t/* Tree with nodes */\n \t\tif (likely(xa_is_node(root))) {\n \t\t\tmas->depth = 1;\n"
        ],
        "special_crash": [],
        "crash": [
            "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"
        ],
        "error": []
    },
    "2e1943a94647f7732dd6fc60368642d6e8dc91b1": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c\nindex b0d9c36acc03..5285cea510b8 100644\n--- a/net/bluetooth/hci_core.c\n+++ b/net/bluetooth/hci_core.c\n@@ -4369,6 +4369,12 @@ static void hci_queue_acl(struct hci_chan *chan, struct sk_buff_head *queue,\n }\n \n void hci_send_acl(struct hci_chan *chan, struct sk_buff *skb, __u16 flags)\n+{\n+if (!chan || !chan->conn) {\n+BT_ERR(\"Invalid channel or connection\");\n+return;\n+}\n+\n {\n \tstruct hci_dev *hdev = chan->conn->hdev;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c\nindex b0d9c36acc03..e6d5929f579a 100644\n--- a/net/bluetooth/hci_core.c\n+++ b/net/bluetooth/hci_core.c\n@@ -4370,7 +4370,8 @@ 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-\tstruct hci_dev *hdev = chan->conn->hdev;\n+\thci_conn_get(chan->conn);\n+    struct hci_dev *hdev = chan->conn->hdev;\n \n \tBT_DBG(\"%s chan %p flags 0x%4.4x\", hdev->name, chan, flags);\n \n@@ -4868,6 +4869,7 @@ static void hci_tx_work(struct work_struct *work)\n \n \t/* Send next queued raw (unknown type) packet */\n \twhile ((skb = skb_dequeue(&hdev->raw_q)))\n+hci_conn_put(hdev->conn);\n \t\thci_send_frame(hdev, skb);\n }\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..da75e05cadf5 100644\n--- a/fs/xfs/xfs_bmap_util.c\n+++ b/fs/xfs/xfs_bmap_util.c\n@@ -558,7 +558,8 @@ 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+                out[bmv->bmv_entries - 1].bmv_oflags |= BMV_OF_LAST;\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..e2f130bb5305 100644\n--- a/fs/xfs/xfs_bmap_util.c\n+++ b/fs/xfs/xfs_bmap_util.c\n@@ -558,7 +558,8 @@ 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+out[bmv->bmv_entries - 1].bmv_oflags |= BMV_OF_LAST;\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..5aad77900fc4 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+                out[bmv->bmv_entries - 1].bmv_oflags |= BMV_OF_LAST;\n+            }\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..ffc7bb6e591f 100644\n--- a/fs/xfs/xfs_bmap_util.c\n+++ b/fs/xfs/xfs_bmap_util.c\n@@ -558,7 +558,8 @@ 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+    out[bmv->bmv_entries - 1].bmv_oflags |= BMV_OF_LAST;\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..e2f130bb5305 100644\n--- a/fs/xfs/xfs_bmap_util.c\n+++ b/fs/xfs/xfs_bmap_util.c\n@@ -558,7 +558,8 @@ 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+out[bmv->bmv_entries - 1].bmv_oflags |= BMV_OF_LAST;\n \n \t\t\tif (whichfork != XFS_ATTR_FORK && bno < end &&\n \t\t\t    !xfs_getbmap_full(bmv)) {\n"
        ],
        "special_crash": [],
        "crash": [],
        "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..0956f8d91193 100644\n--- a/drivers/video/fbdev/core/bitblit.c\n+++ b/drivers/video/fbdev/core/bitblit.c\n@@ -198,7 +198,11 @@ static void bit_putcs(struct vc_data *vc, struct fb_info *info,\n \t   it's a gain to check buf against NULL even though kfree() handles\n \t   NULL pointers just fine */\n \tif (unlikely(buf))\n-\t\tkfree(buf);\n+\t\t// Introduce a flag or mechanism to delay freeing buf until all operations using it are complete\n+    if (unlikely(buf)) {\n+        synchronize_rcu(); // Ensure all operations using buf are complete\n+        kfree(buf);\n+    }\n \n }\n \n",
            "diff --git a/drivers/video/fbdev/core/bitblit.c b/drivers/video/fbdev/core/bitblit.c\nindex 9725ecd1255b..01eaa74b8ac0 100644\n--- a/drivers/video/fbdev/core/bitblit.c\n+++ b/drivers/video/fbdev/core/bitblit.c\n@@ -199,6 +199,7 @@ static void bit_putcs(struct vc_data *vc, struct fb_info *info,\n \t   NULL pointers just fine */\n \tif (unlikely(buf))\n \t\tkfree(buf);\n+buf = NULL;\n \n }\n \n",
            "diff --git a/drivers/video/fbdev/core/bitblit.c b/drivers/video/fbdev/core/bitblit.c\nindex 9725ecd1255b..3742b389e6c9 100644\n--- a/drivers/video/fbdev/core/bitblit.c\n+++ b/drivers/video/fbdev/core/bitblit.c\n@@ -88,7 +88,10 @@ static inline void bit_putcs_aligned(struct vc_data *vc, struct fb_info *info,\n \t\t\t\t\t  charmask)*cellsize;\n \n \t\tif (attr) {\n-\t\t\tupdate_attr(buf, src, attr, vc);\n+\t\t\tif (buf) {\n+    update_attr(buf, src, attr, vc);\n+    src = buf;\n+}\n \t\t\tsrc = buf;\n \t\t}\n \n@@ -123,7 +126,10 @@ static inline void bit_putcs_unaligned(struct vc_data *vc,\n \t\t\t\t\t  charmask)*cellsize;\n \n \t\tif (attr) {\n-\t\t\tupdate_attr(buf, src, attr, vc);\n+\t\t\tif (buf) {\n+    update_attr(buf, src, attr, vc);\n+    src = buf;\n+}\n \t\t\tsrc = buf;\n \t\t}\n \n"
        ],
        "error": []
    },
    "bb281e89381b9ed55728c274447a575e69a96c35": {
        "non_crash": [
            "diff --git a/fs/overlayfs/util.c b/fs/overlayfs/util.c\nindex 81a57a8d80d9..4148015a7fa4 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 inode *inode = d_inode(dentry);\n+    if (!inode)\n+        return NULL;\n+    return ovl_upperdentry_dereference(OVL_I(inode));\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..b32c514ed992 100644\n--- a/fs/overlayfs/util.c\n+++ b/fs/overlayfs/util.c\n@@ -210,7 +210,7 @@ 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+\treturn d_inode(dentry) ? ovl_upperdentry_dereference(OVL_I(d_inode(dentry))) : NULL;\n }\n \n struct dentry *ovl_dentry_lower(struct dentry *dentry)\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/overlayfs/ovl_entry.h b/fs/overlayfs/ovl_entry.h\nindex e1af8f660698..d3f1afd580d8 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-\treturn READ_ONCE(oi->__upperdentry);\n+\tif (!oi)\n+    return NULL;\n+return READ_ONCE(oi->__upperdentry);\n }\n",
            "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 }\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/overlayfs/util.c b/fs/overlayfs/util.c\nindex 81a57a8d80d9..ba7c05b0f02f 100644\n--- a/fs/overlayfs/util.c\n+++ b/fs/overlayfs/util.c\n@@ -209,6 +209,9 @@ enum ovl_path_type ovl_path_realdata(struct dentry *dentry, struct path *path)\n }\n \n struct dentry *ovl_dentry_upper(struct dentry *dentry)\n+{\n+if (!dentry || !d_inode(dentry))\n+return NULL;\n {\n \treturn ovl_upperdentry_dereference(OVL_I(d_inode(dentry)));\n }\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "08bcc3eb4d1892c93490ce2924713568b1fed364": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/f2fs/dir.c b/fs/f2fs/dir.c\nindex d635c58cf5a3..e28ec62073c5 100644\n--- a/fs/f2fs/dir.c\n+++ b/fs/f2fs/dir.c\n@@ -736,7 +736,8 @@ int f2fs_add_regular_entry(struct inode *dir, const struct f2fs_filename *fname,\n \tf2fs_wait_on_page_writeback(dentry_page, DATA, true, true);\n \n \tif (inode) {\n-\t\tf2fs_down_write(&F2FS_I(inode)->i_sem);\n+\t\tf2fs_down_read(&F2FS_I(inode)->i_xattr_sem);\n+    f2fs_down_write(&F2FS_I(inode)->i_sem);\n \t\tpage = f2fs_init_inode_metadata(inode, dir, fname, NULL);\n \t\tif (IS_ERR(page)) {\n \t\t\terr = PTR_ERR(page);\n@@ -835,7 +836,8 @@ int f2fs_do_tmpfile(struct inode *inode, struct inode *dir)\n \tstruct page *page;\n \tint err = 0;\n \n-\tf2fs_down_write(&F2FS_I(inode)->i_sem);\n+\tf2fs_down_read(&F2FS_I(inode)->i_xattr_sem);\n+    f2fs_down_write(&F2FS_I(inode)->i_sem);\n \tpage = f2fs_init_inode_metadata(inode, dir, NULL, NULL);\n \tif (IS_ERR(page)) {\n \t\terr = PTR_ERR(page);\n@@ -854,7 +856,8 @@ void f2fs_drop_nlink(struct inode *dir, struct inode *inode)\n {\n \tstruct f2fs_sb_info *sbi = F2FS_I_SB(dir);\n \n-\tf2fs_down_write(&F2FS_I(inode)->i_sem);\n+\tf2fs_down_read(&F2FS_I(inode)->i_xattr_sem);\n+    f2fs_down_write(&F2FS_I(inode)->i_sem);\n \n \tif (S_ISDIR(inode->i_mode))\n \t\tf2fs_i_links_write(dir, false);\n",
            "diff --git a/fs/f2fs/xattr.c b/fs/f2fs/xattr.c\nindex 9cc1ca75b2da..5a1a000a1dce 100644\n--- a/fs/f2fs/xattr.c\n+++ b/fs/f2fs/xattr.c\n@@ -529,7 +529,7 @@ int f2fs_getxattr(struct inode *inode, int index, const char *name,\n \t\treturn -ERANGE;\n \n \tif (!ipage)\n-\t\tf2fs_down_read(&F2FS_I(inode)->i_xattr_sem);\n+\t\tf2fs_down_read(&F2FS_I(inode)->i_sem);\n \terror = lookup_all_xattrs(inode, ipage, index, len, name,\n \t\t\t\t&entry, &base_addr, &base_size, &is_inline);\n \tif (!ipage)\n@@ -567,7 +567,7 @@ ssize_t f2fs_listxattr(struct dentry *dentry, char *buffer, size_t buffer_size)\n \tint error;\n \tsize_t rest = buffer_size;\n \n-\tf2fs_down_read(&F2FS_I(inode)->i_xattr_sem);\n+\tf2fs_down_read(&F2FS_I(inode)->i_sem);\n \terror = read_all_xattrs(inode, NULL, &base_addr);\n \tf2fs_up_read(&F2FS_I(inode)->i_xattr_sem);\n \tif (error)\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/f2fs/dir.c b/fs/f2fs/dir.c\nindex d635c58cf5a3..9d901964e6ab 100644\n--- a/fs/f2fs/dir.c\n+++ b/fs/f2fs/dir.c\n@@ -736,7 +736,8 @@ int f2fs_add_regular_entry(struct inode *dir, const struct f2fs_filename *fname,\n \tf2fs_wait_on_page_writeback(dentry_page, DATA, true, true);\n \n \tif (inode) {\n-\t\tf2fs_down_write(&F2FS_I(inode)->i_sem);\n+\t\tif (!down_read_trylock(&F2FS_I(inode)->i_xattr_sem)) { return -EDEADLK; }\n+f2fs_down_write(&F2FS_I(inode)->i_sem);\n \t\tpage = f2fs_init_inode_metadata(inode, dir, fname, NULL);\n \t\tif (IS_ERR(page)) {\n \t\t\terr = PTR_ERR(page);\n@@ -835,7 +836,8 @@ int f2fs_do_tmpfile(struct inode *inode, struct inode *dir)\n \tstruct page *page;\n \tint err = 0;\n \n-\tf2fs_down_write(&F2FS_I(inode)->i_sem);\n+\tif (!down_read_trylock(&F2FS_I(inode)->i_xattr_sem)) { return -EDEADLK; }\n+f2fs_down_write(&F2FS_I(inode)->i_sem);\n \tpage = f2fs_init_inode_metadata(inode, dir, NULL, NULL);\n \tif (IS_ERR(page)) {\n \t\terr = PTR_ERR(page);\n@@ -854,7 +856,8 @@ void f2fs_drop_nlink(struct inode *dir, struct inode *inode)\n {\n \tstruct f2fs_sb_info *sbi = F2FS_I_SB(dir);\n \n-\tf2fs_down_write(&F2FS_I(inode)->i_sem);\n+\tif (!down_read_trylock(&F2FS_I(inode)->i_xattr_sem)) { return -EDEADLK; }\n+f2fs_down_write(&F2FS_I(inode)->i_sem);\n \n \tif (S_ISDIR(inode->i_mode))\n \t\tf2fs_i_links_write(dir, false);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "223c64b1a2c03f0d67d64fdf69606ee2d5e26672": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/batman-adv/network-coding.c b/net/batman-adv/network-coding.c\nindex 9f06132e007d..6559f781b2c7 100644\n--- a/net/batman-adv/network-coding.c\n+++ b/net/batman-adv/network-coding.c\n@@ -176,6 +176,8 @@ int batadv_nc_mesh_init(struct batadv_priv *bat_priv)\n  * @bat_priv: the bat priv with all the soft interface information\n  */\n void batadv_nc_init_bat_priv(struct batadv_priv *bat_priv)\n+{\n+    INIT_DELAYED_WORK(&bat_priv->nc.work, batadv_nc_worker);\n {\n \tatomic_set(&bat_priv->network_coding, 0);\n \tbat_priv->nc.min_tq = 200;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/batman-adv/network-coding.c b/net/batman-adv/network-coding.c\nindex 9f06132e007d..480697583eee 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 (bat_priv->nc.work.func) \n+    cancel_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_message": "Failed to build"
            }
        ]
    },
    "766aad2609c9a3742436a3e25518eba8f5c6ddc8": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 73f419adce61..33fa81524273 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -277,7 +277,7 @@ static int usbtmc_ioctl_abort_bulk_in_tag(struct usbtmc_device_data *data,\n \t\treturn -ENOMEM;\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_rcvctrlpipe(data->usb_dev, 0),\n+\t\t\t     usb_sndctrlpipe(data->usb_dev, 0),\n \t\t\t     USBTMC_REQUEST_INITIATE_ABORT_BULK_IN,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_ENDPOINT,\n \t\t\t     tag, data->bulk_in,\n@@ -350,7 +350,7 @@ static int usbtmc_ioctl_abort_bulk_in_tag(struct usbtmc_device_data *data,\n \t}\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_rcvctrlpipe(data->usb_dev, 0),\n+\t\t\t     usb_sndctrlpipe(data->usb_dev, 0),\n \t\t\t     USBTMC_REQUEST_CHECK_ABORT_BULK_IN_STATUS,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_ENDPOINT,\n \t\t\t     0, data->bulk_in, buffer, 0x08,\n@@ -406,7 +406,7 @@ static int usbtmc_ioctl_abort_bulk_out_tag(struct usbtmc_device_data *data,\n \t\treturn -ENOMEM;\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_rcvctrlpipe(data->usb_dev, 0),\n+\t\t\t     usb_sndctrlpipe(data->usb_dev, 0),\n \t\t\t     USBTMC_REQUEST_INITIATE_ABORT_BULK_OUT,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_ENDPOINT,\n \t\t\t     tag, data->bulk_out,\n@@ -432,7 +432,7 @@ static int usbtmc_ioctl_abort_bulk_out_tag(struct usbtmc_device_data *data,\n \t/* do not stress device with subsequent requests */\n \tmsleep(50);\n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_rcvctrlpipe(data->usb_dev, 0),\n+\t\t\t     usb_sndctrlpipe(data->usb_dev, 0),\n \t\t\t     USBTMC_REQUEST_CHECK_ABORT_BULK_OUT_STATUS,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_ENDPOINT,\n \t\t\t     0, data->bulk_out, buffer, 0x08,\n@@ -493,7 +493,7 @@ static int usbtmc_get_stb(struct usbtmc_file_data *file_data, __u8 *stb)\n \tatomic_set(&data->iin_data_valid, 0);\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\tusb_rcvctrlpipe(data->usb_dev, 0),\n+\t\t\tusb_sndctrlpipe(data->usb_dev, 0),\n \t\t\tUSBTMC488_REQUEST_READ_STATUS_BYTE,\n \t\t\tUSB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n \t\t\tdata->iin_bTag,\n@@ -673,7 +673,7 @@ static int usbtmc488_ioctl_simple(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\tusb_sndctrlpipe(data->usb_dev, 0),\n \t\t\tcmd,\n \t\t\tUSB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n \t\t\twValue,\n@@ -1662,7 +1662,7 @@ static int usbtmc_ioctl_clear(struct usbtmc_device_data *data)\n \t\treturn -ENOMEM;\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_rcvctrlpipe(data->usb_dev, 0),\n+\t\t\t     usb_sndctrlpipe(data->usb_dev, 0),\n \t\t\t     USBTMC_REQUEST_INITIATE_CLEAR,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n \t\t\t     0, 0, buffer, 1, USB_CTRL_GET_TIMEOUT);\n@@ -1686,7 +1686,7 @@ static int usbtmc_ioctl_clear(struct usbtmc_device_data *data)\n \tdev_dbg(dev, \"Sending CHECK_CLEAR_STATUS request\\n\");\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_rcvctrlpipe(data->usb_dev, 0),\n+\t\t\t     usb_sndctrlpipe(data->usb_dev, 0),\n \t\t\t     USBTMC_REQUEST_CHECK_CLEAR_STATUS,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n \t\t\t     0, 0, buffer, 2, USB_CTRL_GET_TIMEOUT);\n@@ -1818,7 +1818,7 @@ static int get_capabilities(struct usbtmc_device_data *data)\n \tif (!buffer)\n \t\treturn -ENOMEM;\n \n-\trv = usb_control_msg(data->usb_dev, usb_rcvctrlpipe(data->usb_dev, 0),\n+\trv = usb_control_msg(data->usb_dev, usb_sndctrlpipe(data->usb_dev, 0),\n \t\t\t     USBTMC_REQUEST_GET_CAPABILITIES,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n \t\t\t     0, 0, buffer, 0x18, USB_CTRL_GET_TIMEOUT);\n@@ -1888,7 +1888,7 @@ static int usbtmc_ioctl_indicator_pulse(struct usbtmc_device_data *data)\n \t\treturn -ENOMEM;\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_rcvctrlpipe(data->usb_dev, 0),\n+\t\t\t     usb_sndctrlpipe(data->usb_dev, 0),\n \t\t\t     USBTMC_REQUEST_INDICATOR_PULSE,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n \t\t\t     0, 0, buffer, 0x01, USB_CTRL_GET_TIMEOUT);\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\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"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 73f419adce61..d65758f6db6b 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -277,7 +277,7 @@ static int usbtmc_ioctl_abort_bulk_in_tag(struct usbtmc_device_data *data,\n \t\treturn -ENOMEM;\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_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\t     USBTMC_REQUEST_INITIATE_ABORT_BULK_IN,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_ENDPOINT,\n \t\t\t     tag, data->bulk_in,\n@@ -350,7 +350,7 @@ static int usbtmc_ioctl_abort_bulk_in_tag(struct usbtmc_device_data *data,\n \t}\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_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\t     USBTMC_REQUEST_CHECK_ABORT_BULK_IN_STATUS,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_ENDPOINT,\n \t\t\t     0, data->bulk_in, buffer, 0x08,\n@@ -406,7 +406,7 @@ static int usbtmc_ioctl_abort_bulk_out_tag(struct usbtmc_device_data *data,\n \t\treturn -ENOMEM;\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_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\t     USBTMC_REQUEST_INITIATE_ABORT_BULK_OUT,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_ENDPOINT,\n \t\t\t     tag, data->bulk_out,\n@@ -432,7 +432,7 @@ static int usbtmc_ioctl_abort_bulk_out_tag(struct usbtmc_device_data *data,\n \t/* do not stress device with subsequent requests */\n \tmsleep(50);\n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_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\t     USBTMC_REQUEST_CHECK_ABORT_BULK_OUT_STATUS,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_ENDPOINT,\n \t\t\t     0, data->bulk_out, buffer, 0x08,\n@@ -493,7 +493,7 @@ static int usbtmc_get_stb(struct usbtmc_file_data *file_data, __u8 *stb)\n \tatomic_set(&data->iin_data_valid, 0);\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\tUSBTMC488_REQUEST_READ_STATUS_BYTE,\n \t\t\tUSB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n \t\t\tdata->iin_bTag,\n@@ -673,7 +673,7 @@ static int usbtmc488_ioctl_simple(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\tcmd,\n \t\t\tUSB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n \t\t\twValue,\n@@ -1662,7 +1662,7 @@ static int usbtmc_ioctl_clear(struct usbtmc_device_data *data)\n \t\treturn -ENOMEM;\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_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\t     USBTMC_REQUEST_INITIATE_CLEAR,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n \t\t\t     0, 0, buffer, 1, USB_CTRL_GET_TIMEOUT);\n@@ -1686,7 +1686,7 @@ static int usbtmc_ioctl_clear(struct usbtmc_device_data *data)\n \tdev_dbg(dev, \"Sending CHECK_CLEAR_STATUS request\\n\");\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_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\t     USBTMC_REQUEST_CHECK_CLEAR_STATUS,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n \t\t\t     0, 0, buffer, 2, USB_CTRL_GET_TIMEOUT);\n@@ -1818,7 +1818,7 @@ static int get_capabilities(struct usbtmc_device_data *data)\n \tif (!buffer)\n \t\treturn -ENOMEM;\n \n-\trv = usb_control_msg(data->usb_dev, usb_rcvctrlpipe(data->usb_dev, 0),\n+\trv = usb_control_msg(data->usb_dev, (request.req.bRequestType & USB_DIR_IN) ? usb_rcvctrlpipe(data->usb_dev, 0) : usb_sndctrlpipe(data->usb_dev, 0),\n \t\t\t     USBTMC_REQUEST_GET_CAPABILITIES,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n \t\t\t     0, 0, buffer, 0x18, USB_CTRL_GET_TIMEOUT);\n@@ -1888,7 +1888,7 @@ static int usbtmc_ioctl_indicator_pulse(struct usbtmc_device_data *data)\n \t\treturn -ENOMEM;\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_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\t     USBTMC_REQUEST_INDICATOR_PULSE,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n \t\t\t     0, 0, buffer, 0x01, USB_CTRL_GET_TIMEOUT);\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",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 73f419adce61..a7a8e22aa90d 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -276,7 +276,13 @@ static int usbtmc_ioctl_abort_bulk_in_tag(struct usbtmc_device_data *data,\n \tif (!buffer)\n \t\treturn -ENOMEM;\n \n-\trv = usb_control_msg(data->usb_dev,\n+\tif ((request.req.bRequestType & USB_DIR_IN) != usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_err(dev, \"Control direction mismatch: pipe %x doesn't match bRequestType %x\\n\",\n+            usb_rcvctrlpipe(data->usb_dev, 0), request.req.bRequestType);\n+    return -EINVAL;\n+}\n+\n+rv = usb_control_msg(data->usb_dev,\n \t\t\t     usb_rcvctrlpipe(data->usb_dev, 0),\n \t\t\t     USBTMC_REQUEST_INITIATE_ABORT_BULK_IN,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_ENDPOINT,\n@@ -349,7 +355,13 @@ static int usbtmc_ioctl_abort_bulk_in_tag(struct usbtmc_device_data *data,\n \t\tgoto exit;\n \t}\n \n-\trv = usb_control_msg(data->usb_dev,\n+\tif ((request.req.bRequestType & USB_DIR_IN) != usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_err(dev, \"Control direction mismatch: pipe %x doesn't match bRequestType %x\\n\",\n+            usb_rcvctrlpipe(data->usb_dev, 0), request.req.bRequestType);\n+    return -EINVAL;\n+}\n+\n+rv = usb_control_msg(data->usb_dev,\n \t\t\t     usb_rcvctrlpipe(data->usb_dev, 0),\n \t\t\t     USBTMC_REQUEST_CHECK_ABORT_BULK_IN_STATUS,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_ENDPOINT,\n@@ -405,7 +417,13 @@ static int usbtmc_ioctl_abort_bulk_out_tag(struct usbtmc_device_data *data,\n \tif (!buffer)\n \t\treturn -ENOMEM;\n \n-\trv = usb_control_msg(data->usb_dev,\n+\tif ((request.req.bRequestType & USB_DIR_IN) != usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_err(dev, \"Control direction mismatch: pipe %x doesn't match bRequestType %x\\n\",\n+            usb_rcvctrlpipe(data->usb_dev, 0), request.req.bRequestType);\n+    return -EINVAL;\n+}\n+\n+rv = usb_control_msg(data->usb_dev,\n \t\t\t     usb_rcvctrlpipe(data->usb_dev, 0),\n \t\t\t     USBTMC_REQUEST_INITIATE_ABORT_BULK_OUT,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_ENDPOINT,\n@@ -431,7 +449,13 @@ static int usbtmc_ioctl_abort_bulk_out_tag(struct usbtmc_device_data *data,\n usbtmc_abort_bulk_out_check_status:\n \t/* do not stress device with subsequent requests */\n \tmsleep(50);\n-\trv = usb_control_msg(data->usb_dev,\n+\tif ((request.req.bRequestType & USB_DIR_IN) != usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_err(dev, \"Control direction mismatch: pipe %x doesn't match bRequestType %x\\n\",\n+            usb_rcvctrlpipe(data->usb_dev, 0), request.req.bRequestType);\n+    return -EINVAL;\n+}\n+\n+rv = usb_control_msg(data->usb_dev,\n \t\t\t     usb_rcvctrlpipe(data->usb_dev, 0),\n \t\t\t     USBTMC_REQUEST_CHECK_ABORT_BULK_OUT_STATUS,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_ENDPOINT,\n@@ -492,7 +516,13 @@ static int usbtmc_get_stb(struct usbtmc_file_data *file_data, __u8 *stb)\n \n \tatomic_set(&data->iin_data_valid, 0);\n \n-\trv = usb_control_msg(data->usb_dev,\n+\tif ((request.req.bRequestType & USB_DIR_IN) != usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_err(dev, \"Control direction mismatch: pipe %x doesn't match bRequestType %x\\n\",\n+            usb_rcvctrlpipe(data->usb_dev, 0), request.req.bRequestType);\n+    return -EINVAL;\n+}\n+\n+rv = usb_control_msg(data->usb_dev,\n \t\t\tusb_rcvctrlpipe(data->usb_dev, 0),\n \t\t\tUSBTMC488_REQUEST_READ_STATUS_BYTE,\n \t\t\tUSB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n@@ -672,7 +702,13 @@ static int usbtmc488_ioctl_simple(struct usbtmc_device_data *data,\n \t\twValue = 0;\n \t}\n \n-\trv = usb_control_msg(data->usb_dev,\n+\tif ((request.req.bRequestType & USB_DIR_IN) != usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_err(dev, \"Control direction mismatch: pipe %x doesn't match bRequestType %x\\n\",\n+            usb_rcvctrlpipe(data->usb_dev, 0), request.req.bRequestType);\n+    return -EINVAL;\n+}\n+\n+rv = usb_control_msg(data->usb_dev,\n \t\t\tusb_rcvctrlpipe(data->usb_dev, 0),\n \t\t\tcmd,\n \t\t\tUSB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n@@ -1661,7 +1697,13 @@ static int usbtmc_ioctl_clear(struct usbtmc_device_data *data)\n \tif (!buffer)\n \t\treturn -ENOMEM;\n \n-\trv = usb_control_msg(data->usb_dev,\n+\tif ((request.req.bRequestType & USB_DIR_IN) != usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_err(dev, \"Control direction mismatch: pipe %x doesn't match bRequestType %x\\n\",\n+            usb_rcvctrlpipe(data->usb_dev, 0), request.req.bRequestType);\n+    return -EINVAL;\n+}\n+\n+rv = usb_control_msg(data->usb_dev,\n \t\t\t     usb_rcvctrlpipe(data->usb_dev, 0),\n \t\t\t     USBTMC_REQUEST_INITIATE_CLEAR,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n@@ -1685,7 +1727,13 @@ static int usbtmc_ioctl_clear(struct usbtmc_device_data *data)\n \n \tdev_dbg(dev, \"Sending CHECK_CLEAR_STATUS request\\n\");\n \n-\trv = usb_control_msg(data->usb_dev,\n+\tif ((request.req.bRequestType & USB_DIR_IN) != usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_err(dev, \"Control direction mismatch: pipe %x doesn't match bRequestType %x\\n\",\n+            usb_rcvctrlpipe(data->usb_dev, 0), request.req.bRequestType);\n+    return -EINVAL;\n+}\n+\n+rv = usb_control_msg(data->usb_dev,\n \t\t\t     usb_rcvctrlpipe(data->usb_dev, 0),\n \t\t\t     USBTMC_REQUEST_CHECK_CLEAR_STATUS,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n@@ -1818,7 +1866,13 @@ static int get_capabilities(struct usbtmc_device_data *data)\n \tif (!buffer)\n \t\treturn -ENOMEM;\n \n-\trv = usb_control_msg(data->usb_dev, usb_rcvctrlpipe(data->usb_dev, 0),\n+\tif ((request.req.bRequestType & USB_DIR_IN) != usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_err(dev, \"Control direction mismatch: pipe %x doesn't match bRequestType %x\\n\",\n+            usb_rcvctrlpipe(data->usb_dev, 0), request.req.bRequestType);\n+    return -EINVAL;\n+}\n+\n+rv = usb_control_msg(data->usb_dev, usb_rcvctrlpipe(data->usb_dev, 0),\n \t\t\t     USBTMC_REQUEST_GET_CAPABILITIES,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n \t\t\t     0, 0, buffer, 0x18, USB_CTRL_GET_TIMEOUT);\n@@ -1887,7 +1941,13 @@ static int usbtmc_ioctl_indicator_pulse(struct usbtmc_device_data *data)\n \tif (!buffer)\n \t\treturn -ENOMEM;\n \n-\trv = usb_control_msg(data->usb_dev,\n+\tif ((request.req.bRequestType & USB_DIR_IN) != usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_err(dev, \"Control direction mismatch: pipe %x doesn't match bRequestType %x\\n\",\n+            usb_rcvctrlpipe(data->usb_dev, 0), request.req.bRequestType);\n+    return -EINVAL;\n+}\n+\n+rv = usb_control_msg(data->usb_dev,\n \t\t\t     usb_rcvctrlpipe(data->usb_dev, 0),\n \t\t\t     USBTMC_REQUEST_INDICATOR_PULSE,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n@@ -1944,7 +2004,13 @@ 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+\tif ((request.req.bRequestType & USB_DIR_IN) != usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_err(dev, \"Control direction mismatch: pipe %x doesn't match bRequestType %x\\n\",\n+            usb_rcvctrlpipe(data->usb_dev, 0), request.req.bRequestType);\n+    return -EINVAL;\n+}\n+\n+rv = 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",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 73f419adce61..d3edd31448d8 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -277,7 +277,7 @@ static int usbtmc_ioctl_abort_bulk_in_tag(struct usbtmc_device_data *data,\n \t\treturn -ENOMEM;\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_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\t     USBTMC_REQUEST_INITIATE_ABORT_BULK_IN,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_ENDPOINT,\n \t\t\t     tag, data->bulk_in,\n@@ -350,7 +350,7 @@ static int usbtmc_ioctl_abort_bulk_in_tag(struct usbtmc_device_data *data,\n \t}\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_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\t     USBTMC_REQUEST_CHECK_ABORT_BULK_IN_STATUS,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_ENDPOINT,\n \t\t\t     0, data->bulk_in, buffer, 0x08,\n@@ -406,7 +406,7 @@ static int usbtmc_ioctl_abort_bulk_out_tag(struct usbtmc_device_data *data,\n \t\treturn -ENOMEM;\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_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\t     USBTMC_REQUEST_INITIATE_ABORT_BULK_OUT,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_ENDPOINT,\n \t\t\t     tag, data->bulk_out,\n@@ -432,7 +432,7 @@ static int usbtmc_ioctl_abort_bulk_out_tag(struct usbtmc_device_data *data,\n \t/* do not stress device with subsequent requests */\n \tmsleep(50);\n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_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\t     USBTMC_REQUEST_CHECK_ABORT_BULK_OUT_STATUS,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_ENDPOINT,\n \t\t\t     0, data->bulk_out, buffer, 0x08,\n@@ -493,7 +493,7 @@ static int usbtmc_get_stb(struct usbtmc_file_data *file_data, __u8 *stb)\n \tatomic_set(&data->iin_data_valid, 0);\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\tUSBTMC488_REQUEST_READ_STATUS_BYTE,\n \t\t\tUSB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n \t\t\tdata->iin_bTag,\n@@ -673,7 +673,7 @@ static int usbtmc488_ioctl_simple(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\tcmd,\n \t\t\tUSB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n \t\t\twValue,\n@@ -1662,7 +1662,7 @@ static int usbtmc_ioctl_clear(struct usbtmc_device_data *data)\n \t\treturn -ENOMEM;\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_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\t     USBTMC_REQUEST_INITIATE_CLEAR,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n \t\t\t     0, 0, buffer, 1, USB_CTRL_GET_TIMEOUT);\n@@ -1686,7 +1686,7 @@ static int usbtmc_ioctl_clear(struct usbtmc_device_data *data)\n \tdev_dbg(dev, \"Sending CHECK_CLEAR_STATUS request\\n\");\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_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\t     USBTMC_REQUEST_CHECK_CLEAR_STATUS,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n \t\t\t     0, 0, buffer, 2, USB_CTRL_GET_TIMEOUT);\n@@ -1818,7 +1818,7 @@ static int get_capabilities(struct usbtmc_device_data *data)\n \tif (!buffer)\n \t\treturn -ENOMEM;\n \n-\trv = usb_control_msg(data->usb_dev, usb_rcvctrlpipe(data->usb_dev, 0),\n+\trv = usb_control_msg(data->usb_dev, ((request.req.bRequestType & USB_DIR_IN) ? usb_rcvctrlpipe(data->usb_dev, 0) : usb_sndctrlpipe(data->usb_dev, 0)),\n \t\t\t     USBTMC_REQUEST_GET_CAPABILITIES,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n \t\t\t     0, 0, buffer, 0x18, USB_CTRL_GET_TIMEOUT);\n@@ -1888,7 +1888,7 @@ static int usbtmc_ioctl_indicator_pulse(struct usbtmc_device_data *data)\n \t\treturn -ENOMEM;\n \n \trv = usb_control_msg(data->usb_dev,\n-\t\t\t     usb_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\t     USBTMC_REQUEST_INDICATOR_PULSE,\n \t\t\t     USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE,\n \t\t\t     0, 0, buffer, 0x01, USB_CTRL_GET_TIMEOUT);\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",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/usb/core/urb.c b/drivers/usb/core/urb.c\nindex 33d62d7e3929..a07f4dbcfccd 100644\n--- a/drivers/usb/core/urb.c\n+++ b/drivers/usb/core/urb.c\n@@ -407,7 +407,10 @@ int usb_submit_urb(struct urb *urb, gfp_t mem_flags)\n \t\t\treturn -ENOEXEC;\n \t\tis_out = !(setup->bRequestType & USB_DIR_IN) ||\n \t\t\t\t!setup->wLength;\n-\t\tdev_WARN_ONCE(&dev->dev, (usb_pipeout(urb->pipe) != is_out),\n+\t\tif (usb_pipeout(urb->pipe) != is_out) {\n+            dev_err(&dev->dev, \"Pipe direction mismatch: pipe %x, bRequestType %x\\n\", urb->pipe, setup->bRequestType);\n+            return -EINVAL;\n+        }\n \t\t\t\t\"BOGUS control dir, pipe %x doesn't match bRequestType %x\\n\",\n \t\t\t\turb->pipe, setup->bRequestType);\n \t\tif (le16_to_cpu(setup->wLength) != urb->transfer_buffer_length) {\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "1fbd9fd0ef463a9811d2c5b7d206f119cf259601": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/smc/smc_sysctl.c b/net/smc/smc_sysctl.c\nindex bae19419e755..7000957b98d1 100644\n--- a/net/smc/smc_sysctl.c\n+++ b/net/smc/smc_sysctl.c\n@@ -62,4 +62,6 @@ int __net_init smc_sysctl_net_init(struct net *net)\n void __net_exit smc_sysctl_net_exit(struct net *net)\n {\n \tunregister_net_sysctl_table(net->smc.smc_hdr);\n+    if (!net_eq(net, &init_net))\n+        kfree(smc_table);\n }\n",
            "diff --git a/net/smc/smc_sysctl.c b/net/smc/smc_sysctl.c\nindex bae19419e755..535f4df89287 100644\n--- a/net/smc/smc_sysctl.c\n+++ b/net/smc/smc_sysctl.c\n@@ -53,6 +53,8 @@ int __net_init smc_sysctl_net_init(struct net *net)\n \treturn 0;\n \n err_reg:\n+if (!net_eq(net, &init_net))\n+kfree(table);\n \tif (!net_eq(net, &init_net))\n \t\tkfree(table);\n err_alloc:\n",
            "diff --git a/net/smc/smc_sysctl.c b/net/smc/smc_sysctl.c\nindex bae19419e755..b51e279cf239 100644\n--- a/net/smc/smc_sysctl.c\n+++ b/net/smc/smc_sysctl.c\n@@ -62,4 +62,6 @@ int __net_init smc_sysctl_net_init(struct net *net)\n void __net_exit smc_sysctl_net_exit(struct net *net)\n {\n \tunregister_net_sysctl_table(net->smc.smc_hdr);\n+    if (!net_eq(net, &init_net))\n+        kfree(net->smc.smc_hdr);\n }\n",
            "diff --git a/net/smc/smc_sysctl.c b/net/smc/smc_sysctl.c\nindex bae19419e755..b51e279cf239 100644\n--- a/net/smc/smc_sysctl.c\n+++ b/net/smc/smc_sysctl.c\n@@ -62,4 +62,6 @@ int __net_init smc_sysctl_net_init(struct net *net)\n void __net_exit smc_sysctl_net_exit(struct net *net)\n {\n \tunregister_net_sysctl_table(net->smc.smc_hdr);\n+    if (!net_eq(net, &init_net))\n+        kfree(net->smc.smc_hdr);\n }\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/smc/smc_sysctl.c b/net/smc/smc_sysctl.c\nindex bae19419e755..6f2b8568d339 100644\n--- a/net/smc/smc_sysctl.c\n+++ b/net/smc/smc_sysctl.c\n@@ -62,4 +62,6 @@ int __net_init smc_sysctl_net_init(struct net *net)\n void __net_exit smc_sysctl_net_exit(struct net *net)\n {\n \tunregister_net_sysctl_table(net->smc.smc_hdr);\n+if (!net_eq(net, &init_net))\n+kfree(table);\n }\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "1665a0a4a1d6d4d3f61624353f8a9e5dbfff67bd": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/l2tp/l2tp_core.c b/net/l2tp/l2tp_core.c\nindex 754fdda8a5f5..3798cd6ce8fb 100644\n--- a/net/l2tp/l2tp_core.c\n+++ b/net/l2tp/l2tp_core.c\n@@ -1250,7 +1250,8 @@ static void l2tp_tunnel_del_work(struct work_struct *work)\n \n \t/* Remove the tunnel struct from the tunnel list */\n \tpn = l2tp_pernet(tunnel->l2tp_net);\n-\tspin_lock_bh(&pn->l2tp_tunnel_list_lock);\n+\t// Acquire l2tp_tunnel_list_lock to protect the tunnel list\n+    spin_lock_bh(&pn->l2tp_tunnel_list_lock);\n \tlist_del_rcu(&tunnel->list);\n \tspin_unlock_bh(&pn->l2tp_tunnel_list_lock);\n \n@@ -1474,7 +1475,8 @@ 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+\t// Acquire sk_callback_lock to protect socket callbacks\n+    write_lock(&sk->sk_callback_lock);\n \n \tret = l2tp_validate_socket(sk, net, tunnel->encap);\n \tif (ret < 0)\n@@ -1486,7 +1488,8 @@ int l2tp_tunnel_register(struct l2tp_tunnel *tunnel, struct net *net,\n \tsock_hold(sk);\n \ttunnel->sock = sk;\n \n-\tspin_lock_bh(&pn->l2tp_tunnel_list_lock);\n+\t// Acquire l2tp_tunnel_list_lock to protect the tunnel list\n+    spin_lock_bh(&pn->l2tp_tunnel_list_lock);\n \tlist_for_each_entry(tunnel_walk, &pn->l2tp_tunnel_list, list) {\n \t\tif (tunnel_walk->tunnel_id == tunnel->tunnel_id) {\n \t\t\tspin_unlock_bh(&pn->l2tp_tunnel_list_lock);\n",
            "diff --git a/net/l2tp/l2tp_core.c b/net/l2tp/l2tp_core.c\nindex 754fdda8a5f5..9ebe5813f2ca 100644\n--- a/net/l2tp/l2tp_core.c\n+++ b/net/l2tp/l2tp_core.c\n@@ -1476,6 +1476,9 @@ int l2tp_tunnel_register(struct l2tp_tunnel *tunnel, struct net *net,\n \tsk = sock->sk;\n \twrite_lock(&sk->sk_callback_lock);\n \n+/* Release sk_callback_lock before acquiring l2tp_tunnel_list_lock to avoid deadlock */\n+write_unlock(&sk->sk_callback_lock);\n+\n \tret = l2tp_validate_socket(sk, net, tunnel->encap);\n \tif (ret < 0)\n \t\tgoto err_sock;\n",
            "diff --git a/net/l2tp/l2tp_core.c b/net/l2tp/l2tp_core.c\nindex 754fdda8a5f5..980c158661dc 100644\n--- a/net/l2tp/l2tp_core.c\n+++ b/net/l2tp/l2tp_core.c\n@@ -1474,7 +1474,8 @@ 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+\tspin_lock_bh(&pn->l2tp_tunnel_list_lock);\n+    write_lock(&sk->sk_callback_lock);\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..6066693176e5 100644\n--- a/net/l2tp/l2tp_core.c\n+++ b/net/l2tp/l2tp_core.c\n@@ -1476,6 +1476,9 @@ int l2tp_tunnel_register(struct l2tp_tunnel *tunnel, struct net *net,\n \tsk = sock->sk;\n \twrite_lock(&sk->sk_callback_lock);\n \n+// Release sk_callback_lock before acquiring l2tp_tunnel_list_lock\n+write_unlock(&sk->sk_callback_lock);\n+\n \tret = l2tp_validate_socket(sk, net, tunnel->encap);\n \tif (ret < 0)\n \t\tgoto err_sock;\n",
            "diff --git a/net/l2tp/l2tp_core.c b/net/l2tp/l2tp_core.c\nindex 754fdda8a5f5..980c158661dc 100644\n--- a/net/l2tp/l2tp_core.c\n+++ b/net/l2tp/l2tp_core.c\n@@ -1474,7 +1474,8 @@ 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+\tspin_lock_bh(&pn->l2tp_tunnel_list_lock);\n+    write_lock(&sk->sk_callback_lock);\n \n \tret = l2tp_validate_socket(sk, net, tunnel->encap);\n \tif (ret < 0)\n"
        ],
        "error": []
    },
    "4649ea695ca98903ae82280a3b7aa97dbeb7fd07": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/include/net/nexthop.h b/include/net/nexthop.h\nindex 3a4f9e3b91a5..f97c9da35c0f 100644\n--- a/include/net/nexthop.h\n+++ b/include/net/nexthop.h\n@@ -238,7 +238,9 @@ static inline bool nexthop_is_blackhole(const struct nexthop *nh)\n \t}\n \n \tnhi = rcu_dereference_rtnl(nh->nh_info);\n-\treturn nhi->reject_nh;\n+\tif (!nhi)\n+        return false;\n+    return nhi->reject_nh;\n }\n \n static inline void nexthop_path_fib_result(struct fib_result *res, int hash)\n"
        ],
        "error": [
            {
                "patch": "diff --git a/include/net/nexthop.h b/include/net/nexthop.h\nindex 3a4f9e3b91a5..d69012d00db5 100644\n--- a/include/net/nexthop.h\n+++ b/include/net/nexthop.h\n@@ -147,6 +147,8 @@ static inline bool nexthop_is_fdb(const struct nexthop *nh)\n \t\tconst struct nh_info *nhi;\n \n \t\tnhi = rcu_dereference_rtnl(nh->nh_info);\n+    if (!nhi)\n+        return false;\n \t\treturn nhi->fdb_nh;\n \t}\n }\n@@ -238,6 +240,8 @@ static inline bool nexthop_is_blackhole(const struct nexthop *nh)\n \t}\n \n \tnhi = rcu_dereference_rtnl(nh->nh_info);\n+    if (!nhi)\n+        return false;\n \treturn nhi->reject_nh;\n }\n \n@@ -272,6 +276,8 @@ struct fib_nh_common *nexthop_fib_nhc(struct nexthop *nh, int nhsel)\n \t}\n \n \tnhi = rcu_dereference_rtnl(nh->nh_info);\n+    if (!nhi)\n+        return false;\n \treturn &nhi->fib_nhc;\n }\n \n@@ -380,6 +386,8 @@ static inline struct fib6_nh *nexthop_fib6_nh(struct nexthop *nh)\n \t}\n \n \tnhi = rcu_dereference_rtnl(nh->nh_info);\n+    if (!nhi)\n+        return false;\n \tif (nhi->family == AF_INET6)\n \t\treturn &nhi->fib6_nh;\n \n@@ -402,6 +410,8 @@ static inline void nexthop_path_fib6_result(struct fib6_result *res, int hash)\n \tnh = nexthop_select_path(nh, hash);\n \n \tnhi = rcu_dereference_rtnl(nh->nh_info);\n+    if (!nhi)\n+        return false;\n \tif (nhi->reject_nh) {\n \t\tres->fib6_type = RTN_BLACKHOLE;\n \t\tres->fib6_flags |= RTF_REJECT;\n@@ -418,6 +428,8 @@ int nexthop_for_each_fib6_nh(struct nexthop *nh,\n static inline int nexthop_get_family(struct nexthop *nh)\n {\n \tstruct nh_info *nhi = rcu_dereference_rtnl(nh->nh_info);\n+    if (!nhi)\n+        return false;\n \n \treturn nhi->family;\n }\n@@ -426,6 +438,8 @@ static inline\n struct fib_nh_common *nexthop_fdb_nhc(struct nexthop *nh)\n {\n \tstruct nh_info *nhi = rcu_dereference_rtnl(nh->nh_info);\n+    if (!nhi)\n+        return false;\n \n \treturn &nhi->fib_nhc;\n }\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/include/net/nexthop.h b/include/net/nexthop.h\nindex 3a4f9e3b91a5..ecfe9b25791f 100644\n--- a/include/net/nexthop.h\n+++ b/include/net/nexthop.h\n@@ -147,6 +147,7 @@ static inline bool nexthop_is_fdb(const struct nexthop *nh)\n \t\tconst struct nh_info *nhi;\n \n \t\tnhi = rcu_dereference_rtnl(nh->nh_info);\n+if (!nhi) return false;\n \t\treturn nhi->fdb_nh;\n \t}\n }\n@@ -238,6 +239,7 @@ static inline bool nexthop_is_blackhole(const struct nexthop *nh)\n \t}\n \n \tnhi = rcu_dereference_rtnl(nh->nh_info);\n+if (!nhi) return false;\n \treturn nhi->reject_nh;\n }\n \n@@ -272,6 +274,7 @@ struct fib_nh_common *nexthop_fib_nhc(struct nexthop *nh, int nhsel)\n \t}\n \n \tnhi = rcu_dereference_rtnl(nh->nh_info);\n+if (!nhi) return false;\n \treturn &nhi->fib_nhc;\n }\n \n@@ -380,6 +383,7 @@ static inline struct fib6_nh *nexthop_fib6_nh(struct nexthop *nh)\n \t}\n \n \tnhi = rcu_dereference_rtnl(nh->nh_info);\n+if (!nhi) return false;\n \tif (nhi->family == AF_INET6)\n \t\treturn &nhi->fib6_nh;\n \n@@ -402,6 +406,7 @@ static inline void nexthop_path_fib6_result(struct fib6_result *res, int hash)\n \tnh = nexthop_select_path(nh, hash);\n \n \tnhi = rcu_dereference_rtnl(nh->nh_info);\n+if (!nhi) return false;\n \tif (nhi->reject_nh) {\n \t\tres->fib6_type = RTN_BLACKHOLE;\n \t\tres->fib6_flags |= RTF_REJECT;\n@@ -418,6 +423,7 @@ int nexthop_for_each_fib6_nh(struct nexthop *nh,\n static inline int nexthop_get_family(struct nexthop *nh)\n {\n \tstruct nh_info *nhi = rcu_dereference_rtnl(nh->nh_info);\n+if (!nhi) return false;\n \n \treturn nhi->family;\n }\n@@ -426,6 +432,7 @@ static inline\n struct fib_nh_common *nexthop_fdb_nhc(struct nexthop *nh)\n {\n \tstruct nh_info *nhi = rcu_dereference_rtnl(nh->nh_info);\n+if (!nhi) return false;\n \n \treturn &nhi->fib_nhc;\n }\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "e0083a52ae0eb23d3186173d403646079b45c715": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/usb/core/hcd.c b/drivers/usb/core/hcd.c\nindex 9ffc63ae65ac..3e5b152ae3d0 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+                memcpy(urb->transfer_buffer, buffer, length);\n+            } else {\n+                length = 0;\n+                set_bit(HCD_FLAG_POLL_PENDING, &hcd->flags);\n+            }\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..1dd8b06f234a 100644\n--- a/drivers/usb/core/hcd.c\n+++ b/drivers/usb/core/hcd.c\n@@ -762,7 +762,7 @@ void usb_hcd_poll_rh_status(struct usb_hcd *hcd)\n \t\treturn;\n \n \tlength = hcd->driver->hub_status_data(hcd, buffer);\n-\tif (length > 0) {\n+\tif (length > 0 && length <= sizeof(buffer)) {\n \n \t\t/* try to complete the status urb */\n \t\tspin_lock_irqsave(&hcd_root_hub_lock, flags);\n",
            "diff --git a/drivers/usb/core/hcd.c b/drivers/usb/core/hcd.c\nindex 9ffc63ae65ac..e04582bea195 100644\n--- a/drivers/usb/core/hcd.c\n+++ b/drivers/usb/core/hcd.c\n@@ -771,7 +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\tmemcpy(urb->transfer_buffer, buffer, length);\n+\t\t\tif (length > sizeof(buffer))\n+length = sizeof(buffer);\n+memcpy(urb->transfer_buffer, buffer, length);\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..56ffab932efa 100644\n--- a/drivers/usb/core/hcd.c\n+++ b/drivers/usb/core/hcd.c\n@@ -771,7 +771,8 @@ 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 <= sizeof(buffer))\n+                memcpy(urb->transfer_buffer, buffer, length);\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..b487bf9f98d9 100644\n--- a/drivers/usb/core/hcd.c\n+++ b/drivers/usb/core/hcd.c\n@@ -771,7 +771,8 @@ 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+                memcpy(urb->transfer_buffer, buffer, length);\n \n \t\t\tusb_hcd_unlink_urb_from_ep(hcd, urb);\n \t\t\tusb_hcd_giveback_urb(hcd, urb, 0);\n"
        ],
        "error": []
    },
    "6e185619b66eae1ef09684c5f6e283d6cfb5ba84": {
        "non_crash": [
            "diff --git a/fs/btrfs/file.c b/fs/btrfs/file.c\nindex 448b143a5cb2..12833a84591b 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+    btrfs_abort_transaction(trans, ret);\n+    goto out;\n+} /* -ENOMEM */\n \t\t\t\targs->bytes_found += extent_end - key.offset;\n \t\t\t}\n \n",
            "diff --git a/fs/btrfs/file.c b/fs/btrfs/file.c\nindex 448b143a5cb2..6ec125f4a2a8 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+    btrfs_abort_transaction(trans, ret);\n+    break;\n+} /* -ENOMEM */\n \t\t\t\targs->bytes_found += extent_end - key.offset;\n \t\t\t}\n \n",
            "diff --git a/fs/btrfs/file.c b/fs/btrfs/file.c\nindex 448b143a5cb2..6ec125f4a2a8 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+    btrfs_abort_transaction(trans, ret);\n+    break;\n+} /* -ENOMEM */\n \t\t\t\targs->bytes_found += extent_end - key.offset;\n \t\t\t}\n \n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c\nindex 892d78c1853c..43281ebf4acf 100644\n--- a/fs/btrfs/extent-tree.c\n+++ b/fs/btrfs/extent-tree.c\n@@ -3278,7 +3278,10 @@ void btrfs_free_tree_block(struct btrfs_trans_handle *trans,\n \tif (root_id != BTRFS_TREE_LOG_OBJECTID) {\n \t\tbtrfs_ref_tree_mod(fs_info, &generic_ref);\n \t\tret = btrfs_add_delayed_tree_ref(trans, &generic_ref, NULL);\n-\t\tBUG_ON(ret); /* -ENOMEM */\n+\t\tif (ret) {\n+btrfs_err(fs_info, \"Failed to add delayed tree ref: %d\", ret);\n+return ret;\n+}\n \t}\n \n \tif (last_ref && btrfs_header_generation(buf) == trans->transid) {\n@@ -5193,12 +5196,21 @@ static noinline int walk_down_proc(struct btrfs_trans_handle *trans,\n \tif (!(wc->flags[level] & flag)) {\n \t\tBUG_ON(!path->locks[level]);\n \t\tret = btrfs_inc_ref(trans, root, eb, 1);\n-\t\tBUG_ON(ret); /* -ENOMEM */\n+\t\tif (ret) {\n+btrfs_err(fs_info, \"Failed to add delayed tree ref: %d\", ret);\n+return ret;\n+}\n \t\tret = btrfs_dec_ref(trans, root, eb, 0);\n-\t\tBUG_ON(ret); /* -ENOMEM */\n+\t\tif (ret) {\n+btrfs_err(fs_info, \"Failed to add delayed tree ref: %d\", ret);\n+return ret;\n+}\n \t\tret = btrfs_set_disk_extent_flags(trans, eb, flag,\n \t\t\t\t\t\t  btrfs_header_level(eb));\n-\t\tBUG_ON(ret); /* -ENOMEM */\n+\t\tif (ret) {\n+btrfs_err(fs_info, \"Failed to add delayed tree ref: %d\", ret);\n+return ret;\n+}\n \t\twc->flags[level] |= flag;\n \t}\n \n@@ -5529,7 +5541,10 @@ static noinline int walk_up_proc(struct btrfs_trans_handle *trans,\n \t\t\t\tret = btrfs_dec_ref(trans, root, eb, 1);\n \t\t\telse\n \t\t\t\tret = btrfs_dec_ref(trans, root, eb, 0);\n-\t\t\tBUG_ON(ret); /* -ENOMEM */\n+\t\t\tif (ret) {\n+btrfs_err(fs_info, \"Failed to add delayed tree ref: %d\", ret);\n+return ret;\n+}\n \t\t\tif (is_fstree(root->root_key.objectid)) {\n \t\t\t\tret = btrfs_qgroup_trace_leaf_items(trans, eb);\n \t\t\t\tif (ret) {\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c\nindex 892d78c1853c..61f2b0753b6f 100644\n--- a/fs/btrfs/extent-tree.c\n+++ b/fs/btrfs/extent-tree.c\n@@ -3278,7 +3278,10 @@ void btrfs_free_tree_block(struct btrfs_trans_handle *trans,\n \tif (root_id != BTRFS_TREE_LOG_OBJECTID) {\n \t\tbtrfs_ref_tree_mod(fs_info, &generic_ref);\n \t\tret = btrfs_add_delayed_tree_ref(trans, &generic_ref, NULL);\n-\t\tBUG_ON(ret); /* -ENOMEM */\n+\t\tif (ret) {\n+btrfs_err(fs_info, \"Failed to free extent: %d\", ret);\n+return ret;\n+} /* -ENOMEM */\n \t}\n \n \tif (last_ref && btrfs_header_generation(buf) == trans->transid) {\n@@ -5193,12 +5196,21 @@ static noinline int walk_down_proc(struct btrfs_trans_handle *trans,\n \tif (!(wc->flags[level] & flag)) {\n \t\tBUG_ON(!path->locks[level]);\n \t\tret = btrfs_inc_ref(trans, root, eb, 1);\n-\t\tBUG_ON(ret); /* -ENOMEM */\n+\t\tif (ret) {\n+btrfs_err(fs_info, \"Failed to free extent: %d\", ret);\n+return ret;\n+} /* -ENOMEM */\n \t\tret = btrfs_dec_ref(trans, root, eb, 0);\n-\t\tBUG_ON(ret); /* -ENOMEM */\n+\t\tif (ret) {\n+btrfs_err(fs_info, \"Failed to free extent: %d\", ret);\n+return ret;\n+} /* -ENOMEM */\n \t\tret = btrfs_set_disk_extent_flags(trans, eb, flag,\n \t\t\t\t\t\t  btrfs_header_level(eb));\n-\t\tBUG_ON(ret); /* -ENOMEM */\n+\t\tif (ret) {\n+btrfs_err(fs_info, \"Failed to free extent: %d\", ret);\n+return ret;\n+} /* -ENOMEM */\n \t\twc->flags[level] |= flag;\n \t}\n \n@@ -5529,7 +5541,10 @@ static noinline int walk_up_proc(struct btrfs_trans_handle *trans,\n \t\t\t\tret = btrfs_dec_ref(trans, root, eb, 1);\n \t\t\telse\n \t\t\t\tret = btrfs_dec_ref(trans, root, eb, 0);\n-\t\t\tBUG_ON(ret); /* -ENOMEM */\n+\t\t\tif (ret) {\n+btrfs_err(fs_info, \"Failed to free extent: %d\", ret);\n+return ret;\n+} /* -ENOMEM */\n \t\t\tif (is_fstree(root->root_key.objectid)) {\n \t\t\t\tret = btrfs_qgroup_trace_leaf_items(trans, eb);\n \t\t\t\tif (ret) {\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "bf3e592d3ed61b8f86b8ffba072adcde5485a5f6": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/page_alloc.c b/mm/page_alloc.c\nindex e5486d47406e..a95bc20fd1bd 100644\n--- a/mm/page_alloc.c\n+++ b/mm/page_alloc.c\n@@ -4683,7 +4683,7 @@ void fs_reclaim_acquire(gfp_t gfp_mask)\n {\n \tgfp_mask = current_gfp_context(gfp_mask);\n \n-\tif (__need_reclaim(gfp_mask)) {\n+\tif (__need_reclaim(gfp_mask) && !in_interrupt()) {\n \t\tif (gfp_mask & __GFP_FS)\n \t\t\t__fs_reclaim_acquire(_RET_IP_);\n \n@@ -4700,7 +4700,7 @@ void fs_reclaim_release(gfp_t gfp_mask)\n {\n \tgfp_mask = current_gfp_context(gfp_mask);\n \n-\tif (__need_reclaim(gfp_mask)) {\n+\tif (__need_reclaim(gfp_mask) && !in_interrupt()) {\n \t\tif (gfp_mask & __GFP_FS)\n \t\t\t__fs_reclaim_release(_RET_IP_);\n \t}\n",
            "diff --git a/mm/vmscan.c b/mm/vmscan.c\nindex b2b1431352dc..0c869806cefc 100644\n--- a/mm/vmscan.c\n+++ b/mm/vmscan.c\n@@ -4622,7 +4622,8 @@ unsigned long shrink_all_memory(unsigned long nr_to_reclaim)\n \tunsigned long nr_reclaimed;\n \tunsigned int noreclaim_flag;\n \n-\tfs_reclaim_acquire(sc.gfp_mask);\n+\tif (!in_interrupt())\n+    fs_reclaim_acquire(sc.gfp_mask);\n \tnoreclaim_flag = memalloc_noreclaim_save();\n \tset_task_reclaim_state(current, &sc.reclaim_state);\n \n@@ -4777,7 +4778,8 @@ static int __node_reclaim(struct pglist_data *pgdat, gfp_t gfp_mask, unsigned in\n \n \tcond_resched();\n \tpsi_memstall_enter(&pflags);\n-\tfs_reclaim_acquire(sc.gfp_mask);\n+\tif (!in_interrupt())\n+    fs_reclaim_acquire(sc.gfp_mask);\n \t/*\n \t * We need to be able to allocate from the reserves for RECLAIM_UNMAP\n \t */\n"
        ],
        "error": [
            {
                "patch": "diff --git a/mm/page_alloc.c b/mm/page_alloc.c\nindex e5486d47406e..2857743c4dad 100644\n--- a/mm/page_alloc.c\n+++ b/mm/page_alloc.c\n@@ -4680,6 +4680,12 @@ void __fs_reclaim_release(unsigned long ip)\n }\n \n void fs_reclaim_acquire(gfp_t gfp_mask)\n+{\n+    /* Ensure we are not in interrupt context */\n+    if (in_interrupt()) {\n+        WARN(1, \"fs_reclaim_acquire called in interrupt context\");\n+        return;\n+    }\n {\n \tgfp_mask = current_gfp_context(gfp_mask);\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/mm/page_alloc.c b/mm/page_alloc.c\nindex e5486d47406e..4945628e0bf1 100644\n--- a/mm/page_alloc.c\n+++ b/mm/page_alloc.c\n@@ -4680,6 +4680,11 @@ void __fs_reclaim_release(unsigned long ip)\n }\n \n void fs_reclaim_acquire(gfp_t gfp_mask)\n+{\n+    /* Ensure we are not in an atomic or softirq context */\n+    if (in_atomic() || in_softirq()) {\n+        return;\n+    }\n {\n \tgfp_mask = current_gfp_context(gfp_mask);\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/mm/page_alloc.c b/mm/page_alloc.c\nindex e5486d47406e..8fd4c4a02d32 100644\n--- a/mm/page_alloc.c\n+++ b/mm/page_alloc.c\n@@ -4680,6 +4680,9 @@ void __fs_reclaim_release(unsigned long ip)\n }\n \n void fs_reclaim_acquire(gfp_t gfp_mask)\n+{\n+    if (in_softirq()) return; // Avoid lock acquisition in softirq context\n+    gfp_mask = current_gfp_context(gfp_mask);\n {\n \tgfp_mask = current_gfp_context(gfp_mask);\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "1f07634f79ac1436ec38e2e71d73392404b17bbb": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/quota/quota.c b/fs/quota/quota.c\nindex 052f143e2e0e..792e71a9185c 100644\n--- a/fs/quota/quota.c\n+++ b/fs/quota/quota.c\n@@ -994,9 +994,9 @@ SYSCALL_DEFINE4(quotactl_fd, unsigned int, fd, unsigned int, cmd,\n \n \tsb = f.file->f_path.mnt->mnt_sb;\n \tif (quotactl_cmd_onoff(cmds))\n-\t\tdown_write(&sb->s_umount);\n+\t\tif (!down_write_trylock(&sb->s_umount)) return -EAGAIN;\n \telse\n-\t\tdown_read(&sb->s_umount);\n+\t\tif (!down_read_trylock(&sb->s_umount)) return -EAGAIN;\n \n \tret = do_quotactl(sb, type, cmds, id, addr, ERR_PTR(-EINVAL));\n \n",
            "diff --git a/fs/quota/quota.c b/fs/quota/quota.c\nindex 052f143e2e0e..13d1bb09c184 100644\n--- a/fs/quota/quota.c\n+++ b/fs/quota/quota.c\n@@ -986,7 +986,13 @@ 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+\tif (quotactl_cmd_onoff(cmds)) {\n+        down_write(&sb->s_umount);\n+    } else {\n+        down_read(&sb->s_umount);\n+    }\n+\n+    if (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"
        ],
        "error": []
    },
    "cd95cb722bfa1234ac4c78345c8953ee2e7170d0": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c\nindex e79c767cc5e0..c4a4c81e9cbe 100644\n--- a/fs/ext4/extents.c\n+++ b/fs/ext4/extents.c\n@@ -928,7 +928,9 @@ ext4_find_extent(struct inode *inode, ext4_lblk_t block,\n \t\text_debug(inode, \"depth %d: num %d, max %d\\n\",\n \t\t\t  ppos, le16_to_cpu(eh->eh_entries), le16_to_cpu(eh->eh_max));\n \n-\t\text4_ext_binsearch_idx(inode, path + ppos, block);\n+\t\tif (path) {\n+        ext4_ext_binsearch_idx(inode, path + ppos, block);\n+    }\n \t\tpath[ppos].p_block = ext4_idx_pblock(path[ppos].p_idx);\n \t\tpath[ppos].p_depth = i;\n \t\tpath[ppos].p_ext = NULL;\n",
            "diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c\nindex e79c767cc5e0..81108ec18ead 100644\n--- a/fs/ext4/extents.c\n+++ b/fs/ext4/extents.c\n@@ -961,6 +961,7 @@ ext4_find_extent(struct inode *inode, ext4_lblk_t block,\n \n err:\n \text4_free_ext_path(path);\n+path = NULL;\n \tif (orig_path)\n \t\t*orig_path = NULL;\n \treturn ERR_PTR(ret);\n",
            "diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c\nindex e79c767cc5e0..705adff603a8 100644\n--- a/fs/ext4/extents.c\n+++ b/fs/ext4/extents.c\n@@ -953,7 +953,8 @@ ext4_find_extent(struct inode *inode, ext4_lblk_t block,\n \text4_ext_binsearch(inode, path + ppos, block);\n \t/* if not an empty leaf */\n \tif (path[ppos].p_ext)\n-\t\tpath[ppos].p_block = ext4_ext_pblock(path[ppos].p_ext);\n+\t\tif (path && path[ppos].p_ext)\n+        path[ppos].p_block = ext4_ext_pblock(path[ppos].p_ext);\n \n \text4_ext_show_path(inode, path);\n \n",
            "diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c\nindex e79c767cc5e0..055e9ac6cfea 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+path = NULL;\n \treturn ret;\n }\n \n@@ -961,6 +962,7 @@ ext4_find_extent(struct inode *inode, ext4_lblk_t block,\n \n err:\n \text4_free_ext_path(path);\n+path = NULL;\n \tif (orig_path)\n \t\t*orig_path = NULL;\n \treturn ERR_PTR(ret);\n@@ -3064,6 +3066,7 @@ int ext4_ext_remove_space(struct inode *inode, ext4_lblk_t start,\n \t}\n out:\n \text4_free_ext_path(path);\n+path = NULL;\n \tpath = NULL;\n \tif (err == -EAGAIN)\n \t\tgoto again;\n@@ -4377,6 +4380,7 @@ int ext4_ext_map_blocks(handle_t *handle, struct inode *inode,\n \text4_ext_show_leaf(inode, path);\n out:\n \text4_free_ext_path(path);\n+path = NULL;\n \n \ttrace_ext4_ext_map_blocks_exit(inode, flags, map,\n \t\t\t\t       err ? err : allocated);\n@@ -5261,6 +5265,7 @@ ext4_ext_shift_extents(struct inode *inode, handle_t *handle,\n \t}\n out:\n \text4_free_ext_path(path);\n+path = NULL;\n \treturn ret;\n }\n \n@@ -5539,12 +5544,14 @@ static int ext4_insert_range(struct file *file, loff_t offset, loff_t len)\n \t\t}\n \n \t\text4_free_ext_path(path);\n+path = NULL;\n \t\tif (ret < 0) {\n \t\t\tup_write(&EXT4_I(inode)->i_data_sem);\n \t\t\tgoto out_stop;\n \t\t}\n \t} else {\n \t\text4_free_ext_path(path);\n+path = NULL;\n \t}\n \n \tret = ext4_es_remove_extent(inode, offset_lblk,\n@@ -5852,6 +5859,7 @@ int ext4_clu_mapped(struct inode *inode, ext4_lblk_t lclu)\n \n out:\n \text4_free_ext_path(path);\n+path = NULL;\n \n \treturn err ? err : mapped;\n }\n@@ -5919,6 +5927,7 @@ int ext4_ext_replay_update_ex(struct inode *inode, ext4_lblk_t start,\n \tup_write(&EXT4_I(inode)->i_data_sem);\n out:\n \text4_free_ext_path(path);\n+path = NULL;\n \text4_mark_inode_dirty(NULL, inode);\n \treturn ret;\n }\n@@ -5937,6 +5946,7 @@ void ext4_ext_replay_shrink_inode(struct inode *inode, ext4_lblk_t end)\n \t\tex = path[path->p_depth].p_ext;\n \t\tif (!ex) {\n \t\t\text4_free_ext_path(path);\n+path = NULL;\n \t\t\text4_mark_inode_dirty(NULL, inode);\n \t\t\treturn;\n \t\t}\n@@ -5950,6 +5960,7 @@ void ext4_ext_replay_shrink_inode(struct inode *inode, ext4_lblk_t end)\n \t\tup_write(&EXT4_I(inode)->i_data_sem);\n \t\text4_mark_inode_dirty(NULL, inode);\n \t\text4_free_ext_path(path);\n+path = NULL;\n \t}\n }\n \n@@ -5989,10 +6000,12 @@ int ext4_ext_replay_set_iblocks(struct inode *inode)\n \tex = path[path->p_depth].p_ext;\n \tif (!ex) {\n \t\text4_free_ext_path(path);\n+path = NULL;\n \t\tgoto out;\n \t}\n \tend = le32_to_cpu(ex->ee_block) + ext4_ext_get_actual_len(ex);\n \text4_free_ext_path(path);\n+path = NULL;\n \n \t/* Count the number of data blocks */\n \tcur = 0;\n@@ -6023,6 +6036,7 @@ int ext4_ext_replay_set_iblocks(struct inode *inode)\n \t\tgoto out;\n \tnumblks += path->p_depth;\n \text4_free_ext_path(path);\n+path = NULL;\n \twhile (cur < end) {\n \t\tpath = ext4_find_extent(inode, cur, NULL, 0);\n \t\tif (IS_ERR(path))\n@@ -6030,6 +6044,7 @@ int ext4_ext_replay_set_iblocks(struct inode *inode)\n \t\tex = path[path->p_depth].p_ext;\n \t\tif (!ex) {\n \t\t\text4_free_ext_path(path);\n+path = NULL;\n \t\t\treturn 0;\n \t\t}\n \t\tcur = max(cur + 1, le32_to_cpu(ex->ee_block) +\n@@ -6037,11 +6052,13 @@ int ext4_ext_replay_set_iblocks(struct inode *inode)\n \t\tret = skip_hole(inode, &cur);\n \t\tif (ret < 0) {\n \t\t\text4_free_ext_path(path);\n+path = NULL;\n \t\t\tbreak;\n \t\t}\n \t\tpath2 = ext4_find_extent(inode, cur, NULL, 0);\n \t\tif (IS_ERR(path2)) {\n \t\t\text4_free_ext_path(path);\n+path = NULL;\n \t\t\tbreak;\n \t\t}\n \t\tfor (i = 0; i <= max(path->p_depth, path2->p_depth); i++) {\n@@ -6056,6 +6073,7 @@ int ext4_ext_replay_set_iblocks(struct inode *inode)\n \t\t\t\tnumblks++;\n \t\t}\n \t\text4_free_ext_path(path);\n+path = NULL;\n \t\text4_free_ext_path(path2);\n \t}\n \n@@ -6084,10 +6102,12 @@ int ext4_ext_clear_bb(struct inode *inode)\n \tex = path[path->p_depth].p_ext;\n \tif (!ex) {\n \t\text4_free_ext_path(path);\n+path = NULL;\n \t\treturn 0;\n \t}\n \tend = le32_to_cpu(ex->ee_block) + ext4_ext_get_actual_len(ex);\n \text4_free_ext_path(path);\n+path = NULL;\n \n \tcur = 0;\n \twhile (cur < end) {\n@@ -6107,6 +6127,7 @@ int ext4_ext_clear_bb(struct inode *inode)\n \t\t\t\t\t\t\t0, path[j].p_block, 1, 1);\n \t\t\t\t}\n \t\t\t\text4_free_ext_path(path);\n+path = NULL;\n \t\t\t}\n \t\t\text4_mb_mark_bb(inode->i_sb, map.m_pblk, map.m_len, 0);\n \t\t\text4_fc_record_regions(inode->i_sb, inode->i_ino,\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c\nindex e79c767cc5e0..1c9e87578dce 100644\n--- a/fs/ext4/extents.c\n+++ b/fs/ext4/extents.c\n@@ -122,7 +122,10 @@ static void ext4_ext_drop_refs(struct ext4_ext_path *path)\n void ext4_free_ext_path(struct ext4_ext_path *path)\n {\n \text4_ext_drop_refs(path);\n-\tkfree(path);\n+\tif (path) {\n+    kfree(path);\n+    *orig_path = path = NULL;\n+}\n }\n \n /*\n@@ -905,7 +908,10 @@ ext4_find_extent(struct inode *inode, ext4_lblk_t block,\n \tif (path) {\n \t\text4_ext_drop_refs(path);\n \t\tif (depth > path[0].p_maxdepth) {\n-\t\t\tkfree(path);\n+\t\t\tif (path) {\n+    kfree(path);\n+    *orig_path = path = NULL;\n+}\n \t\t\t*orig_path = path = NULL;\n \t\t}\n \t}\n@@ -5888,7 +5894,10 @@ int ext4_ext_replay_update_ex(struct inode *inode, ext4_lblk_t start,\n \t\tup_write(&EXT4_I(inode)->i_data_sem);\n \t\tif (ret)\n \t\t\tgoto out;\n-\t\tkfree(path);\n+\t\tif (path) {\n+    kfree(path);\n+    *orig_path = path = NULL;\n+}\n \t\tpath = ext4_find_extent(inode, start, NULL, 0);\n \t\tif (IS_ERR(path))\n \t\t\treturn -1;\n@@ -5902,7 +5911,10 @@ int ext4_ext_replay_update_ex(struct inode *inode, ext4_lblk_t start,\n \t\t\tup_write(&EXT4_I(inode)->i_data_sem);\n \t\t\tif (ret)\n \t\t\t\tgoto out;\n-\t\t\tkfree(path);\n+\t\t\tif (path) {\n+    kfree(path);\n+    *orig_path = path = NULL;\n+}\n \t\t\tpath = ext4_find_extent(inode, start, NULL, 0);\n \t\t\tif (IS_ERR(path))\n \t\t\t\treturn -EINVAL;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "a8afc55e6cd0cac79fd97a5c0d2272751dc558fc": {
        "non_crash": [
            "diff --git a/drivers/media/platform/vim2m.c b/drivers/media/platform/vim2m.c\nindex 035c7b7c8d87..d604a03e5593 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_job_finish(ctx->fh.m2m_ctx->m2m_dev, 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"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/media/platform/vim2m.c b/drivers/media/platform/vim2m.c\nindex 035c7b7c8d87..2b5cbdd755ca 100644\n--- a/drivers/media/platform/vim2m.c\n+++ b/drivers/media/platform/vim2m.c\n@@ -807,6 +807,8 @@ static void vim2m_stop_streaming(struct vb2_queue *q)\n \tunsigned long flags;\n \n \tflush_scheduled_work();\n+    int max_iterations = 1000;\n+    int iteration_count = 0;\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/platform/vim2m.c b/drivers/media/platform/vim2m.c\nindex 035c7b7c8d87..1967332cb2cc 100644\n--- a/drivers/media/platform/vim2m.c\n+++ b/drivers/media/platform/vim2m.c\n@@ -807,7 +807,7 @@ static void vim2m_stop_streaming(struct vb2_queue *q)\n \tunsigned long flags;\n \n \tflush_scheduled_work();\n-\tfor (;;) {\n+\tfor (unsigned int timeout = 1000; timeout > 0; --timeout) {\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",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/media/platform/vim2m.c b/drivers/media/platform/vim2m.c\nindex 035c7b7c8d87..65ce944c8acf 100644\n--- a/drivers/media/platform/vim2m.c\n+++ b/drivers/media/platform/vim2m.c\n@@ -801,6 +801,9 @@ static int vim2m_start_streaming(struct vb2_queue *q, unsigned count)\n }\n \n static void vim2m_stop_streaming(struct vb2_queue *q)\n+{\n+    struct vim2m_ctx *ctx = vb2_get_drv_priv(q);\n+    ctx->aborting = true;\n {\n \tstruct vim2m_ctx *ctx = vb2_get_drv_priv(q);\n \tstruct vb2_v4l2_buffer *vbuf;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/media/platform/vim2m.c b/drivers/media/platform/vim2m.c\nindex 035c7b7c8d87..cef44d1a0ae1 100644\n--- a/drivers/media/platform/vim2m.c\n+++ b/drivers/media/platform/vim2m.c\n@@ -66,6 +66,7 @@ MODULE_PARM_DESC(debug, \"activates debug info\");\n /* Flags that indicate processing mode */\n #define MEM2MEM_HFLIP\t(1 << 0)\n #define MEM2MEM_VFLIP\t(1 << 1)\n+#define MAX_ATTEMPTS 100\n \n #define dprintk(dev, fmt, arg...) \\\n \tv4l2_dbg(1, debug, &dev->v4l2_dev, \"%s: \" fmt, __func__, ## arg)\n@@ -807,7 +808,7 @@ static void vim2m_stop_streaming(struct vb2_queue *q)\n \tunsigned long flags;\n \n \tflush_scheduled_work();\n-\tfor (;;) {\n+\tfor (int attempts = 0; attempts < MAX_ATTEMPTS; attempts++) {\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",
                "error_message": "Failed to build"
            }
        ]
    },
    "874c5bfa1234dcef000574388df68a8d08274ecd": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..6315af6918f9 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -96,7 +96,7 @@ static bool hfsplus_release_folio(struct folio *folio, gfp_t mask)\n \t\tnode = hfs_bnode_findhash(tree, nidx);\n \t\tif (!node)\n \t\t\t;\n-\t\telse if (atomic_read(&node->refcnt))\n+\t\telse if (node && atomic_read(&node->refcnt))\n \t\t\tres = false;\n \t\tif (res && node) {\n \t\t\thfs_bnode_unhash(node);\n",
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..da7095a6b594 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -94,13 +94,14 @@ static bool hfsplus_release_folio(struct folio *folio, gfp_t mask)\n \t\t\t(tree->node_size_shift - PAGE_SHIFT);\n \t\tspin_lock(&tree->hash_lock);\n \t\tnode = hfs_bnode_findhash(tree, nidx);\n+            hfs_bnode_get(node);\n \t\tif (!node)\n \t\t\t;\n \t\telse if (atomic_read(&node->refcnt))\n \t\t\tres = false;\n \t\tif (res && node) {\n \t\t\thfs_bnode_unhash(node);\n-\t\t\thfs_bnode_free(node);\n+\t\t\thfs_bnode_put(node);\n \t\t}\n \t\tspin_unlock(&tree->hash_lock);\n \t} else {\n@@ -117,7 +118,7 @@ static bool hfsplus_release_folio(struct folio *folio, gfp_t mask)\n \t\t\t\tbreak;\n \t\t\t}\n \t\t\thfs_bnode_unhash(node);\n-\t\t\thfs_bnode_free(node);\n+\t\t\thfs_bnode_put(node);\n \t\t} while (--i && nidx < tree->node_count);\n \t\tspin_unlock(&tree->hash_lock);\n \t}\n",
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..7f16c3a36803 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -101,6 +101,7 @@ 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+                node = NULL;\n \t\t}\n \t\tspin_unlock(&tree->hash_lock);\n \t} else {\n@@ -118,6 +119,7 @@ static bool hfsplus_release_folio(struct folio *folio, gfp_t mask)\n \t\t\t}\n \t\t\thfs_bnode_unhash(node);\n \t\t\thfs_bnode_free(node);\n+                node = NULL;\n \t\t} while (--i && nidx < tree->node_count);\n \t\tspin_unlock(&tree->hash_lock);\n \t}\n"
        ],
        "error": []
    },
    "6513f6cb5cd6b5fc9f37e3bb70d273b94be9c34c": {
        "non_crash": [
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dfc2e223bd10..14e4a079db31 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2137,7 +2137,11 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\t/* We need to allocate a new block */\n \t\t\text4_fsblk_t goal, block;\n \n-\t\t\tWARN_ON_ONCE(dquot_initialize_needed(inode));\n+\t\t\tif (dquot_initialize_needed(inode)) {\n+    error = dquot_initialize(inode);\n+    if (error)\n+        goto cleanup;\n+}\n \n \t\t\tgoal = ext4_group_first_block_no(sb,\n \t\t\t\t\t\tEXT4_I(inode)->i_block_group);\n",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dfc2e223bd10..869fbb7d8faa 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2137,7 +2137,10 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\t/* We need to allocate a new block */\n \t\t\text4_fsblk_t goal, block;\n \n-\t\t\tWARN_ON_ONCE(dquot_initialize_needed(inode));\n+\t\t\terror = dquot_initialize(inode);\n+            if (error)\n+                goto cleanup;\n+            WARN_ON_ONCE(dquot_initialize_needed(inode));\n \n \t\t\tgoal = ext4_group_first_block_no(sb,\n \t\t\t\t\t\tEXT4_I(inode)->i_block_group);\n",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dfc2e223bd10..869fbb7d8faa 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2137,7 +2137,10 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\t/* We need to allocate a new block */\n \t\t\text4_fsblk_t goal, block;\n \n-\t\t\tWARN_ON_ONCE(dquot_initialize_needed(inode));\n+\t\t\terror = dquot_initialize(inode);\n+            if (error)\n+                goto cleanup;\n+            WARN_ON_ONCE(dquot_initialize_needed(inode));\n \n \t\t\tgoal = ext4_group_first_block_no(sb,\n \t\t\t\t\t\tEXT4_I(inode)->i_block_group);\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dfc2e223bd10..377d849183d1 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -1920,6 +1920,11 @@ ext4_xattr_block_find(struct inode *inode, struct ext4_xattr_info *i,\n \n static int\n ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n+{\n+    int error = dquot_initialize(inode);\n+    if (error)\n+        return error;\n+\n \t\t     struct ext4_xattr_info *i,\n \t\t     struct ext4_xattr_block_find *bs)\n {\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/ext4/xattr_security.c b/fs/ext4/xattr_security.c\nindex 776cf11d24ca..49e499ab6d38 100644\n--- a/fs/ext4/xattr_security.c\n+++ b/fs/ext4/xattr_security.c\n@@ -40,6 +40,12 @@ ext4_initxattrs(struct inode *inode, const struct xattr *xattr_array,\n \thandle_t *handle = fs_info;\n \tint err = 0;\n \n+if (dquot_initialize_needed(inode)) {\n+err = dquot_initialize(inode);\n+if (err)\n+return err;\n+}\n+\n \tfor (xattr = xattr_array; xattr->name != NULL; xattr++) {\n \t\terr = ext4_xattr_set_handle(handle, inode,\n \t\t\t\t\t    EXT4_XATTR_INDEX_SECURITY,\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "7b2aea1ce02f87c175f94492d21d04a34bc99b5e": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/vhost/vsock.c b/drivers/vhost/vsock.c\nindex 37f0b4274113..fea7a3d8ac65 100644\n--- a/drivers/vhost/vsock.c\n+++ b/drivers/vhost/vsock.c\n@@ -579,7 +579,7 @@ static int vhost_vsock_start(struct vhost_vsock *vsock)\n \tsize_t i;\n \tint ret;\n \n-\tmutex_lock(&vsock->dev.mutex);\n+\tmutex_lock_interruptible(&vsock->dev.mutex);\n \n \tret = vhost_dev_check_owner(&vsock->dev);\n \tif (ret)\n@@ -634,7 +634,7 @@ 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+\tmutex_lock_interruptible(&vsock->dev.mutex);\n \n \tif (check_owner) {\n \t\tret = vhost_dev_check_owner(&vsock->dev);\n@@ -826,7 +826,7 @@ static int vhost_vsock_set_features(struct vhost_vsock *vsock, u64 features)\n \tif (features & ~VHOST_VSOCK_FEATURES)\n \t\treturn -EOPNOTSUPP;\n \n-\tmutex_lock(&vsock->dev.mutex);\n+\tmutex_lock_interruptible(&vsock->dev.mutex);\n \tif ((features & (1 << VHOST_F_LOG_ALL)) &&\n \t    !vhost_log_access_ok(&vsock->dev)) {\n \t\tgoto err;\n@@ -898,7 +898,7 @@ static long vhost_vsock_dev_ioctl(struct file *f, unsigned int ioctl,\n \t\tvhost_set_backend_features(&vsock->dev, features);\n \t\treturn 0;\n \tdefault:\n-\t\tmutex_lock(&vsock->dev.mutex);\n+\t\tmutex_lock_interruptible(&vsock->dev.mutex);\n \t\tr = vhost_dev_ioctl(&vsock->dev, ioctl, argp);\n \t\tif (r == -ENOIOCTLCMD)\n \t\t\tr = vhost_vring_ioctl(&vsock->dev, ioctl, argp);\n",
            "diff --git a/drivers/vhost/vsock.c b/drivers/vhost/vsock.c\nindex 37f0b4274113..7bd17027b13f 100644\n--- a/drivers/vhost/vsock.c\n+++ b/drivers/vhost/vsock.c\n@@ -634,7 +634,8 @@ 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+\t// Ensure consistent lock order: acquire vsock->dev.mutex before vq->mutex\n+    mutex_lock(&vsock->dev.mutex);\n \n \tif (check_owner) {\n \t\tret = vhost_dev_check_owner(&vsock->dev);\n",
            "diff --git a/drivers/vhost/vsock.c b/drivers/vhost/vsock.c\nindex 37f0b4274113..be771ec5ebd6 100644\n--- a/drivers/vhost/vsock.c\n+++ b/drivers/vhost/vsock.c\n@@ -579,7 +579,9 @@ static int vhost_vsock_start(struct vhost_vsock *vsock)\n \tsize_t i;\n \tint ret;\n \n-\tmutex_lock(&vsock->dev.mutex);\n+\tif (!mutex_trylock(&vsock->dev.mutex)) {\n+        return -EBUSY;\n+    }\n \n \tret = vhost_dev_check_owner(&vsock->dev);\n \tif (ret)\n@@ -634,7 +636,9 @@ 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+\tif (!mutex_trylock(&vsock->dev.mutex)) {\n+        return -EBUSY;\n+    }\n \n \tif (check_owner) {\n \t\tret = vhost_dev_check_owner(&vsock->dev);\n@@ -826,7 +830,9 @@ static int vhost_vsock_set_features(struct vhost_vsock *vsock, u64 features)\n \tif (features & ~VHOST_VSOCK_FEATURES)\n \t\treturn -EOPNOTSUPP;\n \n-\tmutex_lock(&vsock->dev.mutex);\n+\tif (!mutex_trylock(&vsock->dev.mutex)) {\n+        return -EBUSY;\n+    }\n \tif ((features & (1 << VHOST_F_LOG_ALL)) &&\n \t    !vhost_log_access_ok(&vsock->dev)) {\n \t\tgoto err;\n@@ -898,7 +904,9 @@ static long vhost_vsock_dev_ioctl(struct file *f, unsigned int ioctl,\n \t\tvhost_set_backend_features(&vsock->dev, features);\n \t\treturn 0;\n \tdefault:\n-\t\tmutex_lock(&vsock->dev.mutex);\n+\t\tif (!mutex_trylock(&vsock->dev.mutex)) {\n+        return -EBUSY;\n+    }\n \t\tr = vhost_dev_ioctl(&vsock->dev, ioctl, argp);\n \t\tif (r == -ENOIOCTLCMD)\n \t\t\tr = vhost_vring_ioctl(&vsock->dev, ioctl, argp);\n",
            "diff --git a/drivers/vhost/vsock.c b/drivers/vhost/vsock.c\nindex 37f0b4274113..b8bcfec0da91 100644\n--- a/drivers/vhost/vsock.c\n+++ b/drivers/vhost/vsock.c\n@@ -634,7 +634,8 @@ 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+\tif (mutex_lock_interruptible(&vsock->dev.mutex))\n+        return -ERESTARTSYS;\n \n \tif (check_owner) {\n \t\tret = vhost_dev_check_owner(&vsock->dev);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/vhost/vsock.c b/drivers/vhost/vsock.c\nindex 37f0b4274113..798176d8b1dc 100644\n--- a/drivers/vhost/vsock.c\n+++ b/drivers/vhost/vsock.c\n@@ -96,7 +96,10 @@ vhost_transport_do_send_pkt(struct vhost_vsock *vsock,\n \tbool added = false;\n \tbool restart_tx = false;\n \n-\tmutex_lock(&vq->mutex);\n+\tif (mutex_lock_interruptible(&vq->mutex)) {\n+mutex_unlock(&vsock->dev.mutex);\n+return -EINTR;\n+}\n \n \tif (!vhost_vq_get_backend(vq))\n \t\tgoto out;\n@@ -501,7 +504,10 @@ static void vhost_vsock_handle_tx_kick(struct vhost_work *work)\n \tunsigned int out, in;\n \tbool added = false;\n \n-\tmutex_lock(&vq->mutex);\n+\tif (mutex_lock_interruptible(&vq->mutex)) {\n+mutex_unlock(&vsock->dev.mutex);\n+return -EINTR;\n+}\n \n \tif (!vhost_vq_get_backend(vq))\n \t\tgoto out;\n@@ -588,7 +594,10 @@ static int vhost_vsock_start(struct vhost_vsock *vsock)\n \tfor (i = 0; i < ARRAY_SIZE(vsock->vqs); i++) {\n \t\tvq = &vsock->vqs[i];\n \n-\t\tmutex_lock(&vq->mutex);\n+\t\tif (mutex_lock_interruptible(&vq->mutex)) {\n+mutex_unlock(&vsock->dev.mutex);\n+return -EINTR;\n+}\n \n \t\tif (!vhost_vq_access_ok(vq)) {\n \t\t\tret = -EFAULT;\n@@ -620,7 +629,10 @@ static int vhost_vsock_start(struct vhost_vsock *vsock)\n \tfor (i = 0; i < ARRAY_SIZE(vsock->vqs); i++) {\n \t\tvq = &vsock->vqs[i];\n \n-\t\tmutex_lock(&vq->mutex);\n+\t\tif (mutex_lock_interruptible(&vq->mutex)) {\n+mutex_unlock(&vsock->dev.mutex);\n+return -EINTR;\n+}\n \t\tvhost_vq_set_backend(vq, NULL);\n \t\tmutex_unlock(&vq->mutex);\n \t}\n@@ -645,7 +657,10 @@ static int vhost_vsock_stop(struct vhost_vsock *vsock, bool check_owner)\n \tfor (i = 0; i < ARRAY_SIZE(vsock->vqs); i++) {\n \t\tstruct vhost_virtqueue *vq = &vsock->vqs[i];\n \n-\t\tmutex_lock(&vq->mutex);\n+\t\tif (mutex_lock_interruptible(&vq->mutex)) {\n+mutex_unlock(&vsock->dev.mutex);\n+return -EINTR;\n+}\n \t\tvhost_vq_set_backend(vq, NULL);\n \t\tmutex_unlock(&vq->mutex);\n \t}\n@@ -842,7 +857,10 @@ static int vhost_vsock_set_features(struct vhost_vsock *vsock, u64 features)\n \n \tfor (i = 0; i < ARRAY_SIZE(vsock->vqs); i++) {\n \t\tvq = &vsock->vqs[i];\n-\t\tmutex_lock(&vq->mutex);\n+\t\tif (mutex_lock_interruptible(&vq->mutex)) {\n+mutex_unlock(&vsock->dev.mutex);\n+return -EINTR;\n+}\n \t\tvq->acked_features = features;\n \t\tmutex_unlock(&vq->mutex);\n \t}\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "0ec05481e31f2772a2c6f16aecb38f48467da26e": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 1971ca325fb4..ff149a861860 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -1009,7 +1009,11 @@ static int check_subprogs(struct bpf_verifier_env *env)\n \t\t\tverbose(env, \"function calls to other bpf functions are allowed for root only\\n\");\n \t\t\treturn -EPERM;\n \t\t}\n-\t\tret = add_subprog(env, i + insn[i].imm + 1);\n+\t\tif (i + insn[i].imm + 1 >= insn_cnt || i + insn[i].imm + 1 < 0) {\n+            verbose(env, \"call to invalid destination\\n\");\n+            return -EINVAL;\n+        }\n+        ret = add_subprog(env, i + insn[i].imm + 1);\n \t\tif (ret < 0)\n \t\t\treturn ret;\n \t}\n",
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 1971ca325fb4..b3076f2266a0 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -5324,7 +5324,11 @@ static int do_check(struct bpf_verifier_env *env)\n \t\t\t\t\treturn -EINVAL;\n \t\t\t\t}\n \n-\t\t\t\tinsn_idx += insn->off + 1;\n+\t\t\t\tif (insn_idx + insn->off + 1 >= insn_cnt) {\n+    verbose(env, \"invalid jump: insn_idx %d exceeds insn_cnt %d\\n\", insn_idx + insn->off + 1, insn_cnt);\n+    return -EFAULT;\n+}\n+insn_idx += insn->off + 1;\n \t\t\t\tcontinue;\n \n \t\t\t} else if (opcode == BPF_EXIT) {\n",
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 1971ca325fb4..85a7052dc15b 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -970,7 +970,7 @@ static int add_subprog(struct bpf_verifier_env *env, int off)\n \tint insn_cnt = env->prog->len;\n \tint ret;\n \n-\tif (off >= insn_cnt || off < 0) {\n+\tif (off >= insn_cnt || off < 0 || !env->allow_ptr_leaks) {\n \t\tverbose(env, \"call to invalid destination\\n\");\n \t\treturn -EINVAL;\n \t}\n"
        ],
        "error": [
            {
                "patch": "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 1971ca325fb4..509d36065b45 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -1132,6 +1132,9 @@ static bool is_spillable_regtype(enum bpf_reg_type type)\n \t\treturn true;\n \tdefault:\n \t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t}\n }\n \n@@ -1396,6 +1399,9 @@ static bool may_access_direct_pkt_data(struct bpf_verifier_env *env,\n \tcase BPF_PROG_TYPE_CGROUP_SKB:\n \t\tif (t == BPF_WRITE)\n \t\t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t\t/* fallthrough */\n \n \t/* Program types with direct read + write access go here! */\n@@ -1412,6 +1418,9 @@ static bool may_access_direct_pkt_data(struct bpf_verifier_env *env,\n \t\treturn true;\n \tdefault:\n \t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t}\n }\n \n@@ -1527,6 +1536,9 @@ static bool __is_pointer_value(bool allow_ptr_leaks,\n {\n \tif (allow_ptr_leaks)\n \t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \n \treturn reg->type != SCALAR_VALUE;\n }\n@@ -2466,6 +2478,9 @@ static bool check_arg_pair_ok(const struct bpf_func_proto *fn)\n \t    check_args_pair_invalid(fn->arg3_type, fn->arg4_type) ||\n \t    check_args_pair_invalid(fn->arg4_type, fn->arg5_type))\n \t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \n \treturn true;\n }\n@@ -2944,24 +2959,36 @@ static bool check_reg_sane_offset(struct bpf_verifier_env *env,\n \t\tverbose(env, \"math between %s pointer and %lld is not allowed\\n\",\n \t\t\treg_type_str[type], val);\n \t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t}\n \n \tif (reg->off >= BPF_MAX_VAR_OFF || reg->off <= -BPF_MAX_VAR_OFF) {\n \t\tverbose(env, \"%s pointer offset %d is not allowed\\n\",\n \t\t\treg_type_str[type], reg->off);\n \t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t}\n \n \tif (smin == S64_MIN) {\n \t\tverbose(env, \"math between %s pointer and register with unbounded min value is not allowed\\n\",\n \t\t\treg_type_str[type]);\n \t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t}\n \n \tif (smin >= BPF_MAX_VAR_OFF || smin <= -BPF_MAX_VAR_OFF) {\n \t\tverbose(env, \"value %lld makes %s pointer be out of bounds\\n\",\n \t\t\tsmin, reg_type_str[type]);\n \t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t}\n \n \treturn true;\n@@ -4022,6 +4049,9 @@ static bool try_match_pkt_pointers(const struct bpf_insn *insn,\n {\n \tif (BPF_SRC(insn->code) != BPF_X)\n \t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \n \tswitch (BPF_OP(insn->code)) {\n \tcase BPF_JGT:\n@@ -4041,6 +4071,9 @@ static bool try_match_pkt_pointers(const struct bpf_insn *insn,\n \t\t\t\t\t       src_reg->type, true);\n \t\t} else {\n \t\t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t\t}\n \t\tbreak;\n \tcase BPF_JLT:\n@@ -4060,6 +4093,9 @@ static bool try_match_pkt_pointers(const struct bpf_insn *insn,\n \t\t\t\t\t       src_reg->type, false);\n \t\t} else {\n \t\t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t\t}\n \t\tbreak;\n \tcase BPF_JGE:\n@@ -4079,6 +4115,9 @@ static bool try_match_pkt_pointers(const struct bpf_insn *insn,\n \t\t\t\t\t       src_reg->type, false);\n \t\t} else {\n \t\t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t\t}\n \t\tbreak;\n \tcase BPF_JLE:\n@@ -4098,10 +4137,16 @@ static bool try_match_pkt_pointers(const struct bpf_insn *insn,\n \t\t\t\t\t       src_reg->type, true);\n \t\t} else {\n \t\t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t\t}\n \t\tbreak;\n \tdefault:\n \t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t}\n \n \treturn true;\n@@ -4283,6 +4328,9 @@ static bool may_access_skb(enum bpf_prog_type type)\n \t\treturn true;\n \tdefault:\n \t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t}\n }\n \n@@ -4672,6 +4720,9 @@ static bool check_ids(u32 old_id, u32 cur_id, struct idpair *idmap)\n \t/* We ran out of idmap slots, which should be impossible */\n \tWARN_ON_ONCE(1);\n \treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n }\n \n /* Returns true if (rold safe implies rcur safe) */\n@@ -4700,6 +4751,9 @@ static bool regsafe(struct bpf_reg_state *rold, struct bpf_reg_state *rcur,\n \t\treturn true;\n \tif (rcur->type == NOT_INIT)\n \t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \tswitch (rold->type) {\n \tcase SCALAR_VALUE:\n \t\tif (rcur->type == SCALAR_VALUE) {\n@@ -4715,6 +4769,9 @@ static bool regsafe(struct bpf_reg_state *rold, struct bpf_reg_state *rcur,\n \t\t\t * probably not worth the hassle.\n \t\t\t */\n \t\t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t\t}\n \tcase PTR_TO_MAP_VALUE:\n \t\t/* If the new min/max/var_off satisfy the old ones and\n@@ -4735,14 +4792,23 @@ static bool regsafe(struct bpf_reg_state *rold, struct bpf_reg_state *rcur,\n \t\t */\n \t\tif (rcur->type != PTR_TO_MAP_VALUE_OR_NULL)\n \t\t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t\tif (memcmp(rold, rcur, offsetof(struct bpf_reg_state, id)))\n \t\t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t\t/* Check our ids match any regs they're supposed to */\n \t\treturn check_ids(rold->id, rcur->id, idmap);\n \tcase PTR_TO_PACKET_META:\n \tcase PTR_TO_PACKET:\n \t\tif (rcur->type != rold->type)\n \t\t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t\t/* We must have at least as much range as the old ptr\n \t\t * did, so that any accesses which were safe before are\n \t\t * still safe.  This is true even if old range < old off,\n@@ -4751,14 +4817,23 @@ static bool regsafe(struct bpf_reg_state *rold, struct bpf_reg_state *rcur,\n \t\t */\n \t\tif (rold->range > rcur->range)\n \t\t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t\t/* If the offsets don't match, we can't trust our alignment;\n \t\t * nor can we be sure that we won't fall out of range.\n \t\t */\n \t\tif (rold->off != rcur->off)\n \t\t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t\t/* id relations must be preserved */\n \t\tif (rold->id && !check_ids(rold->id, rcur->id, idmap))\n \t\t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t\t/* new val must satisfy old val knowledge */\n \t\treturn range_within(rold, rcur) &&\n \t\t       tnum_in(rold->var_off, rcur->var_off);\n@@ -4774,11 +4849,17 @@ static bool regsafe(struct bpf_reg_state *rold, struct bpf_reg_state *rcur,\n \tdefault:\n \t\t/* Don't know what's going on, just say it's not safe */\n \t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t}\n \n \t/* Shouldn't get here; if we do, say it's not safe */\n \tWARN_ON_ONCE(1);\n \treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n }\n \n static bool stacksafe(struct bpf_func_state *old,\n@@ -4792,6 +4873,9 @@ static bool stacksafe(struct bpf_func_state *old,\n \t */\n \tif (old->allocated_stack > cur->allocated_stack)\n \t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \n \t/* walk slots of the explored stack and ignore any additional\n \t * slots in the current stack, since explored(safe) state\n@@ -4821,6 +4905,9 @@ static bool stacksafe(struct bpf_func_state *old,\n \t\t\t * return false to continue verification of this path\n \t\t\t */\n \t\t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t\tif (i % BPF_REG_SIZE)\n \t\t\tcontinue;\n \t\tif (old->stack[spi].slot_type[0] != STACK_SPILL)\n@@ -4839,6 +4926,9 @@ static bool stacksafe(struct bpf_func_state *old,\n \t\t\t * return false to continue verification of this path\n \t\t\t */\n \t\t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t}\n \treturn true;\n }\n@@ -4847,6 +4937,9 @@ static bool refsafe(struct bpf_func_state *old, struct bpf_func_state *cur)\n {\n \tif (old->acquired_refs != cur->acquired_refs)\n \t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \treturn !memcmp(old->refs, cur->refs,\n \t\t       sizeof(*old->refs) * old->acquired_refs);\n }\n@@ -4888,6 +4981,9 @@ static bool func_states_equal(struct bpf_func_state *old,\n \t/* If we failed to allocate the idmap, just say it's not safe */\n \tif (!idmap)\n \t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \n \tfor (i = 0; i < MAX_BPF_REG; i++) {\n \t\tif (!regsafe(&old->regs[i], &cur->regs[i], idmap))\n@@ -4913,6 +5009,9 @@ static bool states_equal(struct bpf_verifier_env *env,\n \n \tif (old->curframe != cur->curframe)\n \t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \n \t/* for states to be equal callsites have to be the same\n \t * and all frame states need to be equivalent\n@@ -4920,8 +5019,14 @@ static bool states_equal(struct bpf_verifier_env *env,\n \tfor (i = 0; i <= old->curframe; i++) {\n \t\tif (old->frame[i]->callsite != cur->frame[i]->callsite)\n \t\t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t\tif (!func_states_equal(old->frame[i], cur->frame[i]))\n \t\t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \t}\n \treturn true;\n }\n@@ -5064,6 +5169,9 @@ static bool reg_type_mismatch_ok(enum bpf_reg_type type)\n \tcase PTR_TO_SOCKET:\n \tcase PTR_TO_SOCKET_OR_NULL:\n \t\treturn false;\n+/* Ensure accurate state handling by checking additional conditions */\n+if (rcur->type == PTR_TO_STACK && rold->frameno != rcur->frameno)\n+return false;\n \tdefault:\n \t\treturn true;\n \t}\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 1971ca325fb4..3cb8d59de0fd 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -6303,6 +6303,17 @@ static void free_states(struct bpf_verifier_env *env)\n }\n \n int bpf_check(struct bpf_prog **prog, union bpf_attr *attr)\n+{\n+    int i;\n+    for (i = 0; i < (*prog)->len; i++) {\n+        if ((*prog)->insnsi[i].code == BPF_EXIT) {\n+            break;\n+        }\n+    }\n+    if (i == (*prog)->len) {\n+        printk(KERN_WARNING \"No program starts at insn 7\\n\");\n+        return -EINVAL;\n+    }\n {\n \tstruct bpf_verifier_env *env;\n \tstruct bpf_verifier_log *log;\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..bb418b568fd7 100644\n--- a/net/core/devlink.c\n+++ b/net/core/devlink.c\n@@ -4269,6 +4269,10 @@ static int devlink_nl_cmd_region_read_dumpit(struct sk_buff *skb,\n \n \tmutex_lock(&devlink_mutex);\n \tdevlink = devlink_get_from_attrs(sock_net(cb->skb->sk), attrs);\n+    if (!devlink || !devlink->registered) {\n+        err = -EINVAL;\n+        goto out_dev;\n+    }\n \tif (IS_ERR(devlink)) {\n \t\terr = PTR_ERR(devlink);\n \t\tgoto out_dev;\n",
            "diff --git a/drivers/net/ethernet/mellanox/mlx5/core/devlink.c b/drivers/net/ethernet/mellanox/mlx5/core/devlink.c\nindex a99fe4b02b9b..2398133cdf35 100644\n--- a/drivers/net/ethernet/mellanox/mlx5/core/devlink.c\n+++ b/drivers/net/ethernet/mellanox/mlx5/core/devlink.c\n@@ -270,6 +270,8 @@ static void mlx5_devlink_set_params_init_values(struct devlink *devlink)\n }\n \n int mlx5_devlink_register(struct devlink *devlink, struct device *dev)\n+{\n+    refcount_set(&devlink->refcount, 1);\n {\n \tint err;\n \n@@ -291,6 +293,9 @@ int mlx5_devlink_register(struct devlink *devlink, struct device *dev)\n }\n \n void mlx5_devlink_unregister(struct devlink *devlink)\n+{\n+    if (!refcount_dec_and_test(&devlink->refcount))\n+        return;\n {\n \tdevlink_params_unregister(devlink, mlx5_devlink_params,\n \t\t\t\t  ARRAY_SIZE(mlx5_devlink_params));\n",
            "diff --git a/net/core/devlink.c b/net/core/devlink.c\nindex 2cafbc808b09..7724b0daa1a0 100644\n--- a/net/core/devlink.c\n+++ b/net/core/devlink.c\n@@ -130,7 +130,7 @@ 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 (strcmp(devlink->dev->bus->name, busname) == 0 &&\n+\t\tif (busname && devname && 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\treturn devlink;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/include/net/devlink.h b/include/net/devlink.h\nindex 1df6dfec26c2..2d54c4c847df 100644\n--- a/include/net/devlink.h\n+++ b/include/net/devlink.h\n@@ -23,6 +23,7 @@\n struct devlink_ops;\n \n struct devlink {\n+refcount_t refcount;\n \tstruct list_head list;\n \tstruct list_head port_list;\n \tstruct list_head sb_list;\ndiff --git a/net/core/devlink.c b/net/core/devlink.c\nindex 2cafbc808b09..7bfa8705d0d8 100644\n--- a/net/core/devlink.c\n+++ b/net/core/devlink.c\n@@ -133,7 +133,8 @@ static struct devlink *devlink_get_from_attrs(struct net *net,\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\treturn devlink;\n+\t\t\trefcount_inc(&devlink->refcount);\n+return devlink;\n \t}\n \n \treturn ERR_PTR(-ENODEV);\n@@ -7093,7 +7094,8 @@ struct devlink *devlink_alloc(const struct devlink_ops *ops, size_t priv_size)\n \tdevlink = kzalloc(sizeof(*devlink) + priv_size, GFP_KERNEL);\n \tif (!devlink)\n \t\treturn NULL;\n-\tdevlink->ops = ops;\n+\trefcount_set(&devlink->refcount, 1);\n+devlink->ops = ops;\n \txa_init_flags(&devlink->snapshot_ids, XA_FLAGS_ALLOC);\n \t__devlink_net_set(devlink, &init_net);\n \tINIT_LIST_HEAD(&devlink->port_list);\n@@ -7109,6 +7111,14 @@ struct devlink *devlink_alloc(const struct devlink_ops *ops, size_t priv_size)\n \tmutex_init(&devlink->lock);\n \tmutex_init(&devlink->reporters_lock);\n \treturn devlink;\n+\n+void devlink_put(struct devlink *devlink)\n+{\n+if (refcount_dec_and_test(&devlink->refcount)) {\n+kfree(devlink);\n+}\n+}\n+EXPORT_SYMBOL_GPL(devlink_put);\n }\n EXPORT_SYMBOL_GPL(devlink_alloc);\n \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..bb71453fa59e 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..bb71453fa59e 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"
        ],
        "error": []
    },
    "d92cc44e8c8ce5af6d2bea9f7a73cee791989fc8": {
        "non_crash": [
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex ff7ab63c5b4f..84ba234c4a0a 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, 2);\n }\n #endif\n \n",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex ff7ab63c5b4f..84ba234c4a0a 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, 2);\n }\n #endif\n \n",
            "diff --git a/fs/ext4/ext4.h b/fs/ext4/ext4.h\nindex 9525c52b78dc..2b179a9ed68e 100644\n--- a/fs/ext4/ext4.h\n+++ b/fs/ext4/ext4.h\n@@ -917,12 +917,14 @@ do {\t\t\t\t\t\t\t\t\t       \\\n  *  I_DATA_SEM_OTHER  - Used by move_inode.c for the second normal inode\n  *\t\t\t  where the second inode has larger inode number\n  *\t\t\t  than the first\n- *  I_DATA_SEM_QUOTA  - Used for quota inodes only\n+ *  I_DATA_SEM_QUOTA,\n+    I_DATA_SEM_EA  - Used for quota inodes only\n  */\n enum {\n \tI_DATA_SEM_NORMAL = 0,\n \tI_DATA_SEM_OTHER,\n \tI_DATA_SEM_QUOTA,\n+    I_DATA_SEM_EA,\n };\n \n \ndiff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex ff7ab63c5b4f..215eb4500152 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, I_DATA_SEM_EA);\n }\n #endif\n \n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex ff7ab63c5b4f..0fbf04c2a963 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, EXT4_XATTR_INODE_RWSEM_SUBCLASS);\n }\n #endif\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "64182208616de0ae5ebd9b1652cb213485d61fce": {
        "non_crash": [
            "diff --git a/net/nfc/netlink.c b/net/nfc/netlink.c\nindex 1fc339084d89..4ef3689dd9cc 100644\n--- a/net/nfc/netlink.c\n+++ b/net/nfc/netlink.c\n@@ -1538,6 +1538,10 @@ 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+    if (rc) {\n+        kfree(ctx);\n+        goto put_dev;\n+    }\n \n put_dev:\n \tnfc_put_device(dev);\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/nfc/netlink.c b/net/nfc/netlink.c\nindex 1fc339084d89..bb48d05b8079 100644\n--- a/net/nfc/netlink.c\n+++ b/net/nfc/netlink.c\n@@ -1541,7 +1541,8 @@ static int nfc_genl_se_io(struct sk_buff *skb, struct genl_info *info)\n \n put_dev:\n \tnfc_put_device(dev);\n-\treturn rc;\n+\tkfree(ctx);\n+    return rc;\n }\n \n static int nfc_genl_vendor_cmd(struct sk_buff *skb,\n",
            "diff --git a/net/nfc/netlink.c b/net/nfc/netlink.c\nindex 1fc339084d89..9c5131d7e378 100644\n--- a/net/nfc/netlink.c\n+++ b/net/nfc/netlink.c\n@@ -1541,7 +1541,9 @@ static int nfc_genl_se_io(struct sk_buff *skb, struct genl_info *info)\n \n put_dev:\n \tnfc_put_device(dev);\n-\treturn rc;\n+\tif (rc)\n+        kfree(ctx);\n+    return rc;\n }\n \n static int nfc_genl_vendor_cmd(struct sk_buff *skb,\n",
            "diff --git a/net/nfc/netlink.c b/net/nfc/netlink.c\nindex 1fc339084d89..6c1dd80d0e4e 100644\n--- a/net/nfc/netlink.c\n+++ b/net/nfc/netlink.c\n@@ -1541,7 +1541,8 @@ static int nfc_genl_se_io(struct sk_buff *skb, struct genl_info *info)\n \n put_dev:\n \tnfc_put_device(dev);\n-\treturn rc;\n+\tkfree(ctx);\n+return rc;\n }\n \n static int nfc_genl_vendor_cmd(struct sk_buff *skb,\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/nfc/netlink.c b/net/nfc/netlink.c\nindex 1fc339084d89..854823e87568 100644\n--- a/net/nfc/netlink.c\n+++ b/net/nfc/netlink.c\n@@ -1513,25 +1513,29 @@ static int nfc_genl_se_io(struct sk_buff *skb, struct genl_info *info)\n \n \tif (!dev->ops || !dev->ops->se_io) {\n \t\trc = -EOPNOTSUPP;\n-\t\tgoto put_dev;\n+\t\tkfree(ctx);\n+    goto put_dev;\n \t}\n \n \tapdu_len = nla_len(info->attrs[NFC_ATTR_SE_APDU]);\n \tif (apdu_len == 0) {\n \t\trc = -EINVAL;\n-\t\tgoto put_dev;\n+\t\tkfree(ctx);\n+    goto put_dev;\n \t}\n \n \tapdu = nla_data(info->attrs[NFC_ATTR_SE_APDU]);\n \tif (!apdu) {\n \t\trc = -EINVAL;\n-\t\tgoto put_dev;\n+\t\tkfree(ctx);\n+    goto put_dev;\n \t}\n \n \tctx = kzalloc(sizeof(struct se_io_ctx), GFP_KERNEL);\n \tif (!ctx) {\n \t\trc = -ENOMEM;\n-\t\tgoto put_dev;\n+\t\tkfree(ctx);\n+    goto put_dev;\n \t}\n \n \tctx->dev_idx = dev_idx;\n@@ -1569,7 +1573,8 @@ static int nfc_genl_vendor_cmd(struct sk_buff *skb,\n \n \tif (!dev->vendor_cmds || !dev->n_vendor_cmds) {\n \t\terr = -ENODEV;\n-\t\tgoto put_dev;\n+\t\tkfree(ctx);\n+    goto put_dev;\n \t}\n \n \tif (info->attrs[NFC_ATTR_VENDOR_DATA]) {\n@@ -1577,7 +1582,8 @@ static int nfc_genl_vendor_cmd(struct sk_buff *skb,\n \t\tdata_len = nla_len(info->attrs[NFC_ATTR_VENDOR_DATA]);\n \t\tif (data_len == 0) {\n \t\t\terr = -EINVAL;\n-\t\t\tgoto put_dev;\n+\t\t\tkfree(ctx);\n+    goto put_dev;\n \t\t}\n \t} else {\n \t\tdata = NULL;\n@@ -1593,7 +1599,8 @@ static int nfc_genl_vendor_cmd(struct sk_buff *skb,\n \t\tdev->cur_cmd_info = info;\n \t\terr = cmd->doit(dev, data, data_len);\n \t\tdev->cur_cmd_info = NULL;\n-\t\tgoto put_dev;\n+\t\tkfree(ctx);\n+    goto put_dev;\n \t}\n \n \terr = -EOPNOTSUPP;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "75a2a727e4636c7a34dbd49197b15c3de92a8f7f": {
        "non_crash": [
            "diff --git a/mm/hugetlb.c b/mm/hugetlb.c\nindex 9d97c9a2a15d..0cf2a52a4a8b 100644\n--- a/mm/hugetlb.c\n+++ b/mm/hugetlb.c\n@@ -5726,6 +5726,7 @@ static vm_fault_t hugetlb_no_page(struct mm_struct *mm,\n \t * the spinlock.\n \t */\n \tif ((flags & FAULT_FLAG_WRITE) && !(vma->vm_flags & VM_SHARED)) {\n+    vma->vm_flags |= VM_WRITE;\n \t\tif (vma_needs_reservation(h, vma, haddr) < 0) {\n \t\t\tret = VM_FAULT_OOM;\n \t\t\tgoto backout_unlocked;\n@@ -5756,6 +5757,7 @@ static vm_fault_t hugetlb_no_page(struct mm_struct *mm,\n \n \thugetlb_count_add(pages_per_huge_page(h), mm);\n \tif ((flags & FAULT_FLAG_WRITE) && !(vma->vm_flags & VM_SHARED)) {\n+    vma->vm_flags |= VM_WRITE;\n \t\t/* Optimization, do the COW without a second fault */\n \t\tret = hugetlb_wp(mm, vma, address, ptep, flags, page, ptl);\n \t}\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/hugetlb.c b/mm/hugetlb.c\nindex 9d97c9a2a15d..3002c27b6671 100644\n--- a/mm/hugetlb.c\n+++ b/mm/hugetlb.c\n@@ -5755,7 +5755,7 @@ static vm_fault_t hugetlb_no_page(struct mm_struct *mm,\n \tset_huge_pte_at(mm, haddr, ptep, new_pte);\n \n \thugetlb_count_add(pages_per_huge_page(h), mm);\n-\tif ((flags & FAULT_FLAG_WRITE) && !(vma->vm_flags & VM_SHARED)) {\n+\tif ((flags & FAULT_FLAG_WRITE) && !(vma->vm_flags & VM_SHARED) && (vma->vm_flags & VM_WRITE)) {\n \t\t/* Optimization, do the COW without a second fault */\n \t\tret = hugetlb_wp(mm, vma, address, ptep, flags, page, ptl);\n \t}\n",
            "diff --git a/mm/hugetlb.c b/mm/hugetlb.c\nindex 9d97c9a2a15d..829ba2f5b099 100644\n--- a/mm/hugetlb.c\n+++ b/mm/hugetlb.c\n@@ -5725,7 +5725,7 @@ static vm_fault_t hugetlb_no_page(struct mm_struct *mm,\n \t * any allocations necessary to record that reservation occur outside\n \t * the spinlock.\n \t */\n-\tif ((flags & FAULT_FLAG_WRITE) && !(vma->vm_flags & VM_SHARED)) {\n+\tif ((flags & FAULT_FLAG_WRITE) && !(vma->vm_flags & (VM_SHARED | VM_WRITE))) {\n \t\tif (vma_needs_reservation(h, vma, haddr) < 0) {\n \t\t\tret = VM_FAULT_OOM;\n \t\t\tgoto backout_unlocked;\n@@ -5755,7 +5755,7 @@ static vm_fault_t hugetlb_no_page(struct mm_struct *mm,\n \tset_huge_pte_at(mm, haddr, ptep, new_pte);\n \n \thugetlb_count_add(pages_per_huge_page(h), mm);\n-\tif ((flags & FAULT_FLAG_WRITE) && !(vma->vm_flags & VM_SHARED)) {\n+\tif ((flags & FAULT_FLAG_WRITE) && !(vma->vm_flags & (VM_SHARED | VM_WRITE))) {\n \t\t/* Optimization, do the COW without a second fault */\n \t\tret = hugetlb_wp(mm, vma, address, ptep, flags, page, ptl);\n \t}\n",
            "diff --git a/mm/hugetlb.c b/mm/hugetlb.c\nindex 9d97c9a2a15d..73f9af1886a2 100644\n--- a/mm/hugetlb.c\n+++ b/mm/hugetlb.c\n@@ -5757,7 +5757,8 @@ static vm_fault_t hugetlb_no_page(struct mm_struct *mm,\n \thugetlb_count_add(pages_per_huge_page(h), mm);\n \tif ((flags & FAULT_FLAG_WRITE) && !(vma->vm_flags & VM_SHARED)) {\n \t\t/* Optimization, do the COW without a second fault */\n-\t\tret = hugetlb_wp(mm, vma, address, ptep, flags, page, ptl);\n+\t\tif (flags & FAULT_FLAG_WRITE || (flags & FAULT_FLAG_UNSHARE && vma->vm_flags & VM_WRITE))\n+        ret = hugetlb_wp(mm, vma, address, ptep, flags, page, ptl);\n \t}\n \n \tspin_unlock(ptl);\n",
            "diff --git a/mm/hugetlb.c b/mm/hugetlb.c\nindex 9d97c9a2a15d..ad70bb9d8bac 100644\n--- a/mm/hugetlb.c\n+++ b/mm/hugetlb.c\n@@ -5725,7 +5725,7 @@ static vm_fault_t hugetlb_no_page(struct mm_struct *mm,\n \t * any allocations necessary to record that reservation occur outside\n \t * the spinlock.\n \t */\n-\tif ((flags & FAULT_FLAG_WRITE) && !(vma->vm_flags & VM_SHARED)) {\n+\tif ((flags & FAULT_FLAG_WRITE) && !(vma->vm_flags & VM_SHARED) && (flags & FAULT_FLAG_UNSHARE || vma->vm_flags & VM_WRITE)) {\n \t\tif (vma_needs_reservation(h, vma, haddr) < 0) {\n \t\t\tret = VM_FAULT_OOM;\n \t\t\tgoto backout_unlocked;\n@@ -5755,7 +5755,7 @@ static vm_fault_t hugetlb_no_page(struct mm_struct *mm,\n \tset_huge_pte_at(mm, haddr, ptep, new_pte);\n \n \thugetlb_count_add(pages_per_huge_page(h), mm);\n-\tif ((flags & FAULT_FLAG_WRITE) && !(vma->vm_flags & VM_SHARED)) {\n+\tif ((flags & FAULT_FLAG_WRITE) && !(vma->vm_flags & VM_SHARED) && (flags & FAULT_FLAG_UNSHARE || vma->vm_flags & VM_WRITE)) {\n \t\t/* Optimization, do the COW without a second fault */\n \t\tret = hugetlb_wp(mm, vma, address, ptep, flags, page, ptl);\n \t}\n"
        ],
        "error": []
    },
    "cd246a3e7f0fd69a115b910b3b2cf6fa96351278": {
        "non_crash": [
            "diff --git a/fs/nilfs2/btree.c b/fs/nilfs2/btree.c\nindex b9d15c3df3cc..52603befe530 100644\n--- a/fs/nilfs2/btree.c\n+++ b/fs/nilfs2/btree.c\n@@ -580,6 +580,9 @@ static int nilfs_btree_do_lookup(const struct nilfs_bmap *btree,\n \t\t\tindex = 0;\n \t\tif (index < ncmax) {\n \t\t\tptr = nilfs_btree_node_get_ptr(node, index, ncmax);\n+        if (ptr == NILFS_BMAP_INVALID_PTR) {\n+            return -EINVAL;\n+        }\n \t\t} else {\n \t\t\tWARN_ON(found || level != NILFS_BTREE_LEVEL_NODE_MIN);\n \t\t\t/* insert */\n@@ -624,6 +627,9 @@ static int nilfs_btree_do_lookup_last(const struct nilfs_bmap *btree,\n \t\t\treturn -EINVAL;\n \t\tindex = nilfs_btree_node_get_nchildren(node) - 1;\n \t\tptr = nilfs_btree_node_get_ptr(node, index, ncmax);\n+        if (ptr == NILFS_BMAP_INVALID_PTR) {\n+            return -EINVAL;\n+        }\n \t\tpath[level].bp_index = index;\n \t}\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/btree.c b/fs/nilfs2/btree.c\nindex b9d15c3df3cc..fd6112ecb5bb 100644\n--- a/fs/nilfs2/btree.c\n+++ b/fs/nilfs2/btree.c\n@@ -1210,7 +1210,9 @@ static void nilfs_btree_commit_insert(struct nilfs_bmap *btree,\n \tfor (level = NILFS_BTREE_LEVEL_NODE_MIN; level <= maxlevel; level++) {\n \t\tnilfs_bmap_commit_alloc_ptr(btree,\n \t\t\t\t\t    &path[level - 1].bp_newreq, dat);\n-\t\tpath[level].bp_op(btree, path, level, &key, &ptr);\n+\t\tif (path[level].bp_op) {\n+            path[level].bp_op(btree, path, level, &key, &ptr);\n+        }\n \t}\n \n \tif (!nilfs_bmap_dirty(btree))\n",
            "diff --git a/fs/nilfs2/btree.c b/fs/nilfs2/btree.c\nindex b9d15c3df3cc..70a81f303c4c 100644\n--- a/fs/nilfs2/btree.c\n+++ b/fs/nilfs2/btree.c\n@@ -415,7 +415,8 @@ 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-\treturn (struct nilfs_btree_node *)path[level].bp_bh->b_data;\n+\tif (path[level].bp_bh == NULL) return NULL;\n+    return (struct nilfs_btree_node *)path[level].bp_bh->b_data;\n }\n \n static struct nilfs_btree_node *\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/nilfs2/btree.c b/fs/nilfs2/btree.c\nindex b9d15c3df3cc..79a62dfed6d0 100644\n--- a/fs/nilfs2/btree.c\n+++ b/fs/nilfs2/btree.c\n@@ -438,6 +438,8 @@ nilfs_btree_get_node(const struct nilfs_bmap *btree,\n \n \tif (level == nilfs_btree_height(btree) - 1) {\n \t\tnode = nilfs_btree_get_root(btree);\n+    if (!node)\n+        return -EINVAL;\n \t\t*ncmaxp = NILFS_BTREE_ROOT_NCHILDREN_MAX;\n \t} else {\n \t\tnode = nilfs_btree_get_nonroot_node(path, level);\n@@ -545,6 +547,8 @@ static int nilfs_btree_do_lookup(const struct nilfs_bmap *btree,\n \tint level, index, found, ncmax, ret;\n \n \tnode = nilfs_btree_get_root(btree);\n+    if (!node)\n+        return -EINVAL;\n \tlevel = nilfs_btree_node_get_level(node);\n \tif (level < minlevel || nilfs_btree_node_get_nchildren(node) <= 0)\n \t\treturn -ENOENT;\n@@ -605,6 +609,8 @@ static int nilfs_btree_do_lookup_last(const struct nilfs_bmap *btree,\n \tint index, level, ncmax, ret;\n \n \tnode = nilfs_btree_get_root(btree);\n+    if (!node)\n+        return -EINVAL;\n \tindex = nilfs_btree_node_get_nchildren(node) - 1;\n \tif (index < 0)\n \t\treturn -ENOENT;\n@@ -658,6 +664,8 @@ static int nilfs_btree_get_next_key(const struct nilfs_bmap *btree,\n \tfor (level = minlevel; level <= maxlevel; level++) {\n \t\tif (level == maxlevel)\n \t\t\tnode = nilfs_btree_get_root(btree);\n+    if (!node)\n+        return -EINVAL;\n \t\telse\n \t\t\tnode = nilfs_btree_get_nonroot_node(path, level);\n \n@@ -817,6 +825,8 @@ static void nilfs_btree_do_insert(struct nilfs_bmap *btree,\n \t\t\t\t\t\t\t\t\t 0));\n \t} else {\n \t\tnode = nilfs_btree_get_root(btree);\n+    if (!node)\n+        return -EINVAL;\n \t\tnilfs_btree_node_insert(node, path[level].bp_index,\n \t\t\t\t\t*keyp, *ptrp,\n \t\t\t\t\tNILFS_BTREE_ROOT_NCHILDREN_MAX);\n@@ -1143,6 +1153,8 @@ static int nilfs_btree_prepare_insert(struct nilfs_bmap *btree,\n \n \t/* root */\n \tnode = nilfs_btree_get_root(btree);\n+    if (!node)\n+        return -EINVAL;\n \tif (nilfs_btree_node_get_nchildren(node) <\n \t    NILFS_BTREE_ROOT_NCHILDREN_MAX) {\n \t\tpath[level].bp_op = nilfs_btree_do_insert;\n@@ -1265,6 +1277,8 @@ static void nilfs_btree_do_delete(struct nilfs_bmap *btree,\n \t\t\t\tnilfs_btree_node_get_key(node, 0));\n \t} else {\n \t\tnode = nilfs_btree_get_root(btree);\n+    if (!node)\n+        return -EINVAL;\n \t\tnilfs_btree_node_delete(node, path[level].bp_index,\n \t\t\t\t\tkeyp, ptrp,\n \t\t\t\t\tNILFS_BTREE_ROOT_NCHILDREN_MAX);\n@@ -1526,6 +1540,8 @@ static int nilfs_btree_prepare_delete(struct nilfs_bmap *btree,\n \n shrink_root_child:\n \tnode = nilfs_btree_get_root(btree);\n+    if (!node)\n+        return -EINVAL;\n \tpath[level].bp_oldreq.bpr_ptr =\n \t\tnilfs_btree_node_get_ptr(node, dindex,\n \t\t\t\t\t NILFS_BTREE_ROOT_NCHILDREN_MAX);\n@@ -1820,6 +1836,8 @@ nilfs_btree_commit_convert_and_insert(struct nilfs_bmap *btree,\n \n \t\t/* create root node at level 2 */\n \t\tnode = nilfs_btree_get_root(btree);\n+    if (!node)\n+        return -EINVAL;\n \t\ttmpptr = nreq->bpr_ptr;\n \t\tnilfs_btree_node_init(node, NILFS_BTREE_NODE_ROOT, 2, 1,\n \t\t\t\t      NILFS_BTREE_ROOT_NCHILDREN_MAX,\n@@ -1829,6 +1847,8 @@ nilfs_btree_commit_convert_and_insert(struct nilfs_bmap *btree,\n \n \t\t/* create root node at level 1 */\n \t\tnode = nilfs_btree_get_root(btree);\n+    if (!node)\n+        return -EINVAL;\n \t\tnilfs_btree_node_init(node, NILFS_BTREE_NODE_ROOT, 1, n,\n \t\t\t\t      NILFS_BTREE_ROOT_NCHILDREN_MAX,\n \t\t\t\t      keys, ptrs);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/nilfs2/btree.c b/fs/nilfs2/btree.c\nindex b9d15c3df3cc..240540413d50 100644\n--- a/fs/nilfs2/btree.c\n+++ b/fs/nilfs2/btree.c\n@@ -1218,6 +1218,9 @@ static void nilfs_btree_commit_insert(struct nilfs_bmap *btree,\n }\n \n static int nilfs_btree_insert(struct nilfs_bmap *btree, __u64 key, __u64 ptr)\n+{\n+    if (btree->b_u.u_data == NULL)\n+        return -EINVAL;\n {\n \tstruct nilfs_btree_path *path;\n \tstruct nilfs_bmap_stats stats;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "a9412f636e2d733130f8def7975897d0b57f6e37": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/autofs/waitq.c b/fs/autofs/waitq.c\nindex 54c1f8b8b075..ad4bb3737c9f 100644\n--- a/fs/autofs/waitq.c\n+++ b/fs/autofs/waitq.c\n@@ -370,7 +370,8 @@ int autofs_wait(struct autofs_sb_info *sbi,\n \t\tif (ret != -EINTR)\n \t\t\tmutex_unlock(&sbi->wq_mutex);\n \t\tkfree(name);\n-\t\treturn ret;\n+\t\tkfree(wq);\n+        return ret;\n \t}\n \n \tif (!wq) {\n",
            "diff --git a/fs/autofs/waitq.c b/fs/autofs/waitq.c\nindex 54c1f8b8b075..4637ac564a30 100644\n--- a/fs/autofs/waitq.c\n+++ b/fs/autofs/waitq.c\n@@ -370,7 +370,8 @@ int autofs_wait(struct autofs_sb_info *sbi,\n \t\tif (ret != -EINTR)\n \t\t\tmutex_unlock(&sbi->wq_mutex);\n \t\tkfree(name);\n-\t\treturn ret;\n+\t\tkfree(wq);\n+return ret;\n \t}\n \n \tif (!wq) {\n",
            "diff --git a/fs/autofs/waitq.c b/fs/autofs/waitq.c\nindex 54c1f8b8b075..b0274f4d4029 100644\n--- a/fs/autofs/waitq.c\n+++ b/fs/autofs/waitq.c\n@@ -342,7 +342,8 @@ int autofs_wait(struct autofs_sb_info *sbi,\n \n \tname = kmalloc(NAME_MAX + 1, GFP_KERNEL);\n \tif (!name)\n-\t\treturn -ENOMEM;\n+\t\tkfree(wq);\n+            return -ENOMEM;\n \n \t/* If this is a direct mount request create a dummy name */\n \tif (IS_ROOT(dentry) && autofs_type_trigger(sbi->type)) {\n@@ -379,7 +380,8 @@ int autofs_wait(struct autofs_sb_info *sbi,\n \t\tif (!wq) {\n \t\t\tkfree(name);\n \t\t\tmutex_unlock(&sbi->wq_mutex);\n-\t\t\treturn -ENOMEM;\n+\t\t\tkfree(wq);\n+            return -ENOMEM;\n \t\t}\n \n \t\twq->wait_queue_token = autofs_next_wait_queue;\n",
            "diff --git a/fs/autofs/waitq.c b/fs/autofs/waitq.c\nindex 54c1f8b8b075..83fe8559f313 100644\n--- a/fs/autofs/waitq.c\n+++ b/fs/autofs/waitq.c\n@@ -367,6 +367,7 @@ int autofs_wait(struct autofs_sb_info *sbi,\n \n \tret = validate_request(&wq, sbi, &qstr, path, notify);\n \tif (ret <= 0) {\n+        if (wq) kfree(wq);\n \t\tif (ret != -EINTR)\n \t\t\tmutex_unlock(&sbi->wq_mutex);\n \t\tkfree(name);\n"
        ],
        "error": []
    },
    "9d6af32008ffd651175d152c5bea92cf767ae38c": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/io_uring/io_uring.c b/io_uring/io_uring.c\nindex 2ac1cd8d23ea..c9a89433f720 100644\n--- a/io_uring/io_uring.c\n+++ b/io_uring/io_uring.c\n@@ -2222,6 +2222,7 @@ static __cold int io_submit_fail_init(const struct io_uring_sqe *sqe,\n \t\t\treq = head;\n \t\t}\n \t\tio_queue_sqe_fallback(req);\n+io_free_req(req);\n \t\treturn ret;\n \t}\n \n@@ -2279,6 +2280,7 @@ static inline int io_submit_sqe(struct io_ring_ctx *ctx, struct io_kiocb *req,\n \t\t} else {\n fallback:\n \t\t\tio_queue_sqe_fallback(req);\n+io_free_req(req);\n \t\t}\n \t\treturn 0;\n \t}\n",
            "diff --git a/io_uring/io_uring.c b/io_uring/io_uring.c\nindex 2ac1cd8d23ea..387d48df752f 100644\n--- a/io_uring/io_uring.c\n+++ b/io_uring/io_uring.c\n@@ -2386,7 +2386,8 @@ 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_free_req(req);\n+            io_req_add_to_cache(req, ctx);\n \t\t\tbreak;\n \t\t}\n \n",
            "diff --git a/io_uring/io_uring.c b/io_uring/io_uring.c\nindex 2ac1cd8d23ea..d428bb033898 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_free_req(req);\n \t\t\tbreak;\n \t\t}\n \n",
            "diff --git a/io_uring/io_uring.c b/io_uring/io_uring.c\nindex 2ac1cd8d23ea..2a254a8375b0 100644\n--- a/io_uring/io_uring.c\n+++ b/io_uring/io_uring.c\n@@ -989,6 +989,7 @@ void io_req_defer_failed(struct io_kiocb *req, s32 res)\n \tif (def->fail)\n \t\tdef->fail(req);\n \tio_req_complete_defer(req);\n+io_free_req(req);\n }\n \n /*\n"
        ],
        "error": [
            {
                "patch": "diff --git a/io_uring/io_uring.c b/io_uring/io_uring.c\nindex 2ac1cd8d23ea..48093c2c9803 100644\n--- a/io_uring/io_uring.c\n+++ b/io_uring/io_uring.c\n@@ -2395,6 +2395,7 @@ int io_submit_sqes(struct io_ring_ctx *ctx, unsigned int nr)\n \t\t * ring was setup with IORING_SETUP_SUBMIT_ALL\n \t\t */\n \t\tif (unlikely(io_submit_sqe(ctx, req, sqe)) &&\n+            io_req_add_to_cache(req, ctx) &&\n \t\t    !(ctx->flags & IORING_SETUP_SUBMIT_ALL)) {\n \t\t\tleft--;\n \t\t\tbreak;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "8e9ea22655c782ac9af556ba3d4d822530a59390": {
        "non_crash": [
            "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 4bb6d304eb4b..f955c2b028a3 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -1949,6 +1949,10 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \n \tif (is_in)\n \t\tpipe = usb_rcvctrlpipe(data->usb_dev, 0);\n+if (!(request.req.bRequestType & USB_DIR_IN) && is_in) {\n+dev_warn(dev, \"Inconsistent direction: bRequestType 0x%x, pipe %x\\n\",\n+request.req.bRequestType, pipe);\n+}\n \telse\n \t\tpipe = usb_sndctrlpipe(data->usb_dev, 0);\n \trv = usb_control_msg(data->usb_dev,\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 4bb6d304eb4b..10bed1ba2dfd 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -1948,7 +1948,12 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \t}\n \n \tif (is_in)\n-\t\tpipe = usb_rcvctrlpipe(data->usb_dev, 0);\n+\t\tif (usb_pipeout(pipe) != is_in) {\n+            dev_err(dev, \"Pipe direction mismatch with bRequestType\\n\");\n+            rv = -EINVAL;\n+            goto exit;\n+        }\n+        pipe = usb_rcvctrlpipe(data->usb_dev, 0);\n \telse\n \t\tpipe = usb_sndctrlpipe(data->usb_dev, 0);\n \trv = usb_control_msg(data->usb_dev,\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 4bb6d304eb4b..40a1c93171e5 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -1949,6 +1949,7 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \n \tif (is_in)\n \t\tpipe = usb_rcvctrlpipe(data->usb_dev, 0);\n+dev_dbg(dev, \"Control transfer direction: %s\\n\", is_in ? \"IN\" : \"OUT\");\n \telse\n \t\tpipe = usb_sndctrlpipe(data->usb_dev, 0);\n \trv = usb_control_msg(data->usb_dev,\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 4bb6d304eb4b..f8cfd2133355 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -1948,7 +1948,14 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \t}\n \n \tif (is_in)\n-\t\tpipe = usb_rcvctrlpipe(data->usb_dev, 0);\n+\t\tif ((is_in && !(request.req.bRequestType & USB_DIR_IN)) ||\n+    (!is_in && (request.req.bRequestType & USB_DIR_IN))) {\n+    dev_err(dev, \"Control direction mismatch: bRequestType does not match pipe direction\\n\");\n+    rv = -EINVAL;\n+    goto exit;\n+}\n+\n+pipe = usb_rcvctrlpipe(data->usb_dev, 0);\n \telse\n \t\tpipe = usb_sndctrlpipe(data->usb_dev, 0);\n \trv = usb_control_msg(data->usb_dev,\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "6cd217d3878763ebef28a8fd279c88e791c1c9ef": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/fork.c b/kernel/fork.c\nindex f68954d05e89..810e7203d987 100644\n--- a/kernel/fork.c\n+++ b/kernel/fork.c\n@@ -2521,6 +2521,7 @@ static __latent_entropy struct task_struct *copy_process(\n \t\tput_unused_fd(pidfd);\n \t}\n bad_fork_free_pid:\n+    /* Ensure PID is freed to prevent memory leaks */\n \tif (pid != &init_struct_pid)\n \t\tfree_pid(pid);\n bad_fork_cleanup_thread:\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"
        ],
        "error": []
    },
    "2db2545ff94291fabe4a5dd4ee182db44ef35d4b": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/drivers/hid/uhid.c b/drivers/hid/uhid.c\nindex 3c5507313606..d13e35a1f4f8 100644\n--- a/drivers/hid/uhid.c\n+++ b/drivers/hid/uhid.c\n@@ -539,7 +539,7 @@ 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) || 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..076a538eeec1 100644\n--- a/drivers/hid/uhid.c\n+++ b/drivers/hid/uhid.c\n@@ -539,7 +539,7 @@ 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) || 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..047c17c8d4c3 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+    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..076a538eeec1 100644\n--- a/drivers/hid/uhid.c\n+++ b/drivers/hid/uhid.c\n@@ -539,7 +539,7 @@ 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) || 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..d18eaefb176c 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+            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"
            }
        ]
    },
    "e0640a911365faa499433155c3d5d5b674b36a83": {
        "non_crash": [
            "diff --git a/net/netfilter/nfnetlink_cttimeout.c b/net/netfilter/nfnetlink_cttimeout.c\nindex a518eb162344..c45fff7a935f 100644\n--- a/net/netfilter/nfnetlink_cttimeout.c\n+++ b/net/netfilter/nfnetlink_cttimeout.c\n@@ -437,7 +437,8 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \t__u16 l3num;\n \t__u8 l4num;\n \n-\tif (!cda[CTA_TIMEOUT_L3PROTO] || !cda[CTA_TIMEOUT_L4PROTO])\n+\tif (!cda[CTA_TIMEOUT_L3PROTO] || nla_len(cda[CTA_TIMEOUT_L3PROTO]) != sizeof(__u16) ||\n+    !cda[CTA_TIMEOUT_L4PROTO] || nla_len(cda[CTA_TIMEOUT_L4PROTO]) != sizeof(__u8))\n \t\treturn -EINVAL;\n \n \tl3num = ntohs(nla_get_be16(cda[CTA_TIMEOUT_L3PROTO]));\n",
            "diff --git a/net/netfilter/nfnetlink_cttimeout.c b/net/netfilter/nfnetlink_cttimeout.c\nindex a518eb162344..99e2d33a6541 100644\n--- a/net/netfilter/nfnetlink_cttimeout.c\n+++ b/net/netfilter/nfnetlink_cttimeout.c\n@@ -475,7 +475,8 @@ 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\terr = -EINVAL;\n+goto err;\n \t\tbreak;\n \t}\n \n",
            "diff --git a/net/netfilter/nfnetlink_cttimeout.c b/net/netfilter/nfnetlink_cttimeout.c\nindex a518eb162344..c45fff7a935f 100644\n--- a/net/netfilter/nfnetlink_cttimeout.c\n+++ b/net/netfilter/nfnetlink_cttimeout.c\n@@ -437,7 +437,8 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \t__u16 l3num;\n \t__u8 l4num;\n \n-\tif (!cda[CTA_TIMEOUT_L3PROTO] || !cda[CTA_TIMEOUT_L4PROTO])\n+\tif (!cda[CTA_TIMEOUT_L3PROTO] || nla_len(cda[CTA_TIMEOUT_L3PROTO]) != sizeof(__u16) ||\n+    !cda[CTA_TIMEOUT_L4PROTO] || nla_len(cda[CTA_TIMEOUT_L4PROTO]) != sizeof(__u8))\n \t\treturn -EINVAL;\n \n \tl3num = ntohs(nla_get_be16(cda[CTA_TIMEOUT_L3PROTO]));\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netfilter/nfnetlink_cttimeout.c b/net/netfilter/nfnetlink_cttimeout.c\nindex a518eb162344..2d6b022e4b88 100644\n--- a/net/netfilter/nfnetlink_cttimeout.c\n+++ b/net/netfilter/nfnetlink_cttimeout.c\n@@ -476,6 +476,7 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \t\tbreak;\n \tdefault:\n \t\tWARN_ON_ONCE(1);\n+return -EINVAL;\n \t\tbreak;\n \t}\n \n",
            "diff --git a/net/netfilter/nfnetlink_cttimeout.c b/net/netfilter/nfnetlink_cttimeout.c\nindex a518eb162344..a1398edd4080 100644\n--- a/net/netfilter/nfnetlink_cttimeout.c\n+++ b/net/netfilter/nfnetlink_cttimeout.c\n@@ -475,7 +475,8 @@ 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\tpr_err(\"Unsupported protocol: %u\\n\", l4proto->l4proto);\n+        WARN_ON_ONCE(1);\n \t\tbreak;\n \t}\n \n"
        ],
        "error": []
    },
    "e2fdad19640cdf94dec600b3c67260b6095e5f7d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 4eae088046d0..a2487fec2c3d 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -138,7 +138,9 @@ static __cold void __io_uring_show_fdinfo(struct io_ring_ctx *ctx,\n \t */\n \thas_lock = mutex_trylock(&ctx->uring_lock);\n \n-\tif (has_lock && (ctx->flags & IORING_SETUP_SQPOLL)) {\n+\tif (!has_lock) return;\n+\n+    if (ctx->flags & IORING_SETUP_SQPOLL) {\n \t\tsq = ctx->sq_data;\n \t\tif (!sq->thread)\n \t\t\tsq = NULL;\n",
            "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 4eae088046d0..f89ea711000b 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 (percpu_ref_tryget(&ctx->refs) && ctx->rings) {\n \t\t__io_uring_show_fdinfo(ctx, m);\n \t\tpercpu_ref_put(&ctx->refs);\n \t}\n"
        ],
        "error": [
            {
                "patch": "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 4eae088046d0..d72a0b1a5213 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 (if (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",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 4eae088046d0..028418edc036 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -202,7 +202,8 @@ __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 (!percpu_ref_tryget(&ctx->refs))\n+return;\n \t\t__io_uring_show_fdinfo(ctx, m);\n \t\tpercpu_ref_put(&ctx->refs);\n \t}\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..f237f55fd7e8 100644\n--- a/fs/f2fs/f2fs.h\n+++ b/fs/f2fs/f2fs.h\n@@ -3272,7 +3272,9 @@ 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+\tint index = extra_size + DEF_INLINE_RESERVED_SIZE;\n+    if (index >= 923) return NULL;  // Add boundary check\n+    return (void *)&(ri->i_addr[index]);\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..0f8e571b199f 100644\n--- a/fs/f2fs/f2fs.h\n+++ b/fs/f2fs/f2fs.h\n@@ -3272,7 +3272,8 @@ 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) return NULL;\n+    return (void *)&(ri->i_addr[extra_size + DEF_INLINE_RESERVED_SIZE]);\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..8e82ccae33dd 100644\n--- a/fs/f2fs/f2fs.h\n+++ b/fs/f2fs/f2fs.h\n@@ -3272,7 +3272,8 @@ 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)) return NULL;\n+    return (void *)&(ri->i_addr[extra_size + DEF_INLINE_RESERVED_SIZE]);\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..770864d0d6b6 100644\n--- a/fs/f2fs/f2fs.h\n+++ b/fs/f2fs/f2fs.h\n@@ -3272,7 +3272,9 @@ 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+        return NULL;\n+    return (void *)&(ri->i_addr[extra_size + DEF_INLINE_RESERVED_SIZE]);\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..b89daa33f676 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+\tint index = extra_size + DEF_INLINE_RESERVED_SIZE;\n+    if (index >= 923) {\n+        pr_err(\"inline_data_addr: index out of bounds\\n\");\n+        return NULL;\n+    }\n+    return (void *)&(ri->i_addr[index]);\n }\n \n static inline int f2fs_has_inline_dentry(struct inode *inode)\n"
        ],
        "error": []
    },
    "e8fc405587520f9442d64d47321fd53cef0f9bde": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/block/zram/zram_drv.c b/drivers/block/zram/zram_drv.c\nindex f6d90f1ba5cf..90e3428e25ff 100644\n--- a/drivers/block/zram/zram_drv.c\n+++ b/drivers/block/zram/zram_drv.c\n@@ -64,7 +64,8 @@ static int zram_slot_trylock(struct zram *zram, u32 index)\n \n static void zram_slot_lock(struct zram *zram, u32 index)\n {\n-\tbit_spin_lock(ZRAM_LOCK, &zram->table[index].flags);\n+\tif (index >= zram->disksize >> PAGE_SHIFT) return;\n+    bit_spin_lock(ZRAM_LOCK, &zram->table[index].flags);\n }\n \n static void zram_slot_unlock(struct zram *zram, u32 index)\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/block/zram/zram_drv.c b/drivers/block/zram/zram_drv.c\nindex f6d90f1ba5cf..bed6137e90f4 100644\n--- a/drivers/block/zram/zram_drv.c\n+++ b/drivers/block/zram/zram_drv.c\n@@ -290,7 +290,8 @@ 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 >= 0 && index < nr_pages && init_done(zram)) {\n+zram_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@@ -662,7 +663,8 @@ static ssize_t writeback_store(struct device *dev,\n \t\t\t}\n \t\t}\n \n-\t\tzram_slot_lock(zram, index);\n+\t\tif (index >= 0 && index < nr_pages && init_done(zram)) {\n+zram_slot_lock(zram, index);\n \t\tif (!zram_allocated(zram, index))\n \t\t\tgoto next;\n \n@@ -690,7 +692,8 @@ static ssize_t writeback_store(struct device *dev,\n \t\tzram_set_flag(zram, index, ZRAM_IDLE);\n \t\tzram_slot_unlock(zram, index);\n \t\tif (zram_read_page(zram, page, index, NULL)) {\n-\t\t\tzram_slot_lock(zram, index);\n+\t\t\tif (index >= 0 && index < nr_pages && init_done(zram)) {\n+zram_slot_lock(zram, index);\n \t\t\tzram_clear_flag(zram, index, ZRAM_UNDER_WB);\n \t\t\tzram_clear_flag(zram, index, ZRAM_IDLE);\n \t\t\tzram_slot_unlock(zram, index);\n@@ -708,7 +711,8 @@ static ssize_t writeback_store(struct device *dev,\n \t\t */\n \t\terr = submit_bio_wait(&bio);\n \t\tif (err) {\n-\t\t\tzram_slot_lock(zram, index);\n+\t\t\tif (index >= 0 && index < nr_pages && init_done(zram)) {\n+zram_slot_lock(zram, index);\n \t\t\tzram_clear_flag(zram, index, ZRAM_UNDER_WB);\n \t\t\tzram_clear_flag(zram, index, ZRAM_IDLE);\n \t\t\tzram_slot_unlock(zram, index);\n@@ -734,7 +738,8 @@ static ssize_t writeback_store(struct device *dev,\n \t\t * mark ZRAM_IDLE once it found the slot was ZRAM_UNDER_WB.\n \t\t * Thus, we could close the race by checking ZRAM_IDLE bit.\n \t\t */\n-\t\tzram_slot_lock(zram, index);\n+\t\tif (index >= 0 && index < nr_pages && init_done(zram)) {\n+zram_slot_lock(zram, index);\n \t\tif (!zram_allocated(zram, index) ||\n \t\t\t  !zram_test_flag(zram, index, ZRAM_IDLE)) {\n \t\t\tzram_clear_flag(zram, index, ZRAM_UNDER_WB);\n@@ -873,7 +878,8 @@ static ssize_t read_block_state(struct file *file, char __user *buf,\n \tfor (index = *ppos; index < nr_pages; index++) {\n \t\tint copied;\n \n-\t\tzram_slot_lock(zram, index);\n+\t\tif (index >= 0 && index < nr_pages && init_done(zram)) {\n+zram_slot_lock(zram, index);\n \t\tif (!zram_allocated(zram, index))\n \t\t\tgoto next;\n \n@@ -1359,7 +1365,8 @@ 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 (index >= 0 && index < nr_pages && init_done(zram)) {\n+zram_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@@ -1511,7 +1518,8 @@ static int zram_write_page(struct zram *zram, struct page *page, u32 index)\n \t * Free memory associated with this sector\n \t * before overwriting unused sectors.\n \t */\n-\tzram_slot_lock(zram, index);\n+\tif (index >= 0 && index < nr_pages && init_done(zram)) {\n+zram_slot_lock(zram, index);\n \tzram_free_page(zram, index);\n \n \tif (comp_len == PAGE_SIZE) {\n@@ -1792,7 +1800,8 @@ static ssize_t recompress_store(struct device *dev,\n \tfor (index = 0; index < nr_pages; index++) {\n \t\tint err = 0;\n \n-\t\tzram_slot_lock(zram, index);\n+\t\tif (index >= 0 && index < nr_pages && init_done(zram)) {\n+zram_slot_lock(zram, index);\n \n \t\tif (!zram_allocated(zram, index))\n \t\t\tgoto next;\n@@ -1857,7 +1866,8 @@ static void zram_bio_discard(struct zram *zram, struct bio *bio)\n \t}\n \n \twhile (n >= PAGE_SIZE) {\n-\t\tzram_slot_lock(zram, index);\n+\t\tif (index >= 0 && index < nr_pages && init_done(zram)) {\n+zram_slot_lock(zram, index);\n \t\tzram_free_page(zram, index);\n \t\tzram_slot_unlock(zram, index);\n \t\tatomic64_inc(&zram->stats.notify_free);\n@@ -1887,7 +1897,8 @@ static void zram_bio_read(struct zram *zram, struct bio *bio)\n \t\t}\n \t\tflush_dcache_page(bv.bv_page);\n \n-\t\tzram_slot_lock(zram, index);\n+\t\tif (index >= 0 && index < nr_pages && init_done(zram)) {\n+zram_slot_lock(zram, index);\n \t\tzram_accessed(zram, index);\n \t\tzram_slot_unlock(zram, index);\n \t}\n@@ -1913,7 +1924,8 @@ static void zram_bio_write(struct zram *zram, struct bio *bio)\n \t\t\tbreak;\n \t\t}\n \n-\t\tzram_slot_lock(zram, index);\n+\t\tif (index >= 0 && index < nr_pages && init_done(zram)) {\n+zram_slot_lock(zram, index);\n \t\tzram_accessed(zram, index);\n \t\tzram_slot_unlock(zram, index);\n \t}\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..85ba3cc67130 100644\n--- a/drivers/block/zram/zram_drv.c\n+++ b/drivers/block/zram/zram_drv.c\n@@ -63,6 +63,13 @@ static int zram_slot_trylock(struct zram *zram, u32 index)\n }\n \n static void zram_slot_lock(struct zram *zram, u32 index)\n+{\n+    if (!zram || index >= zram->table_size) {\n+        pr_err(\"Invalid zram or index out of bounds\\n\");\n+        return;\n+    }\n+    bit_spin_lock(ZRAM_LOCK, &zram->table[index].flags);\n+}\n {\n \tbit_spin_lock(ZRAM_LOCK, &zram->table[index].flags);\n }\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..2d0b0ceb74b6 100644\n--- a/drivers/block/zram/zram_drv.c\n+++ b/drivers/block/zram/zram_drv.c\n@@ -286,6 +286,9 @@ static void mark_idle(struct zram *zram, ktime_t cutoff)\n \tint index;\n \n \tfor (index = 0; index < nr_pages; index++) {\n+if (index >= zram->table_size) {\n+continue;\n+}\n \t\t/*\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@@ -1790,6 +1793,9 @@ static ssize_t recompress_store(struct device *dev,\n \n \tret = len;\n \tfor (index = 0; index < nr_pages; index++) {\n+if (index >= zram->table_size) {\n+continue;\n+}\n \t\tint err = 0;\n \n \t\tzram_slot_lock(zram, index);\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..9c070d230407 100644\n--- a/drivers/block/zram/zram_drv.c\n+++ b/drivers/block/zram/zram_drv.c\n@@ -290,7 +290,8 @@ 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 < nr_pages) {\n+zram_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@@ -662,7 +663,8 @@ static ssize_t writeback_store(struct device *dev,\n \t\t\t}\n \t\t}\n \n-\t\tzram_slot_lock(zram, index);\n+\t\tif (index < nr_pages) {\n+zram_slot_lock(zram, index);\n \t\tif (!zram_allocated(zram, index))\n \t\t\tgoto next;\n \n@@ -690,7 +692,8 @@ static ssize_t writeback_store(struct device *dev,\n \t\tzram_set_flag(zram, index, ZRAM_IDLE);\n \t\tzram_slot_unlock(zram, index);\n \t\tif (zram_read_page(zram, page, index, NULL)) {\n-\t\t\tzram_slot_lock(zram, index);\n+\t\t\tif (index < nr_pages) {\n+zram_slot_lock(zram, index);\n \t\t\tzram_clear_flag(zram, index, ZRAM_UNDER_WB);\n \t\t\tzram_clear_flag(zram, index, ZRAM_IDLE);\n \t\t\tzram_slot_unlock(zram, index);\n@@ -708,7 +711,8 @@ static ssize_t writeback_store(struct device *dev,\n \t\t */\n \t\terr = submit_bio_wait(&bio);\n \t\tif (err) {\n-\t\t\tzram_slot_lock(zram, index);\n+\t\t\tif (index < nr_pages) {\n+zram_slot_lock(zram, index);\n \t\t\tzram_clear_flag(zram, index, ZRAM_UNDER_WB);\n \t\t\tzram_clear_flag(zram, index, ZRAM_IDLE);\n \t\t\tzram_slot_unlock(zram, index);\n@@ -734,7 +738,8 @@ static ssize_t writeback_store(struct device *dev,\n \t\t * mark ZRAM_IDLE once it found the slot was ZRAM_UNDER_WB.\n \t\t * Thus, we could close the race by checking ZRAM_IDLE bit.\n \t\t */\n-\t\tzram_slot_lock(zram, index);\n+\t\tif (index < nr_pages) {\n+zram_slot_lock(zram, index);\n \t\tif (!zram_allocated(zram, index) ||\n \t\t\t  !zram_test_flag(zram, index, ZRAM_IDLE)) {\n \t\t\tzram_clear_flag(zram, index, ZRAM_UNDER_WB);\n@@ -873,7 +878,8 @@ static ssize_t read_block_state(struct file *file, char __user *buf,\n \tfor (index = *ppos; index < nr_pages; index++) {\n \t\tint copied;\n \n-\t\tzram_slot_lock(zram, index);\n+\t\tif (index < nr_pages) {\n+zram_slot_lock(zram, index);\n \t\tif (!zram_allocated(zram, index))\n \t\t\tgoto next;\n \n@@ -1359,7 +1365,8 @@ 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 (index < nr_pages) {\n+zram_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@@ -1511,7 +1518,8 @@ static int zram_write_page(struct zram *zram, struct page *page, u32 index)\n \t * Free memory associated with this sector\n \t * before overwriting unused sectors.\n \t */\n-\tzram_slot_lock(zram, index);\n+\tif (index < nr_pages) {\n+zram_slot_lock(zram, index);\n \tzram_free_page(zram, index);\n \n \tif (comp_len == PAGE_SIZE) {\n@@ -1792,7 +1800,8 @@ static ssize_t recompress_store(struct device *dev,\n \tfor (index = 0; index < nr_pages; index++) {\n \t\tint err = 0;\n \n-\t\tzram_slot_lock(zram, index);\n+\t\tif (index < nr_pages) {\n+zram_slot_lock(zram, index);\n \n \t\tif (!zram_allocated(zram, index))\n \t\t\tgoto next;\n@@ -1857,7 +1866,8 @@ static void zram_bio_discard(struct zram *zram, struct bio *bio)\n \t}\n \n \twhile (n >= PAGE_SIZE) {\n-\t\tzram_slot_lock(zram, index);\n+\t\tif (index < nr_pages) {\n+zram_slot_lock(zram, index);\n \t\tzram_free_page(zram, index);\n \t\tzram_slot_unlock(zram, index);\n \t\tatomic64_inc(&zram->stats.notify_free);\n@@ -1887,7 +1897,8 @@ static void zram_bio_read(struct zram *zram, struct bio *bio)\n \t\t}\n \t\tflush_dcache_page(bv.bv_page);\n \n-\t\tzram_slot_lock(zram, index);\n+\t\tif (index < nr_pages) {\n+zram_slot_lock(zram, index);\n \t\tzram_accessed(zram, index);\n \t\tzram_slot_unlock(zram, index);\n \t}\n@@ -1913,7 +1924,8 @@ static void zram_bio_write(struct zram *zram, struct bio *bio)\n \t\t\tbreak;\n \t\t}\n \n-\t\tzram_slot_lock(zram, index);\n+\t\tif (index < nr_pages) {\n+zram_slot_lock(zram, index);\n \t\tzram_accessed(zram, index);\n \t\tzram_slot_unlock(zram, index);\n \t}\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "fe36c362e30b849dad0ab99e2d1f09b82fc72883": {
        "non_crash": [
            "diff --git a/net/sched/act_pedit.c b/net/sched/act_pedit.c\nindex fb93d4c1faca..7aa68bcd8570 100644\n--- a/net/sched/act_pedit.c\n+++ b/net/sched/act_pedit.c\n@@ -292,6 +292,7 @@ static int tcf_pedit_init(struct net *net, struct nlattr *nla,\n \treturn ret;\n \n put_chain:\n+    kfree(nparms->tcfp_keys);\n \tif (goto_ch)\n \t\ttcf_chain_put_by_act(goto_ch);\n out_free_ex:\n",
            "diff --git a/net/sched/act_pedit.c b/net/sched/act_pedit.c\nindex fb93d4c1faca..94db0a9de551 100644\n--- a/net/sched/act_pedit.c\n+++ b/net/sched/act_pedit.c\n@@ -295,6 +295,7 @@ static int tcf_pedit_init(struct net *net, struct nlattr *nla,\n \tif (goto_ch)\n \t\ttcf_chain_put_by_act(goto_ch);\n out_free_ex:\n+    kfree(nparms->tcfp_keys);\n \tkfree(nparms->tcfp_keys_ex);\n out_free:\n \tkfree(nparms);\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/sched/act_api.c b/net/sched/act_api.c\nindex f7887f42d542..c6c6d2f98d4f 100644\n--- a/net/sched/act_api.c\n+++ b/net/sched/act_api.c\n@@ -922,6 +922,9 @@ static int tcf_pernet_add_id_list(unsigned int id)\n \tlist_add_tail(&id_ptr->list, &act_pernet_id_list);\n \n err_out:\n+    if (a) {\n+        tcf_idr_release(a, false);\n+    }\n \tmutex_unlock(&act_id_mutex);\n \treturn ret;\n }\n@@ -977,6 +980,9 @@ int tcf_register_action(struct tc_action_ops *act,\n \treturn 0;\n \n err_out:\n+    if (a) {\n+        tcf_idr_release(a, false);\n+    }\n \twrite_unlock(&act_mod_lock);\n \tif (ops->id)\n \t\ttcf_pernet_del_id_list(*ops->id);\n@@ -1410,6 +1416,9 @@ struct tc_action *tcf_action_init_1(struct net *net, struct tcf_proto *tp,\n \treturn a;\n \n err_out:\n+    if (a) {\n+        tcf_idr_release(a, false);\n+    }\n \tif (user_cookie) {\n \t\tkfree(user_cookie->data);\n \t\tkfree(user_cookie);\n@@ -1672,6 +1681,9 @@ static struct tc_action *tcf_action_get_1(struct net *net, struct nlattr *nla,\n err_mod:\n \tmodule_put(ops->owner);\n err_out:\n+    if (a) {\n+        tcf_idr_release(a, false);\n+    }\n \treturn ERR_PTR(err);\n }\n \n@@ -1747,6 +1759,9 @@ static int tca_action_flush(struct net *net, struct nlattr *nla,\n out_module_put:\n \tmodule_put(ops->owner);\n err_out:\n+    if (a) {\n+        tcf_idr_release(a, false);\n+    }\n \tkfree_skb(skb);\n \treturn err;\n }\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/sched/act_pedit.c b/net/sched/act_pedit.c\nindex fb93d4c1faca..6c924519993e 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_cleanup;\n \t}\n \n \terr = tcf_action_check_ctrlact(parm->action, tp, &goto_ch, extack);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "5d48b50ed679f22d7d4a4b578da8559d34b104ac": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/lib/percpu-refcount.c b/lib/percpu-refcount.c\nindex af9302141bcf..168f33b5b038 100644\n--- a/lib/percpu-refcount.c\n+++ b/lib/percpu-refcount.c\n@@ -213,6 +213,10 @@ static void __percpu_ref_switch_to_atomic(struct percpu_ref *ref,\n \t\t\t\t\t  percpu_ref_func_t *confirm_switch)\n {\n \tif (ref->percpu_count_ptr & __PERCPU_REF_ATOMIC) {\n+        if (!percpu_count_ptr(ref)) {\n+            pr_err(\"Invalid percpu_count_ptr state during transition\");\n+            return;\n+        }\n \t\tif (confirm_switch)\n \t\t\tconfirm_switch(ref);\n \t\treturn;\n",
            "diff --git a/kernel/bpf/cgroup.c b/kernel/bpf/cgroup.c\nindex 03145d45e3d5..fca059c2abfd 100644\n--- a/kernel/bpf/cgroup.c\n+++ b/kernel/bpf/cgroup.c\n@@ -25,7 +25,8 @@ EXPORT_SYMBOL(cgroup_bpf_enabled_key);\n void cgroup_bpf_offline(struct cgroup *cgrp)\n {\n \tcgroup_get(cgrp);\n-\tpercpu_ref_kill(&cgrp->bpf.refcnt);\n+\tif (!percpu_ref_is_zero(&cgrp->bpf.refcnt))\n+percpu_ref_kill(&cgrp->bpf.refcnt);\n }\n \n static void bpf_cgroup_storages_free(struct bpf_cgroup_storage *storages[])\n",
            "diff --git a/lib/percpu-refcount.c b/lib/percpu-refcount.c\nindex af9302141bcf..27660564d984 100644\n--- a/lib/percpu-refcount.c\n+++ b/lib/percpu-refcount.c\n@@ -237,7 +237,11 @@ static void __percpu_ref_switch_to_percpu(struct percpu_ref *ref)\n \tunsigned long __percpu *percpu_count = percpu_count_ptr(ref);\n \tint cpu;\n \n-\tBUG_ON(!percpu_count);\n+\tif (!percpu_count) {\n+        pr_err(\"Invalid percpu_count_ptr detected during transition\\n\");\n+        return;\n+    }\n+    BUG_ON(!percpu_count);\n \n \tif (!(ref->percpu_count_ptr & __PERCPU_REF_ATOMIC))\n \t\treturn;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/kernel/cgroup/cgroup.c b/kernel/cgroup/cgroup.c\nindex 8afa8690d288..aca41d43542f 100644\n--- a/kernel/cgroup/cgroup.c\n+++ b/kernel/cgroup/cgroup.c\n@@ -5160,6 +5160,7 @@ static void init_and_link_css(struct cgroup_subsys_state *css,\n \tcgroup_get_live(cgrp);\n \n \tmemset(css, 0, sizeof(*css));\n+    if (!css || !ss || !cgrp) return;\n \tcss->cgroup = cgrp;\n \tcss->ss = ss;\n \tcss->id = -1;\n",
                "error_message": "ssh failed"
            }
        ]
    },
    "f9cfa5c5564ffc453258d835293bf6e9881c5b1c": {
        "non_crash": [
            "diff --git a/net/sctp/stream_sched_rr.c b/net/sctp/stream_sched_rr.c\nindex 52ba743fa7a7..5857bd1a877a 100644\n--- a/net/sctp/stream_sched_rr.c\n+++ b/net/sctp/stream_sched_rr.c\n@@ -138,6 +138,8 @@ 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+    if (!soute || list_empty(&soute->outq))\n+        goto out;;\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..4723a10fc14e 100644\n--- a/net/sctp/stream_sched_rr.c\n+++ b/net/sctp/stream_sched_rr.c\n@@ -138,7 +138,12 @@ 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+        ch = list_entry(soute->outq.next, struct sctp_chunk, stream_list);\n+    }\n+    else {\n+        goto out;\n+    }\n \n \tsctp_sched_dequeue_common(q, ch);\n \n",
            "diff --git a/net/sctp/stream_sched_rr.c b/net/sctp/stream_sched_rr.c\nindex 52ba743fa7a7..4b929653a494 100644\n--- a/net/sctp/stream_sched_rr.c\n+++ b/net/sctp/stream_sched_rr.c\n@@ -138,6 +138,8 @@ 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+if (!soute)\n+goto out;\n \tch = list_entry(soute->outq.next, struct sctp_chunk, stream_list);\n \n \tsctp_sched_dequeue_common(q, ch);\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/sctp/stream_sched_rr.c b/net/sctp/stream_sched_rr.c\nindex 52ba743fa7a7..647e8a4b218c 100644\n--- a/net/sctp/stream_sched_rr.c\n+++ b/net/sctp/stream_sched_rr.c\n@@ -138,7 +138,9 @@ 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+        ch = list_entry(soute->outq.next, struct sctp_chunk, stream_list);\n+    }\n \n \tsctp_sched_dequeue_common(q, ch);\n \n",
            "diff --git a/net/sctp/stream_sched_rr.c b/net/sctp/stream_sched_rr.c\nindex 52ba743fa7a7..9d3be6e73c4c 100644\n--- a/net/sctp/stream_sched_rr.c\n+++ b/net/sctp/stream_sched_rr.c\n@@ -138,7 +138,8 @@ 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+        ch = list_entry(soute->outq.next, struct sctp_chunk, stream_list);\n \n \tsctp_sched_dequeue_common(q, ch);\n \n"
        ],
        "error": []
    },
    "5eb8a5d29d77f8a364cf3270bf9625eb4d4ffc52": {
        "non_crash": [
            "diff --git a/fs/jfs/jfs_dmap.c b/fs/jfs/jfs_dmap.c\nindex 765838578a72..70e35c39b09b 100644\n--- a/fs/jfs/jfs_dmap.c\n+++ b/fs/jfs/jfs_dmap.c\n@@ -198,7 +198,12 @@ 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_agl2size > L2MAXL2SIZE) {\n+        err = -EINVAL;\n+        goto err_release_metapage;\n+    }\n+\n+    if (((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..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..64f5567c5e64 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_agl2size >= sizeof(bmp->db_mapsize) * 8 || ((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"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "01383b29d139cf9c9f9d9bd6e9947474ffe657a6": {
        "non_crash": [
            "diff --git a/mm/gup.c b/mm/gup.c\nindex ef29641671c7..928094804636 100644\n--- a/mm/gup.c\n+++ b/mm/gup.c\n@@ -1170,7 +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\tif (vma->vm_flags & VM_GROWSDOWN) {\n+                    start = vma->vm_start;\n+                }\n \t\t\t\tvma = NULL;\n \t\t\t}\n \t\t\tif (!vma && in_gate_area(mm, start)) {\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/gup.c b/mm/gup.c\nindex ef29641671c7..093d5d5cd995 100644\n--- a/mm/gup.c\n+++ b/mm/gup.c\n@@ -1341,7 +1341,7 @@ int fixup_user_fault(struct mm_struct *mm,\n \tif (!vma)\n \t\treturn -EFAULT;\n \tif (address < vma->vm_start ) {\n-\t\tWARN_ON_ONCE(vma->vm_flags & VM_GROWSDOWN);\n+\t\tif (vma->vm_flags & VM_GROWSDOWN) return -EFAULT;\n \t\treturn -EFAULT;\n \t}\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/mm/gup.c b/mm/gup.c\nindex ef29641671c7..6d17cc6e6deb 100644\n--- a/mm/gup.c\n+++ b/mm/gup.c\n@@ -1170,7 +1170,11 @@ 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\tif (vma->vm_flags & VM_GROWSDOWN) {\n+    if (address < vma->vm_start) {\n+        return -EFAULT;\n+    }\n+}\n \t\t\t\tvma = NULL;\n \t\t\t}\n \t\t\tif (!vma && in_gate_area(mm, start)) {\n@@ -1341,7 +1345,11 @@ int fixup_user_fault(struct mm_struct *mm,\n \tif (!vma)\n \t\treturn -EFAULT;\n \tif (address < vma->vm_start ) {\n-\t\tWARN_ON_ONCE(vma->vm_flags & VM_GROWSDOWN);\n+\t\tif (vma->vm_flags & VM_GROWSDOWN) {\n+    if (address < vma->vm_start) {\n+        return -EFAULT;\n+    }\n+}\n \t\treturn -EFAULT;\n \t}\n \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..663c36a370cc 100644\n--- a/net/smc/af_smc.c\n+++ b/net/smc/af_smc.c\n@@ -3102,6 +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+kfree(smc);\n \t\t\tgoto out;\n \t\t}\n \t} else {\n",
            "diff --git a/net/smc/af_smc.c b/net/smc/af_smc.c\nindex 14ddc40149e8..663c36a370cc 100644\n--- a/net/smc/af_smc.c\n+++ b/net/smc/af_smc.c\n@@ -3102,6 +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+kfree(smc);\n \t\t\tgoto out;\n \t\t}\n \t} else {\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/smc/af_smc.c b/net/smc/af_smc.c\nindex 14ddc40149e8..da6520b1a05d 100644\n--- a/net/smc/af_smc.c\n+++ b/net/smc/af_smc.c\n@@ -73,7 +73,8 @@ int smc_nl_dump_hs_limitation(struct sk_buff *skb, struct netlink_callback *cb)\n \tvoid *hdr;\n \n \tif (cb_ctx->pos[0])\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \n \thdr = genlmsg_put(skb, NETLINK_CB(cb->skb).portid, cb->nlh->nlmsg_seq,\n \t\t\t  &smc_gen_nl_family, NLM_F_MULTI,\n@@ -298,7 +299,8 @@ static int smc_release(struct socket *sock)\n \tint old_state, rc = 0;\n \n \tif (!sk)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \n \tsock_hold(sk); /* sock_put below */\n \tsmc = smc_sk(sk);\n@@ -390,17 +392,20 @@ static int smc_bind(struct socket *sock, struct sockaddr *uaddr,\n \t/* replicate tests from inet_bind(), to be safe wrt. future changes */\n \trc = -EINVAL;\n \tif (addr_len < sizeof(struct sockaddr_in))\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \n \trc = -EAFNOSUPPORT;\n \tif (addr->sin_family != AF_INET &&\n \t    addr->sin_family != AF_INET6 &&\n \t    addr->sin_family != AF_UNSPEC)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \t/* accept AF_UNSPEC (mapped to AF_INET) only if s_addr is INADDR_ANY */\n \tif (addr->sin_family == AF_UNSPEC &&\n \t    addr->sin_addr.s_addr != htonl(INADDR_ANY))\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \n \tlock_sock(sk);\n \n@@ -489,14 +494,16 @@ static int smcr_lgr_reg_rmbs(struct smc_link *link,\n \t\t\tcontinue;\n \t\trc = smcr_link_reg_rmb(&lgr->lnk[i], rmb_desc);\n \t\tif (rc)\n-\t\t\tgoto out;\n+\t\t\tsk_common_release(sk);\n+goto out;\n \t}\n \n \t/* exchange confirm_rkey msg with peer */\n \trc = smc_llc_do_confirm_rkey(link, rmb_desc);\n \tif (rc) {\n \t\trc = -EFAULT;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \t}\n \trmb_desc->is_conf_rkey = true;\n out:\n@@ -731,7 +738,8 @@ static void smc_fback_forward_wakeup(struct smc_sock *smc, struct sock *clcsk,\n \trcu_read_lock();\n \twq = rcu_dereference(clcsk->sk_wq);\n \tif (!wq)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \tadd_wait_queue(sk_sleep(clcsk), &mark.wait_entry);\n \tclcsock_callback(clcsk);\n \tremove_wait_queue(sk_sleep(clcsk), &mark.wait_entry);\n@@ -790,12 +798,14 @@ static int smc_switch_to_fallback(struct smc_sock *smc, int reason_code)\n \tmutex_lock(&smc->clcsock_release_lock);\n \tif (!smc->clcsock) {\n \t\trc = -EBADF;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \t}\n \tclcsk = smc->clcsock->sk;\n \n \tif (smc->use_fallback)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \tsmc->use_fallback = true;\n \tsmc->fallback_rsn = reason_code;\n \tsmc_stat_fallback(smc);\n@@ -1068,7 +1078,8 @@ void smc_fill_gid_list(struct smc_link_group *lgr,\n \n \talt_ini = kzalloc(sizeof(*alt_ini), GFP_KERNEL);\n \tif (!alt_ini)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \n \talt_ini->vlan_id = lgr->vlan_id;\n \talt_ini->check_smcrv2 = true;\n@@ -1076,7 +1087,8 @@ void smc_fill_gid_list(struct smc_link_group *lgr,\n \tsmc_pnet_find_alt_roce(lgr, alt_ini, known_dev);\n \n \tif (!alt_ini->smcrv2.ib_dev_v2)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \n \tmemcpy(gidlist->list[gidlist->len++], alt_ini->smcrv2.ib_gid_v2,\n \t       SMC_GID_SIZE);\n@@ -1478,7 +1490,8 @@ static void smc_connect_work(struct work_struct *work)\n \t\telse if (signal_pending(current))\n \t\t\tsmc->sk.sk_err = -sock_intr_errno(timeo);\n \t\tsock_put(&smc->sk); /* passive closing */\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \t}\n \n \trc = __smc_connect(smc);\n@@ -1515,10 +1528,12 @@ static int smc_connect(struct socket *sock, struct sockaddr *addr,\n \tlock_sock(sk);\n \tswitch (sk->sk_state) {\n \tdefault:\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \tcase SMC_ACTIVE:\n \t\trc = -EISCONN;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \tcase SMC_INIT:\n \t\tbreak;\n \t}\n@@ -1527,15 +1542,18 @@ static int smc_connect(struct socket *sock, struct sockaddr *addr,\n \ttcp_sk(smc->clcsock->sk)->syn_smc = 1;\n \tif (smc->connect_nonblock) {\n \t\trc = -EALREADY;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \t}\n \trc = kernel_connect(smc->clcsock, addr, alen, flags);\n \tif (rc && rc != -EINPROGRESS)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \n \tsock_hold(&smc->sk); /* sock put in passive closing */\n \tif (smc->use_fallback)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \tif (flags & O_NONBLOCK) {\n \t\tif (queue_work(smc_hs_wq, &smc->connect_work))\n \t\t\tsmc->connect_nonblock = 1;\n@@ -1543,7 +1561,8 @@ static int smc_connect(struct socket *sock, struct sockaddr *addr,\n \t} else {\n \t\trc = __smc_connect(smc);\n \t\tif (rc < 0)\n-\t\t\tgoto out;\n+\t\t\tsk_common_release(sk);\n+goto out;\n \t\telse\n \t\t\trc = 0; /* success cases including fallback */\n \t}\n@@ -1568,7 +1587,8 @@ static int smc_clcsock_accept(struct smc_sock *lsmc, struct smc_sock **new_smc)\n \t\tlsk->sk_err = ENOMEM;\n \t\t*new_smc = NULL;\n \t\tlock_sock(lsk);\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \t}\n \t*new_smc = smc_sk(new_sk);\n \n@@ -1587,7 +1607,8 @@ static int smc_clcsock_accept(struct smc_sock *lsmc, struct smc_sock **new_smc)\n \t\tsock_set_flag(new_sk, SOCK_DEAD);\n \t\tsock_put(new_sk); /* final */\n \t\t*new_smc = NULL;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \t}\n \n \t/* new clcsock has inherited the smc listen-specific sk_data_ready\n@@ -1806,14 +1827,16 @@ static int smc_listen_v2_check(struct smc_sock *new_smc,\n \t}\n \tif (!(ini->smcd_version & SMC_V2) && !(ini->smcr_version & SMC_V2)) {\n \t\trc = SMC_CLC_DECL_PEERNOSMC;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \t}\n \tpclc_v2_ext = smc_get_clc_v2_ext(pclc);\n \tif (!pclc_v2_ext) {\n \t\tini->smcd_version &= ~SMC_V2;\n \t\tini->smcr_version &= ~SMC_V2;\n \t\trc = SMC_CLC_DECL_NOV2EXT;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \t}\n \tpclc_smcd_v2_ext = smc_get_clc_smcd_v2_ext(pclc_v2_ext);\n \tif (ini->smcd_version & SMC_V2) {\n@@ -2326,7 +2349,8 @@ static void smc_tcp_listen_work(struct work_struct *work)\n \twhile (lsk->sk_state == SMC_LISTEN) {\n \t\trc = smc_clcsock_accept(lsmc, &new_smc);\n \t\tif (rc) /* clcsock accept queue empty or error */\n-\t\t\tgoto out;\n+\t\t\tsk_common_release(sk);\n+goto out;\n \t\tif (!new_smc)\n \t\t\tcontinue;\n \n@@ -2378,12 +2402,14 @@ static int smc_listen(struct socket *sock, int backlog)\n \trc = -EINVAL;\n \tif ((sk->sk_state != SMC_INIT && sk->sk_state != SMC_LISTEN) ||\n \t    smc->connect_nonblock)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \n \trc = 0;\n \tif (sk->sk_state == SMC_LISTEN) {\n \t\tsk->sk_max_ack_backlog = backlog;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \t}\n \t/* some socket options are handled in core, so we could not apply\n \t * them to the clc socket -- copy smc socket options to clc socket\n@@ -2414,7 +2440,8 @@ static int smc_listen(struct socket *sock, int backlog)\n \trc = kernel_listen(smc->clcsock, backlog);\n \tif (rc) {\n \t\tsmc->clcsock->sk->sk_data_ready = smc->clcsk_data_ready;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \t}\n \tsk->sk_max_ack_backlog = backlog;\n \tsk->sk_ack_backlog = 0;\n@@ -2441,7 +2468,8 @@ static int smc_accept(struct socket *sock, struct socket *new_sock,\n \tif (lsmc->sk.sk_state != SMC_LISTEN) {\n \t\trc = -EINVAL;\n \t\trelease_sock(sk);\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \t}\n \n \t/* Wait for an incoming connection */\n@@ -2470,7 +2498,8 @@ static int smc_accept(struct socket *sock, struct socket *new_sock,\n \t\trc = sock_error(nsk);\n \trelease_sock(sk);\n \tif (rc)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \n \tif (lsmc->sockopt_defer_accept && !(flags & O_NONBLOCK)) {\n \t\t/* wait till data arrives on the socket */\n@@ -2520,16 +2549,19 @@ static int smc_sendmsg(struct socket *sock, struct msghdr *msg, size_t len)\n \tif ((sk->sk_state != SMC_ACTIVE) &&\n \t    (sk->sk_state != SMC_APPCLOSEWAIT1) &&\n \t    (sk->sk_state != SMC_INIT))\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \n \tif (msg->msg_flags & MSG_FASTOPEN) {\n \t\tif (sk->sk_state == SMC_INIT && !smc->connect_nonblock) {\n \t\t\trc = smc_switch_to_fallback(smc, SMC_CLC_DECL_OPTUNSUPP);\n \t\t\tif (rc)\n-\t\t\t\tgoto out;\n+\t\t\t\tsk_common_release(sk);\n+goto out;\n \t\t} else {\n \t\t\trc = -EINVAL;\n-\t\t\tgoto out;\n+\t\t\tsk_common_release(sk);\n+goto out;\n \t\t}\n \t}\n \n@@ -2556,16 +2588,19 @@ static int smc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \tif (sk->sk_state == SMC_CLOSED && (sk->sk_shutdown & RCV_SHUTDOWN)) {\n \t\t/* socket was connected before, no more data to read */\n \t\trc = 0;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \t}\n \tif ((sk->sk_state == SMC_INIT) ||\n \t    (sk->sk_state == SMC_LISTEN) ||\n \t    (sk->sk_state == SMC_CLOSED))\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \n \tif (sk->sk_state == SMC_PEERFINCLOSEWAIT) {\n \t\trc = 0;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \t}\n \n \tif (smc->use_fallback) {\n@@ -2670,13 +2705,15 @@ static int smc_shutdown(struct socket *sock, int how)\n \t    (sk->sk_state != SMC_APPCLOSEWAIT1) &&\n \t    (sk->sk_state != SMC_APPCLOSEWAIT2) &&\n \t    (sk->sk_state != SMC_APPFINCLOSEWAIT))\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \tif (smc->use_fallback) {\n \t\trc = kernel_sock_shutdown(smc->clcsock, how);\n \t\tsk->sk_shutdown = smc->clcsock->sk->sk_shutdown;\n \t\tif (sk->sk_shutdown == SHUTDOWN_MASK)\n \t\t\tsk->sk_state = SMC_CLOSED;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \t}\n \tswitch (how) {\n \tcase SHUT_RDWR:\t\t/* shutdown in both directions */\n@@ -2809,7 +2846,8 @@ static int smc_setsockopt(struct socket *sock, int level, int optname,\n \n \tlock_sock(sk);\n \tif (rc || smc->use_fallback)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \tswitch (optname) {\n \tcase TCP_FASTOPEN:\n \tcase TCP_FASTOPEN_CONNECT:\n@@ -2974,7 +3012,8 @@ static ssize_t smc_sendpage(struct socket *sock, struct page *page,\n \tlock_sock(sk);\n \tif (sk->sk_state != SMC_ACTIVE) {\n \t\trelease_sock(sk);\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \t}\n \trelease_sock(sk);\n \tif (smc->use_fallback) {\n@@ -3010,16 +3049,19 @@ static ssize_t smc_splice_read(struct socket *sock, loff_t *ppos,\n \tif (sk->sk_state == SMC_CLOSED && (sk->sk_shutdown & RCV_SHUTDOWN)) {\n \t\t/* socket was connected before, no more data to read */\n \t\trc = 0;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \t}\n \tif (sk->sk_state == SMC_INIT ||\n \t    sk->sk_state == SMC_LISTEN ||\n \t    sk->sk_state == SMC_CLOSED)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \n \tif (sk->sk_state == SMC_PEERFINCLOSEWAIT) {\n \t\trc = 0;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \t}\n \n \tif (smc->use_fallback) {\n@@ -3028,7 +3070,8 @@ static ssize_t smc_splice_read(struct socket *sock, loff_t *ppos,\n \t} else {\n \t\tif (*ppos) {\n \t\t\trc = -ESPIPE;\n-\t\t\tgoto out;\n+\t\t\tsk_common_release(sk);\n+goto out;\n \t\t}\n \t\tif (flags & SPLICE_F_NONBLOCK)\n \t\t\tflags = MSG_DONTWAIT;\n@@ -3076,17 +3119,20 @@ static int __smc_create(struct net *net, struct socket *sock, int protocol,\n \n \trc = -ESOCKTNOSUPPORT;\n \tif (sock->type != SOCK_STREAM)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \n \trc = -EPROTONOSUPPORT;\n \tif (protocol != SMCPROTO_SMC && protocol != SMCPROTO_SMC6)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \n \trc = -ENOBUFS;\n \tsock->ops = &smc_sock_ops;\n \tsk = smc_sock_alloc(net, sock, protocol);\n \tif (!sk)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+goto out;\n \n \t/* create internal TCP socket for CLC handshake and fallback */\n \tsmc = smc_sk(sk);\n@@ -3102,7 +3148,8 @@ 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\tsk_common_release(sk);\n+goto out;\n \t\t}\n \t} else {\n \t\tsmc->clcsock = clcsock;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/smc/af_smc.c b/net/smc/af_smc.c\nindex 14ddc40149e8..17f61297bb5c 100644\n--- a/net/smc/af_smc.c\n+++ b/net/smc/af_smc.c\n@@ -88,6 +88,7 @@ int smc_nl_dump_hs_limitation(struct sk_buff *skb, struct netlink_callback *cb)\n \tgenlmsg_end(skb, hdr);\n \tcb_ctx->pos[0] = 1;\n out:\n+if (sk) sk_common_release(sk);\n \treturn skb->len;\n err:\n \tgenlmsg_cancel(skb, hdr);\n@@ -334,6 +335,7 @@ static int smc_release(struct socket *sock)\n \tsock_put(sk); /* sock_hold above */\n \tsock_put(sk); /* final sock_put */\n out:\n+if (sk) sk_common_release(sk);\n \treturn rc;\n }\n \n@@ -415,6 +417,7 @@ static int smc_bind(struct socket *sock, struct sockaddr *uaddr,\n out_rel:\n \trelease_sock(sk);\n out:\n+if (sk) sk_common_release(sk);\n \treturn rc;\n }\n \n@@ -500,6 +503,7 @@ static int smcr_lgr_reg_rmbs(struct smc_link *link,\n \t}\n \trmb_desc->is_conf_rkey = true;\n out:\n+if (sk) sk_common_release(sk);\n \tmutex_unlock(&lgr->llc_conf_mutex);\n \tsmc_llc_flow_stop(lgr, &lgr->llc_flow_lcl);\n \treturn rc;\n@@ -739,6 +743,7 @@ static void smc_fback_forward_wakeup(struct smc_sock *smc, struct sock *clcsk,\n \tif (mark.woken)\n \t\tsmc_fback_wakeup_waitqueue(smc, mark.key);\n out:\n+if (sk) sk_common_release(sk);\n \trcu_read_unlock();\n }\n \n@@ -824,6 +829,7 @@ static int smc_switch_to_fallback(struct smc_sock *smc, int reason_code)\n \t\t\t(void *)((uintptr_t)smc | SK_USER_DATA_NOCOPY);\n \t}\n out:\n+if (sk) sk_common_release(sk);\n \tmutex_unlock(&smc->clcsock_release_lock);\n \treturn rc;\n }\n@@ -1082,6 +1088,7 @@ void smc_fill_gid_list(struct smc_link_group *lgr,\n \t       SMC_GID_SIZE);\n \n out:\n+if (sk) sk_common_release(sk);\n \tkfree(alt_ini);\n }\n \n@@ -1486,6 +1493,7 @@ static void smc_connect_work(struct work_struct *work)\n \t\tsmc->sk.sk_err = -rc;\n \n out:\n+if (sk) sk_common_release(sk);\n \tif (!sock_flag(&smc->sk, SOCK_DEAD)) {\n \t\tif (smc->sk.sk_err) {\n \t\t\tsmc->sk.sk_state_change(&smc->sk);\n@@ -1549,6 +1557,7 @@ static int smc_connect(struct socket *sock, struct sockaddr *addr,\n \t}\n \n out:\n+if (sk) sk_common_release(sk);\n \trelease_sock(sk);\n out_err:\n \treturn rc;\n@@ -1596,6 +1605,7 @@ static int smc_clcsock_accept(struct smc_sock *lsmc, struct smc_sock **new_smc)\n \tnew_clcsock->sk->sk_data_ready = lsmc->clcsk_data_ready;\n \t(*new_smc)->clcsock = new_clcsock;\n out:\n+if (sk) sk_common_release(sk);\n \treturn rc;\n }\n \n@@ -1837,6 +1847,7 @@ static int smc_listen_v2_check(struct smc_sock *new_smc,\n \t}\n \n out:\n+if (sk) sk_common_release(sk);\n \tif (!ini->smcd_version && !ini->smcr_version)\n \t\treturn rc;\n \n@@ -2347,6 +2358,7 @@ static void smc_tcp_listen_work(struct work_struct *work)\n \t}\n \n out:\n+if (sk) sk_common_release(sk);\n \trelease_sock(lsk);\n \tsock_put(&lsmc->sk); /* sock_hold in smc_clcsock_data_ready() */\n }\n@@ -2421,6 +2433,7 @@ static int smc_listen(struct socket *sock, int backlog)\n \tsk->sk_state = SMC_LISTEN;\n \n out:\n+if (sk) sk_common_release(sk);\n \trelease_sock(sk);\n \treturn rc;\n }\n@@ -2491,6 +2504,7 @@ static int smc_accept(struct socket *sock, struct socket *new_sock,\n \t}\n \n out:\n+if (sk) sk_common_release(sk);\n \tsock_put(sk); /* sock_hold above */\n \treturn rc;\n }\n@@ -2540,6 +2554,7 @@ static int smc_sendmsg(struct socket *sock, struct msghdr *msg, size_t len)\n \t\tSMC_STAT_TX_PAYLOAD(smc, len, rc);\n \t}\n out:\n+if (sk) sk_common_release(sk);\n \trelease_sock(sk);\n \treturn rc;\n }\n@@ -2577,6 +2592,7 @@ static int smc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \t}\n \n out:\n+if (sk) sk_common_release(sk);\n \trelease_sock(sk);\n \treturn rc;\n }\n@@ -2700,6 +2716,7 @@ static int smc_shutdown(struct socket *sock, int how)\n \tsk->sk_shutdown |= how + 1;\n \n out:\n+if (sk) sk_common_release(sk);\n \trelease_sock(sk);\n \treturn rc ? rc : rc1;\n }\n@@ -2851,6 +2868,7 @@ static int smc_setsockopt(struct socket *sock, int level, int optname,\n \t\tbreak;\n \t}\n out:\n+if (sk) sk_common_release(sk);\n \trelease_sock(sk);\n \n \treturn rc;\n@@ -2988,6 +3006,7 @@ static ssize_t smc_sendpage(struct socket *sock, struct page *page,\n \t}\n \n out:\n+if (sk) sk_common_release(sk);\n \treturn rc;\n }\n \n@@ -3038,6 +3057,7 @@ static ssize_t smc_splice_read(struct socket *sock, loff_t *ppos,\n \t\trc = smc_rx_recvmsg(smc, NULL, pipe, len, flags);\n \t}\n out:\n+if (sk) sk_common_release(sk);\n \trelease_sock(sk);\n \n \treturn rc;\n@@ -3112,6 +3132,7 @@ static int __smc_create(struct net *net, struct socket *sock, int protocol,\n \tsmc->sk.sk_rcvbuf = max(smc->clcsock->sk->sk_rcvbuf, SMC_BUF_MIN_SIZE);\n \n out:\n+if (sk) sk_common_release(sk);\n \treturn rc;\n }\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/smc/af_smc.c b/net/smc/af_smc.c\nindex 14ddc40149e8..4f74c0f337b6 100644\n--- a/net/smc/af_smc.c\n+++ b/net/smc/af_smc.c\n@@ -73,7 +73,8 @@ int smc_nl_dump_hs_limitation(struct sk_buff *skb, struct netlink_callback *cb)\n \tvoid *hdr;\n \n \tif (cb_ctx->pos[0])\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \n \thdr = genlmsg_put(skb, NETLINK_CB(cb->skb).portid, cb->nlh->nlmsg_seq,\n \t\t\t  &smc_gen_nl_family, NLM_F_MULTI,\n@@ -298,7 +299,8 @@ static int smc_release(struct socket *sock)\n \tint old_state, rc = 0;\n \n \tif (!sk)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \n \tsock_hold(sk); /* sock_put below */\n \tsmc = smc_sk(sk);\n@@ -390,17 +392,20 @@ static int smc_bind(struct socket *sock, struct sockaddr *uaddr,\n \t/* replicate tests from inet_bind(), to be safe wrt. future changes */\n \trc = -EINVAL;\n \tif (addr_len < sizeof(struct sockaddr_in))\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \n \trc = -EAFNOSUPPORT;\n \tif (addr->sin_family != AF_INET &&\n \t    addr->sin_family != AF_INET6 &&\n \t    addr->sin_family != AF_UNSPEC)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \t/* accept AF_UNSPEC (mapped to AF_INET) only if s_addr is INADDR_ANY */\n \tif (addr->sin_family == AF_UNSPEC &&\n \t    addr->sin_addr.s_addr != htonl(INADDR_ANY))\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \n \tlock_sock(sk);\n \n@@ -489,14 +494,16 @@ static int smcr_lgr_reg_rmbs(struct smc_link *link,\n \t\t\tcontinue;\n \t\trc = smcr_link_reg_rmb(&lgr->lnk[i], rmb_desc);\n \t\tif (rc)\n-\t\t\tgoto out;\n+\t\t\tsk_common_release(sk);\n+    goto out;\n \t}\n \n \t/* exchange confirm_rkey msg with peer */\n \trc = smc_llc_do_confirm_rkey(link, rmb_desc);\n \tif (rc) {\n \t\trc = -EFAULT;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \t}\n \trmb_desc->is_conf_rkey = true;\n out:\n@@ -731,7 +738,8 @@ static void smc_fback_forward_wakeup(struct smc_sock *smc, struct sock *clcsk,\n \trcu_read_lock();\n \twq = rcu_dereference(clcsk->sk_wq);\n \tif (!wq)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \tadd_wait_queue(sk_sleep(clcsk), &mark.wait_entry);\n \tclcsock_callback(clcsk);\n \tremove_wait_queue(sk_sleep(clcsk), &mark.wait_entry);\n@@ -790,12 +798,14 @@ static int smc_switch_to_fallback(struct smc_sock *smc, int reason_code)\n \tmutex_lock(&smc->clcsock_release_lock);\n \tif (!smc->clcsock) {\n \t\trc = -EBADF;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \t}\n \tclcsk = smc->clcsock->sk;\n \n \tif (smc->use_fallback)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \tsmc->use_fallback = true;\n \tsmc->fallback_rsn = reason_code;\n \tsmc_stat_fallback(smc);\n@@ -1068,7 +1078,8 @@ void smc_fill_gid_list(struct smc_link_group *lgr,\n \n \talt_ini = kzalloc(sizeof(*alt_ini), GFP_KERNEL);\n \tif (!alt_ini)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \n \talt_ini->vlan_id = lgr->vlan_id;\n \talt_ini->check_smcrv2 = true;\n@@ -1076,7 +1087,8 @@ void smc_fill_gid_list(struct smc_link_group *lgr,\n \tsmc_pnet_find_alt_roce(lgr, alt_ini, known_dev);\n \n \tif (!alt_ini->smcrv2.ib_dev_v2)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \n \tmemcpy(gidlist->list[gidlist->len++], alt_ini->smcrv2.ib_gid_v2,\n \t       SMC_GID_SIZE);\n@@ -1478,7 +1490,8 @@ static void smc_connect_work(struct work_struct *work)\n \t\telse if (signal_pending(current))\n \t\t\tsmc->sk.sk_err = -sock_intr_errno(timeo);\n \t\tsock_put(&smc->sk); /* passive closing */\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \t}\n \n \trc = __smc_connect(smc);\n@@ -1515,10 +1528,12 @@ static int smc_connect(struct socket *sock, struct sockaddr *addr,\n \tlock_sock(sk);\n \tswitch (sk->sk_state) {\n \tdefault:\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \tcase SMC_ACTIVE:\n \t\trc = -EISCONN;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \tcase SMC_INIT:\n \t\tbreak;\n \t}\n@@ -1527,15 +1542,18 @@ static int smc_connect(struct socket *sock, struct sockaddr *addr,\n \ttcp_sk(smc->clcsock->sk)->syn_smc = 1;\n \tif (smc->connect_nonblock) {\n \t\trc = -EALREADY;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \t}\n \trc = kernel_connect(smc->clcsock, addr, alen, flags);\n \tif (rc && rc != -EINPROGRESS)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \n \tsock_hold(&smc->sk); /* sock put in passive closing */\n \tif (smc->use_fallback)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \tif (flags & O_NONBLOCK) {\n \t\tif (queue_work(smc_hs_wq, &smc->connect_work))\n \t\t\tsmc->connect_nonblock = 1;\n@@ -1543,7 +1561,8 @@ static int smc_connect(struct socket *sock, struct sockaddr *addr,\n \t} else {\n \t\trc = __smc_connect(smc);\n \t\tif (rc < 0)\n-\t\t\tgoto out;\n+\t\t\tsk_common_release(sk);\n+    goto out;\n \t\telse\n \t\t\trc = 0; /* success cases including fallback */\n \t}\n@@ -1568,7 +1587,8 @@ static int smc_clcsock_accept(struct smc_sock *lsmc, struct smc_sock **new_smc)\n \t\tlsk->sk_err = ENOMEM;\n \t\t*new_smc = NULL;\n \t\tlock_sock(lsk);\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \t}\n \t*new_smc = smc_sk(new_sk);\n \n@@ -1587,7 +1607,8 @@ static int smc_clcsock_accept(struct smc_sock *lsmc, struct smc_sock **new_smc)\n \t\tsock_set_flag(new_sk, SOCK_DEAD);\n \t\tsock_put(new_sk); /* final */\n \t\t*new_smc = NULL;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \t}\n \n \t/* new clcsock has inherited the smc listen-specific sk_data_ready\n@@ -1806,14 +1827,16 @@ static int smc_listen_v2_check(struct smc_sock *new_smc,\n \t}\n \tif (!(ini->smcd_version & SMC_V2) && !(ini->smcr_version & SMC_V2)) {\n \t\trc = SMC_CLC_DECL_PEERNOSMC;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \t}\n \tpclc_v2_ext = smc_get_clc_v2_ext(pclc);\n \tif (!pclc_v2_ext) {\n \t\tini->smcd_version &= ~SMC_V2;\n \t\tini->smcr_version &= ~SMC_V2;\n \t\trc = SMC_CLC_DECL_NOV2EXT;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \t}\n \tpclc_smcd_v2_ext = smc_get_clc_smcd_v2_ext(pclc_v2_ext);\n \tif (ini->smcd_version & SMC_V2) {\n@@ -2326,7 +2349,8 @@ static void smc_tcp_listen_work(struct work_struct *work)\n \twhile (lsk->sk_state == SMC_LISTEN) {\n \t\trc = smc_clcsock_accept(lsmc, &new_smc);\n \t\tif (rc) /* clcsock accept queue empty or error */\n-\t\t\tgoto out;\n+\t\t\tsk_common_release(sk);\n+    goto out;\n \t\tif (!new_smc)\n \t\t\tcontinue;\n \n@@ -2378,12 +2402,14 @@ static int smc_listen(struct socket *sock, int backlog)\n \trc = -EINVAL;\n \tif ((sk->sk_state != SMC_INIT && sk->sk_state != SMC_LISTEN) ||\n \t    smc->connect_nonblock)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \n \trc = 0;\n \tif (sk->sk_state == SMC_LISTEN) {\n \t\tsk->sk_max_ack_backlog = backlog;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \t}\n \t/* some socket options are handled in core, so we could not apply\n \t * them to the clc socket -- copy smc socket options to clc socket\n@@ -2414,7 +2440,8 @@ static int smc_listen(struct socket *sock, int backlog)\n \trc = kernel_listen(smc->clcsock, backlog);\n \tif (rc) {\n \t\tsmc->clcsock->sk->sk_data_ready = smc->clcsk_data_ready;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \t}\n \tsk->sk_max_ack_backlog = backlog;\n \tsk->sk_ack_backlog = 0;\n@@ -2441,7 +2468,8 @@ static int smc_accept(struct socket *sock, struct socket *new_sock,\n \tif (lsmc->sk.sk_state != SMC_LISTEN) {\n \t\trc = -EINVAL;\n \t\trelease_sock(sk);\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \t}\n \n \t/* Wait for an incoming connection */\n@@ -2470,7 +2498,8 @@ static int smc_accept(struct socket *sock, struct socket *new_sock,\n \t\trc = sock_error(nsk);\n \trelease_sock(sk);\n \tif (rc)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \n \tif (lsmc->sockopt_defer_accept && !(flags & O_NONBLOCK)) {\n \t\t/* wait till data arrives on the socket */\n@@ -2520,16 +2549,19 @@ static int smc_sendmsg(struct socket *sock, struct msghdr *msg, size_t len)\n \tif ((sk->sk_state != SMC_ACTIVE) &&\n \t    (sk->sk_state != SMC_APPCLOSEWAIT1) &&\n \t    (sk->sk_state != SMC_INIT))\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \n \tif (msg->msg_flags & MSG_FASTOPEN) {\n \t\tif (sk->sk_state == SMC_INIT && !smc->connect_nonblock) {\n \t\t\trc = smc_switch_to_fallback(smc, SMC_CLC_DECL_OPTUNSUPP);\n \t\t\tif (rc)\n-\t\t\t\tgoto out;\n+\t\t\t\tsk_common_release(sk);\n+    goto out;\n \t\t} else {\n \t\t\trc = -EINVAL;\n-\t\t\tgoto out;\n+\t\t\tsk_common_release(sk);\n+    goto out;\n \t\t}\n \t}\n \n@@ -2556,16 +2588,19 @@ static int smc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \tif (sk->sk_state == SMC_CLOSED && (sk->sk_shutdown & RCV_SHUTDOWN)) {\n \t\t/* socket was connected before, no more data to read */\n \t\trc = 0;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \t}\n \tif ((sk->sk_state == SMC_INIT) ||\n \t    (sk->sk_state == SMC_LISTEN) ||\n \t    (sk->sk_state == SMC_CLOSED))\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \n \tif (sk->sk_state == SMC_PEERFINCLOSEWAIT) {\n \t\trc = 0;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \t}\n \n \tif (smc->use_fallback) {\n@@ -2670,13 +2705,15 @@ static int smc_shutdown(struct socket *sock, int how)\n \t    (sk->sk_state != SMC_APPCLOSEWAIT1) &&\n \t    (sk->sk_state != SMC_APPCLOSEWAIT2) &&\n \t    (sk->sk_state != SMC_APPFINCLOSEWAIT))\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \tif (smc->use_fallback) {\n \t\trc = kernel_sock_shutdown(smc->clcsock, how);\n \t\tsk->sk_shutdown = smc->clcsock->sk->sk_shutdown;\n \t\tif (sk->sk_shutdown == SHUTDOWN_MASK)\n \t\t\tsk->sk_state = SMC_CLOSED;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \t}\n \tswitch (how) {\n \tcase SHUT_RDWR:\t\t/* shutdown in both directions */\n@@ -2809,7 +2846,8 @@ static int smc_setsockopt(struct socket *sock, int level, int optname,\n \n \tlock_sock(sk);\n \tif (rc || smc->use_fallback)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \tswitch (optname) {\n \tcase TCP_FASTOPEN:\n \tcase TCP_FASTOPEN_CONNECT:\n@@ -2974,7 +3012,8 @@ static ssize_t smc_sendpage(struct socket *sock, struct page *page,\n \tlock_sock(sk);\n \tif (sk->sk_state != SMC_ACTIVE) {\n \t\trelease_sock(sk);\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \t}\n \trelease_sock(sk);\n \tif (smc->use_fallback) {\n@@ -3010,16 +3049,19 @@ static ssize_t smc_splice_read(struct socket *sock, loff_t *ppos,\n \tif (sk->sk_state == SMC_CLOSED && (sk->sk_shutdown & RCV_SHUTDOWN)) {\n \t\t/* socket was connected before, no more data to read */\n \t\trc = 0;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \t}\n \tif (sk->sk_state == SMC_INIT ||\n \t    sk->sk_state == SMC_LISTEN ||\n \t    sk->sk_state == SMC_CLOSED)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \n \tif (sk->sk_state == SMC_PEERFINCLOSEWAIT) {\n \t\trc = 0;\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \t}\n \n \tif (smc->use_fallback) {\n@@ -3028,7 +3070,8 @@ static ssize_t smc_splice_read(struct socket *sock, loff_t *ppos,\n \t} else {\n \t\tif (*ppos) {\n \t\t\trc = -ESPIPE;\n-\t\t\tgoto out;\n+\t\t\tsk_common_release(sk);\n+    goto out;\n \t\t}\n \t\tif (flags & SPLICE_F_NONBLOCK)\n \t\t\tflags = MSG_DONTWAIT;\n@@ -3076,17 +3119,20 @@ static int __smc_create(struct net *net, struct socket *sock, int protocol,\n \n \trc = -ESOCKTNOSUPPORT;\n \tif (sock->type != SOCK_STREAM)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \n \trc = -EPROTONOSUPPORT;\n \tif (protocol != SMCPROTO_SMC && protocol != SMCPROTO_SMC6)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \n \trc = -ENOBUFS;\n \tsock->ops = &smc_sock_ops;\n \tsk = smc_sock_alloc(net, sock, protocol);\n \tif (!sk)\n-\t\tgoto out;\n+\t\tsk_common_release(sk);\n+    goto out;\n \n \t/* create internal TCP socket for CLC handshake and fallback */\n \tsmc = smc_sk(sk);\n@@ -3102,7 +3148,8 @@ 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\tsk_common_release(sk);\n+    goto out;\n \t\t}\n \t} else {\n \t\tsmc->clcsock = clcsock;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "f7649aa07ffca82dc93dc5cebc00c665849f5138": {
        "non_crash": [
            "diff --git a/security/keys/request_key.c b/security/keys/request_key.c\nindex 3f56a312dd35..e0fa16dde4ff 100644\n--- a/security/keys/request_key.c\n+++ b/security/keys/request_key.c\n@@ -529,6 +529,7 @@ struct key *request_key_and_link(struct key_type *type,\n \t\t\t\t unsigned long flags)\n {\n \tstruct keyring_search_context ctx = {\n+        .index_key.desc_len = strlen(description),\n \t\t.index_key.type\t\t= type,\n \t\t.index_key.description\t= description,\n \t\t.cred\t\t\t= current_cred(),\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/security/keys/keyring.c b/security/keys/keyring.c\nindex eadebb92986a..7e23bd4dccad 100644\n--- a/security/keys/keyring.c\n+++ b/security/keys/keyring.c\n@@ -1363,7 +1363,9 @@ int key_link(struct key *keyring, struct key *key)\n \tkey_check(keyring);\n \tkey_check(key);\n \n-\tret = __key_link_begin(keyring, &key->index_key, &edit);\n+\tif (key->index_key.desc_len == 0)\n+        return -EINVAL;\n+    ret = __key_link_begin(keyring, &key->index_key, &edit);\n \tif (ret == 0) {\n \t\tkdebug(\"begun {%d,%d}\", keyring->serial, refcount_read(&keyring->usage));\n \t\tret = __key_link_check_restriction(keyring, key);\n",
            "diff --git a/security/keys/request_key.c b/security/keys/request_key.c\nindex 3f56a312dd35..1083391e9cd3 100644\n--- a/security/keys/request_key.c\n+++ b/security/keys/request_key.c\n@@ -363,7 +363,8 @@ static int construct_alloc_key(struct keyring_search_context *ctx,\n \t    ctx->index_key.type->update)\n \t\tperm |= KEY_POS_WRITE;\n \n-\tkey = key_alloc(ctx->index_key.type, ctx->index_key.description,\n+\tif (ctx->index_key.desc_len == 0) return -EINVAL;\n+key = key_alloc(ctx->index_key.type, ctx->index_key.description,\n \t\t\tctx->cred->fsuid, ctx->cred->fsgid, ctx->cred,\n \t\t\tperm, flags, NULL);\n \tif (IS_ERR(key))\n",
            "diff --git a/security/keys/keyctl.c b/security/keys/keyctl.c\nindex 7bbe03593e58..e3c5056f7571 100644\n--- a/security/keys/keyctl.c\n+++ b/security/keys/keyctl.c\n@@ -209,7 +209,13 @@ SYSCALL_DEFINE4(request_key, const char __user *, _type,\n \t\tgoto error4;\n \t}\n \n-\t/* do the search */\n+\t/* ensure description is valid */\n+if (!description || strlen(description) == 0) {\n+ret = -EINVAL;\n+goto error2;\n+}\n+\n+/* do the search */\n \tkey = request_key_and_link(ktype, description, callout_info,\n \t\t\t\t   callout_len, NULL, key_ref_to_ptr(dest_ref),\n \t\t\t\t   KEY_ALLOC_IN_QUOTA);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/security/keys/keyring.c b/security/keys/keyring.c\nindex eadebb92986a..3d2a44039a4c 100644\n--- a/security/keys/keyring.c\n+++ b/security/keys/keyring.c\n@@ -492,6 +492,9 @@ static long keyring_read(const struct key *keyring,\n  * Allocate a keyring and link into the destination keyring.\n  */\n struct key *keyring_alloc(const char *description, kuid_t uid, kgid_t gid,\n+{\n+    if (!description || *description == '\\0')\n+        return ERR_PTR(-EINVAL);\n \t\t\t  const struct cred *cred, key_perm_t perm,\n \t\t\t  unsigned long flags,\n \t\t\t  struct key_restriction *restrict_link,\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "5b79a616feb996279758323aba4031c57f80a8bc": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex 9a0ae59cdc50..904cba4472a0 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1138,7 +1138,8 @@ static int do_replace(struct net *net, sockptr_t arg, unsigned int len)\n \tnewinfo->entries = __vmalloc(tmp.entries_size, GFP_KERNEL_ACCOUNT);\n \tif (!newinfo->entries) {\n \t\tret = -ENOMEM;\n-\t\tgoto free_newinfo;\n+\t\tgoto free_entries;\n+free_newinfo: vfree(newinfo);\n \t}\n \tif (copy_from_user(\n \t   newinfo->entries, tmp.entries, tmp.entries_size) != 0) {\n@@ -1206,7 +1207,8 @@ int ebt_register_table(struct net *net, const struct ebt_table *input_table,\n \n \tp = vmalloc(repl->entries_size);\n \tif (!p)\n-\t\tgoto free_newinfo;\n+\t\tgoto free_entries;\n+free_newinfo: vfree(newinfo);\n \n \tmemcpy(p, repl->entries, repl->entries_size);\n \tnewinfo->entries = p;\n@@ -2273,7 +2275,8 @@ static int compat_do_replace(struct net *net, sockptr_t arg, unsigned int len)\n \tnewinfo->entries = vmalloc(tmp.entries_size);\n \tif (!newinfo->entries) {\n \t\tret = -ENOMEM;\n-\t\tgoto free_newinfo;\n+\t\tgoto free_entries;\n+free_newinfo: vfree(newinfo);\n \t}\n \tif (copy_from_user(\n \t   newinfo->entries, tmp.entries, tmp.entries_size) != 0) {\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "0b6b2d6d6cefa8b462930e55be699efba635788f": {
        "non_crash": [
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 63d032191e62..3580dcd384c8 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -464,7 +464,11 @@ static void __nf_unregister_net_hook(struct net *net, int pf,\n \n \tmutex_lock(&nf_hook_mutex);\n \n-\tp = nf_entry_dereference(*pp);\n+\tif (!*pp) {\n+    mutex_unlock(&nf_hook_mutex);\n+    return;\n+}\n+p = nf_entry_dereference(*pp);\n \tif (WARN_ON_ONCE(!p)) {\n \t\tmutex_unlock(&nf_hook_mutex);\n \t\treturn;\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 63d032191e62..5fca0442985b 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -465,7 +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+        pr_warn(\"Warning: Hook entry not found or already freed, pf %d num %d\", pf, reg->hooknum);\n+        mutex_unlock(&nf_hook_mutex);\n+        return;\n+    }\n+\n+    if (nf_remove_net_hook(p, reg)) {\n \t\tmutex_unlock(&nf_hook_mutex);\n \t\treturn;\n \t}\n",
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 63d032191e62..c3a6582f0268 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -499,7 +499,11 @@ void nf_unregister_net_hook(struct net *net, const struct nf_hook_ops *reg)\n \t\t\t__nf_unregister_net_hook(net, NFPROTO_IPV6, reg);\n \t\t}\n \t} else {\n-\t\t__nf_unregister_net_hook(net, reg->pf, reg);\n+\t\tif (reg->hooknum < ARRAY_SIZE(net->nf.hooks_ipv4)) {\n+            __nf_unregister_net_hook(net, reg->pf, reg);\n+        } else {\n+            WARN_ONCE(1, \"Invalid hooknum: %d\", reg->hooknum);\n+        }\n \t}\n }\n EXPORT_SYMBOL(nf_unregister_net_hook);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex c0851fec11d4..e625044f8e23 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -203,6 +203,8 @@ static int nft_netdev_register_hooks(struct net *net,\n \n \tj = 0;\n \tlist_for_each_entry(hook, hook_list, list) {\n+    if (!hook || !hook->ops.hook)\n+        continue; {\n \t\terr = nf_register_net_hook(net, &hook->ops);\n \t\tif (err < 0)\n \t\t\tgoto err_register;\n@@ -213,6 +215,8 @@ static int nft_netdev_register_hooks(struct net *net,\n \n err_register:\n \tlist_for_each_entry(hook, hook_list, list) {\n+    if (!hook || !hook->ops.hook)\n+        continue; {\n \t\tif (j-- <= 0)\n \t\t\tbreak;\n \n@@ -226,7 +230,9 @@ static void nft_netdev_unregister_hooks(struct net *net,\n {\n \tstruct nft_hook *hook;\n \n-\tlist_for_each_entry(hook, hook_list, list)\n+\tlist_for_each_entry(hook, hook_list, list) {\n+    if (!hook || !hook->ops.hook)\n+        continue;\n \t\tnf_unregister_net_hook(net, &hook->ops);\n }\n \n@@ -1836,6 +1842,8 @@ static struct nft_hook *nft_hook_list_find(struct list_head *hook_list,\n \tstruct nft_hook *hook;\n \n \tlist_for_each_entry(hook, hook_list, list) {\n+    if (!hook || !hook->ops.hook)\n+        continue; {\n \t\tif (this->ops.dev == hook->ops.dev)\n \t\t\treturn hook;\n \t}\n@@ -7196,7 +7204,9 @@ static void nft_unregister_flowtable_net_hooks(struct net *net,\n {\n \tstruct nft_hook *hook;\n \n-\tlist_for_each_entry(hook, hook_list, list)\n+\tlist_for_each_entry(hook, hook_list, list) {\n+    if (!hook || !hook->ops.hook)\n+        continue;\n \t\tnf_unregister_net_hook(net, &hook->ops);\n }\n \n@@ -7210,6 +7220,8 @@ static int nft_register_flowtable_net_hooks(struct net *net,\n \tint err, i = 0;\n \n \tlist_for_each_entry(hook, hook_list, list) {\n+    if (!hook || !hook->ops.hook)\n+        continue; {\n \t\tlist_for_each_entry(ft, &table->flowtables, list) {\n \t\t\tif (!nft_is_active_next(net, ft))\n \t\t\t\tcontinue;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex c0851fec11d4..c3d38c57137f 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -202,7 +202,8 @@ static int nft_netdev_register_hooks(struct net *net,\n \tint err, j;\n \n \tj = 0;\n-\tlist_for_each_entry(hook, hook_list, list) {\n+\tlist_for_each_entry(hook, hook_list, list)\n+    if (hook->is_registered) {\n \t\terr = nf_register_net_hook(net, &hook->ops);\n \t\tif (err < 0)\n \t\t\tgoto err_register;\n@@ -212,7 +213,8 @@ static int nft_netdev_register_hooks(struct net *net,\n \treturn 0;\n \n err_register:\n-\tlist_for_each_entry(hook, hook_list, list) {\n+\tlist_for_each_entry(hook, hook_list, list)\n+    if (hook->is_registered) {\n \t\tif (j-- <= 0)\n \t\t\tbreak;\n \n@@ -227,6 +229,7 @@ static void nft_netdev_unregister_hooks(struct net *net,\n \tstruct nft_hook *hook;\n \n \tlist_for_each_entry(hook, hook_list, list)\n+    if (hook->is_registered)\n \t\tnf_unregister_net_hook(net, &hook->ops);\n }\n \n@@ -1835,7 +1838,8 @@ static struct nft_hook *nft_hook_list_find(struct list_head *hook_list,\n {\n \tstruct nft_hook *hook;\n \n-\tlist_for_each_entry(hook, hook_list, list) {\n+\tlist_for_each_entry(hook, hook_list, list)\n+    if (hook->is_registered) {\n \t\tif (this->ops.dev == hook->ops.dev)\n \t\t\treturn hook;\n \t}\n@@ -7197,6 +7201,7 @@ static void nft_unregister_flowtable_net_hooks(struct net *net,\n \tstruct nft_hook *hook;\n \n \tlist_for_each_entry(hook, hook_list, list)\n+    if (hook->is_registered)\n \t\tnf_unregister_net_hook(net, &hook->ops);\n }\n \n@@ -7209,7 +7214,8 @@ static int nft_register_flowtable_net_hooks(struct net *net,\n \tstruct nft_flowtable *ft;\n \tint err, i = 0;\n \n-\tlist_for_each_entry(hook, hook_list, list) {\n+\tlist_for_each_entry(hook, hook_list, list)\n+    if (hook->is_registered) {\n \t\tlist_for_each_entry(ft, &table->flowtables, list) {\n \t\t\tif (!nft_is_active_next(net, ft))\n \t\t\t\tcontinue;\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..df1f1d791022 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 && ptr + sizeof(*ev) + ev->length + 1 <= skb_tail_pointer(skb)) {\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..5d89000d395e 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 && ev->length >= 0) {\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..09ca7f6f0a1c 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 && ev->length < sizeof(ev->data)) {\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_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c\nindex d4b75a6cfeee..09ca7f6f0a1c 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 && ev->length < sizeof(ev->data)) {\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_message": "Failed to build"
            }
        ]
    },
    "c861c927f694825cea94240c7acf698eccb2a8c2": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/alloc.c b/fs/nilfs2/alloc.c\nindex 6ce8617b562d..b0a01d5cd3b3 100644\n--- a/fs/nilfs2/alloc.c\n+++ b/fs/nilfs2/alloc.c\n@@ -606,6 +606,10 @@ 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+    if (!desc_kaddr) {\n+        nilfs_warn(inode->i_sb, \"Failed to map descriptor page\");\n+        return;\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@@ -647,6 +651,10 @@ void nilfs_palloc_abort_alloc_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+    if (!desc_kaddr) {\n+        nilfs_warn(inode->i_sb, \"Failed to map descriptor page\");\n+        return;\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"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/nilfs2/alloc.c b/fs/nilfs2/alloc.c\nindex 6ce8617b562d..8493f25b4fef 100644\n--- a/fs/nilfs2/alloc.c\n+++ b/fs/nilfs2/alloc.c\n@@ -497,6 +497,11 @@ int nilfs_palloc_count_max_entries(struct inode *inode, u64 nused, u64 *nmaxp)\n  */\n int nilfs_palloc_prepare_alloc_entry(struct inode *inode,\n \t\t\t\t     struct nilfs_palloc_req *req)\n+{\n+    if (!req || !req->pr_desc_bh || !req->pr_bitmap_bh) {\n+        nilfs_warn(inode->i_sb, \"%s: invalid palloc request\", __func__);\n+        return;\n+    }\n {\n \tstruct buffer_head *desc_bh, *bitmap_bh;\n \tstruct nilfs_palloc_group_desc *desc;\n@@ -581,6 +586,11 @@ int nilfs_palloc_prepare_alloc_entry(struct inode *inode,\n  */\n void nilfs_palloc_commit_alloc_entry(struct inode *inode,\n \t\t\t\t     struct nilfs_palloc_req *req)\n+{\n+    if (!req || !req->pr_desc_bh || !req->pr_bitmap_bh) {\n+        nilfs_warn(inode->i_sb, \"%s: invalid palloc request\", __func__);\n+        return;\n+    }\n {\n \tmark_buffer_dirty(req->pr_bitmap_bh);\n \tmark_buffer_dirty(req->pr_desc_bh);\n@@ -597,6 +607,11 @@ void nilfs_palloc_commit_alloc_entry(struct inode *inode,\n  */\n void nilfs_palloc_commit_free_entry(struct inode *inode,\n \t\t\t\t    struct nilfs_palloc_req *req)\n+{\n+    if (!req || !req->pr_desc_bh || !req->pr_bitmap_bh) {\n+        nilfs_warn(inode->i_sb, \"%s: invalid palloc request\", __func__);\n+        return;\n+    }\n {\n \tstruct nilfs_palloc_group_desc *desc;\n \tunsigned long group, group_offset;\n@@ -638,6 +653,11 @@ void nilfs_palloc_commit_free_entry(struct inode *inode,\n  */\n void nilfs_palloc_abort_alloc_entry(struct inode *inode,\n \t\t\t\t    struct nilfs_palloc_req *req)\n+{\n+    if (!req || !req->pr_desc_bh || !req->pr_bitmap_bh) {\n+        nilfs_warn(inode->i_sb, \"%s: invalid palloc request\", __func__);\n+        return;\n+    }\n {\n \tstruct nilfs_palloc_group_desc *desc;\n \tvoid *desc_kaddr, *bitmap_kaddr;\n@@ -679,6 +699,11 @@ void nilfs_palloc_abort_alloc_entry(struct inode *inode,\n  */\n int nilfs_palloc_prepare_free_entry(struct inode *inode,\n \t\t\t\t    struct nilfs_palloc_req *req)\n+{\n+    if (!req || !req->pr_desc_bh || !req->pr_bitmap_bh) {\n+        nilfs_warn(inode->i_sb, \"%s: invalid palloc request\", __func__);\n+        return;\n+    }\n {\n \tstruct buffer_head *desc_bh, *bitmap_bh;\n \tunsigned long group, group_offset;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/nilfs2/alloc.c b/fs/nilfs2/alloc.c\nindex 6ce8617b562d..635fb8eded05 100644\n--- a/fs/nilfs2/alloc.c\n+++ b/fs/nilfs2/alloc.c\n@@ -596,6 +596,12 @@ void nilfs_palloc_commit_alloc_entry(struct inode *inode,\n  * @req: nilfs_palloc_req structure exchanged for the removal\n  */\n void nilfs_palloc_commit_free_entry(struct inode *inode,\n+                                    struct nilfs_palloc_req *req) {\n+    if (!req->pr_desc_bh || !req->pr_bitmap_bh) {\n+        nilfs_warn(inode->i_sb, \"nilfs_palloc_commit_free_entry: Buffer heads are NULL\");\n+        return;\n+    }\n+\n \t\t\t\t    struct nilfs_palloc_req *req)\n {\n \tstruct nilfs_palloc_group_desc *desc;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "41a6b5d4917c0412eb3b3c3c604965bed7d7420b": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dadad29bd81b..cbbdf376e8d2 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -643,7 +643,7 @@ ext4_xattr_block_get(struct inode *inode, int name_index, const char *name,\n \n cleanup:\n \tbrelse(bh);\n-\treturn error;\n+\tgoto cleanup;\n }\n \n int\n@@ -662,7 +662,7 @@ ext4_xattr_ibody_get(struct inode *inode, int name_index, const char *name,\n \t\treturn -ENODATA;\n \terror = ext4_get_inode_loc(inode, &iloc);\n \tif (error)\n-\t\treturn error;\n+\t\tgoto cleanup;\n \traw_inode = ext4_raw_inode(&iloc);\n \theader = IHDR(inode, raw_inode);\n \tend = (void *)raw_inode + EXT4_SB(inode->i_sb)->s_inode_size;\n@@ -698,7 +698,7 @@ ext4_xattr_ibody_get(struct inode *inode, int name_index, const char *name,\n \n cleanup:\n \tbrelse(iloc.bh);\n-\treturn error;\n+\tgoto cleanup;\n }\n \n /*\n@@ -730,7 +730,7 @@ ext4_xattr_get(struct inode *inode, int name_index, const char *name,\n \t\terror = ext4_xattr_block_get(inode, name_index, name, buffer,\n \t\t\t\t\t     buffer_size);\n \tup_read(&EXT4_I(inode)->xattr_sem);\n-\treturn error;\n+\tgoto cleanup;\n }\n \n static int\n@@ -789,7 +789,7 @@ ext4_xattr_block_list(struct dentry *dentry, char *buffer, size_t buffer_size)\n \t\t\t\t\tbuffer_size);\n cleanup:\n \tbrelse(bh);\n-\treturn error;\n+\tgoto cleanup;\n }\n \n static int\n@@ -806,7 +806,7 @@ ext4_xattr_ibody_list(struct dentry *dentry, char *buffer, size_t buffer_size)\n \t\treturn 0;\n \terror = ext4_get_inode_loc(inode, &iloc);\n \tif (error)\n-\t\treturn error;\n+\t\tgoto cleanup;\n \traw_inode = ext4_raw_inode(&iloc);\n \theader = IHDR(inode, raw_inode);\n \tend = (void *)raw_inode + EXT4_SB(inode->i_sb)->s_inode_size;\n@@ -818,7 +818,7 @@ ext4_xattr_ibody_list(struct dentry *dentry, char *buffer, size_t buffer_size)\n \n cleanup:\n \tbrelse(iloc.bh);\n-\treturn error;\n+\tgoto cleanup;\n }\n \n /*\n@@ -1177,7 +1177,7 @@ static int ext4_xattr_restart_fn(handle_t *handle, struct inode *inode,\n \t\tif (error) {\n \t\t\text4_warning(inode->i_sb, \"Handle metadata (error %d)\",\n \t\t\t\t     error);\n-\t\t\treturn error;\n+\t\t\tgoto cleanup;\n \t\t}\n \t}\n \treturn 0;\n@@ -1896,14 +1896,14 @@ ext4_xattr_block_find(struct inode *inode, struct ext4_xattr_info *i,\n \t\tif (IS_ERR(bs->bh)) {\n \t\t\terror = PTR_ERR(bs->bh);\n \t\t\tbs->bh = NULL;\n-\t\t\treturn error;\n+\t\t\tgoto cleanup;\n \t\t}\n \t\tea_bdebug(bs->bh, \"b_count=%d, refcount=%d\",\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\t\treturn error;\n+\t\t\tgoto cleanup;\n \t\t/* Find the named attribute. */\n \t\tbs->s.base = BHDR(bs->bh);\n \t\tbs->s.first = BFIRST(bs->bh);\n@@ -1912,7 +1912,7 @@ ext4_xattr_block_find(struct inode *inode, struct ext4_xattr_info *i,\n \t\terror = xattr_find_entry(inode, &bs->s.here, bs->s.end,\n \t\t\t\t\t i->name_index, i->name, 1);\n \t\tif (error && error != -ENODATA)\n-\t\t\treturn error;\n+\t\t\tgoto cleanup;\n \t\tbs->s.not_found = error;\n \t}\n \treturn 0;\n@@ -2231,7 +2231,7 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \tif (!(bs->bh && s->base == bs->bh->b_data))\n \t\tkfree(s->base);\n \n-\treturn error;\n+\tgoto cleanup;\n \n cleanup_dquot:\n \tdquot_free_block(inode, EXT4_C2B(EXT4_SB(sb), 1));\n@@ -2263,12 +2263,12 @@ int ext4_xattr_ibody_find(struct inode *inode, struct ext4_xattr_info *i,\n \tif (ext4_test_inode_state(inode, EXT4_STATE_XATTR)) {\n \t\terror = xattr_check_inode(inode, header, is->s.end);\n \t\tif (error)\n-\t\t\treturn error;\n+\t\t\tgoto cleanup;\n \t\t/* Find the named attribute. */\n \t\terror = xattr_find_entry(inode, &is->s.here, is->s.end,\n \t\t\t\t\t i->name_index, i->name, 0);\n \t\tif (error && error != -ENODATA)\n-\t\t\treturn error;\n+\t\t\tgoto cleanup;\n \t\tis->s.not_found = error;\n \t}\n \treturn 0;\n@@ -2287,7 +2287,7 @@ int ext4_xattr_ibody_set(handle_t *handle, struct inode *inode,\n \n \terror = ext4_xattr_set_entry(i, s, handle, inode, false /* is_block */);\n \tif (error)\n-\t\treturn error;\n+\t\tgoto cleanup;\n \theader = IHDR(inode, ext4_raw_inode(&is->iloc));\n \tif (!IS_LAST_ENTRY(s->first)) {\n \t\theader->h_magic = cpu_to_le32(EXT4_XATTR_MAGIC);\n@@ -2493,7 +2493,7 @@ ext4_xattr_set_handle(handle_t *handle, struct inode *inode, int name_index,\n \tbrelse(is.iloc.bh);\n \tbrelse(bs.bh);\n \text4_write_unlock_xattr(inode, &no_expand);\n-\treturn error;\n+\tgoto cleanup;\n }\n \n int ext4_xattr_set_credits(struct inode *inode, size_t value_len,\n@@ -2542,13 +2542,13 @@ ext4_xattr_set(struct inode *inode, int name_index, const char *name,\n \n \terror = dquot_initialize(inode);\n \tif (error)\n-\t\treturn error;\n+\t\tgoto cleanup;\n \n retry:\n \terror = ext4_xattr_set_credits(inode, value_len, flags & XATTR_CREATE,\n \t\t\t\t       &credits);\n \tif (error)\n-\t\treturn error;\n+\t\tgoto cleanup;\n \n \thandle = ext4_journal_start(inode, EXT4_HT_XATTR, credits);\n \tif (IS_ERR(handle)) {\n@@ -2567,7 +2567,7 @@ ext4_xattr_set(struct inode *inode, int name_index, const char *name,\n \t}\n \text4_fc_mark_ineligible(inode->i_sb, EXT4_FC_REASON_XATTR, NULL);\n \n-\treturn error;\n+\tgoto cleanup;\n }\n \n /*\n@@ -2684,7 +2684,7 @@ static int ext4_xattr_move_to_block(handle_t *handle, struct inode *inode,\n \tkfree(is);\n \tkfree(bs);\n \n-\treturn error;\n+\tgoto cleanup;\n }\n \n static int ext4_xattr_make_inode_space(handle_t *handle, struct inode *inode,\n@@ -2742,7 +2742,7 @@ static int ext4_xattr_make_inode_space(handle_t *handle, struct inode *inode,\n \t\terror = ext4_xattr_move_to_block(handle, inode, raw_inode,\n \t\t\t\t\t\t entry);\n \t\tif (error)\n-\t\t\treturn error;\n+\t\t\tgoto cleanup;\n \n \t\t*total_ino -= entry_size;\n \t\tifree += total_size;\n@@ -2860,7 +2860,7 @@ int ext4_expand_extra_isize_ea(struct inode *inode, int new_extra_isize,\n \t\t\t     inode->i_ino);\n \t\tmnt_count = le16_to_cpu(sbi->s_es->s_mnt_count);\n \t}\n-\treturn error;\n+\tgoto cleanup;\n }\n \n #define EIA_INCR 16 /* must be 2^n */\n@@ -3014,7 +3014,7 @@ int ext4_xattr_delete_inode(handle_t *handle, struct inode *inode,\n cleanup:\n \tbrelse(iloc.bh);\n \tbrelse(bh);\n-\treturn error;\n+\tgoto cleanup;\n }\n \n void ext4_xattr_inode_array_free(struct ext4_xattr_inode_array *ea_inode_array)\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dadad29bd81b..1cd716b6178e 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2855,6 +2855,7 @@ int ext4_expand_extra_isize_ea(struct inode *inode, int new_extra_isize,\n \t\terror = ext4_find_inline_data_nolock(inode);\n \n cleanup:\n+    brelse(bh);\n \tif (error && (mnt_count != le16_to_cpu(sbi->s_es->s_mnt_count))) {\n \t\text4_warning(inode->i_sb, \"Unable to expand inode %lu. Delete some EAs or run e2fsck.\",\n \t\t\t     inode->i_ino);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dadad29bd81b..dde916a3211c 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2855,6 +2855,15 @@ int ext4_expand_extra_isize_ea(struct inode *inode, int new_extra_isize,\n \t\terror = ext4_find_inline_data_nolock(inode);\n \n cleanup:\n+/* Ensure all allocated memory is freed to prevent leaks */\n+if (buffer)\n+kvfree(buffer);\n+if (is)\n+kfree(is);\n+if (bs)\n+kfree(bs);\n+if (b_entry_name)\n+kfree(b_entry_name);\n \tif (error && (mnt_count != le16_to_cpu(sbi->s_es->s_mnt_count))) {\n \t\text4_warning(inode->i_sb, \"Unable to expand inode %lu. Delete some EAs or run e2fsck.\",\n \t\t\t     inode->i_ino);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dadad29bd81b..a0f4f757ae7e 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -611,31 +611,37 @@ 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\tgoto cleanup;\n+\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \text4_xattr_block_cache_insert(ea_block_cache, bh);\n \tentry = BFIRST(bh);\n \tend = bh->b_data + bh->b_size;\n \terror = xattr_find_entry(inode, &entry, end, name_index, name, 1);\n \tif (error)\n-\t\tgoto cleanup;\n+\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \tsize = le32_to_cpu(entry->e_value_size);\n \terror = -ERANGE;\n \tif (unlikely(size > EXT4_XATTR_SIZE_MAX))\n-\t\tgoto cleanup;\n+\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \tif (buffer) {\n \t\tif (size > buffer_size)\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\tif (entry->e_value_inum) {\n \t\t\terror = ext4_xattr_inode_get(inode, entry, buffer,\n \t\t\t\t\t\t     size);\n \t\t\tif (error)\n-\t\t\t\tgoto cleanup;\n+\t\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\t} else {\n \t\t\tu16 offset = le16_to_cpu(entry->e_value_offs);\n \t\t\tvoid *p = bh->b_data + offset;\n \n \t\t\tif (unlikely(p + size > end))\n-\t\t\t\tgoto cleanup;\n+\t\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\t\tmemcpy(buffer, p, size);\n \t\t}\n \t}\n@@ -668,29 +674,35 @@ ext4_xattr_ibody_get(struct inode *inode, int name_index, const char *name,\n \tend = (void *)raw_inode + EXT4_SB(inode->i_sb)->s_inode_size;\n \terror = xattr_check_inode(inode, header, end);\n \tif (error)\n-\t\tgoto cleanup;\n+\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \tentry = IFIRST(header);\n \terror = xattr_find_entry(inode, &entry, end, name_index, name, 0);\n \tif (error)\n-\t\tgoto cleanup;\n+\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \tsize = le32_to_cpu(entry->e_value_size);\n \terror = -ERANGE;\n \tif (unlikely(size > EXT4_XATTR_SIZE_MAX))\n-\t\tgoto cleanup;\n+\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \tif (buffer) {\n \t\tif (size > buffer_size)\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\tif (entry->e_value_inum) {\n \t\t\terror = ext4_xattr_inode_get(inode, entry, buffer,\n \t\t\t\t\t\t     size);\n \t\t\tif (error)\n-\t\t\t\tgoto cleanup;\n+\t\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\t} else {\n \t\t\tu16 offset = le16_to_cpu(entry->e_value_offs);\n \t\t\tvoid *p = (void *)IFIRST(header) + offset;\n \n \t\t\tif (unlikely(p + size > end))\n-\t\t\t\tgoto cleanup;\n+\t\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\t\tmemcpy(buffer, p, size);\n \t\t}\n \t}\n@@ -783,7 +795,8 @@ ext4_xattr_block_list(struct dentry *dentry, char *buffer, size_t buffer_size)\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\tgoto cleanup;\n+\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \text4_xattr_block_cache_insert(EA_BLOCK_CACHE(inode), bh);\n \terror = ext4_xattr_list_entries(dentry, BFIRST(bh), buffer,\n \t\t\t\t\tbuffer_size);\n@@ -812,7 +825,8 @@ ext4_xattr_ibody_list(struct dentry *dentry, char *buffer, size_t buffer_size)\n \tend = (void *)raw_inode + EXT4_SB(inode->i_sb)->s_inode_size;\n \terror = xattr_check_inode(inode, header, end);\n \tif (error)\n-\t\tgoto cleanup;\n+\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \terror = ext4_xattr_list_entries(dentry, IFIRST(header),\n \t\t\t\t\tbuffer, buffer_size);\n \n@@ -1127,12 +1141,14 @@ static int ext4_xattr_inode_inc_ref_all(handle_t *handle, struct inode *parent,\n \t\t\t\t\t    le32_to_cpu(entry->e_hash),\n \t\t\t\t\t    &ea_inode);\n \t\tif (err)\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\terr = ext4_xattr_inode_inc_ref(handle, ea_inode);\n \t\tif (err) {\n \t\t\text4_warning_inode(ea_inode, \"inc ref error %d\", err);\n \t\t\tiput(ea_inode);\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\t}\n \t\tiput(ea_inode);\n \t}\n@@ -1944,7 +1960,8 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\terror = ext4_journal_get_write_access(handle, sb, bs->bh,\n \t\t\t\t\t\t      EXT4_JTR_NONE);\n \t\tif (error)\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\tlock_buffer(bs->bh);\n \n \t\tif (header(s->base)->h_refcount == cpu_to_le32(1)) {\n@@ -1981,7 +1998,8 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\t\t\t\t\t\t   inode,\n \t\t\t\t\t\t\t\t   bs->bh);\n \t\t\tif (error)\n-\t\t\t\tgoto cleanup;\n+\t\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\t\tgoto inserted;\n \t\t}\n clone_block:\n@@ -1990,7 +2008,8 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\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\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\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@@ -2009,7 +2028,8 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\t\t      le32_to_cpu(s->here->e_hash),\n \t\t\t\t      &tmp_inode);\n \t\t\tif (error)\n-\t\t\t\tgoto cleanup;\n+\t\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \n \t\t\tif (!ext4_test_inode_state(tmp_inode,\n \t\t\t\t\tEXT4_STATE_LUSTRE_EA_INODE)) {\n@@ -2030,7 +2050,8 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\ts->base = kzalloc(sb->s_blocksize, GFP_NOFS);\n \t\terror = -ENOMEM;\n \t\tif (s->base == NULL)\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\theader(s->base)->h_magic = cpu_to_le32(EXT4_XATTR_MAGIC);\n \t\theader(s->base)->h_blocks = cpu_to_le32(1);\n \t\theader(s->base)->h_refcount = cpu_to_le32(1);\n@@ -2043,7 +2064,8 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \tif (error == -EFSCORRUPTED)\n \t\tgoto bad_block;\n \tif (error)\n-\t\tgoto cleanup;\n+\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \n \tif (i->value && s->here->e_value_inum) {\n \t\t/*\n@@ -2058,7 +2080,8 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\t\t\t      &ea_inode);\n \t\tif (error) {\n \t\t\tea_inode = NULL;\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\t}\n \t}\n \n@@ -2080,7 +2103,8 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\t\terror = dquot_alloc_block(inode,\n \t\t\t\t\t\tEXT4_C2B(EXT4_SB(sb), 1));\n \t\t\t\tif (error)\n-\t\t\t\t\tgoto cleanup;\n+\t\t\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\t\t\tBUFFER_TRACE(new_bh, \"get_write_access\");\n \t\t\t\terror = ext4_journal_get_write_access(\n \t\t\t\t\t\thandle, sb, new_bh,\n@@ -2144,7 +2168,8 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\tblock = ext4_new_meta_blocks(handle, inode, goal, 0,\n \t\t\t\t\t\t     NULL, &error);\n \t\t\tif (error)\n-\t\t\t\tgoto cleanup;\n+\t\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \n \t\t\tea_idebug(inode, \"creating block %llu\",\n \t\t\t\t  (unsigned long long)block);\n@@ -2155,7 +2180,8 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n getblk_failed:\n \t\t\t\text4_free_blocks(handle, inode, NULL, block, 1,\n \t\t\t\t\t\t EXT4_FREE_BLOCKS_METADATA);\n-\t\t\t\tgoto cleanup;\n+\t\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\t\t}\n \t\t\terror = ext4_xattr_inode_inc_ref_all(handle, inode,\n \t\t\t\t\t\t      ENTRY(header(s->base)+1));\n@@ -2189,7 +2215,8 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\terror = ext4_handle_dirty_metadata(handle, inode,\n \t\t\t\t\t\t\t   new_bh);\n \t\t\tif (error)\n-\t\t\t\tgoto cleanup;\n+\t\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\t}\n \t}\n \n@@ -2235,12 +2262,14 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \n cleanup_dquot:\n \tdquot_free_block(inode, EXT4_C2B(EXT4_SB(sb), 1));\n-\tgoto cleanup;\n+\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \n bad_block:\n \tEXT4_ERROR_INODE(inode, \"bad block %llu\",\n \t\t\t EXT4_I(inode)->i_file_acl);\n-\tgoto cleanup;\n+\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \n #undef header\n }\n@@ -2379,7 +2408,8 @@ ext4_xattr_set_handle(handle_t *handle, struct inode *inode, int name_index,\n \t\tbh = ext4_xattr_get_block(inode);\n \t\tif (IS_ERR(bh)) {\n \t\t\terror = PTR_ERR(bh);\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\t}\n \n \t\tcredits = __ext4_xattr_set_credits(inode->i_sb, inode, bh,\n@@ -2389,14 +2419,16 @@ ext4_xattr_set_handle(handle_t *handle, struct inode *inode, int name_index,\n \n \t\tif (jbd2_handle_buffer_credits(handle) < credits) {\n \t\t\terror = -ENOSPC;\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\t}\n \t\tWARN_ON_ONCE(!(current->flags & PF_MEMALLOC_NOFS));\n \t}\n \n \terror = ext4_reserve_inode_write(handle, inode, &is.iloc);\n \tif (error)\n-\t\tgoto cleanup;\n+\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \n \tif (ext4_test_inode_state(inode, EXT4_STATE_NEW)) {\n \t\tstruct ext4_inode *raw_inode = ext4_raw_inode(&is.iloc);\n@@ -2406,22 +2438,27 @@ ext4_xattr_set_handle(handle_t *handle, struct inode *inode, int name_index,\n \n \terror = ext4_xattr_ibody_find(inode, &i, &is);\n \tif (error)\n-\t\tgoto cleanup;\n+\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \tif (is.s.not_found)\n \t\terror = ext4_xattr_block_find(inode, &i, &bs);\n \tif (error)\n-\t\tgoto cleanup;\n+\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \tif (is.s.not_found && bs.s.not_found) {\n \t\terror = -ENODATA;\n \t\tif (flags & XATTR_REPLACE)\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\terror = 0;\n \t\tif (!value)\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t} else {\n \t\terror = -EEXIST;\n \t\tif (flags & XATTR_CREATE)\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t}\n \n \tif (!value) {\n@@ -2433,9 +2470,11 @@ ext4_xattr_set_handle(handle_t *handle, struct inode *inode, int name_index,\n \t\terror = 0;\n \t\t/* Xattr value did not change? Save us some work and bail out */\n \t\tif (!is.s.not_found && ext4_xattr_value_same(&is.s, &i))\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\tif (!bs.s.not_found && ext4_xattr_value_same(&bs.s, &i))\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \n \t\tif (ext4_has_feature_ea_inode(inode->i_sb) &&\n \t\t    (EXT4_XATTR_SIZE(i.value_len) >\n@@ -2452,7 +2491,8 @@ ext4_xattr_set_handle(handle_t *handle, struct inode *inode, int name_index,\n \t\t\t\tbs.bh = NULL;\n \t\t\t\terror = ext4_xattr_block_find(inode, &i, &bs);\n \t\t\t\tif (error)\n-\t\t\t\t\tgoto cleanup;\n+\t\t\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\t\t}\n \t\t\terror = ext4_xattr_block_set(handle, inode, &i, &bs);\n \t\t\tif (!error && !is.s.not_found) {\n@@ -2789,7 +2829,8 @@ int ext4_expand_extra_isize_ea(struct inode *inode, int new_extra_isize,\n \n \terror = xattr_check_inode(inode, header, end);\n \tif (error)\n-\t\tgoto cleanup;\n+\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \n \tifree = ext4_xattr_free_space(base, &min_offs, base, &total_ino);\n \tif (ifree >= isize_diff)\n@@ -2805,12 +2846,14 @@ int ext4_expand_extra_isize_ea(struct inode *inode, int new_extra_isize,\n \t\tbh = ext4_sb_bread(inode->i_sb, EXT4_I(inode)->i_file_acl, REQ_PRIO);\n \t\tif (IS_ERR(bh)) {\n \t\t\terror = PTR_ERR(bh);\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\t}\n \t\terror = ext4_xattr_check_block(inode, bh);\n \t\tif (error) {\n \t\t\tbrelse(bh);\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\t}\n \t\tbase = BHDR(bh);\n \t\tend = bh->b_data + bh->b_size;\n@@ -2825,7 +2868,8 @@ int ext4_expand_extra_isize_ea(struct inode *inode, int new_extra_isize,\n \t\t\t\tgoto retry;\n \t\t\t}\n \t\t\terror = -ENOSPC;\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\t}\n \t} else {\n \t\tbfree = inode->i_sb->s_blocksize;\n@@ -2841,7 +2885,8 @@ int ext4_expand_extra_isize_ea(struct inode *inode, int new_extra_isize,\n \t\t\tnew_extra_isize = s_min_extra_isize;\n \t\t\tgoto retry;\n \t\t}\n-\t\tgoto cleanup;\n+\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t}\n shift:\n \t/* Adjust the offsets and shift the remaining entries ahead */\n@@ -2931,7 +2976,8 @@ int ext4_xattr_delete_inode(handle_t *handle, struct inode *inode,\n \t\t\text4_free_metadata_revoke_credits(inode->i_sb, 1));\n \tif (error < 0) {\n \t\tEXT4_ERROR_INODE(inode, \"ensure credits (error %d)\", error);\n-\t\tgoto cleanup;\n+\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t}\n \n \tif (ext4_has_feature_ea_inode(inode->i_sb) &&\n@@ -2940,7 +2986,8 @@ int ext4_xattr_delete_inode(handle_t *handle, struct inode *inode,\n \t\terror = ext4_get_inode_loc(inode, &iloc);\n \t\tif (error) {\n \t\t\tEXT4_ERROR_INODE(inode, \"inode loc (error %d)\", error);\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\t}\n \n \t\terror = ext4_journal_get_write_access(handle, inode->i_sb,\n@@ -2948,7 +2995,8 @@ int ext4_xattr_delete_inode(handle_t *handle, struct inode *inode,\n \t\tif (error) {\n \t\t\tEXT4_ERROR_INODE(inode, \"write access (error %d)\",\n \t\t\t\t\t error);\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\t}\n \n \t\theader = IHDR(inode, ext4_raw_inode(&iloc));\n@@ -2971,11 +3019,13 @@ int ext4_xattr_delete_inode(handle_t *handle, struct inode *inode,\n \t\t\t\t\t\t     EXT4_I(inode)->i_file_acl);\n \t\t\t}\n \t\t\tbh = NULL;\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\t}\n \t\terror = ext4_xattr_check_block(inode, bh);\n \t\tif (error)\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \n \t\tif (ext4_has_feature_ea_inode(inode->i_sb)) {\n \t\t\tfor (entry = BFIRST(bh); !IS_LAST_ENTRY(entry);\n@@ -3006,7 +3056,8 @@ int ext4_xattr_delete_inode(handle_t *handle, struct inode *inode,\n \t\tif (error) {\n \t\t\tEXT4_ERROR_INODE(inode, \"mark inode dirty (error %d)\",\n \t\t\t\t\t error);\n-\t\t\tgoto cleanup;\n+\t\t\tbrelse(bh); // Ensure buffer head is released\n+goto cleanup;\n \t\t}\n \t\text4_fc_mark_ineligible(inode->i_sb, EXT4_FC_REASON_XATTR, handle);\n \t}\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "802aba2422de4218ad0c01b46c9525cc9d4e4aa3": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 76bd4d03dbda..89ce91aa97a5 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -9946,7 +9946,7 @@ static void __nft_release_hooks(struct net *net)\n \tstruct nft_table *table;\n \n \tlist_for_each_entry(table, &nft_net->tables, list) {\n-\t\tif (nft_table_has_owner(table))\n+\t\t/* Ensure all tables are processed, including those with owners */\n \t\t\tcontinue;\n \n \t\t__nft_release_hook(net, table);\n@@ -10005,7 +10005,7 @@ static void __nft_release_tables(struct net *net)\n \tstruct nft_table *table, *nt;\n \n \tlist_for_each_entry_safe(table, nt, &nft_net->tables, list) {\n-\t\tif (nft_table_has_owner(table))\n+\t\t/* Ensure all tables are processed, including those with owners */\n \t\t\tcontinue;\n \n \t\tlist_del(&table->list);\n",
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 76bd4d03dbda..9cb626fcba91 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -9997,6 +9997,9 @@ static void __nft_release_table(struct net *net, struct nft_table *table)\n \t\tnf_tables_chain_destroy(&ctx);\n \t}\n \tnf_tables_table_destroy(&ctx);\n+    if (table->use != 0) {\n+        pr_warn(\"Table %s still in use: %d references remain\\n\", table->name, table->use);\n+    }\n }\n \n static void __nft_release_tables(struct net *net)\n",
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 76bd4d03dbda..1f559953bad9 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -9946,7 +9946,10 @@ static void __nft_release_hooks(struct net *net)\n \tstruct nft_table *table;\n \n \tlist_for_each_entry(table, &nft_net->tables, list) {\n-\t\tif (nft_table_has_owner(table))\n+\t\tif (nft_table_has_owner(table)) {\n+pr_warn(\"Table with owner found during cleanup: %s\\n\", table->name);\n+continue;\n+}\n \t\t\tcontinue;\n \n \t\t__nft_release_hook(net, table);\n@@ -10005,7 +10008,10 @@ static void __nft_release_tables(struct net *net)\n \tstruct nft_table *table, *nt;\n \n \tlist_for_each_entry_safe(table, nt, &nft_net->tables, list) {\n-\t\tif (nft_table_has_owner(table))\n+\t\tif (nft_table_has_owner(table)) {\n+pr_warn(\"Table with owner found during cleanup: %s\\n\", table->name);\n+continue;\n+}\n \t\t\tcontinue;\n \n \t\tlist_del(&table->list);\n",
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 76bd4d03dbda..5ee92fdd613b 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -9946,7 +9946,9 @@ static void __nft_release_hooks(struct net *net)\n \tstruct nft_table *table;\n \n \tlist_for_each_entry(table, &nft_net->tables, list) {\n-\t\tif (nft_table_has_owner(table))\n+\t\t/* Ensure all tables are released regardless of ownership */\n+/* if (nft_table_has_owner(table))\n+continue; */\n \t\t\tcontinue;\n \n \t\t__nft_release_hook(net, table);\n@@ -10005,7 +10007,9 @@ static void __nft_release_tables(struct net *net)\n \tstruct nft_table *table, *nt;\n \n \tlist_for_each_entry_safe(table, nt, &nft_net->tables, list) {\n-\t\tif (nft_table_has_owner(table))\n+\t\t/* Ensure all tables are released regardless of ownership */\n+/* if (nft_table_has_owner(table))\n+continue; */\n \t\t\tcontinue;\n \n \t\tlist_del(&table->list);\n"
        ],
        "error": []
    },
    "724cf869d3bb512081588651530d8071a4b61ceb": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/btrfs/qgroup.c b/fs/btrfs/qgroup.c\nindex 00851c86aa8a..b358cf780c52 100644\n--- a/fs/btrfs/qgroup.c\n+++ b/fs/btrfs/qgroup.c\n@@ -3380,7 +3380,11 @@ static void btrfs_qgroup_rescan_worker(struct btrfs_work *work)\n \n \terr = 0;\n \twhile (!err && !(stopped = rescan_should_stop(fs_info))) {\n-\t\ttrans = btrfs_start_transaction(fs_info->fs_root, 0);\n+\t\tif (!fs_info || !fs_info->fs_root) {\n+btrfs_err(fs_info, \"Invalid fs_info or fs_root\");\n+return;\n+}\n+trans = btrfs_start_transaction(fs_info->fs_root, 0);\n \t\tif (IS_ERR(trans)) {\n \t\t\terr = PTR_ERR(trans);\n \t\t\tbreak;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex b8c52e89688c..6412ae10cabe 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -558,6 +558,7 @@ static inline bool need_reserve_reloc_root(struct btrfs_root *root)\n \n static struct btrfs_trans_handle *\n start_transaction(struct btrfs_root *root, unsigned int num_items,\n+    if (!root || !root->fs_info) return ERR_PTR(-EINVAL);\n \t\t  unsigned int type, enum btrfs_reserve_flush_enum flush,\n \t\t  bool enforce_qgroups)\n {\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex b8c52e89688c..f2b6f082488e 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -558,6 +558,11 @@ static inline bool need_reserve_reloc_root(struct btrfs_root *root)\n \n static struct btrfs_trans_handle *\n start_transaction(struct btrfs_root *root, unsigned int num_items,\n+{\n+    if (!root) {\n+        return ERR_PTR(-EINVAL);\n+    }\n+}\n \t\t  unsigned int type, enum btrfs_reserve_flush_enum flush,\n \t\t  bool enforce_qgroups)\n {\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex b8c52e89688c..4269b7ef1c96 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -558,6 +558,7 @@ static inline bool need_reserve_reloc_root(struct btrfs_root *root)\n \n static struct btrfs_trans_handle *\n start_transaction(struct btrfs_root *root, unsigned int num_items,\n+    if (!root) return ERR_PTR(-EINVAL);\n \t\t  unsigned int type, enum btrfs_reserve_flush_enum flush,\n \t\t  bool enforce_qgroups)\n {\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex b8c52e89688c..98bd956262f8 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -558,6 +558,10 @@ static inline bool need_reserve_reloc_root(struct btrfs_root *root)\n \n static struct btrfs_trans_handle *\n start_transaction(struct btrfs_root *root, unsigned int num_items,\n+{\n+    if (!root || !root->fs_info) {\n+        return ERR_PTR(-EINVAL);\n+    }\n \t\t  unsigned int type, enum btrfs_reserve_flush_enum flush,\n \t\t  bool enforce_qgroups)\n {\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..0f09fe2c485b 100644\n--- a/drivers/tty/vt/vt.c\n+++ b/drivers/tty/vt/vt.c\n@@ -4577,7 +4577,7 @@ 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+\tif (op->data && c <= max_font_size && copy_to_user(op->data, font.data, c))\n \t\trc = -EFAULT;\n \n out:\n",
            "diff --git a/drivers/tty/vt/vt.c b/drivers/tty/vt/vt.c\nindex 57a5c23b51d4..0f09fe2c485b 100644\n--- a/drivers/tty/vt/vt.c\n+++ b/drivers/tty/vt/vt.c\n@@ -4577,7 +4577,7 @@ 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+\tif (op->data && c <= max_font_size && copy_to_user(op->data, font.data, c))\n \t\trc = -EFAULT;\n \n out:\n",
            "diff --git a/drivers/tty/vt/vt.c b/drivers/tty/vt/vt.c\nindex 57a5c23b51d4..0f09fe2c485b 100644\n--- a/drivers/tty/vt/vt.c\n+++ b/drivers/tty/vt/vt.c\n@@ -4577,7 +4577,7 @@ 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+\tif (op->data && c <= max_font_size && copy_to_user(op->data, font.data, c))\n \t\trc = -EFAULT;\n \n out:\n",
            "diff --git a/drivers/tty/vt/vt.c b/drivers/tty/vt/vt.c\nindex 57a5c23b51d4..d06fcfd1f278 100644\n--- a/drivers/tty/vt/vt.c\n+++ b/drivers/tty/vt/vt.c\n@@ -4564,7 +4564,7 @@ static int con_font_get(struct vc_data *vc, struct console_font_op *op)\n \tif (rc)\n \t\tgoto out;\n \n-\tc = (font.width+7)/8 * vpitch * font.charcount;\n+\tc = min((font.width+7)/8 * vpitch * font.charcount, max_font_size);\n \n \tif (op->data && font.charcount > op->charcount)\n \t\trc = -ENOSPC;\n"
        ],
        "error": []
    },
    "1bc76a5779300075e3466a0e2abcd753df212779": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/drivers/bluetooth/hci_h5.c b/drivers/bluetooth/hci_h5.c\nindex 0c0dedece59c..958f87878ac4 100644\n--- a/drivers/bluetooth/hci_h5.c\n+++ b/drivers/bluetooth/hci_h5.c\n@@ -555,7 +555,10 @@ static void h5_reset_rx(struct h5 *h5)\n \tclear_bit(H5_RX_ESC, &h5->flags);\n }\n \n-static int h5_recv(struct hci_uart *hu, const void *data, int count)\n+static int h5_recv(struct hci_uart *hu, const void *data, int count) {\n+    if (!hu || !hu->serdev) {\n+        return -EINVAL;\n+    }\n {\n \tstruct h5 *h5 = hu->priv;\n \tconst unsigned char *ptr = data;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/base/power/runtime.c b/drivers/base/power/runtime.c\nindex 8a66eaf731e4..8f2af4ac649f 100644\n--- a/drivers/base/power/runtime.c\n+++ b/drivers/base/power/runtime.c\n@@ -1094,6 +1094,8 @@ EXPORT_SYMBOL_GPL(__pm_runtime_suspend);\n  * or if pm_runtime_irq_safe() has been called.\n  */\n int __pm_runtime_resume(struct device *dev, int rpmflags)\n+{\n+    if (!dev) return -EINVAL;\n {\n \tunsigned long flags;\n \tint retval;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/base/power/runtime.c b/drivers/base/power/runtime.c\nindex 8a66eaf731e4..a4dd76fafa7f 100644\n--- a/drivers/base/power/runtime.c\n+++ b/drivers/base/power/runtime.c\n@@ -1094,6 +1094,8 @@ EXPORT_SYMBOL_GPL(__pm_runtime_suspend);\n  * or if pm_runtime_irq_safe() has been called.\n  */\n int __pm_runtime_resume(struct device *dev, int rpmflags)\n+{\n+    if (!dev || !dev->power) return -EINVAL;\n {\n \tunsigned long flags;\n \tint retval;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/base/power/runtime.c b/drivers/base/power/runtime.c\nindex 8a66eaf731e4..fa652ce1af21 100644\n--- a/drivers/base/power/runtime.c\n+++ b/drivers/base/power/runtime.c\n@@ -1094,6 +1094,8 @@ EXPORT_SYMBOL_GPL(__pm_runtime_suspend);\n  * or if pm_runtime_irq_safe() has been called.\n  */\n int __pm_runtime_resume(struct device *dev, int rpmflags)\n+{\n+    if (!dev || !&dev->power) return -EINVAL;\n {\n \tunsigned long flags;\n \tint retval;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "b32fa08468c9e84e361296e1bc502283ea202ec6": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c\nindex 46943a18a10d..0f2162e1f65d 100644\n--- a/net/packet/af_packet.c\n+++ b/net/packet/af_packet.c\n@@ -4492,7 +4492,8 @@ static int packet_set_ring(struct sock *sk, union tpacket_req_u *req_u,\n \t}\n \n out_free_pg_vec:\n-\tbitmap_free(rx_owner_map);\n+\tif (rx_owner_map)\n+    bitmap_free(rx_owner_map);\n \tif (pg_vec)\n \t\tfree_pg_vec(pg_vec, order, req->tp_block_nr);\n out:\n",
            "diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c\nindex 46943a18a10d..9b0595c9b786 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 && !rb->pg_vec)\n \t\tfree_pg_vec(pg_vec, order, req->tp_block_nr);\n out:\n \treturn err;\n",
            "diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c\nindex 46943a18a10d..c3891daaf602 100644\n--- a/net/packet/af_packet.c\n+++ b/net/packet/af_packet.c\n@@ -4419,7 +4419,7 @@ static int packet_set_ring(struct sock *sk, union tpacket_req_u *req_u,\n \t\t\t\t    req3->tp_sizeof_priv ||\n \t\t\t\t    req3->tp_feature_req_word) {\n \t\t\t\t\terr = -EINVAL;\n-\t\t\t\t\tgoto out_free_pg_vec;\n+\t\t\t\t\tgoto out;\n \t\t\t\t}\n \t\t\t}\n \t\t\tbreak;\n@@ -4428,7 +4428,7 @@ static int packet_set_ring(struct sock *sk, union tpacket_req_u *req_u,\n \t\t\t\trx_owner_map = bitmap_alloc(req->tp_frame_nr,\n \t\t\t\t\tGFP_KERNEL | __GFP_NOWARN | __GFP_ZERO);\n \t\t\t\tif (!rx_owner_map)\n-\t\t\t\t\tgoto out_free_pg_vec;\n+\t\t\t\t\tgoto out;\n \t\t\t}\n \t\t\tbreak;\n \t\t}\n",
            "diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c\nindex 46943a18a10d..0c3c60d8b79a 100644\n--- a/net/packet/af_packet.c\n+++ b/net/packet/af_packet.c\n@@ -4492,7 +4492,7 @@ static int packet_set_ring(struct sock *sk, union tpacket_req_u *req_u,\n \t}\n \n out_free_pg_vec:\n-\tbitmap_free(rx_owner_map);\n+\tif (rx_owner_map) bitmap_free(rx_owner_map);\n \tif (pg_vec)\n \t\tfree_pg_vec(pg_vec, order, req->tp_block_nr);\n out:\n",
            "diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c\nindex 46943a18a10d..ed900e8ed05b 100644\n--- a/net/packet/af_packet.c\n+++ b/net/packet/af_packet.c\n@@ -4494,6 +4494,8 @@ static int packet_set_ring(struct sock *sk, union tpacket_req_u *req_u,\n out_free_pg_vec:\n \tbitmap_free(rx_owner_map);\n \tif (pg_vec)\n+    free_pg_vec(pg_vec, order, req->tp_block_nr);\n+    pg_vec = NULL;\n \t\tfree_pg_vec(pg_vec, order, req->tp_block_nr);\n out:\n \treturn err;\n"
        ],
        "error": []
    },
    "7ba391f8e821454d748011f0dbd3ed0f862dfb78": {
        "non_crash": [
            "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..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..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"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/io_uring/cancel.c b/io_uring/cancel.c\nindex 2291a53cdabd..d2c812234bdd 100644\n--- a/io_uring/cancel.c\n+++ b/io_uring/cancel.c\n@@ -284,7 +284,8 @@ 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\t__set_current_state(TASK_RUNNING);\n+prepare_to_wait(&ctx->cq_wait, &wait, TASK_INTERRUPTIBLE);\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..75bfb573cb8b 100644\n--- a/io_uring/cancel.c\n+++ b/io_uring/cancel.c\n@@ -284,7 +284,8 @@ 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\tset_current_state(TASK_INTERRUPTIBLE);\n+        prepare_to_wait(&ctx->cq_wait, &wait, TASK_UNINTERRUPTIBLE);\n \n \t\tret = __io_sync_cancel(current->io_uring, &cd, sc.fd);\n \n"
        ],
        "error": []
    },
    "1bd2e7a7bb0310b1b0974022c78ee23975119187": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/rxrpc/conn_client.c b/net/rxrpc/conn_client.c\nindex ea7d4c21f889..855737931c7c 100644\n--- a/net/rxrpc/conn_client.c\n+++ b/net/rxrpc/conn_client.c\n@@ -106,7 +106,7 @@ static int rxrpc_get_client_connection_id(struct rxrpc_connection *conn,\n \t_enter(\"\");\n \n \tidr_preload(gfp);\n-\tspin_lock(&rxrpc_conn_id_lock);\n+\tspin_lock_bh(&rxrpc_conn_id_lock);\n \n \tid = idr_alloc_cyclic(&rxrpc_client_conn_ids, conn,\n \t\t\t      1, 0x40000000, GFP_NOWAIT);\n@@ -135,7 +135,7 @@ 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",
            "diff --git a/net/rxrpc/conn_client.c b/net/rxrpc/conn_client.c\nindex ea7d4c21f889..f0e9504eab1a 100644\n--- a/net/rxrpc/conn_client.c\n+++ b/net/rxrpc/conn_client.c\n@@ -135,7 +135,7 @@ 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",
            "diff --git a/net/rxrpc/conn_client.c b/net/rxrpc/conn_client.c\nindex ea7d4c21f889..c87ce5d49b77 100644\n--- a/net/rxrpc/conn_client.c\n+++ b/net/rxrpc/conn_client.c\n@@ -958,7 +958,7 @@ rxrpc_put_one_client_conn(struct rxrpc_connection *conn)\n \n \tif (test_bit(RXRPC_CONN_COUNTED, &conn->flags)) {\n \t\ttrace_rxrpc_client(conn, -1, rxrpc_client_uncount);\n-\t\tspin_lock(&rxnet->client_conn_cache_lock);\n+\t\tspin_lock_bh(&rxnet->client_conn_cache_lock);\n \t\tnr_conns = --rxnet->nr_client_conns;\n \n \t\tif (nr_conns < rxrpc_max_client_connections &&\n@@ -969,7 +969,7 @@ rxrpc_put_one_client_conn(struct rxrpc_connection *conn)\n \t\t\trxrpc_activate_conn(rxnet, next);\n \t\t}\n \n-\t\tspin_unlock(&rxnet->client_conn_cache_lock);\n+\t\tspin_unlock_bh(&rxnet->client_conn_cache_lock);\n \t}\n \n \trxrpc_kill_connection(conn);\n",
            "diff --git a/net/rxrpc/conn_client.c b/net/rxrpc/conn_client.c\nindex ea7d4c21f889..8792d78f9b24 100644\n--- a/net/rxrpc/conn_client.c\n+++ b/net/rxrpc/conn_client.c\n@@ -106,7 +106,8 @@ static int rxrpc_get_client_connection_id(struct rxrpc_connection *conn,\n \t_enter(\"\");\n \n \tidr_preload(gfp);\n-\tspin_lock(&rxrpc_conn_id_lock);\n+\tunsigned long flags;\n+    spin_lock_irqsave(&rxrpc_conn_id_lock, flags);\n \n \tid = idr_alloc_cyclic(&rxrpc_client_conn_ids, conn,\n \t\t\t      1, 0x40000000, GFP_NOWAIT);\n@@ -135,7 +136,8 @@ 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\tunsigned long flags;\n+    spin_lock_irqsave(&rxrpc_conn_id_lock, flags);\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"
        ],
        "error": [
            {
                "patch": "diff --git a/net/rxrpc/conn_client.c b/net/rxrpc/conn_client.c\nindex ea7d4c21f889..c3b4a98d4756 100644\n--- a/net/rxrpc/conn_client.c\n+++ b/net/rxrpc/conn_client.c\n@@ -132,6 +132,22 @@ static int rxrpc_get_client_connection_id(struct rxrpc_connection *conn,\n /*\n  * Release a connection ID for a client connection from the global pool.\n  */\n+static void rxrpc_put_client_connection_id_deferred(struct rxrpc_connection *conn)\n+{\n+    schedule_work(&conn->work);\n+}\n+\n+static void rxrpc_put_client_connection_id_work(struct work_struct *work)\n+{\n+    struct rxrpc_connection *conn = container_of(work, struct rxrpc_connection, work);\n+    if (test_bit(RXRPC_CONN_HAS_IDR, &conn->flags)) {\n+        spin_lock(&rxrpc_conn_id_lock);\n+        idr_remove(&rxrpc_client_conn_ids,\n+                   conn->proto.cid >> RXRPC_CIDSHIFT);\n+        spin_unlock(&rxrpc_conn_id_lock);\n+    }\n+}\n+\n static void rxrpc_put_client_connection_id(struct rxrpc_connection *conn)\n {\n \tif (test_bit(RXRPC_CONN_HAS_IDR, &conn->flags)) {\n@@ -222,7 +238,7 @@ rxrpc_alloc_client_connection(struct rxrpc_conn_parameters *cp, gfp_t gfp)\n error_2:\n \tconn->security->clear(conn);\n error_1:\n-\trxrpc_put_client_connection_id(conn);\n+\trxrpc_put_client_connection_id_deferred(conn);\n error_0:\n \tkfree(conn);\n \t_leave(\" = %d\", ret);\n@@ -952,7 +968,7 @@ rxrpc_put_one_client_conn(struct rxrpc_connection *conn)\n \t\tspin_unlock(&local->client_conns_lock);\n \t}\n \n-\trxrpc_put_client_connection_id(conn);\n+\trxrpc_put_client_connection_id_deferred(conn);\n \n \tASSERTCMP(conn->cache_state, ==, RXRPC_CONN_CLIENT_INACTIVE);\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "8137f770127ad3ae80cc615fbb3b3bdf71c5e17e": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/bluetooth/hci_sync.c b/net/bluetooth/hci_sync.c\nindex 286d6767f017..31f05d439185 100644\n--- a/net/bluetooth/hci_sync.c\n+++ b/net/bluetooth/hci_sync.c\n@@ -4033,7 +4033,9 @@ int hci_dev_open_sync(struct hci_dev *hdev)\n \t\t}\n \t} else {\n \t\t/* Init failed, cleanup */\n-\t\tflush_work(&hdev->tx_work);\n+\t\tif (!flush_work(&hdev->tx_work)) {\n+        bt_dev_err(hdev, \"Failed to flush tx_work\");\n+    }\n \n \t\t/* Since hci_rx_work() is possible to awake new cmd_work\n \t\t * it should be flushed first to avoid unexpected call of\n@@ -4088,7 +4090,9 @@ int hci_dev_close_sync(struct hci_dev *hdev)\n \n \tbt_dev_dbg(hdev, \"\");\n \n-\tcancel_work_sync(&hdev->power_on);\n+\tif (!cancel_work_sync(&hdev->power_on)) {\n+        bt_dev_err(hdev, \"Failed to cancel power_on work\");\n+    }\n \tcancel_delayed_work(&hdev->power_off);\n \tcancel_delayed_work(&hdev->ncmd_timer);\n \n@@ -4110,7 +4114,9 @@ int hci_dev_close_sync(struct hci_dev *hdev)\n \thci_leds_update_powered(hdev, false);\n \n \t/* Flush RX and TX works */\n-\tflush_work(&hdev->tx_work);\n+\tif (!flush_work(&hdev->tx_work)) {\n+        bt_dev_err(hdev, \"Failed to flush tx_work\");\n+    }\n \tflush_work(&hdev->rx_work);\n \n \tif (hdev->discov_timeout > 0) {\n",
            "diff --git a/net/bluetooth/hci_sync.c b/net/bluetooth/hci_sync.c\nindex 286d6767f017..f300197a6415 100644\n--- a/net/bluetooth/hci_sync.c\n+++ b/net/bluetooth/hci_sync.c\n@@ -4137,6 +4137,7 @@ int hci_dev_close_sync(struct hci_dev *hdev)\n \tdrain_workqueue(hdev->workqueue);\n \n \thci_dev_lock(hdev);\n+    bt_dev_dbg(hdev, \"Locked device\");\n \n \thci_discovery_set_state(hdev, DISCOVERY_STOPPED);\n \n@@ -4153,6 +4154,7 @@ int hci_dev_close_sync(struct hci_dev *hdev)\n \t/* Prevent data races on hdev->smp_data or hdev->smp_bredr_data */\n \tsmp_unregister(hdev);\n \thci_dev_unlock(hdev);\n+    bt_dev_dbg(hdev, \"Unlocked device\");\n \n \thci_sock_dev_event(hdev, HCI_DEV_DOWN);\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/bluetooth/hci_sync.c b/net/bluetooth/hci_sync.c\nindex 286d6767f017..c83ec6c3d244 100644\n--- a/net/bluetooth/hci_sync.c\n+++ b/net/bluetooth/hci_sync.c\n@@ -4033,7 +4033,9 @@ int hci_dev_open_sync(struct hci_dev *hdev)\n \t\t}\n \t} else {\n \t\t/* Init failed, cleanup */\n-\t\tflush_work(&hdev->tx_work);\n+\t\tif (!flush_work(&hdev->tx_work)) {\n+        pr_warn(\"Timeout on flush_work: tx_work\\n\");\n+    }\n \n \t\t/* Since hci_rx_work() is possible to awake new cmd_work\n \t\t * it should be flushed first to avoid unexpected call of\n@@ -4088,7 +4090,9 @@ int hci_dev_close_sync(struct hci_dev *hdev)\n \n \tbt_dev_dbg(hdev, \"\");\n \n-\tcancel_work_sync(&hdev->power_on);\n+\tif (!cancel_work_sync(&hdev->power_on)) {\n+        pr_warn(\"Timeout on cancel_work_sync: power_on\\n\");\n+    }\n \tcancel_delayed_work(&hdev->power_off);\n \tcancel_delayed_work(&hdev->ncmd_timer);\n \n@@ -4110,7 +4114,9 @@ int hci_dev_close_sync(struct hci_dev *hdev)\n \thci_leds_update_powered(hdev, false);\n \n \t/* Flush RX and TX works */\n-\tflush_work(&hdev->tx_work);\n+\tif (!flush_work(&hdev->tx_work)) {\n+        pr_warn(\"Timeout on flush_work: tx_work\\n\");\n+    }\n \tflush_work(&hdev->rx_work);\n \n \tif (hdev->discov_timeout > 0) {\n@@ -4134,7 +4140,9 @@ 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+\tif (!drain_workqueue(hdev->workqueue)) {\n+        pr_warn(\"Timeout on drain_workqueue\\n\");\n+    }\n \n \thci_dev_lock(hdev);\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "4f4531908efc47fa22cc64aacbb920d7afb4e222": {
        "non_crash": [
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 718ef3987f94..41333eb34bd9 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2003,7 +2003,8 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\telse {\n \t\t\t\tu32 ref;\n \n-\t\t\t\tWARN_ON_ONCE(dquot_initialize_needed(inode));\n+\t\t\t\tdquot_initialize(inode);\n+            WARN_ON_ONCE(dquot_initialize_needed(inode));\n \n \t\t\t\t/* The old block is released after updating\n \t\t\t\t   the inode. */\n@@ -2067,7 +2068,8 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\t/* We need to allocate a new block */\n \t\t\text4_fsblk_t goal, block;\n \n-\t\t\tWARN_ON_ONCE(dquot_initialize_needed(inode));\n+\t\t\tdquot_initialize(inode);\n+            WARN_ON_ONCE(dquot_initialize_needed(inode));\n \n \t\t\tgoal = ext4_group_first_block_no(sb,\n \t\t\t\t\t\tEXT4_I(inode)->i_block_group);\n",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 718ef3987f94..c0fc0ae365fd 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2003,7 +2003,10 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\telse {\n \t\t\t\tu32 ref;\n \n-\t\t\t\tWARN_ON_ONCE(dquot_initialize_needed(inode));\n+\t\t\t\terror = dquot_initialize(inode);\n+if (error)\n+goto cleanup;\n+WARN_ON_ONCE(dquot_initialize_needed(inode));\n \n \t\t\t\t/* The old block is released after updating\n \t\t\t\t   the inode. */\n@@ -2067,7 +2070,10 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \t\t\t/* We need to allocate a new block */\n \t\t\text4_fsblk_t goal, block;\n \n-\t\t\tWARN_ON_ONCE(dquot_initialize_needed(inode));\n+\t\t\terror = dquot_initialize(inode);\n+if (error)\n+goto cleanup;\n+WARN_ON_ONCE(dquot_initialize_needed(inode));\n \n \t\t\tgoal = ext4_group_first_block_no(sb,\n \t\t\t\t\t\tEXT4_I(inode)->i_block_group);\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 718ef3987f94..bba23a89b157 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2366,7 +2366,10 @@ ext4_xattr_set_handle(handle_t *handle, struct inode *inode, int name_index,\n \t\tif (!is.s.not_found)\n \t\t\terror = ext4_xattr_ibody_set(handle, inode, &i, &is);\n \t\telse if (!bs.s.not_found)\n-\t\t\terror = ext4_xattr_block_set(handle, inode, &i, &bs);\n+\t\t\tdquot_initialize(inode);\n+if (error)\n+goto cleanup;\n+error = ext4_xattr_block_set(handle, inode, &i, &bs);\n \t} else {\n \t\terror = 0;\n \t\t/* Xattr value did not change? Save us some work and bail out */\n@@ -2383,7 +2386,10 @@ ext4_xattr_set_handle(handle_t *handle, struct inode *inode, int name_index,\n \t\terror = ext4_xattr_ibody_set(handle, inode, &i, &is);\n \t\tif (!error && !bs.s.not_found) {\n \t\t\ti.value = NULL;\n-\t\t\terror = ext4_xattr_block_set(handle, inode, &i, &bs);\n+\t\t\tdquot_initialize(inode);\n+if (error)\n+goto cleanup;\n+error = ext4_xattr_block_set(handle, inode, &i, &bs);\n \t\t} else if (error == -ENOSPC) {\n \t\t\tif (EXT4_I(inode)->i_file_acl && !bs.s.base) {\n \t\t\t\tbrelse(bs.bh);\n@@ -2392,7 +2398,10 @@ ext4_xattr_set_handle(handle_t *handle, struct inode *inode, int name_index,\n \t\t\t\tif (error)\n \t\t\t\t\tgoto cleanup;\n \t\t\t}\n-\t\t\terror = ext4_xattr_block_set(handle, inode, &i, &bs);\n+\t\t\tdquot_initialize(inode);\n+if (error)\n+goto cleanup;\n+error = ext4_xattr_block_set(handle, inode, &i, &bs);\n \t\t\tif (!error && !is.s.not_found) {\n \t\t\t\ti.value = NULL;\n \t\t\t\terror = ext4_xattr_ibody_set(handle, inode, &i,\n"
        ],
        "error": []
    },
    "19526c104e66c633a05949201c4c09a3ec8c5644": {
        "non_crash": [
            "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",
            "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"
        ],
        "special_crash": [],
        "crash": [
            "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": [
            {
                "patch": "diff --git a/fs/ext4/ext4_jbd2.c b/fs/ext4/ext4_jbd2.c\nindex 760b9ee49dc0..5af46fcdc762 100644\n--- a/fs/ext4/ext4_jbd2.c\n+++ b/fs/ext4/ext4_jbd2.c\n@@ -218,6 +218,27 @@ static void ext4_check_bdev_write_error(struct super_block *sb)\n }\n \n int __ext4_journal_get_write_access(const char *where, unsigned int line,\n+    handle_t *handle, struct buffer_head *bh)\n+{\n+    int err = 0;\n+\n+    might_sleep();\n+\n+    if (!bh || !bh->b_bdev) {\n+        return -EINVAL;\n+    }\n+\n+    if (bh->b_bdev->bd_super)\n+        ext4_check_bdev_write_error(bh->b_bdev->bd_super);\n+\n+    if (ext4_handle_valid(handle)) {\n+        err = jbd2_journal_get_write_access(handle, bh);\n+        if (err)\n+            ext4_journal_abort_handle(where, line, __func__, bh,\n+                                      handle, err);\n+    }\n+    return err;\n+}\n \t\t\t\t    handle_t *handle, struct buffer_head *bh)\n {\n \tint err = 0;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/ext4/ext4_jbd2.c b/fs/ext4/ext4_jbd2.c\nindex 760b9ee49dc0..24183aa6c73e 100644\n--- a/fs/ext4/ext4_jbd2.c\n+++ b/fs/ext4/ext4_jbd2.c\n@@ -218,6 +218,26 @@ static void ext4_check_bdev_write_error(struct super_block *sb)\n }\n \n int __ext4_journal_get_write_access(const char *where, unsigned int line,\n+    handle_t *handle, struct buffer_head *bh)\n+{\n+    int err = 0;\n+\n+    might_sleep();\n+\n+    if (!bh || !handle)\n+        return -EINVAL;\n+\n+    if (bh->b_bdev->bd_super)\n+        ext4_check_bdev_write_error(bh->b_bdev->bd_super);\n+\n+    if (ext4_handle_valid(handle)) {\n+        err = jbd2_journal_get_write_access(handle, bh);\n+        if (err)\n+            ext4_journal_abort_handle(where, line, __func__, bh,\n+                          handle, err);\n+    }\n+    return err;\n+}\n \t\t\t\t    handle_t *handle, struct buffer_head *bh)\n {\n \tint err = 0;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "a49f5785c682daf283714b6695f902e5371b83d7": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/erofs/zdata.c b/fs/erofs/zdata.c\nindex a90d37c7bdd7..3cf3a97000e4 100644\n--- a/fs/erofs/zdata.c\n+++ b/fs/erofs/zdata.c\n@@ -847,7 +847,7 @@ static int z_erofs_collector_begin(struct z_erofs_decompress_frontend *fe)\n \tDBG_BUGON(fe->pcl);\n \n \t/* must be Z_EROFS_PCLUSTER_TAIL or pointed to previous pcluster */\n-\tDBG_BUGON(fe->owned_head == Z_EROFS_PCLUSTER_NIL);\n+\tif (fe->owned_head == Z_EROFS_PCLUSTER_NIL) fe->owned_head = Z_EROFS_PCLUSTER_TAIL;\n \tDBG_BUGON(fe->owned_head == Z_EROFS_PCLUSTER_TAIL_CLOSED);\n \n \tif (!(map->m_flags & EROFS_MAP_META)) {\n",
            "diff --git a/fs/erofs/zdata.c b/fs/erofs/zdata.c\nindex a90d37c7bdd7..f1668c8793f8 100644\n--- a/fs/erofs/zdata.c\n+++ b/fs/erofs/zdata.c\n@@ -1412,6 +1412,9 @@ static void z_erofs_decompress_queue(const struct z_erofs_decompressqueue *io,\n \tz_erofs_next_pcluster_t owned = io->head;\n \n \twhile (owned != Z_EROFS_PCLUSTER_TAIL_CLOSED) {\n+if (!owned || owned == Z_EROFS_PCLUSTER_NIL) {\n+return; // Invalid pointer, exit early\n+}\n \t\t/* impossible that 'owned' equals Z_EROFS_WORK_TPTR_TAIL */\n \t\tDBG_BUGON(owned == Z_EROFS_PCLUSTER_TAIL);\n \t\t/* impossible that 'owned' equals Z_EROFS_PCLUSTER_NIL */\n",
            "diff --git a/fs/erofs/zdata.c b/fs/erofs/zdata.c\nindex a90d37c7bdd7..f42a1ed249e5 100644\n--- a/fs/erofs/zdata.c\n+++ b/fs/erofs/zdata.c\n@@ -1411,7 +1411,7 @@ static void z_erofs_decompress_queue(const struct z_erofs_decompressqueue *io,\n \t};\n \tz_erofs_next_pcluster_t owned = io->head;\n \n-\twhile (owned != Z_EROFS_PCLUSTER_TAIL_CLOSED) {\n+\twhile (owned != Z_EROFS_PCLUSTER_TAIL_CLOSED && owned != NULL) {\n \t\t/* impossible that 'owned' equals Z_EROFS_WORK_TPTR_TAIL */\n \t\tDBG_BUGON(owned == Z_EROFS_PCLUSTER_TAIL);\n \t\t/* impossible that 'owned' equals Z_EROFS_PCLUSTER_NIL */\n",
            "diff --git a/fs/erofs/zdata.c b/fs/erofs/zdata.c\nindex a90d37c7bdd7..9ac58c5de305 100644\n--- a/fs/erofs/zdata.c\n+++ b/fs/erofs/zdata.c\n@@ -1418,7 +1418,11 @@ static void z_erofs_decompress_queue(const struct z_erofs_decompressqueue *io,\n \t\tDBG_BUGON(owned == Z_EROFS_PCLUSTER_NIL);\n \n \t\tbe.pcl = container_of(owned, struct z_erofs_pcluster, next);\n-\t\towned = READ_ONCE(be.pcl->next);\n+\t\tif (!be.pcl || !be.pcl->next) {\n+            DBG_BUGON(1); // Invalid pointer, trigger debug\n+            return; // Exit early to prevent fault\n+        }\n+        owned = READ_ONCE(be.pcl->next);\n \n \t\tz_erofs_decompress_pcluster(&be, io->eio ? -EIO : 0);\n \t\terofs_workgroup_put(&be.pcl->obj);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/erofs/zdata.c b/fs/erofs/zdata.c\nindex a90d37c7bdd7..839d90a4716a 100644\n--- a/fs/erofs/zdata.c\n+++ b/fs/erofs/zdata.c\n@@ -1703,7 +1703,11 @@ static void z_erofs_submit_queue(struct z_erofs_decompress_frontend *f,\n \tqtail[JQ_SUBMIT] = &q[JQ_SUBMIT]->head;\n \n \t/* by default, all need io submission */\n-\tq[JQ_SUBMIT]->head = owned_head;\n+\tif (owned_head == Z_EROFS_PCLUSTER_TAIL_CLOSED || owned_head == Z_EROFS_PCLUSTER_NIL) {\n+        printk(KERN_ERR \"Invalid owned_head detected\\n\");\n+        return NULL;\n+    }\n+    q[JQ_SUBMIT]->head = owned_head;\n \n \tdo {\n \t\tstruct erofs_map_dev mdev;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "ee9018bd8989530a2dbdd62436efd8b1c3ecd3e5": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/bluetooth/rfcomm/core.c b/net/bluetooth/rfcomm/core.c\nindex 8d6fce9005bd..e514881a4c7e 100644\n--- a/net/bluetooth/rfcomm/core.c\n+++ b/net/bluetooth/rfcomm/core.c\n@@ -484,7 +484,8 @@ 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\trfcomm_unlock();\n+    rfcomm_dlc_lock(d);\n \t\td->state = BT_CLOSED;\n \t\td->state_change(d, err);\n \t\trfcomm_dlc_unlock(d);\n",
            "diff --git a/net/bluetooth/rfcomm/sock.c b/net/bluetooth/rfcomm/sock.c\nindex 21e24da4847f..b2ec7dde3622 100644\n--- a/net/bluetooth/rfcomm/sock.c\n+++ b/net/bluetooth/rfcomm/sock.c\n@@ -70,7 +70,8 @@ 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+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \tif (err)\n \t\tsk->sk_err = err;\n",
            "diff --git a/net/bluetooth/rfcomm/core.c b/net/bluetooth/rfcomm/core.c\nindex 8d6fce9005bd..e703b4934727 100644\n--- a/net/bluetooth/rfcomm/core.c\n+++ b/net/bluetooth/rfcomm/core.c\n@@ -484,10 +484,12 @@ 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\tlock_sock(d->owner);\n+    rfcomm_dlc_lock(d);\n \t\td->state = BT_CLOSED;\n \t\td->state_change(d, err);\n \t\trfcomm_dlc_unlock(d);\n+    release_sock(d->owner);\n \n \t\tskb_queue_purge(&d->tx_queue);\n \t\trfcomm_dlc_unlink(d);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/bluetooth/rfcomm/sock.c b/net/bluetooth/rfcomm/sock.c\nindex 21e24da4847f..36a5487448a2 100644\n--- a/net/bluetooth/rfcomm/sock.c\n+++ b/net/bluetooth/rfcomm/sock.c\n@@ -70,7 +70,8 @@ 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+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \tif (err)\n \t\tsk->sk_err = err;\n@@ -231,7 +232,8 @@ static void __rfcomm_sock_close(struct sock *sk)\n  */\n static void rfcomm_sock_close(struct sock *sk)\n {\n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \t__rfcomm_sock_close(sk);\n \trelease_sock(sk);\n }\n@@ -347,7 +349,8 @@ static int rfcomm_sock_bind(struct socket *sock, struct sockaddr *addr, int addr\n \n \tBT_DBG(\"sk %p %pMR\", sk, &sa.rc_bdaddr);\n \n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \tif (sk->sk_state != BT_OPEN) {\n \t\terr = -EBADFD;\n@@ -391,7 +394,8 @@ static int rfcomm_sock_connect(struct socket *sock, struct sockaddr *addr, int a\n \t    addr->sa_family != AF_BLUETOOTH)\n \t\treturn -EINVAL;\n \n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \tif (sk->sk_state != BT_OPEN && sk->sk_state != BT_BOUND) {\n \t\terr = -EBADFD;\n@@ -428,7 +432,8 @@ static int rfcomm_sock_listen(struct socket *sock, int backlog)\n \n \tBT_DBG(\"sk %p backlog %d\", sk, backlog);\n \n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \tif (sk->sk_state != BT_BOUND) {\n \t\terr = -EBADFD;\n@@ -572,7 +577,8 @@ static int rfcomm_sock_sendmsg(struct socket *sock, struct msghdr *msg,\n \n \tBT_DBG(\"sock %p, sk %p\", sock, sk);\n \n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \tsent = bt_sock_wait_ready(sk, msg->msg_flags);\n \n@@ -607,7 +613,8 @@ static int rfcomm_sock_recvmsg(struct socket *sock, struct msghdr *msg,\n \n \tlen = bt_sock_stream_recvmsg(sock, msg, size, flags);\n \n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \tif (!(flags & MSG_PEEK) && len > 0)\n \t\tatomic_sub(len, &sk->sk_rmem_alloc);\n \n@@ -627,7 +634,8 @@ static int rfcomm_sock_setsockopt_old(struct socket *sock, int optname,\n \n \tBT_DBG(\"sk %p\", sk);\n \n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \tswitch (optname) {\n \tcase RFCOMM_LM:\n@@ -677,7 +685,8 @@ static int rfcomm_sock_setsockopt(struct socket *sock, int level, int optname,\n \tif (level != SOL_BLUETOOTH)\n \t\treturn -ENOPROTOOPT;\n \n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \tswitch (optname) {\n \tcase BT_SECURITY:\n@@ -743,7 +752,8 @@ static int rfcomm_sock_getsockopt_old(struct socket *sock, int optname, char __u\n \tif (get_user(len, optlen))\n \t\treturn -EFAULT;\n \n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \tswitch (optname) {\n \tcase RFCOMM_LM:\n@@ -821,7 +831,8 @@ static int rfcomm_sock_getsockopt(struct socket *sock, int level, int optname, c\n \tif (get_user(len, optlen))\n \t\treturn -EFAULT;\n \n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \tswitch (optname) {\n \tcase BT_SECURITY:\n@@ -871,7 +882,8 @@ static int rfcomm_sock_ioctl(struct socket *sock, unsigned int cmd, unsigned lon\n \n \tif (err == -ENOIOCTLCMD) {\n #ifdef CONFIG_BT_RFCOMM_TTY\n-\t\tlock_sock(sk);\n+\t\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \t\terr = rfcomm_dev_ioctl(sk, cmd, (void __user *) arg);\n \t\trelease_sock(sk);\n #else\n@@ -899,13 +911,15 @@ static int rfcomm_sock_shutdown(struct socket *sock, int how)\n \tif (!sk)\n \t\treturn 0;\n \n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \tif (!sk->sk_shutdown) {\n \t\tsk->sk_shutdown = SHUTDOWN_MASK;\n \n \t\trelease_sock(sk);\n \t\t__rfcomm_sock_close(sk);\n-\t\tlock_sock(sk);\n+\t\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \t\tif (sock_flag(sk, SOCK_LINGER) && sk->sk_lingertime &&\n \t\t    !(current->flags & PF_EXITING))\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/bluetooth/rfcomm/sock.c b/net/bluetooth/rfcomm/sock.c\nindex 21e24da4847f..36a5487448a2 100644\n--- a/net/bluetooth/rfcomm/sock.c\n+++ b/net/bluetooth/rfcomm/sock.c\n@@ -70,7 +70,8 @@ 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+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \tif (err)\n \t\tsk->sk_err = err;\n@@ -231,7 +232,8 @@ static void __rfcomm_sock_close(struct sock *sk)\n  */\n static void rfcomm_sock_close(struct sock *sk)\n {\n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \t__rfcomm_sock_close(sk);\n \trelease_sock(sk);\n }\n@@ -347,7 +349,8 @@ static int rfcomm_sock_bind(struct socket *sock, struct sockaddr *addr, int addr\n \n \tBT_DBG(\"sk %p %pMR\", sk, &sa.rc_bdaddr);\n \n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \tif (sk->sk_state != BT_OPEN) {\n \t\terr = -EBADFD;\n@@ -391,7 +394,8 @@ static int rfcomm_sock_connect(struct socket *sock, struct sockaddr *addr, int a\n \t    addr->sa_family != AF_BLUETOOTH)\n \t\treturn -EINVAL;\n \n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \tif (sk->sk_state != BT_OPEN && sk->sk_state != BT_BOUND) {\n \t\terr = -EBADFD;\n@@ -428,7 +432,8 @@ static int rfcomm_sock_listen(struct socket *sock, int backlog)\n \n \tBT_DBG(\"sk %p backlog %d\", sk, backlog);\n \n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \tif (sk->sk_state != BT_BOUND) {\n \t\terr = -EBADFD;\n@@ -572,7 +577,8 @@ static int rfcomm_sock_sendmsg(struct socket *sock, struct msghdr *msg,\n \n \tBT_DBG(\"sock %p, sk %p\", sock, sk);\n \n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \tsent = bt_sock_wait_ready(sk, msg->msg_flags);\n \n@@ -607,7 +613,8 @@ static int rfcomm_sock_recvmsg(struct socket *sock, struct msghdr *msg,\n \n \tlen = bt_sock_stream_recvmsg(sock, msg, size, flags);\n \n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \tif (!(flags & MSG_PEEK) && len > 0)\n \t\tatomic_sub(len, &sk->sk_rmem_alloc);\n \n@@ -627,7 +634,8 @@ static int rfcomm_sock_setsockopt_old(struct socket *sock, int optname,\n \n \tBT_DBG(\"sk %p\", sk);\n \n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \tswitch (optname) {\n \tcase RFCOMM_LM:\n@@ -677,7 +685,8 @@ static int rfcomm_sock_setsockopt(struct socket *sock, int level, int optname,\n \tif (level != SOL_BLUETOOTH)\n \t\treturn -ENOPROTOOPT;\n \n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \tswitch (optname) {\n \tcase BT_SECURITY:\n@@ -743,7 +752,8 @@ static int rfcomm_sock_getsockopt_old(struct socket *sock, int optname, char __u\n \tif (get_user(len, optlen))\n \t\treturn -EFAULT;\n \n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \tswitch (optname) {\n \tcase RFCOMM_LM:\n@@ -821,7 +831,8 @@ static int rfcomm_sock_getsockopt(struct socket *sock, int level, int optname, c\n \tif (get_user(len, optlen))\n \t\treturn -EFAULT;\n \n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \tswitch (optname) {\n \tcase BT_SECURITY:\n@@ -871,7 +882,8 @@ static int rfcomm_sock_ioctl(struct socket *sock, unsigned int cmd, unsigned lon\n \n \tif (err == -ENOIOCTLCMD) {\n #ifdef CONFIG_BT_RFCOMM_TTY\n-\t\tlock_sock(sk);\n+\t\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \t\terr = rfcomm_dev_ioctl(sk, cmd, (void __user *) arg);\n \t\trelease_sock(sk);\n #else\n@@ -899,13 +911,15 @@ static int rfcomm_sock_shutdown(struct socket *sock, int how)\n \tif (!sk)\n \t\treturn 0;\n \n-\tlock_sock(sk);\n+\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \tif (!sk->sk_shutdown) {\n \t\tsk->sk_shutdown = SHUTDOWN_MASK;\n \n \t\trelease_sock(sk);\n \t\t__rfcomm_sock_close(sk);\n-\t\tlock_sock(sk);\n+\t\trfcomm_dlc_unlock(d);\n+    lock_sock(sk);\n \n \t\tif (sock_flag(sk, SOCK_LINGER) && sk->sk_lingertime &&\n \t\t    !(current->flags & PF_EXITING))\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "46dd655664a8b38dbf7234683b294171a4e0142b": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/base/class.c b/drivers/base/class.c\nindex ac1808d1a2e8..ad7fb46b18f3 100644\n--- a/drivers/base/class.c\n+++ b/drivers/base/class.c\n@@ -292,6 +292,7 @@ void class_destroy(const struct class *cls)\n \t\treturn;\n \n \tclass_unregister(cls);\n+    kfree(cls);\n }\n EXPORT_SYMBOL_GPL(class_destroy);\n \n",
            "diff --git a/drivers/usb/core/file.c b/drivers/usb/core/file.c\nindex c4ed3310e069..4923cf3cd050 100644\n--- a/drivers/usb/core/file.c\n+++ b/drivers/usb/core/file.c\n@@ -207,6 +207,7 @@ int usb_register_dev(struct usb_interface *intf,\n \t\tusb_minors[minor] = NULL;\n \t\tintf->minor = -1;\n \t\tretval = PTR_ERR(intf->usb_dev);\n+destroy_usb_class();\n \t}\n \tup_write(&minor_rwsem);\n \treturn retval;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/usb/class/usblp.c b/drivers/usb/class/usblp.c\nindex 5a2e43331064..d13f04d12bb5 100644\n--- a/drivers/usb/class/usblp.c\n+++ b/drivers/usb/class/usblp.c\n@@ -1227,6 +1227,7 @@ static int usblp_probe(struct usb_interface *intf,\n abort_intfdata:\n \tusb_set_intfdata(intf, NULL);\n abort:\n+usblp_disconnect(intf);\n \tkfree(usblp->readbuf);\n \tkfree(usblp->statusbuf);\n \tkfree(usblp->device_id_string);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/usb/core/driver.c b/drivers/usb/core/driver.c\nindex f58a0299fb3b..9990e4249111 100644\n--- a/drivers/usb/core/driver.c\n+++ b/drivers/usb/core/driver.c\n@@ -407,6 +407,7 @@ static int usb_probe_interface(struct device *dev)\n \treturn error;\n \n  err:\n+usb_deregister_dev(intf, driver);\n \tusb_set_intfdata(intf, NULL);\n \tintf->needs_remote_wakeup = 0;\n \tintf->condition = USB_INTERFACE_UNBOUND;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/usb/class/usblp.c b/drivers/usb/class/usblp.c\nindex 5a2e43331064..fd626dce6fe0 100644\n--- a/drivers/usb/class/usblp.c\n+++ b/drivers/usb/class/usblp.c\n@@ -1210,7 +1210,8 @@ static int usblp_probe(struct usb_interface *intf,\n \t\tdev_err(&intf->dev,\n \t\t\t\"usblp: Not able to get a minor (base %u, slice default): %d\\n\",\n \t\t\tUSBLP_MINOR_BASE, retval);\n-\t\tgoto abort_intfdata;\n+\t\tgoto usb_deregister_dev(intf, &usblp_class);\n+abort_intfdata;\n \t}\n \tusblp->minor = intf->minor;\n \tdev_info(&intf->dev,\n@@ -1224,6 +1225,7 @@ static int usblp_probe(struct usb_interface *intf,\n \n \treturn 0;\n \n+usb_deregister_dev(intf, &usblp_class);\n abort_intfdata:\n \tusb_set_intfdata(intf, NULL);\n abort:\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "ac6fc97113de554dc57614c3ffa4c6a2c2668a97": {
        "non_crash": [
            "diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c\nindex 9c1d31f63f85..ed01d50e6383 100644\n--- a/drivers/hid/hid-core.c\n+++ b/drivers/hid/hid-core.c\n@@ -1320,7 +1320,7 @@ static s32 snto32(__u32 value, unsigned n)\n \tcase 16: return ((__s16)value);\n \tcase 32: return ((__s32)value);\n \t}\n-\treturn value & (1 << (n - 1)) ? value | (~0U << n) : value;\n+\treturn n < 32 && (value & (1 << (n - 1))) ? value | (~0U << n) : value;\n }\n \n s32 hid_snto32(__u32 value, unsigned n)\n",
            "diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c\nindex 9c1d31f63f85..e202f548dad6 100644\n--- a/drivers/hid/hid-core.c\n+++ b/drivers/hid/hid-core.c\n@@ -1320,7 +1320,8 @@ static s32 snto32(__u32 value, unsigned n)\n \tcase 16: return ((__s16)value);\n \tcase 32: return ((__s32)value);\n \t}\n-\treturn value & (1 << (n - 1)) ? value | (~0U << n) : value;\n+\tif (n > 31) return value; // handle safely\n+    return value & (1 << (n - 1)) ? value | (~0U << n) : value;\n }\n \n s32 hid_snto32(__u32 value, unsigned n)\n",
            "diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c\nindex 9c1d31f63f85..03bef25e76f2 100644\n--- a/drivers/hid/hid-core.c\n+++ b/drivers/hid/hid-core.c\n@@ -1320,7 +1320,8 @@ static s32 snto32(__u32 value, unsigned n)\n \tcase 16: return ((__s16)value);\n \tcase 32: return ((__s32)value);\n \t}\n-\treturn value & (1 << (n - 1)) ? value | (~0U << n) : value;\n+\tif (n > 32) n = 32;\n+    return value & (1 << (n - 1)) ? value | (~0U << n) : value;\n }\n \n s32 hid_snto32(__u32 value, unsigned n)\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c\nindex 9c1d31f63f85..3fde308c3152 100644\n--- a/drivers/hid/hid-core.c\n+++ b/drivers/hid/hid-core.c\n@@ -1335,7 +1335,7 @@ EXPORT_SYMBOL_GPL(hid_snto32);\n \n static u32 s32ton(__s32 value, unsigned n)\n {\n-\ts32 a = value >> (n - 1);\n+\ts32 a = n > 32 ? 0 : value >> (n - 1);\n \tif (a && a != -1)\n \t\treturn value < 0 ? 1 << (n - 1) : (1 << (n - 1)) - 1;\n \treturn value & ((1 << n) - 1);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c\nindex 9c1d31f63f85..3e281933d96a 100644\n--- a/drivers/hid/hid-core.c\n+++ b/drivers/hid/hid-core.c\n@@ -1569,9 +1569,9 @@ static void hid_input_fetch_field(struct hid_device *hid,\n \tfor (n = 0; n < count; n++) {\n \n \t\tvalue[n] = min < 0 ?\n-\t\t\tsnto32(hid_field_extract(hid, data, offset + n * size,\n+\t\t\tsnto32((size <= 32 ? hid_field_extract(hid, data, offset + n * size,\n \t\t\t       size), size) :\n-\t\t\thid_field_extract(hid, data, offset + n * size, size);\n+\t\t\t(size <= 32 ? hid_field_extract(hid, data, offset + n * size, size);\n \n \t\t/* Ignore report if ErrorRollOver */\n \t\tif (!(field->flags & HID_MAIN_ITEM_VARIABLE) &&\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "19a04b43c75ed1092021010419b5e560a8172c4f": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/hid/hidraw.c b/drivers/hid/hidraw.c\nindex 681614a8302a..ad78bf45f619 100644\n--- a/drivers/hid/hidraw.c\n+++ b/drivers/hid/hidraw.c\n@@ -519,6 +519,7 @@ int hidraw_report_event(struct hid_device *hid, u8 *data, int len)\n \t\t\tcontinue;\n \n \t\tif (!(list->buffer[list->head].value = kmemdup(data, len, GFP_ATOMIC))) {\n+            kfree(list->buffer[list->head].value);\n \t\t\tret = -ENOMEM;\n \t\t\tbreak;\n \t\t}\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/hid/hidraw.c b/drivers/hid/hidraw.c\nindex 681614a8302a..6e03ac39bd9f 100644\n--- a/drivers/hid/hidraw.c\n+++ b/drivers/hid/hidraw.c\n@@ -518,7 +518,8 @@ int hidraw_report_event(struct hid_device *hid, u8 *data, int len)\n \t\tif (new_head == list->tail)\n \t\t\tcontinue;\n \n-\t\tif (!(list->buffer[list->head].value = kmemdup(data, len, GFP_ATOMIC))) {\n+\t\tif (!(kfree(list->buffer[list->head].value);\n+        list->buffer[list->head].value = kmemdup(data, len, GFP_ATOMIC))) {\n \t\t\tret = -ENOMEM;\n \t\t\tbreak;\n \t\t}\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/hid/hidraw.c b/drivers/hid/hidraw.c\nindex 681614a8302a..dc4fe350bcfb 100644\n--- a/drivers/hid/hidraw.c\n+++ b/drivers/hid/hidraw.c\n@@ -531,8 +531,14 @@ int hidraw_report_event(struct hid_device *hid, u8 *data, int len)\n \twake_up_interruptible(&dev->wait);\n \treturn ret;\n }\n+free_hidraw_event(list);\n EXPORT_SYMBOL_GPL(hidraw_report_event);\n \n+static void free_hidraw_event(struct hidraw_list *list) {\n+    kfree(list->buffer[list->head].value);\n+    list->buffer[list->head].value = NULL;\n+}\n+\n int hidraw_connect(struct hid_device *hid)\n {\n \tint minor, result;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/hid/hidraw.c b/drivers/hid/hidraw.c\nindex 681614a8302a..7142807b5b20 100644\n--- a/drivers/hid/hidraw.c\n+++ b/drivers/hid/hidraw.c\n@@ -505,6 +505,40 @@ static const struct file_operations hidraw_ops = {\n };\n \n int hidraw_report_event(struct hid_device *hid, u8 *data, int len)\n+{\n+    struct hidraw *dev = hid->hidraw;\n+    struct hidraw_list *list;\n+    int ret = 0;\n+    unsigned long flags;\n+\n+    spin_lock_irqsave(&dev->list_lock, flags);\n+    list_for_each_entry(list, &dev->list, node) {\n+        int new_head = (list->head + 1) & (HIDRAW_BUFFER_SIZE - 1);\n+\n+        if (new_head == list->tail)\n+            continue;\n+\n+        if (!(list->buffer[list->head].value = kmemdup(data, len, GFP_ATOMIC))) {\n+            ret = -ENOMEM;\n+            break;\n+        }\n+        list->buffer[list->head].len = len;\n+        list->head = new_head;\n+        kill_fasync(&list->fasync, SIGIO, POLL_IN);\n+    }\n+    if (ret == -ENOMEM) {\n+        list_for_each_entry_continue_reverse(list, &dev->list, node) {\n+            if (list->buffer[list->head].value) {\n+                kfree(list->buffer[list->head].value);\n+                list->buffer[list->head].value = NULL;\n+            }\n+        }\n+    }\n+    spin_unlock_irqrestore(&dev->list_lock, flags);\n+\n+    wake_up_interruptible(&dev->wait);\n+    return ret;\n+}\n {\n \tstruct hidraw *dev = hid->hidraw;\n \tstruct hidraw_list *list;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/hid/hidraw.c b/drivers/hid/hidraw.c\nindex 681614a8302a..c8669de5a30d 100644\n--- a/drivers/hid/hidraw.c\n+++ b/drivers/hid/hidraw.c\n@@ -516,7 +516,8 @@ 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\tcontinue;\n+\t\t\tkfree(data);\n+continue;\n \n \t\tif (!(list->buffer[list->head].value = kmemdup(data, len, GFP_ATOMIC))) {\n \t\t\tret = -ENOMEM;\n@@ -550,7 +551,8 @@ int hidraw_connect(struct hid_device *hid)\n \n \tfor (minor = 0; minor < HIDRAW_MAX_DEVICES; minor++) {\n \t\tif (hidraw_table[minor])\n-\t\t\tcontinue;\n+\t\t\tkfree(data);\n+continue;\n \t\thidraw_table[minor] = dev;\n \t\tresult = 0;\n \t\tbreak;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "848057f402cb7a9107901060c07f48cd2e00e0e9": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/scsi/scsi_proc.c b/drivers/scsi/scsi_proc.c\nindex 4a6eb1741be0..ce9b82fa6b97 100644\n--- a/drivers/scsi/scsi_proc.c\n+++ b/drivers/scsi/scsi_proc.c\n@@ -203,7 +203,12 @@ 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\tremove_proc_entry(sht->proc_name, proc_scsi);\n+\t\tlist_for_each_entry(e, &scsi_proc_list, entry) {\n+            if (strcmp(e->sht->proc_name, sht->proc_name) == 0) {\n+                remove_proc_entry(e->sht->proc_name, proc_scsi);\n+            }\n+        }\n+        remove_proc_entry(sht->proc_name, proc_scsi);\n \t\tlist_del(&e->entry);\n \t\tkfree(e);\n \t}\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/scsi/scsi_proc.c b/drivers/scsi/scsi_proc.c\nindex 4a6eb1741be0..1e7bc6be6250 100644\n--- a/drivers/scsi/scsi_proc.c\n+++ b/drivers/scsi/scsi_proc.c\n@@ -260,7 +260,14 @@ void scsi_proc_host_rm(struct Scsi_Host *shost)\n \t\treturn;\n \n \tsprintf(name,\"%d\", shost->host_no);\n-\tremove_proc_entry(name, e->proc_dir);\n+\t// Iterate and remove all sub-entries within the proc directory\n+    struct proc_dir_entry *sub_entry;\n+    while ((sub_entry = proc_read_dir(e->proc_dir))) {\n+        remove_proc_entry(sub_entry->name, e->proc_dir);\n+    }\n+\n+    // Remove the host directory\n+    remove_proc_entry(name, e->proc_dir);\n }\n /**\n  * proc_print_scsidevice - return data about this host\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/scsi/scsi_proc.c b/drivers/scsi/scsi_proc.c\nindex 4a6eb1741be0..bd378b5b92ed 100644\n--- a/drivers/scsi/scsi_proc.c\n+++ b/drivers/scsi/scsi_proc.c\n@@ -203,7 +203,13 @@ 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\tremove_proc_entry(sht->proc_name, proc_scsi);\n+\t\tchar sub_name[10];\n+struct proc_dir_entry *sub_de;\n+list_for_each_entry(sub_de, &e->proc_dir->subdir, subdir_node) {\n+strncpy(sub_name, sub_de->name, sizeof(sub_name));\n+remove_proc_entry(sub_name, e->proc_dir);\n+}\n+remove_proc_entry(sht->proc_name, proc_scsi);\n \t\tlist_del(&e->entry);\n \t\tkfree(e);\n \t}\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/proc/generic.c b/fs/proc/generic.c\nindex 8379593fa4bb..4461d53712d6 100644\n--- a/fs/proc/generic.c\n+++ b/fs/proc/generic.c\n@@ -684,6 +684,8 @@ void pde_put(struct proc_dir_entry *pde)\n  * Remove a /proc entry and free it if it's not currently in use.\n  */\n void remove_proc_entry(const char *name, struct proc_dir_entry *parent)\n+{\n+    remove_proc_subtree(name, parent);\n {\n \tstruct proc_dir_entry *de = NULL;\n \tconst char *fn = name;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/scsi/scsi_proc.c b/drivers/scsi/scsi_proc.c\nindex 4a6eb1741be0..dc7c9b343013 100644\n--- a/drivers/scsi/scsi_proc.c\n+++ b/drivers/scsi/scsi_proc.c\n@@ -203,7 +203,12 @@ 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\tremove_proc_entry(sht->proc_name, proc_scsi);\n+\t\t\n+        struct proc_dir_entry *child;\n+        while ((child = pde_subdir_first(e->proc_dir))) {\n+            remove_proc_entry(child->name, e->proc_dir);\n+        }\n+        remove_proc_entry(sht->proc_name, proc_scsi);\n \t\tlist_del(&e->entry);\n \t\tkfree(e);\n \t}\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "8dba39eccdf108d625bf6acb2bea1aa0c7e1fd61": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/netfilter/xt_RATEEST.c b/net/netfilter/xt_RATEEST.c\nindex 37253d399c6b..2813227fda87 100644\n--- a/net/netfilter/xt_RATEEST.c\n+++ b/net/netfilter/xt_RATEEST.c\n@@ -63,6 +63,8 @@ static struct xt_rateest *__xt_rateest_lookup(struct xt_rateest_net *xn,\n struct xt_rateest *xt_rateest_lookup(struct net *net, const char *name)\n {\n \tstruct xt_rateest_net *xn = net_generic(net, xt_rateest_id);\n+    if (!xn || !est)\n+        return;\n \tstruct xt_rateest *est;\n \n \tmutex_lock(&xn->hash_lock);\n@@ -75,6 +77,8 @@ EXPORT_SYMBOL_GPL(xt_rateest_lookup);\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+    if (!xn || !est)\n+        return;\n \n \tmutex_lock(&xn->hash_lock);\n \tif (--est->refcnt == 0) {\n@@ -190,6 +194,8 @@ static struct xt_target xt_rateest_tg_reg __read_mostly = {\n static __net_init int xt_rateest_net_init(struct net *net)\n {\n \tstruct xt_rateest_net *xn = net_generic(net, xt_rateest_id);\n+    if (!xn || !est)\n+        return;\n \tint i;\n \n \tmutex_init(&xn->hash_lock);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/netfilter/xt_RATEEST.c b/net/netfilter/xt_RATEEST.c\nindex 37253d399c6b..eace87681d59 100644\n--- a/net/netfilter/xt_RATEEST.c\n+++ b/net/netfilter/xt_RATEEST.c\n@@ -63,6 +63,7 @@ static struct xt_rateest *__xt_rateest_lookup(struct xt_rateest_net *xn,\n struct xt_rateest *xt_rateest_lookup(struct net *net, const char *name)\n {\n \tstruct xt_rateest_net *xn = net_generic(net, xt_rateest_id);\n+    if (!xn || !est) return;\n \tstruct xt_rateest *est;\n \n \tmutex_lock(&xn->hash_lock);\n@@ -75,6 +76,7 @@ EXPORT_SYMBOL_GPL(xt_rateest_lookup);\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+    if (!xn || !est) return;\n \n \tmutex_lock(&xn->hash_lock);\n \tif (--est->refcnt == 0) {\n@@ -190,6 +192,7 @@ static struct xt_target xt_rateest_tg_reg __read_mostly = {\n static __net_init int xt_rateest_net_init(struct net *net)\n {\n \tstruct xt_rateest_net *xn = net_generic(net, xt_rateest_id);\n+    if (!xn || !est) return;\n \tint i;\n \n \tmutex_init(&xn->hash_lock);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/netfilter/xt_RATEEST.c b/net/netfilter/xt_RATEEST.c\nindex 37253d399c6b..ff8b44143522 100644\n--- a/net/netfilter/xt_RATEEST.c\n+++ b/net/netfilter/xt_RATEEST.c\n@@ -73,6 +73,9 @@ struct xt_rateest *xt_rateest_lookup(struct net *net, const char *name)\n EXPORT_SYMBOL_GPL(xt_rateest_lookup);\n \n void xt_rateest_put(struct net *net, struct xt_rateest *est)\n+{\n+    if (!est) return;\n+    struct xt_rateest_net *xn = net_generic(net, xt_rateest_id);\n {\n \tstruct xt_rateest_net *xn = net_generic(net, xt_rateest_id);\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/netfilter/xt_RATEEST.c b/net/netfilter/xt_RATEEST.c\nindex 37253d399c6b..a2458f44a63a 100644\n--- a/net/netfilter/xt_RATEEST.c\n+++ b/net/netfilter/xt_RATEEST.c\n@@ -189,7 +189,8 @@ static struct xt_target xt_rateest_tg_reg __read_mostly = {\n \n static __net_init int xt_rateest_net_init(struct net *net)\n {\n-\tstruct xt_rateest_net *xn = net_generic(net, xt_rateest_id);\n+\tstruct xt_rateest_net *xn = if (!xt_rateest_id) return; /* Ensure xt_rateest_id is initialized */\n+ net_generic(net, xt_rateest_id);\n \tint i;\n \n \tmutex_init(&xn->hash_lock);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "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,\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,\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/aio.c b/fs/aio.c\nindex c1e581dd32f5..9bf2b3804307 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_irqsave(&ctx->ctx_lock, flags);\n \n \twhile (!list_empty(&ctx->active_reqs)) {\n \t\treq = list_first_entry(&ctx->active_reqs,\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/aio.c b/fs/aio.c\nindex c1e581dd32f5..9bf2b3804307 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_irqsave(&ctx->ctx_lock, flags);\n \n \twhile (!list_empty(&ctx->active_reqs)) {\n \t\treq = list_first_entry(&ctx->active_reqs,\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "accafa9281766c4630ea5aeaad0d83decd70406d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex a8ce522ac747..12e4ff86d459 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1035,7 +1035,10 @@ int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)\n \t\tif (ii->i_bh == NULL)\n \t\t\tii->i_bh = *pbh;\n \t\telse {\n-\t\t\tbrelse(*pbh);\n+\t\t\tif (*pbh) {\n+brelse(*pbh);\n+*pbh = NULL;\n+}\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 a8ce522ac747..9d81b9375a0b 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1035,7 +1035,8 @@ int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)\n \t\tif (ii->i_bh == NULL)\n \t\t\tii->i_bh = *pbh;\n \t\telse {\n-\t\t\tbrelse(*pbh);\n+\t\t\tif (*pbh != NULL)\n+            brelse(*pbh);\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 a8ce522ac747..f2791dbe354f 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1036,6 +1036,7 @@ int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)\n \t\t\tii->i_bh = *pbh;\n \t\telse {\n \t\t\tbrelse(*pbh);\n+*pbh = NULL;\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 a8ce522ac747..124e1bd3c86d 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1025,7 +1025,7 @@ int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)\n \tint err;\n \n \tspin_lock(&nilfs->ns_inode_lock);\n-\tif (ii->i_bh == NULL) {\n+\tif (ii->i_bh == NULL || !*pbh) {\n \t\tspin_unlock(&nilfs->ns_inode_lock);\n \t\terr = nilfs_ifile_get_inode_block(ii->i_root->ifile,\n \t\t\t\t\t\t  inode->i_ino, pbh);\n",
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex a8ce522ac747..85351a673135 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1041,7 +1041,7 @@ int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)\n \t} else\n \t\t*pbh = ii->i_bh;\n \n-\tget_bh(*pbh);\n+\tif (*pbh) get_bh(*pbh);\n \tspin_unlock(&nilfs->ns_inode_lock);\n \treturn 0;\n }\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..dbfb2a1fda89 100644\n--- a/sound/core/oss/pcm_plugin.c\n+++ b/sound/core/oss/pcm_plugin.c\n@@ -63,6 +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+if (size > SIZE_MAX / 2) return -ENOMEM;\n \tif (snd_BUG_ON(size % 8))\n \t\treturn -ENXIO;\n \tsize /= 8;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/sound/core/oss/pcm_plugin.c b/sound/core/oss/pcm_plugin.c\nindex 061ba06bc926..9327f03168e4 100644\n--- a/sound/core/oss/pcm_plugin.c\n+++ b/sound/core/oss/pcm_plugin.c\n@@ -68,7 +68,8 @@ static int snd_pcm_plugin_alloc(struct snd_pcm_plugin *plugin, snd_pcm_uframes_t\n \tsize /= 8;\n \tif (plugin->buf_frames < frames) {\n \t\tkvfree(plugin->buf);\n-\t\tplugin->buf = kvzalloc(size, GFP_KERNEL);\n+\t\tplugin->buf = if (size > MAX_ALLOWED_SIZE) return -ENOMEM;\n+        plugin->buf = kvzalloc(size, GFP_KERNEL);\n \t\tplugin->buf_frames = frames;\n \t}\n \tif (!plugin->buf) {\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..83ad5f928456 100644\n--- a/sound/core/oss/pcm_plugin.c\n+++ b/sound/core/oss/pcm_plugin.c\n@@ -63,6 +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+    if (size == 0 || size > MAX_ALLOWED_SIZE) return -EINVAL;\n \tif (snd_BUG_ON(size % 8))\n \t\treturn -ENXIO;\n \tsize /= 8;\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..75d608822271 100644\n--- a/sound/core/oss/pcm_plugin.c\n+++ b/sound/core/oss/pcm_plugin.c\n@@ -63,6 +63,9 @@ 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+    if (size <= 0 || size > MAX_ALLOWED_SIZE) {\n+        return -EINVAL;\n+    };\n \tif (snd_BUG_ON(size % 8))\n \t\treturn -ENXIO;\n \tsize /= 8;\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..120ad3e68f7f 100644\n--- a/sound/core/oss/pcm_plugin.c\n+++ b/sound/core/oss/pcm_plugin.c\n@@ -66,7 +66,8 @@ static int snd_pcm_plugin_alloc(struct snd_pcm_plugin *plugin, snd_pcm_uframes_t\n \tif (snd_BUG_ON(size % 8))\n \t\treturn -ENXIO;\n \tsize /= 8;\n-\tif (plugin->buf_frames < frames) {\n+\tif (frames > MAX_FRAMES) return -EINVAL;\n+    if (plugin->buf_frames < frames) {\n \t\tkvfree(plugin->buf);\n \t\tplugin->buf = kvzalloc(size, GFP_KERNEL);\n \t\tplugin->buf_frames = frames;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "ec324fb855382395411b32d87a6eafd5da721ecc": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "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": [
            {
                "patch": "diff --git a/net/sctp/socket.c b/net/sctp/socket.c\nindex fc0386e8ff23..f42c3f7e4f90 100644\n--- a/net/sctp/socket.c\n+++ b/net/sctp/socket.c\n@@ -7169,7 +7169,7 @@ static int sctp_getsockopt_pr_streamstatus(struct sock *sk, int len,\n \t\t}\n \t} else {\n \t\tparams.sprstat_abandoned_unsent =\n-\t\t\tstreamoute->abandoned_unsent[__SCTP_PR_INDEX(policy)];\n+\t\t\tstreamoute->abandoned_unsent[(__SCTP_PR_INDEX(policy) < MAX_POLICY_INDEX) ? __SCTP_PR_INDEX(policy) : 0];\n \t\tparams.sprstat_abandoned_sent =\n \t\t\tstreamoute->abandoned_sent[__SCTP_PR_INDEX(policy)];\n \t}\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/sctp/socket.c b/net/sctp/socket.c\nindex fc0386e8ff23..bb484f151d1e 100644\n--- a/net/sctp/socket.c\n+++ b/net/sctp/socket.c\n@@ -7146,7 +7146,7 @@ static int sctp_getsockopt_pr_streamstatus(struct sock *sk, int len,\n \t\tgoto out;\n \n \tasoc = sctp_id2assoc(sk, params.sprstat_assoc_id);\n-\tif (!asoc || params.sprstat_sid >= asoc->stream.outcnt)\n+\tif (!asoc || params.sprstat_sid >= asoc->stream.outcnt || __SCTP_PR_INDEX(policy) >= MAX)\n \t\tgoto out;\n \n \tstreamoute = SCTP_SO(&asoc->stream, params.sprstat_sid)->ext;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/sctp/socket.c b/net/sctp/socket.c\nindex fc0386e8ff23..fe9bc7eda2eb 100644\n--- a/net/sctp/socket.c\n+++ b/net/sctp/socket.c\n@@ -7169,9 +7169,9 @@ static int sctp_getsockopt_pr_streamstatus(struct sock *sk, int len,\n \t\t}\n \t} else {\n \t\tparams.sprstat_abandoned_unsent =\n-\t\t\tstreamoute->abandoned_unsent[__SCTP_PR_INDEX(policy)];\n+\t\t\t( (__SCTP_PR_INDEX(policy) >= 0 && __SCTP_PR_INDEX(policy) < MAX_POLICY_INDEX) ? streamoute->abandoned_unsent[__SCTP_PR_INDEX(policy)] : 0 );\n \t\tparams.sprstat_abandoned_sent =\n-\t\t\tstreamoute->abandoned_sent[__SCTP_PR_INDEX(policy)];\n+\t\t\t( (__SCTP_PR_INDEX(policy) >= 0 && __SCTP_PR_INDEX(policy) < MAX_POLICY_INDEX) ? streamoute->abandoned_sent[__SCTP_PR_INDEX(policy)] : 0 );\n \t}\n \n \tif (put_user(len, optlen) || copy_to_user(optval, &params, len)) {\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "75b0feac9a3f9e361fd60605e261f8a4ffef1c40": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/truncate.c b/mm/truncate.c\nindex ab50d0d59a2a..bc3e5245f014 100644\n--- a/mm/truncate.c\n+++ b/mm/truncate.c\n@@ -234,7 +234,11 @@ 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 && offset >= 0 && length > 0 && offset + length <= folio_size(folio)) {\n+    folio_zero_range(folio, offset, length);\n+} else {\n+    return false;\n+}\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..79b587de6e12 100644\n--- a/mm/truncate.c\n+++ b/mm/truncate.c\n@@ -234,7 +234,9 @@ 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+    folio_zero_range(folio, offset, length);\n+}\n \n \tif (folio_has_private(folio))\n \t\tfolio_invalidate(folio, offset, length);\n"
        ],
        "error": []
    },
    "82136e2452d5e1ea212f5bf76fcd8db36512f981": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/erofs/inode.c b/fs/erofs/inode.c\nindex 95a403720e8c..c65354628964 100644\n--- a/fs/erofs/inode.c\n+++ b/fs/erofs/inode.c\n@@ -219,7 +219,7 @@ static int erofs_fill_symlink(struct inode *inode, void *kaddr,\n \t\treturn 0;\n \t}\n \n-\tlnk = kmalloc(inode->i_size + 1, GFP_KERNEL);\n+\tlnk = kmalloc(max(inode->i_size + 1, EROFS_BLKSIZ), GFP_KERNEL);\n \tif (!lnk)\n \t\treturn -ENOMEM;\n \n",
            "diff --git a/fs/erofs/inode.c b/fs/erofs/inode.c\nindex 95a403720e8c..1676d84601f2 100644\n--- a/fs/erofs/inode.c\n+++ b/fs/erofs/inode.c\n@@ -220,6 +220,10 @@ static int erofs_fill_symlink(struct inode *inode, void *kaddr,\n \t}\n \n \tlnk = kmalloc(inode->i_size + 1, GFP_KERNEL);\n+    if (inode->i_size == 0) {\n+        erofs_err(inode->i_sb, \"invalid symlink size @ nid %llu\", vi->nid);\n+        return -EFSCORRUPTED;\n+    }\n \tif (!lnk)\n \t\treturn -ENOMEM;\n \n",
            "diff --git a/fs/erofs/inode.c b/fs/erofs/inode.c\nindex 95a403720e8c..9eb62d5cbee1 100644\n--- a/fs/erofs/inode.c\n+++ b/fs/erofs/inode.c\n@@ -220,6 +220,10 @@ static int erofs_fill_symlink(struct inode *inode, void *kaddr,\n \t}\n \n \tlnk = kmalloc(inode->i_size + 1, GFP_KERNEL);\n+    if (!lnk) {\n+        erofs_err(inode->i_sb, \"kmalloc failed for symlink @ nid %llu\", vi->nid);\n+        return -ENOMEM;\n+    }\n \tif (!lnk)\n \t\treturn -ENOMEM;\n \n",
            "diff --git a/fs/erofs/inode.c b/fs/erofs/inode.c\nindex 95a403720e8c..02ed72d80e14 100644\n--- a/fs/erofs/inode.c\n+++ b/fs/erofs/inode.c\n@@ -219,7 +219,8 @@ static int erofs_fill_symlink(struct inode *inode, void *kaddr,\n \t\treturn 0;\n \t}\n \n-\tlnk = kmalloc(inode->i_size + 1, GFP_KERNEL);\n+\tif (inode->i_size > EROFS_BLKSIZ - vi->xattr_isize) return -EFSCORRUPTED;\n+    lnk = kmalloc(inode->i_size + 1, GFP_KERNEL);\n \tif (!lnk)\n \t\treturn -ENOMEM;\n \n",
            "diff --git a/fs/erofs/inode.c b/fs/erofs/inode.c\nindex 95a403720e8c..6fb7fb49d57a 100644\n--- a/fs/erofs/inode.c\n+++ b/fs/erofs/inode.c\n@@ -219,7 +219,8 @@ static int erofs_fill_symlink(struct inode *inode, void *kaddr,\n \t\treturn 0;\n \t}\n \n-\tlnk = kmalloc(inode->i_size + 1, GFP_KERNEL);\n+\tif (inode->i_size >= EROFS_BLKSIZ) return -EFSCORRUPTED;\n+    lnk = kmalloc(inode->i_size + 1, GFP_KERNEL);\n \tif (!lnk)\n \t\treturn -ENOMEM;\n \n"
        ],
        "error": []
    },
    "6922c8c31f1fdd120d1cef3f58b319b6dd1d8c00": {
        "non_crash": [],
        "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..04ea72713495 100644\n--- a/drivers/misc/vmw_vmci/vmci_queue_pair.c\n+++ b/drivers/misc/vmw_vmci/vmci_queue_pair.c\n@@ -632,7 +632,8 @@ static void qp_release_pages(struct page **pages,\n \t\tif (dirty)\n \t\t\tset_page_dirty(pages[i]);\n \n-\t\tput_page(pages[i]);\n+\t\tif (pages[i])\n+            put_page(pages[i]);\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..a96bf23698b4 100644\n--- a/drivers/misc/vmw_vmci/vmci_queue_pair.c\n+++ b/drivers/misc/vmw_vmci/vmci_queue_pair.c\n@@ -632,7 +632,8 @@ static void qp_release_pages(struct page **pages,\n \t\tif (dirty)\n \t\t\tset_page_dirty(pages[i]);\n \n-\t\tput_page(pages[i]);\n+\t\tif (pages[i])\n+put_page(pages[i]);\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..04ea72713495 100644\n--- a/drivers/misc/vmw_vmci/vmci_queue_pair.c\n+++ b/drivers/misc/vmw_vmci/vmci_queue_pair.c\n@@ -632,7 +632,8 @@ static void qp_release_pages(struct page **pages,\n \t\tif (dirty)\n \t\t\tset_page_dirty(pages[i]);\n \n-\t\tput_page(pages[i]);\n+\t\tif (pages[i])\n+            put_page(pages[i]);\n \t\tpages[i] = NULL;\n \t}\n }\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/misc/vmw_vmci/vmci_queue_pair.c b/drivers/misc/vmw_vmci/vmci_queue_pair.c\nindex 8531ae781195..a3a738935198 100644\n--- a/drivers/misc/vmw_vmci/vmci_queue_pair.c\n+++ b/drivers/misc/vmw_vmci/vmci_queue_pair.c\n@@ -624,6 +624,23 @@ static void qp_release_queue_mutex(struct vmci_queue *queue)\n  * previously obtained using get_user_pages.\n  */\n static void qp_release_pages(struct page **pages,\n+                             u64 num_pages, bool dirty)\n+{\n+    int i;\n+\n+    if (!pages || num_pages <= 0) {\n+        pr_warn(\"Invalid pages array or number of pages\\n\");\n+        return;\n+    }\n+\n+    for (i = 0; i < num_pages; i++) {\n+        if (dirty)\n+            set_page_dirty(pages[i]);\n+\n+        put_page(pages[i]);\n+        pages[i] = NULL;\n+    }\n+}\n \t\t\t     u64 num_pages, bool dirty)\n {\n \tint i;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/misc/vmw_vmci/vmci_queue_pair.c b/drivers/misc/vmw_vmci/vmci_queue_pair.c\nindex 8531ae781195..a9f108f74db9 100644\n--- a/drivers/misc/vmw_vmci/vmci_queue_pair.c\n+++ b/drivers/misc/vmw_vmci/vmci_queue_pair.c\n@@ -302,7 +302,8 @@ static void *qp_alloc_queue(u64 size, u32 flags)\n \t\t(void **)((u8 *)queue->kernel_if->u.g.pas + pas_size);\n \tqueue->kernel_if->host = false;\n \n-\tfor (i = 0; i < num_pages; i++) {\n+\tif (!pages) return;\n+    for (i = 0; i < num_pages; i++) {\n \t\tqueue->kernel_if->u.g.vas[i] =\n \t\t\tdma_alloc_coherent(&vmci_pdev->dev, PAGE_SIZE,\n \t\t\t\t\t   &queue->kernel_if->u.g.pas[i],\n@@ -628,7 +629,8 @@ static void qp_release_pages(struct page **pages,\n {\n \tint i;\n \n-\tfor (i = 0; i < num_pages; i++) {\n+\tif (!pages) return;\n+    for (i = 0; i < num_pages; i++) {\n \t\tif (dirty)\n \t\t\tset_page_dirty(pages[i]);\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "ad6e459b5804609befe3e5c24001b25185b073fc": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/net/wireguard/netlink.c b/drivers/net/wireguard/netlink.c\nindex 20a4f3c0a0a1..2601f97c7783 100644\n--- a/drivers/net/wireguard/netlink.c\n+++ b/drivers/net/wireguard/netlink.c\n@@ -64,7 +64,8 @@ static struct wg_device *lookup_interface(struct nlattr **attrs,\n \t\t\t\t      nla_data(attrs[WGDEVICE_A_IFNAME]));\n \tif (!dev)\n \t\treturn ERR_PTR(-ENODEV);\n-\tif (!dev->rtnl_link_ops || !dev->rtnl_link_ops->kind ||\n+\tif (!dev) return ERR_PTR(-ENODEV);\n+    if (!dev->rtnl_link_ops || !dev->rtnl_link_ops->kind ||\n \t    strcmp(dev->rtnl_link_ops->kind, KBUILD_MODNAME)) {\n \t\tdev_put(dev);\n \t\treturn ERR_PTR(-EOPNOTSUPP);\n",
            "diff --git a/net/core/dev_ioctl.c b/net/core/dev_ioctl.c\nindex 547b587c1950..bb2cd86569be 100644\n--- a/net/core/dev_ioctl.c\n+++ b/net/core/dev_ioctl.c\n@@ -163,7 +163,8 @@ static int dev_ifsioc_locked(struct net *net, struct ifreq *ifr, unsigned int cm\n \t\tbreak;\n \n \t}\n-\treturn err;\n+\tdev_put(dev);\n+    return err;\n }\n \n static int net_hwtstamp_validate(struct ifreq *ifr)\n",
            "diff --git a/net/core/dev.c b/net/core/dev.c\nindex 90b59fc50dc9..cd5952f2457a 100644\n--- a/net/core/dev.c\n+++ b/net/core/dev.c\n@@ -902,7 +902,8 @@ struct net_device *dev_get_by_name(struct net *net, const char *name)\n \tstruct net_device *dev;\n \n \trcu_read_lock();\n-\tdev = dev_get_by_name_rcu(net, name);\n+\tif (!name || !rcu_access_pointer(name)) return NULL;\n+    dev = dev_get_by_name_rcu(net, name);\n \tif (dev)\n \t\tdev_hold(dev);\n \trcu_read_unlock();\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/net/wireguard/netlink.c b/drivers/net/wireguard/netlink.c\nindex 20a4f3c0a0a1..5420e798da2c 100644\n--- a/drivers/net/wireguard/netlink.c\n+++ b/drivers/net/wireguard/netlink.c\n@@ -69,7 +69,8 @@ static struct wg_device *lookup_interface(struct nlattr **attrs,\n \t\tdev_put(dev);\n \t\treturn ERR_PTR(-EOPNOTSUPP);\n \t}\n-\treturn netdev_priv(dev);\n+\tdev_hold(dev);\n+    return netdev_priv(dev);\n }\n \n static int get_allowedips(struct sk_buff *skb, const u8 *ip, u8 cidr,\n@@ -90,7 +91,8 @@ static int get_allowedips(struct sk_buff *skb, const u8 *ip, u8 cidr,\n \t}\n \n \tnla_nest_end(skb, allowedip_nest);\n-\treturn 0;\n+\tdev_put(DUMP_CTX(cb)->wg->dev);\n+    return 0;\n }\n \n struct dump_ctx {\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/core/dev.c b/net/core/dev.c\nindex 90b59fc50dc9..ba322fab0157 100644\n--- a/net/core/dev.c\n+++ b/net/core/dev.c\n@@ -316,6 +316,8 @@ int netdev_name_node_alt_create(struct net_device *dev, const char *name)\n EXPORT_SYMBOL(netdev_name_node_alt_create);\n \n static void __netdev_name_node_alt_destroy(struct netdev_name_node *name_node)\n+{\n+spin_lock(&dev_base_lock);\n {\n \tlist_del(&name_node->list);\n \tnetdev_name_node_del(name_node);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "b0932be9507e30fc4cbd16bf05cd3bea03b325d7": {
        "non_crash": [
            "diff --git a/block/disk-events.c b/block/disk-events.c\nindex 8d5496e7592a..19cbe1dc698c 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+    disk->ev = NULL;\n }\n",
            "diff --git a/block/disk-events.c b/block/disk-events.c\nindex 8d5496e7592a..e5ec55c5c6d2 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+disk->ev = NULL;\n }\n",
            "diff --git a/block/disk-events.c b/block/disk-events.c\nindex 8d5496e7592a..e5ec55c5c6d2 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+disk->ev = NULL;\n }\n",
            "diff --git a/block/disk-events.c b/block/disk-events.c\nindex 8d5496e7592a..e5ec55c5c6d2 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+disk->ev = NULL;\n }\n",
            "diff --git a/block/disk-events.c b/block/disk-events.c\nindex 8d5496e7592a..e5ec55c5c6d2 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+disk->ev = NULL;\n }\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "d8e8c32d387c7b35680b035aab36efdefe253ab7": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/btrfs/block-group.c b/fs/btrfs/block-group.c\nindex 0cb1dee965a0..7848ea9cd51c 100644\n--- a/fs/btrfs/block-group.c\n+++ b/fs/btrfs/block-group.c\n@@ -3765,7 +3765,7 @@ static int should_alloc_chunk(struct btrfs_fs_info *fs_info,\n \t\t\treturn 1;\n \t}\n \n-\tif (bytes_used + SZ_2M < mult_perc(sinfo->total_bytes, 80))\n+\tif (bytes_used + SZ_2M < mult_perc(sinfo->total_bytes, 80) || sinfo->total_bytes - bytes_used < SZ_1M)\n \t\treturn 0;\n \treturn 1;\n }\n",
            "diff --git a/fs/btrfs/volumes.c b/fs/btrfs/volumes.c\nindex bfdfecee1afe..153f9d530898 100644\n--- a/fs/btrfs/volumes.c\n+++ b/fs/btrfs/volumes.c\n@@ -5487,7 +5487,8 @@ struct btrfs_block_group *btrfs_create_chunk(struct btrfs_trans_handle *trans,\n \tif (list_empty(&fs_devices->alloc_list)) {\n \t\tif (btrfs_test_opt(info, ENOSPC_DEBUG))\n \t\t\tbtrfs_debug(info, \"%s: no writable device\", __func__);\n-\t\treturn ERR_PTR(-ENOSPC);\n+\t\tbtrfs_debug(info, \"%s: ENOSPC error, no writable device available\", __func__);\n+return ERR_PTR(-ENOSPC);\n \t}\n \n \tif (!(type & BTRFS_BLOCK_GROUP_TYPE_MASK)) {\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/btrfs/block-group.c b/fs/btrfs/block-group.c\nindex 0cb1dee965a0..a568dfc6b959 100644\n--- a/fs/btrfs/block-group.c\n+++ b/fs/btrfs/block-group.c\n@@ -2897,7 +2897,9 @@ int btrfs_inc_block_group_ro(struct btrfs_block_group *cache,\n \t\t\t * ENOSPC is allowed here, we may have enough space\n \t\t\t * already allocated at the new raid level to carry on\n \t\t\t */\n-\t\t\tif (ret == -ENOSPC)\n+\t\t\tif (ret == -ENOSPC) {\n+            WARN_ON(1);\n+            btrfs_warn(fs_info, \"chunk allocation failed due to ENOSPC\");\n \t\t\t\tret = 0;\n \t\t\tif (ret < 0)\n \t\t\t\tgoto out;\n@@ -3185,7 +3187,9 @@ static int cache_save_setup(struct btrfs_block_group *block_group,\n \t */\n \tif (!ret)\n \t\tdcs = BTRFS_DC_SETUP;\n-\telse if (ret == -ENOSPC)\n+\telse if (ret == -ENOSPC) {\n+            WARN_ON(1);\n+            btrfs_warn(fs_info, \"chunk allocation failed due to ENOSPC\");\n \t\tset_bit(BTRFS_TRANS_CACHE_ENOSPC, &trans->transaction->flags);\n \n out_put:\n@@ -3836,6 +3840,8 @@ static struct btrfs_block_group *do_chunk_alloc(struct btrfs_trans_handle *trans\n \t *    then adds back the entry to the block group cache).\n \t */\n \tif (ret == -ENOSPC) {\n+            WARN_ON(1);\n+            btrfs_warn(fs_info, \"chunk allocation failed due to ENOSPC\"); {\n \t\tconst u64 sys_flags = btrfs_system_alloc_profile(trans->fs_info);\n \t\tstruct btrfs_block_group *sys_bg;\n \n@@ -4102,7 +4108,9 @@ int btrfs_chunk_alloc(struct btrfs_trans_handle *trans, u64 flags,\n \n \tspin_lock(&space_info->lock);\n \tif (ret < 0) {\n-\t\tif (ret == -ENOSPC)\n+\t\tif (ret == -ENOSPC) {\n+            WARN_ON(1);\n+            btrfs_warn(fs_info, \"chunk allocation failed due to ENOSPC\");\n \t\t\tspace_info->full = 1;\n \t\telse\n \t\t\tgoto out;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/btrfs/block-group.c b/fs/btrfs/block-group.c\nindex 0cb1dee965a0..d7179a901efd 100644\n--- a/fs/btrfs/block-group.c\n+++ b/fs/btrfs/block-group.c\n@@ -3835,7 +3835,7 @@ static struct btrfs_block_group *do_chunk_alloc(struct btrfs_trans_handle *trans\n \t *    block group (discard removes a free space entry, discards it, and\n \t *    then adds back the entry to the block group cache).\n \t */\n-\tif (ret == -ENOSPC) {\n+\tif (ret == -ENOSPC && !space_info->full) {\n \t\tconst u64 sys_flags = btrfs_system_alloc_profile(trans->fs_info);\n \t\tstruct btrfs_block_group *sys_bg;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/btrfs/block-group.c b/fs/btrfs/block-group.c\nindex 0cb1dee965a0..62460e0ac3ec 100644\n--- a/fs/btrfs/block-group.c\n+++ b/fs/btrfs/block-group.c\n@@ -3839,7 +3839,16 @@ static struct btrfs_block_group *do_chunk_alloc(struct btrfs_trans_handle *trans\n \t\tconst u64 sys_flags = btrfs_system_alloc_profile(trans->fs_info);\n \t\tstruct btrfs_block_group *sys_bg;\n \n-\t\tsys_bg = btrfs_create_chunk(trans, sys_flags);\n+\t\tint retries = 3;\n+        while (retries-- > 0) {\n+            sys_bg = btrfs_create_chunk(trans, sys_flags);\n+            if (!IS_ERR(sys_bg))\n+                break;\n+            ret = PTR_ERR(sys_bg);\n+            if (ret != -ENOSPC)\n+                break;\n+        }\n+        if (IS_ERR(sys_bg)) {\n \t\tif (IS_ERR(sys_bg)) {\n \t\t\tret = PTR_ERR(sys_bg);\n \t\t\tbtrfs_abort_transaction(trans, ret);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "38efa4618c3379cf98642b9379d6e340b14d2702": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 91de361ea9ab..34228ddf11a6 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) {\n+            ret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\n+        } else {\n+            return -EINVAL;\n+        }\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..a45b8c18038a 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -2773,7 +2773,8 @@ 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) return -EINVAL;\n+        ret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\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..a45b8c18038a 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -2773,7 +2773,8 @@ 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) return -EINVAL;\n+        ret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\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..82fb6ea2e308 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -2773,7 +2773,8 @@ 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 (unlikely(!kiocb->ki_filp)) return -EBADF;\n+        ret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\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..34228ddf11a6 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) {\n+            ret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\n+        } else {\n+            return -EINVAL;\n+        }\n \t\tif (unlikely(ret < 0))\n \t\t\treturn ret;\n \t\telse if (ret)\n"
        ],
        "error": []
    },
    "11acaa6d5c31d0b655997957f725da4a3cc05435": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex d1f1da6820fb..13df7cb41605 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+        btrfs_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..04207d355460 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -1956,6 +1956,7 @@ static void cleanup_transaction(struct btrfs_trans_handle *trans, int err)\n \tWARN_ON(refcount_read(&trans->use_count) > 1);\n \n \tbtrfs_abort_transaction(trans, err);\n+btrfs_warn(fs_info, \"Cleaning up aborted transaction with error: %d\", err);\n \n \tspin_lock(&fs_info->trans_lock);\n \n",
            "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex d1f1da6820fb..5971e64618d0 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -2526,6 +2526,8 @@ int btrfs_commit_transaction(struct btrfs_trans_handle *trans)\n \tbtrfs_trans_release_chunk_metadata(trans);\n \ttrans->block_rsv = NULL;\n \tbtrfs_warn(fs_info, \"Skipping commit of aborted transaction.\");\n+    /* Ensure all transaction resources are released for aborted transactions */\n+    btrfs_cleanup_one_transaction(trans->transaction, fs_info);\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..7d45a2cf3fa0 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -1955,7 +1955,11 @@ static void cleanup_transaction(struct btrfs_trans_handle *trans, int err)\n \n \tWARN_ON(refcount_read(&trans->use_count) > 1);\n \n-\tbtrfs_abort_transaction(trans, err);\n+\tif (!TRANS_ABORTED(cur_trans)) {\n+        btrfs_abort_transaction(trans, err);\n+    } else {\n+        printk(KERN_INFO \"BTRFS: Transaction aborted intentionally.\");\n+    }\n \n \tspin_lock(&fs_info->trans_lock);\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex d1f1da6820fb..1d0919383785 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -2090,6 +2090,123 @@ static void update_commit_stats(struct btrfs_fs_info *fs_info, ktime_t interval)\n }\n \n int btrfs_commit_transaction(struct btrfs_trans_handle *trans)\n+{\n+    struct btrfs_fs_info *fs_info = trans->fs_info;\n+    struct btrfs_transaction *cur_trans = trans->transaction;\n+    struct btrfs_transaction *prev_trans = NULL;\n+    int ret;\n+    ktime_t start_time;\n+    ktime_t interval;\n+\n+    ASSERT(refcount_read(&trans->use_count) == 1);\n+    btrfs_trans_state_lockdep_acquire(fs_info, BTRFS_LOCKDEP_TRANS_COMMIT_START);\n+\n+    /* Stop the commit early if ->aborted is set */\n+    if (TRANS_ABORTED(cur_trans)) {\n+        ret = cur_trans->aborted;\n+        goto lockdep_trans_commit_start_release;\n+    }\n+\n+    btrfs_trans_release_metadata(trans);\n+    trans->block_rsv = NULL;\n+\n+    /* Additional check for aborted transaction */\n+    if (TRANS_ABORTED(cur_trans)) {\n+        ret = cur_trans->aborted;\n+        goto lockdep_trans_commit_start_release;\n+    }\n+\n+    /* We only want one transaction commit doing the flushing so we do not\n+     * waste a bunch of time on lock contention on the extent root node.\n+     */\n+    if (!test_and_set_bit(BTRFS_DELAYED_REFS_FLUSHING,\n+                          &cur_trans->delayed_refs.flags)) {\n+        /*\n+         * Make a pass through all the delayed refs we have so far.\n+         * Any running threads may add more while we are here.\n+         */\n+        ret = btrfs_run_delayed_refs(trans, 0);\n+        if (ret)\n+            goto lockdep_trans_commit_start_release;\n+    }\n+\n+    btrfs_create_pending_block_groups(trans);\n+\n+    if (!test_bit(BTRFS_TRANS_DIRTY_BG_RUN, &cur_trans->flags)) {\n+        int run_it = 0;\n+\n+        /* this mutex is also taken before trying to set\n+         * block groups readonly.  We need to make sure\n+         * that nobody has set a block group readonly\n+         * after a extents from that block group have been\n+         * allocated for cache files.  btrfs_set_block_group_ro\n+         * will wait for the transaction to commit if it\n+         * finds BTRFS_TRANS_DIRTY_BG_RUN set.\n+         *\n+         * The BTRFS_TRANS_DIRTY_BG_RUN flag is also used to make sure\n+         * only one process starts all the block group IO.  It wouldn't\n+         * hurt to have more than one go through, but there's no\n+         * real advantage to it either.\n+         */\n+        mutex_lock(&fs_info->ro_block_group_mutex);\n+        if (!test_and_set_bit(BTRFS_TRANS_DIRTY_BG_RUN,\n+                              &cur_trans->flags))\n+            run_it = 1;\n+        mutex_unlock(&fs_info->ro_block_group_mutex);\n+\n+        if (run_it) {\n+            ret = btrfs_start_dirty_block_groups(trans);\n+            if (ret)\n+                goto lockdep_trans_commit_start_release;\n+        }\n+    }\n+\n+    spin_lock(&fs_info->trans_lock);\n+    if (cur_trans->state >= TRANS_STATE_COMMIT_START) {\n+        enum btrfs_trans_state want_state = TRANS_STATE_COMPLETED;\n+\n+        add_pending_snapshot(trans);\n+\n+        spin_unlock(&fs_info->trans_lock);\n+        refcount_inc(&cur_trans->use_count);\n+\n+        if (trans->in_fsync)\n+            want_state = TRANS_STATE_SUPER_COMMITTED;\n+\n+        btrfs_trans_state_lockdep_release(fs_info,\n+                                          BTRFS_LOCKDEP_TRANS_COMMIT_START);\n+        ret = btrfs_end_transaction(trans);\n+        wait_for_commit(cur_trans, want_state);\n+\n+        if (TRANS_ABORTED(cur_trans))\n+            ret = cur_trans->aborted;\n+\n+        btrfs_put_transaction(cur_trans);\n+\n+        return ret;\n+    }\n+\n+    cur_trans->state = TRANS_STATE_COMMIT_START;\n+    wake_up(&fs_info->transaction_blocked_wait);\n+    btrfs_trans_state_lockdep_release(fs_info, BTRFS_LOCKDEP_TRANS_COMMIT_START);\n+\n+    /* Additional check for aborted transaction */\n+    if (TRANS_ABORTED(cur_trans)) {\n+        ret = cur_trans->aborted;\n+        goto lockdep_trans_commit_start_release;\n+    }\n+\n+    prev_trans = btrfs_commit_transaction_async(trans);\n+    interval = ktime_sub(ktime_get(), start_time);\n+    update_commit_stats(fs_info, interval);\n+\n+    btrfs_cleanup_pending_block_groups(trans);\n+\n+    if (prev_trans)\n+        wait_for_commit(prev_trans, TRANS_STATE_SUPER_COMMITTED);\n+\n+    return ret;\n+}\n {\n \tstruct btrfs_fs_info *fs_info = trans->fs_info;\n \tstruct btrfs_transaction *cur_trans = trans->transaction;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "74c4de068e77c137156235cc06a904c9baea491f": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex 1310d2d5feb3..73c628adf861 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1007,7 +1007,7 @@ int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)\n \tint err;\n \n \tspin_lock(&nilfs->ns_inode_lock);\n-\tif (ii->i_bh == NULL) {\n+\tif (ii->i_bh == NULL || !buffer_uptodate(ii->i_bh)) {\n \t\tspin_unlock(&nilfs->ns_inode_lock);\n \t\terr = nilfs_ifile_get_inode_block(ii->i_root->ifile,\n \t\t\t\t\t\t  inode->i_ino, pbh);\n",
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex 1310d2d5feb3..bfe96ca736ef 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1018,10 +1018,22 @@ int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)\n \t\t\tii->i_bh = *pbh;\n \t\telse {\n \t\t\tbrelse(*pbh);\n-\t\t\t*pbh = ii->i_bh;\n+\t\t\tif (ii->i_bh) {\n+*pbh = ii->i_bh;\n+get_bh(*pbh);\n+}\n+else {\n+return -EINVAL; /* Invalid buffer head */\n+}\n \t\t}\n \t} else\n-\t\t*pbh = ii->i_bh;\n+\t\tif (ii->i_bh) {\n+*pbh = ii->i_bh;\n+get_bh(*pbh);\n+}\n+else {\n+return -EINVAL; /* Invalid buffer head */\n+}\n \n \tget_bh(*pbh);\n \tspin_unlock(&nilfs->ns_inode_lock);\n",
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex 1310d2d5feb3..fb7234fe9711 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1018,10 +1018,12 @@ int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)\n \t\t\tii->i_bh = *pbh;\n \t\telse {\n \t\t\tbrelse(*pbh);\n-\t\t\t*pbh = ii->i_bh;\n+\t\t\tif (ii->i_bh != NULL)\n+*pbh = ii->i_bh;\n \t\t}\n \t} else\n-\t\t*pbh = ii->i_bh;\n+\t\tif (ii->i_bh != NULL)\n+*pbh = ii->i_bh;\n \n \tget_bh(*pbh);\n \tspin_unlock(&nilfs->ns_inode_lock);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex 1310d2d5feb3..a19aa5d0a55f 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1001,6 +1001,41 @@ int nilfs_permission(struct mnt_idmap *idmap, struct inode *inode,\n }\n \n int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)\n+{\n+    struct the_nilfs *nilfs = inode->i_sb->s_fs_info;\n+    struct nilfs_inode_info *ii = NILFS_I(inode);\n+    int err;\n+\n+    spin_lock(&nilfs->ns_inode_lock);\n+    if (ii->i_bh == NULL) {\n+        spin_unlock(&nilfs->ns_inode_lock);\n+        err = nilfs_ifile_get_inode_block(ii->i_root->ifile,\n+                                          inode->i_ino, pbh);\n+        if (unlikely(err))\n+            return err;\n+        spin_lock(&nilfs->ns_inode_lock);\n+        if (ii->i_bh == NULL) {\n+            ii->i_bh = *pbh;\n+        } else {\n+            brelse(*pbh);\n+            *pbh = ii->i_bh;\n+        }\n+    } else {\n+        *pbh = ii->i_bh;\n+    }\n+\n+    get_bh(*pbh);\n+    spin_unlock(&nilfs->ns_inode_lock);\n+\n+    if (!*pbh) {\n+        nilfs_warn(inode->i_sb, \"buffer head is NULL after unlock\");\n+        return -EIO;\n+    }\n+\n+    return 0;\n+}\n+\n+int nilfs_inode_dirty(struct inode *inode)\n {\n \tstruct the_nilfs *nilfs = inode->i_sb->s_fs_info;\n \tstruct nilfs_inode_info *ii = NILFS_I(inode);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex 1310d2d5feb3..f36b8fc5cd95 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1001,6 +1001,36 @@ int nilfs_permission(struct mnt_idmap *idmap, struct inode *inode,\n }\n \n int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)\n+{\n+    struct the_nilfs *nilfs = inode->i_sb->s_fs_info;\n+    struct nilfs_inode_info *ii = NILFS_I(inode);\n+    int err;\n+\n+    spin_lock(&nilfs->ns_inode_lock);\n+    if (ii->i_bh == NULL) {\n+        spin_unlock(&nilfs->ns_inode_lock);\n+        err = nilfs_ifile_get_inode_block(ii->i_root->ifile,\n+                                          inode->i_ino, pbh);\n+        if (unlikely(err))\n+            return err;\n+        spin_lock(&nilfs->ns_inode_lock);\n+        if (ii->i_bh == NULL)\n+            ii->i_bh = *pbh;\n+        else {\n+            brelse(*pbh);\n+            *pbh = ii->i_bh;\n+        }\n+    } else if (ii->i_bh) { // Check if buffer head is still valid\n+        *pbh = ii->i_bh;\n+    } else {\n+        spin_unlock(&nilfs->ns_inode_lock);\n+        return -EFAULT; // Return error if buffer head is invalid\n+    }\n+\n+    get_bh(*pbh);\n+    spin_unlock(&nilfs->ns_inode_lock);\n+    return 0;\n+}\n {\n \tstruct the_nilfs *nilfs = inode->i_sb->s_fs_info;\n \tstruct nilfs_inode_info *ii = NILFS_I(inode);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "032c91d1b0189a2a36f47141f9c3331f8c09d7b1": {
        "non_crash": [
            "diff --git a/kernel/jump_label.c b/kernel/jump_label.c\nindex 714ac4c3b556..cd77a1c45d1c 100644\n--- a/kernel/jump_label.c\n+++ b/kernel/jump_label.c\n@@ -221,7 +221,10 @@ static bool static_key_slow_try_dec(struct static_key *key)\n {\n \tint val;\n \n-\tval = atomic_fetch_add_unless(&key->enabled, -1, 1);\n+\tif (atomic_read(&key->enabled) <= 0)\n+        return false;\n+\n+    val = atomic_fetch_add_unless(&key->enabled, -1, 1);\n \tif (val == 1)\n \t\treturn false;\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/jump_label.c b/kernel/jump_label.c\nindex 714ac4c3b556..d052c0cfb736 100644\n--- a/kernel/jump_label.c\n+++ b/kernel/jump_label.c\n@@ -221,7 +221,12 @@ static bool static_key_slow_try_dec(struct static_key *key)\n {\n \tint val;\n \n-\tval = atomic_fetch_add_unless(&key->enabled, -1, 1);\n+\tval = atomic_read(&key->enabled);\n+    if (val <= 0) {\n+        WARN(val <= 0, \"jump label: negative or zero count!\\n\");\n+        return false;\n+    }\n+    val = atomic_fetch_add_unless(&key->enabled, -1, 1);\n \tif (val == 1)\n \t\treturn false;\n \n",
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 816052089b33..de1290661c7f 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 (rcu_access_pointer(basechain->stats))\n+            static_branch_dec(&nft_counters_enabled);\n \t\t\tfree_percpu(rcu_dereference_raw(basechain->stats));\n \t\t}\n \t\tkfree(chain->name);\n",
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 816052089b33..f2a1f00158f1 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -1877,7 +1877,10 @@ 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 (rcu_access_pointer(basechain->stats)) {\n+            static_branch_dec(&nft_counters_enabled);\n+            free_percpu(rcu_dereference_raw(basechain->stats));\n+        }\n \t\t\tfree_percpu(rcu_dereference_raw(basechain->stats));\n \t\t}\n \t\tkfree(chain->name);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 816052089b33..ef83f0f7db71 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -1829,14 +1829,14 @@ static void nft_chain_stats_replace(struct nft_trans *trans)\n {\n \tstruct nft_base_chain *chain = nft_base_chain(trans->ctx.chain);\n \n-\tif (!nft_trans_chain_stats(trans))\n+\tif (!nft_trans_chain_stats(trans) && rcu_access_pointer(basechain->stats))\n \t\treturn;\n \n \tnft_trans_chain_stats(trans) =\n \t\trcu_replace_pointer(chain->stats, nft_trans_chain_stats(trans),\n \t\t\t\t    lockdep_commit_lock_is_held(trans->ctx.net));\n \n-\tif (!nft_trans_chain_stats(trans))\n+\tif (!nft_trans_chain_stats(trans) && rcu_access_pointer(basechain->stats))\n \t\tstatic_branch_inc(&nft_counters_enabled);\n }\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "b139c306850a825c7656508c3773dbea33eb56a1": {
        "non_crash": [
            "diff --git a/fs/xfs/xfs_dquot.c b/fs/xfs/xfs_dquot.c\nindex 8fb90da89787..cc727bd36652 100644\n--- a/fs/xfs/xfs_dquot.c\n+++ b/fs/xfs/xfs_dquot.c\n@@ -798,7 +798,10 @@ 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+            mutex_unlock(&qi->qi_tree_lock);\n+            return error;\n+        }\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..485961697b7f 100644\n--- a/fs/xfs/xfs_dquot.c\n+++ b/fs/xfs/xfs_dquot.c\n@@ -798,7 +798,11 @@ 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+pr_err(\"Unexpected error in radix_tree_insert: %d\\n\", error);\n+mutex_unlock(&qi->qi_tree_lock);\n+return error;\n+}\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..36b34cc2ff61 100644\n--- a/fs/xfs/xfs_dquot.c\n+++ b/fs/xfs/xfs_dquot.c\n@@ -798,7 +798,10 @@ 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+mutex_unlock(&qi->qi_tree_lock);\n+return error;\n+}\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..27403783c828 100644\n--- a/fs/xfs/xfs_dquot.c\n+++ b/fs/xfs/xfs_dquot.c\n@@ -798,7 +798,7 @@ 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\tpr_info(\"Duplicate entry found in radix tree: %d\\n\", id);\n \t\tmutex_unlock(&qi->qi_tree_lock);\n \t\ttrace_xfs_dqget_dup(dqp);\n \t\treturn error;\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/xfs/xfs_dquot.c b/fs/xfs/xfs_dquot.c\nindex 8fb90da89787..d317caa422af 100644\n--- a/fs/xfs/xfs_dquot.c\n+++ b/fs/xfs/xfs_dquot.c\n@@ -798,7 +798,10 @@ 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+pr_warn(\"Unexpected error in dqget cache insert: %d\\n\", error);\n+WARN_ON(1);\n+}\n \t\tmutex_unlock(&qi->qi_tree_lock);\n \t\ttrace_xfs_dqget_dup(dqp);\n \t\treturn error;\n"
        ],
        "error": []
    },
    "7a56fd91f3db3a79c974b34e1aac3879898d6f29": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 3ac7c8c1548d..eb0a45fce308 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -424,7 +424,8 @@ static void __nf_unregister_net_hook(struct net *net, int pf,\n \n void nf_unregister_net_hook(struct net *net, const struct nf_hook_ops *reg)\n {\n-\tif (reg->pf == NFPROTO_INET) {\n+\tpr_debug(\"Registering hook for pf: %d, hooknum: %d\\n\", reg->pf, reg->hooknum);\n+    if (reg->pf == NFPROTO_INET) {\n \t\t__nf_unregister_net_hook(net, NFPROTO_IPV4, reg);\n \t\t__nf_unregister_net_hook(net, NFPROTO_IPV6, reg);\n \t} else {\n@@ -450,7 +451,8 @@ int nf_register_net_hook(struct net *net, const struct nf_hook_ops *reg)\n {\n \tint err;\n \n-\tif (reg->pf == NFPROTO_INET) {\n+\tpr_debug(\"Registering hook for pf: %d, hooknum: %d\\n\", reg->pf, reg->hooknum);\n+    if (reg->pf == NFPROTO_INET) {\n \t\terr = __nf_register_net_hook(net, NFPROTO_IPV4, reg);\n \t\tif (err < 0)\n \t\t\treturn err;\n",
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 3ac7c8c1548d..3c1070d33399 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@@ -439,7 +439,7 @@ void nf_hook_entries_delete_raw(struct nf_hook_entries __rcu **pp,\n \tstruct nf_hook_entries *p;\n \n \tp = rcu_dereference_raw(*pp);\n-\tif (nf_remove_net_hook(p, reg)) {\n+\tif (p && nf_remove_net_hook(p, reg)) {\n \t\tp = __nf_hook_entries_try_shrink(p, pp);\n \t\tnf_hook_entries_free(p);\n \t}\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 3ac7c8c1548d..ed3e343e4fce 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -422,7 +422,35 @@ static void __nf_unregister_net_hook(struct net *net, int pf,\n \tnf_hook_entries_free(p);\n }\n \n+bool nf_is_hook_registered(struct net *net, int pf, const struct nf_hook_ops *reg) {\n+    struct nf_hook_entries __rcu **pp;\n+    struct nf_hook_entries *p;\n+\n+    pp = nf_hook_entry_head(net, pf, reg->hooknum, reg->dev);\n+    if (!pp)\n+        return false;\n+\n+    p = nf_entry_dereference(*pp);\n+    if (!p)\n+        return false;\n+\n+    return nf_remove_net_hook(p, reg);\n+}\n+\n+bool nf_is_hook_registered(struct net *net, int pf, const struct nf_hook_ops *reg);\n+\n void nf_unregister_net_hook(struct net *net, const struct nf_hook_ops *reg)\n+{\n+    if (reg->pf == NFPROTO_INET) {\n+        if (nf_is_hook_registered(net, NFPROTO_IPV4, reg))\n+            __nf_unregister_net_hook(net, NFPROTO_IPV4, reg);\n+        if (nf_is_hook_registered(net, NFPROTO_IPV6, reg))\n+            __nf_unregister_net_hook(net, NFPROTO_IPV6, reg);\n+    } else {\n+        if (nf_is_hook_registered(net, reg->pf, reg))\n+            __nf_unregister_net_hook(net, reg->pf, reg);\n+    }\n+}\n {\n \tif (reg->pf == NFPROTO_INET) {\n \t\t__nf_unregister_net_hook(net, NFPROTO_IPV4, reg);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 3ac7c8c1548d..7f0198ab32dc 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -396,7 +396,10 @@ 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+        WARN_ON_ONCE(!p);\n+        return;\n+    }\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 3ac7c8c1548d..2ee00eb79e1f 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -312,6 +312,9 @@ nf_hook_entry_head(struct net *net, int pf, unsigned int hooknum,\n }\n \n static int __nf_register_net_hook(struct net *net, int pf,\n+                                     const struct nf_hook_ops *reg) {\n+    pr_info(\"Registering hook: pf %d, hooknum %d\\n\", pf, reg->hooknum);\n+    struct nf_hook_entries *p, *new_hooks;\n \t\t\t\t  const struct nf_hook_ops *reg)\n {\n \tstruct nf_hook_entries *p, *new_hooks;\n@@ -384,6 +387,9 @@ static bool nf_remove_net_hook(struct nf_hook_entries *old,\n }\n \n static void __nf_unregister_net_hook(struct net *net, int pf,\n+                                     const struct nf_hook_ops *reg) {\n+    pr_info(\"Unregistering hook: pf %d, hooknum %d\\n\", pf, reg->hooknum);\n+    struct nf_hook_entries __rcu **pp;\n \t\t\t\t     const struct nf_hook_ops *reg)\n {\n \tstruct nf_hook_entries __rcu **pp;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "72c3096dbc86cdffde7afa178a39dc1a29dec67a": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/exfat/dir.c b/fs/exfat/dir.c\nindex bc48f3329921..a3550b830d03 100644\n--- a/fs/exfat/dir.c\n+++ b/fs/exfat/dir.c\n@@ -233,7 +233,8 @@ 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+\t/* Release sbi->s_lock before any operations that might acquire mmap_lock */\n+    mutex_lock(&EXFAT_SB(sb)->s_lock);\n \n \tcpos = ctx->pos;\n \tif (!dir_emit_dots(file, ctx))\n@@ -290,7 +291,8 @@ static int exfat_iterate(struct file *file, struct dir_context *ctx)\n \tif (!dir_emit(ctx, nb->lfn, strlen(nb->lfn), inum,\n \t\t\t(de.attr & ATTR_SUBDIR) ? DT_DIR : DT_REG))\n \t\tgoto out_unlocked;\n-\tmutex_lock(&EXFAT_SB(sb)->s_lock);\n+\t/* Release sbi->s_lock before any operations that might acquire mmap_lock */\n+    mutex_lock(&EXFAT_SB(sb)->s_lock);\n \tctx->pos = cpos;\n \tgoto get_new;\n \n",
            "diff --git a/fs/exfat/dir.c b/fs/exfat/dir.c\nindex bc48f3329921..3aefe73fa976 100644\n--- a/fs/exfat/dir.c\n+++ b/fs/exfat/dir.c\n@@ -233,7 +233,8 @@ 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+\t// Ensure operations that might acquire mm->mmap_lock are deferred\n+mutex_lock(&EXFAT_SB(sb)->s_lock);\n \n \tcpos = ctx->pos;\n \tif (!dir_emit_dots(file, ctx))\n@@ -290,7 +291,8 @@ static int exfat_iterate(struct file *file, struct dir_context *ctx)\n \tif (!dir_emit(ctx, nb->lfn, strlen(nb->lfn), inum,\n \t\t\t(de.attr & ATTR_SUBDIR) ? DT_DIR : DT_REG))\n \t\tgoto out_unlocked;\n-\tmutex_lock(&EXFAT_SB(sb)->s_lock);\n+\t// Ensure operations that might acquire mm->mmap_lock are deferred\n+mutex_lock(&EXFAT_SB(sb)->s_lock);\n \tctx->pos = cpos;\n \tgoto get_new;\n \n",
            "diff --git a/fs/exfat/dir.c b/fs/exfat/dir.c\nindex bc48f3329921..8bf18279e67b 100644\n--- a/fs/exfat/dir.c\n+++ b/fs/exfat/dir.c\n@@ -233,7 +233,8 @@ 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+\t// Ensure s_lock is released before acquiring mm->mmap_lock\n+    mutex_lock(&EXFAT_SB(sb)->s_lock);\n \n \tcpos = ctx->pos;\n \tif (!dir_emit_dots(file, ctx))\n@@ -290,7 +291,8 @@ static int exfat_iterate(struct file *file, struct dir_context *ctx)\n \tif (!dir_emit(ctx, nb->lfn, strlen(nb->lfn), inum,\n \t\t\t(de.attr & ATTR_SUBDIR) ? DT_DIR : DT_REG))\n \t\tgoto out_unlocked;\n-\tmutex_lock(&EXFAT_SB(sb)->s_lock);\n+\t// Ensure s_lock is released before acquiring mm->mmap_lock\n+    mutex_lock(&EXFAT_SB(sb)->s_lock);\n \tctx->pos = cpos;\n \tgoto get_new;\n \n"
        ],
        "error": []
    },
    "e90732b9b16086b7f6207149157d36c0faea59f1": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/crypto/acompress.c b/crypto/acompress.c\nindex c32c72048a1c..7c45a24c847c 100644\n--- a/crypto/acompress.c\n+++ b/crypto/acompress.c\n@@ -144,6 +144,7 @@ void acomp_request_free(struct acomp_req *req)\n \t}\n \n \t__acomp_request_free(req);\n+    crypto_free_tfm(tfm);\n }\n EXPORT_SYMBOL_GPL(acomp_request_free);\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/crypto/api.c b/crypto/api.c\nindex 64f2d365a8e9..ddfa6d5f1266 100644\n--- a/crypto/api.c\n+++ b/crypto/api.c\n@@ -514,7 +514,8 @@ void *crypto_create_tfm_node(struct crypto_alg *alg,\n \t\tgoto out_free_tfm;\n \n \tif (!tfm->exit && alg->cra_init && (err = alg->cra_init(tfm)))\n-\t\tgoto cra_init_failed;\n+\t\tkfree(mem);\n+goto cra_init_failed;\n \n \tgoto out;\n \n",
                "error_message": "Failed to set up instance"
            },
            {
                "patch": "diff --git a/crypto/api.c b/crypto/api.c\nindex 64f2d365a8e9..6a30b53b0382 100644\n--- a/crypto/api.c\n+++ b/crypto/api.c\n@@ -426,6 +426,7 @@ struct crypto_tfm *__crypto_alloc_tfm(struct crypto_alg *alg, u32 type,\n \t\tcrypto_shoot_alg(alg);\n \tkfree(tfm);\n out_err:\n+    kfree(mem);\n \ttfm = ERR_PTR(err);\n out:\n \treturn tfm;\n@@ -525,6 +526,7 @@ void *crypto_create_tfm_node(struct crypto_alg *alg,\n \t\tcrypto_shoot_alg(alg);\n \tkfree(mem);\n out_err:\n+    kfree(mem);\n \tmem = ERR_PTR(err);\n out:\n \treturn mem;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "1a351beaed9d438481f1fc96aa336a25f71a2ae1": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex fbde494444b8..472f1863b8bc 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -4754,7 +4754,12 @@ static inline void *mas_next_entry(struct ma_state *mas, unsigned long limit)\n \t}\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+            mas_rewalk(mas, last);\n+            goto retry;\n+        }\n+\n+        entry = 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",
            "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex fbde494444b8..df4c5f98e7dd 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -4755,7 +4755,7 @@ 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\tif (unlikely(ma_dead_node(node) || node == NULL)) {\n \t\t\tmas_rewalk(mas, last);\n \t\t\tgoto retry;\n \t\t}\n",
            "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex fbde494444b8..2a8e1bb31265 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -4755,7 +4755,7 @@ 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\tif (unlikely(ma_dead_node(node) || !node)) {\n \t\t\tmas_rewalk(mas, last);\n \t\t\tgoto retry;\n \t\t}\n",
            "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex fbde494444b8..c78a6fbb0bf6 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -4711,7 +4711,8 @@ static inline void mas_rewalk(struct ma_state *mas, unsigned long index)\n {\n \n retry:\n-\tmas_set(mas, index);\n+\tif (!mas_is_none(mas))\n+        mas_set(mas, index);\n \tmas_state_walk(mas);\n \tif (mas_is_start(mas))\n \t\tgoto retry;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex fbde494444b8..8977a67cea61 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -5771,6 +5771,7 @@ void mas_destroy(struct ma_state *mas)\n \t\tkmem_cache_free(maple_node_cache, node);\n \t}\n \tmas->alloc = NULL;\n+    mas->node = NULL;\n }\n \n /*\n",
                "error_message": "Failed to set up instance"
            }
        ]
    },
    "6fe3c93209dfd48301d1cad0ab1efd53c87462e1": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/module/main.c b/kernel/module/main.c\nindex 834de86ebe35..e48f00da8315 100644\n--- a/kernel/module/main.c\n+++ b/kernel/module/main.c\n@@ -2919,7 +2919,10 @@ static int load_module(struct load_info *info, const char __user *uargs,\n \tflush_module_icache(mod);\n \n \t/* Now copy in args */\n-\tmod->args = strndup_user(uargs, ~0UL >> 1);\n+\tif (!uargs || !access_ok(uargs, sizeof(char))) {\n+        return -EINVAL;\n+    }\n+    mod->args = strndup_user(uargs, ~0UL >> 1);\n \tif (IS_ERR(mod->args)) {\n \t\terr = PTR_ERR(mod->args);\n \t\tgoto free_arch_cleanup;\n",
            "diff --git a/kernel/module/main.c b/kernel/module/main.c\nindex 834de86ebe35..5e2f6957ad18 100644\n--- a/kernel/module/main.c\n+++ b/kernel/module/main.c\n@@ -3126,7 +3126,11 @@ static int init_module_from_file(struct file *f, const char __user * uargs, int\n \t\treturn idem.ret;\n \t}\n \n-\tlen = kernel_read_file(f, 0, &buf, INT_MAX, NULL, READING_MODULE);\n+\tif (!access_ok(uargs, sizeof(*uargs))) {\n+        return -EFAULT;\n+    }\n+\n+    len = kernel_read_file(f, 0, &buf, INT_MAX, NULL, READING_MODULE);\n \tif (len < 0) {\n \t\tmod_stat_inc(&failed_kreads);\n \t\tmod_stat_add_long(len, &invalid_kread_bytes);\n",
            "diff --git a/kernel/module/main.c b/kernel/module/main.c\nindex 834de86ebe35..66624d87870d 100644\n--- a/kernel/module/main.c\n+++ b/kernel/module/main.c\n@@ -2919,7 +2919,11 @@ static int load_module(struct load_info *info, const char __user *uargs,\n \tflush_module_icache(mod);\n \n \t/* Now copy in args */\n-\tmod->args = strndup_user(uargs, ~0UL >> 1);\n+\tif (!access_ok(uargs, ~0UL >> 1)) {\n+    err = -EFAULT;\n+    goto free_arch_cleanup;\n+}\n+mod->args = strndup_user(uargs, ~0UL >> 1);\n \tif (IS_ERR(mod->args)) {\n \t\terr = PTR_ERR(mod->args);\n \t\tgoto free_arch_cleanup;\n",
            "diff --git a/kernel/module/main.c b/kernel/module/main.c\nindex 834de86ebe35..3745a645fdeb 100644\n--- a/kernel/module/main.c\n+++ b/kernel/module/main.c\n@@ -2919,7 +2919,8 @@ static int load_module(struct load_info *info, const char __user *uargs,\n \tflush_module_icache(mod);\n \n \t/* Now copy in args */\n-\tmod->args = strndup_user(uargs, ~0UL >> 1);\n+\tif (!uargs || !access_ok(uargs, ~0UL >> 1)) return -EFAULT;\n+    mod->args = strndup_user(uargs, ~0UL >> 1);\n \tif (IS_ERR(mod->args)) {\n \t\terr = PTR_ERR(mod->args);\n \t\tgoto free_arch_cleanup;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/kernel/module/main.c b/kernel/module/main.c\nindex 834de86ebe35..aa43269eaf09 100644\n--- a/kernel/module/main.c\n+++ b/kernel/module/main.c\n@@ -2919,7 +2919,9 @@ static int load_module(struct load_info *info, const char __user *uargs,\n \tflush_module_icache(mod);\n \n \t/* Now copy in args */\n-\tmod->args = strndup_user(uargs, ~0UL >> 1);\n+\tif (!uargs || !access_ok(uargs, MAX_UARGS_LEN))\n+        return -EFAULT;\n+    mod->args = strndup_user(uargs, MAX_UARGS_LEN);\n \tif (IS_ERR(mod->args)) {\n \t\terr = PTR_ERR(mod->args);\n \t\tgoto free_arch_cleanup;\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..40a582cc7b32 100644\n--- a/drivers/net/wireless/virtual/mac80211_hwsim.c\n+++ b/drivers/net/wireless/virtual/mac80211_hwsim.c\n@@ -5970,7 +5970,8 @@ static int hwsim_new_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \t\tparam.pmsr_capa = pmsr_capa;\n \t}\n \n-\tret = mac80211_hwsim_new_radio(info, &param);\n+\tret = ret = mac80211_hwsim_new_radio(info, &param);\n+    goto out_free;\n \n out_free:\n \tkfree(hwname);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/net/wireless/virtual/mac80211_hwsim.c b/drivers/net/wireless/virtual/mac80211_hwsim.c\nindex 9a8faaf4c6b6..c63447c480a1 100644\n--- a/drivers/net/wireless/virtual/mac80211_hwsim.c\n+++ b/drivers/net/wireless/virtual/mac80211_hwsim.c\n@@ -564,7 +564,8 @@ static int mac80211_hwsim_vendor_cmd_test(struct wiphy *wiphy,\n \tif (err)\n \t\treturn err;\n \tif (!tb[QCA_WLAN_VENDOR_ATTR_TEST])\n-\t\treturn -EINVAL;\n+\t\tret = -EINVAL;\n+    goto out_free;\n \tval = nla_get_u32(tb[QCA_WLAN_VENDOR_ATTR_TEST]);\n \twiphy_dbg(wiphy, \"%s: test=%u\\n\", __func__, val);\n \n@@ -1081,11 +1082,13 @@ static int hwsim_fops_ps_write(void *dat, u64 val)\n \n \tif (val != PS_DISABLED && val != PS_ENABLED && val != PS_AUTO_POLL &&\n \t    val != PS_MANUAL_POLL)\n-\t\treturn -EINVAL;\n+\t\tret = -EINVAL;\n+    goto out_free;\n \n \tif (val == PS_MANUAL_POLL) {\n \t\tif (data->ps != PS_ENABLED)\n-\t\t\treturn -EINVAL;\n+\t\t\tret = -EINVAL;\n+    goto out_free;\n \t\tlocal_bh_disable();\n \t\tieee80211_iterate_active_interfaces_atomic(\n \t\t\tdata->hw, IEEE80211_IFACE_ITER_NORMAL,\n@@ -1157,7 +1160,8 @@ static int hwsim_fops_rx_rssi_write(void *dat, u64 val)\n \tint rssi = (int)val;\n \n \tif (rssi >= 0 || rssi < -100)\n-\t\treturn -EINVAL;\n+\t\tret = -EINVAL;\n+    goto out_free;\n \n \tdata->rx_rssi = rssi;\n \treturn 0;\n@@ -2751,12 +2755,14 @@ static int mac80211_hwsim_testmode_cmd(struct ieee80211_hw *hw,\n \t\treturn err;\n \n \tif (!tb[HWSIM_TM_ATTR_CMD])\n-\t\treturn -EINVAL;\n+\t\tret = -EINVAL;\n+    goto out_free;\n \n \tswitch (nla_get_u32(tb[HWSIM_TM_ATTR_CMD])) {\n \tcase HWSIM_TM_CMD_SET_PS:\n \t\tif (!tb[HWSIM_TM_ATTR_PS])\n-\t\t\treturn -EINVAL;\n+\t\t\tret = -EINVAL;\n+    goto out_free;\n \t\tps = nla_get_u32(tb[HWSIM_TM_ATTR_PS]);\n \t\treturn hwsim_fops_ps_write(hwsim, ps);\n \tcase HWSIM_TM_CMD_GET_PS:\n@@ -3254,7 +3260,8 @@ static int mac80211_hwsim_send_pmsr_ftm_request_peer(struct sk_buff *msg,\n \tstruct nlattr *ftm;\n \n \tif (!request->requested)\n-\t\treturn -EINVAL;\n+\t\tret = -EINVAL;\n+    goto out_free;\n \n \tftm = nla_nest_start(msg, NL80211_PMSR_TYPE_FTM);\n \tif (!ftm)\n@@ -3716,7 +3723,8 @@ static int mac80211_hwsim_parse_pmsr_resp(struct nlattr *resp,\n \t\t\tbreak;\n \t\tdefault:\n \t\t\tNL_SET_ERR_MSG_ATTR(info->extack, pmsr, \"Unknown pmsr resp type\");\n-\t\t\treturn -EINVAL;\n+\t\t\tret = -EINVAL;\n+    goto out_free;\n \t\t}\n \t}\n \n@@ -3731,7 +3739,8 @@ static int mac80211_hwsim_parse_pmsr_result(struct nlattr *peer,\n \tint ret;\n \n \tif (!peer)\n-\t\treturn -EINVAL;\n+\t\tret = -EINVAL;\n+    goto out_free;\n \n \tret = nla_parse_nested(tb, NL80211_PMSR_PEER_ATTR_MAX, peer,\n \t\t\t       hwsim_pmsr_peer_result_policy, info->extack);\n@@ -3761,12 +3770,14 @@ static int hwsim_pmsr_report_nl(struct sk_buff *msg, struct genl_info *info)\n \tint rem;\n \n \tif (!info->attrs[HWSIM_ATTR_ADDR_TRANSMITTER])\n-\t\treturn -EINVAL;\n+\t\tret = -EINVAL;\n+    goto out_free;\n \n \tsrc = nla_data(info->attrs[HWSIM_ATTR_ADDR_TRANSMITTER]);\n \tdata = get_hwsim_data_ref_from_addr(src);\n \tif (!data)\n-\t\treturn -EINVAL;\n+\t\tret = -EINVAL;\n+    goto out_free;\n \n \tmutex_lock(&data->mutex);\n \tif (!data->pmsr_request) {\n@@ -4948,7 +4959,8 @@ static int mac80211_hwsim_new_radio(struct genl_info *info,\n \tint n_limits = 0;\n \n \tif (WARN_ON(param->channels > 1 && !param->use_chanctx))\n-\t\treturn -EINVAL;\n+\t\tret = -EINVAL;\n+    goto out_free;\n \n \tspin_lock_bh(&hwsim_radio_lock);\n \tidx = hwsim_radio_idx++;\n@@ -5591,7 +5603,8 @@ static int hwsim_tx_info_frame_received_nl(struct sk_buff *skb_2,\n \tieee80211_tx_status_irqsafe(data2->hw, skb);\n \treturn 0;\n out:\n-\treturn -EINVAL;\n+\tret = -EINVAL;\n+    goto out_free;\n \n }\n \n@@ -5706,7 +5719,8 @@ static int hwsim_cloned_frame_received_nl(struct sk_buff *skb_2,\n \tpr_debug(\"mac80211_hwsim: error occurred in %s\\n\", __func__);\n out:\n \tdev_kfree_skb(skb);\n-\treturn -EINVAL;\n+\tret = -EINVAL;\n+    goto out_free;\n }\n \n static int hwsim_register_received_nl(struct sk_buff *skb_2,\n@@ -5773,7 +5787,8 @@ static int parse_ftm_capa(const struct nlattr *ftm_capa, struct cfg80211_pmsr_ca\n \t\t\t       NULL);\n \tif (ret) {\n \t\tNL_SET_ERR_MSG_ATTR(info->extack, ftm_capa, \"malformed FTM capability\");\n-\t\treturn -EINVAL;\n+\t\tret = -EINVAL;\n+    goto out_free;\n \t}\n \n \tout->ftm.supported = 1;\n@@ -5808,7 +5823,8 @@ static int parse_pmsr_capa(const struct nlattr *pmsr_capa, struct cfg80211_pmsr_\n \tret = nla_parse_nested(tb, NL80211_PMSR_ATTR_MAX, pmsr_capa, hwsim_pmsr_capa_policy, NULL);\n \tif (ret) {\n \t\tNL_SET_ERR_MSG_ATTR(info->extack, pmsr_capa, \"malformed PMSR capability\");\n-\t\treturn -EINVAL;\n+\t\tret = -EINVAL;\n+    goto out_free;\n \t}\n \n \tif (tb[NL80211_PMSR_ATTR_MAX_PEERS])\n@@ -5819,7 +5835,8 @@ static int parse_pmsr_capa(const struct nlattr *pmsr_capa, struct cfg80211_pmsr_\n \tif (!tb[NL80211_PMSR_ATTR_TYPE_CAPA]) {\n \t\tNL_SET_ERR_MSG_ATTR(info->extack, tb[NL80211_PMSR_ATTR_TYPE_CAPA],\n \t\t\t\t    \"malformed PMSR type\");\n-\t\treturn -EINVAL;\n+\t\tret = -EINVAL;\n+    goto out_free;\n \t}\n \n \tnla_for_each_nested(nla, tb[NL80211_PMSR_ATTR_TYPE_CAPA], size) {\n@@ -5829,7 +5846,8 @@ static int parse_pmsr_capa(const struct nlattr *pmsr_capa, struct cfg80211_pmsr_\n \t\t\tbreak;\n \t\tdefault:\n \t\t\tNL_SET_ERR_MSG_ATTR(info->extack, nla, \"unsupported measurement type\");\n-\t\t\treturn -EINVAL;\n+\t\t\tret = -EINVAL;\n+    goto out_free;\n \t\t}\n \t}\n \n@@ -5853,7 +5871,8 @@ static int hwsim_new_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \n \tif (param.channels < 1) {\n \t\tGENL_SET_ERR_MSG(info, \"must have at least one channel\");\n-\t\treturn -EINVAL;\n+\t\tret = -EINVAL;\n+    goto out_free;\n \t}\n \n \tif (info->attrs[HWSIM_ATTR_NO_VIF])\n@@ -5872,7 +5891,8 @@ static int hwsim_new_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \t\tu32 idx = nla_get_u32(info->attrs[HWSIM_ATTR_REG_CUSTOM_REG]);\n \n \t\tif (idx >= ARRAY_SIZE(hwsim_world_regdom_custom))\n-\t\t\treturn -EINVAL;\n+\t\t\tret = -EINVAL;\n+    goto out_free;\n \n \t\tidx = array_index_nospec(idx,\n \t\t\t\t\t ARRAY_SIZE(hwsim_world_regdom_custom));\n@@ -5885,7 +5905,8 @@ static int hwsim_new_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \t\t\tGENL_SET_ERR_MSG(info,\"MAC is no valid source addr\");\n \t\t\tNL_SET_BAD_ATTR(info->extack,\n \t\t\t\t\tinfo->attrs[HWSIM_ATTR_PERM_ADDR]);\n-\t\t\treturn -EINVAL;\n+\t\t\tret = -EINVAL;\n+    goto out_free;\n \t\t}\n \n \t\tparam.perm_addr = nla_data(info->attrs[HWSIM_ATTR_PERM_ADDR]);\n@@ -5899,7 +5920,8 @@ static int hwsim_new_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \t\t\tNL_SET_ERR_MSG_ATTR(info->extack,\n \t\t\t\t\t    info->attrs[HWSIM_ATTR_IFTYPE_SUPPORT],\n \t\t\t\t\t    \"cannot support more iftypes than kernel\");\n-\t\t\treturn -EINVAL;\n+\t\t\tret = -EINVAL;\n+    goto out_free;\n \t\t}\n \t} else {\n \t\tparam.iftypes = HWSIM_IFTYPE_SUPPORT_MASK;\n@@ -5922,7 +5944,8 @@ static int hwsim_new_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \t\t\tNL_SET_ERR_MSG_ATTR(info->extack,\n \t\t\t\t\t    info->attrs[HWSIM_ATTR_CIPHER_SUPPORT],\n \t\t\t\t\t    \"bad cipher list length\");\n-\t\t\treturn -EINVAL;\n+\t\t\tret = -EINVAL;\n+    goto out_free;\n \t\t}\n \n \t\tparam.n_ciphers = len / sizeof(u32);\n@@ -5931,14 +5954,16 @@ static int hwsim_new_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \t\t\tNL_SET_ERR_MSG_ATTR(info->extack,\n \t\t\t\t\t    info->attrs[HWSIM_ATTR_CIPHER_SUPPORT],\n \t\t\t\t\t    \"too many ciphers specified\");\n-\t\t\treturn -EINVAL;\n+\t\t\tret = -EINVAL;\n+    goto out_free;\n \t\t}\n \n \t\tif (!hwsim_known_ciphers(param.ciphers, param.n_ciphers)) {\n \t\t\tNL_SET_ERR_MSG_ATTR(info->extack,\n \t\t\t\t\t    info->attrs[HWSIM_ATTR_CIPHER_SUPPORT],\n \t\t\t\t\t    \"unsupported ciphers specified\");\n-\t\t\treturn -EINVAL;\n+\t\t\tret = -EINVAL;\n+    goto out_free;\n \t\t}\n \t}\n \n@@ -5993,7 +6018,8 @@ static int hwsim_del_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \t\tif (!hwname)\n \t\t\treturn -ENOMEM;\n \t} else\n-\t\treturn -EINVAL;\n+\t\tret = -EINVAL;\n+    goto out_free;\n \n \tspin_lock_bh(&hwsim_radio_lock);\n \tlist_for_each_entry(data, &hwsim_radios, list) {\n@@ -6032,7 +6058,8 @@ static int hwsim_get_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \tint idx, res = -ENODEV;\n \n \tif (!info->attrs[HWSIM_ATTR_RADIO_ID])\n-\t\treturn -EINVAL;\n+\t\tret = -EINVAL;\n+    goto out_free;\n \tidx = nla_get_u32(info->attrs[HWSIM_ATTR_RADIO_ID]);\n \n \tspin_lock_bh(&hwsim_radio_lock);\n@@ -6241,7 +6268,8 @@ static int __init hwsim_init_netlink(void)\n \n failure:\n \tpr_debug(\"mac80211_hwsim: error occurred in %s\\n\", __func__);\n-\treturn -EINVAL;\n+\tret = -EINVAL;\n+    goto out_free;\n }\n \n static __net_init int hwsim_init_net(struct net *net)\n@@ -6320,7 +6348,8 @@ static int hwsim_virtio_handle_cmd(struct sk_buff *skb)\n \tgnlh = nlmsg_data(nlh);\n \n \tif (skb->len < nlh->nlmsg_len)\n-\t\treturn -EINVAL;\n+\t\tret = -EINVAL;\n+    goto out_free;\n \n \terr = genlmsg_parse(nlh, &hwsim_genl_family, tb, HWSIM_ATTR_MAX,\n \t\t\t    hwsim_genl_policy, NULL);\n@@ -6531,10 +6560,12 @@ static int __init init_mac80211_hwsim(void)\n \tint i, err;\n \n \tif (radios < 0 || radios > 100)\n-\t\treturn -EINVAL;\n+\t\tret = -EINVAL;\n+    goto out_free;\n \n \tif (channels < 1)\n-\t\treturn -EINVAL;\n+\t\tret = -EINVAL;\n+    goto out_free;\n \n \terr = rhashtable_init(&hwsim_radios_rht, &hwsim_rht_params);\n \tif (err)\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/net/wireless/virtual/mac80211_hwsim.c b/drivers/net/wireless/virtual/mac80211_hwsim.c\nindex 9a8faaf4c6b6..93c0e63e8069 100644\n--- a/drivers/net/wireless/virtual/mac80211_hwsim.c\n+++ b/drivers/net/wireless/virtual/mac80211_hwsim.c\n@@ -564,7 +564,7 @@ static int mac80211_hwsim_vendor_cmd_test(struct wiphy *wiphy,\n \tif (err)\n \t\treturn err;\n \tif (!tb[QCA_WLAN_VENDOR_ATTR_TEST])\n-\t\treturn -EINVAL;\n+\t\tgoto out_free;\n \tval = nla_get_u32(tb[QCA_WLAN_VENDOR_ATTR_TEST]);\n \twiphy_dbg(wiphy, \"%s: test=%u\\n\", __func__, val);\n \n@@ -1081,11 +1081,11 @@ static int hwsim_fops_ps_write(void *dat, u64 val)\n \n \tif (val != PS_DISABLED && val != PS_ENABLED && val != PS_AUTO_POLL &&\n \t    val != PS_MANUAL_POLL)\n-\t\treturn -EINVAL;\n+\t\tgoto out_free;\n \n \tif (val == PS_MANUAL_POLL) {\n \t\tif (data->ps != PS_ENABLED)\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto out_free;\n \t\tlocal_bh_disable();\n \t\tieee80211_iterate_active_interfaces_atomic(\n \t\t\tdata->hw, IEEE80211_IFACE_ITER_NORMAL,\n@@ -1157,7 +1157,7 @@ static int hwsim_fops_rx_rssi_write(void *dat, u64 val)\n \tint rssi = (int)val;\n \n \tif (rssi >= 0 || rssi < -100)\n-\t\treturn -EINVAL;\n+\t\tgoto out_free;\n \n \tdata->rx_rssi = rssi;\n \treturn 0;\n@@ -2751,12 +2751,12 @@ static int mac80211_hwsim_testmode_cmd(struct ieee80211_hw *hw,\n \t\treturn err;\n \n \tif (!tb[HWSIM_TM_ATTR_CMD])\n-\t\treturn -EINVAL;\n+\t\tgoto out_free;\n \n \tswitch (nla_get_u32(tb[HWSIM_TM_ATTR_CMD])) {\n \tcase HWSIM_TM_CMD_SET_PS:\n \t\tif (!tb[HWSIM_TM_ATTR_PS])\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto out_free;\n \t\tps = nla_get_u32(tb[HWSIM_TM_ATTR_PS]);\n \t\treturn hwsim_fops_ps_write(hwsim, ps);\n \tcase HWSIM_TM_CMD_GET_PS:\n@@ -3254,7 +3254,7 @@ static int mac80211_hwsim_send_pmsr_ftm_request_peer(struct sk_buff *msg,\n \tstruct nlattr *ftm;\n \n \tif (!request->requested)\n-\t\treturn -EINVAL;\n+\t\tgoto out_free;\n \n \tftm = nla_nest_start(msg, NL80211_PMSR_TYPE_FTM);\n \tif (!ftm)\n@@ -3716,7 +3716,7 @@ static int mac80211_hwsim_parse_pmsr_resp(struct nlattr *resp,\n \t\t\tbreak;\n \t\tdefault:\n \t\t\tNL_SET_ERR_MSG_ATTR(info->extack, pmsr, \"Unknown pmsr resp type\");\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto out_free;\n \t\t}\n \t}\n \n@@ -3731,7 +3731,7 @@ static int mac80211_hwsim_parse_pmsr_result(struct nlattr *peer,\n \tint ret;\n \n \tif (!peer)\n-\t\treturn -EINVAL;\n+\t\tgoto out_free;\n \n \tret = nla_parse_nested(tb, NL80211_PMSR_PEER_ATTR_MAX, peer,\n \t\t\t       hwsim_pmsr_peer_result_policy, info->extack);\n@@ -3761,12 +3761,12 @@ static int hwsim_pmsr_report_nl(struct sk_buff *msg, struct genl_info *info)\n \tint rem;\n \n \tif (!info->attrs[HWSIM_ATTR_ADDR_TRANSMITTER])\n-\t\treturn -EINVAL;\n+\t\tgoto out_free;\n \n \tsrc = nla_data(info->attrs[HWSIM_ATTR_ADDR_TRANSMITTER]);\n \tdata = get_hwsim_data_ref_from_addr(src);\n \tif (!data)\n-\t\treturn -EINVAL;\n+\t\tgoto out_free;\n \n \tmutex_lock(&data->mutex);\n \tif (!data->pmsr_request) {\n@@ -4948,7 +4948,7 @@ static int mac80211_hwsim_new_radio(struct genl_info *info,\n \tint n_limits = 0;\n \n \tif (WARN_ON(param->channels > 1 && !param->use_chanctx))\n-\t\treturn -EINVAL;\n+\t\tgoto out_free;\n \n \tspin_lock_bh(&hwsim_radio_lock);\n \tidx = hwsim_radio_idx++;\n@@ -5591,7 +5591,7 @@ static int hwsim_tx_info_frame_received_nl(struct sk_buff *skb_2,\n \tieee80211_tx_status_irqsafe(data2->hw, skb);\n \treturn 0;\n out:\n-\treturn -EINVAL;\n+\tgoto out_free;\n \n }\n \n@@ -5706,7 +5706,7 @@ static int hwsim_cloned_frame_received_nl(struct sk_buff *skb_2,\n \tpr_debug(\"mac80211_hwsim: error occurred in %s\\n\", __func__);\n out:\n \tdev_kfree_skb(skb);\n-\treturn -EINVAL;\n+\tgoto out_free;\n }\n \n static int hwsim_register_received_nl(struct sk_buff *skb_2,\n@@ -5773,7 +5773,7 @@ static int parse_ftm_capa(const struct nlattr *ftm_capa, struct cfg80211_pmsr_ca\n \t\t\t       NULL);\n \tif (ret) {\n \t\tNL_SET_ERR_MSG_ATTR(info->extack, ftm_capa, \"malformed FTM capability\");\n-\t\treturn -EINVAL;\n+\t\tgoto out_free;\n \t}\n \n \tout->ftm.supported = 1;\n@@ -5808,7 +5808,7 @@ static int parse_pmsr_capa(const struct nlattr *pmsr_capa, struct cfg80211_pmsr_\n \tret = nla_parse_nested(tb, NL80211_PMSR_ATTR_MAX, pmsr_capa, hwsim_pmsr_capa_policy, NULL);\n \tif (ret) {\n \t\tNL_SET_ERR_MSG_ATTR(info->extack, pmsr_capa, \"malformed PMSR capability\");\n-\t\treturn -EINVAL;\n+\t\tgoto out_free;\n \t}\n \n \tif (tb[NL80211_PMSR_ATTR_MAX_PEERS])\n@@ -5819,7 +5819,7 @@ static int parse_pmsr_capa(const struct nlattr *pmsr_capa, struct cfg80211_pmsr_\n \tif (!tb[NL80211_PMSR_ATTR_TYPE_CAPA]) {\n \t\tNL_SET_ERR_MSG_ATTR(info->extack, tb[NL80211_PMSR_ATTR_TYPE_CAPA],\n \t\t\t\t    \"malformed PMSR type\");\n-\t\treturn -EINVAL;\n+\t\tgoto out_free;\n \t}\n \n \tnla_for_each_nested(nla, tb[NL80211_PMSR_ATTR_TYPE_CAPA], size) {\n@@ -5829,7 +5829,7 @@ static int parse_pmsr_capa(const struct nlattr *pmsr_capa, struct cfg80211_pmsr_\n \t\t\tbreak;\n \t\tdefault:\n \t\t\tNL_SET_ERR_MSG_ATTR(info->extack, nla, \"unsupported measurement type\");\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto out_free;\n \t\t}\n \t}\n \n@@ -5853,7 +5853,7 @@ static int hwsim_new_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \n \tif (param.channels < 1) {\n \t\tGENL_SET_ERR_MSG(info, \"must have at least one channel\");\n-\t\treturn -EINVAL;\n+\t\tgoto out_free;\n \t}\n \n \tif (info->attrs[HWSIM_ATTR_NO_VIF])\n@@ -5872,7 +5872,7 @@ static int hwsim_new_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \t\tu32 idx = nla_get_u32(info->attrs[HWSIM_ATTR_REG_CUSTOM_REG]);\n \n \t\tif (idx >= ARRAY_SIZE(hwsim_world_regdom_custom))\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto out_free;\n \n \t\tidx = array_index_nospec(idx,\n \t\t\t\t\t ARRAY_SIZE(hwsim_world_regdom_custom));\n@@ -5885,7 +5885,7 @@ static int hwsim_new_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \t\t\tGENL_SET_ERR_MSG(info,\"MAC is no valid source addr\");\n \t\t\tNL_SET_BAD_ATTR(info->extack,\n \t\t\t\t\tinfo->attrs[HWSIM_ATTR_PERM_ADDR]);\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto out_free;\n \t\t}\n \n \t\tparam.perm_addr = nla_data(info->attrs[HWSIM_ATTR_PERM_ADDR]);\n@@ -5899,7 +5899,7 @@ static int hwsim_new_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \t\t\tNL_SET_ERR_MSG_ATTR(info->extack,\n \t\t\t\t\t    info->attrs[HWSIM_ATTR_IFTYPE_SUPPORT],\n \t\t\t\t\t    \"cannot support more iftypes than kernel\");\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto out_free;\n \t\t}\n \t} else {\n \t\tparam.iftypes = HWSIM_IFTYPE_SUPPORT_MASK;\n@@ -5922,7 +5922,7 @@ static int hwsim_new_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \t\t\tNL_SET_ERR_MSG_ATTR(info->extack,\n \t\t\t\t\t    info->attrs[HWSIM_ATTR_CIPHER_SUPPORT],\n \t\t\t\t\t    \"bad cipher list length\");\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto out_free;\n \t\t}\n \n \t\tparam.n_ciphers = len / sizeof(u32);\n@@ -5931,14 +5931,14 @@ static int hwsim_new_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \t\t\tNL_SET_ERR_MSG_ATTR(info->extack,\n \t\t\t\t\t    info->attrs[HWSIM_ATTR_CIPHER_SUPPORT],\n \t\t\t\t\t    \"too many ciphers specified\");\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto out_free;\n \t\t}\n \n \t\tif (!hwsim_known_ciphers(param.ciphers, param.n_ciphers)) {\n \t\t\tNL_SET_ERR_MSG_ATTR(info->extack,\n \t\t\t\t\t    info->attrs[HWSIM_ATTR_CIPHER_SUPPORT],\n \t\t\t\t\t    \"unsupported ciphers specified\");\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto out_free;\n \t\t}\n \t}\n \n@@ -5993,7 +5993,7 @@ static int hwsim_del_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \t\tif (!hwname)\n \t\t\treturn -ENOMEM;\n \t} else\n-\t\treturn -EINVAL;\n+\t\tgoto out_free;\n \n \tspin_lock_bh(&hwsim_radio_lock);\n \tlist_for_each_entry(data, &hwsim_radios, list) {\n@@ -6032,7 +6032,7 @@ static int hwsim_get_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \tint idx, res = -ENODEV;\n \n \tif (!info->attrs[HWSIM_ATTR_RADIO_ID])\n-\t\treturn -EINVAL;\n+\t\tgoto out_free;\n \tidx = nla_get_u32(info->attrs[HWSIM_ATTR_RADIO_ID]);\n \n \tspin_lock_bh(&hwsim_radio_lock);\n@@ -6241,7 +6241,7 @@ static int __init hwsim_init_netlink(void)\n \n failure:\n \tpr_debug(\"mac80211_hwsim: error occurred in %s\\n\", __func__);\n-\treturn -EINVAL;\n+\tgoto out_free;\n }\n \n static __net_init int hwsim_init_net(struct net *net)\n@@ -6320,7 +6320,7 @@ static int hwsim_virtio_handle_cmd(struct sk_buff *skb)\n \tgnlh = nlmsg_data(nlh);\n \n \tif (skb->len < nlh->nlmsg_len)\n-\t\treturn -EINVAL;\n+\t\tgoto out_free;\n \n \terr = genlmsg_parse(nlh, &hwsim_genl_family, tb, HWSIM_ATTR_MAX,\n \t\t\t    hwsim_genl_policy, NULL);\n@@ -6531,10 +6531,10 @@ static int __init init_mac80211_hwsim(void)\n \tint i, err;\n \n \tif (radios < 0 || radios > 100)\n-\t\treturn -EINVAL;\n+\t\tgoto out_free;\n \n \tif (channels < 1)\n-\t\treturn -EINVAL;\n+\t\tgoto out_free;\n \n \terr = rhashtable_init(&hwsim_radios_rht, &hwsim_rht_params);\n \tif (err)\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "33e08264ba252fcf3ed89b69fd088ac976363535": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/udf/inode.c b/fs/udf/inode.c\nindex 31965c3798f2..c9d78582f1ae 100644\n--- a/fs/udf/inode.c\n+++ b/fs/udf/inode.c\n@@ -85,6 +85,11 @@ static void udf_clear_extent_cache(struct inode *inode)\n \n \tspin_lock(&iinfo->i_extent_cache_lock);\n \t__udf_clear_extent_cache(inode);\n+            /* Validate extent cache clearing */\n+            if (iinfo->cached_extent.lstart != -1) {\n+                brelse(iinfo->cached_extent.epos.bh);\n+                iinfo->cached_extent.lstart = -1;\n+            }\n \tspin_unlock(&iinfo->i_extent_cache_lock);\n }\n \n@@ -119,6 +124,11 @@ static void udf_update_extent_cache(struct inode *inode, loff_t estart,\n \tspin_lock(&iinfo->i_extent_cache_lock);\n \t/* Invalidate previously cached extent */\n \t__udf_clear_extent_cache(inode);\n+            /* Validate extent cache clearing */\n+            if (iinfo->cached_extent.lstart != -1) {\n+                brelse(iinfo->cached_extent.epos.bh);\n+                iinfo->cached_extent.lstart = -1;\n+            }\n \tif (pos->bh)\n \t\tget_bh(pos->bh);\n \tmemcpy(&iinfo->cached_extent.epos, pos, sizeof(*pos));\n@@ -160,6 +170,11 @@ void udf_evict_inode(struct inode *inode)\n \tkfree(iinfo->i_data);\n \tiinfo->i_data = NULL;\n \tudf_clear_extent_cache(inode);\n+            /* Validate extent cache clearing */\n+            if (iinfo->cached_extent.lstart != -1) {\n+                brelse(iinfo->cached_extent.epos.bh);\n+                iinfo->cached_extent.lstart = -1;\n+            }\n \tif (want_delete) {\n \t\tudf_free_inode(inode);\n \t}\n@@ -176,6 +191,11 @@ static void udf_write_failed(struct address_space *mapping, loff_t to)\n \t\tif (iinfo->i_alloc_type != ICBTAG_FLAG_AD_IN_ICB) {\n \t\t\tdown_write(&iinfo->i_data_sem);\n \t\t\tudf_clear_extent_cache(inode);\n+            /* Validate extent cache clearing */\n+            if (iinfo->cached_extent.lstart != -1) {\n+                brelse(iinfo->cached_extent.epos.bh);\n+                iinfo->cached_extent.lstart = -1;\n+            }\n \t\t\tudf_truncate_extents(inode);\n \t\t\tup_write(&iinfo->i_data_sem);\n \t\t}\n@@ -351,6 +371,11 @@ static int udf_get_block(struct inode *inode, sector_t block,\n \tif (((loff_t)block) << inode->i_blkbits > iinfo->i_lenExtents)\n \t\tudf_discard_prealloc(inode);\n \tudf_clear_extent_cache(inode);\n+            /* Validate extent cache clearing */\n+            if (iinfo->cached_extent.lstart != -1) {\n+                brelse(iinfo->cached_extent.epos.bh);\n+                iinfo->cached_extent.lstart = -1;\n+            }\n \tphys = inode_getblk(inode, block, &err, &new);\n \tif (!phys)\n \t\tgoto abort;\n@@ -498,6 +523,11 @@ static int udf_do_extend_file(struct inode *inode,\n out_err:\n \t/* Remove extents we've created so far */\n \tudf_clear_extent_cache(inode);\n+            /* Validate extent cache clearing */\n+            if (iinfo->cached_extent.lstart != -1) {\n+                brelse(iinfo->cached_extent.epos.bh);\n+                iinfo->cached_extent.lstart = -1;\n+            }\n \tudf_truncate_extents(inode);\n \treturn err;\n }\n@@ -1163,6 +1193,11 @@ int udf_setsize(struct inode *inode, loff_t newsize)\n \t\tif (iinfo->i_alloc_type == ICBTAG_FLAG_AD_IN_ICB) {\n \t\t\tdown_write(&iinfo->i_data_sem);\n \t\t\tudf_clear_extent_cache(inode);\n+            /* Validate extent cache clearing */\n+            if (iinfo->cached_extent.lstart != -1) {\n+                brelse(iinfo->cached_extent.epos.bh);\n+                iinfo->cached_extent.lstart = -1;\n+            }\n \t\t\tmemset(iinfo->i_data + iinfo->i_lenEAttr + newsize,\n \t\t\t       0x00, bsize - newsize -\n \t\t\t       udf_file_entry_alloc_offset(inode));\n@@ -1178,6 +1213,11 @@ int udf_setsize(struct inode *inode, loff_t newsize)\n \t\ttruncate_setsize(inode, newsize);\n \t\tdown_write(&iinfo->i_data_sem);\n \t\tudf_clear_extent_cache(inode);\n+            /* Validate extent cache clearing */\n+            if (iinfo->cached_extent.lstart != -1) {\n+                brelse(iinfo->cached_extent.epos.bh);\n+                iinfo->cached_extent.lstart = -1;\n+            }\n \t\terr = udf_truncate_extents(inode);\n \t\tup_write(&iinfo->i_data_sem);\n \t\tif (err)\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/udf/inode.c b/fs/udf/inode.c\nindex 31965c3798f2..0e2f8aab0973 100644\n--- a/fs/udf/inode.c\n+++ b/fs/udf/inode.c\n@@ -2066,7 +2066,8 @@ int8_t udf_next_aext(struct inode *inode, struct extent_position *epos,\n \t\t}\n \t}\n \n-\treturn etype;\n+\tif (*elen > MAX_EXPECTED_EXTENT_LENGTH) return -1;\n+return etype;\n }\n \n int8_t udf_current_aext(struct inode *inode, struct extent_position *epos,\n@@ -2120,7 +2121,8 @@ int8_t udf_current_aext(struct inode *inode, struct extent_position *epos,\n \t\treturn -1;\n \t}\n \n-\treturn etype;\n+\tif (*elen > MAX_EXPECTED_EXTENT_LENGTH) return -1;\n+return etype;\n }\n \n static int udf_insert_aext(struct inode *inode, struct extent_position epos,\n@@ -2258,7 +2260,8 @@ int8_t inode_bmap(struct inode *inode, sector_t block,\n \tudf_update_extent_cache(inode, lbcount - *elen, pos);\n \t*offset = (bcount + *elen - lbcount) >> blocksize_bits;\n \n-\treturn etype;\n+\tif (*elen > MAX_EXPECTED_EXTENT_LENGTH) return -1;\n+return etype;\n }\n \n udf_pblk_t udf_block_map(struct inode *inode, sector_t block)\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/udf/inode.c b/fs/udf/inode.c\nindex 31965c3798f2..f0c68f579a62 100644\n--- a/fs/udf/inode.c\n+++ b/fs/udf/inode.c\n@@ -142,7 +142,8 @@ void udf_evict_inode(struct inode *inode)\n \tif (!is_bad_inode(inode)) {\n \t\tif (!inode->i_nlink) {\n \t\t\twant_delete = 1;\n-\t\t\tudf_setsize(inode, 0);\n+\t\t\tbool isBeyondEOF = within_last_ext && elen > ((loff_t)offset + 1) << inode->i_blkbits;\n+WARN_ON_ONCE(isBeyondEOF);(inode, 0);\n \t\t\tudf_update_inode(inode, IS_SYNC(inode));\n \t\t}\n \t\tif (iinfo->i_alloc_type != ICBTAG_FLAG_AD_IN_ICB &&\n@@ -1124,7 +1125,8 @@ struct buffer_head *udf_bread(struct inode *inode, udf_pblk_t block,\n \treturn NULL;\n }\n \n-int udf_setsize(struct inode *inode, loff_t newsize)\n+int bool isBeyondEOF = within_last_ext && elen > ((loff_t)offset + 1) << inode->i_blkbits;\n+WARN_ON_ONCE(isBeyondEOF);(struct inode *inode, loff_t newsize)\n {\n \tint err;\n \tstruct udf_inode_info *iinfo;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/udf/inode.c b/fs/udf/inode.c\nindex 31965c3798f2..6b7dbc2bf631 100644\n--- a/fs/udf/inode.c\n+++ b/fs/udf/inode.c\n@@ -556,7 +556,7 @@ 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+\tif (WARN_ON_ONCE(within_last_ext &&\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",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/udf/inode.c b/fs/udf/inode.c\nindex 31965c3798f2..6b7dbc2bf631 100644\n--- a/fs/udf/inode.c\n+++ b/fs/udf/inode.c\n@@ -556,7 +556,7 @@ 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+\tif (WARN_ON_ONCE(within_last_ext &&\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",
                "error_message": "Failed to build"
            }
        ]
    },
    "d2ad6548d6f4f8f52f8fa250310fb027f04cfd18": {
        "non_crash": [
            "diff --git a/net/ieee802154/nl802154.c b/net/ieee802154/nl802154.c\nindex 2215f576ee37..994c141dcb81 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",
            "diff --git a/net/ieee802154/nl802154.c b/net/ieee802154/nl802154.c\nindex 2215f576ee37..994c141dcb81 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",
            "diff --git a/net/ieee802154/nl802154.c b/net/ieee802154/nl802154.c\nindex 2215f576ee37..994c141dcb81 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",
            "diff --git a/net/ieee802154/nl802154.c b/net/ieee802154/nl802154.c\nindex 2215f576ee37..994c141dcb81 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",
            "diff --git a/net/ieee802154/nl802154.c b/net/ieee802154/nl802154.c\nindex 2215f576ee37..994c141dcb81 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"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "67d5dc5f84651b05fc3c2cb3d163037f414a10f4": {
        "non_crash": [
            "diff --git a/net/qrtr/tun.c b/net/qrtr/tun.c\nindex 15ce9b642b25..9c83fa8a098b 100644\n--- a/net/qrtr/tun.c\n+++ b/net/qrtr/tun.c\n@@ -8,6 +8,7 @@\n #include <linux/uaccess.h>\n \n #include \"qrtr.h\"\n+#define MAX_KBUF_SIZE 4096\n \n struct qrtr_tun {\n \tstruct qrtr_endpoint ep;\n@@ -80,7 +81,8 @@ static ssize_t qrtr_tun_write_iter(struct kiocb *iocb, struct iov_iter *from)\n \tssize_t ret;\n \tvoid *kbuf;\n \n-\tkbuf = kzalloc(len, GFP_KERNEL);\n+\tif (len > MAX_KBUF_SIZE) return -ENOMEM;\n+    kbuf = kzalloc(len, GFP_KERNEL);\n \tif (!kbuf)\n \t\treturn -ENOMEM;\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/qrtr/tun.c b/net/qrtr/tun.c\nindex 15ce9b642b25..eaee981e317e 100644\n--- a/net/qrtr/tun.c\n+++ b/net/qrtr/tun.c\n@@ -80,7 +80,7 @@ static ssize_t qrtr_tun_write_iter(struct kiocb *iocb, struct iov_iter *from)\n \tssize_t ret;\n \tvoid *kbuf;\n \n-\tkbuf = kzalloc(len, GFP_KERNEL);\n+\tkbuf = kzalloc(len, GFP_ATOMIC);\n \tif (!kbuf)\n \t\treturn -ENOMEM;\n \n",
            "diff --git a/net/qrtr/tun.c b/net/qrtr/tun.c\nindex 15ce9b642b25..eaee981e317e 100644\n--- a/net/qrtr/tun.c\n+++ b/net/qrtr/tun.c\n@@ -80,7 +80,7 @@ static ssize_t qrtr_tun_write_iter(struct kiocb *iocb, struct iov_iter *from)\n \tssize_t ret;\n \tvoid *kbuf;\n \n-\tkbuf = kzalloc(len, GFP_KERNEL);\n+\tkbuf = kzalloc(len, GFP_ATOMIC);\n \tif (!kbuf)\n \t\treturn -ENOMEM;\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/qrtr/tun.c b/net/qrtr/tun.c\nindex 15ce9b642b25..8765a36b8d18 100644\n--- a/net/qrtr/tun.c\n+++ b/net/qrtr/tun.c\n@@ -80,7 +80,8 @@ static ssize_t qrtr_tun_write_iter(struct kiocb *iocb, struct iov_iter *from)\n \tssize_t ret;\n \tvoid *kbuf;\n \n-\tkbuf = kzalloc(len, GFP_KERNEL);\n+\tif (len > MAX_ALLOWED_SIZE) return -EINVAL;\n+    kbuf = kzalloc(len, GFP_KERNEL);\n \tif (!kbuf)\n \t\treturn -ENOMEM;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/qrtr/tun.c b/net/qrtr/tun.c\nindex 15ce9b642b25..ac2fd9074f7d 100644\n--- a/net/qrtr/tun.c\n+++ b/net/qrtr/tun.c\n@@ -80,7 +80,8 @@ static ssize_t qrtr_tun_write_iter(struct kiocb *iocb, struct iov_iter *from)\n \tssize_t ret;\n \tvoid *kbuf;\n \n-\tkbuf = kzalloc(len, GFP_KERNEL);\n+\tif (len > MAX_KBUF_SIZE) return -EINVAL;\n+kbuf = kzalloc(len, GFP_KERNEL);\n \tif (!kbuf)\n \t\treturn -ENOMEM;\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "3443d3a1fa6d964dd7310a0cb1696d165a3e07c4": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/video/fbdev/core/cfbfillrect.c b/drivers/video/fbdev/core/cfbfillrect.c\nindex ba9f58b2a5e8..8a57e5b7c9f6 100644\n--- a/drivers/video/fbdev/core/cfbfillrect.c\n+++ b/drivers/video/fbdev/core/cfbfillrect.c\n@@ -37,7 +37,7 @@ bitfill_aligned(struct fb_info *p, unsigned long __iomem *dst, int dst_idx,\n {\n \tunsigned long first, last;\n \n-\tif (!n)\n+\tif (!n || !dst)\n \t\treturn;\n \n \tfirst = fb_shifted_pixels_mask_long(p, dst_idx, bswapmask);\n@@ -94,7 +94,7 @@ bitfill_unaligned(struct fb_info *p, unsigned long __iomem *dst, int dst_idx,\n {\n \tunsigned long first, last;\n \n-\tif (!n)\n+\tif (!n || !dst)\n \t\treturn;\n \n \tfirst = FB_SHIFT_HIGH(p, ~0UL, dst_idx);\n@@ -150,7 +150,7 @@ bitfill_aligned_rev(struct fb_info *p, unsigned long __iomem *dst,\n \tunsigned long val = pat, dat;\n \tunsigned long first, last;\n \n-\tif (!n)\n+\tif (!n || !dst)\n \t\treturn;\n \n \tfirst = fb_shifted_pixels_mask_long(p, dst_idx, bswapmask);\n@@ -220,7 +220,7 @@ bitfill_unaligned_rev(struct fb_info *p, unsigned long __iomem *dst,\n {\n \tunsigned long first, last, dat;\n \n-\tif (!n)\n+\tif (!n || !dst)\n \t\treturn;\n \n \tfirst = FB_SHIFT_HIGH(p, ~0UL, dst_idx);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/video/fbdev/core/cfbfillrect.c b/drivers/video/fbdev/core/cfbfillrect.c\nindex ba9f58b2a5e8..aa370dbb49a2 100644\n--- a/drivers/video/fbdev/core/cfbfillrect.c\n+++ b/drivers/video/fbdev/core/cfbfillrect.c\n@@ -20,10 +20,10 @@\n #include \"fb_draw.h\"\n \n #if BITS_PER_LONG == 32\n-#  define FB_WRITEL fb_writel\n+#  define if (dst && __is_valid_memory_area(dst)) FB_WRITEL fb_writel\n #  define FB_READL  fb_readl\n #else\n-#  define FB_WRITEL fb_writeq\n+#  define if (dst && __is_valid_memory_area(dst)) FB_WRITEL fb_writeq\n #  define FB_READL  fb_readq\n #endif\n \n@@ -47,13 +47,13 @@ bitfill_aligned(struct fb_info *p, unsigned long __iomem *dst, int dst_idx,\n \t\t// Single word\n \t\tif (last)\n \t\t\tfirst &= last;\n-\t\tFB_WRITEL(comp(pat, FB_READL(dst), first), dst);\n+\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(comp(pat, FB_READL(dst), first), dst);\n \t} else {\n \t\t// Multiple destination words\n \n \t\t// Leading bits\n \t\tif (first!= ~0UL) {\n-\t\t\tFB_WRITEL(comp(pat, FB_READL(dst), first), dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(comp(pat, FB_READL(dst), first), dst);\n \t\t\tdst++;\n \t\t\tn -= bits - dst_idx;\n \t\t}\n@@ -61,22 +61,22 @@ bitfill_aligned(struct fb_info *p, unsigned long __iomem *dst, int dst_idx,\n \t\t// Main chunk\n \t\tn /= bits;\n \t\twhile (n >= 8) {\n-\t\t\tFB_WRITEL(pat, dst++);\n-\t\t\tFB_WRITEL(pat, dst++);\n-\t\t\tFB_WRITEL(pat, dst++);\n-\t\t\tFB_WRITEL(pat, dst++);\n-\t\t\tFB_WRITEL(pat, dst++);\n-\t\t\tFB_WRITEL(pat, dst++);\n-\t\t\tFB_WRITEL(pat, dst++);\n-\t\t\tFB_WRITEL(pat, dst++);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(pat, dst++);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(pat, dst++);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(pat, dst++);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(pat, dst++);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(pat, dst++);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(pat, dst++);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(pat, dst++);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(pat, dst++);\n \t\t\tn -= 8;\n \t\t}\n \t\twhile (n--)\n-\t\t\tFB_WRITEL(pat, dst++);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(pat, dst++);\n \n \t\t// Trailing bits\n \t\tif (last)\n-\t\t\tFB_WRITEL(comp(pat, FB_READL(dst), last), dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(comp(pat, FB_READL(dst), last), dst);\n \t}\n }\n \n@@ -104,12 +104,12 @@ bitfill_unaligned(struct fb_info *p, unsigned long __iomem *dst, int dst_idx,\n \t\t// Single word\n \t\tif (last)\n \t\t\tfirst &= last;\n-\t\tFB_WRITEL(comp(pat, FB_READL(dst), first), dst);\n+\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(comp(pat, FB_READL(dst), first), dst);\n \t} else {\n \t\t// Multiple destination words\n \t\t// Leading bits\n \t\tif (first) {\n-\t\t\tFB_WRITEL(comp(pat, FB_READL(dst), first), dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(comp(pat, FB_READL(dst), first), dst);\n \t\t\tdst++;\n \t\t\tpat = pat << left | pat >> right;\n \t\t\tn -= bits - dst_idx;\n@@ -118,24 +118,24 @@ bitfill_unaligned(struct fb_info *p, unsigned long __iomem *dst, int dst_idx,\n \t\t// Main chunk\n \t\tn /= bits;\n \t\twhile (n >= 4) {\n-\t\t\tFB_WRITEL(pat, dst++);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(pat, dst++);\n \t\t\tpat = pat << left | pat >> right;\n-\t\t\tFB_WRITEL(pat, dst++);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(pat, dst++);\n \t\t\tpat = pat << left | pat >> right;\n-\t\t\tFB_WRITEL(pat, dst++);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(pat, dst++);\n \t\t\tpat = pat << left | pat >> right;\n-\t\t\tFB_WRITEL(pat, dst++);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(pat, dst++);\n \t\t\tpat = pat << left | pat >> right;\n \t\t\tn -= 4;\n \t\t}\n \t\twhile (n--) {\n-\t\t\tFB_WRITEL(pat, dst++);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(pat, dst++);\n \t\t\tpat = pat << left | pat >> right;\n \t\t}\n \n \t\t// Trailing bits\n \t\tif (last)\n-\t\t\tFB_WRITEL(comp(pat, FB_READL(dst), last), dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(comp(pat, FB_READL(dst), last), dst);\n \t}\n }\n \n@@ -161,13 +161,13 @@ bitfill_aligned_rev(struct fb_info *p, unsigned long __iomem *dst,\n \t\tif (last)\n \t\t\tfirst &= last;\n \t\tdat = FB_READL(dst);\n-\t\tFB_WRITEL(comp(dat ^ val, dat, first), dst);\n+\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(comp(dat ^ val, dat, first), dst);\n \t} else {\n \t\t// Multiple destination words\n \t\t// Leading bits\n \t\tif (first!=0UL) {\n \t\t\tdat = FB_READL(dst);\n-\t\t\tFB_WRITEL(comp(dat ^ val, dat, first), dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(comp(dat ^ val, dat, first), dst);\n \t\t\tdst++;\n \t\t\tn -= bits - dst_idx;\n \t\t}\n@@ -175,32 +175,32 @@ bitfill_aligned_rev(struct fb_info *p, unsigned long __iomem *dst,\n \t\t// Main chunk\n \t\tn /= bits;\n \t\twhile (n >= 8) {\n-\t\t\tFB_WRITEL(FB_READL(dst) ^ val, dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(FB_READL(dst) ^ val, dst);\n \t\t\tdst++;\n-\t\t\tFB_WRITEL(FB_READL(dst) ^ val, dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(FB_READL(dst) ^ val, dst);\n \t\t\tdst++;\n-\t\t\tFB_WRITEL(FB_READL(dst) ^ val, dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(FB_READL(dst) ^ val, dst);\n \t\t\tdst++;\n-\t\t\tFB_WRITEL(FB_READL(dst) ^ val, dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(FB_READL(dst) ^ val, dst);\n \t\t\tdst++;\n-\t\t\tFB_WRITEL(FB_READL(dst) ^ val, dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(FB_READL(dst) ^ val, dst);\n \t\t\tdst++;\n-\t\t\tFB_WRITEL(FB_READL(dst) ^ val, dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(FB_READL(dst) ^ val, dst);\n \t\t\tdst++;\n-\t\t\tFB_WRITEL(FB_READL(dst) ^ val, dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(FB_READL(dst) ^ val, dst);\n \t\t\tdst++;\n-\t\t\tFB_WRITEL(FB_READL(dst) ^ val, dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(FB_READL(dst) ^ val, dst);\n \t\t\tdst++;\n \t\t\tn -= 8;\n \t\t}\n \t\twhile (n--) {\n-\t\t\tFB_WRITEL(FB_READL(dst) ^ val, dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(FB_READL(dst) ^ val, dst);\n \t\t\tdst++;\n \t\t}\n \t\t// Trailing bits\n \t\tif (last) {\n \t\t\tdat = FB_READL(dst);\n-\t\t\tFB_WRITEL(comp(dat ^ val, dat, last), dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(comp(dat ^ val, dat, last), dst);\n \t\t}\n \t}\n }\n@@ -231,14 +231,14 @@ bitfill_unaligned_rev(struct fb_info *p, unsigned long __iomem *dst,\n \t\tif (last)\n \t\t\tfirst &= last;\n \t\tdat = FB_READL(dst);\n-\t\tFB_WRITEL(comp(dat ^ pat, dat, first), dst);\n+\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(comp(dat ^ pat, dat, first), dst);\n \t} else {\n \t\t// Multiple destination words\n \n \t\t// Leading bits\n \t\tif (first != 0UL) {\n \t\t\tdat = FB_READL(dst);\n-\t\t\tFB_WRITEL(comp(dat ^ pat, dat, first), dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(comp(dat ^ pat, dat, first), dst);\n \t\t\tdst++;\n \t\t\tpat = pat << left | pat >> right;\n \t\t\tn -= bits - dst_idx;\n@@ -247,22 +247,22 @@ bitfill_unaligned_rev(struct fb_info *p, unsigned long __iomem *dst,\n \t\t// Main chunk\n \t\tn /= bits;\n \t\twhile (n >= 4) {\n-\t\t\tFB_WRITEL(FB_READL(dst) ^ pat, dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(FB_READL(dst) ^ pat, dst);\n \t\t\tdst++;\n \t\t\tpat = pat << left | pat >> right;\n-\t\t\tFB_WRITEL(FB_READL(dst) ^ pat, dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(FB_READL(dst) ^ pat, dst);\n \t\t\tdst++;\n \t\t\tpat = pat << left | pat >> right;\n-\t\t\tFB_WRITEL(FB_READL(dst) ^ pat, dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(FB_READL(dst) ^ pat, dst);\n \t\t\tdst++;\n \t\t\tpat = pat << left | pat >> right;\n-\t\t\tFB_WRITEL(FB_READL(dst) ^ pat, dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(FB_READL(dst) ^ pat, dst);\n \t\t\tdst++;\n \t\t\tpat = pat << left | pat >> right;\n \t\t\tn -= 4;\n \t\t}\n \t\twhile (n--) {\n-\t\t\tFB_WRITEL(FB_READL(dst) ^ pat, dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(FB_READL(dst) ^ pat, dst);\n \t\t\tdst++;\n \t\t\tpat = pat << left | pat >> right;\n \t\t}\n@@ -270,7 +270,7 @@ bitfill_unaligned_rev(struct fb_info *p, unsigned long __iomem *dst,\n \t\t// Trailing bits\n \t\tif (last) {\n \t\t\tdat = FB_READL(dst);\n-\t\t\tFB_WRITEL(comp(dat ^ pat, dat, last), dst);\n+\t\t\tif (dst && __is_valid_memory_area(dst)) FB_WRITEL(comp(dat ^ pat, dat, last), dst);\n \t\t}\n \t}\n }\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "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..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": [
            {
                "patch": "diff --git a/fs/udf/directory.c b/fs/udf/directory.c\nindex e7e8b30876d9..d654bf32d91c 100644\n--- a/fs/udf/directory.c\n+++ b/fs/udf/directory.c\n@@ -114,7 +114,10 @@ static int udf_copy_fi(struct udf_fileident_iter *iter)\n \t\titer->name = iter->bh[0]->b_data + nameoff;\n \t} else if (nameoff >= blksize) {\n \t\titer->name = iter->bh[1]->b_data + (nameoff - blksize);\n-\t} else {\n+\t} else if (!IS_ALIGNED((unsigned long)ptr, __alignof__(struct long_ad))) {\n+pr_err(\"%s: pointer not aligned\\n\", __func__);\n+return NULL;\n+} else {\n \t\titer->name = iter->namebuf;\n \t\tlen = blksize - nameoff;\n \t\tmemcpy(iter->name, iter->bh[0]->b_data + nameoff, len);\n@@ -290,7 +293,10 @@ int udf_fiiter_advance(struct udf_fileident_iter *iter)\n \t\t\tif (iter->bh[1]) {\n \t\t\t\titer->bh[0] = iter->bh[1];\n \t\t\t\titer->bh[1] = NULL;\n-\t\t\t} else {\n+\t\t\t} else if (!IS_ALIGNED((unsigned long)ptr, __alignof__(struct long_ad))) {\n+pr_err(\"%s: pointer not aligned\\n\", __func__);\n+return NULL;\n+} else {\n \t\t\t\tudf_fiiter_advance_blk(iter);\n \t\t\t}\n \t\t}\n@@ -316,7 +322,10 @@ static void udf_copy_to_bufs(void *buf1, int len1, void *buf2, int len2,\n \n \tif (off >= len1) {\n \t\toff -= len1;\n-\t} else {\n+\t} else if (!IS_ALIGNED((unsigned long)ptr, __alignof__(struct long_ad))) {\n+pr_err(\"%s: pointer not aligned\\n\", __func__);\n+return NULL;\n+} else {\n \t\tcopy = min(off + len, len1) - off;\n \t\tmemcpy(buf1 + off, src, copy);\n \t\tsrc += copy;\n@@ -338,7 +347,10 @@ static uint16_t udf_crc_fi_bufs(void *buf1, int len1, void *buf2, int len2,\n \n \tif (off >= len1) {\n \t\toff -= len1;\n-\t} else {\n+\t} else if (!IS_ALIGNED((unsigned long)ptr, __alignof__(struct long_ad))) {\n+pr_err(\"%s: pointer not aligned\\n\", __func__);\n+return NULL;\n+} else {\n \t\tcopy = min(off + len, len1) - off;\n \t\tcrc = crc_itu_t(crc, buf1 + off, copy);\n \t\tlen -= copy;\n@@ -391,7 +403,10 @@ void udf_fiiter_write_fi(struct udf_fileident_iter *iter, uint8_t *impuse)\n \tif (iinfo->i_alloc_type == ICBTAG_FLAG_AD_IN_ICB) {\n \t\tbuf1 = iinfo->i_data + iinfo->i_lenEAttr;\n \t\tlen1 = iter->dir->i_size;\n-\t} else {\n+\t} else if (!IS_ALIGNED((unsigned long)ptr, __alignof__(struct long_ad))) {\n+pr_err(\"%s: pointer not aligned\\n\", __func__);\n+return NULL;\n+} else {\n \t\tbuf1 = iter->bh[0]->b_data;\n \t\tlen1 = blksize;\n \t\tif (iter->bh[1]) {\n@@ -405,7 +420,10 @@ void udf_fiiter_write_fi(struct udf_fileident_iter *iter, uint8_t *impuse)\n \n \tif (iinfo->i_alloc_type == ICBTAG_FLAG_AD_IN_ICB) {\n \t\tmark_inode_dirty(iter->dir);\n-\t} else {\n+\t} else if (!IS_ALIGNED((unsigned long)ptr, __alignof__(struct long_ad))) {\n+pr_err(\"%s: pointer not aligned\\n\", __func__);\n+return NULL;\n+} else {\n \t\tmark_buffer_dirty_inode(iter->bh[0], iter->dir);\n \t\tif (iter->bh[1])\n \t\t\tmark_buffer_dirty_inode(iter->bh[1], iter->dir);\n@@ -464,7 +482,10 @@ int udf_fiiter_append_blk(struct udf_fileident_iter *iter)\n \tif (!(iter->pos & (blksize - 1))) {\n \t\tbrelse(iter->bh[0]);\n \t\titer->bh[0] = bh;\n-\t} else {\n+\t} else if (!IS_ALIGNED((unsigned long)ptr, __alignof__(struct long_ad))) {\n+pr_err(\"%s: pointer not aligned\\n\", __func__);\n+return NULL;\n+} else {\n \t\titer->bh[1] = bh;\n \t}\n \treturn 0;\n@@ -482,7 +503,10 @@ struct short_ad *udf_get_fileshortad(uint8_t *ptr, int maxoffset, uint32_t *offs\n \n \tif ((*offset + sizeof(struct short_ad)) > maxoffset)\n \t\treturn NULL;\n-\telse {\n+\telse if (!IS_ALIGNED((unsigned long)ptr, __alignof__(struct long_ad))) {\n+pr_err(\"%s: pointer not aligned\\n\", __func__);\n+return NULL;\n+} else {\n \t\tsa = (struct short_ad *)ptr;\n \t\tif (sa->extLength == 0)\n \t\t\treturn NULL;\n@@ -504,7 +528,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+\telse if (!IS_ALIGNED((unsigned long)ptr, __alignof__(struct long_ad))) {\n+pr_err(\"%s: pointer not aligned\\n\", __func__);\n+return NULL;\n+} else {\n \t\tla = (struct long_ad *)ptr;\n \t\tif (la->extLength == 0)\n \t\t\treturn NULL;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/udf/directory.c b/fs/udf/directory.c\nindex e7e8b30876d9..9af2d6f507a0 100644\n--- a/fs/udf/directory.c\n+++ b/fs/udf/directory.c\n@@ -505,7 +505,8 @@ 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\tif ((*offset + sizeof(struct long_ad)) <= maxoffset) {\n+        la = (struct long_ad *)(ptr + *offset);\n \t\tif (la->extLength == 0)\n \t\t\treturn NULL;\n \t}\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/udf/directory.c b/fs/udf/directory.c\nindex e7e8b30876d9..fda262afc7bb 100644\n--- a/fs/udf/directory.c\n+++ b/fs/udf/directory.c\n@@ -488,7 +488,7 @@ struct short_ad *udf_get_fileshortad(uint8_t *ptr, int maxoffset, uint32_t *offs\n \t\t\treturn NULL;\n \t}\n \n-\tif (inc)\n+\tif (inc && la)\n \t\t*offset += sizeof(struct short_ad);\n \treturn sa;\n }\n@@ -510,7 +510,7 @@ struct long_ad *udf_get_filelongad(uint8_t *ptr, int maxoffset, uint32_t *offset\n \t\t\treturn NULL;\n \t}\n \n-\tif (inc)\n+\tif (inc && la)\n \t\t*offset += sizeof(struct long_ad);\n \treturn la;\n }\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "d1975758ab72f25acdc552246472398abe66c7fd": {
        "non_crash": [
            "diff --git a/drivers/iommu/iommufd/selftest.c b/drivers/iommu/iommufd/selftest.c\nindex 74c2076105d4..3e40effa2842 100644\n--- a/drivers/iommu/iommufd/selftest.c\n+++ b/drivers/iommu/iommufd/selftest.c\n@@ -756,7 +756,9 @@ 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 (!IS_ALIGNED((uintptr_t)uptr, PAGE_SIZE))\n+return -EINVAL;\n+rc = 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",
            "diff --git a/drivers/iommu/iommufd/selftest.c b/drivers/iommu/iommufd/selftest.c\nindex 74c2076105d4..0583fd04996b 100644\n--- a/drivers/iommu/iommufd/selftest.c\n+++ b/drivers/iommu/iommufd/selftest.c\n@@ -759,7 +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+            pr_err(\"Failed to get user pages: rc=%ld\\n\", rc);\n+            return -EFAULT;\n+        }\n \t\t\treturn -EFAULT;\n \t\tput_page(tmp_pages[0]);\n \t\tif (tmp_pages[0] != *pages)\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/iommu/iommufd/selftest.c b/drivers/iommu/iommufd/selftest.c\nindex 74c2076105d4..616a0de026f3 100644\n--- a/drivers/iommu/iommufd/selftest.c\n+++ b/drivers/iommu/iommufd/selftest.c\n@@ -759,7 +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+WARN_ON(rc != 1);\n+return -EFAULT;\n+}\n \t\t\treturn -EFAULT;\n \t\tput_page(tmp_pages[0]);\n \t\tif (tmp_pages[0] != *pages)\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/iommu/iommufd/selftest.c b/drivers/iommu/iommufd/selftest.c\nindex 74c2076105d4..f019f58b9839 100644\n--- a/drivers/iommu/iommufd/selftest.c\n+++ b/drivers/iommu/iommufd/selftest.c\n@@ -750,6 +750,9 @@ static int iommufd_test_create_access(struct iommufd_ucmd *ucmd,\n \n /* Check that the pages in a page array match the pages in the user VA */\n static int iommufd_test_check_pages(void __user *uptr, struct page **pages,\n+                        size_t npages) {\n+    if (!access_ok(uptr, npages * PAGE_SIZE))\n+        return -EFAULT;\n \t\t\t\t    size_t npages)\n {\n \tfor (; npages; npages--) {\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/iommu/iommufd/selftest.c b/drivers/iommu/iommufd/selftest.c\nindex 74c2076105d4..a169a821222d 100644\n--- a/drivers/iommu/iommufd/selftest.c\n+++ b/drivers/iommu/iommufd/selftest.c\n@@ -759,7 +759,8 @@ 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+pr_err(\"get_user_pages_fast failed to pin exactly one page\\n\");\n \t\t\treturn -EFAULT;\n \t\tput_page(tmp_pages[0]);\n \t\tif (tmp_pages[0] != *pages)\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "35dd38010e383ee37d27b39f6b50eb25b4c92dd2": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/media/usb/siano/smsusb.c b/drivers/media/usb/siano/smsusb.c\nindex 6f443c542c6d..c1c6e19c5d81 100644\n--- a/drivers/media/usb/siano/smsusb.c\n+++ b/drivers/media/usb/siano/smsusb.c\n@@ -180,6 +180,7 @@ static void smsusb_stop_streaming(struct smsusb_device_t *dev)\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+        pr_debug(\"Work item for urb %d canceled successfully\\n\", i);\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..469990cf64bd 100644\n--- a/drivers/media/usb/siano/smsusb.c\n+++ b/drivers/media/usb/siano/smsusb.c\n@@ -179,7 +179,10 @@ 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+            flush_work(&dev->surbs[i].wq);\n+        }\n+        cancel_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"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/media/usb/siano/smsusb.c b/drivers/media/usb/siano/smsusb.c\nindex 6f443c542c6d..6dfeca4e47ca 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.data)\n+            cancel_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",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/media/usb/siano/smsusb.c b/drivers/media/usb/siano/smsusb.c\nindex 6f443c542c6d..56e432b05362 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)\n+        cancel_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",
                "error_message": "Failed to build"
            }
        ]
    },
    "9e03d0567a2ff908a4bcf8bc378c03be4afdd75d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/rcu/rcutorture.c b/kernel/rcu/rcutorture.c\nindex 634df26a2c27..39e249399e95 100644\n--- a/kernel/rcu/rcutorture.c\n+++ b/kernel/rcu/rcutorture.c\n@@ -713,7 +713,9 @@ static void srcu_torture_stats(void)\n \n static void srcu_torture_synchronize_expedited(void)\n {\n-\tsynchronize_srcu_expedited(srcu_ctlp);\n+\tif (should_trigger_expedited()) {\n+        synchronize_srcu_expedited(srcu_ctlp);\n+    }\n }\n \n static struct rcu_torture_ops srcu_ops = {\n",
            "diff --git a/kernel/rcu/tree_stall.h b/kernel/rcu/tree_stall.h\nindex 5653560573e2..52fad0de812c 100644\n--- a/kernel/rcu/tree_stall.h\n+++ b/kernel/rcu/tree_stall.h\n@@ -100,7 +100,8 @@ bool rcu_gp_might_be_stalled(void)\n \t// of ULONG_MAX/4 jiffies voids your no-false-positive warranty.\n \tsmp_mb(); // .gp_seq before second .gp_start\n \t// And ditto here.\n-\treturn !time_before(j, READ_ONCE(rcu_state.gp_start) + d);\n+\tprintk(KERN_INFO \"RCU stall detected: j=%lu, gp_start=%lu, d=%lu\\n\", j, READ_ONCE(rcu_state.gp_start), d);\n+return !time_before(j, READ_ONCE(rcu_state.gp_start) + d);\n }\n \n /* Don't do RCU CPU stall warnings during long sysrq printouts. */\n"
        ],
        "error": [
            {
                "patch": "diff --git a/kernel/rcu/tree_stall.h b/kernel/rcu/tree_stall.h\nindex 5653560573e2..03a1c9a84d02 100644\n--- a/kernel/rcu/tree_stall.h\n+++ b/kernel/rcu/tree_stall.h\n@@ -925,6 +925,7 @@ static void rcu_check_gp_start_stall(struct rcu_node *rnp, struct rcu_data *rdp,\n \traw_spin_lock_irqsave_rcu_node(rnp, flags);\n \tj = jiffies;\n \tif (rcu_gp_in_progress() ||\n+    gpssdelay < MIN_GRACE_PERIOD_DELAY ||\n \t    ULONG_CMP_GE(READ_ONCE(rnp_root->gp_seq),\n \t\t\t READ_ONCE(rnp_root->gp_seq_needed)) ||\n \t    time_before(j, READ_ONCE(rcu_state.gp_req_activity) + gpssdelay) ||\n@@ -939,6 +940,7 @@ static void rcu_check_gp_start_stall(struct rcu_node *rnp, struct rcu_data *rdp,\n \t\traw_spin_lock_rcu_node(rnp_root); /* irqs already disabled. */\n \tj = jiffies;\n \tif (rcu_gp_in_progress() ||\n+    gpssdelay < MIN_GRACE_PERIOD_DELAY ||\n \t    ULONG_CMP_GE(READ_ONCE(rnp_root->gp_seq),\n \t\t\t READ_ONCE(rnp_root->gp_seq_needed)) ||\n \t    time_before(j, READ_ONCE(rcu_state.gp_req_activity) + gpssdelay) ||\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/kernel/rcu/tree_exp.h b/kernel/rcu/tree_exp.h\nindex ed6c3cce28f2..41aa8175ef8d 100644\n--- a/kernel/rcu/tree_exp.h\n+++ b/kernel/rcu/tree_exp.h\n@@ -587,6 +587,7 @@ static void synchronize_rcu_expedited_wait(void)\n \tint cpu;\n \tunsigned long j;\n \tunsigned long jiffies_stall;\n+unsigned long stall_detected_count = 0;\n \tunsigned long jiffies_start;\n \tunsigned long mask;\n \tint ndetected;\n@@ -636,6 +637,7 @@ static void synchronize_rcu_expedited_wait(void)\n \t\t\t\tif (!(READ_ONCE(rnp->expmask) & mask))\n \t\t\t\t\tcontinue;\n \t\t\t\tndetected++;\n+stall_detected_count++;\n \t\t\t\trdp = per_cpu_ptr(&rcu_data, cpu);\n \t\t\t\tpr_cont(\" %d-%c%c%c%c\", cpu,\n \t\t\t\t\t\"O.\"[!!cpu_online(cpu)],\n@@ -806,6 +808,7 @@ static int rcu_print_task_exp_stall(struct rcu_node *rnp)\n \tlist_for_each_entry_continue(t, &rnp->blkd_tasks, rcu_node_entry) {\n \t\tpr_cont(\" P%d\", t->pid);\n \t\tndetected++;\n+stall_detected_count++;\n \t}\n \traw_spin_unlock_irqrestore_rcu_node(rnp, flags);\n \treturn ndetected;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "12be9aa373be9d8727cdd172f190de39528a413a": {
        "non_crash": [
            "diff --git a/security/selinux/hooks.c b/security/selinux/hooks.c\nindex 4c037c2545c1..1c8fbab8b215 100644\n--- a/security/selinux/hooks.c\n+++ b/security/selinux/hooks.c\n@@ -4838,7 +4838,9 @@ 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-\treturn sock_has_perm(sock->sk, SOCKET__READ);\n+\tif (!sock || !sock->sk)\n+    return -EINVAL;\n+return sock_has_perm(sock->sk, SOCKET__READ);\n }\n \n static int selinux_socket_getsockname(struct socket *sock)\n",
            "diff --git a/security/selinux/hooks.c b/security/selinux/hooks.c\nindex 4c037c2545c1..b842ee6ed00a 100644\n--- a/security/selinux/hooks.c\n+++ b/security/selinux/hooks.c\n@@ -4838,7 +4838,10 @@ 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-\treturn sock_has_perm(sock->sk, SOCKET__READ);\n+\tif (!sock || !sock->sk)\n+    return -EINVAL;\n+\n+return sock_has_perm(sock->sk, SOCKET__READ);\n }\n \n static int selinux_socket_getsockname(struct socket *sock)\n",
            "diff --git a/security/selinux/hooks.c b/security/selinux/hooks.c\nindex 4c037c2545c1..daf7c6f8a37c 100644\n--- a/security/selinux/hooks.c\n+++ b/security/selinux/hooks.c\n@@ -4838,7 +4838,9 @@ 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-\treturn sock_has_perm(sock->sk, SOCKET__READ);\n+\tif (!sock || !sock->sk)\n+return -EINVAL;\n+return sock_has_perm(sock->sk, SOCKET__READ);\n }\n \n static int selinux_socket_getsockname(struct socket *sock)\n",
            "diff --git a/security/selinux/hooks.c b/security/selinux/hooks.c\nindex 4c037c2545c1..d8dc26c4f319 100644\n--- a/security/selinux/hooks.c\n+++ b/security/selinux/hooks.c\n@@ -4838,7 +4838,9 @@ 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-\treturn sock_has_perm(sock->sk, SOCKET__READ);\n+\tif (!sock || !sock->sk)\n+        return -EINVAL;\n+    return sock_has_perm(sock->sk, SOCKET__READ);\n }\n \n static int selinux_socket_getsockname(struct socket *sock)\n",
            "diff --git a/security/selinux/hooks.c b/security/selinux/hooks.c\nindex 4c037c2545c1..d8dc26c4f319 100644\n--- a/security/selinux/hooks.c\n+++ b/security/selinux/hooks.c\n@@ -4838,7 +4838,9 @@ 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-\treturn sock_has_perm(sock->sk, SOCKET__READ);\n+\tif (!sock || !sock->sk)\n+        return -EINVAL;\n+    return sock_has_perm(sock->sk, SOCKET__READ);\n }\n \n static int selinux_socket_getsockname(struct socket *sock)\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "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..d7b71ab05166 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -2542,6 +2542,7 @@ 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+if (!fileio) return -EINVAL;\n \n \tif (fileio) {\n \t\tvb2_core_streamoff(q, q->type);\n@@ -2595,6 +2596,7 @@ static size_t __vb2_perform_fileio(struct vb2_queue *q, char __user *data, size_\n \t\t\treturn ret;\n \t}\n \tfileio = q->fileio;\n+if (!fileio) return -EINVAL;\n \n \t/*\n \t * Check if we need to dequeue the buffer.\n",
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex b98ec6e1a222..cc06494c29a6 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -2542,6 +2542,7 @@ 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+    if (!fileio) return -EFAULT;\n \n \tif (fileio) {\n \t\tvb2_core_streamoff(q, q->type);\n@@ -2595,6 +2596,7 @@ static size_t __vb2_perform_fileio(struct vb2_queue *q, char __user *data, size_\n \t\t\treturn ret;\n \t}\n \tfileio = q->fileio;\n+    if (!fileio) return -EFAULT;\n \n \t/*\n \t * Check if we need to dequeue the buffer.\n",
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex b98ec6e1a222..7568cf43dd0d 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -2594,7 +2594,8 @@ static size_t __vb2_perform_fileio(struct vb2_queue *q, char __user *data, size_\n \t\tif (ret)\n \t\t\treturn ret;\n \t}\n-\tfileio = q->fileio;\n+\tif (!q->fileio) return -EFAULT;\n+fileio = q->fileio;\n \n \t/*\n \t * Check if we need to dequeue the buffer.\n",
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex b98ec6e1a222..174d97cbf395 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -2080,7 +2080,7 @@ int vb2_core_expbuf(struct vb2_queue *q, int *fd, unsigned int type,\n \t\treturn -EINVAL;\n \t}\n \n-\tif (index >= q->num_buffers) {\n+\tif (index >= q->num_buffers || !q->bufs[index]) {\n \t\tdprintk(1, \"buffer index out of range\\n\");\n \t\treturn -EINVAL;\n \t}\n@@ -2600,7 +2600,7 @@ static size_t __vb2_perform_fileio(struct vb2_queue *q, char __user *data, size_\n \t * Check if we need to dequeue the buffer.\n \t */\n \tindex = fileio->cur_index;\n-\tif (index >= q->num_buffers) {\n+\tif (index >= q->num_buffers || !q->bufs[index]) {\n \t\tstruct vb2_buffer *b;\n \n \t\t/*\n",
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex b98ec6e1a222..4cee6d746830 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -2613,7 +2613,11 @@ static size_t __vb2_perform_fileio(struct vb2_queue *q, char __user *data, size_\n \t\tfileio->dq_count += 1;\n \n \t\tfileio->cur_index = index;\n-\t\tbuf = &fileio->bufs[index];\n+\t\tif (index < q->num_buffers) {\n+            buf = &fileio->bufs[index];\n+        } else {\n+            return -EINVAL;\n+        }\n \t\tb = q->bufs[index];\n \n \t\t/*\n@@ -2630,7 +2634,11 @@ static size_t __vb2_perform_fileio(struct vb2_queue *q, char __user *data, size_\n \t\t\tbuf->size -= buf->pos;\n \t\t}\n \t} else {\n-\t\tbuf = &fileio->bufs[index];\n+\t\tif (index < q->num_buffers) {\n+            buf = &fileio->bufs[index];\n+        } else {\n+            return -EINVAL;\n+        }\n \t}\n \n \t/*\n"
        ],
        "error": []
    },
    "8dc7a6aed7b8ead4c982ecdf2cd1ea5a4c3b57bb": {
        "non_crash": [
            "diff --git a/fs/inode.c b/fs/inode.c\nindex b608528efd3a..547e19baf50a 100644\n--- a/fs/inode.c\n+++ b/fs/inode.c\n@@ -2010,7 +2010,10 @@ static int __remove_privs(struct user_namespace *mnt_userns,\n \t * Note we call this on write, so notify_change will not\n \t * encounter any conflicting delegations:\n \t */\n-\treturn notify_change(mnt_userns, dentry, &newattrs, NULL);\n+\tinode_lock(dentry->d_inode);\n+    int result = notify_change(mnt_userns, dentry, &newattrs, NULL);\n+    inode_unlock(dentry->d_inode);\n+    return result;\n }\n \n static int __file_remove_privs(struct file *file, unsigned int flags)\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/inode.c b/fs/inode.c\nindex b608528efd3a..59de01faf423 100644\n--- a/fs/inode.c\n+++ b/fs/inode.c\n@@ -2006,6 +2006,7 @@ static int __remove_privs(struct user_namespace *mnt_userns,\n \tstruct iattr newattrs;\n \n \tnewattrs.ia_valid = ATTR_FORCE | kill;\n+inode_lock(dentry->d_inode);\n \t/*\n \t * Note we call this on write, so notify_change will not\n \t * encounter any conflicting delegations:\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/btrfs/file.c b/fs/btrfs/file.c\nindex d01631d47806..6ef3bab6e4e7 100644\n--- a/fs/btrfs/file.c\n+++ b/fs/btrfs/file.c\n@@ -1452,7 +1452,9 @@ static int btrfs_write_check(struct kiocb *iocb, struct iov_iter *from,\n \t\treturn -EAGAIN;\n \n \tcurrent->backing_dev_info = inode_to_bdi(inode);\n-\tret = file_remove_privs(file);\n+\tbtrfs_inode_lock(inode);\n+    ret = file_remove_privs(file);\n+    btrfs_inode_unlock(inode);\n \tif (ret)\n \t\treturn ret;\n \ndiff --git a/fs/ceph/file.c b/fs/ceph/file.c\nindex 04fd34557de8..0c1b12f87488 100644\n--- a/fs/ceph/file.c\n+++ b/fs/ceph/file.c\n@@ -1825,7 +1825,9 @@ static ssize_t ceph_write_iter(struct kiocb *iocb, struct iov_iter *from)\n \t\tgoto out;\n \t}\n \n-\terr = file_remove_privs(file);\n+\tinode_lock(inode);\n+    err = file_remove_privs(file);\n+    inode_unlock(inode);\n \tif (err)\n \t\tgoto out;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/inode.c b/fs/inode.c\nindex b608528efd3a..ff5fdfd2fd48 100644\n--- a/fs/inode.c\n+++ b/fs/inode.c\n@@ -2010,7 +2010,10 @@ static int __remove_privs(struct user_namespace *mnt_userns,\n \t * Note we call this on write, so notify_change will not\n \t * encounter any conflicting delegations:\n \t */\n-\treturn notify_change(mnt_userns, dentry, &newattrs, NULL);\n+\treturn inode_lock(inode);\n+    error = notify_change(mnt_userns, dentry, &newattrs, NULL);\n+    inode_unlock(inode);\n+    return error;\n }\n \n static int __file_remove_privs(struct file *file, unsigned int flags)\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..d67c923ee878 100644\n--- a/fs/btrfs/ordered-data.c\n+++ b/fs/btrfs/ordered-data.c\n@@ -376,6 +376,9 @@ bool btrfs_finish_ordered_extent(struct btrfs_ordered_extent *ordered,\n \tunsigned long flags;\n \tbool ret;\n \n+    if (!ordered)\n+        return false;\n+\n \ttrace_btrfs_finish_ordered_extent(inode, file_offset, len, uptodate);\n \n \tspin_lock_irqsave(&inode->ordered_tree.lock, flags);\n",
            "diff --git a/fs/btrfs/ordered-data.c b/fs/btrfs/ordered-data.c\nindex a629532283bc..ae72499eb866 100644\n--- a/fs/btrfs/ordered-data.c\n+++ b/fs/btrfs/ordered-data.c\n@@ -376,7 +376,10 @@ bool btrfs_finish_ordered_extent(struct btrfs_ordered_extent *ordered,\n \tunsigned long flags;\n \tbool ret;\n \n-\ttrace_btrfs_finish_ordered_extent(inode, file_offset, len, uptodate);\n+\tif (!ordered || !ordered->inode) {\n+        return false;\n+    }\n+    trace_btrfs_finish_ordered_extent(inode, file_offset, len, uptodate);\n \n \tspin_lock_irqsave(&inode->ordered_tree.lock, flags);\n \tret = can_finish_ordered_extent(ordered, page, file_offset, len, uptodate);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/btrfs/ordered-data.c b/fs/btrfs/ordered-data.c\nindex a629532283bc..4062a4eb1ef9 100644\n--- a/fs/btrfs/ordered-data.c\n+++ b/fs/btrfs/ordered-data.c\n@@ -369,6 +369,7 @@ static void btrfs_queue_ordered_fn(struct btrfs_ordered_extent *ordered)\n }\n \n bool btrfs_finish_ordered_extent(struct btrfs_ordered_extent *ordered,\n+    if (!ordered) return false;\n \t\t\t\t struct page *page, u64 file_offset, u64 len,\n \t\t\t\t bool uptodate)\n {\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/btrfs/ordered-data.c b/fs/btrfs/ordered-data.c\nindex a629532283bc..286b1ed5073e 100644\n--- a/fs/btrfs/ordered-data.c\n+++ b/fs/btrfs/ordered-data.c\n@@ -304,6 +304,10 @@ static void finish_ordered_fn(struct btrfs_work *work)\n }\n \n static bool can_finish_ordered_extent(struct btrfs_ordered_extent *ordered,\n+{\n+    if (!ordered->inode) {\n+        return false;\n+    }\n \t\t\t\t      struct page *page, u64 file_offset,\n \t\t\t\t      u64 len, bool uptodate)\n {\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "f07cf3e7df6d272b92ccdabfeef07ae06c014ca5": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/namei.c b/fs/ext4/namei.c\nindex e8f429330f3c..d92827f83187 100644\n--- a/fs/ext4/namei.c\n+++ b/fs/ext4/namei.c\n@@ -3877,7 +3877,8 @@ 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\tinode_unlock(old.inode);\n+    inode_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",
            "diff --git a/fs/ext4/namei.c b/fs/ext4/namei.c\nindex e8f429330f3c..6ff415e830d1 100644\n--- a/fs/ext4/namei.c\n+++ b/fs/ext4/namei.c\n@@ -3877,7 +3877,7 @@ 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// inode_lock_nested(old.inode, I_MUTEX_NONDIR2); // Temporarily commented out for deadlock resolution\n \t\tretval = ext4_rename_dir_prepare(handle, &old);\n \t\tif (retval) {\n \t\t\tinode_unlock(old.inode);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/namei.c b/fs/ext4/namei.c\nindex e8f429330f3c..587b2e56eedd 100644\n--- a/fs/ext4/namei.c\n+++ b/fs/ext4/namei.c\n@@ -3877,7 +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\tif (!inode_trylock_nested(old.inode, I_MUTEX_NONDIR2)) {\n+            jbd2_log_wait_commit(journal, tid);\n+            inode_lock_nested(old.inode, I_MUTEX_NONDIR2);\n+        }\n \t\tretval = ext4_rename_dir_prepare(handle, &old);\n \t\tif (retval) {\n \t\t\tinode_unlock(old.inode);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "b5ecc684bb9e49db213e88f69d4ce80f7e20238d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/nfc/nci/core.c b/net/nfc/nci/core.c\nindex dbe5258e13ff..307299e4d3f6 100644\n--- a/net/nfc/nci/core.c\n+++ b/net/nfc/nci/core.c\n@@ -542,7 +542,8 @@ static int nci_open_device(struct nci_dev *ndev)\n \t\tskb_queue_purge(&ndev->rx_q);\n \t\tskb_queue_purge(&ndev->tx_q);\n \n-\t\tndev->ops->close(ndev);\n+\t\tmutex_unlock(&ndev->req_lock);\n+    ndev->ops->close(ndev);\n \t\tndev->flags = 0;\n \t}\n \n@@ -590,7 +591,8 @@ static int nci_close_device(struct nci_dev *ndev)\n \t/* After this point our queues are empty\n \t * and no works are scheduled.\n \t */\n-\tndev->ops->close(ndev);\n+\tmutex_unlock(&ndev->req_lock);\n+    ndev->ops->close(ndev);\n \n \tclear_bit(NCI_INIT, &ndev->flags);\n \n",
            "diff --git a/net/nfc/nci/core.c b/net/nfc/nci/core.c\nindex dbe5258e13ff..51522a4c5c32 100644\n--- a/net/nfc/nci/core.c\n+++ b/net/nfc/nci/core.c\n@@ -542,7 +542,9 @@ static int nci_open_device(struct nci_dev *ndev)\n \t\tskb_queue_purge(&ndev->rx_q);\n \t\tskb_queue_purge(&ndev->tx_q);\n \n-\t\tndev->ops->close(ndev);\n+\t\tmutex_unlock(&ndev->req_lock);\n+ndev->ops->close(ndev);\n+mutex_lock(&ndev->req_lock);\n \t\tndev->flags = 0;\n \t}\n \n@@ -590,7 +592,9 @@ static int nci_close_device(struct nci_dev *ndev)\n \t/* After this point our queues are empty\n \t * and no works are scheduled.\n \t */\n-\tndev->ops->close(ndev);\n+\tmutex_unlock(&ndev->req_lock);\n+ndev->ops->close(ndev);\n+mutex_lock(&ndev->req_lock);\n \n \tclear_bit(NCI_INIT, &ndev->flags);\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/nfc/nci/core.c b/net/nfc/nci/core.c\nindex dbe5258e13ff..998dcff04862 100644\n--- a/net/nfc/nci/core.c\n+++ b/net/nfc/nci/core.c\n@@ -147,6 +147,10 @@ inline int nci_request(struct nci_dev *ndev,\n \n \t/* Serialize all requests */\n \tmutex_lock(&ndev->req_lock);\n+\n+    /* Release req_lock before calling ops->close to avoid deadlock */\n+    mutex_unlock(&ndev->req_lock);\n+    mutex_lock(&ndev->req_lock);\n \t/* check the state after obtaing the lock against any races\n \t * from nci_close_device when the device gets removed.\n \t */\n@@ -477,6 +481,10 @@ static int nci_open_device(struct nci_dev *ndev)\n \n \tmutex_lock(&ndev->req_lock);\n \n+    /* Release req_lock before calling ops->close to avoid deadlock */\n+    mutex_unlock(&ndev->req_lock);\n+    mutex_lock(&ndev->req_lock);\n+\n \tif (test_bit(NCI_UNREG, &ndev->flags)) {\n \t\trc = -ENODEV;\n \t\tgoto done;\n@@ -560,6 +568,10 @@ static int nci_close_device(struct nci_dev *ndev)\n \t */\n \tmutex_lock(&ndev->req_lock);\n \n+    /* Release req_lock before calling ops->close to avoid deadlock */\n+    mutex_unlock(&ndev->req_lock);\n+    mutex_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@@ -1285,6 +1297,10 @@ void nci_unregister_device(struct nci_dev *ndev)\n \n \t/* This set_bit is not protected with specialized barrier,\n \t * However, it is fine because the mutex_lock(&ndev->req_lock);\n+\n+    /* Release req_lock before calling ops->close to avoid deadlock */\n+    mutex_unlock(&ndev->req_lock);\n+    mutex_lock(&ndev->req_lock);\n \t * in nci_close_device() will help to emit one.\n \t */\n \tset_bit(NCI_UNREG, &ndev->flags);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "5c8b4f0ea10c23945625f4187bac8e6e471d732c": {
        "non_crash": [
            "diff --git a/mm/util.c b/mm/util.c\nindex 7e43369064c8..b217340d517e 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 (PageCompound(page) && PageDoubleMap(page))\n \t\tret--;\n \treturn ret;\n }\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/huge_memory.c b/mm/huge_memory.c\nindex 406a3c28c026..e3471a40e93e 100644\n--- a/mm/huge_memory.c\n+++ b/mm/huge_memory.c\n@@ -2513,7 +2513,7 @@ int total_mapcount(struct page *page)\n \t/* File pages has compound_mapcount included in _mapcount */\n \tif (!PageAnon(page))\n \t\treturn ret - compound * nr;\n-\tif (PageDoubleMap(page))\n+\tif (trylock_page(page) && PageDoubleMap(page))\n \t\tret -= nr;\n \treturn ret;\n }\n@@ -2560,7 +2560,7 @@ int page_trans_huge_mapcount(struct page *page)\n \t\tret = max(ret, mapcount);\n \t}\n \n-\tif (PageDoubleMap(page))\n+\tif (trylock_page(page) && PageDoubleMap(page))\n \t\tret -= 1;\n \n \treturn ret + compound_mapcount(page);\n",
            "diff --git a/mm/rmap.c b/mm/rmap.c\nindex 6a1e8c7f6213..fac848e7c968 100644\n--- a/mm/rmap.c\n+++ b/mm/rmap.c\n@@ -1297,7 +1297,10 @@ static void page_remove_file_rmap(struct page *page, bool compound)\n \t\t\tif (atomic_add_negative(-1, &page[i]._mapcount))\n \t\t\t\tnr++;\n \t\t}\n-\t\tif (!atomic_add_negative(-1, compound_mapcount_ptr(page)))\n+\t\tif (!atomic_add_negative(-1, compound_mapcount_ptr(page))) {\n+        VM_BUG_ON_PAGE(!PageHead(page), page);\n+        return;\n+    }\n \t\t\treturn;\n \t\tif (PageSwapBacked(page))\n \t\t\t__mod_lruvec_page_state(page, NR_SHMEM_PMDMAPPED,\n@@ -1325,7 +1328,10 @@ static void page_remove_anon_compound_rmap(struct page *page)\n {\n \tint i, nr;\n \n-\tif (!atomic_add_negative(-1, compound_mapcount_ptr(page)))\n+\tif (!atomic_add_negative(-1, compound_mapcount_ptr(page))) {\n+        VM_BUG_ON_PAGE(!PageHead(page), page);\n+        return;\n+    }\n \t\treturn;\n \n \t/* Hugepages are not counted in NR_ANON_PAGES for now. */\n"
        ],
        "error": [
            {
                "patch": "diff --git a/mm/util.c b/mm/util.c\nindex 7e43369064c8..c2d45d83080b 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+\tif (PageDoubleMap(page)) {\n+    /* Ensure valid usage of PageDoubleMap */\n+    VM_BUG_ON_PAGE(!PageCompound(page), page);\n+    ret--;\n+}\n \t\tret--;\n \treturn ret;\n }\n",
                "error_message": "Failed to set up instance"
            }
        ]
    },
    "789df5b54ebd19aec0b5c3900c933d1910db8ec5": {
        "non_crash": [
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 6bdd502527f8..889a8ca3a458 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2213,7 +2213,8 @@ int ext4_xattr_ibody_set(handle_t *handle, struct inode *inode,\n \tint error;\n \n \tif (!EXT4_INODE_HAS_XATTR_SPACE(inode))\n-\t\treturn -ENOSPC;\n+\t\tea_idebug(inode, \"Failed to allocate space for extra isize expansion\");\n+                return -ENOSPC;\n \n \terror = ext4_xattr_set_entry(i, s, handle, inode, false /* is_block */);\n \tif (error)\n@@ -2654,7 +2655,8 @@ static int ext4_xattr_make_inode_space(handle_t *handle, struct inode *inode,\n \n \t\tif (entry == NULL) {\n \t\t\tif (small_entry == NULL)\n-\t\t\t\treturn -ENOSPC;\n+\t\t\t\tea_idebug(inode, \"Failed to allocate space for extra isize expansion\");\n+                return -ENOSPC;\n \t\t\tentry = small_entry;\n \t\t}\n \n",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 6bdd502527f8..1f8771ef0aff 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2625,7 +2625,10 @@ static int ext4_xattr_make_inode_space(handle_t *handle, struct inode *inode,\n \tunsigned int min_total_size;\n \tint error;\n \n-\twhile (isize_diff > ifree) {\n+\tif (isize_diff > ifree) {\n+        return -ENOSPC;\n+    }\n+    while (isize_diff > ifree) {\n \t\tentry = NULL;\n \t\tsmall_entry = NULL;\n \t\tmin_total_size = ~0U;\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 6bdd502527f8..96408faa3867 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2652,7 +2652,7 @@ static int ext4_xattr_make_inode_space(handle_t *handle, struct inode *inode,\n \t\t\t}\n \t\t}\n \n-\t\tif (entry == NULL) {\n+\t\tif (entry == NULL || total_size > MAX_SIZE_ALLOWED) {\n \t\t\tif (small_entry == NULL)\n \t\t\t\treturn -ENOSPC;\n \t\t\tentry = small_entry;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 6bdd502527f8..29826e488a03 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -1322,6 +1322,9 @@ static size_t ext4_xattr_free_space(struct ext4_xattr_entry *last,\n \t\t\t\t    size_t *min_offs, void *base, int *total)\n {\n \tfor (; !IS_LAST_ENTRY(last); last = EXT4_XATTR_NEXT(last)) {\n+    if (!last || !last->e_name_len) {\n+        return -EINVAL;\n+    }\n \t\tif (!last->e_value_inum && last->e_value_size) {\n \t\t\tsize_t offs = le16_to_cpu(last->e_value_offs);\n \t\t\tif (offs < *min_offs)\n@@ -2516,6 +2519,9 @@ static void ext4_xattr_shift_entries(struct ext4_xattr_entry *entry,\n \n \t/* Adjust the value offsets of the entries */\n \tfor (; !IS_LAST_ENTRY(last); last = EXT4_XATTR_NEXT(last)) {\n+    if (!last || !last->e_name_len) {\n+        return -EINVAL;\n+    }\n \t\tif (!last->e_value_inum && last->e_value_size) {\n \t\t\tnew_offs = le16_to_cpu(last->e_value_offs) +\n \t\t\t\t\t\t\tvalue_offs_shift;\n@@ -2632,6 +2638,9 @@ static int ext4_xattr_make_inode_space(handle_t *handle, struct inode *inode,\n \t\tlast = IFIRST(header);\n \t\t/* Find the entry best suited to be pushed into EA block */\n \t\tfor (; !IS_LAST_ENTRY(last); last = EXT4_XATTR_NEXT(last)) {\n+    if (!last || !last->e_name_len) {\n+        return -EINVAL;\n+    }\n \t\t\t/* never move system.data out of the inode */\n \t\t\tif ((last->e_name_len == 4) &&\n \t\t\t    (last->e_name_index == EXT4_XATTR_INDEX_SYSTEM) &&\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "5e2e50e2c145ca06459e9e0900c20eefd1a0877e": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/9p/trans_fd.c b/net/9p/trans_fd.c\nindex 56a186768750..851b8d758a2e 100644\n--- a/net/9p/trans_fd.c\n+++ b/net/9p/trans_fd.c\n@@ -211,7 +211,10 @@ static void p9_conn_cancel(struct p9_conn *m, int err)\n \n \tlist_for_each_entry_safe(req, rtmp, &cancel_list, req_list) {\n \t\tp9_debug(P9_DEBUG_ERROR, \"call back req %p\\n\", req);\n-\t\tlist_del(&req->req_list);\n+\t\tif (req->status != REQ_STATUS_FLSHD && req->status != REQ_STATUS_RCVD) {\n+        list_del(&req->req_list);\n+        req->status = REQ_STATUS_FLSHD;\n+    }\n \t\tif (!req->t_err)\n \t\t\treq->t_err = err;\n \t\tp9_client_cb(m->client, req, REQ_STATUS_ERROR);\n@@ -700,7 +703,10 @@ static int p9_fd_cancel(struct p9_client *client, struct p9_req_t *req)\n \tspin_lock(&m->req_lock);\n \n \tif (req->status == REQ_STATUS_UNSENT) {\n-\t\tlist_del(&req->req_list);\n+\t\tif (req->status != REQ_STATUS_FLSHD && req->status != REQ_STATUS_RCVD) {\n+        list_del(&req->req_list);\n+        req->status = REQ_STATUS_FLSHD;\n+    }\n \t\treq->status = REQ_STATUS_FLSHD;\n \t\tp9_req_put(client, req);\n \t\tret = 0;\n@@ -729,7 +735,10 @@ static int p9_fd_cancelled(struct p9_client *client, struct p9_req_t *req)\n \t/* we haven't received a response for oldreq,\n \t * remove it from the list.\n \t */\n-\tlist_del(&req->req_list);\n+\tif (req->status != REQ_STATUS_FLSHD && req->status != REQ_STATUS_RCVD) {\n+        list_del(&req->req_list);\n+        req->status = REQ_STATUS_FLSHD;\n+    }\n \treq->status = REQ_STATUS_FLSHD;\n \tspin_unlock(&m->req_lock);\n \n",
            "diff --git a/net/9p/trans_fd.c b/net/9p/trans_fd.c\nindex 56a186768750..657bb65b401c 100644\n--- a/net/9p/trans_fd.c\n+++ b/net/9p/trans_fd.c\n@@ -211,7 +211,9 @@ static void p9_conn_cancel(struct p9_conn *m, int err)\n \n \tlist_for_each_entry_safe(req, rtmp, &cancel_list, req_list) {\n \t\tp9_debug(P9_DEBUG_ERROR, \"call back req %p\\n\", req);\n-\t\tlist_del(&req->req_list);\n+\t\tif (!list_empty(&req->req_list)) {\n+            list_del(&req->req_list);\n+        }\n \t\tif (!req->t_err)\n \t\t\treq->t_err = err;\n \t\tp9_client_cb(m->client, req, REQ_STATUS_ERROR);\n@@ -700,7 +702,9 @@ static int p9_fd_cancel(struct p9_client *client, struct p9_req_t *req)\n \tspin_lock(&m->req_lock);\n \n \tif (req->status == REQ_STATUS_UNSENT) {\n-\t\tlist_del(&req->req_list);\n+\t\tif (!list_empty(&req->req_list)) {\n+            list_del(&req->req_list);\n+        }\n \t\treq->status = REQ_STATUS_FLSHD;\n \t\tp9_req_put(client, req);\n \t\tret = 0;\n@@ -729,7 +733,9 @@ static int p9_fd_cancelled(struct p9_client *client, struct p9_req_t *req)\n \t/* we haven't received a response for oldreq,\n \t * remove it from the list.\n \t */\n-\tlist_del(&req->req_list);\n+\tif (!list_empty(&req->req_list)) {\n+            list_del(&req->req_list);\n+        }\n \treq->status = REQ_STATUS_FLSHD;\n \tspin_unlock(&m->req_lock);\n \n",
            "diff --git a/net/9p/trans_fd.c b/net/9p/trans_fd.c\nindex 56a186768750..175a99ada190 100644\n--- a/net/9p/trans_fd.c\n+++ b/net/9p/trans_fd.c\n@@ -699,7 +699,7 @@ static int p9_fd_cancel(struct p9_client *client, struct p9_req_t *req)\n \n \tspin_lock(&m->req_lock);\n \n-\tif (req->status == REQ_STATUS_UNSENT) {\n+\tif (req->status == REQ_STATUS_UNSENT && !list_empty(&req->req_list)) {\n \t\tlist_del(&req->req_list);\n \t\treq->status = REQ_STATUS_FLSHD;\n \t\tp9_req_put(client, req);\n"
        ],
        "error": []
    },
    "cdc284a3166b0aa5c8797071e971fd0606769e61": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/core/neighbour.c b/net/core/neighbour.c\nindex 952a54763358..66e3dadb10d2 100644\n--- a/net/core/neighbour.c\n+++ b/net/core/neighbour.c\n@@ -672,14 +672,16 @@ ___neigh_create(struct neigh_table *tbl, const void *pkey,\n \t/* Protocol specific setup. */\n \tif (tbl->constructor &&\t(error = tbl->constructor(n)) < 0) {\n \t\trc = ERR_PTR(error);\n-\t\tgoto out_neigh_release;\n+\t\tneigh_release(n);\n+goto out_neigh_release;\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\trc = ERR_PTR(error);\n-\t\t\tgoto out_neigh_release;\n+\t\t\tneigh_release(n);\n+goto out_neigh_release;\n \t\t}\n \t}\n \n@@ -687,7 +689,8 @@ ___neigh_create(struct neigh_table *tbl, const void *pkey,\n \tif (n->parms->neigh_setup &&\n \t    (error = n->parms->neigh_setup(n)) < 0) {\n \t\trc = ERR_PTR(error);\n-\t\tgoto out_neigh_release;\n+\t\tneigh_release(n);\n+goto out_neigh_release;\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..66e3dadb10d2 100644\n--- a/net/core/neighbour.c\n+++ b/net/core/neighbour.c\n@@ -672,14 +672,16 @@ ___neigh_create(struct neigh_table *tbl, const void *pkey,\n \t/* Protocol specific setup. */\n \tif (tbl->constructor &&\t(error = tbl->constructor(n)) < 0) {\n \t\trc = ERR_PTR(error);\n-\t\tgoto out_neigh_release;\n+\t\tneigh_release(n);\n+goto out_neigh_release;\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\trc = ERR_PTR(error);\n-\t\t\tgoto out_neigh_release;\n+\t\t\tneigh_release(n);\n+goto out_neigh_release;\n \t\t}\n \t}\n \n@@ -687,7 +689,8 @@ ___neigh_create(struct neigh_table *tbl, const void *pkey,\n \tif (n->parms->neigh_setup &&\n \t    (error = n->parms->neigh_setup(n)) < 0) {\n \t\trc = ERR_PTR(error);\n-\t\tgoto out_neigh_release;\n+\t\tneigh_release(n);\n+goto out_neigh_release;\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..b5ad91c2be0c 100644\n--- a/net/core/neighbour.c\n+++ b/net/core/neighbour.c\n@@ -133,7 +133,7 @@ static void neigh_update_gc_list(struct neighbour *n)\n \twrite_lock_bh(&n->tbl->lock);\n \twrite_lock(&n->lock);\n \tif (n->dead)\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \n \t/* remove from the gc list if new state is permanent or if neighbor\n \t * is externally learned; otherwise entry should be on the gc list\n@@ -162,7 +162,7 @@ static void neigh_update_managed_list(struct neighbour *n)\n \twrite_lock_bh(&n->tbl->lock);\n \twrite_lock(&n->lock);\n \tif (n->dead)\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \n \tadd_to_managed = n->flags & NTF_MANAGED;\n \ton_managed_list = !list_empty(&n->managed_list);\n@@ -468,14 +468,14 @@ static struct neighbour *neigh_alloc(struct neigh_table *tbl,\n \t\t\tnet_info_ratelimited(\"%s: neighbor table overflow!\\n\",\n \t\t\t\t\t     tbl->id);\n \t\t\tNEIGH_CACHE_STAT_INC(tbl, table_fulls);\n-\t\t\tgoto out_entries;\n+\t\t\tgoto out_neigh_release_entries;\n \t\t}\n \t}\n \n do_alloc:\n \tn = kzalloc(tbl->entry_size + dev->neigh_priv_len, GFP_ATOMIC);\n \tif (!n)\n-\t\tgoto out_entries;\n+\t\tgoto out_neigh_release_entries;\n \n \t__skb_queue_head_init(&n->arp_queue);\n \trwlock_init(&n->lock);\n@@ -502,7 +502,7 @@ static struct neighbour *neigh_alloc(struct neigh_table *tbl,\n out_entries:\n \tif (!exempt_from_gc)\n \t\tatomic_dec(&tbl->gc_entries);\n-\tgoto out;\n+\tgoto out_neigh_release;\n }\n \n static void neigh_get_hash_rnd(u32 *x)\n@@ -662,7 +662,7 @@ ___neigh_create(struct neigh_table *tbl, const void *pkey,\n \ttrace_neigh_create(tbl, dev, pkey, n, exempt_from_gc);\n \tif (!n) {\n \t\trc = ERR_PTR(-ENOBUFS);\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \t}\n \n \tmemcpy(n->primary_key, pkey, key_len);\n@@ -672,14 +672,14 @@ ___neigh_create(struct neigh_table *tbl, const void *pkey,\n \t/* Protocol specific setup. */\n \tif (tbl->constructor &&\t(error = tbl->constructor(n)) < 0) {\n \t\trc = ERR_PTR(error);\n-\t\tgoto out_neigh_release;\n+\t\tgoto out_neigh_release_neigh_release;\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\trc = ERR_PTR(error);\n-\t\t\tgoto out_neigh_release;\n+\t\t\tgoto out_neigh_release_neigh_release;\n \t\t}\n \t}\n \n@@ -687,7 +687,7 @@ ___neigh_create(struct neigh_table *tbl, const void *pkey,\n \tif (n->parms->neigh_setup &&\n \t    (error = n->parms->neigh_setup(n)) < 0) {\n \t\trc = ERR_PTR(error);\n-\t\tgoto out_neigh_release;\n+\t\tgoto out_neigh_release_neigh_release;\n \t}\n \n \tn->confirmed = jiffies - (NEIGH_VAR(n->parms, BASE_REACHABLE_TIME) << 1);\n@@ -703,7 +703,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_tbl_unlock;\n \t}\n \n \tfor (n1 = rcu_dereference_protected(nht->hash_buckets[hash_val],\n@@ -715,7 +715,7 @@ ___neigh_create(struct neigh_table *tbl, const void *pkey,\n \t\t\tif (want_ref)\n \t\t\t\tneigh_hold(n1);\n \t\t\trc = n1;\n-\t\t\tgoto out_tbl_unlock;\n+\t\t\tgoto out_neigh_release_tbl_unlock;\n \t\t}\n \t}\n \n@@ -741,7 +741,7 @@ ___neigh_create(struct neigh_table *tbl, const void *pkey,\n \tif (!exempt_from_gc)\n \t\tatomic_dec(&tbl->gc_entries);\n \tneigh_release(n);\n-\tgoto out;\n+\tgoto out_neigh_release;\n }\n \n struct neighbour *__neigh_create(struct neigh_table *tbl, const void *pkey,\n@@ -802,13 +802,13 @@ struct pneigh_entry * pneigh_lookup(struct neigh_table *tbl,\n \tread_unlock_bh(&tbl->lock);\n \n \tif (n || !creat)\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \n \tASSERT_RTNL();\n \n \tn = kzalloc(sizeof(*n) + key_len, GFP_KERNEL);\n \tif (!n)\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \n \twrite_pnet(&n->net, net);\n \tmemcpy(n->key, pkey, key_len);\n@@ -819,7 +819,7 @@ struct pneigh_entry * pneigh_lookup(struct neigh_table *tbl,\n \t\tnetdev_put(dev, &n->dev_tracker);\n \t\tkfree(n);\n \t\tn = NULL;\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \t}\n \n \twrite_lock_bh(&tbl->lock);\n@@ -983,7 +983,7 @@ static void neigh_periodic_work(struct work_struct *work)\n \t}\n \n \tif (atomic_read(&tbl->entries) < tbl->gc_thresh1)\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \n \tfor (i = 0 ; i < (1 << nht->hash_shift); i++) {\n \t\tnp = &nht->hash_buckets[i];\n@@ -1101,7 +1101,7 @@ static void neigh_timer_handler(struct timer_list *t)\n \tnext = now + HZ;\n \n \tif (!(state & NUD_IN_TIMER))\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \n \tif (state & NUD_REACHABLE) {\n \t\tif (time_before_eq(now,\n@@ -1152,7 +1152,7 @@ static void neigh_timer_handler(struct timer_list *t)\n \t\tneigh->nud_state = NUD_FAILED;\n \t\tnotify = 1;\n \t\tneigh_invalidate(neigh);\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \t}\n \n \tif (neigh->nud_state & NUD_IN_TIMER) {\n@@ -1186,9 +1186,9 @@ int __neigh_event_send(struct neighbour *neigh, struct sk_buff *skb,\n \n \trc = 0;\n \tif (neigh->nud_state & (NUD_CONNECTED | NUD_DELAY | NUD_PROBE))\n-\t\tgoto out_unlock_bh;\n+\t\tgoto out_neigh_release_unlock_bh;\n \tif (neigh->dead)\n-\t\tgoto out_dead;\n+\t\tgoto out_neigh_release_dead;\n \n \tif (!(neigh->nud_state & (NUD_STALE | NUD_INCOMPLETE))) {\n \t\tif (NEIGH_VAR(neigh->parms, MCAST_PROBES) +\n@@ -1256,7 +1256,7 @@ int __neigh_event_send(struct neighbour *neigh, struct sk_buff *skb,\n \n out_dead:\n \tif (neigh->nud_state & NUD_STALE)\n-\t\tgoto out_unlock_bh;\n+\t\tgoto out_neigh_release_unlock_bh;\n \twrite_unlock_bh(&neigh->lock);\n \tkfree_skb_reason(skb, SKB_DROP_REASON_NEIGH_DEAD);\n \ttrace_neigh_event_send_dead(neigh, 1);\n@@ -1323,18 +1323,18 @@ static int __neigh_update(struct neighbour *neigh, const u8 *lladdr,\n \tif (neigh->dead) {\n \t\tNL_SET_ERR_MSG(extack, \"Neighbor entry is now dead\");\n \t\tnew = old;\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \t}\n \tif (!(flags & NEIGH_UPDATE_F_ADMIN) &&\n \t    (old & (NUD_NOARP | NUD_PERMANENT)))\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \n \tneigh_update_flags(neigh, flags, &notify, &gc_update, &managed_update);\n \tif (flags & (NEIGH_UPDATE_F_USE | NEIGH_UPDATE_F_MANAGED)) {\n \t\tnew = old & ~NUD_PERMANENT;\n \t\tneigh->nud_state = new;\n \t\terr = 0;\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \t}\n \n \tif (!(new & NUD_VALID)) {\n@@ -1349,7 +1349,7 @@ static int __neigh_update(struct neighbour *neigh, const u8 *lladdr,\n \t\t\tneigh_invalidate(neigh);\n \t\t\tnotify = 1;\n \t\t}\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \t}\n \n \t/* Compare new lladdr with cached one */\n@@ -1372,7 +1372,7 @@ static int __neigh_update(struct neighbour *neigh, const u8 *lladdr,\n \t\terr = -EINVAL;\n \t\tif (!(old & NUD_VALID)) {\n \t\t\tNL_SET_ERR_MSG(extack, \"No link layer address given\");\n-\t\t\tgoto out;\n+\t\t\tgoto out_neigh_release;\n \t\t}\n \t\tlladdr = neigh->ha;\n \t}\n@@ -1396,7 +1396,7 @@ static int __neigh_update(struct neighbour *neigh, const u8 *lladdr,\n \t\t\t\tlladdr = neigh->ha;\n \t\t\t\tnew = NUD_STALE;\n \t\t\t} else\n-\t\t\t\tgoto out;\n+\t\t\t\tgoto out_neigh_release;\n \t\t} else {\n \t\t\tif (lladdr == neigh->ha && new == NUD_STALE &&\n \t\t\t    !(flags & NEIGH_UPDATE_F_ADMIN))\n@@ -1435,7 +1435,7 @@ static int __neigh_update(struct neighbour *neigh, const u8 *lladdr,\n \t\tnotify = 1;\n \t}\n \tif (new == old)\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \tif (new & NUD_CONNECTED)\n \t\tneigh_connect(neigh);\n \telse\n@@ -1570,14 +1570,14 @@ int neigh_resolve_output(struct neighbour *neigh, struct sk_buff *skb)\n \t\tif (err >= 0)\n \t\t\trc = dev_queue_xmit(skb);\n \t\telse\n-\t\t\tgoto out_kfree_skb;\n+\t\t\tgoto out_neigh_release_kfree_skb;\n \t}\n out:\n \treturn rc;\n out_kfree_skb:\n \trc = -EINVAL;\n \tkfree_skb(skb);\n-\tgoto out;\n+\tgoto out_neigh_release;\n }\n EXPORT_SYMBOL(neigh_resolve_output);\n \n@@ -1902,12 +1902,12 @@ static int neigh_delete(struct sk_buff *skb, struct nlmsghdr *nlh,\n \n \tASSERT_RTNL();\n \tif (nlmsg_len(nlh) < sizeof(*ndm))\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \n \tdst_attr = nlmsg_find_attr(nlh, sizeof(*ndm), NDA_DST);\n \tif (!dst_attr) {\n \t\tNL_SET_ERR_MSG(extack, \"Network address not specified\");\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \t}\n \n \tndm = nlmsg_data(nlh);\n@@ -1915,7 +1915,7 @@ static int neigh_delete(struct sk_buff *skb, struct nlmsghdr *nlh,\n \t\tdev = __dev_get_by_index(net, ndm->ndm_ifindex);\n \t\tif (dev == NULL) {\n \t\t\terr = -ENODEV;\n-\t\t\tgoto out;\n+\t\t\tgoto out_neigh_release;\n \t\t}\n \t}\n \n@@ -1925,21 +1925,21 @@ static int neigh_delete(struct sk_buff *skb, struct nlmsghdr *nlh,\n \n \tif (nla_len(dst_attr) < (int)tbl->key_len) {\n \t\tNL_SET_ERR_MSG(extack, \"Invalid network address\");\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \t}\n \n \tif (ndm->ndm_flags & NTF_PROXY) {\n \t\terr = pneigh_delete(tbl, net, nla_data(dst_attr), dev);\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \t}\n \n \tif (dev == NULL)\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \n \tneigh = neigh_lookup(tbl, nla_data(dst_attr), dev);\n \tif (neigh == NULL) {\n \t\terr = -ENOENT;\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \t}\n \n \terr = __neigh_update(neigh, NULL, NUD_FAILED,\n@@ -1974,12 +1974,12 @@ static int neigh_add(struct sk_buff *skb, struct nlmsghdr *nlh,\n \terr = nlmsg_parse_deprecated(nlh, sizeof(*ndm), tb, NDA_MAX,\n \t\t\t\t     nda_policy, extack);\n \tif (err < 0)\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \n \terr = -EINVAL;\n \tif (!tb[NDA_DST]) {\n \t\tNL_SET_ERR_MSG(extack, \"Network address not specified\");\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \t}\n \n \tndm = nlmsg_data(nlh);\n@@ -1996,12 +1996,12 @@ static int neigh_add(struct sk_buff *skb, struct nlmsghdr *nlh,\n \t\tdev = __dev_get_by_index(net, ndm->ndm_ifindex);\n \t\tif (dev == NULL) {\n \t\t\terr = -ENODEV;\n-\t\t\tgoto out;\n+\t\t\tgoto out_neigh_release;\n \t\t}\n \n \t\tif (tb[NDA_LLADDR] && nla_len(tb[NDA_LLADDR]) < dev->addr_len) {\n \t\t\tNL_SET_ERR_MSG(extack, \"Invalid link address\");\n-\t\t\tgoto out;\n+\t\t\tgoto out_neigh_release;\n \t\t}\n \t}\n \n@@ -2011,7 +2011,7 @@ static int neigh_add(struct sk_buff *skb, struct nlmsghdr *nlh,\n \n \tif (nla_len(tb[NDA_DST]) < (int)tbl->key_len) {\n \t\tNL_SET_ERR_MSG(extack, \"Invalid network address\");\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \t}\n \n \tdst = nla_data(tb[NDA_DST]);\n@@ -2024,7 +2024,7 @@ static int neigh_add(struct sk_buff *skb, struct nlmsghdr *nlh,\n \n \t\tif (ndm_flags & NTF_MANAGED) {\n \t\t\tNL_SET_ERR_MSG(extack, \"Invalid NTF_* flag combination\");\n-\t\t\tgoto out;\n+\t\t\tgoto out_neigh_release;\n \t\t}\n \n \t\terr = -ENOBUFS;\n@@ -2035,17 +2035,17 @@ static int neigh_add(struct sk_buff *skb, struct nlmsghdr *nlh,\n \t\t\t\tpn->protocol = protocol;\n \t\t\terr = 0;\n \t\t}\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \t}\n \n \tif (!dev) {\n \t\tNL_SET_ERR_MSG(extack, \"Device not specified\");\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \t}\n \n \tif (tbl->allow_add && !tbl->allow_add(dev, extack)) {\n \t\terr = -EINVAL;\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \t}\n \n \tneigh = neigh_lookup(tbl, dst, dev);\n@@ -2056,12 +2056,12 @@ static int neigh_add(struct sk_buff *skb, struct nlmsghdr *nlh,\n \n \t\tif (!(nlh->nlmsg_flags & NLM_F_CREATE)) {\n \t\t\terr = -ENOENT;\n-\t\t\tgoto out;\n+\t\t\tgoto out_neigh_release;\n \t\t}\n \t\tif (ndm_permanent && (ndm_flags & NTF_MANAGED)) {\n \t\t\tNL_SET_ERR_MSG(extack, \"Invalid NTF_* flag for permanent entry\");\n \t\t\terr = -EINVAL;\n-\t\t\tgoto out;\n+\t\t\tgoto out_neigh_release;\n \t\t}\n \n \t\tneigh = ___neigh_create(tbl, dst, dev,\n@@ -2070,13 +2070,13 @@ static int neigh_add(struct sk_buff *skb, struct nlmsghdr *nlh,\n \t\t\t\t\texempt_from_gc, true);\n \t\tif (IS_ERR(neigh)) {\n \t\t\terr = PTR_ERR(neigh);\n-\t\t\tgoto out;\n+\t\t\tgoto out_neigh_release;\n \t\t}\n \t} else {\n \t\tif (nlh->nlmsg_flags & NLM_F_EXCL) {\n \t\t\terr = -EEXIST;\n \t\t\tneigh_release(neigh);\n-\t\t\tgoto out;\n+\t\t\tgoto out_neigh_release;\n \t\t}\n \n \t\tif (!(nlh->nlmsg_flags & NLM_F_REPLACE))\n@@ -2542,7 +2542,7 @@ static int neightbl_dump_info(struct sk_buff *skb, struct netlink_callback *cb)\n \t\t\t\t\t\t     nlh->nlmsg_seq,\n \t\t\t\t\t\t     RTM_NEWNEIGHTBL,\n \t\t\t\t\t\t     NLM_F_MULTI) < 0)\n-\t\t\t\tgoto out;\n+\t\t\t\tgoto out_neigh_release;\n \t\tnext:\n \t\t\tnidx++;\n \t\t}\n@@ -2731,7 +2731,7 @@ static int neigh_dump_table(struct neigh_table *tbl, struct sk_buff *skb,\n \t\t\t\t\t    RTM_NEWNEIGH,\n \t\t\t\t\t    flags) < 0) {\n \t\t\t\trc = -1;\n-\t\t\t\tgoto out;\n+\t\t\t\tgoto out_neigh_release;\n \t\t\t}\n next:\n \t\t\tidx++;\n@@ -2774,7 +2774,7 @@ static int pneigh_dump_table(struct neigh_table *tbl, struct sk_buff *skb,\n \t\t\t\t\t    RTM_NEWNEIGH, flags, tbl) < 0) {\n \t\t\t\tread_unlock_bh(&tbl->lock);\n \t\t\t\trc = -1;\n-\t\t\t\tgoto out;\n+\t\t\t\tgoto out_neigh_release;\n \t\t\t}\n \t\tnext:\n \t\t\tidx++;\n@@ -3146,7 +3146,7 @@ int neigh_xmit(int index, struct net_device *dev,\n \n \t\ttbl = neigh_tables[index];\n \t\tif (!tbl)\n-\t\t\tgoto out;\n+\t\t\tgoto out_neigh_release;\n \t\trcu_read_lock_bh();\n \t\tif (index == NEIGH_ARP_TABLE) {\n \t\t\tu32 key = *((u32 *)addr);\n@@ -3160,7 +3160,7 @@ int neigh_xmit(int index, struct net_device *dev,\n \t\terr = PTR_ERR(neigh);\n \t\tif (IS_ERR(neigh)) {\n \t\t\trcu_read_unlock_bh();\n-\t\t\tgoto out_kfree_skb;\n+\t\t\tgoto out_neigh_release_kfree_skb;\n \t\t}\n \t\terr = neigh->output(neigh, skb);\n \t\trcu_read_unlock_bh();\n@@ -3169,14 +3169,14 @@ int neigh_xmit(int index, struct net_device *dev,\n \t\terr = dev_hard_header(skb, dev, ntohs(skb->protocol),\n \t\t\t\t      addr, NULL, skb->len);\n \t\tif (err < 0)\n-\t\t\tgoto out_kfree_skb;\n+\t\t\tgoto out_neigh_release_kfree_skb;\n \t\terr = dev_queue_xmit(skb);\n \t}\n out:\n \treturn err;\n out_kfree_skb:\n \tkfree_skb(skb);\n-\tgoto out;\n+\tgoto out_neigh_release;\n }\n EXPORT_SYMBOL(neigh_xmit);\n \n@@ -3386,14 +3386,14 @@ void *neigh_seq_next(struct seq_file *seq, void *v, loff_t *pos)\n \n \tif (v == SEQ_START_TOKEN) {\n \t\trc = neigh_get_first(seq);\n-\t\tgoto out;\n+\t\tgoto out_neigh_release;\n \t}\n \n \tstate = seq->private;\n \tif (!(state->flags & NEIGH_SEQ_IS_PNEIGH)) {\n \t\trc = neigh_get_next(seq, v, NULL);\n \t\tif (rc)\n-\t\t\tgoto out;\n+\t\t\tgoto out_neigh_release;\n \t\tif (!(state->flags & NEIGH_SEQ_NEIGH_ONLY))\n \t\t\trc = pneigh_get_first(seq);\n \t} else {\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "96e0ffd75bd9a59edf367decb7583c8994e48cd6": {
        "non_crash": [
            "diff --git a/fs/ntfs3/super.c b/fs/ntfs3/super.c\nindex 1e2c04e48f98..0fced475955b 100644\n--- a/fs/ntfs3/super.c\n+++ b/fs/ntfs3/super.c\n@@ -787,7 +787,7 @@ static int ntfs_init_from_boot(struct super_block *sb, u32 sector_size,\n \t\tdev_size += sector_size - 1;\n \t}\n \n-\tsbi->cluster_size = boot_sector_size * sct_per_clst;\n+\tsbi->cluster_size = (boot_sector_size != sector_size) ? sector_size * sct_per_clst : boot_sector_size * sct_per_clst;\n \tsbi->cluster_bits = blksize_bits(sbi->cluster_size);\n \n \tsbi->mft.lbo = mlcn << sbi->cluster_bits;\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ntfs3/super.c b/fs/ntfs3/super.c\nindex 1e2c04e48f98..dfd989f3d12e 100644\n--- a/fs/ntfs3/super.c\n+++ b/fs/ntfs3/super.c\n@@ -780,6 +780,7 @@ static int ntfs_init_from_boot(struct super_block *sb, u32 sector_size,\n \t * - Volume formatted 512 and mounted as 4K.\n \t */\n \tif (boot_sector_size != sector_size) {\n+        /* Adjust logic or provide more informative warning here */\n \t\tntfs_warn(\n \t\t\tsb,\n \t\t\t\"Different NTFS' sector size (%u) and media sector size (%u)\",\n",
            "diff --git a/fs/ntfs3/bitmap.c b/fs/ntfs3/bitmap.c\nindex 629c1ee97268..6be396ad1e52 100644\n--- a/fs/ntfs3/bitmap.c\n+++ b/fs/ntfs3/bitmap.c\n@@ -657,6 +657,9 @@ 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+    if (sb->s_blocksize != 512) {\n+        wnd->nwnd = bytes_to_block(sb, bitmap_size(nbits) * (sb->s_blocksize / 512));\n+    }\n \twnd->bits_last = nbits & (wbits - 1);\n \tif (!wnd->bits_last)\n \t\twnd->bits_last = wbits;\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..60d4933c4f8f 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -239,7 +239,8 @@ 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\tif (vb->planes[plane].mem_priv)\n+        call_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}\n",
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex 2fcab61b8ff5..9f9b04edf3d6 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -239,7 +239,9 @@ 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\tif (vb->planes[plane].mem_priv) {\n+        call_void_memop(vb, put, vb->planes[plane].mem_priv);\n+    }\n \t\tvb->planes[plane].mem_priv = NULL;\n \t\tdprintk(3, \"freed plane %d of buffer %d\\n\", plane, vb->index);\n \t}\n",
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex 2fcab61b8ff5..60d4933c4f8f 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -239,7 +239,8 @@ 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\tif (vb->planes[plane].mem_priv)\n+        call_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}\n",
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex 2fcab61b8ff5..60d4933c4f8f 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -239,7 +239,8 @@ 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\tif (vb->planes[plane].mem_priv)\n+        call_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}\n",
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex 2fcab61b8ff5..753b7936ce49 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -239,7 +239,9 @@ 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\tif (vb->planes[plane].mem_priv) {\n+            call_void_memop(vb, put, vb->planes[plane].mem_priv);\n+        }\n \t\tvb->planes[plane].mem_priv = NULL;\n \t\tdprintk(3, \"freed plane %d of buffer %d\\n\", plane, vb->index);\n \t}\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "4d37ad3f55c09b663fe33db0a19fc9684e805a81": {
        "non_crash": [
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 1e7f653c1df7..96b901b52944 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -196,7 +196,11 @@ void nilfs_dat_commit_end(struct inode *dat, struct nilfs_palloc_req *req,\n \t\t\t\t\t     req->pr_entry_bh, kaddr);\n \tend = start = le64_to_cpu(entry->de_start);\n \tif (!dead) {\n-\t\tend = nilfs_mdt_cno(dat);\n+\t\tif (nilfs_mdt_cno(dat) < start) {\n+end = start;\n+} else {\n+end = nilfs_mdt_cno(dat);\n+}\n \t\tWARN_ON(start > end);\n \t}\n \tentry->de_end = cpu_to_le64(end);\n",
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 1e7f653c1df7..54ad73b0b9ee 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -197,7 +197,11 @@ 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+            printk(KERN_WARNING \"nilfs_dat_commit_end: start > end detected\\n\");\n+            start = end;\n+        }\n+        \n \t}\n \tentry->de_end = cpu_to_le64(end);\n \tblocknr = le64_to_cpu(entry->de_blocknr);\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 1e7f653c1df7..cc608bae83cd 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -197,7 +197,9 @@ 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 (WARN_ON(start > end)) {\n+        end = start;\n+    }\n \t}\n \tentry->de_end = cpu_to_le64(end);\n \tblocknr = le64_to_cpu(entry->de_blocknr);\n"
        ],
        "error": []
    },
    "212130bd8af05df1d923b02f9a71db6e8208e40d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/block/loop.c b/drivers/block/loop.c\nindex 204558d7a81d..cbaedff98328 100644\n--- a/drivers/block/loop.c\n+++ b/drivers/block/loop.c\n@@ -1143,7 +1143,9 @@ 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+\tspin_unlock_irq(&lo->lo_lock);\n+destroy_workqueue(lo->workqueue);\n+spin_lock_irq(&lo->lo_lock);\n \tloop_free_idle_workers(lo, true);\n \tdel_timer_sync(&lo->timer);\n \n",
            "diff --git a/block/bdev.c b/block/bdev.c\nindex 7bf88e591aaf..e38908ce5607 100644\n--- a/block/bdev.c\n+++ b/block/bdev.c\n@@ -939,7 +939,9 @@ void blkdev_put(struct block_device *bdev, fmode_t mode)\n \t * event.  This is to ensure detection of media removal commanded\n \t * from userland - e.g. eject(1).\n \t */\n-\tdisk_flush_events(disk, DISK_EVENT_MEDIA_CHANGE);\n+\tmutex_unlock(&disk->open_mutex);\n+    disk_flush_events(disk, DISK_EVENT_MEDIA_CHANGE);\n+    mutex_lock(&disk->open_mutex);\n \n \tif (bdev_is_partition(bdev))\n \t\tblkdev_put_part(bdev, mode);\n",
            "diff --git a/block/bdev.c b/block/bdev.c\nindex 7bf88e591aaf..2af3e2bb6faf 100644\n--- a/block/bdev.c\n+++ b/block/bdev.c\n@@ -903,6 +903,9 @@ void blkdev_put(struct block_device *bdev, fmode_t mode)\n \t\tsync_blockdev(bdev);\n \n \tmutex_lock(&disk->open_mutex);\n+    mutex_unlock(&disk->open_mutex);\n+    disk_flush_events(disk, DISK_EVENT_MEDIA_CHANGE);\n+    mutex_lock(&disk->open_mutex);\n \tif (mode & FMODE_EXCL) {\n \t\tstruct block_device *whole = bdev_whole(bdev);\n \t\tbool bdev_free;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/block/loop.c b/drivers/block/loop.c\nindex 204558d7a81d..2c23d885d498 100644\n--- a/drivers/block/loop.c\n+++ b/drivers/block/loop.c\n@@ -510,7 +510,8 @@ static void loop_reread_partitions(struct loop_device *lo)\n {\n \tint rc;\n \n-\tmutex_lock(&lo->lo_disk->open_mutex);\n+\tif (!release)\n+            mutex_lock(&lo->lo_disk->open_mutex);\n \trc = bdev_disk_changed(lo->lo_disk, false);\n \tmutex_unlock(&lo->lo_disk->open_mutex);\n \tif (rc)\n@@ -1183,7 +1184,8 @@ static void __loop_clr_fd(struct loop_device *lo, bool release)\n \t\t * current holder is released.\n \t\t */\n \t\tif (!release)\n-\t\t\tmutex_lock(&lo->lo_disk->open_mutex);\n+\t\t\tif (!release)\n+            mutex_lock(&lo->lo_disk->open_mutex);\n \t\terr = bdev_disk_changed(lo->lo_disk, false);\n \t\tif (!release)\n \t\t\tmutex_unlock(&lo->lo_disk->open_mutex);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/block/loop.c b/drivers/block/loop.c\nindex 204558d7a81d..e2a3b1b38c4c 100644\n--- a/drivers/block/loop.c\n+++ b/drivers/block/loop.c\n@@ -510,7 +510,10 @@ static void loop_reread_partitions(struct loop_device *lo)\n {\n \tint rc;\n \n-\tmutex_lock(&lo->lo_disk->open_mutex);\n+\tif (!release) {\n+            mutex_unlock(&lo->lo_disk->open_mutex);\n+            mutex_lock(&lo->lo_disk->open_mutex);\n+        }\n \trc = bdev_disk_changed(lo->lo_disk, false);\n \tmutex_unlock(&lo->lo_disk->open_mutex);\n \tif (rc)\n@@ -1183,7 +1186,10 @@ static void __loop_clr_fd(struct loop_device *lo, bool release)\n \t\t * current holder is released.\n \t\t */\n \t\tif (!release)\n-\t\t\tmutex_lock(&lo->lo_disk->open_mutex);\n+\t\t\tif (!release) {\n+            mutex_unlock(&lo->lo_disk->open_mutex);\n+            mutex_lock(&lo->lo_disk->open_mutex);\n+        }\n \t\terr = bdev_disk_changed(lo->lo_disk, false);\n \t\tif (!release)\n \t\t\tmutex_unlock(&lo->lo_disk->open_mutex);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "699e4f546c33df9781a67891d42766bbbe3ca30b": {
        "non_crash": [
            "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..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"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/fuse/dir.c b/fs/fuse/dir.c\nindex 2798fbe8d001..f88660662dfd 100644\n--- a/fs/fuse/dir.c\n+++ b/fs/fuse/dir.c\n@@ -1097,7 +1097,7 @@ int fuse_reverse_inval_entry(struct fuse_conn *fc, u64 parent_nodeid,\n \tfuse_dir_changed(parent);\n \tfuse_invalidate_entry(entry);\n \n-\tif (child_nodeid != 0 && d_really_is_positive(entry)) {\n+\tif (child_nodeid != 0 && d_really_is_positive(entry) && d_inode(entry) != parent) {\n \t\tinode_lock(d_inode(entry));\n \t\tif (get_node_id(d_inode(entry)) != child_nodeid) {\n \t\t\terr = -ENOENT;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/fuse/dir.c b/fs/fuse/dir.c\nindex 2798fbe8d001..ec644b2b3ac4 100644\n--- a/fs/fuse/dir.c\n+++ b/fs/fuse/dir.c\n@@ -1098,7 +1098,8 @@ 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\tlockdep_set_novalidate_class_once(&d_inode(entry)->i_lock);\n+inode_lock(d_inode(entry));\n \t\tif (get_node_id(d_inode(entry)) != child_nodeid) {\n \t\t\terr = -ENOENT;\n \t\t\tgoto badentry;\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..71e5522f5e1b 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -271,6 +271,7 @@ long watch_queue_set_size(struct pipe_inode_info *pipe, unsigned int nr_notes)\n \treturn 0;\n \n error_p:\n+    kfree(bitmap);\n \twhile (--i >= 0)\n \t\t__free_page(pages[i]);\n \tkfree(pages);\n",
            "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 3990e4df3d7b..17c47ed78045 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -271,6 +271,7 @@ long watch_queue_set_size(struct pipe_inode_info *pipe, unsigned int nr_notes)\n \treturn 0;\n \n error_p:\n+kfree(bitmap);\n \twhile (--i >= 0)\n \t\t__free_page(pages[i]);\n \tkfree(pages);\n",
            "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 3990e4df3d7b..a1b58ccbe062 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -271,10 +271,12 @@ long watch_queue_set_size(struct pipe_inode_info *pipe, unsigned int nr_notes)\n \treturn 0;\n \n error_p:\n+kfree(bitmap);\n \twhile (--i >= 0)\n \t\t__free_page(pages[i]);\n \tkfree(pages);\n error:\n+bitmap_free(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..17c47ed78045 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -271,6 +271,7 @@ long watch_queue_set_size(struct pipe_inode_info *pipe, unsigned int nr_notes)\n \treturn 0;\n \n error_p:\n+kfree(bitmap);\n \twhile (--i >= 0)\n \t\t__free_page(pages[i]);\n \tkfree(pages);\n"
        ],
        "error": []
    },
    "d5cd7bc74de1e50a5139d45189395427cc5c3f63": {
        "non_crash": [
            "diff --git a/kernel/bpf/btf.c b/kernel/bpf/btf.c\nindex cad09858a5f2..6cf0d62843fc 100644\n--- a/kernel/bpf/btf.c\n+++ b/kernel/bpf/btf.c\n@@ -1928,6 +1928,10 @@ static int btf_array_resolve(struct btf_verifier_env *env,\n \t/* Check array->index_type */\n \tindex_type_id = array->index_type;\n \tindex_type = btf_type_by_id(btf, index_type_id);\n+    if (!index_type) {\n+        btf_verifier_log_type(env, v->t, \"index_type is NULL\");\n+        return -EINVAL;\n+    }\n \tif (btf_type_is_resolve_source_only(index_type) ||\n \t    btf_type_nosize_or_null(index_type)) {\n \t\tbtf_verifier_log_type(env, v->t, \"Invalid index\");\n",
            "diff --git a/kernel/bpf/btf.c b/kernel/bpf/btf.c\nindex cad09858a5f2..8e7443a6cabe 100644\n--- a/kernel/bpf/btf.c\n+++ b/kernel/bpf/btf.c\n@@ -1928,6 +1928,10 @@ static int btf_array_resolve(struct btf_verifier_env *env,\n \t/* Check array->index_type */\n \tindex_type_id = array->index_type;\n \tindex_type = btf_type_by_id(btf, index_type_id);\n+    if (!index_type) {\n+        btf_verifier_log_type(env, v->t, \"Invalid index type\");\n+        return -EINVAL;\n+    }\n \tif (btf_type_is_resolve_source_only(index_type) ||\n \t    btf_type_nosize_or_null(index_type)) {\n \t\tbtf_verifier_log_type(env, v->t, \"Invalid index\");\n@@ -1948,6 +1952,10 @@ static int btf_array_resolve(struct btf_verifier_env *env,\n \t/* Check array->type */\n \telem_type_id = array->type;\n \telem_type = btf_type_by_id(btf, elem_type_id);\n+    if (!elem_type) {\n+        btf_verifier_log_type(env, v->t, \"Invalid elem type\");\n+        return -EINVAL;\n+    }\n \tif (btf_type_is_resolve_source_only(elem_type) ||\n \t    btf_type_nosize_or_null(elem_type)) {\n \t\tbtf_verifier_log_type(env, v->t,\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/kernel/bpf/btf.c b/kernel/bpf/btf.c\nindex cad09858a5f2..ef761eb652a4 100644\n--- a/kernel/bpf/btf.c\n+++ b/kernel/bpf/btf.c\n@@ -1939,7 +1939,12 @@ static int btf_array_resolve(struct btf_verifier_env *env,\n \t\treturn env_stack_push(env, index_type, index_type_id);\n \n \tindex_type = btf_type_id_size(btf, &index_type_id, NULL);\n-\tif (!index_type || !btf_type_is_int(index_type) ||\n+\tif (!index_type) {\n+        btf_verifier_log_type(env, v->t, \"Index type is NULL\");\n+        return -EINVAL;\n+    }\n+\n+    if (!btf_type_is_int(index_type) ||\n \t    !btf_type_int_is_regular(index_type)) {\n \t\tbtf_verifier_log_type(env, v->t, \"Invalid index\");\n \t\treturn -EINVAL;\n@@ -1961,6 +1966,9 @@ static int btf_array_resolve(struct btf_verifier_env *env,\n \n \telem_type = btf_type_id_size(btf, &elem_type_id, &elem_size);\n \tif (!elem_type) {\n+        btf_verifier_log_type(env, v->t, \"Element type is NULL\");\n+        return -EINVAL;\n+    }\n \t\tbtf_verifier_log_type(env, v->t, \"Invalid elem\");\n \t\treturn -EINVAL;\n \t}\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/kernel/bpf/btf.c b/kernel/bpf/btf.c\nindex cad09858a5f2..f59b5856ffef 100644\n--- a/kernel/bpf/btf.c\n+++ b/kernel/bpf/btf.c\n@@ -1939,7 +1939,11 @@ static int btf_array_resolve(struct btf_verifier_env *env,\n \t\treturn env_stack_push(env, index_type, index_type_id);\n \n \tindex_type = btf_type_id_size(btf, &index_type_id, NULL);\n-\tif (!index_type || !btf_type_is_int(index_type) ||\n+\tif (!index_type) {\n+        btf_verifier_log_type(env, v->t, \"Null index_type\");\n+        return -EINVAL;\n+    }\n+    if (!btf_type_is_int(index_type) ||\n \t    !btf_type_int_is_regular(index_type)) {\n \t\tbtf_verifier_log_type(env, v->t, \"Invalid index\");\n \t\treturn -EINVAL;\n@@ -1961,6 +1965,9 @@ static int btf_array_resolve(struct btf_verifier_env *env,\n \n \telem_type = btf_type_id_size(btf, &elem_type_id, &elem_size);\n \tif (!elem_type) {\n+        btf_verifier_log_type(env, v->t, \"Null elem_type\");\n+        return -EINVAL;\n+    }\n \t\tbtf_verifier_log_type(env, v->t, \"Invalid elem\");\n \t\treturn -EINVAL;\n \t}\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/kernel/bpf/btf.c b/kernel/bpf/btf.c\nindex cad09858a5f2..7e2201dd59e1 100644\n--- a/kernel/bpf/btf.c\n+++ b/kernel/bpf/btf.c\n@@ -1917,6 +1917,81 @@ static s32 btf_array_check_meta(struct btf_verifier_env *env,\n }\n \n static int btf_array_resolve(struct btf_verifier_env *env,\n+                             const struct resolve_vertex *v)\n+{\n+    const struct btf_array *array = btf_type_array(v->t);\n+    if (!array) {\n+        btf_verifier_log_type(env, v->t, \"Invalid array\");\n+        return -EINVAL;\n+    }\n+    const struct btf_type *elem_type, *index_type;\n+    u32 elem_type_id, index_type_id;\n+    struct btf *btf = env->btf;\n+    u32 elem_size;\n+\n+    /* Check array->index_type */\n+    if (!array->index_type) {\n+        btf_verifier_log_type(env, v->t, \"Invalid index\");\n+        return -EINVAL;\n+    }\n+    index_type_id = array->index_type;\n+    index_type = btf_type_by_id(btf, index_type_id);\n+    if (btf_type_is_resolve_source_only(index_type) ||\n+        btf_type_nosize_or_null(index_type)) {\n+        btf_verifier_log_type(env, v->t, \"Invalid index\");\n+        return -EINVAL;\n+    }\n+\n+    if (!env_type_is_resolve_sink(env, index_type) &&\n+        !env_type_is_resolved(env, index_type_id))\n+        return env_stack_push(env, index_type, index_type_id);\n+\n+    index_type = btf_type_id_size(btf, &index_type_id, NULL);\n+    if (!index_type || !btf_type_is_int(index_type) ||\n+        !btf_type_int_is_regular(index_type)) {\n+        btf_verifier_log_type(env, v->t, \"Invalid index\");\n+        return -EINVAL;\n+    }\n+\n+    /* Check array->type */\n+    if (!array->type) {\n+        btf_verifier_log_type(env, v->t, \"Invalid elem\");\n+        return -EINVAL;\n+    }\n+    elem_type_id = array->type;\n+    elem_type = btf_type_by_id(btf, elem_type_id);\n+    if (btf_type_is_resolve_source_only(elem_type) ||\n+        btf_type_nosize_or_null(elem_type)) {\n+        btf_verifier_log_type(env, v->t,\n+                              \"Invalid elem\");\n+        return -EINVAL;\n+    }\n+\n+    if (!env_type_is_resolve_sink(env, elem_type) &&\n+        !env_type_is_resolved(env, elem_type_id))\n+        return env_stack_push(env, elem_type, elem_type_id);\n+\n+    elem_type = btf_type_id_size(btf, &elem_type_id, &elem_size);\n+    if (!elem_type) {\n+        btf_verifier_log_type(env, v->t, \"Invalid elem\");\n+        return -EINVAL;\n+    }\n+\n+    if (btf_type_is_int(elem_type) && !btf_type_int_is_regular(elem_type)) {\n+        btf_verifier_log_type(env, v->t, \"Invalid array of int\");\n+        return -EINVAL;\n+    }\n+\n+    if (array->nelems && elem_size > U32_MAX / array->nelems) {\n+        btf_verifier_log_type(env, v->t,\n+                              \"Array size overflows U32_MAX\");\n+        return -EINVAL;\n+    }\n+\n+    env_stack_pop_resolved(env, elem_type_id, elem_size * array->nelems);\n+\n+    return 0;\n+}\n \t\t\t     const struct resolve_vertex *v)\n {\n \tconst struct btf_array *array = btf_type_array(v->t);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "093e7092e01bed192b564b04528826cc6f1dbf91": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/media/platform/vivid/vivid-vid-cap.c b/drivers/media/platform/vivid/vivid-vid-cap.c\nindex 8213297ee9dc..54c2bb80f5eb 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,12 @@ 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\tif (win->bitmap && dev->bitmap_cap &&\n+            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 && dev->clips_cap) {\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": [
            {
                "patch": "diff --git a/drivers/media/platform/vivid/vivid-vid-cap.c b/drivers/media/platform/vivid/vivid-vid-cap.c\nindex 8213297ee9dc..15ef39b0472c 100644\n--- a/drivers/media/platform/vivid/vivid-vid-cap.c\n+++ b/drivers/media/platform/vivid/vivid-vid-cap.c\n@@ -1079,12 +1079,14 @@ 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\tif (!access_ok(win->bitmap, ((compose->width + 7) / 8) * compose->height) ||\n+        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 (copy_to_user(win->clips, dev->clips_cap,\n+\t\tif (!access_ok(win->clips, clipcount * sizeof(dev->clips_cap[0])) ||\n+        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 \t}\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..ba74f904cf49 100644\n--- a/drivers/media/platform/vivid/vivid-vid-cap.c\n+++ b/drivers/media/platform/vivid/vivid-vid-cap.c\n@@ -1079,12 +1079,12 @@ 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\tif (!access_ok(win->bitmap, ((compose->width + 7) / 8) * compose->height) || 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 (copy_to_user(win->clips, dev->clips_cap,\n+\t\tif (!access_ok(win->clips, clipcount * sizeof(dev->clips_cap[0])) || 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 \t}\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"
            }
        ]
    },
    "507c1be447a4c69f108a0b8cd281fcab44eaf774": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 928446fe1319..0be3240ba4be 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -9456,8 +9456,18 @@ 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+        struct io_rsrc_node *node = list_first_entry(&ctx->rsrc_ref_list, struct io_rsrc_node, node);\n+        list_del(&node->node);\n+        kfree(node);\n+    }\n+    WARN_ON_ONCE(!list_empty(&ctx->rsrc_ref_list));\n+\twhile (!llist_empty(&ctx->rsrc_put_llist)) {\n+        struct llist_node *node = llist_del_first(&ctx->rsrc_put_llist);\n+        struct io_rsrc_node *ref_node = llist_entry(node, struct io_rsrc_node, llist);\n+        kfree(ref_node);\n+    }\n+    WARN_ON_ONCE(!llist_empty(&ctx->rsrc_put_llist));\n \n #if defined(CONFIG_UNIX)\n \tif (ctx->ring_sock) {\n@@ -9465,7 +9475,12 @@ 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+\twhile (!list_empty(&ctx->ltimeout_list)) {\n+        struct io_kiocb *req = list_first_entry(&ctx->ltimeout_list, struct io_kiocb, timeout.list);\n+        list_del(&req->timeout.list);\n+        kfree(req);\n+    }\n+    WARN_ON_ONCE(!list_empty(&ctx->ltimeout_list));\n \n \tio_mem_free(ctx->rings);\n \tio_mem_free(ctx->sq_sqes);\n",
            "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 928446fe1319..e8f16e0dd783 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -9456,7 +9456,10 @@ 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+\tif (!list_empty(&ctx->rsrc_ref_list)) { \n+    io_rsrc_refs_drop(ctx); \n+    WARN_ON_ONCE(!list_empty(&ctx->rsrc_ref_list)); \n+}\n \tWARN_ON_ONCE(!llist_empty(&ctx->rsrc_put_llist));\n \n #if defined(CONFIG_UNIX)\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 928446fe1319..bf434eb6423b 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -9456,7 +9456,12 @@ 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+\twhile (!list_empty(&ctx->rsrc_ref_list)) {\n+        struct io_rsrc_node *node;\n+        node = list_first_entry(&ctx->rsrc_ref_list, struct io_rsrc_node, list);\n+        io_rsrc_node_ref_zero(node);\n+    }\n+    WARN_ON_ONCE(!list_empty(&ctx->rsrc_ref_list));\n \tWARN_ON_ONCE(!llist_empty(&ctx->rsrc_put_llist));\n \n #if defined(CONFIG_UNIX)\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 928446fe1319..4e31b9ae8bc4 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -9620,7 +9620,10 @@ static __cold void io_ring_exit_work(struct work_struct *work)\n \tspin_lock(&ctx->completion_lock);\n \tspin_unlock(&ctx->completion_lock);\n \n-\tio_ring_ctx_free(ctx);\n+\tlist_del(&ctx->rsrc_ref_list);\n+list_del(&ctx->rsrc_put_llist);\n+list_del(&ctx->ltimeout_list);\n+io_ring_ctx_free(ctx);\n }\n \n /* Returns true if we found and killed one or more timeouts */\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "dad6a582c4d54162ae8d096210ca126b659fd8c0": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/hfs/bfind.c b/fs/hfs/bfind.c\nindex ef9498a6e88a..8214c605a294 100644\n--- a/fs/hfs/bfind.c\n+++ b/fs/hfs/bfind.c\n@@ -27,7 +27,7 @@ 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",
            "diff --git a/fs/hfs/bfind.c b/fs/hfs/bfind.c\nindex ef9498a6e88a..3e54a9ca9333 100644\n--- a/fs/hfs/bfind.c\n+++ b/fs/hfs/bfind.c\n@@ -38,7 +38,8 @@ int hfs_find_init(struct hfs_btree *tree, struct hfs_find_data *fd)\n \tdefault:\n \t\treturn -EINVAL;\n \t}\n-\treturn 0;\n+\tmutex_unlock(&tree->tree_lock);\n+    return 0;\n }\n \n void hfs_find_exit(struct hfs_find_data *fd)\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/fs-writeback.c b/fs/fs-writeback.c\nindex 443f83382b9b..115cfaede1b1 100644\n--- a/fs/fs-writeback.c\n+++ b/fs/fs-writeback.c\n@@ -313,7 +313,8 @@ locked_inode_to_wb_and_lock_list(struct inode *inode)\n \t\t */\n \t\twb_get(wb);\n \t\tspin_unlock(&inode->i_lock);\n-\t\tspin_lock(&wb->list_lock);\n+\t\tspin_unlock(&inode->i_lock);\n+    spin_lock(&wb->list_lock);\n \n \t\t/* i_wb may have changed inbetween, can't use inode_to_wb() */\n \t\tif (likely(wb == inode->i_wb)) {\n@@ -644,7 +645,8 @@ bool cleanup_offline_cgwb(struct bdi_writeback *wb)\n \t\tisw->new_wb = &wb->bdi->wb; /* wb_get() is noop for bdi's wb */\n \n \tnr = 0;\n-\tspin_lock(&wb->list_lock);\n+\tspin_unlock(&inode->i_lock);\n+    spin_lock(&wb->list_lock);\n \tlist_for_each_entry(inode, &wb->b_attached, i_io_list) {\n \t\tif (!inode_prepare_wbs_switch(inode, isw->new_wb))\n \t\t\tcontinue;\n@@ -1143,7 +1145,8 @@ locked_inode_to_wb_and_lock_list(struct inode *inode)\n \tstruct bdi_writeback *wb = inode_to_wb(inode);\n \n \tspin_unlock(&inode->i_lock);\n-\tspin_lock(&wb->list_lock);\n+\tspin_unlock(&inode->i_lock);\n+    spin_lock(&wb->list_lock);\n \treturn wb;\n }\n \n@@ -1152,7 +1155,8 @@ static struct bdi_writeback *inode_to_wb_and_lock_list(struct inode *inode)\n {\n \tstruct bdi_writeback *wb = inode_to_wb(inode);\n \n-\tspin_lock(&wb->list_lock);\n+\tspin_unlock(&inode->i_lock);\n+    spin_lock(&wb->list_lock);\n \treturn wb;\n }\n \n@@ -1853,7 +1857,8 @@ static long writeback_sb_inodes(struct super_block *sb,\n \t\t\t/* Wait for I_SYNC. This function drops i_lock... */\n \t\t\tinode_sleep_on_writeback(inode);\n \t\t\t/* Inode may be gone, start again */\n-\t\t\tspin_lock(&wb->list_lock);\n+\t\t\tspin_unlock(&inode->i_lock);\n+    spin_lock(&wb->list_lock);\n \t\t\tcontinue;\n \t\t}\n \t\tinode->i_state |= I_SYNC;\n@@ -1902,7 +1907,8 @@ static long writeback_sb_inodes(struct super_block *sb,\n \n \t\tif (unlikely(tmp_wb != wb)) {\n \t\t\tspin_unlock(&tmp_wb->list_lock);\n-\t\t\tspin_lock(&wb->list_lock);\n+\t\t\tspin_unlock(&inode->i_lock);\n+    spin_lock(&wb->list_lock);\n \t\t}\n \n \t\t/*\n@@ -1965,7 +1971,8 @@ static long writeback_inodes_wb(struct bdi_writeback *wb, long nr_pages,\n \tstruct blk_plug plug;\n \n \tblk_start_plug(&plug);\n-\tspin_lock(&wb->list_lock);\n+\tspin_unlock(&inode->i_lock);\n+    spin_lock(&wb->list_lock);\n \tif (list_empty(&wb->b_io))\n \t\tqueue_io(wb, &work, jiffies);\n \t__writeback_inodes_wb(wb, &work);\n@@ -2000,7 +2007,8 @@ static long wb_writeback(struct bdi_writeback *wb,\n \tstruct blk_plug plug;\n \n \tblk_start_plug(&plug);\n-\tspin_lock(&wb->list_lock);\n+\tspin_unlock(&inode->i_lock);\n+    spin_lock(&wb->list_lock);\n \tfor (;;) {\n \t\t/*\n \t\t * Stop writeback when nr_pages has been consumed\n@@ -2072,7 +2080,8 @@ static long wb_writeback(struct bdi_writeback *wb,\n \t\tspin_unlock(&wb->list_lock);\n \t\t/* This function drops i_lock... */\n \t\tinode_sleep_on_writeback(inode);\n-\t\tspin_lock(&wb->list_lock);\n+\t\tspin_unlock(&inode->i_lock);\n+    spin_lock(&wb->list_lock);\n \t}\n \tspin_unlock(&wb->list_lock);\n \tblk_finish_plug(&plug);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "deb061ff946b02c2f4821f91683d89a68b2f45f8": {
        "non_crash": [
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..c5017da2fb58 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -585,7 +585,10 @@ int hfsplus_cat_write_inode(struct inode *inode)\n \t\t/* panic? */\n \t\tgoto out;\n \n-\tif (S_ISDIR(main_inode->i_mode)) {\n+\tif (fd.entrylength < sizeof(struct hfsplus_cat_file))\n+        fd.entrylength = sizeof(struct hfsplus_cat_file);\n+\n+    if (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",
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..733d19b266bc 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -613,7 +613,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+pr_err(\"Entry length is too small for hfsplus_cat_file\\n\");\n+goto out;\n+}\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": [],
        "error": []
    },
    "e2907149c69cbccae0842eb502b8af4f6fac52a0": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/xfs/libxfs/xfs_btree.c b/fs/xfs/libxfs/xfs_btree.c\nindex c4649cc624e1..3079c0d05ad3 100644\n--- a/fs/xfs/libxfs/xfs_btree.c\n+++ b/fs/xfs/libxfs/xfs_btree.c\n@@ -1810,7 +1810,9 @@ 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+\tif (level < 0 || level >= cur->bc_nlevels) return -EINVAL;\n+\n+    bp = cur->bc_levels[level].bp;\n \terror = xfs_btree_ptr_to_daddr(cur, pp, &daddr);\n \tif (error)\n \t\treturn error;\n",
            "diff --git a/fs/xfs/libxfs/xfs_btree.c b/fs/xfs/libxfs/xfs_btree.c\nindex c4649cc624e1..a4101a217abd 100644\n--- a/fs/xfs/libxfs/xfs_btree.c\n+++ b/fs/xfs/libxfs/xfs_btree.c\n@@ -1810,7 +1810,8 @@ 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+\tif (level >= cur->bc_nlevels) return -EFSCORRUPTED;\n+    bp = cur->bc_levels[level].bp;\n \terror = xfs_btree_ptr_to_daddr(cur, pp, &daddr);\n \tif (error)\n \t\treturn error;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/xfs/libxfs/xfs_btree.c b/fs/xfs/libxfs/xfs_btree.c\nindex c4649cc624e1..23dc4960af14 100644\n--- a/fs/xfs/libxfs/xfs_btree.c\n+++ b/fs/xfs/libxfs/xfs_btree.c\n@@ -1811,7 +1811,10 @@ xfs_btree_lookup_get_block(\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+\terror = if (!xfs_btree_check_ptr(cur, pp, level)) {\n+        return -EFSCORRUPTED;\n+    }\n+    xfs_btree_ptr_to_daddr(cur, pp, &daddr);\n \tif (error)\n \t\treturn error;\n \tif (bp && xfs_buf_daddr(bp) == daddr) {\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/xfs/libxfs/xfs_btree.c b/fs/xfs/libxfs/xfs_btree.c\nindex c4649cc624e1..ea2057065ab2 100644\n--- a/fs/xfs/libxfs/xfs_btree.c\n+++ b/fs/xfs/libxfs/xfs_btree.c\n@@ -1788,6 +1788,7 @@ xfs_btree_decrement(\n \n int\n xfs_btree_lookup_get_block(\n+    if (level < 0 || level >= cur->bc_nlevels) return -EINVAL;\n \tstruct xfs_btree_cur\t\t*cur,\t/* btree cursor */\n \tint\t\t\t\tlevel,\t/* level in the btree */\n \tconst union xfs_btree_ptr\t*pp,\t/* ptr to btree block */\n@@ -1910,7 +1911,8 @@ xfs_btree_lookup(\n \t */\n \tfor (level = cur->bc_nlevels - 1, diff = 1; level >= 0; level--) {\n \t\t/* Get the block we need to do the lookup on. */\n-\t\terror = xfs_btree_lookup_get_block(cur, level, pp, &block);\n+\t\terror = xfs_btree_lookup_get_block(\n+    if (level < 0 || level >= cur->bc_nlevels) return -EINVAL;cur, level, pp, &block);\n \t\tif (error)\n \t\t\tgoto error0;\n \n@@ -4364,7 +4366,8 @@ xfs_btree_visit_block(\n \n \t/*\n \t * We only visit blocks once in this walk, so we have to avoid the\n-\t * internal xfs_btree_lookup_get_block() optimisation where it will\n+\t * internal xfs_btree_lookup_get_block(\n+    if (level < 0 || level >= cur->bc_nlevels) return -EINVAL;) optimisation where it will\n \t * return the same block without checking if the right sibling points\n \t * back to us and creates a cyclic reference in the btree.\n \t */\n@@ -4377,7 +4380,8 @@ xfs_btree_visit_block(\n \t\t\t\t\t\t\txfs_buf_daddr(bp)))\n \t\t\treturn -EFSCORRUPTED;\n \t}\n-\treturn xfs_btree_lookup_get_block(cur, level, &rptr, &block);\n+\treturn xfs_btree_lookup_get_block(\n+    if (level < 0 || level >= cur->bc_nlevels) return -EINVAL;cur, level, &rptr, &block);\n }\n \n \n@@ -4399,7 +4403,8 @@ xfs_btree_visit_blocks(\n \t/* for each level */\n \tfor (level = cur->bc_nlevels - 1; level >= 0; level--) {\n \t\t/* grab the left hand block */\n-\t\terror = xfs_btree_lookup_get_block(cur, level, &lptr, &block);\n+\t\terror = xfs_btree_lookup_get_block(\n+    if (level < 0 || level >= cur->bc_nlevels) return -EINVAL;cur, level, &lptr, &block);\n \t\tif (error)\n \t\t\treturn error;\n \n@@ -4823,7 +4828,8 @@ xfs_btree_overlapped_query_range(\n \t/* Load the root of the btree. */\n \tlevel = cur->bc_nlevels - 1;\n \tcur->bc_ops->init_ptr_from_cur(cur, &ptr);\n-\terror = xfs_btree_lookup_get_block(cur, level, &ptr, &block);\n+\terror = xfs_btree_lookup_get_block(\n+    if (level < 0 || level >= cur->bc_nlevels) return -EINVAL;cur, level, &ptr, &block);\n \tif (error)\n \t\treturn error;\n \txfs_btree_get_block(cur, level, &bp);\n@@ -4894,7 +4900,8 @@ xfs_btree_overlapped_query_range(\n \t\t */\n \t\tif (ldiff >= 0 && hdiff >= 0) {\n \t\t\tlevel--;\n-\t\t\terror = xfs_btree_lookup_get_block(cur, level, pp,\n+\t\t\terror = xfs_btree_lookup_get_block(\n+    if (level < 0 || level >= cur->bc_nlevels) return -EINVAL;cur, level, pp,\n \t\t\t\t\t&block);\n \t\t\tif (error)\n \t\t\t\tgoto out;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "e1306831b0c04a2ee7705d93be9747c870cadfd5": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex a0a36bfa3aa0..90f869c87b6f 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+cond_resched();\n \t\t} else {\n \t\t\t/*\n \t\t\t * This prevents priority inversion, if the task\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/namespace.c b/fs/namespace.c\nindex a0a36bfa3aa0..9124b68ad8c9 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -346,6 +346,10 @@ int __mnt_want_write(struct vfsmount *m)\n \tsmp_mb();\n \tmight_lock(&mount_lock.lock);\n \twhile (READ_ONCE(mnt->mnt.mnt_flags) & MNT_WRITE_HOLD) {\n+if (time_after(jiffies, start_jiffies + MAX_WAIT_JIFFIES)) {\n+ret = -EAGAIN;\n+break;\n+}\n \t\tif (!IS_ENABLED(CONFIG_PREEMPT_RT)) {\n \t\t\tcpu_relax();\n \t\t} else {\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..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..60f29d871f07 100644\n--- a/net/xdp/xdp_umem.c\n+++ b/net/xdp/xdp_umem.c\n@@ -99,7 +99,8 @@ 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) return -EINVAL;\n+umem->pgs = kvcalloc(umem->npgs, sizeof(*umem->pgs), GFP_KERNEL | __GFP_NOWARN);\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": [
            {
                "patch": "diff --git a/net/xdp/xdp_umem.c b/net/xdp/xdp_umem.c\nindex f01ef6bda390..2af9056cca04 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 > MAX_ALLOWED_PAGES) {\n+        pr_warn(\"Requested pages exceed maximum allowed limit\\n\");\n+        return -ENOMEM;\n+    }\n+umem->pgs = kvcalloc(umem->npgs, sizeof(*umem->pgs), GFP_KERNEL | __GFP_NOWARN);\n \tif (!umem->pgs)\n \t\treturn -ENOMEM;\n \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..4ed42213a528 100644\n--- a/net/bluetooth/hci_conn.c\n+++ b/net/bluetooth/hci_conn.c\n@@ -2480,6 +2480,7 @@ 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+/* Ensure no further operations on 'c' after deletion */\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..6d88c6aaa7c4 100644\n--- a/net/bluetooth/hci_conn.c\n+++ b/net/bluetooth/hci_conn.c\n@@ -2481,6 +2481,7 @@ 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+c = NULL;\n \t}\n }\n \n",
            "diff --git a/net/bluetooth/hci_conn.c b/net/bluetooth/hci_conn.c\nindex 44d0643fc681..143d8e9d562a 100644\n--- a/net/bluetooth/hci_conn.c\n+++ b/net/bluetooth/hci_conn.c\n@@ -2471,6 +2471,8 @@ void hci_conn_hash_flush(struct hci_dev *hdev)\n \tBT_DBG(\"hdev %s\", hdev->name);\n \n \tlist_for_each_entry_safe(c, n, &h->list, list) {\n+        if (!c)\n+            continue;\n \t\tc->state = BT_CLOSED;\n \n \t\thci_disconn_cfm(c, HCI_ERROR_LOCAL_HOST_TERM);\n",
            "diff --git a/net/bluetooth/hci_conn.c b/net/bluetooth/hci_conn.c\nindex 44d0643fc681..fd0160c0d958 100644\n--- a/net/bluetooth/hci_conn.c\n+++ b/net/bluetooth/hci_conn.c\n@@ -2481,6 +2481,7 @@ 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+        /* Ensure no further access to 'c' after deletion to avoid use-after-free */\n \t}\n }\n \n",
            "diff --git a/net/bluetooth/hci_conn.c b/net/bluetooth/hci_conn.c\nindex 44d0643fc681..e716ef1621f1 100644\n--- a/net/bluetooth/hci_conn.c\n+++ b/net/bluetooth/hci_conn.c\n@@ -200,6 +200,7 @@ static void le_scan_cleanup(struct work_struct *work)\n \tif (c == conn) {\n \t\thci_connect_le_scan_cleanup(conn, 0x00);\n \t\thci_conn_cleanup(conn);\n+        conn = NULL;\n \t}\n \n \thci_dev_unlock(hdev);\n@@ -1163,6 +1164,7 @@ int hci_conn_del(struct hci_conn *conn)\n \t * rest of hci_conn_del.\n \t */\n \thci_conn_cleanup(conn);\n+        conn = NULL;\n \n \treturn 0;\n }\n"
        ],
        "error": []
    },
    "14f3125f37b7c76896b25c222159f6c205ff7e08": {
        "non_crash": [
            "diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c\nindex 7da343efd090..28322b5dbaed 100644\n--- a/net/mac80211/cfg.c\n+++ b/net/mac80211/cfg.c\n@@ -372,7 +372,8 @@ static int ieee80211_set_tx(struct ieee80211_sub_if_data *sdata,\n \t\treturn 0;\n \n \tmutex_lock(&local->key_mtx);\n-\tkey = key_mtx_dereference(local, sta->ptk[key_idx]);\n+\tif (key_idx < NUM_DEFAULT_KEYS)\n+            key = key_mtx_dereference(local, sta->ptk[key_idx]);\n \n \tif (key && key->conf.flags & IEEE80211_KEY_FLAG_NO_AUTO_TX)\n \t\tret = ieee80211_set_tx_key(key);\n@@ -518,7 +519,8 @@ static int ieee80211_del_key(struct wiphy *wiphy, struct net_device *dev,\n \t\t\tgoto out_unlock;\n \n \t\tif (pairwise)\n-\t\t\tkey = key_mtx_dereference(local, sta->ptk[key_idx]);\n+\t\t\tif (key_idx < NUM_DEFAULT_KEYS)\n+            key = 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"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c\nindex 7da343efd090..7a804ae8df93 100644\n--- a/net/mac80211/cfg.c\n+++ b/net/mac80211/cfg.c\n@@ -507,6 +507,12 @@ static int ieee80211_del_key(struct wiphy *wiphy, struct net_device *dev,\n \tstruct ieee80211_key *key = NULL;\n \tint ret;\n \n+    /* Ensure key_idx is within bounds */\n+    if (key_idx >= NUM_DEFAULT_KEYS) {\n+        ret = -EINVAL;\n+        goto out_unlock;\n+    }\n+\n \tmutex_lock(&local->sta_mtx);\n \tmutex_lock(&local->key_mtx);\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c\nindex 7da343efd090..e4eeccaa4c9d 100644\n--- a/net/mac80211/cfg.c\n+++ b/net/mac80211/cfg.c\n@@ -435,6 +435,10 @@ static int ieee80211_add_key(struct wiphy *wiphy, struct net_device *dev,\n \tmutex_lock(&local->sta_mtx);\n \n \tif (mac_addr) {\n+    if (key_idx >= NUM_DEFAULT_KEYS) {\n+        ret = -EINVAL;\n+        goto out_unlock;\n+    }\n \t\tsta = sta_info_get_bss(sdata, mac_addr);\n \t\t/*\n \t\t * The ASSOC test makes sure the driver is ready to\n@@ -511,6 +515,10 @@ static int ieee80211_del_key(struct wiphy *wiphy, struct net_device *dev,\n \tmutex_lock(&local->key_mtx);\n \n \tif (mac_addr) {\n+    if (key_idx >= NUM_DEFAULT_KEYS) {\n+        ret = -EINVAL;\n+        goto out_unlock;\n+    }\n \t\tret = -ENOENT;\n \n \t\tsta = sta_info_get_bss(sdata, mac_addr);\n@@ -561,6 +569,10 @@ static int ieee80211_get_key(struct wiphy *wiphy, struct net_device *dev,\n \trcu_read_lock();\n \n \tif (mac_addr) {\n+    if (key_idx >= NUM_DEFAULT_KEYS) {\n+        ret = -EINVAL;\n+        goto out_unlock;\n+    }\n \t\tsta = sta_info_get_bss(sdata, mac_addr);\n \t\tif (!sta)\n \t\t\tgoto out;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c\nindex 7da343efd090..729a13ed1517 100644\n--- a/net/mac80211/cfg.c\n+++ b/net/mac80211/cfg.c\n@@ -434,7 +434,12 @@ static int ieee80211_add_key(struct wiphy *wiphy, struct net_device *dev,\n \n \tmutex_lock(&local->sta_mtx);\n \n-\tif (mac_addr) {\n+\tif (key_idx >= NUM_DEFAULT_KEYS) {\n+ret = -EINVAL;\n+goto out_unlock;\n+}\n+\n+if (mac_addr) {\n \t\tsta = sta_info_get_bss(sdata, mac_addr);\n \t\t/*\n \t\t * The ASSOC test makes sure the driver is ready to\n@@ -510,7 +515,12 @@ 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 (mac_addr) {\n+\tif (key_idx >= NUM_DEFAULT_KEYS) {\n+ret = -EINVAL;\n+goto out_unlock;\n+}\n+\n+if (mac_addr) {\n \t\tret = -ENOENT;\n \n \t\tsta = sta_info_get_bss(sdata, mac_addr);\n@@ -560,7 +570,12 @@ static int ieee80211_get_key(struct wiphy *wiphy, struct net_device *dev,\n \n \trcu_read_lock();\n \n-\tif (mac_addr) {\n+\tif (key_idx >= NUM_DEFAULT_KEYS) {\n+ret = -EINVAL;\n+goto out_unlock;\n+}\n+\n+if (mac_addr) {\n \t\tsta = sta_info_get_bss(sdata, mac_addr);\n \t\tif (!sta)\n \t\t\tgoto out;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c\nindex 7da343efd090..c1eac06be267 100644\n--- a/net/mac80211/cfg.c\n+++ b/net/mac80211/cfg.c\n@@ -98,7 +98,7 @@ static int ieee80211_set_mon_options(struct ieee80211_sub_if_data *sdata,\n \t\t\tieee80211_adjust_monitor_flags(sdata, 1);\n \n \t\t\tieee80211_configure_filter(local);\n-\t\t} else {\n+\t\t} else if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS) {\n \t\t\t/*\n \t\t\t * Because the interface is down, ieee80211_do_stop\n \t\t\t * and ieee80211_do_open take care of \"everything\"\n@@ -161,7 +161,7 @@ static int ieee80211_change_iface(struct wiphy *wiphy,\n \tif (type == NL80211_IFTYPE_AP_VLAN && params->use_4addr == 0) {\n \t\tRCU_INIT_POINTER(sdata->u.vlan.sta, NULL);\n \t\tieee80211_check_fast_rx_iface(sdata);\n-\t} else if (type == NL80211_IFTYPE_STATION && params->use_4addr >= 0) {\n+\t} else if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS) if (type == NL80211_IFTYPE_STATION && params->use_4addr >= 0) {\n \t\tsdata->u.mgd.use_4addr = params->use_4addr;\n \t}\n \n@@ -426,7 +426,7 @@ static int ieee80211_add_key(struct wiphy *wiphy, struct net_device *dev,\n \tif (IS_ERR(key))\n \t\treturn PTR_ERR(key);\n \n-\tif (pairwise)\n+\tif (pairwise && key_idx < NUM_DEFAULT_KEYS)\n \t\tkey->conf.flags |= IEEE80211_KEY_FLAG_PAIRWISE;\n \n \tif (params->mode == NL80211_KEY_NO_TX)\n@@ -517,11 +517,11 @@ 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 (pairwise)\n+\t\tif (pairwise && key_idx < NUM_DEFAULT_KEYS)\n \t\t\tkey = key_mtx_dereference(local, sta->ptk[key_idx]);\n-\t\telse\n+\t\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\t\tkey = key_mtx_dereference(local, sta->gtk[key_idx]);\n-\t} else\n+\t} else if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\tkey = key_mtx_dereference(local, sdata->keys[key_idx]);\n \n \tif (!key) {\n@@ -567,11 +567,11 @@ static int ieee80211_get_key(struct wiphy *wiphy, struct net_device *dev,\n \n \t\tif (pairwise && key_idx < NUM_DEFAULT_KEYS)\n \t\t\tkey = rcu_dereference(sta->ptk[key_idx]);\n-\t\telse if (!pairwise &&\n+\t\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS) if (!pairwise &&\n \t\t\t key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS +\n \t\t\t NUM_DEFAULT_BEACON_KEYS)\n \t\t\tkey = rcu_dereference(sta->gtk[key_idx]);\n-\t} else\n+\t} else if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\tkey = rcu_dereference(sdata->keys[key_idx]);\n \n \tif (!key)\n@@ -624,7 +624,7 @@ static int ieee80211_get_key(struct wiphy *wiphy, struct net_device *dev,\n \t\t    !(key->conf.flags & IEEE80211_KEY_FLAG_GENERATE_IV)) {\n \t\t\tdrv_get_key_seq(sdata->local, key, &kseq);\n \t\t\tmemcpy(seq, kseq.ccmp.pn, 6);\n-\t\t} else {\n+\t\t} else if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS) {\n \t\t\tpn64 = atomic64_read(&key->conf.tx_pn);\n \t\t\tseq[0] = pn64;\n \t\t\tseq[1] = pn64 >> 8;\n@@ -700,11 +700,11 @@ void sta_set_rate_info_tx(struct sta_info *sta,\n \tif (rate->flags & IEEE80211_TX_RC_MCS) {\n \t\trinfo->flags |= RATE_INFO_FLAGS_MCS;\n \t\trinfo->mcs = rate->idx;\n-\t} else if (rate->flags & IEEE80211_TX_RC_VHT_MCS) {\n+\t} else if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS) if (rate->flags & IEEE80211_TX_RC_VHT_MCS) {\n \t\trinfo->flags |= RATE_INFO_FLAGS_VHT_MCS;\n \t\trinfo->mcs = ieee80211_rate_get_vht_mcs(rate);\n \t\trinfo->nss = ieee80211_rate_get_vht_nss(rate);\n-\t} else {\n+\t} else if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS) {\n \t\tstruct ieee80211_supported_band *sband;\n \t\tint shift = ieee80211_vif_get_shift(&sta->sdata->vif);\n \t\tu16 brate;\n@@ -718,11 +718,11 @@ void sta_set_rate_info_tx(struct sta_info *sta,\n \t}\n \tif (rate->flags & IEEE80211_TX_RC_40_MHZ_WIDTH)\n \t\trinfo->bw = RATE_INFO_BW_40;\n-\telse if (rate->flags & IEEE80211_TX_RC_80_MHZ_WIDTH)\n+\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS) if (rate->flags & IEEE80211_TX_RC_80_MHZ_WIDTH)\n \t\trinfo->bw = RATE_INFO_BW_80;\n-\telse if (rate->flags & IEEE80211_TX_RC_160_MHZ_WIDTH)\n+\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS) if (rate->flags & IEEE80211_TX_RC_160_MHZ_WIDTH)\n \t\trinfo->bw = RATE_INFO_BW_160;\n-\telse\n+\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\trinfo->bw = RATE_INFO_BW_20;\n \tif (rate->flags & IEEE80211_TX_RC_SHORT_GI)\n \t\trinfo->flags |= RATE_INFO_FLAGS_SHORT_GI;\n@@ -797,7 +797,7 @@ static int ieee80211_set_monitor_channel(struct wiphy *wiphy,\n \t\t\tret = ieee80211_vif_use_channel(sdata, chandef,\n \t\t\t\t\tIEEE80211_CHANCTX_EXCLUSIVE);\n \t\t}\n-\t} else if (local->open_count == local->monitors) {\n+\t} else if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS) if (local->open_count == local->monitors) {\n \t\tlocal->_oper_chandef = *chandef;\n \t\tieee80211_hw_config(local, 0);\n \t}\n@@ -953,14 +953,14 @@ static int ieee80211_assign_beacon(struct ieee80211_sub_if_data *sdata,\n \t/* new or old head? */\n \tif (params->head)\n \t\tnew_head_len = params->head_len;\n-\telse\n+\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\tnew_head_len = old->head_len;\n \n \t/* new or old tail? */\n \tif (params->tail || !old)\n \t\t/* params->tail_len will be zero for !params->tail */\n \t\tnew_tail_len = params->tail_len;\n-\telse\n+\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\tnew_tail_len = old->tail_len;\n \n \tsize = sizeof(*new) + new_head_len + new_tail_len;\n@@ -990,13 +990,13 @@ static int ieee80211_assign_beacon(struct ieee80211_sub_if_data *sdata,\n \t/* copy in head */\n \tif (params->head)\n \t\tmemcpy(new->head, params->head, new_head_len);\n-\telse\n+\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\tmemcpy(new->head, old->head, new_head_len);\n \n \t/* copy in optional tail */\n \tif (params->tail)\n \t\tmemcpy(new->tail, params->tail, new_tail_len);\n-\telse\n+\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\tif (old)\n \t\t\tmemcpy(new->tail, old->tail, new_tail_len);\n \n@@ -1352,9 +1352,9 @@ static int sta_apply_auth_flags(struct ieee80211_local *local,\n \tif (mask & BIT(NL80211_STA_FLAG_AUTHORIZED)) {\n \t\tif (set & BIT(NL80211_STA_FLAG_AUTHORIZED))\n \t\t\tret = sta_info_move_state(sta, IEEE80211_STA_AUTHORIZED);\n-\t\telse if (test_sta_flag(sta, WLAN_STA_AUTHORIZED))\n+\t\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS) if (test_sta_flag(sta, WLAN_STA_AUTHORIZED))\n \t\t\tret = sta_info_move_state(sta, IEEE80211_STA_ASSOC);\n-\t\telse\n+\t\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\t\tret = 0;\n \t\tif (ret)\n \t\t\treturn ret;\n@@ -1469,7 +1469,7 @@ static int sta_apply_parameters(struct ieee80211_local *local,\n \t\t\tmask |= BIT(NL80211_STA_FLAG_ASSOCIATED);\n \t\tif (set & BIT(NL80211_STA_FLAG_AUTHENTICATED))\n \t\t\tset |= BIT(NL80211_STA_FLAG_ASSOCIATED);\n-\t} else if (test_sta_flag(sta, WLAN_STA_TDLS_PEER)) {\n+\t} else if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS) if (test_sta_flag(sta, WLAN_STA_TDLS_PEER)) {\n \t\t/*\n \t\t * TDLS -- everything follows authorized, but\n \t\t * only becoming authorized is possible, not\n@@ -1500,7 +1500,7 @@ static int sta_apply_parameters(struct ieee80211_local *local,\n \tif (mask & BIT(NL80211_STA_FLAG_SHORT_PREAMBLE)) {\n \t\tif (set & BIT(NL80211_STA_FLAG_SHORT_PREAMBLE))\n \t\t\tset_sta_flag(sta, WLAN_STA_SHORT_PREAMBLE);\n-\t\telse\n+\t\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\t\tclear_sta_flag(sta, WLAN_STA_SHORT_PREAMBLE);\n \t}\n \n@@ -1508,14 +1508,14 @@ static int sta_apply_parameters(struct ieee80211_local *local,\n \t\tsta->sta.mfp = !!(set & BIT(NL80211_STA_FLAG_MFP));\n \t\tif (set & BIT(NL80211_STA_FLAG_MFP))\n \t\t\tset_sta_flag(sta, WLAN_STA_MFP);\n-\t\telse\n+\t\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\t\tclear_sta_flag(sta, WLAN_STA_MFP);\n \t}\n \n \tif (mask & BIT(NL80211_STA_FLAG_TDLS_PEER)) {\n \t\tif (set & BIT(NL80211_STA_FLAG_TDLS_PEER))\n \t\t\tset_sta_flag(sta, WLAN_STA_TDLS_PEER);\n-\t\telse\n+\t\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\t\tclear_sta_flag(sta, WLAN_STA_TDLS_PEER);\n \t}\n \n@@ -1659,7 +1659,7 @@ static int ieee80211_add_station(struct wiphy *wiphy, struct net_device *dev,\n \t\tif (sdata->vif.type != NL80211_IFTYPE_AP_VLAN &&\n \t\t    sdata->vif.type != NL80211_IFTYPE_AP)\n \t\t\treturn -EINVAL;\n-\t} else\n+\t} else if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\tsdata = IEEE80211_DEV_TO_SUB_IF(dev);\n \n \tif (ether_addr_equal(mac, sdata->vif.addr))\n@@ -1743,7 +1743,7 @@ static int ieee80211_change_station(struct wiphy *wiphy,\n \tcase NL80211_IFTYPE_MESH_POINT:\n \t\tif (sdata->u.mesh.user_mpm)\n \t\t\tstatype = CFG80211_STA_MESH_PEER_USER;\n-\t\telse\n+\t\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\t\tstatype = CFG80211_STA_MESH_PEER_KERNEL;\n \t\tbreak;\n \tcase NL80211_IFTYPE_ADHOC:\n@@ -1756,14 +1756,14 @@ static int ieee80211_change_station(struct wiphy *wiphy,\n \t\t}\n \t\tif (test_sta_flag(sta, WLAN_STA_AUTHORIZED))\n \t\t\tstatype = CFG80211_STA_TDLS_PEER_ACTIVE;\n-\t\telse\n+\t\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\t\tstatype = CFG80211_STA_TDLS_PEER_SETUP;\n \t\tbreak;\n \tcase NL80211_IFTYPE_AP:\n \tcase NL80211_IFTYPE_AP_VLAN:\n \t\tif (test_sta_flag(sta, WLAN_STA_ASSOC))\n \t\t\tstatype = CFG80211_STA_AP_CLIENT;\n-\t\telse\n+\t\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\t\tstatype = CFG80211_STA_AP_CLIENT_UNASSOC;\n \t\tbreak;\n \tdefault:\n@@ -1901,7 +1901,7 @@ static void mpath_set_pinfo(struct mesh_path *mpath, u8 *next_hop,\n \n \tif (next_hop_sta)\n \t\tmemcpy(next_hop, next_hop_sta->sta.addr, ETH_ALEN);\n-\telse\n+\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\teth_zero_addr(next_hop);\n \n \tmemset(pinfo, 0, sizeof(*pinfo));\n@@ -2322,7 +2322,7 @@ static int ieee80211_change_bss(struct wiphy *wiphy,\n \tif (params->ap_isolate >= 0) {\n \t\tif (params->ap_isolate)\n \t\t\tsdata->flags |= IEEE80211_SDATA_DONT_BRIDGE_PACKETS;\n-\t\telse\n+\t\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\t\tsdata->flags &= ~IEEE80211_SDATA_DONT_BRIDGE_PACKETS;\n \t\tieee80211_check_fast_rx_iface(sdata);\n \t}\n@@ -2345,7 +2345,7 @@ static int ieee80211_change_bss(struct wiphy *wiphy,\n \t\tsdata->vif.bss_conf.p2p_noa_attr.oppps_ctwindow |=\n \t\t\t\t\tIEEE80211_P2P_OPPPS_ENABLE_BIT;\n \t\tchanged |= BSS_CHANGED_P2P_PS;\n-\t} else if (params->p2p_opp_ps == 0) {\n+\t} else if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS) if (params->p2p_opp_ps == 0) {\n \t\tsdata->vif.bss_conf.p2p_noa_attr.oppps_ctwindow &=\n \t\t\t\t\t~IEEE80211_P2P_OPPPS_ENABLE_BIT;\n \t\tchanged |= BSS_CHANGED_P2P_PS;\n@@ -2408,7 +2408,7 @@ static int ieee80211_resume(struct wiphy *wiphy)\n {\n \treturn __ieee80211_resume(wiphy_priv(wiphy));\n }\n-#else\n+#else if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n #define ieee80211_suspend NULL\n #define ieee80211_resume NULL\n #endif\n@@ -2703,7 +2703,7 @@ static int ieee80211_get_tx_power(struct wiphy *wiphy,\n \n \tif (!local->use_chanctx)\n \t\t*dbm = local->hw.conf.power_level;\n-\telse\n+\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\t*dbm = sdata->vif.bss_conf.txpower;\n \n \treturn 0;\n@@ -2798,7 +2798,7 @@ int __ieee80211_request_smps_mgd(struct ieee80211_sub_if_data *sdata,\n \tif (smps_mode == IEEE80211_SMPS_AUTOMATIC) {\n \t\tif (tdls_peer_found || !sdata->u.mgd.powersave)\n \t\t\tsmps_mode = IEEE80211_SMPS_OFF;\n-\t\telse\n+\t\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\t\tsmps_mode = IEEE80211_SMPS_DYNAMIC;\n \t}\n \n@@ -2807,7 +2807,7 @@ int __ieee80211_request_smps_mgd(struct ieee80211_sub_if_data *sdata,\n \t\t\t\t\t ap, ap);\n \tif (err)\n \t\tsdata->u.mgd.req_smps = old_req;\n-\telse if (smps_mode != IEEE80211_SMPS_OFF && tdls_peer_found)\n+\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS) if (smps_mode != IEEE80211_SMPS_OFF && tdls_peer_found)\n \t\tieee80211_teardown_tdls_peers(sdata);\n \n \treturn err;\n@@ -3340,7 +3340,7 @@ static int ieee80211_set_csa_beacon(struct ieee80211_sub_if_data *sdata,\n \t\t\tifmsh->csa_role = IEEE80211_MESH_CSA_ROLE_INIT;\n \t\t\tif (!ifmsh->pre_value)\n \t\t\t\tifmsh->pre_value = 1;\n-\t\t\telse\n+\t\t\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\t\t\tifmsh->pre_value++;\n \t\t}\n \n@@ -3455,7 +3455,7 @@ __ieee80211_channel_switch(struct wiphy *wiphy, struct net_device *dev,\n \tif (changed) {\n \t\tieee80211_bss_info_change_notify(sdata, changed);\n \t\tdrv_channel_switch_beacon(sdata, &params->chandef);\n-\t} else {\n+\t} else if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS) {\n \t\t/* if the beacon didn't change, we can finalize immediately */\n \t\tieee80211_csa_finalize(sdata);\n \t}\n@@ -3621,7 +3621,7 @@ static int ieee80211_probe_client(struct wiphy *wiphy, struct net_device *dev,\n \tsta = sta_info_get_bss(sdata, peer);\n \tif (sta) {\n \t\tqos = sta->sta.wme;\n-\t} else {\n+\t} else if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS) {\n \t\tret = -ENOLINK;\n \t\tgoto unlock;\n \t}\n@@ -3630,7 +3630,7 @@ static int ieee80211_probe_client(struct wiphy *wiphy, struct net_device *dev,\n \t\tfc = cpu_to_le16(IEEE80211_FTYPE_DATA |\n \t\t\t\t IEEE80211_STYPE_QOS_NULLFUNC |\n \t\t\t\t IEEE80211_FCTL_FROMDS);\n-\t} else {\n+\t} else if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS) {\n \t\tsize -= 2;\n \t\tfc = cpu_to_le16(IEEE80211_FTYPE_DATA |\n \t\t\t\t IEEE80211_STYPE_NULLFUNC |\n@@ -3698,12 +3698,12 @@ static int ieee80211_cfg_get_channel(struct wiphy *wiphy,\n \tif (chanctx_conf) {\n \t\t*chandef = sdata->vif.bss_conf.chandef;\n \t\tret = 0;\n-\t} else if (local->open_count > 0 &&\n+\t} else if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS) if (local->open_count > 0 &&\n \t\t   local->open_count == local->monitors &&\n \t\t   sdata->vif.type == NL80211_IFTYPE_MONITOR) {\n \t\tif (local->use_chanctx)\n \t\t\t*chandef = local->monitor_chandef;\n-\t\telse\n+\t\telse if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS)\n \t\t\t*chandef = local->_oper_chandef;\n \t\tret = 0;\n \t}\n@@ -3731,7 +3731,7 @@ static int ieee80211_set_qos_map(struct wiphy *wiphy,\n \t\tif (!new_qos_map)\n \t\t\treturn -ENOMEM;\n \t\tmemcpy(&new_qos_map->qos_map, qos_map, sizeof(*qos_map));\n-\t} else {\n+\t} else if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS) {\n \t\t/* A NULL qos_map was passed to disable QoS mapping */\n \t\tnew_qos_map = NULL;\n \t}\n@@ -3967,7 +3967,7 @@ static int ieee80211_get_txq_stats(struct wiphy *wiphy,\n \t\t\tgoto out;\n \t\t}\n \t\tieee80211_fill_txq_stats(txqstats, to_txq_info(sdata->vif.txq));\n-\t} else {\n+\t} else if (key_idx < NUM_DEFAULT_KEYS + NUM_DEFAULT_MGMT_KEYS + NUM_DEFAULT_BEACON_KEYS) {\n \t\t/* phy stats */\n \t\ttxqstats->filled |= BIT(NL80211_TXQ_STATS_BACKLOG_PACKETS) |\n \t\t\t\t    BIT(NL80211_TXQ_STATS_BACKLOG_BYTES) |\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "c434e401d70d584f408424099090ddebe2076705": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ntfs3/super.c b/fs/ntfs3/super.c\nindex 278dcf502410..cb992a18272c 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       : (1u << (boot->sectors_per_clusters - 1));\n }\n \n /*\n",
            "diff --git a/fs/ntfs3/super.c b/fs/ntfs3/super.c\nindex 278dcf502410..5beff4f57383 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 ? 0 : (1u << (boot->sectors_per_clusters - 1)));\n }\n \n /*\n",
            "diff --git a/fs/ntfs3/super.c b/fs/ntfs3/super.c\nindex 278dcf502410..7411ea529e3d 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 > 0x80 ? 1u << (boot->sectors_per_clusters - 0x80) : boot->sectors_per_clusters);\n }\n \n /*\n"
        ],
        "error": []
    },
    "e1c3525a4f4e2e4b6c1f73611ceaf61ef462700c": {
        "non_crash": [
            "diff --git a/drivers/hid/hid-thrustmaster.c b/drivers/hid/hid-thrustmaster.c\nindex a4e20f9e598b..71a5c359e148 100644\n--- a/drivers/hid/hid-thrustmaster.c\n+++ b/drivers/hid/hid-thrustmaster.c\n@@ -160,7 +160,13 @@ static void thrustmaster_interrupts(struct hid_device *hdev)\n \t\treturn;\n \t}\n \n-\tep = &usbif->cur_altsetting->endpoint[1];\n+\tif (usbif->cur_altsetting->desc.bNumEndpoints > 1)\n+        ep = &usbif->cur_altsetting->endpoint[1];\n+    else {\n+        hid_err(hdev, \"Not enough endpoints available\\n\");\n+        kfree(send_buf);\n+        return;\n+    }\n \tb_ep = ep->desc.bEndpointAddress;\n \n \tfor (i = 0; i < ARRAY_SIZE(setup_arr); ++i) {\n",
            "diff --git a/drivers/hid/hid-thrustmaster.c b/drivers/hid/hid-thrustmaster.c\nindex a4e20f9e598b..5cc85f9da75f 100644\n--- a/drivers/hid/hid-thrustmaster.c\n+++ b/drivers/hid/hid-thrustmaster.c\n@@ -160,7 +160,13 @@ static void thrustmaster_interrupts(struct hid_device *hdev)\n \t\treturn;\n \t}\n \n-\tep = &usbif->cur_altsetting->endpoint[1];\n+\tif (usbif->cur_altsetting->desc.bNumEndpoints < 2) {\n+        hid_err(hdev, \"Not enough endpoints available\\n\");\n+        kfree(send_buf);\n+        return;\n+    }\n+\n+    ep = &usbif->cur_altsetting->endpoint[1];\n \tb_ep = ep->desc.bEndpointAddress;\n \n \tfor (i = 0; i < ARRAY_SIZE(setup_arr); ++i) {\n",
            "diff --git a/drivers/hid/hid-thrustmaster.c b/drivers/hid/hid-thrustmaster.c\nindex a4e20f9e598b..488b22cc161d 100644\n--- a/drivers/hid/hid-thrustmaster.c\n+++ b/drivers/hid/hid-thrustmaster.c\n@@ -160,7 +160,12 @@ static void thrustmaster_interrupts(struct hid_device *hdev)\n \t\treturn;\n \t}\n \n-\tep = &usbif->cur_altsetting->endpoint[1];\n+\tif (usbif->cur_altsetting->desc.bNumEndpoints < 2) {\n+        hid_err(hdev, \"not enough endpoints\\n\");\n+        kfree(send_buf);\n+        return;\n+    }\n+    ep = &usbif->cur_altsetting->endpoint[1];\n \tb_ep = ep->desc.bEndpointAddress;\n \n \tfor (i = 0; i < ARRAY_SIZE(setup_arr); ++i) {\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/hid/hid-thrustmaster.c b/drivers/hid/hid-thrustmaster.c\nindex a4e20f9e598b..eda75500a1fc 100644\n--- a/drivers/hid/hid-thrustmaster.c\n+++ b/drivers/hid/hid-thrustmaster.c\n@@ -164,7 +164,13 @@ 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\tmemcpy(send_buf, setup_arr[i], setup_arr_sizes[i]);\n+\t\tif (setup_arr_sizes[i] <= 256) {\n+            memcpy(send_buf, setup_arr[i], setup_arr_sizes[i]);\n+        } else {\n+            hid_err(hdev, \"setup data size exceeds buffer capacity\\n\");\n+            kfree(send_buf);\n+            return;\n+        }\n \n \t\tret = usb_interrupt_msg(usbdev,\n \t\t\tusb_sndintpipe(usbdev, b_ep),\n",
            "diff --git a/drivers/hid/hid-thrustmaster.c b/drivers/hid/hid-thrustmaster.c\nindex a4e20f9e598b..702e0866694f 100644\n--- a/drivers/hid/hid-thrustmaster.c\n+++ b/drivers/hid/hid-thrustmaster.c\n@@ -214,7 +214,7 @@ static void thrustmaster_model_handler(struct urb *urb)\n \t\treturn;\n \t}\n \n-\tif (tm_wheel->response->type == cpu_to_le16(0x49))\n+\tif (tm_wheel->response->type == cpu_to_le16(0x49) && urb->actual_length >= sizeof(tm_wheel->response->data.a))\n \t\tmodel = le16_to_cpu(tm_wheel->response->data.a.model);\n \telse if (tm_wheel->response->type == cpu_to_le16(0x47))\n \t\tmodel = le16_to_cpu(tm_wheel->response->data.b.model);\n"
        ],
        "error": []
    },
    "39b560f8c5d46a5c107b83c6a1e8ae4051826de0": {
        "non_crash": [
            "diff --git a/net/ethtool/pse-pd.c b/net/ethtool/pse-pd.c\nindex 5a471e115b66..b879dc364695 100644\n--- a/net/ethtool/pse-pd.c\n+++ b/net/ethtool/pse-pd.c\n@@ -64,7 +64,11 @@ static int pse_prepare_data(const struct ethnl_req_info *req_base,\n \tif (ret < 0)\n \t\treturn ret;\n \n-\tret = pse_get_pse_attributes(dev, info->extack, data);\n+\tif (!dev || !info || !info->extack) {\n+        return -EINVAL;\n+    }\n+\n+    ret = pse_get_pse_attributes(dev, info->extack, data);\n \n \tethnl_ops_complete(dev);\n \n",
            "diff --git a/net/ethtool/pse-pd.c b/net/ethtool/pse-pd.c\nindex 5a471e115b66..c43841dad805 100644\n--- a/net/ethtool/pse-pd.c\n+++ b/net/ethtool/pse-pd.c\n@@ -64,7 +64,10 @@ static int pse_prepare_data(const struct ethnl_req_info *req_base,\n \tif (ret < 0)\n \t\treturn ret;\n \n-\tret = pse_get_pse_attributes(dev, info->extack, data);\n+\tif (!dev->phydev || !dev->phydev->psec) {\n+        return -EOPNOTSUPP;\n+    }\n+    ret = pse_get_pse_attributes(dev, info->extack, data);\n \n \tethnl_ops_complete(dev);\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/ethtool/pse-pd.c b/net/ethtool/pse-pd.c\nindex 5a471e115b66..30656c57d3d2 100644\n--- a/net/ethtool/pse-pd.c\n+++ b/net/ethtool/pse-pd.c\n@@ -65,6 +65,8 @@ static int pse_prepare_data(const struct ethnl_req_info *req_base,\n \t\treturn ret;\n \n \tret = pse_get_pse_attributes(dev, info->extack, data);\n+    if (ret < 0)\n+        return ret;\n \n \tethnl_ops_complete(dev);\n \n",
            "diff --git a/net/ethtool/pse-pd.c b/net/ethtool/pse-pd.c\nindex 5a471e115b66..91848a610150 100644\n--- a/net/ethtool/pse-pd.c\n+++ b/net/ethtool/pse-pd.c\n@@ -64,7 +64,12 @@ static int pse_prepare_data(const struct ethnl_req_info *req_base,\n \tif (ret < 0)\n \t\treturn ret;\n \n-\tret = pse_get_pse_attributes(dev, info->extack, data);\n+\tif (!dev || !dev->phydev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid device or PHY not attached\");\n+        ethnl_ops_complete(dev);\n+        return -EOPNOTSUPP;\n+    }\n+    ret = pse_get_pse_attributes(dev, info->extack, data);\n \n \tethnl_ops_complete(dev);\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/ethtool/pse-pd.c b/net/ethtool/pse-pd.c\nindex 5a471e115b66..a366305a1d16 100644\n--- a/net/ethtool/pse-pd.c\n+++ b/net/ethtool/pse-pd.c\n@@ -53,6 +53,12 @@ static int pse_get_pse_attributes(struct net_device *dev,\n }\n \n static int pse_prepare_data(const struct ethnl_req_info *req_base,\n+               struct ethnl_reply_data *reply_base,\n+               struct genl_info *info)\n+{\n+    if (!reply_base) {\n+        return -EINVAL;\n+    }\n \t\t\t       struct ethnl_reply_data *reply_base,\n \t\t\t       struct genl_info *info)\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..b3626f0f785c 100644\n--- a/net/qrtr/qrtr.c\n+++ b/net/qrtr/qrtr.c\n@@ -695,7 +695,9 @@ static int qrtr_port_assign(struct qrtr_sock *ipc, int *port)\n \tint rc;\n \n \tmutex_lock(&qrtr_port_lock);\n-\tif (!*port) {\n+\tif (*port < 0) {\n+        rc = -EINVAL;\n+    } else if (!*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"
        ],
        "error": [
            {
                "patch": "diff --git a/net/qrtr/qrtr.c b/net/qrtr/qrtr.c\nindex b4c0db0b7d31..158ca76306e3 100644\n--- a/net/qrtr/qrtr.c\n+++ b/net/qrtr/qrtr.c\n@@ -694,6 +694,11 @@ static int qrtr_port_assign(struct qrtr_sock *ipc, int *port)\n {\n \tint rc;\n \n+    if (*port < 0) {\n+        mutex_unlock(&qrtr_port_lock);\n+        return -EINVAL;\n+    }\n+\n \tmutex_lock(&qrtr_port_lock);\n \tif (!*port) {\n \t\trc = idr_alloc(&qrtr_ports, ipc,\n@@ -754,6 +759,11 @@ static int __qrtr_bind(struct socket *sock,\n \tint port;\n \tint rc;\n \n+    if (*port < 0) {\n+        mutex_unlock(&qrtr_port_lock);\n+        return -EINVAL;\n+    }\n+\n \t/* rebinding ok */\n \tif (!zapped && addr->sq_port == ipc->us.sq_port)\n \t\treturn 0;\n@@ -801,6 +811,11 @@ static int qrtr_bind(struct socket *sock, struct sockaddr *saddr, int len)\n \tstruct sock *sk = sock->sk;\n \tint rc;\n \n+    if (*port < 0) {\n+        mutex_unlock(&qrtr_port_lock);\n+        return -EINVAL;\n+    }\n+\n \tif (len < sizeof(*addr) || addr->sq_family != AF_QIPCRTR)\n \t\treturn -EINVAL;\n \n@@ -879,6 +894,11 @@ static int qrtr_sendmsg(struct socket *sock, struct msghdr *msg, size_t len)\n \tu32 type;\n \tint rc;\n \n+    if (*port < 0) {\n+        mutex_unlock(&qrtr_port_lock);\n+        return -EINVAL;\n+    }\n+\n \tif (msg->msg_flags & ~(MSG_DONTWAIT))\n \t\treturn -EINVAL;\n \n@@ -1054,6 +1074,11 @@ static int qrtr_connect(struct socket *sock, struct sockaddr *saddr,\n \tstruct sock *sk = sock->sk;\n \tint rc;\n \n+    if (*port < 0) {\n+        mutex_unlock(&qrtr_port_lock);\n+        return -EINVAL;\n+    }\n+\n \tif (len < sizeof(*addr) || addr->sq_family != AF_QIPCRTR)\n \t\treturn -EINVAL;\n \n@@ -1256,6 +1281,11 @@ static int __init qrtr_proto_init(void)\n {\n \tint rc;\n \n+    if (*port < 0) {\n+        mutex_unlock(&qrtr_port_lock);\n+        return -EINVAL;\n+    }\n+\n \trc = proto_register(&qrtr_proto, 1);\n \tif (rc)\n \t\treturn rc;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/qrtr/qrtr.c b/net/qrtr/qrtr.c\nindex b4c0db0b7d31..1b021a15d464 100644\n--- a/net/qrtr/qrtr.c\n+++ b/net/qrtr/qrtr.c\n@@ -287,7 +287,9 @@ static int qrtr_tx_wait(struct qrtr_node *node, int dest_node, int dest_port,\n \t} else if (flow->tx_failed) {\n \t\tflow->tx_failed = 0;\n \t\tconfirm_rx = 1;\n-\t} else {\n+\t} else if (*port < 0) {\n+rc = -EINVAL;\n+\n \t\tflow->pending++;\n \t\tconfirm_rx = flow->pending == QRTR_TX_FLOW_LOW;\n \t}\n@@ -349,7 +351,9 @@ static int qrtr_node_enqueue(struct qrtr_node *node, struct sk_buff *skb,\n \tif (to->sq_port == QRTR_PORT_CTRL) {\n \t\thdr->dst_node_id = cpu_to_le32(node->nid);\n \t\thdr->dst_port_id = cpu_to_le32(QRTR_NODE_BCAST);\n-\t} else {\n+\t} else if (*port < 0) {\n+rc = -EINVAL;\n+\n \t\thdr->dst_node_id = cpu_to_le32(to->sq_node);\n \t\thdr->dst_port_id = cpu_to_le32(to->sq_port);\n \t}\n@@ -495,7 +499,9 @@ int qrtr_endpoint_post(struct qrtr_endpoint *ep, const void *data, size_t len)\n \n \tif (cb->type == QRTR_TYPE_RESUME_TX) {\n \t\tqrtr_tx_resume(node, skb);\n-\t} else {\n+\t} else if (*port < 0) {\n+rc = -EINVAL;\n+\n \t\tipc = qrtr_port_lookup(cb->dst_port);\n \t\tif (!ipc)\n \t\t\tgoto err;\n@@ -705,7 +711,9 @@ static int qrtr_port_assign(struct qrtr_sock *ipc, int *port)\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} else {\n+\t} else if (*port < 0) {\n+rc = -EINVAL;\n+\n \t\trc = idr_alloc(&qrtr_ports, ipc, *port, *port + 1, GFP_ATOMIC);\n \t\tif (rc >= 0)\n \t\t\t*port = rc;\n@@ -905,7 +913,9 @@ static int qrtr_sendmsg(struct socket *sock, struct msghdr *msg, size_t len)\n \t\t}\n \t} else if (sk->sk_state == TCP_ESTABLISHED) {\n \t\taddr = &ipc->peer;\n-\t} else {\n+\t} else if (*port < 0) {\n+rc = -EINVAL;\n+\n \t\trelease_sock(sk);\n \t\treturn -ENOTCONN;\n \t}\n@@ -920,7 +930,9 @@ static int qrtr_sendmsg(struct socket *sock, struct msghdr *msg, size_t len)\n \t\tenqueue_fn = qrtr_bcast_enqueue;\n \t} else if (addr->sq_node == ipc->us.sq_node) {\n \t\tenqueue_fn = qrtr_local_enqueue;\n-\t} else {\n+\t} else if (*port < 0) {\n+rc = -EINVAL;\n+\n \t\tnode = qrtr_node_lookup(addr->sq_node);\n \t\tif (!node) {\n \t\t\trelease_sock(sk);\n@@ -1092,7 +1104,9 @@ static int qrtr_getname(struct socket *sock, struct sockaddr *saddr,\n \t\t}\n \n \t\tqaddr = ipc->peer;\n-\t} else {\n+\t} else if (*port < 0) {\n+rc = -EINVAL;\n+\n \t\tqaddr = ipc->us;\n \t}\n \trelease_sock(sk);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/qrtr/qrtr.c b/net/qrtr/qrtr.c\nindex b4c0db0b7d31..c93839efeaa8 100644\n--- a/net/qrtr/qrtr.c\n+++ b/net/qrtr/qrtr.c\n@@ -696,6 +696,9 @@ static int qrtr_port_assign(struct qrtr_sock *ipc, int *port)\n \n \tmutex_lock(&qrtr_port_lock);\n \tif (!*port) {\n+    if (*port < 0) {\n+        rc = -EINVAL;\n+    } else {\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",
                "error_message": "Failed to build"
            }
        ]
    },
    "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..21364019e9bd 100644\n--- a/net/netfilter/ipset/ip_set_core.c\n+++ b/net/netfilter/ipset/ip_set_core.c\n@@ -357,7 +357,8 @@ ip_set_init_comment(struct ip_set *set, struct ip_set_comment *comment,\n \tsize_t len = ext->comment ? strlen(ext->comment) : 0;\n \n \tif (unlikely(c)) {\n-\t\tset->ext_size -= sizeof(*c) + strlen(c->str) + 1;\n+\t\tif (c->str)\n+        set->ext_size -= sizeof(*c) + strlen(c->str) + 1;\n \t\tkfree_rcu(c, rcu);\n \t\trcu_assign_pointer(comment->c, NULL);\n \t}\n@@ -399,7 +400,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 (c->str)\n+        set->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..ff63095ca6bd 100644\n--- a/net/netfilter/ipset/ip_set_core.c\n+++ b/net/netfilter/ipset/ip_set_core.c\n@@ -399,7 +399,7 @@ 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) set->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..0bf7cd038aca 100644\n--- a/net/netfilter/ipset/ip_set_core.c\n+++ b/net/netfilter/ipset/ip_set_core.c\n@@ -396,7 +396,9 @@ ip_set_comment_free(struct ip_set *set, void *ptr)\n \tstruct ip_set_comment *comment = ptr;\n \tstruct ip_set_comment_rcu *c;\n \n-\tc = rcu_dereference_protected(comment->c, 1);\n+\tif (unlikely(!comment))\n+        return;\n+c = rcu_dereference_protected(comment->c, 1);\n \tif (unlikely(!c))\n \t\treturn;\n \tset->ext_size -= sizeof(*c) + strlen(c->str) + 1;\n",
            "diff --git a/net/netfilter/ipset/ip_set_core.c b/net/netfilter/ipset/ip_set_core.c\nindex 8dd17589217d..d81c698a50b3 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 (c->str)\n+        set->ext_size -= sizeof(*c) + strlen(c->str) + 1;\n \tkfree_rcu(c, rcu);\n \trcu_assign_pointer(comment->c, NULL);\n }\n"
        ],
        "error": []
    },
    "544afab64e441605326c54f7c2d4aa9bab2419ff": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netrom/af_netrom.c b/net/netrom/af_netrom.c\nindex 6f7f4392cffb..fc6013add528 100644\n--- a/net/netrom/af_netrom.c\n+++ b/net/netrom/af_netrom.c\n@@ -432,7 +432,8 @@ static int nr_create(struct net *net, struct socket *sock, int protocol,\n \n \tsk = sk_alloc(net, PF_NETROM, GFP_ATOMIC, &nr_proto, kern);\n \tif (sk  == NULL)\n-\t\treturn -ENOMEM;\n+\t\tsock_put(sk);\n+        return -ENOMEM;\n \n \tnr = nr_sk(sk);\n \n",
            "diff --git a/net/netrom/af_netrom.c b/net/netrom/af_netrom.c\nindex 6f7f4392cffb..844c5363e057 100644\n--- a/net/netrom/af_netrom.c\n+++ b/net/netrom/af_netrom.c\n@@ -429,6 +429,8 @@ static int nr_create(struct net *net, struct socket *sock, int protocol,\n \n \tif (sock->type != SOCK_SEQPACKET || protocol != 0)\n \t\treturn -ESOCKTNOSUPPORT;\n+    if (sk)\n+        sock_put(sk);\n \n \tsk = sk_alloc(net, PF_NETROM, GFP_ATOMIC, &nr_proto, kern);\n \tif (sk  == NULL)\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/netrom/af_netrom.c b/net/netrom/af_netrom.c\nindex 6f7f4392cffb..938afafd4dcb 100644\n--- a/net/netrom/af_netrom.c\n+++ b/net/netrom/af_netrom.c\n@@ -441,6 +441,12 @@ static int nr_create(struct net *net, struct socket *sock, int protocol,\n \tsock->ops    = &nr_proto_ops;\n \tsk->sk_protocol = protocol;\n \n+    // Ensure resources are freed if initialization fails\n+    if (sock_init_data(sock, sk) < 0) {\n+        sk_free(sk);\n+        return -ENOMEM;\n+    }\n+\n \tskb_queue_head_init(&nr->ack_queue);\n \tskb_queue_head_init(&nr->reseq_queue);\n \tskb_queue_head_init(&nr->frag_queue);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/netrom/af_netrom.c b/net/netrom/af_netrom.c\nindex 6f7f4392cffb..c2bfa7f0ac1a 100644\n--- a/net/netrom/af_netrom.c\n+++ b/net/netrom/af_netrom.c\n@@ -431,7 +431,13 @@ 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+        return -ENOMEM;\n+\n+    if (sock_init_data(sock, sk) < 0) {\n+        sock_put(sk);\n+        return -ENOMEM;\n+    }\n \t\treturn -ENOMEM;\n \n \tnr = nr_sk(sk);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "cdaf5ed409125df023889aefe50b4cc4a41c0973": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/namei.c b/fs/namei.c\nindex edfedfbccaef..de9dddaefed2 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -3979,6 +3979,10 @@ static int do_mknodat(int dfd, struct filename *name, umode_t mode,\n \t}\n out2:\n \tdone_path_create(&path, dentry);\n+    if (error) {\n+        inode_lock(path.dentry->d_inode);\n+        done_path_create(&path, dentry);\n+    }\n \tif (retry_estale(error, lookup_flags)) {\n \t\tlookup_flags |= LOOKUP_REVAL;\n \t\tgoto retry;\n@@ -4062,6 +4066,10 @@ int do_mkdirat(int dfd, struct filename *name, umode_t mode)\n \t\t\t\t  dentry, mode);\n \t}\n \tdone_path_create(&path, dentry);\n+    if (error) {\n+        inode_lock(path.dentry->d_inode);\n+        done_path_create(&path, dentry);\n+    }\n \tif (retry_estale(error, lookup_flags)) {\n \t\tlookup_flags |= LOOKUP_REVAL;\n \t\tgoto retry;\n@@ -4424,6 +4432,10 @@ int do_symlinkat(struct filename *from, int newdfd, struct filename *to)\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+    if (error) {\n+        inode_lock(path.dentry->d_inode);\n+        done_path_create(&path, dentry);\n+    }\n \tif (retry_estale(error, lookup_flags)) {\n \t\tlookup_flags |= LOOKUP_REVAL;\n \t\tgoto retry;\n",
            "diff --git a/fs/namei.c b/fs/namei.c\nindex edfedfbccaef..eceba5a8e011 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -4423,7 +4423,8 @@ int do_symlinkat(struct filename *from, int newdfd, struct filename *to)\n \tif (!error)\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+\tinode_lock(dentry->d_inode);\n+done_path_create(&path, dentry);\n \tif (retry_estale(error, lookup_flags)) {\n \t\tlookup_flags |= LOOKUP_REVAL;\n \t\tgoto retry;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/namei.c b/fs/namei.c\nindex edfedfbccaef..99cfe198dcff 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -4420,6 +4420,7 @@ 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+inode_lock(path.dentry->d_inode);\n \tif (!error)\n \t\terror = vfs_symlink(mnt_idmap(path.mnt), path.dentry->d_inode,\n \t\t\t\t    dentry, from->name);\n",
                "error_message": "Failed to set up instance"
            },
            {
                "patch": "diff --git a/fs/namei.c b/fs/namei.c\nindex edfedfbccaef..caa9a784ec32 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -2573,7 +2573,7 @@ static struct dentry *__kern_path_locked(struct filename *name, struct path *pat\n \tinode_lock_nested(path->dentry->d_inode, I_MUTEX_PARENT);\n \td = __lookup_hash(&last, path->dentry, 0);\n \tif (IS_ERR(d)) {\n-\t\tinode_unlock(path->dentry->d_inode);\n+\t\t\n \t\tpath_put(path);\n \t}\n \treturn d;\n@@ -3833,7 +3833,7 @@ static struct dentry *filename_create(int dfd, struct filename *name,\n \tdput(dentry);\n \tdentry = ERR_PTR(error);\n unlock:\n-\tinode_unlock(path->dentry->d_inode);\n+\t\n \tif (!err2)\n \t\tmnt_drop_write(path->mnt);\n out:\n@@ -3855,7 +3855,7 @@ 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+\t\n \tmnt_drop_write(path->mnt);\n \tpath_put(path);\n }\n",
                "error_message": "Failed to set up instance"
            }
        ]
    },
    "0987d64a09e1eb9642824a088eb331dbdb2db644": {
        "non_crash": [
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 0194a36d0b36..6017de4236be 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -12649,7 +12649,8 @@ 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 can only use preallocated hash map\\n\");\n+            return -EINVAL;\n \t\tverbose(env, \"trace type programs with run-time allocated hash maps are unsafe. Switch to preallocated hash maps.\\n\");\n \t}\n \n",
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 0194a36d0b36..9e624b18c105 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -12649,7 +12649,8 @@ 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, \"Error: trace type programs cannot use run-time allocated hash maps. Convert to preallocated hash maps.\\n\");\n+return -EINVAL;\n \t\tverbose(env, \"trace type programs with run-time allocated hash maps are unsafe. Switch to preallocated hash maps.\\n\");\n \t}\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 0194a36d0b36..6e8f7ab7663c 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -12649,7 +12649,7 @@ 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\tWARN_ONCE(1, \"trace type BPF program uses run-time allocation. Consider using BPF_MAP_TYPE_HASH or BPF_MAP_TYPE_PERCPU_HASH with BPF_F_NO_PREALLOC flag set for preallocation.\\n\");\n \t\tverbose(env, \"trace type programs with run-time allocated hash maps are unsafe. Switch to preallocated hash maps.\\n\");\n \t}\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/kernel/bpf/hashtab.c b/kernel/bpf/hashtab.c\nindex 508e64351f87..ddaa19205406 100644\n--- a/kernel/bpf/hashtab.c\n+++ b/kernel/bpf/hashtab.c\n@@ -440,6 +440,9 @@ static int htab_map_alloc_check(union bpf_attr *attr)\n \t */\n \tbool percpu_lru = (attr->map_flags & BPF_F_NO_COMMON_LRU);\n \tbool prealloc = !(attr->map_flags & BPF_F_NO_PREALLOC);\n+if (trace_type_program) {\n+    prealloc = true;\n+}\n \tbool zero_seed = (attr->map_flags & BPF_F_ZERO_SEED);\n \tint numa_node = bpf_map_attr_numa_node(attr);\n \n@@ -503,6 +506,9 @@ static struct bpf_map *htab_map_alloc(union bpf_attr *attr)\n \t */\n \tbool percpu_lru = (attr->map_flags & BPF_F_NO_COMMON_LRU);\n \tbool prealloc = !(attr->map_flags & BPF_F_NO_PREALLOC);\n+if (trace_type_program) {\n+    prealloc = true;\n+}\n \tstruct bpf_htab *htab;\n \tint err, i;\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "07c9d71dc1a215b19c6a245c68f502bc57dbdb83": {
        "non_crash": [
            "diff --git a/net/qrtr/ns.c b/net/qrtr/ns.c\nindex d8252fdab851..a63c879ea21e 100644\n--- a/net/qrtr/ns.c\n+++ b/net/qrtr/ns.c\n@@ -554,7 +554,8 @@ static int ctrl_cmd_new_lookup(struct sockaddr_qrtr *from,\n \tfilter.service = service;\n \tfilter.instance = instance;\n \n-\tradix_tree_for_each_slot(node_slot, &nodes, &node_iter, 0) {\n+\trcu_read_lock();\n+    radix_tree_for_each_slot(node_slot, &nodes, &node_iter, 0) {\n \t\tnode = radix_tree_deref_slot(node_slot);\n \n \t\tradix_tree_for_each_slot(srv_slot, &node->servers,\n@@ -570,7 +571,8 @@ static int ctrl_cmd_new_lookup(struct sockaddr_qrtr *from,\n \t}\n \n \t/* Empty notification, to indicate end of listing */\n-\tlookup_notify(from, NULL, true);\n+\trcu_read_unlock();\n+    lookup_notify(from, NULL, true);\n \n \treturn 0;\n }\n",
            "diff --git a/net/qrtr/ns.c b/net/qrtr/ns.c\nindex d8252fdab851..cf6fbf25d323 100644\n--- a/net/qrtr/ns.c\n+++ b/net/qrtr/ns.c\n@@ -554,7 +554,8 @@ static int ctrl_cmd_new_lookup(struct sockaddr_qrtr *from,\n \tfilter.service = service;\n \tfilter.instance = instance;\n \n-\tradix_tree_for_each_slot(node_slot, &nodes, &node_iter, 0) {\n+\trcu_read_lock();\n+    radix_tree_for_each_slot(node_slot, &nodes, &node_iter, 0) {\n \t\tnode = radix_tree_deref_slot(node_slot);\n \n \t\tradix_tree_for_each_slot(srv_slot, &node->servers,\n@@ -570,7 +571,10 @@ static int ctrl_cmd_new_lookup(struct sockaddr_qrtr *from,\n \t}\n \n \t/* Empty notification, to indicate end of listing */\n-\tlookup_notify(from, NULL, true);\n+\trcu_read_unlock();\n+\n+    /* Empty notification, to indicate end of listing */\n+    lookup_notify(from, NULL, true);\n \n \treturn 0;\n }\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/qrtr/ns.c b/net/qrtr/ns.c\nindex d8252fdab851..825e4f9c1489 100644\n--- a/net/qrtr/ns.c\n+++ b/net/qrtr/ns.c\n@@ -94,7 +94,8 @@ static int server_match(const struct qrtr_server *srv,\n \tunsigned int ifilter = f->ifilter;\n \n \tif (f->service != 0 && srv->service != f->service)\n-\t\treturn 0;\n+\t\trcu_read_unlock();\n+    return 0;\n \tif (!ifilter && f->instance)\n \t\tifilter = ~0;\n \n@@ -197,7 +198,8 @@ static int announce_servers(struct sockaddr_qrtr *sq)\n \n \tnode = node_get(qrtr_ns.local_node);\n \tif (!node)\n-\t\treturn 0;\n+\t\trcu_read_unlock();\n+    return 0;\n \n \t/* Announce the list of servers registered in this node */\n \tradix_tree_for_each_slot(slot, &node->servers, &iter, 0) {\n@@ -210,7 +212,8 @@ static int announce_servers(struct sockaddr_qrtr *sq)\n \t\t}\n \t}\n \n-\treturn 0;\n+\trcu_read_unlock();\n+    return 0;\n }\n \n static struct qrtr_server *server_add(unsigned int service,\n@@ -286,7 +289,8 @@ static int server_del(struct qrtr_node *node, unsigned int port)\n \n \tkfree(srv);\n \n-\treturn 0;\n+\trcu_read_unlock();\n+    return 0;\n }\n \n static int say_hello(struct sockaddr_qrtr *dest)\n@@ -342,7 +346,8 @@ static int ctrl_cmd_bye(struct sockaddr_qrtr *from)\n \n \tnode = node_get(from->sq_node);\n \tif (!node)\n-\t\treturn 0;\n+\t\trcu_read_unlock();\n+    return 0;\n \n \t/* Advertise removal of this client to all servers of remote node */\n \tradix_tree_for_each_slot(slot, &node->servers, &iter, 0) {\n@@ -353,7 +358,8 @@ static int ctrl_cmd_bye(struct sockaddr_qrtr *from)\n \t/* Advertise the removal of this client to all local servers */\n \tlocal_node = node_get(qrtr_ns.local_node);\n \tif (!local_node)\n-\t\treturn 0;\n+\t\trcu_read_unlock();\n+    return 0;\n \n \tmemset(&pkt, 0, sizeof(pkt));\n \tpkt.cmd = cpu_to_le32(QRTR_TYPE_BYE);\n@@ -376,7 +382,8 @@ static int ctrl_cmd_bye(struct sockaddr_qrtr *from)\n \t\t}\n \t}\n \n-\treturn 0;\n+\trcu_read_unlock();\n+    return 0;\n }\n \n static int ctrl_cmd_del_client(struct sockaddr_qrtr *from,\n@@ -427,7 +434,8 @@ static int ctrl_cmd_del_client(struct sockaddr_qrtr *from,\n \t/* Advertise the removal of this client to all local servers */\n \tlocal_node = node_get(qrtr_ns.local_node);\n \tif (!local_node)\n-\t\treturn 0;\n+\t\trcu_read_unlock();\n+    return 0;\n \n \tmemset(&pkt, 0, sizeof(pkt));\n \tpkt.cmd = cpu_to_le32(QRTR_TYPE_DEL_CLIENT);\n@@ -451,7 +459,8 @@ static int ctrl_cmd_del_client(struct sockaddr_qrtr *from,\n \t\t}\n \t}\n \n-\treturn 0;\n+\trcu_read_unlock();\n+    return 0;\n }\n \n static int ctrl_cmd_new_server(struct sockaddr_qrtr *from,\n@@ -554,7 +563,8 @@ static int ctrl_cmd_new_lookup(struct sockaddr_qrtr *from,\n \tfilter.service = service;\n \tfilter.instance = instance;\n \n-\tradix_tree_for_each_slot(node_slot, &nodes, &node_iter, 0) {\n+\trcu_read_lock();\n+    radix_tree_for_each_slot(node_slot, &nodes, &node_iter, 0) {\n \t\tnode = radix_tree_deref_slot(node_slot);\n \n \t\tradix_tree_for_each_slot(srv_slot, &node->servers,\n@@ -572,7 +582,8 @@ static int ctrl_cmd_new_lookup(struct sockaddr_qrtr *from,\n \t/* Empty notification, to indicate end of listing */\n \tlookup_notify(from, NULL, true);\n \n-\treturn 0;\n+\trcu_read_unlock();\n+    return 0;\n }\n \n static void ctrl_cmd_del_lookup(struct sockaddr_qrtr *from,\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/qrtr/ns.c b/net/qrtr/ns.c\nindex d8252fdab851..59e7b9da74b6 100644\n--- a/net/qrtr/ns.c\n+++ b/net/qrtr/ns.c\n@@ -555,13 +555,13 @@ static int ctrl_cmd_new_lookup(struct sockaddr_qrtr *from,\n \tfilter.instance = instance;\n \n \tradix_tree_for_each_slot(node_slot, &nodes, &node_iter, 0) {\n-\t\tnode = radix_tree_deref_slot(node_slot);\n+\t\tnode = rcu_dereference(node_slot);\n \n \t\tradix_tree_for_each_slot(srv_slot, &node->servers,\n \t\t\t\t\t &srv_iter, 0) {\n \t\t\tstruct qrtr_server *srv;\n \n-\t\t\tsrv = radix_tree_deref_slot(srv_slot);\n+\t\t\tsrv = rcu_dereference(srv_slot);\n \t\t\tif (!server_match(srv, &filter))\n \t\t\t\tcontinue;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/qrtr/ns.c b/net/qrtr/ns.c\nindex d8252fdab851..5698c62d79e3 100644\n--- a/net/qrtr/ns.c\n+++ b/net/qrtr/ns.c\n@@ -555,13 +555,13 @@ static int ctrl_cmd_new_lookup(struct sockaddr_qrtr *from,\n \tfilter.instance = instance;\n \n \tradix_tree_for_each_slot(node_slot, &nodes, &node_iter, 0) {\n-\t\tnode = radix_tree_deref_slot(node_slot);\n+\t\tnode = rcu_dereference_protected(*node_slot, lockdep_is_held(&qrtr_ns.work));\n \n \t\tradix_tree_for_each_slot(srv_slot, &node->servers,\n \t\t\t\t\t &srv_iter, 0) {\n \t\t\tstruct qrtr_server *srv;\n \n-\t\t\tsrv = radix_tree_deref_slot(srv_slot);\n+\t\t\tsrv = rcu_dereference_protected(*srv_slot, lockdep_is_held(&qrtr_ns.work));\n \t\t\tif (!server_match(srv, &filter))\n \t\t\t\tcontinue;\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "e675fbaf856bd1465eed8b8f51ae182b58b8d656": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/lib/idr.c b/lib/idr.c\nindex 7ecdfdb5309e..3136abb50ecb 100644\n--- a/lib/idr.c\n+++ b/lib/idr.c\n@@ -496,6 +496,7 @@ void ida_free(struct ida *ida, unsigned int id)\n \n \txas_lock_irqsave(&xas, flags);\n \tbitmap = xas_load(&xas);\n+    if (!bitmap) return;\n \n \tif (xa_is_value(bitmap)) {\n \t\tunsigned long v = xa_to_value(bitmap);\n",
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex bc0f15257b49..a7c858fbc375 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -157,7 +157,8 @@ 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+\tif (mnt->mnt_group_id)\n+        ida_free(&mnt_group_ida, mnt->mnt_group_id);\n \tmnt->mnt_group_id = 0;\n }\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/namespace.c b/fs/namespace.c\nindex bc0f15257b49..db88683f1210 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -1718,6 +1718,9 @@ static int do_umount(struct mount *mnt, int flags)\n \t\t}\n \t}\n out:\n+    if (!err) {\n+        invent_group_ids(mnt, true);\n+    }\n \tunlock_mount_hash();\n \tnamespace_unlock();\n \treturn retval;\n@@ -1931,6 +1934,9 @@ struct mount *copy_tree(struct mount *mnt, struct dentry *dentry,\n \t}\n \treturn res;\n out:\n+    if (!err) {\n+        invent_group_ids(mnt, true);\n+    }\n \tif (res) {\n \t\tlock_mount_hash();\n \t\tumount_tree(res, UMOUNT_SYNC);\n@@ -2277,6 +2283,9 @@ static int attach_recursive_mnt(struct mount *source_mnt,\n \tunlock_mount_hash();\n \tcleanup_group_ids(source_mnt, NULL);\n  out:\n+    if (!err) {\n+        invent_group_ids(mnt, true);\n+    }\n \tns->pending_mounts = 0;\n \n \tread_seqlock_excl(&mount_lock);\n@@ -2460,6 +2469,9 @@ static int do_loopback(struct path *path, const char *old_name,\n out2:\n \tunlock_mount(mp);\n out:\n+    if (!err) {\n+        invent_group_ids(mnt, true);\n+    }\n \tpath_put(&old_path);\n \treturn err;\n }\n@@ -2745,6 +2757,9 @@ static bool check_for_nsfs_mounts(struct mount *subtree)\n \n \tret = true;\n out:\n+    if (!err) {\n+        invent_group_ids(mnt, true);\n+    }\n \tunlock_mount_hash();\n \treturn ret;\n }\n@@ -2817,6 +2832,9 @@ static int do_set_group(struct path *from_path, struct path *to_path)\n \n \terr = 0;\n out:\n+    if (!err) {\n+        invent_group_ids(mnt, true);\n+    }\n \tnamespace_unlock();\n \treturn err;\n }\n@@ -2893,6 +2911,9 @@ static int do_move_mount(struct path *old_path, struct path *new_path)\n \tif (attached)\n \t\tput_mountpoint(old_mp);\n out:\n+    if (!err) {\n+        invent_group_ids(mnt, true);\n+    }\n \tunlock_mount(mp);\n \tif (!err) {\n \t\tif (attached)\n@@ -4180,6 +4201,9 @@ static int do_mount_setattr(struct path *path, struct mount_kattr *kattr)\n \t\tmount_setattr_commit(kattr, mnt);\n \n out:\n+    if (!err) {\n+        invent_group_ids(mnt, true);\n+    }\n \tunlock_mount_hash();\n \n \tif (kattr->propagation) {\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/namespace.c b/fs/namespace.c\nindex bc0f15257b49..9d7ee7a13d2b 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -156,6 +156,8 @@ static int mnt_alloc_group_id(struct mount *mnt)\n  * Release a peer group ID\n  */\n void mnt_release_group_id(struct mount *mnt)\n+{\n+    if (mnt->mnt_group_id) {\n {\n \tida_free(&mnt_group_ida, mnt->mnt_group_id);\n \tmnt->mnt_group_id = 0;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/namespace.c b/fs/namespace.c\nindex bc0f15257b49..a8c8dd6bb252 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -156,6 +156,8 @@ static int mnt_alloc_group_id(struct mount *mnt)\n  * Release a peer group ID\n  */\n void mnt_release_group_id(struct mount *mnt)\n+{\n+    if (!mnt->mnt_group_id) return;\n {\n \tida_free(&mnt_group_ida, mnt->mnt_group_id);\n \tmnt->mnt_group_id = 0;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "1a201ce4f0f4ab2f165b93d0ce5c15ebe1a5b321": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/sys.c b/kernel/sys.c\nindex 5fd54bf0e886..bae411400d4f 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+            anon_vma_name_put(anon_name);\n+        else\n+            anon_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..fc99441de39e 100644\n--- a/kernel/sys.c\n+++ b/kernel/sys.c\n@@ -2332,6 +2332,9 @@ static int prctl_set_vma(unsigned long opt, unsigned long addr,\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+if (error) {\n+kfree(anon_name);\n+}\n \t\tbreak;\n \tdefault:\n \t\terror = -EINVAL;\n",
            "diff --git a/kernel/sys.c b/kernel/sys.c\nindex 5fd54bf0e886..27d75c1c124c 100644\n--- a/kernel/sys.c\n+++ b/kernel/sys.c\n@@ -2321,7 +2321,10 @@ static int prctl_set_vma(unsigned long opt, unsigned long addr,\n \t\t\t\t}\n \t\t\t}\n \t\t\t/* anon_vma has its own copy */\n-\t\t\tanon_name = anon_vma_name_alloc(name);\n+\t\t\tanon_name = anon_name = anon_vma_name_alloc(name);\n+if (!anon_name)\n+return -ENOMEM;\n+anon_vma_name_put(anon_name);\n \t\t\tkfree(name);\n \t\t\tif (!anon_name)\n \t\t\t\treturn -ENOMEM;\n",
            "diff --git a/kernel/sys.c b/kernel/sys.c\nindex 5fd54bf0e886..e1fa04a805df 100644\n--- a/kernel/sys.c\n+++ b/kernel/sys.c\n@@ -2324,7 +2324,8 @@ static int prctl_set_vma(unsigned long opt, unsigned long addr,\n \t\t\tanon_name = anon_vma_name_alloc(name);\n \t\t\tkfree(name);\n \t\t\tif (!anon_name)\n-\t\t\t\treturn -ENOMEM;\n+\t\t\t\tanon_vma_name_put(anon_name);\n+                return -ENOMEM;\n \n \t\t}\n \n",
            "diff --git a/kernel/sys.c b/kernel/sys.c\nindex 5fd54bf0e886..e6adf66c31c8 100644\n--- a/kernel/sys.c\n+++ b/kernel/sys.c\n@@ -2331,6 +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+if (error)\n+anon_vma_name_put(anon_name);\n \t\tanon_vma_name_put(anon_name);\n \t\tbreak;\n \tdefault:\n"
        ],
        "error": []
    },
    "384b9a05e5d4c3e74e31427e43a08f40f71db54a": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/afs/super.c b/fs/afs/super.c\nindex 95d713074dc8..0e97fba6f997 100644\n--- a/fs/afs/super.c\n+++ b/fs/afs/super.c\n@@ -575,7 +575,7 @@ static int afs_get_tree(struct fs_context *fc)\n \n \t/* allocate a deviceless superblock */\n \tsb = sget_fc(fc,\n-\t\t     as->dyn_root ? afs_dynroot_test_super : afs_test_super,\n+\t\t     as && as->dyn_root ? afs_dynroot_test_super : afs_test_super,\n \t\t     afs_set_super);\n \tif (IS_ERR(sb)) {\n \t\tret = PTR_ERR(sb);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/afs/super.c b/fs/afs/super.c\nindex 95d713074dc8..9f19560730a0 100644\n--- a/fs/afs/super.c\n+++ b/fs/afs/super.c\n@@ -548,6 +548,7 @@ static void afs_kill_super(struct super_block *sb)\n \tif (as->volume)\n \t\tafs_deactivate_volume(as->volume);\n \tafs_destroy_sbi(as);\n+b->s_fs_info = NULL;\n }\n \n /*\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/afs/super.c b/fs/afs/super.c\nindex 95d713074dc8..f80506106651 100644\n--- a/fs/afs/super.c\n+++ b/fs/afs/super.c\n@@ -428,6 +428,9 @@ static int afs_test_super(struct super_block *sb, struct fs_context *fc)\n }\n \n static int afs_dynroot_test_super(struct super_block *sb, struct fs_context *fc)\n+{\n+if (!(sb->s_flags & SB_ACTIVE))\n+return 0; // Superblock is not active, prevent use-after-free\n {\n \tstruct afs_super_info *as = AFS_FS_S(sb);\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "17ba20e86ace8566cff1a3ace9042a779bd8bb7c": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/char/hw_random/core.c b/drivers/char/hw_random/core.c\nindex a3db27916256..92896323971f 100644\n--- a/drivers/char/hw_random/core.c\n+++ b/drivers/char/hw_random/core.c\n@@ -139,6 +139,8 @@ static void put_rng(struct hwrng *rng)\n \t * on rng again immediately.\n \t */\n \tmutex_lock(&rng_mutex);\n+\n+/* Minimize operations within the mutex lock */\n \tif (rng)\n \t\tkref_put(&rng->ref, cleanup_rng);\n \tmutex_unlock(&rng_mutex);\n@@ -471,6 +473,8 @@ int hwrng_register(struct hwrng *rng)\n \n \tmutex_lock(&rng_mutex);\n \n+/* Minimize operations within the mutex lock */\n+\n \t/* Must not register two RNGs with the same name. */\n \terr = -EEXIST;\n \tlist_for_each_entry(tmp, &rng_list, list) {\n@@ -533,6 +537,8 @@ void hwrng_unregister(struct hwrng *rng)\n \n \tmutex_lock(&rng_mutex);\n \n+/* Minimize operations within the mutex lock */\n+\n \told_rng = current_rng;\n \tlist_del(&rng->list);\n \tif (current_rng == rng) {\n@@ -630,6 +636,8 @@ static int __init hwrng_modinit(void)\n static void __exit hwrng_modexit(void)\n {\n \tmutex_lock(&rng_mutex);\n+\n+/* Minimize operations within the mutex lock */\n \tBUG_ON(current_rng);\n \tkfree(rng_buffer);\n \tkfree(rng_fillbuf);\n",
            "diff --git a/drivers/char/hw_random/core.c b/drivers/char/hw_random/core.c\nindex a3db27916256..dd5792c866e7 100644\n--- a/drivers/char/hw_random/core.c\n+++ b/drivers/char/hw_random/core.c\n@@ -138,7 +138,7 @@ static void put_rng(struct hwrng *rng)\n \t * Hold rng_mutex here so we serialize in case they set_current_rng\n \t * on rng again immediately.\n \t */\n-\tmutex_lock(&rng_mutex);\n+\tmutex_lock(&rng_mutex); // Optimize list operations and reduce mutex scope\n \tif (rng)\n \t\tkref_put(&rng->ref, cleanup_rng);\n \tmutex_unlock(&rng_mutex);\n@@ -469,7 +469,7 @@ int hwrng_register(struct hwrng *rng)\n \tif (!rng->name || (!rng->data_read && !rng->read))\n \t\tgoto out;\n \n-\tmutex_lock(&rng_mutex);\n+\tmutex_lock(&rng_mutex); // Optimize list operations and reduce mutex scope\n \n \t/* Must not register two RNGs with the same name. */\n \terr = -EEXIST;\n@@ -531,7 +531,7 @@ void hwrng_unregister(struct hwrng *rng)\n \tstruct hwrng *old_rng, *new_rng;\n \tint err;\n \n-\tmutex_lock(&rng_mutex);\n+\tmutex_lock(&rng_mutex); // Optimize list operations and reduce mutex scope\n \n \told_rng = current_rng;\n \tlist_del(&rng->list);\n@@ -629,7 +629,7 @@ static int __init hwrng_modinit(void)\n \n static void __exit hwrng_modexit(void)\n {\n-\tmutex_lock(&rng_mutex);\n+\tmutex_lock(&rng_mutex); // Optimize list operations and reduce mutex scope\n \tBUG_ON(current_rng);\n \tkfree(rng_buffer);\n \tkfree(rng_fillbuf);\n",
            "diff --git a/drivers/usb/misc/chaoskey.c b/drivers/usb/misc/chaoskey.c\nindex 87067c3d6109..01e28bbbaa91 100644\n--- a/drivers/usb/misc/chaoskey.c\n+++ b/drivers/usb/misc/chaoskey.c\n@@ -382,7 +382,7 @@ static int _chaoskey_fill(struct chaoskey *dev)\n \tresult = wait_event_interruptible_timeout(\n \t\tdev->wait_q,\n \t\t!dev->reading,\n-\t\t(started ? NAK_TIMEOUT : ALEA_FIRST_TIMEOUT) );\n+\t\t(NAK_TIMEOUT) );\n \n \tif (result < 0) {\n \t\tusb_kill_urb(dev->urb);\n",
            "diff --git a/drivers/char/hw_random/core.c b/drivers/char/hw_random/core.c\nindex a3db27916256..c177c1965dbb 100644\n--- a/drivers/char/hw_random/core.c\n+++ b/drivers/char/hw_random/core.c\n@@ -496,7 +496,13 @@ 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\terr = set_current_rng(rng);\n+\t\tmutex_unlock(&rng_mutex);\n+    err = hwrng_init(rng);\n+    if (err)\n+        return err;\n+    mutex_lock(&rng_mutex);\n+    drop_current_rng();\n+    current_rng = rng;\n \t\tif (err)\n \t\t\tgoto out_unlock;\n \t\t/* to use current_rng in add_early_randomness() we need\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/char/hw_random/core.c b/drivers/char/hw_random/core.c\nindex a3db27916256..4450f85c8d67 100644\n--- a/drivers/char/hw_random/core.c\n+++ b/drivers/char/hw_random/core.c\n@@ -138,7 +138,9 @@ static void put_rng(struct hwrng *rng)\n \t * Hold rng_mutex here so we serialize in case they set_current_rng\n \t * on rng again immediately.\n \t */\n-\tmutex_lock(&rng_mutex);\n+\tinit_completion(&rng->cleanup_done);\n+    complete(&rng->cleanup_done);\n+    mutex_lock(&rng_mutex); /* Acquire lock for critical section */ /* Acquire lock for critical section */\n \tif (rng)\n \t\tkref_put(&rng->ref, cleanup_rng);\n \tmutex_unlock(&rng_mutex);\n@@ -469,7 +471,9 @@ int hwrng_register(struct hwrng *rng)\n \tif (!rng->name || (!rng->data_read && !rng->read))\n \t\tgoto out;\n \n-\tmutex_lock(&rng_mutex);\n+\tinit_completion(&rng->cleanup_done);\n+    complete(&rng->cleanup_done);\n+    mutex_lock(&rng_mutex); /* Acquire lock for critical section */ /* Acquire lock for critical section */\n \n \t/* Must not register two RNGs with the same name. */\n \terr = -EEXIST;\n@@ -531,7 +535,9 @@ void hwrng_unregister(struct hwrng *rng)\n \tstruct hwrng *old_rng, *new_rng;\n \tint err;\n \n-\tmutex_lock(&rng_mutex);\n+\tinit_completion(&rng->cleanup_done);\n+    complete(&rng->cleanup_done);\n+    mutex_lock(&rng_mutex); /* Acquire lock for critical section */ /* Acquire lock for critical section */\n \n \told_rng = current_rng;\n \tlist_del(&rng->list);\n@@ -629,7 +635,9 @@ static int __init hwrng_modinit(void)\n \n static void __exit hwrng_modexit(void)\n {\n-\tmutex_lock(&rng_mutex);\n+\tinit_completion(&rng->cleanup_done);\n+    complete(&rng->cleanup_done);\n+    mutex_lock(&rng_mutex); /* Acquire lock for critical section */ /* Acquire lock for critical section */\n \tBUG_ON(current_rng);\n \tkfree(rng_buffer);\n \tkfree(rng_fillbuf);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "4a547542bb29dc957c096f0c95ef9154e93d68d3": {
        "non_crash": [
            "diff --git a/fs/ext4/indirect.c b/fs/ext4/indirect.c\nindex 07a8c75b65ed..8e3e3ac8a203 100644\n--- a/fs/ext4/indirect.c\n+++ b/fs/ext4/indirect.c\n@@ -1241,7 +1241,11 @@ 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+        ext4_warning(inode->i_sb, \"Invalid block range: start %lu, end %lu\",\n+                     start, end);\n+        return -EINVAL;\n+    }\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..1d875f543ff5 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+    ext4_warning(inode->i_sb, \"Invalid path length: %d > %d\", n, n2);\n+    return -EINVAL;\n+}\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..183fa0ab3f9d 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+        ext4_warning(inode->i_sb, \"Invalid path lengths: start %lu, end %lu\", start, end);\n+        return -EINVAL;\n+    }\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..6aef4fdfa94a 100644\n--- a/fs/ext4/indirect.c\n+++ b/fs/ext4/indirect.c\n@@ -1235,7 +1235,7 @@ 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 >= end) || (start > max_block) || (start < 0) || (end < 0))\n \t\treturn 0;\n \n \tn = ext4_block_to_path(inode, start, offsets, NULL);\n",
            "diff --git a/fs/ext4/indirect.c b/fs/ext4/indirect.c\nindex 07a8c75b65ed..71062af8d8f8 100644\n--- a/fs/ext4/indirect.c\n+++ b/fs/ext4/indirect.c\n@@ -1235,7 +1235,7 @@ 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 >= end) || (start > max_block) || (end > max_block))\n \t\treturn 0;\n \n \tn = ext4_block_to_path(inode, start, offsets, NULL);\n"
        ],
        "error": []
    },
    "ffb9228cab75ad9d812af93d19e9637873d18439": {
        "non_crash": [
            "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"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/ipv4/ip_gre.c b/net/ipv4/ip_gre.c\nindex 7e474a85deaf..d25650bd0d9a 100644\n--- a/net/ipv4/ip_gre.c\n+++ b/net/ipv4/ip_gre.c\n@@ -558,7 +558,8 @@ static void erspan_fb_xmit(struct sk_buff *skb, struct net_device *dev)\n \t    (ntohs(ip_hdr(skb)->tot_len) > skb->len - nhoff))\n \t\ttruncate = true;\n \n-\tthoff = skb_transport_header(skb) - skb_mac_header(skb);\n+\tskb_set_transport_header(skb, nhoff);\n+thoff = skb_transport_header(skb) - skb_mac_header(skb);\n \tif (skb->protocol == htons(ETH_P_IPV6) &&\n \t    (ntohs(ipv6_hdr(skb)->payload_len) > skb->len - thoff))\n \t\ttruncate = true;\n",
            "diff --git a/net/ipv4/ip_gre.c b/net/ipv4/ip_gre.c\nindex 7e474a85deaf..0f5583ff7df4 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 (unlikely(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..7ff63c70f703 100644\n--- a/net/ipv4/ip_gre.c\n+++ b/net/ipv4/ip_gre.c\n@@ -636,7 +636,10 @@ 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+            pr_warn(\"Transport header offset issue detected\\n\");\n+            goto free_skb;\n+        }\n \t\t\tgoto free_skb;\n \n \t\t/* Pull skb since ip_tunnel_xmit() needs skb->data pointing\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/ipv4/ip_gre.c b/net/ipv4/ip_gre.c\nindex 7e474a85deaf..a6517ec8b012 100644\n--- a/net/ipv4/ip_gre.c\n+++ b/net/ipv4/ip_gre.c\n@@ -636,7 +636,8 @@ 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\tskb_set_transport_header(skb, tunnel->hlen);\n+639:        if (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_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..3ba055dbc835 100644\n--- a/drivers/video/fbdev/core/sysfillrect.c\n+++ b/drivers/video/fbdev/core/sysfillrect.c\n@@ -26,6 +26,12 @@ bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\tunsigned long pat, unsigned n, int bits)\n {\n \tunsigned long first, last;\n+unsigned long max_n = p->fix.smem_len * 8; // Calculate the maximum allowable n based on framebuffer size // Calculate the maximum allowable n based on dst size\n+\n+if (n > max_n) {\n+printk(KERN_WARNING \"bitfill_aligned: n exceeds bounds, limiting to max_n\\n\");\n+n = max_n;\n+}\n \n \tif (!n)\n \t\treturn;\n@@ -82,6 +88,12 @@ bitfill_unaligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\t  unsigned long pat, int left, int right, unsigned n, int bits)\n {\n \tunsigned long first, last;\n+unsigned long max_n = p->fix.smem_len * 8; // Calculate the maximum allowable n based on framebuffer size // Calculate the maximum allowable n based on dst size\n+\n+if (n > max_n) {\n+printk(KERN_WARNING \"bitfill_aligned: n exceeds bounds, limiting to max_n\\n\");\n+n = max_n;\n+}\n \n \tif (!n)\n \t\treturn;\n@@ -137,6 +149,12 @@ bitfill_aligned_rev(struct fb_info *p, unsigned long *dst, int dst_idx,\n {\n \tunsigned long val = pat;\n \tunsigned long first, last;\n+unsigned long max_n = p->fix.smem_len * 8; // Calculate the maximum allowable n based on framebuffer size // Calculate the maximum allowable n based on dst size\n+\n+if (n > max_n) {\n+printk(KERN_WARNING \"bitfill_aligned: n exceeds bounds, limiting to max_n\\n\");\n+n = max_n;\n+}\n \n \tif (!n)\n \t\treturn;\n@@ -193,6 +211,12 @@ bitfill_unaligned_rev(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\t      int bits)\n {\n \tunsigned long first, last;\n+unsigned long max_n = p->fix.smem_len * 8; // Calculate the maximum allowable n based on framebuffer size // Calculate the maximum allowable n based on dst size\n+\n+if (n > max_n) {\n+printk(KERN_WARNING \"bitfill_aligned: n exceeds bounds, limiting to max_n\\n\");\n+n = max_n;\n+}\n \n \tif (!n)\n \t\treturn;\n",
            "diff --git a/drivers/video/fbdev/core/sysfillrect.c b/drivers/video/fbdev/core/sysfillrect.c\nindex 33ee3d34f9d2..84b8927e8f6e 100644\n--- a/drivers/video/fbdev/core/sysfillrect.c\n+++ b/drivers/video/fbdev/core/sysfillrect.c\n@@ -51,18 +51,18 @@ 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\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\tif (dst < p->screen_base + p->screen_size) *dst++ = pat;\n+\t\t\tif (dst < p->screen_base + p->screen_size) *dst++ = pat;\n+\t\t\tif (dst < p->screen_base + p->screen_size) *dst++ = pat;\n+\t\t\tif (dst < p->screen_base + p->screen_size) *dst++ = pat;\n+\t\t\tif (dst < p->screen_base + p->screen_size) *dst++ = pat;\n+\t\t\tif (dst < p->screen_base + p->screen_size) *dst++ = pat;\n+\t\t\tif (dst < p->screen_base + p->screen_size) *dst++ = pat;\n+\t\t\tif (dst < p->screen_base + p->screen_size) *dst++ = pat;\n \t\t\tn -= 8;\n \t\t}\n \t\twhile (n--)\n-\t\t\t*dst++ = pat;\n+\t\t\tif (dst < p->screen_base + p->screen_size) *dst++ = pat;\n \t\t/* Trailing bits */\n \t\tif (last)\n \t\t\t*dst = comp(pat, *dst, last);\n@@ -107,18 +107,18 @@ bitfill_unaligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\t/* Main chunk */\n \t\tn /= bits;\n \t\twhile (n >= 4) {\n-\t\t\t*dst++ = pat;\n+\t\t\tif (dst < p->screen_base + p->screen_size) *dst++ = pat;\n \t\t\tpat = pat << left | pat >> right;\n-\t\t\t*dst++ = pat;\n+\t\t\tif (dst < p->screen_base + p->screen_size) *dst++ = pat;\n \t\t\tpat = pat << left | pat >> right;\n-\t\t\t*dst++ = pat;\n+\t\t\tif (dst < p->screen_base + p->screen_size) *dst++ = pat;\n \t\t\tpat = pat << left | pat >> right;\n-\t\t\t*dst++ = pat;\n+\t\t\tif (dst < p->screen_base + p->screen_size) *dst++ = pat;\n \t\t\tpat = pat << left | pat >> right;\n \t\t\tn -= 4;\n \t\t}\n \t\twhile (n--) {\n-\t\t\t*dst++ = pat;\n+\t\t\tif (dst < p->screen_base + p->screen_size) *dst++ = pat;\n \t\t\tpat = pat << left | pat >> right;\n \t\t}\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/video/fbdev/core/sysfillrect.c b/drivers/video/fbdev/core/sysfillrect.c\nindex 33ee3d34f9d2..a930a78463da 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@@ -160,7 +160,7 @@ bitfill_aligned_rev(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++ ^= val;\n \t\t\t*dst++ ^= val;\n \t\t\t*dst++ ^= val;\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..5e81b8e5f8a7 100644\n--- a/drivers/video/fbdev/core/sysfillrect.c\n+++ b/drivers/video/fbdev/core/sysfillrect.c\n@@ -22,7 +22,7 @@\n      */\n \n static void\n-bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n+bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx, unsigned long dst_len,\n \t\tunsigned long pat, unsigned n, int bits)\n {\n \tunsigned long first, last;\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_start) + 8) <= dst_len) {\n \t\t\t*dst++ = pat;\n \t\t\t*dst++ = pat;\n \t\t\t*dst++ = pat;\n@@ -160,7 +160,7 @@ bitfill_aligned_rev(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_start) + 8) <= dst_len) {\n \t\t\t*dst++ ^= val;\n \t\t\t*dst++ ^= val;\n \t\t\t*dst++ ^= val;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "e9d3ca982b76224e183481018baa693a26655ac4": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex 1602d74b5eeb..72e99cecf700 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -341,7 +341,11 @@ 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+\tif (len < EXT4_MIN_INLINE_DATA_SIZE) {\n+    error = -EINVAL;\n+    goto out;\n+}\n+len -= EXT4_MIN_INLINE_DATA_SIZE;\n \tvalue = kzalloc(len, GFP_NOFS);\n \tif (!value) {\n \t\terror = -ENOMEM;\n",
            "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex 1602d74b5eeb..616838a38d06 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -341,7 +341,11 @@ 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+\tif (len <= EXT4_MIN_INLINE_DATA_SIZE) {\n+        error = -EINVAL;\n+        goto out;\n+    }\n+    len -= EXT4_MIN_INLINE_DATA_SIZE;\n \tvalue = kzalloc(len, GFP_NOFS);\n \tif (!value) {\n \t\terror = -ENOMEM;\n",
            "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex 1602d74b5eeb..09d962cf4a26 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -342,6 +342,10 @@ 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+if (len <= 0) {\n+    error = -EINVAL;\n+    goto out;\n+}\n \tvalue = kzalloc(len, GFP_NOFS);\n \tif (!value) {\n \t\terror = -ENOMEM;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex 1602d74b5eeb..9214c729d3a0 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -342,7 +342,8 @@ 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 = if (len > MAX_INLINE_DATA_SIZE) return -EINVAL;\n+    value = kzalloc(len, GFP_NOFS);\n \tif (!value) {\n \t\terror = -ENOMEM;\n \t\tgoto out;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex 1602d74b5eeb..6b2fc842bc51 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -342,7 +342,11 @@ 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+\tif (len > MAX_INLINE_DATA_SIZE) {\n+        error = -ENOMEM;\n+        goto out;\n+    }\n+    value = kzalloc(len, GFP_NOFS);\n \tif (!value) {\n \t\terror = -ENOMEM;\n \t\tgoto out;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "6c4345574ac937d9ccc195fdadb44f7cc95a19f9": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 2ee50e23c9b7..1cf3c8658738 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -925,7 +925,7 @@ static int nft_netlink_dump_start_rcu(struct sock *nlsk, struct sk_buff *skb,\n \tint err;\n \n \tif (!try_module_get(THIS_MODULE))\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \trcu_read_unlock();\n \terr = netlink_dump_start(nlsk, skb, nlh, c);\n@@ -2007,11 +2007,17 @@ static int nft_chain_parse_netdev(struct net *net,\n \t\t\treturn err;\n \n \t\tif (list_empty(hook_list))\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \t} else {\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \t}\n \n+err_cleanup:\n+list_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \treturn 0;\n }\n \n@@ -2036,7 +2042,7 @@ static int nft_chain_parse_hook(struct net *net,\n \n \tif (ha[NFTA_HOOK_HOOKNUM] == NULL ||\n \t    ha[NFTA_HOOK_PRIORITY] == NULL)\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \thook->num = ntohl(nla_get_be32(ha[NFTA_HOOK_HOOKNUM]));\n \thook->priority = ntohl(nla_get_be32(ha[NFTA_HOOK_PRIORITY]));\n@@ -2245,7 +2251,7 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n \t\t}\n \t} else {\n \t\tif (flags & NFT_CHAIN_BASE)\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \t\tif (flags & NFT_CHAIN_HW_OFFLOAD)\n \t\t\treturn -EOPNOTSUPP;\n \n@@ -2538,7 +2544,7 @@ static int nf_tables_newchain(struct sk_buff *skb, const struct nfnl_info *info,\n \t\t\tchain = NULL;\n \t\t}\n \t} else if (!nla[NFTA_CHAIN_ID]) {\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \t}\n \n \tif (nla[NFTA_CHAIN_POLICY]) {\n@@ -2560,7 +2566,7 @@ static int nf_tables_newchain(struct sk_buff *skb, const struct nfnl_info *info,\n \t\tcase NF_ACCEPT:\n \t\t\tbreak;\n \t\tdefault:\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \t\t}\n \t}\n \n@@ -2576,7 +2582,7 @@ static int nf_tables_newchain(struct sk_buff *skb, const struct nfnl_info *info,\n \n \tif (chain != NULL) {\n \t\tif (chain->flags & NFT_CHAIN_BINDING)\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \n \t\tif (info->nlh->nlmsg_flags & NLM_F_EXCL) {\n \t\t\tNL_SET_BAD_ATTR(extack, attr);\n@@ -3431,7 +3437,7 @@ static int nf_tables_newrule(struct sk_buff *skb, const struct nfnl_info *info,\n \t\t\treturn PTR_ERR(chain);\n \t\t}\n \t} else {\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \t}\n \n \tif (nla[NFTA_RULE_HANDLE]) {\n@@ -3453,7 +3459,7 @@ static int nf_tables_newrule(struct sk_buff *skb, const struct nfnl_info *info,\n \t} else {\n \t\tif (!(info->nlh->nlmsg_flags & NLM_F_CREATE) ||\n \t\t    info->nlh->nlmsg_flags & NLM_F_REPLACE)\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \t\thandle = nf_tables_alloc_handle(table);\n \n \t\tif (chain->use == UINT_MAX)\n@@ -3902,7 +3908,7 @@ static int nf_tables_set_alloc_name(struct nft_ctx *ctx, struct nft_set *set,\n \tp = strchr(name, '%');\n \tif (p != NULL) {\n \t\tif (p[1] != 'd' || strchr(p + 2, '%'))\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \n \t\tinuse = (unsigned long *)get_zeroed_page(GFP_KERNEL);\n \t\tif (inuse == NULL)\n@@ -4243,7 +4249,7 @@ static int nf_tables_getset(struct sk_buff *skb, const struct nfnl_info *info,\n \tif (info->nfmsg->nfgen_family == NFPROTO_UNSPEC)\n \t\treturn -EAFNOSUPPORT;\n \tif (!nla[NFTA_SET_TABLE])\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \tset = nft_set_lookup(table, nla[NFTA_SET_NAME], genmask);\n \tif (IS_ERR(set))\n@@ -4284,11 +4290,11 @@ static int nft_set_desc_concat_parse(const struct nlattr *attr,\n \t\treturn err;\n \n \tif (!tb[NFTA_SET_FIELD_LEN])\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \tlen = ntohl(nla_get_be32(tb[NFTA_SET_FIELD_LEN]));\n \tif (!len || len > U8_MAX)\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \tdesc->field_len[desc->field_count++] = len;\n \n@@ -4304,7 +4310,7 @@ static int nft_set_desc_concat(struct nft_set_desc *desc,\n \n \tnla_for_each_nested(attr, nla, rem) {\n \t\tif (nla_type(attr) != NFTA_LIST_ELEM)\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \n \t\terr = nft_set_desc_concat_parse(attr, desc);\n \t\tif (err < 0)\n@@ -4365,7 +4371,7 @@ static int nf_tables_newset(struct sk_buff *skb, const struct nfnl_info *info,\n \t    nla[NFTA_SET_NAME] == NULL ||\n \t    nla[NFTA_SET_KEY_LEN] == NULL ||\n \t    nla[NFTA_SET_ID] == NULL)\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \tmemset(&desc, 0, sizeof(desc));\n \n@@ -4373,12 +4379,12 @@ static int nf_tables_newset(struct sk_buff *skb, const struct nfnl_info *info,\n \tif (nla[NFTA_SET_KEY_TYPE] != NULL) {\n \t\tktype = ntohl(nla_get_be32(nla[NFTA_SET_KEY_TYPE]));\n \t\tif ((ktype & NFT_DATA_RESERVED_MASK) == NFT_DATA_RESERVED_MASK)\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \t}\n \n \tdesc.klen = ntohl(nla_get_be32(nla[NFTA_SET_KEY_LEN]));\n \tif (desc.klen == 0 || desc.klen > NFT_DATA_VALUE_MAXLEN)\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \tflags = 0;\n \tif (nla[NFTA_SET_FLAGS] != NULL) {\n@@ -4400,41 +4406,41 @@ static int nf_tables_newset(struct sk_buff *skb, const struct nfnl_info *info,\n \tdtype = 0;\n \tif (nla[NFTA_SET_DATA_TYPE] != NULL) {\n \t\tif (!(flags & NFT_SET_MAP))\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \n \t\tdtype = ntohl(nla_get_be32(nla[NFTA_SET_DATA_TYPE]));\n \t\tif ((dtype & NFT_DATA_RESERVED_MASK) == NFT_DATA_RESERVED_MASK &&\n \t\t    dtype != NFT_DATA_VERDICT)\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \n \t\tif (dtype != NFT_DATA_VERDICT) {\n \t\t\tif (nla[NFTA_SET_DATA_LEN] == NULL)\n-\t\t\t\treturn -EINVAL;\n+\t\t\t\tgoto err_cleanup;\n \t\t\tdesc.dlen = ntohl(nla_get_be32(nla[NFTA_SET_DATA_LEN]));\n \t\t\tif (desc.dlen == 0 || desc.dlen > NFT_DATA_VALUE_MAXLEN)\n-\t\t\t\treturn -EINVAL;\n+\t\t\t\tgoto err_cleanup;\n \t\t} else\n \t\t\tdesc.dlen = sizeof(struct nft_verdict);\n \t} else if (flags & NFT_SET_MAP)\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \tif (nla[NFTA_SET_OBJ_TYPE] != NULL) {\n \t\tif (!(flags & NFT_SET_OBJECT))\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \n \t\tobjtype = ntohl(nla_get_be32(nla[NFTA_SET_OBJ_TYPE]));\n \t\tif (objtype == NFT_OBJECT_UNSPEC ||\n \t\t    objtype > NFT_OBJECT_MAX)\n \t\t\treturn -EOPNOTSUPP;\n \t} else if (flags & NFT_SET_OBJECT)\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \telse\n \t\tobjtype = NFT_OBJECT_UNSPEC;\n \n \ttimeout = 0;\n \tif (nla[NFTA_SET_TIMEOUT] != NULL) {\n \t\tif (!(flags & NFT_SET_TIMEOUT))\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \n \t\terr = nf_msecs_to_jiffies64(nla[NFTA_SET_TIMEOUT], &timeout);\n \t\tif (err)\n@@ -4443,7 +4449,7 @@ static int nf_tables_newset(struct sk_buff *skb, const struct nfnl_info *info,\n \tgc_int = 0;\n \tif (nla[NFTA_SET_GC_INTERVAL] != NULL) {\n \t\tif (!(flags & NFT_SET_TIMEOUT))\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \t\tgc_int = ntohl(nla_get_be32(nla[NFTA_SET_GC_INTERVAL]));\n \t}\n \n@@ -4457,9 +4463,9 @@ static int nf_tables_newset(struct sk_buff *skb, const struct nfnl_info *info,\n \t\t\treturn err;\n \n \t\tif (desc.field_count > 1 && !(flags & NFT_SET_CONCAT))\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \t} else if (flags & NFT_SET_CONCAT) {\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \t}\n \n \tif (nla[NFTA_SET_EXPR] || nla[NFTA_SET_EXPRESSIONS])\n@@ -5206,10 +5212,10 @@ static int nft_setelem_parse_flags(const struct nft_set *set,\n \t\treturn -EOPNOTSUPP;\n \tif (!(set->flags & NFT_SET_INTERVAL) &&\n \t    *flags & NFT_SET_ELEM_INTERVAL_END)\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \tif ((*flags & (NFT_SET_ELEM_INTERVAL_END | NFT_SET_ELEM_CATCHALL)) ==\n \t    (NFT_SET_ELEM_INTERVAL_END | NFT_SET_ELEM_CATCHALL))\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \treturn 0;\n }\n@@ -5305,7 +5311,7 @@ static int nft_get_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \t\treturn err;\n \n \tif (!nla[NFTA_SET_ELEM_KEY] && !(flags & NFT_SET_ELEM_CATCHALL))\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \tif (nla[NFTA_SET_ELEM_KEY]) {\n \t\terr = nft_setelem_parse_key(ctx, set, &elem.key.val,\n@@ -5387,7 +5393,7 @@ static int nf_tables_getsetelem(struct sk_buff *skb,\n \t}\n \n \tif (!nla[NFTA_SET_ELEM_LIST_ELEMENTS])\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \tnla_for_each_nested(attr, nla[NFTA_SET_ELEM_LIST_ELEMENTS], rem) {\n \t\terr = nft_get_set_elem(&ctx, set, attr);\n@@ -5646,7 +5652,7 @@ static int nft_set_elem_expr_setup(struct nft_ctx *ctx,\n \t\tlen += expr_array[i]->ops->size;\n \n \tif (nft_set_ext_check(tmpl, NFT_SET_EXT_EXPRESSIONS, len) < 0)\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \tfor (i = 0; i < num_exprs; i++) {\n \t\texpr = nft_setelem_expr_at(elem_expr, elem_expr->size);\n@@ -5907,7 +5913,7 @@ static int nft_add_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \t\treturn err;\n \n \tif (!nla[NFTA_SET_ELEM_KEY] && !(flags & NFT_SET_ELEM_CATCHALL))\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \tif (flags != 0) {\n \t\terr = nft_set_ext_add(&tmpl, NFT_SET_EXT_FLAGS);\n@@ -5918,23 +5924,23 @@ static int nft_add_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \tif (set->flags & NFT_SET_MAP) {\n \t\tif (nla[NFTA_SET_ELEM_DATA] == NULL &&\n \t\t    !(flags & NFT_SET_ELEM_INTERVAL_END))\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \t} else {\n \t\tif (nla[NFTA_SET_ELEM_DATA] != NULL)\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \t}\n \n \tif (set->flags & NFT_SET_OBJECT) {\n \t\tif (!nla[NFTA_SET_ELEM_OBJREF] &&\n \t\t    !(flags & NFT_SET_ELEM_INTERVAL_END))\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \t} else {\n \t\tif (nla[NFTA_SET_ELEM_OBJREF])\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \t}\n \n \tif (!nft_setelem_valid_key_end(set, nla, flags))\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \tif ((flags & NFT_SET_ELEM_INTERVAL_END) &&\n \t     (nla[NFTA_SET_ELEM_DATA] ||\n@@ -5945,12 +5951,12 @@ static int nft_add_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \t      nla[NFTA_SET_ELEM_EXPR] ||\n \t      nla[NFTA_SET_ELEM_KEY_END] ||\n \t      nla[NFTA_SET_ELEM_EXPRESSIONS]))\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \ttimeout = 0;\n \tif (nla[NFTA_SET_ELEM_TIMEOUT] != NULL) {\n \t\tif (!(set->flags & NFT_SET_TIMEOUT))\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \t\terr = nf_msecs_to_jiffies64(nla[NFTA_SET_ELEM_TIMEOUT],\n \t\t\t\t\t    &timeout);\n \t\tif (err)\n@@ -5962,7 +5968,7 @@ static int nft_add_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \texpiration = 0;\n \tif (nla[NFTA_SET_ELEM_EXPIRATION] != NULL) {\n \t\tif (!(set->flags & NFT_SET_TIMEOUT))\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \t\terr = nf_msecs_to_jiffies64(nla[NFTA_SET_ELEM_EXPIRATION],\n \t\t\t\t\t    &expiration);\n \t\tif (err)\n@@ -6250,7 +6256,7 @@ static int nf_tables_newsetelem(struct sk_buff *skb,\n \tint rem, err;\n \n \tif (nla[NFTA_SET_ELEM_LIST_ELEMENTS] == NULL)\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \ttable = nft_table_lookup(net, nla[NFTA_SET_ELEM_LIST_TABLE], family,\n \t\t\t\t genmask, NETLINK_CB(skb).portid);\n@@ -6364,10 +6370,10 @@ static int nft_del_setelem(struct nft_ctx *ctx, struct nft_set *set,\n \t\treturn err;\n \n \tif (!nla[NFTA_SET_ELEM_KEY] && !(flags & NFT_SET_ELEM_CATCHALL))\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \tif (!nft_setelem_valid_key_end(set, nla, flags))\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \tnft_set_ext_prepare(&tmpl);\n \n@@ -6603,7 +6609,7 @@ struct nft_set_gc_batch *nft_set_gc_batch_alloc(const struct nft_set *set,\n int nft_register_obj(struct nft_object_type *obj_type)\n {\n \tif (obj_type->type == NFT_OBJECT_UNSPEC)\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \tnfnl_lock(NFNL_SUBSYS_NFTABLES);\n \tlist_add_rcu(&obj_type->list, &nf_tables_objects);\n@@ -6841,7 +6847,7 @@ static int nf_tables_newobj(struct sk_buff *skb, const struct nfnl_info *info,\n \tif (!nla[NFTA_OBJ_TYPE] ||\n \t    !nla[NFTA_OBJ_NAME] ||\n \t    !nla[NFTA_OBJ_DATA])\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \ttable = nft_table_lookup(net, nla[NFTA_OBJ_TABLE], family, genmask,\n \t\t\t\t NETLINK_CB(skb).portid);\n@@ -7107,7 +7113,7 @@ static int nf_tables_getobj(struct sk_buff *skb, const struct nfnl_info *info,\n \n \tif (!nla[NFTA_OBJ_NAME] ||\n \t    !nla[NFTA_OBJ_TYPE])\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \ttable = nft_table_lookup(net, nla[NFTA_OBJ_TABLE], family, genmask, 0);\n \tif (IS_ERR(table)) {\n@@ -7183,7 +7189,7 @@ static int nf_tables_delobj(struct sk_buff *skb, const struct nfnl_info *info,\n \n \tif (!nla[NFTA_OBJ_TYPE] ||\n \t    (!nla[NFTA_OBJ_NAME] && !nla[NFTA_OBJ_HANDLE]))\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \ttable = nft_table_lookup(net, nla[NFTA_OBJ_TABLE], family, genmask,\n \t\t\t\t NETLINK_CB(skb).portid);\n@@ -7369,7 +7375,7 @@ static int nft_flowtable_parse_hook(const struct nft_ctx *ctx,\n \tif (add) {\n \t\tif (!tb[NFTA_FLOWTABLE_HOOK_NUM] ||\n \t\t    !tb[NFTA_FLOWTABLE_HOOK_PRIORITY])\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \n \t\thooknum = ntohl(nla_get_be32(tb[NFTA_FLOWTABLE_HOOK_NUM]));\n \t\tif (hooknum != NF_NETDEV_INGRESS)\n@@ -7633,7 +7639,7 @@ static int nf_tables_newflowtable(struct sk_buff *skb,\n \tif (!nla[NFTA_FLOWTABLE_TABLE] ||\n \t    !nla[NFTA_FLOWTABLE_NAME] ||\n \t    !nla[NFTA_FLOWTABLE_HOOK])\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \ttable = nft_table_lookup(net, nla[NFTA_FLOWTABLE_TABLE], family,\n \t\t\t\t genmask, NETLINK_CB(skb).portid);\n@@ -7814,7 +7820,7 @@ static int nf_tables_delflowtable(struct sk_buff *skb,\n \tif (!nla[NFTA_FLOWTABLE_TABLE] ||\n \t    (!nla[NFTA_FLOWTABLE_NAME] &&\n \t     !nla[NFTA_FLOWTABLE_HANDLE]))\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \ttable = nft_table_lookup(net, nla[NFTA_FLOWTABLE_TABLE], family,\n \t\t\t\t genmask, NETLINK_CB(skb).portid);\n@@ -8017,7 +8023,7 @@ static int nf_tables_getflowtable(struct sk_buff *skb,\n \t}\n \n \tif (!nla[NFTA_FLOWTABLE_NAME])\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \ttable = nft_table_lookup(net, nla[NFTA_FLOWTABLE_TABLE], family,\n \t\t\t\t genmask, 0);\n@@ -9568,9 +9574,9 @@ EXPORT_SYMBOL_GPL(nft_dump_register);\n static int nft_validate_register_load(enum nft_registers reg, unsigned int len)\n {\n \tif (reg < NFT_REG_1 * NFT_REG_SIZE / NFT_REG32_SIZE)\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \tif (len == 0)\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \tif (reg * NFT_REG32_SIZE + len > sizeof_field(struct nft_regs, data))\n \t\treturn -ERANGE;\n \n@@ -9606,7 +9612,7 @@ static int nft_validate_register_store(const struct nft_ctx *ctx,\n \tswitch (reg) {\n \tcase NFT_REG_VERDICT:\n \t\tif (type != NFT_DATA_VERDICT)\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \n \t\tif (data != NULL &&\n \t\t    (data->verdict.code == NFT_GOTO ||\n@@ -9619,15 +9625,15 @@ static int nft_validate_register_store(const struct nft_ctx *ctx,\n \t\treturn 0;\n \tdefault:\n \t\tif (reg < NFT_REG_1 * NFT_REG_SIZE / NFT_REG32_SIZE)\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \t\tif (len == 0)\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \t\tif (reg * NFT_REG32_SIZE + len >\n \t\t    sizeof_field(struct nft_regs, data))\n \t\t\treturn -ERANGE;\n \n \t\tif (data != NULL && type != NFT_DATA_VALUE)\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \t\treturn 0;\n \t}\n }\n@@ -9674,7 +9680,7 @@ static int nft_verdict_init(const struct nft_ctx *ctx, struct nft_data *data,\n \t\treturn err;\n \n \tif (!tb[NFTA_VERDICT_CODE])\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \tdata->verdict.code = ntohl(nla_get_be32(tb[NFTA_VERDICT_CODE]));\n \n \tswitch (data->verdict.code) {\n@@ -9685,7 +9691,7 @@ static int nft_verdict_init(const struct nft_ctx *ctx, struct nft_data *data,\n \t\tcase NF_QUEUE:\n \t\t\tbreak;\n \t\tdefault:\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \t\t}\n \t\tfallthrough;\n \tcase NFT_CONTINUE:\n@@ -9704,7 +9710,7 @@ static int nft_verdict_init(const struct nft_ctx *ctx, struct nft_data *data,\n \t\t\tif (IS_ERR(chain))\n \t\t\t\treturn PTR_ERR(chain);\n \t\t} else {\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \t\t}\n \n \t\tif (IS_ERR(chain))\n@@ -9712,10 +9718,10 @@ static int nft_verdict_init(const struct nft_ctx *ctx, struct nft_data *data,\n \t\tif (nft_is_base_chain(chain))\n \t\t\treturn -EOPNOTSUPP;\n \t\tif (nft_chain_is_bound(chain))\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \t\tif (desc->flags & NFT_DATA_DESC_SETELEM &&\n \t\t    chain->flags & NFT_CHAIN_BINDING)\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \n \t\tchain->use++;\n \t\tdata->verdict.chain = chain;\n@@ -9783,12 +9789,12 @@ static int nft_value_init(const struct nft_ctx *ctx,\n \n \tlen = nla_len(nla);\n \tif (len == 0)\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \tif (len > desc->size)\n \t\treturn -EOVERFLOW;\n \tif (desc->len) {\n \t\tif (len != desc->len)\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \t} else {\n \t\tdesc->len = len;\n \t}\n@@ -9830,7 +9836,7 @@ int nft_data_init(const struct nft_ctx *ctx, struct nft_data *data,\n \tint err;\n \n \tif (WARN_ON_ONCE(!desc->size))\n-\t\treturn -EINVAL;\n+\t\tgoto err_cleanup;\n \n \terr = nla_parse_nested_deprecated(tb, NFTA_DATA_MAX, nla,\n \t\t\t\t\t  nft_data_policy, NULL);\n@@ -9839,12 +9845,12 @@ int nft_data_init(const struct nft_ctx *ctx, struct nft_data *data,\n \n \tif (tb[NFTA_DATA_VALUE]) {\n \t\tif (desc->type != NFT_DATA_VALUE)\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \n \t\terr = nft_value_init(ctx, data, desc, tb[NFTA_DATA_VALUE]);\n \t} else if (tb[NFTA_DATA_VERDICT] && ctx != NULL) {\n \t\tif (desc->type != NFT_DATA_VERDICT)\n-\t\t\treturn -EINVAL;\n+\t\t\tgoto err_cleanup;\n \n \t\terr = nft_verdict_init(ctx, data, desc, tb[NFTA_DATA_VERDICT]);\n \t} else {\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..cc774bfbceaa 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -2073,10 +2073,12 @@ static int nft_chain_parse_hook(struct net *net,\n \t\terr = nft_chain_parse_netdev(net, ha, &hook->list);\n \t\tif (err < 0) {\n \t\t\tmodule_put(type->owner);\n+        nft_chain_release_hook(hook);\n \t\t\treturn err;\n \t\t}\n \t} else if (ha[NFTA_HOOK_DEV] || ha[NFTA_HOOK_DEVS]) {\n \t\tmodule_put(type->owner);\n+        nft_chain_release_hook(hook);\n \t\treturn -EOPNOTSUPP;\n \t}\n \n@@ -2852,6 +2854,7 @@ static int nf_tables_expr_parse(const struct nft_ctx *ctx,\n \n err1:\n \tmodule_put(type->owner);\n+        nft_chain_release_hook(hook);\n \treturn err;\n }\n \n@@ -2883,6 +2886,7 @@ static void nf_tables_expr_destroy(const struct nft_ctx *ctx,\n \tif (expr->ops->destroy)\n \t\texpr->ops->destroy(ctx, expr);\n \tmodule_put(type->owner);\n+        nft_chain_release_hook(hook);\n }\n \n static struct nft_expr *nft_expr_init(const struct nft_ctx *ctx,\n@@ -6821,6 +6825,7 @@ static int nf_tables_updobj(const struct nft_ctx *ctx,\n \tkfree(trans);\n err_trans:\n \tmodule_put(type->owner);\n+        nft_chain_release_hook(hook);\n \treturn err;\n }\n \n@@ -6926,6 +6931,7 @@ static int nf_tables_newobj(struct sk_buff *skb, const struct nfnl_info *info,\n \tkfree(obj);\n err_init:\n \tmodule_put(type->owner);\n+        nft_chain_release_hook(hook);\n \treturn err;\n }\n \n@@ -7733,6 +7739,7 @@ static int nf_tables_newflowtable(struct sk_buff *skb,\n \tflowtable->data.type->free(&flowtable->data);\n err3:\n \tmodule_put(type->owner);\n+        nft_chain_release_hook(hook);\n err2:\n \tkfree(flowtable->name);\n err1:\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "0be1740a2972a1852f35a3ed7dc70577610edcbd": {
        "non_crash": [
            "diff --git a/sound/core/seq/seq_ports.c b/sound/core/seq/seq_ports.c\nindex 9b80f8275026..707e5b30f2a3 100644\n--- a/sound/core/seq/seq_ports.c\n+++ b/sound/core/seq/seq_ports.c\n@@ -164,6 +164,10 @@ int snd_seq_create_port(struct snd_seq_client *client, int port,\n \tsprintf(new_port->name, \"port-%d\", num);\n \t*port_ret = new_port;\n  unlock:\n+    if (num < 0 && new_port) {\n+        kfree(new_port);\n+        *port_ret = NULL;\n+    }\n \twrite_unlock_irq(&client->ports_lock);\n \tmutex_unlock(&client->ports_mutex);\n \n",
            "diff --git a/sound/core/seq/seq_ports.c b/sound/core/seq/seq_ports.c\nindex 9b80f8275026..7baeea5b84f8 100644\n--- a/sound/core/seq/seq_ports.c\n+++ b/sound/core/seq/seq_ports.c\n@@ -150,7 +150,9 @@ 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\tkfree(new_port);\n+num = -EBUSY;\n+goto unlock;\n \t\t}\n \t\tif (p->addr.port > num)\n \t\t\tbreak;\n",
            "diff --git a/sound/core/seq/seq_ports.c b/sound/core/seq/seq_ports.c\nindex 9b80f8275026..3a49ef41c2fd 100644\n--- a/sound/core/seq/seq_ports.c\n+++ b/sound/core/seq/seq_ports.c\n@@ -149,7 +149,8 @@ int snd_seq_create_port(struct snd_seq_client *client, int port,\n \twrite_lock_irq(&client->ports_lock);\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+num = -EBUSY;\n \t\t\tgoto unlock;\n \t\t}\n \t\tif (p->addr.port > num)\n",
            "diff --git a/sound/core/seq/seq_ports.c b/sound/core/seq/seq_ports.c\nindex 9b80f8275026..9a8c481e1a6e 100644\n--- a/sound/core/seq/seq_ports.c\n+++ b/sound/core/seq/seq_ports.c\n@@ -149,7 +149,8 @@ int snd_seq_create_port(struct snd_seq_client *client, int port,\n \twrite_lock_irq(&client->ports_lock);\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+            num = -EBUSY;\n \t\t\tgoto unlock;\n \t\t}\n \t\tif (p->addr.port > num)\n",
            "diff --git a/sound/core/seq/seq_ports.c b/sound/core/seq/seq_ports.c\nindex 9b80f8275026..3a49ef41c2fd 100644\n--- a/sound/core/seq/seq_ports.c\n+++ b/sound/core/seq/seq_ports.c\n@@ -149,7 +149,8 @@ int snd_seq_create_port(struct snd_seq_client *client, int port,\n \twrite_lock_irq(&client->ports_lock);\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+num = -EBUSY;\n \t\t\tgoto unlock;\n \t\t}\n \t\tif (p->addr.port > num)\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "5091eca677b6821339a9491de5b4151c5be85ae7": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/ipv6/mcast.c b/net/ipv6/mcast.c\nindex 87c699d57b36..c1d30f939474 100644\n--- a/net/ipv6/mcast.c\n+++ b/net/ipv6/mcast.c\n@@ -1907,6 +1907,10 @@ static struct sk_buff *add_grec(struct sk_buff *skb, struct ifmcaddr6 *pmc,\n \t\t\tif (skb)\n \t\t\t\tmld_sendpack(skb);\n \t\t\tskb = mld_newpack(idev, mtu);\n+if (!skb) {\n+    kfree_skb(skb);\n+    return NULL;\n+}\n \t\t}\n \t}\n \tfirst = 1;\n@@ -1945,6 +1949,10 @@ static struct sk_buff *add_grec(struct sk_buff *skb, struct ifmcaddr6 *pmc,\n \t\t\tif (skb)\n \t\t\t\tmld_sendpack(skb);\n \t\t\tskb = mld_newpack(idev, mtu);\n+if (!skb) {\n+    kfree_skb(skb);\n+    return NULL;\n+}\n \t\t\tfirst = 1;\n \t\t\tscount = 0;\n \t\t}\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/ipv6/mcast.c b/net/ipv6/mcast.c\nindex 87c699d57b36..82252bd0a78b 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-\t\treturn NULL;\n+\tif (!skb) {\n+    kfree_skb(skb);\n+    return NULL;\n+}\t\treturn NULL;\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\t\treturn NULL;\n+\t\tif (!skb) {\n+    kfree_skb(skb);\n+    return NULL;\n+}\t\t\treturn NULL;\n \t}\n \tpgr = skb_put(skb, sizeof(struct mld2_grec));\n \tpgr->grec_type = type;\n@@ -1952,8 +1956,10 @@ static struct sk_buff *add_grec(struct sk_buff *skb, struct ifmcaddr6 *pmc,\n \t\t\tskb = add_grhead(skb, pmc, type, &pgr, mtu);\n \t\t\tfirst = 0;\n \t\t}\n-\t\tif (!skb)\n-\t\t\treturn NULL;\n+\t\tif (!skb) {\n+    kfree_skb(skb);\n+    return NULL;\n+}\t\t\treturn NULL;\n \t\tpsrc = skb_put(skb, sizeof(*psrc));\n \t\t*psrc = psf->sf_addr;\n \t\tscount++; stotal++;\n@@ -2116,8 +2122,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-\t\treturn;\n+\tif (!skb) {\n+    kfree_skb(skb);\n+    return NULL;\n+}\t\treturn;\n \t(void) mld_sendpack(skb);\n }\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/ipv6/mcast.c b/net/ipv6/mcast.c\nindex 87c699d57b36..9dd8cff6d410 100644\n--- a/net/ipv6/mcast.c\n+++ b/net/ipv6/mcast.c\n@@ -306,12 +306,15 @@ static struct inet6_dev *ip6_mc_find_dev_rtnl(struct net *net,\n \t}\n \n \tif (!dev)\n-\t\treturn NULL;\n+\t\tkfree_skb(skb);\n+        return NULL;\n \tidev = __in6_dev_get(dev);\n \tif (!idev)\n-\t\treturn NULL;\n+\t\tkfree_skb(skb);\n+        return NULL;\n \tif (idev->dead)\n-\t\treturn NULL;\n+\t\tkfree_skb(skb);\n+        return NULL;\n \treturn idev;\n }\n \n@@ -879,7 +882,8 @@ static struct ifmcaddr6 *mca_alloc(struct inet6_dev *idev,\n \n \tmc = kzalloc(sizeof(*mc), GFP_KERNEL);\n \tif (!mc)\n-\t\treturn NULL;\n+\t\tkfree_skb(skb);\n+        return NULL;\n \n \tINIT_DELAYED_WORK(&mc->mca_work, mld_mca_work);\n \n@@ -1747,7 +1751,8 @@ static struct sk_buff *mld_newpack(struct inet6_dev *idev, unsigned int mtu)\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-\t\treturn NULL;\n+\t\tkfree_skb(skb);\n+        return NULL;\n \n \tskb->priority = TC_PRIO_CONTROL;\n \tskb_reserve(skb, hlen);\n@@ -1850,7 +1855,8 @@ static struct sk_buff *add_grhead(struct sk_buff *skb, struct ifmcaddr6 *pmc,\n \tif (!skb) {\n \t\tskb = mld_newpack(pmc->idev, mtu);\n \t\tif (!skb)\n-\t\t\treturn NULL;\n+\t\t\tkfree_skb(skb);\n+        return NULL;\n \t}\n \tpgr = skb_put(skb, sizeof(struct mld2_grec));\n \tpgr->grec_type = type;\n@@ -1953,7 +1959,8 @@ static struct sk_buff *add_grec(struct sk_buff *skb, struct ifmcaddr6 *pmc,\n \t\t\tfirst = 0;\n \t\t}\n \t\tif (!skb)\n-\t\t\treturn NULL;\n+\t\t\tkfree_skb(skb);\n+        return NULL;\n \t\tpsrc = skb_put(skb, sizeof(*psrc));\n \t\t*psrc = psf->sf_addr;\n \t\tscount++; stotal++;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/ipv6/mcast.c b/net/ipv6/mcast.c\nindex 87c699d57b36..92fa63a43609 100644\n--- a/net/ipv6/mcast.c\n+++ b/net/ipv6/mcast.c\n@@ -1905,6 +1905,9 @@ static struct sk_buff *add_grec(struct sk_buff *skb, struct ifmcaddr6 *pmc,\n \t\tif (pmr && pmr->mld2r_ngrec &&\n \t\t    AVAILABLE(skb) < grec_size(pmc, type, gdeleted, sdeleted)) {\n \t\t\tif (skb)\n+mld_sendpack(skb);\n+if (!skb)\n+return NULL;\n \t\t\t\tmld_sendpack(skb);\n \t\t\tskb = mld_newpack(idev, mtu);\n \t\t}\n@@ -1943,6 +1946,9 @@ static struct sk_buff *add_grec(struct sk_buff *skb, struct ifmcaddr6 *pmc,\n \t\t\tif (pgr)\n \t\t\t\tpgr->grec_nsrcs = htons(scount);\n \t\t\tif (skb)\n+mld_sendpack(skb);\n+if (!skb)\n+return NULL;\n \t\t\t\tmld_sendpack(skb);\n \t\t\tskb = mld_newpack(idev, mtu);\n \t\t\tfirst = 1;\n@@ -2021,6 +2027,9 @@ static void mld_send_report(struct inet6_dev *idev, struct ifmcaddr6 *pmc)\n \t\tskb = add_grec(skb, pmc, type, 0, 0, 0);\n \t}\n \tif (skb)\n+mld_sendpack(skb);\n+if (!skb)\n+return NULL;\n \t\tmld_sendpack(skb);\n }\n \n@@ -2236,6 +2245,9 @@ static void mld_send_initial_cr(struct inet6_dev *idev)\n \t\tskb = add_grec(skb, pmc, type, 0, 0, 1);\n \t}\n \tif (skb)\n+mld_sendpack(skb);\n+if (!skb)\n+return NULL;\n \t\tmld_sendpack(skb);\n }\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "d905b9cf668a6fd23e8268008fff061b302d6fb5": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex afe2b64b14f1..6592d42d05ef 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -633,12 +633,14 @@ int __legitimize_mnt(struct vfsmount *bastard, unsigned seq)\n \tif (likely(!read_seqretry(&mount_lock, seq)))\n \t\treturn 0;\n \tif (bastard->mnt_flags & MNT_SYNC_UMOUNT) {\n-\t\tmnt_add_count(mnt, -1);\n+\t\tif (mnt_get_count(mnt) > 0)\n+mnt_add_count(mnt, -1);\n \t\treturn 1;\n \t}\n \tlock_mount_hash();\n \tif (unlikely(bastard->mnt_flags & MNT_DOOMED)) {\n-\t\tmnt_add_count(mnt, -1);\n+\t\tif (mnt_get_count(mnt) > 0)\n+mnt_add_count(mnt, -1);\n \t\tunlock_mount_hash();\n \t\treturn 1;\n \t}\n@@ -1220,7 +1222,8 @@ static void mntput_no_expire(struct mount *mnt)\n \t\t * non-NULL under rcu_read_lock(), the reference\n \t\t * we are dropping is not the final one.\n \t\t */\n-\t\tmnt_add_count(mnt, -1);\n+\t\tif (mnt_get_count(mnt) > 0)\n+mnt_add_count(mnt, -1);\n \t\trcu_read_unlock();\n \t\treturn;\n \t}\n@@ -1230,7 +1233,8 @@ 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+\tif (mnt_get_count(mnt) > 0)\n+mnt_add_count(mnt, -1);\n \tcount = mnt_get_count(mnt);\n \tif (count != 0) {\n \t\tWARN_ON(count < 0);\n",
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex afe2b64b14f1..33348929764b 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -633,12 +633,12 @@ int __legitimize_mnt(struct vfsmount *bastard, unsigned seq)\n \tif (likely(!read_seqretry(&mount_lock, seq)))\n \t\treturn 0;\n \tif (bastard->mnt_flags & MNT_SYNC_UMOUNT) {\n-\t\tmnt_add_count(mnt, -1);\n+\t\tif (mnt_get_count(mnt) > 0) mnt_add_count(mnt, -1);\n \t\treturn 1;\n \t}\n \tlock_mount_hash();\n \tif (unlikely(bastard->mnt_flags & MNT_DOOMED)) {\n-\t\tmnt_add_count(mnt, -1);\n+\t\tif (mnt_get_count(mnt) > 0) mnt_add_count(mnt, -1);\n \t\tunlock_mount_hash();\n \t\treturn 1;\n \t}\n@@ -1220,7 +1220,7 @@ static void mntput_no_expire(struct mount *mnt)\n \t\t * non-NULL under rcu_read_lock(), the reference\n \t\t * we are dropping is not the final one.\n \t\t */\n-\t\tmnt_add_count(mnt, -1);\n+\t\tif (mnt_get_count(mnt) > 0) mnt_add_count(mnt, -1);\n \t\trcu_read_unlock();\n \t\treturn;\n \t}\n@@ -1230,7 +1230,7 @@ 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+\tif (mnt_get_count(mnt) > 0) mnt_add_count(mnt, -1);\n \tcount = mnt_get_count(mnt);\n \tif (count != 0) {\n \t\tWARN_ON(count < 0);\n",
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex afe2b64b14f1..9f4432c7f41e 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -633,12 +633,16 @@ int __legitimize_mnt(struct vfsmount *bastard, unsigned seq)\n \tif (likely(!read_seqretry(&mount_lock, seq)))\n \t\treturn 0;\n \tif (bastard->mnt_flags & MNT_SYNC_UMOUNT) {\n-\t\tmnt_add_count(mnt, -1);\n+\t\tif (mnt_get_count(mnt) > 0) {\n+        mnt_add_count(mnt, -1);\n+    }\n \t\treturn 1;\n \t}\n \tlock_mount_hash();\n \tif (unlikely(bastard->mnt_flags & MNT_DOOMED)) {\n-\t\tmnt_add_count(mnt, -1);\n+\t\tif (mnt_get_count(mnt) > 0) {\n+        mnt_add_count(mnt, -1);\n+    }\n \t\tunlock_mount_hash();\n \t\treturn 1;\n \t}\n@@ -1220,7 +1224,9 @@ static void mntput_no_expire(struct mount *mnt)\n \t\t * non-NULL under rcu_read_lock(), the reference\n \t\t * we are dropping is not the final one.\n \t\t */\n-\t\tmnt_add_count(mnt, -1);\n+\t\tif (mnt_get_count(mnt) > 0) {\n+        mnt_add_count(mnt, -1);\n+    }\n \t\trcu_read_unlock();\n \t\treturn;\n \t}\n@@ -1230,7 +1236,9 @@ 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+\tif (mnt_get_count(mnt) > 0) {\n+        mnt_add_count(mnt, -1);\n+    }\n \tcount = mnt_get_count(mnt);\n \tif (count != 0) {\n \t\tWARN_ON(count < 0);\n",
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex afe2b64b14f1..33348929764b 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -633,12 +633,12 @@ int __legitimize_mnt(struct vfsmount *bastard, unsigned seq)\n \tif (likely(!read_seqretry(&mount_lock, seq)))\n \t\treturn 0;\n \tif (bastard->mnt_flags & MNT_SYNC_UMOUNT) {\n-\t\tmnt_add_count(mnt, -1);\n+\t\tif (mnt_get_count(mnt) > 0) mnt_add_count(mnt, -1);\n \t\treturn 1;\n \t}\n \tlock_mount_hash();\n \tif (unlikely(bastard->mnt_flags & MNT_DOOMED)) {\n-\t\tmnt_add_count(mnt, -1);\n+\t\tif (mnt_get_count(mnt) > 0) mnt_add_count(mnt, -1);\n \t\tunlock_mount_hash();\n \t\treturn 1;\n \t}\n@@ -1220,7 +1220,7 @@ static void mntput_no_expire(struct mount *mnt)\n \t\t * non-NULL under rcu_read_lock(), the reference\n \t\t * we are dropping is not the final one.\n \t\t */\n-\t\tmnt_add_count(mnt, -1);\n+\t\tif (mnt_get_count(mnt) > 0) mnt_add_count(mnt, -1);\n \t\trcu_read_unlock();\n \t\treturn;\n \t}\n@@ -1230,7 +1230,7 @@ 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+\tif (mnt_get_count(mnt) > 0) mnt_add_count(mnt, -1);\n \tcount = mnt_get_count(mnt);\n \tif (count != 0) {\n \t\tWARN_ON(count < 0);\n"
        ],
        "error": []
    },
    "f55849742bdcdf58f6eaae61e747ac00e5c061f4": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/mprotect.c b/mm/mprotect.c\nindex 461dcbd4f21a..db7bd2349315 100644\n--- a/mm/mprotect.c\n+++ b/mm/mprotect.c\n@@ -275,7 +275,7 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\t * exist.  Doing that by install a marker.\n \t\t\t\t */\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\t\t   make_pte_marker(PTE_MARKER_UFFD_WP) /* Ensure valid conditions for marker creation */);\n \t\t\t\tpages++;\n \t\t\t}\n \t\t}\n"
        ],
        "error": [
            {
                "patch": "diff --git a/mm/mprotect.c b/mm/mprotect.c\nindex 461dcbd4f21a..b398357c1dac 100644\n--- a/mm/mprotect.c\n+++ b/mm/mprotect.c\n@@ -240,7 +240,9 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\t\tnewpte = pte_swp_mksoft_dirty(newpte);\n \t\t\t\tif (pte_swp_uffd_wp(oldpte))\n \t\t\t\t\tnewpte = pte_swp_mkuffd_wp(newpte);\n-\t\t\t} else if (pte_marker_entry_uffd_wp(entry)) {\n+\t\t\t} else if (#ifdef CONFIG_PTE_MARKER\n+            pte_marker_entry_uffd_wp(entry)\n+#endif) {\n \t\t\t\t/*\n \t\t\t\t * If this is uffd-wp pte marker and we'd like\n \t\t\t\t * to unprotect it, drop it; the next page\n@@ -275,7 +277,9 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\t * exist.  Doing that by install a marker.\n \t\t\t\t */\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\t\t   #ifdef CONFIG_PTE_MARKER\n+            make_pte_marker(PTE_MARKER_UFFD_WP)\n+#endif);\n \t\t\t\tpages++;\n \t\t\t}\n \t\t}\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/mm/mprotect.c b/mm/mprotect.c\nindex 461dcbd4f21a..31e217691dcd 100644\n--- a/mm/mprotect.c\n+++ b/mm/mprotect.c\n@@ -267,7 +267,8 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t} else {\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+\t\t\t#ifdef CONFIG_PTE_MARKER\n+if (unlikely(uffd_wp && !vma_is_anonymous(vma))) {\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",
                "error_message": "Failed to build"
            }
        ]
    },
    "36a409539269df8733aaba8c3b36cf2fc7091cf7": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/sched/cls_tcindex.c b/net/sched/cls_tcindex.c\nindex eb0e9458e722..7b9b5518b0e5 100644\n--- a/net/sched/cls_tcindex.c\n+++ b/net/sched/cls_tcindex.c\n@@ -516,6 +516,7 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \treturn 0;\n \n errout_alloc:\n+if (cp) kfree(cp);\n \tif (balloc == 1)\n \t\ttcindex_free_perfect_hash(cp);\n \telse if (balloc == 2)\n",
            "diff --git a/net/sched/cls_tcindex.c b/net/sched/cls_tcindex.c\nindex eb0e9458e722..d8bbb0d4e9f7 100644\n--- a/net/sched/cls_tcindex.c\n+++ b/net/sched/cls_tcindex.c\n@@ -317,6 +317,7 @@ static int tcindex_alloc_perfect_hash(struct net *net, struct tcindex_data *cp)\n \t\t\t\t    TCA_TCINDEX_ACT, TCA_TCINDEX_POLICE);\n \t\tif (err < 0)\n \t\t\tgoto errout;\n+kfree(cp);\n \t\tcp->perfect[i].p = cp;\n \t}\n \n@@ -346,6 +347,7 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \terr = tcf_exts_validate(net, tp, tb, est, &e, flags, extack);\n \tif (err < 0)\n \t\tgoto errout;\n+kfree(cp);\n \n \terr = -ENOMEM;\n \t/* tcindex_data attributes must look atomic to classifier/lookup so\n@@ -355,6 +357,7 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \tcp = kzalloc(sizeof(*cp), GFP_KERNEL);\n \tif (!cp)\n \t\tgoto errout;\n+kfree(cp);\n \n \tcp->mask = p->mask;\n \tcp->shift = p->shift;\n@@ -375,6 +378,7 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \t\tif (cp->shift > 16) {\n \t\t\terr = -EINVAL;\n \t\t\tgoto errout;\n+kfree(cp);\n \t\t}\n \t}\n \tif (!cp->hash) {\n@@ -392,6 +396,7 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \n \t\tif (tcindex_alloc_perfect_hash(net, cp) < 0)\n \t\t\tgoto errout;\n+kfree(cp);\n \t\tcp->alloc_hash = cp->hash;\n \t\tfor (i = 0; i < min(cp->hash, p->hash); i++)\n \t\t\tcp->perfect[i].res = p->perfect[i].res;\n",
            "diff --git a/net/sched/cls_tcindex.c b/net/sched/cls_tcindex.c\nindex eb0e9458e722..94f6ec402e15 100644\n--- a/net/sched/cls_tcindex.c\n+++ b/net/sched/cls_tcindex.c\n@@ -516,6 +516,8 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \treturn 0;\n \n errout_alloc:\n+    if (f)\n+        kfree(f);\n \tif (balloc == 1)\n \t\ttcindex_free_perfect_hash(cp);\n \telse if (balloc == 2)\n",
            "diff --git a/net/sched/cls_tcindex.c b/net/sched/cls_tcindex.c\nindex eb0e9458e722..540fc841aa97 100644\n--- a/net/sched/cls_tcindex.c\n+++ b/net/sched/cls_tcindex.c\n@@ -323,6 +323,7 @@ static int tcindex_alloc_perfect_hash(struct net *net, struct tcindex_data *cp)\n \treturn 0;\n \n errout:\n+    kfree(cp);\n \ttcindex_free_perfect_hash(cp);\n \treturn err;\n }\n@@ -522,6 +523,7 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \t\tkfree(cp->h);\n \ttcf_exts_destroy(&new_filter_result.exts);\n errout:\n+    kfree(cp);\n \tkfree(cp);\n \ttcf_exts_destroy(&e);\n \treturn err;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/sched/cls_tcindex.c b/net/sched/cls_tcindex.c\nindex eb0e9458e722..503146be74ad 100644\n--- a/net/sched/cls_tcindex.c\n+++ b/net/sched/cls_tcindex.c\n@@ -401,7 +401,8 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \n \terr = tcindex_filter_result_init(&new_filter_result, cp, net);\n \tif (err < 0)\n-\t\tgoto errout_alloc;\n+\t\tkfree(cp);\n+goto errout_alloc;\n \tif (old_r)\n \t\tcr = r->res;\n \n@@ -413,9 +414,11 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \tif (cp->perfect) {\n \t\tif (!valid_perfect_hash(cp) ||\n \t\t    cp->hash > cp->alloc_hash)\n-\t\t\tgoto errout_alloc;\n+\t\t\tkfree(cp);\n+goto errout_alloc;\n \t} else if (cp->h && cp->hash != cp->alloc_hash) {\n-\t\tgoto errout_alloc;\n+\t\tkfree(cp);\n+goto errout_alloc;\n \t}\n \n \terr = -EINVAL;\n@@ -432,14 +435,16 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \t */\n \tif (cp->perfect || valid_perfect_hash(cp))\n \t\tif (handle >= cp->alloc_hash)\n-\t\t\tgoto errout_alloc;\n+\t\t\tkfree(cp);\n+goto errout_alloc;\n \n \n \terr = -ENOMEM;\n \tif (!cp->perfect && !cp->h) {\n \t\tif (valid_perfect_hash(cp)) {\n \t\t\tif (tcindex_alloc_perfect_hash(net, cp) < 0)\n-\t\t\t\tgoto errout_alloc;\n+\t\t\t\tkfree(cp);\n+goto errout_alloc;\n \t\t\tballoc = 1;\n \t\t} else {\n \t\t\tstruct tcindex_filter __rcu **hash;\n@@ -449,7 +454,8 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \t\t\t\t       GFP_KERNEL);\n \n \t\t\tif (!hash)\n-\t\t\t\tgoto errout_alloc;\n+\t\t\t\tkfree(cp);\n+goto errout_alloc;\n \n \t\t\tcp->h = hash;\n \t\t\tballoc = 2;\n@@ -464,13 +470,15 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \tif (r == &new_filter_result) {\n \t\tf = kzalloc(sizeof(*f), GFP_KERNEL);\n \t\tif (!f)\n-\t\t\tgoto errout_alloc;\n+\t\t\tkfree(cp);\n+goto errout_alloc;\n \t\tf->key = handle;\n \t\tf->next = NULL;\n \t\terr = tcindex_filter_result_init(&f->result, cp, net);\n \t\tif (err < 0) {\n \t\t\tkfree(f);\n-\t\t\tgoto errout_alloc;\n+\t\t\tkfree(cp);\n+goto errout_alloc;\n \t\t}\n \t}\n \n@@ -483,7 +491,8 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \t\terr = tcindex_filter_result_init(old_r, cp, net);\n \t\tif (err < 0) {\n \t\t\tkfree(f);\n-\t\t\tgoto errout_alloc;\n+\t\t\tkfree(cp);\n+goto errout_alloc;\n \t\t}\n \t}\n \n@@ -551,7 +560,7 @@ tcindex_change(struct net *net, struct sk_buff *in_skb,\n \tif (err < 0)\n \t\treturn err;\n \n-\treturn tcindex_set_parms(net, tp, base, handle, p, r, tb,\n+\terr = tcindex_set_parms(net, tp, base, handle, p, r, tb,\n \t\t\t\t tca[TCA_RATE], flags, extack);\n }\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "6bb7224cd01f8742533b486573005f65d512fdf6": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/sctp/stream_sched_prio.c b/net/sctp/stream_sched_prio.c\nindex 80b5a2c4cbc7..ec72c793fda1 100644\n--- a/net/sctp/stream_sched_prio.c\n+++ b/net/sctp/stream_sched_prio.c\n@@ -166,7 +166,7 @@ static int sctp_sched_prio_set(struct sctp_stream *stream, __u16 sid,\n \tif (reschedule)\n \t\tsctp_sched_prio_sched(stream, soute);\n \n-\tif (!old)\n+\tif (!old || list_empty(&old->prio_sched))\n \t\t/* Happens when we set the priority for the first time */\n \t\treturn 0;\n \n",
            "diff --git a/net/sctp/stream_sched_prio.c b/net/sctp/stream_sched_prio.c\nindex 80b5a2c4cbc7..747dd3fdcd11 100644\n--- a/net/sctp/stream_sched_prio.c\n+++ b/net/sctp/stream_sched_prio.c\n@@ -178,7 +178,10 @@ 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+        printk(KERN_DEBUG \"Freeing old priority head\\n\");\n+    }\n+    kfree(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..58af494cd557 100644\n--- a/net/sctp/stream_sched_prio.c\n+++ b/net/sctp/stream_sched_prio.c\n@@ -172,7 +172,7 @@ 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 && !list_empty(&soute->prio_list))\n \t\t\t/* It's still in use, nothing else to do here. */\n \t\t\treturn 0;\n \t}\n",
            "diff --git a/net/sctp/stream_sched_prio.c b/net/sctp/stream_sched_prio.c\nindex 80b5a2c4cbc7..72d2300c938c 100644\n--- a/net/sctp/stream_sched_prio.c\n+++ b/net/sctp/stream_sched_prio.c\n@@ -173,6 +173,7 @@ static int sctp_sched_prio_set(struct sctp_stream *stream, __u16 sid,\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+            continue;\n \t\t\t/* It's still in use, nothing else to do here. */\n \t\t\treturn 0;\n \t}\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/sctp/stream_sched_prio.c b/net/sctp/stream_sched_prio.c\nindex 80b5a2c4cbc7..9a57cedc5e2b 100644\n--- a/net/sctp/stream_sched_prio.c\n+++ b/net/sctp/stream_sched_prio.c\n@@ -173,6 +173,8 @@ static int sctp_sched_prio_set(struct sctp_stream *stream, __u16 sid,\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+            return 0;\n+    }\n \t\t\t/* It's still in use, nothing else to do here. */\n \t\t\treturn 0;\n \t}\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "943853d124b5c70143eb385e993d35cb42a883c7": {
        "non_crash": [
            "diff --git a/net/qrtr/af_qrtr.c b/net/qrtr/af_qrtr.c\nindex 5c2fb992803b..431af7786a28 100644\n--- a/net/qrtr/af_qrtr.c\n+++ b/net/qrtr/af_qrtr.c\n@@ -1001,6 +1001,7 @@ static int qrtr_send_resume_tx(struct qrtr_cb *cb)\n \tint ret;\n \n \tnode = qrtr_node_lookup(remote.sq_node);\n+    node = qrtr_node_acquire(node);\n \tif (!node)\n \t\treturn -EINVAL;\n \n",
            "diff --git a/net/qrtr/af_qrtr.c b/net/qrtr/af_qrtr.c\nindex 5c2fb992803b..6fa523f3d052 100644\n--- a/net/qrtr/af_qrtr.c\n+++ b/net/qrtr/af_qrtr.c\n@@ -1001,6 +1001,7 @@ static int qrtr_send_resume_tx(struct qrtr_cb *cb)\n \tint ret;\n \n \tnode = qrtr_node_lookup(remote.sq_node);\n+    qrtr_node_acquire(node);\n \tif (!node)\n \t\treturn -EINVAL;\n \n",
            "diff --git a/net/qrtr/af_qrtr.c b/net/qrtr/af_qrtr.c\nindex 5c2fb992803b..e3a92c4c4e8e 100644\n--- a/net/qrtr/af_qrtr.c\n+++ b/net/qrtr/af_qrtr.c\n@@ -1066,7 +1066,15 @@ static int qrtr_recvmsg(struct socket *sock, struct msghdr *msg,\n \t}\n \n out:\n-\tif (cb->confirm_rx)\n+\tif (cb->confirm_rx) {\n+        struct qrtr_node *node = qrtr_node_lookup(cb->dst_node);\n+        if (!node) {\n+            rc = -EINVAL;\n+            goto out;\n+        }\n+        qrtr_send_resume_tx(cb);\n+        qrtr_node_release(node);\n+    }\n \t\tqrtr_send_resume_tx(cb);\n \n \tskb_free_datagram(sk, skb);\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/qrtr/af_qrtr.c b/net/qrtr/af_qrtr.c\nindex 5c2fb992803b..4fb1ea874d1f 100644\n--- a/net/qrtr/af_qrtr.c\n+++ b/net/qrtr/af_qrtr.c\n@@ -198,7 +198,7 @@ static void __qrtr_node_release(struct kref *kref)\n /* Increment reference to node. */\n static struct qrtr_node *qrtr_node_acquire(struct qrtr_node *node)\n {\n-\tif (node)\n+\tif (node && kref_read(&node->ref) > 0)\n \t\tkref_get(&node->ref);\n \treturn node;\n }\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/qrtr/af_qrtr.c b/net/qrtr/af_qrtr.c\nindex 5c2fb992803b..76c270e61588 100644\n--- a/net/qrtr/af_qrtr.c\n+++ b/net/qrtr/af_qrtr.c\n@@ -206,7 +206,7 @@ static struct qrtr_node *qrtr_node_acquire(struct qrtr_node *node)\n /* Decrement reference to node and release as necessary. */\n static void qrtr_node_release(struct qrtr_node *node)\n {\n-\tif (!node)\n+\tif (!node || !refcount_read(&node->refcount))\n \t\treturn;\n \tkref_put_mutex(&node->ref, __qrtr_node_release, &qrtr_node_lock);\n }\n@@ -581,7 +581,7 @@ int qrtr_endpoint_register(struct qrtr_endpoint *ep, unsigned int nid)\n \t\treturn -EINVAL;\n \n \tnode = kzalloc(sizeof(*node), GFP_KERNEL);\n-\tif (!node)\n+\tif (!node || !refcount_read(&node->refcount))\n \t\treturn -ENOMEM;\n \n \tkref_init(&node->ref);\n@@ -945,7 +945,7 @@ static int qrtr_sendmsg(struct socket *sock, struct msghdr *msg, size_t len)\n \t\tenqueue_fn = qrtr_local_enqueue;\n \t} else {\n \t\tnode = qrtr_node_lookup(addr->sq_node);\n-\t\tif (!node) {\n+\t\tif (!node || !refcount_read(&node->refcount)) {\n \t\t\trelease_sock(sk);\n \t\t\treturn -ECONNRESET;\n \t\t}\n@@ -1001,7 +1001,7 @@ static int qrtr_send_resume_tx(struct qrtr_cb *cb)\n \tint ret;\n \n \tnode = qrtr_node_lookup(remote.sq_node);\n-\tif (!node)\n+\tif (!node || !refcount_read(&node->refcount))\n \t\treturn -EINVAL;\n \n \tskb = qrtr_alloc_ctrl_packet(&pkt, GFP_KERNEL);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "993d8b5e64393ed9e6a70f9ae4de0119c605a822": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/vhost/vhost.c b/drivers/vhost/vhost.c\nindex 59edb5a1ffe2..b1070eda45dc 100644\n--- a/drivers/vhost/vhost.c\n+++ b/drivers/vhost/vhost.c\n@@ -2329,6 +2329,7 @@ int vhost_get_vq_desc(struct vhost_virtqueue *vq,\n \n \t/* On success, increment avail index. */\n \tvq->last_avail_idx++;\n+vhost_disable_notify(vq->dev, 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",
            "diff --git a/drivers/vhost/vsock.c b/drivers/vhost/vsock.c\nindex d6ca1c7ad513..664d20f140ac 100644\n--- a/drivers/vhost/vsock.c\n+++ b/drivers/vhost/vsock.c\n@@ -525,7 +525,7 @@ static void vhost_vsock_handle_tx_kick(struct vhost_work *work)\n \t\t\tbreak;\n \n \t\tif (head == vq->num) {\n-\t\t\tif (unlikely(vhost_enable_notify(&vsock->dev, vq))) {\n+\t\t\tif (unlikely(head == vq->num && vhost_enable_notify(&vsock->dev, vq))) {\n \t\t\t\tvhost_disable_notify(&vsock->dev, vq);\n \t\t\t\tcontinue;\n \t\t\t}\n",
            "diff --git a/drivers/vhost/vsock.c b/drivers/vhost/vsock.c\nindex d6ca1c7ad513..cde5673f6a28 100644\n--- a/drivers/vhost/vsock.c\n+++ b/drivers/vhost/vsock.c\n@@ -106,6 +106,7 @@ vhost_transport_do_send_pkt(struct vhost_vsock *vsock,\n \n \t/* Avoid further vmexits, we're already processing the virtqueue */\n \tvhost_disable_notify(&vsock->dev, vq);\n+    BUG_ON(!(vq->used_flags & VRING_USED_F_NO_NOTIFY));\n \n \tdo {\n \t\tstruct virtio_vsock_pkt *pkt;\n@@ -147,6 +148,7 @@ vhost_transport_do_send_pkt(struct vhost_vsock *vsock,\n \t\t\t */\n \t\t\tif (unlikely(vhost_enable_notify(&vsock->dev, vq))) {\n \t\t\t\tvhost_disable_notify(&vsock->dev, vq);\n+    BUG_ON(!(vq->used_flags & VRING_USED_F_NO_NOTIFY));\n \t\t\t\tcontinue;\n \t\t\t}\n \t\t\tbreak;\n@@ -510,6 +512,7 @@ static void vhost_vsock_handle_tx_kick(struct vhost_work *work)\n \t\tgoto out;\n \n \tvhost_disable_notify(&vsock->dev, vq);\n+    BUG_ON(!(vq->used_flags & VRING_USED_F_NO_NOTIFY));\n \tdo {\n \t\tif (!vhost_vsock_more_replies(vsock)) {\n \t\t\t/* Stop tx until the device processes already\n@@ -527,6 +530,7 @@ static void vhost_vsock_handle_tx_kick(struct vhost_work *work)\n \t\tif (head == vq->num) {\n \t\t\tif (unlikely(vhost_enable_notify(&vsock->dev, vq))) {\n \t\t\t\tvhost_disable_notify(&vsock->dev, vq);\n+    BUG_ON(!(vq->used_flags & VRING_USED_F_NO_NOTIFY));\n \t\t\t\tcontinue;\n \t\t\t}\n \t\t\tbreak;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/vhost/vsock.c b/drivers/vhost/vsock.c\nindex d6ca1c7ad513..60fe63c1a504 100644\n--- a/drivers/vhost/vsock.c\n+++ b/drivers/vhost/vsock.c\n@@ -119,7 +119,7 @@ vhost_transport_do_send_pkt(struct vhost_vsock *vsock,\n \t\tspin_lock_bh(&vsock->send_pkt_list_lock);\n \t\tif (list_empty(&vsock->send_pkt_list)) {\n \t\t\tspin_unlock_bh(&vsock->send_pkt_list_lock);\n-\t\t\tvhost_enable_notify(&vsock->dev, vq);\n+\t\t\tif (!(vq->used_flags & VRING_USED_F_NO_NOTIFY)) vhost_enable_notify(&vsock->dev, vq);\n \t\t\tbreak;\n \t\t}\n \n@@ -145,7 +145,7 @@ vhost_transport_do_send_pkt(struct vhost_vsock *vsock,\n \t\t\t/* We cannot finish yet if more buffers snuck in while\n \t\t\t * re-enabling notify.\n \t\t\t */\n-\t\t\tif (unlikely(vhost_enable_notify(&vsock->dev, vq))) {\n+\t\t\tif (unlikely(if (!(vq->used_flags & VRING_USED_F_NO_NOTIFY)) vhost_enable_notify(&vsock->dev, vq))) {\n \t\t\t\tvhost_disable_notify(&vsock->dev, vq);\n \t\t\t\tcontinue;\n \t\t\t}\n@@ -525,7 +525,7 @@ static void vhost_vsock_handle_tx_kick(struct vhost_work *work)\n \t\t\tbreak;\n \n \t\tif (head == vq->num) {\n-\t\t\tif (unlikely(vhost_enable_notify(&vsock->dev, vq))) {\n+\t\t\tif (unlikely(if (!(vq->used_flags & VRING_USED_F_NO_NOTIFY)) vhost_enable_notify(&vsock->dev, vq))) {\n \t\t\t\tvhost_disable_notify(&vsock->dev, vq);\n \t\t\t\tcontinue;\n \t\t\t}\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..f034e46e5caa 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+pr_err(\"Failed to allocate extent state\\n\");\n+goto out;\n+}\n \t\terr = split_state(tree, state, prealloc, start);\n \t\tif (err)\n \t\t\textent_io_tree_panic(tree, err);\n@@ -657,7 +660,10 @@ 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+pr_err(\"Failed to allocate extent state\\n\");\n+goto out;\n+}\n \t\terr = split_state(tree, state, prealloc, end + 1);\n \t\tif (err)\n \t\t\textent_io_tree_panic(tree, err);\n@@ -1012,7 +1018,10 @@ static int __set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \tstate = tree_search_for_insert(tree, start, &p, &parent);\n \tif (!state) {\n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+pr_err(\"Failed to allocate extent state\\n\");\n+goto out;\n+}\n \t\tprealloc->start = start;\n \t\tprealloc->end = end;\n \t\tinsert_state_fast(tree, prealloc, p, parent, bits, changeset);\n@@ -1085,7 +1094,10 @@ static int __set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \t\t}\n \n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+pr_err(\"Failed to allocate extent state\\n\");\n+goto out;\n+}\n \t\terr = split_state(tree, state, prealloc, start);\n \t\tif (err)\n \t\t\textent_io_tree_panic(tree, err);\n@@ -1122,7 +1134,10 @@ static int __set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \t\t\tthis_end = last_start - 1;\n \n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+pr_err(\"Failed to allocate extent state\\n\");\n+goto out;\n+}\n \n \t\t/*\n \t\t * Avoid to free 'prealloc' if it can be merged with the later\n@@ -1154,7 +1169,10 @@ static int __set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \t\t}\n \n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+pr_err(\"Failed to allocate extent state\\n\");\n+goto out;\n+}\n \t\terr = split_state(tree, state, prealloc, end + 1);\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..80c46e1f0189 100644\n--- a/fs/btrfs/extent-io-tree.c\n+++ b/fs/btrfs/extent-io-tree.c\n@@ -636,7 +636,11 @@ 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+            printk(KERN_ERR \"Failed to allocate extent state\\n\");\n+            err = -ENOMEM;\n+            goto out;\n+        }\n \t\terr = split_state(tree, state, prealloc, start);\n \t\tif (err)\n \t\t\textent_io_tree_panic(tree, err);\n@@ -657,7 +661,11 @@ 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+            printk(KERN_ERR \"Failed to allocate extent state\\n\");\n+            err = -ENOMEM;\n+            goto out;\n+        }\n \t\terr = split_state(tree, state, prealloc, end + 1);\n \t\tif (err)\n \t\t\textent_io_tree_panic(tree, err);\n@@ -1012,7 +1020,11 @@ static int __set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \tstate = tree_search_for_insert(tree, start, &p, &parent);\n \tif (!state) {\n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+            printk(KERN_ERR \"Failed to allocate extent state\\n\");\n+            err = -ENOMEM;\n+            goto out;\n+        }\n \t\tprealloc->start = start;\n \t\tprealloc->end = end;\n \t\tinsert_state_fast(tree, prealloc, p, parent, bits, changeset);\n@@ -1085,7 +1097,11 @@ static int __set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \t\t}\n \n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+            printk(KERN_ERR \"Failed to allocate extent state\\n\");\n+            err = -ENOMEM;\n+            goto out;\n+        }\n \t\terr = split_state(tree, state, prealloc, start);\n \t\tif (err)\n \t\t\textent_io_tree_panic(tree, err);\n@@ -1122,7 +1138,11 @@ static int __set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \t\t\tthis_end = last_start - 1;\n \n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+            printk(KERN_ERR \"Failed to allocate extent state\\n\");\n+            err = -ENOMEM;\n+            goto out;\n+        }\n \n \t\t/*\n \t\t * Avoid to free 'prealloc' if it can be merged with the later\n@@ -1154,7 +1174,11 @@ static int __set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \t\t}\n \n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+            printk(KERN_ERR \"Failed to allocate extent state\\n\");\n+            err = -ENOMEM;\n+            goto out;\n+        }\n \t\terr = split_state(tree, state, prealloc, end + 1);\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..6dfab3f2e06c 100644\n--- a/fs/btrfs/extent-io-tree.c\n+++ b/fs/btrfs/extent-io-tree.c\n@@ -636,7 +636,11 @@ 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+            printk(KERN_ERR \"Failed to allocate extent_state\\n\");\n+            err = -ENOMEM;\n+            goto out;\n+        }\n \t\terr = split_state(tree, state, prealloc, start);\n \t\tif (err)\n \t\t\textent_io_tree_panic(tree, err);\n@@ -657,7 +661,11 @@ 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+            printk(KERN_ERR \"Failed to allocate extent_state\\n\");\n+            err = -ENOMEM;\n+            goto out;\n+        }\n \t\terr = split_state(tree, state, prealloc, end + 1);\n \t\tif (err)\n \t\t\textent_io_tree_panic(tree, err);\n@@ -1012,7 +1020,11 @@ static int __set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \tstate = tree_search_for_insert(tree, start, &p, &parent);\n \tif (!state) {\n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+            printk(KERN_ERR \"Failed to allocate extent_state\\n\");\n+            err = -ENOMEM;\n+            goto out;\n+        }\n \t\tprealloc->start = start;\n \t\tprealloc->end = end;\n \t\tinsert_state_fast(tree, prealloc, p, parent, bits, changeset);\n@@ -1085,7 +1097,11 @@ static int __set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \t\t}\n \n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+            printk(KERN_ERR \"Failed to allocate extent_state\\n\");\n+            err = -ENOMEM;\n+            goto out;\n+        }\n \t\terr = split_state(tree, state, prealloc, start);\n \t\tif (err)\n \t\t\textent_io_tree_panic(tree, err);\n@@ -1122,7 +1138,11 @@ static int __set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \t\t\tthis_end = last_start - 1;\n \n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+            printk(KERN_ERR \"Failed to allocate extent_state\\n\");\n+            err = -ENOMEM;\n+            goto out;\n+        }\n \n \t\t/*\n \t\t * Avoid to free 'prealloc' if it can be merged with the later\n@@ -1154,7 +1174,11 @@ static int __set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \t\t}\n \n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+            printk(KERN_ERR \"Failed to allocate extent_state\\n\");\n+            err = -ENOMEM;\n+            goto out;\n+        }\n \t\terr = split_state(tree, state, prealloc, end + 1);\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..7ad02f92d659 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+            err = -ENOMEM;\n+            goto out;\n+        }\n \t\terr = split_state(tree, state, prealloc, start);\n \t\tif (err)\n \t\t\textent_io_tree_panic(tree, err);\n@@ -657,7 +660,10 @@ 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+            err = -ENOMEM;\n+            goto out;\n+        }\n \t\terr = split_state(tree, state, prealloc, end + 1);\n \t\tif (err)\n \t\t\textent_io_tree_panic(tree, err);\n@@ -1012,7 +1018,10 @@ static int __set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \tstate = tree_search_for_insert(tree, start, &p, &parent);\n \tif (!state) {\n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+            err = -ENOMEM;\n+            goto out;\n+        }\n \t\tprealloc->start = start;\n \t\tprealloc->end = end;\n \t\tinsert_state_fast(tree, prealloc, p, parent, bits, changeset);\n@@ -1085,7 +1094,10 @@ static int __set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \t\t}\n \n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+            err = -ENOMEM;\n+            goto out;\n+        }\n \t\terr = split_state(tree, state, prealloc, start);\n \t\tif (err)\n \t\t\textent_io_tree_panic(tree, err);\n@@ -1122,7 +1134,10 @@ static int __set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \t\t\tthis_end = last_start - 1;\n \n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+            err = -ENOMEM;\n+            goto out;\n+        }\n \n \t\t/*\n \t\t * Avoid to free 'prealloc' if it can be merged with the later\n@@ -1154,7 +1169,10 @@ static int __set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \t\t}\n \n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc) {\n+            err = -ENOMEM;\n+            goto out;\n+        }\n \t\terr = split_state(tree, state, prealloc, end + 1);\n \t\tif (err)\n \t\t\textent_io_tree_panic(tree, err);\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "bf7780df648105d40e1fdbb0566defda3605ed93": {
        "non_crash": [
            "diff --git a/net/core/gro.c b/net/core/gro.c\nindex b4190eb08467..98249d68b846 100644\n--- a/net/core/gro.c\n+++ b/net/core/gro.c\n@@ -133,7 +133,8 @@ 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 > skb_headlen(skb)) return ERR_PTR(-EINVAL);\n+    __skb_pull(skb, vlan_depth);\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..2e017d272e6e 100644\n--- a/net/core/gro.c\n+++ b/net/core/gro.c\n@@ -133,7 +133,8 @@ 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->len) return ERR_PTR(-EINVAL);\n+    __skb_pull(skb, vlan_depth);\n \n \trcu_read_lock();\n \tlist_for_each_entry_rcu(ptype, &offload_base, list) {\n",
            "diff --git a/net/core/gro.c b/net/core/gro.c\nindex b4190eb08467..4e471e59758e 100644\n--- a/net/core/gro.c\n+++ b/net/core/gro.c\n@@ -133,7 +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-\t__skb_pull(skb, vlan_depth);\n+\tif (vlan_depth <= skb->len)\n+__skb_pull(skb, vlan_depth);\n+else\n+return ERR_PTR(-EINVAL);\n \n \trcu_read_lock();\n \tlist_for_each_entry_rcu(ptype, &offload_base, list) {\n",
            "diff --git a/net/core/gro.c b/net/core/gro.c\nindex b4190eb08467..e706516b9c38 100644\n--- a/net/core/gro.c\n+++ b/net/core/gro.c\n@@ -133,7 +133,8 @@ 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->mac_len)\n+        __skb_pull(skb, vlan_depth);\n \n \trcu_read_lock();\n \tlist_for_each_entry_rcu(ptype, &offload_base, list) {\n",
            "diff --git a/net/core/gro.c b/net/core/gro.c\nindex b4190eb08467..560e3f583f74 100644\n--- a/net/core/gro.c\n+++ b/net/core/gro.c\n@@ -133,7 +133,8 @@ 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->len)\n+    __skb_pull(skb, vlan_depth);\n \n \trcu_read_lock();\n \tlist_for_each_entry_rcu(ptype, &offload_base, list) {\n"
        ],
        "error": []
    },
    "738a1a0b5b9b8ece2bbf714f2e244358be2523c3": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/pipe.c b/fs/pipe.c\nindex 2d88f73f585a..be3054bb3497 100644\n--- a/fs/pipe.c\n+++ b/fs/pipe.c\n@@ -100,7 +100,9 @@ EXPORT_SYMBOL(pipe_unlock);\n \n static inline void __pipe_lock(struct pipe_inode_info *pipe)\n {\n-\tmutex_lock_nested(&pipe->mutex, I_MUTEX_PARENT);\n+\tif (mutex_lock_interruptible(&pipe->mutex)) {\n+        printk(KERN_WARNING \"pipe mutex lock interrupted\\n\");\n+    }\n }\n \n static inline void __pipe_unlock(struct pipe_inode_info *pipe)\n",
            "diff --git a/fs/pipe.c b/fs/pipe.c\nindex 2d88f73f585a..da99708becd6 100644\n--- a/fs/pipe.c\n+++ b/fs/pipe.c\n@@ -725,7 +725,7 @@ pipe_release(struct inode *inode, struct file *file)\n \t\tpipe->writers--;\n \n \t/* Was that the last reader or writer, but not the other side? */\n-\tif (!pipe->readers != !pipe->writers) {\n+\tif ((pipe->readers == 0) != (pipe->writers == 0)) {\n \t\twake_up_interruptible_all(&pipe->rd_wait);\n \t\twake_up_interruptible_all(&pipe->wr_wait);\n \t\tkill_fasync(&pipe->fasync_readers, SIGIO, POLL_IN);\n",
            "diff --git a/fs/pipe.c b/fs/pipe.c\nindex 2d88f73f585a..daf54ae8df0d 100644\n--- a/fs/pipe.c\n+++ b/fs/pipe.c\n@@ -725,7 +725,7 @@ pipe_release(struct inode *inode, struct file *file)\n \t\tpipe->writers--;\n \n \t/* Was that the last reader or writer, but not the other side? */\n-\tif (!pipe->readers != !pipe->writers) {\n+\tif (!pipe->readers || !pipe->writers) {\n \t\twake_up_interruptible_all(&pipe->rd_wait);\n \t\twake_up_interruptible_all(&pipe->wr_wait);\n \t\tkill_fasync(&pipe->fasync_readers, SIGIO, POLL_IN);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/pipe.c b/fs/pipe.c\nindex 2d88f73f585a..33c29b902112 100644\n--- a/fs/pipe.c\n+++ b/fs/pipe.c\n@@ -238,10 +238,13 @@ pipe_read(struct kiocb *iocb, struct iov_iter *to)\n \n \t/* Null read succeeds. */\n \tif (unlikely(total_len == 0))\n-\t\treturn 0;\n+\t\tif (lock_acquired)\n+        __pipe_unlock(pipe);\n+    return 0;\n \n \tret = 0;\n \t__pipe_lock(pipe);\n+    int lock_acquired = 1;\n \n \t/*\n \t * We only wake up writers if the pipe was full when we started\n@@ -380,6 +383,7 @@ pipe_read(struct kiocb *iocb, struct iov_iter *to)\n \t\t\treturn -ERESTARTSYS;\n \n \t\t__pipe_lock(pipe);\n+    int lock_acquired = 1;\n \t\twas_full = pipe_full(pipe->head, pipe->tail, pipe->max_usage);\n \t\twake_next_reader = true;\n \t}\n@@ -427,9 +431,12 @@ pipe_write(struct kiocb *iocb, struct iov_iter *from)\n \n \t/* Null write succeeds. */\n \tif (unlikely(total_len == 0))\n-\t\treturn 0;\n+\t\tif (lock_acquired)\n+        __pipe_unlock(pipe);\n+    return 0;\n \n \t__pipe_lock(pipe);\n+    int lock_acquired = 1;\n \n \tif (!pipe->readers) {\n \t\tsend_sig(SIGPIPE, current, 0);\n@@ -572,6 +579,7 @@ pipe_write(struct kiocb *iocb, struct iov_iter *from)\n \t\tkill_fasync(&pipe->fasync_readers, SIGIO, POLL_IN);\n \t\twait_event_interruptible_exclusive(pipe->wr_wait, pipe_writable(pipe));\n \t\t__pipe_lock(pipe);\n+    int lock_acquired = 1;\n \t\twas_empty = pipe_empty(pipe->head, pipe->tail);\n \t\twake_next_writer = true;\n \t}\n@@ -614,6 +622,7 @@ static long pipe_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)\n \tswitch (cmd) {\n \tcase FIONREAD:\n \t\t__pipe_lock(pipe);\n+    int lock_acquired = 1;\n \t\tcount = 0;\n \t\thead = pipe->head;\n \t\ttail = pipe->tail;\n@@ -631,6 +640,7 @@ static long pipe_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)\n \tcase IOC_WATCH_QUEUE_SET_SIZE: {\n \t\tint ret;\n \t\t__pipe_lock(pipe);\n+    int lock_acquired = 1;\n \t\tret = watch_queue_set_size(pipe, arg);\n \t\t__pipe_unlock(pipe);\n \t\treturn ret;\n@@ -719,6 +729,7 @@ pipe_release(struct inode *inode, struct file *file)\n \tstruct pipe_inode_info *pipe = file->private_data;\n \n \t__pipe_lock(pipe);\n+    int lock_acquired = 1;\n \tif (file->f_mode & FMODE_READ)\n \t\tpipe->readers--;\n \tif (file->f_mode & FMODE_WRITE)\n@@ -734,7 +745,9 @@ pipe_release(struct inode *inode, struct file *file)\n \t__pipe_unlock(pipe);\n \n \tput_pipe_info(inode, pipe);\n-\treturn 0;\n+\tif (lock_acquired)\n+        __pipe_unlock(pipe);\n+    return 0;\n }\n \n static int\n@@ -744,6 +757,7 @@ pipe_fasync(int fd, struct file *filp, int on)\n \tint retval = 0;\n \n \t__pipe_lock(pipe);\n+    int lock_acquired = 1;\n \tif (filp->f_mode & FMODE_READ)\n \t\tretval = fasync_helper(fd, filp, on, &pipe->fasync_readers);\n \tif ((filp->f_mode & FMODE_WRITE) && retval >= 0) {\n@@ -950,7 +964,9 @@ int create_pipe_files(struct file **res, int flags)\n \tres[1] = f;\n \tstream_open(inode, res[0]);\n \tstream_open(inode, res[1]);\n-\treturn 0;\n+\tif (lock_acquired)\n+        __pipe_unlock(pipe);\n+    return 0;\n }\n \n static int __do_pipe_flags(int *fd, struct file **files, int flags)\n@@ -981,7 +997,9 @@ static int __do_pipe_flags(int *fd, struct file **files, int flags)\n \t/* pipe groks IOCB_NOWAIT */\n \tfiles[0]->f_mode |= FMODE_NOWAIT;\n \tfiles[1]->f_mode |= FMODE_NOWAIT;\n-\treturn 0;\n+\tif (lock_acquired)\n+        __pipe_unlock(pipe);\n+    return 0;\n \n  err_fdr:\n \tput_unused_fd(fdr);\n@@ -1129,6 +1147,7 @@ static int fifo_open(struct inode *inode, struct file *filp)\n \t/* OK, we have a pipe and it's pinned down */\n \n \t__pipe_lock(pipe);\n+    int lock_acquired = 1;\n \n \t/* We can only do regular read/write on fifos */\n \tstream_open(inode, filp);\n@@ -1199,7 +1218,9 @@ static int fifo_open(struct inode *inode, struct file *filp)\n \n \t/* Ok! */\n \t__pipe_unlock(pipe);\n-\treturn 0;\n+\tif (lock_acquired)\n+        __pipe_unlock(pipe);\n+    return 0;\n \n err_rd:\n \tif (!--pipe->readers)\n@@ -1239,7 +1260,9 @@ const struct file_operations pipefifo_fops = {\n unsigned int round_pipe_size(unsigned long size)\n {\n \tif (size > (1U << 31))\n-\t\treturn 0;\n+\t\tif (lock_acquired)\n+        __pipe_unlock(pipe);\n+    return 0;\n \n \t/* Minimum pipe size, as required by POSIX */\n \tif (size < PAGE_SIZE)\n@@ -1312,7 +1335,9 @@ int pipe_resize_ring(struct pipe_inode_info *pipe, unsigned int nr_slots)\n \n \t/* This might have made more room for writers */\n \twake_up_interruptible(&pipe->wr_wait);\n-\treturn 0;\n+\tif (lock_acquired)\n+        __pipe_unlock(pipe);\n+    return 0;\n }\n \n /*\n@@ -1397,6 +1422,7 @@ long pipe_fcntl(struct file *file, unsigned int cmd, unsigned long arg)\n \t\treturn -EBADF;\n \n \t__pipe_lock(pipe);\n+    int lock_acquired = 1;\n \n \tswitch (cmd) {\n \tcase F_SETPIPE_SZ:\n@@ -1433,7 +1459,9 @@ static int pipefs_init_fs_context(struct fs_context *fc)\n \t\treturn -ENOMEM;\n \tctx->ops = &pipefs_ops;\n \tctx->dops = &pipefs_dentry_operations;\n-\treturn 0;\n+\tif (lock_acquired)\n+        __pipe_unlock(pipe);\n+    return 0;\n }\n \n static struct file_system_type pipe_fs_type = {\n@@ -1460,7 +1488,9 @@ static int do_proc_dopipe_max_size_conv(unsigned long *lvalp,\n \t\t*lvalp = (unsigned long) val;\n \t}\n \n-\treturn 0;\n+\tif (lock_acquired)\n+        __pipe_unlock(pipe);\n+    return 0;\n }\n \n static int proc_dopipe_max_size(struct ctl_table *table, int write,\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "91e171a9aa357b24b62b3ab188bc04996448c99b": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c\nindex 5864cbc30db6..57ed2651b927 100644\n--- a/net/ipv6/addrconf.c\n+++ b/net/ipv6/addrconf.c\n@@ -5168,7 +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\tfor (ifmca = rcu_dereference(idev->mc_list);\n+\t\tfor (ifmca = rcu_dereference_protected(idev->mc_list, lockdep_is_held(&idev->lock));\n \t\t     ifmca;\n \t\t     ifmca = rcu_dereference(ifmca->next), ip_idx++) {\n \t\t\tif (ip_idx < s_ip_idx)\n",
            "diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c\nindex 5864cbc30db6..0b19a8947573 100644\n--- a/net/ipv6/addrconf.c\n+++ b/net/ipv6/addrconf.c\n@@ -5168,7 +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\tfor (ifmca = rcu_dereference(idev->mc_list);\n+\t\tfor (ifmca = rcu_dereference_check(idev->mc_list, rcu_read_lock_held());\n \t\t     ifmca;\n \t\t     ifmca = rcu_dereference(ifmca->next), ip_idx++) {\n \t\t\tif (ip_idx < s_ip_idx)\n",
            "diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c\nindex 5864cbc30db6..0b19a8947573 100644\n--- a/net/ipv6/addrconf.c\n+++ b/net/ipv6/addrconf.c\n@@ -5168,7 +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\tfor (ifmca = rcu_dereference(idev->mc_list);\n+\t\tfor (ifmca = rcu_dereference_check(idev->mc_list, rcu_read_lock_held());\n \t\t     ifmca;\n \t\t     ifmca = rcu_dereference(ifmca->next), ip_idx++) {\n \t\t\tif (ip_idx < s_ip_idx)\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c\nindex 5864cbc30db6..14b69f43d15d 100644\n--- a/net/ipv6/addrconf.c\n+++ b/net/ipv6/addrconf.c\n@@ -822,7 +822,7 @@ static void dev_forward_change(struct inet6_dev *idev)\n \t\t\tcontinue;\n \t\tlist_add_tail(&ifa->if_list_aux, &tmp_addr_list);\n \t}\n-\tread_unlock_bh(&idev->lock);\n+\t\n \n \twhile (!list_empty(&tmp_addr_list)) {\n \t\tifa = list_first_entry(&tmp_addr_list,\n@@ -1874,7 +1874,7 @@ int ipv6_get_lladdr(struct net_device *dev, struct in6_addr *addr,\n \tif (idev) {\n \t\tread_lock_bh(&idev->lock);\n \t\terr = __ipv6_get_lladdr(idev, addr, banned_flags);\n-\t\tread_unlock_bh(&idev->lock);\n+\t\t\n \t}\n \trcu_read_unlock();\n \treturn err;\n@@ -2352,7 +2352,7 @@ static int ipv6_inherit_eui64(u8 *eui, struct inet6_dev *idev)\n \t\t\tbreak;\n \t\t}\n \t}\n-\tread_unlock_bh(&idev->lock);\n+\t\n \treturn err;\n }\n \n@@ -2569,10 +2569,10 @@ static void manage_tempaddrs(struct inet6_dev *idev,\n \t\t * Also create a temporary address if it's enabled but\n \t\t * no temporary address currently exists.\n \t\t */\n-\t\tread_unlock_bh(&idev->lock);\n+\t\t\n \t\tipv6_create_tempaddr(ifp, false);\n \t} else {\n-\t\tread_unlock_bh(&idev->lock);\n+\t\t\n \t}\n }\n \n@@ -3022,7 +3022,7 @@ static int inet6_addr_del(struct net *net, int ifindex, u32 ifa_flags,\n \t\tif (ifp->prefix_len == plen &&\n \t\t    ipv6_addr_equal(pfx, &ifp->addr)) {\n \t\t\tin6_ifa_hold(ifp);\n-\t\t\tread_unlock_bh(&idev->lock);\n+\t\t\t\n \n \t\t\tif (!(ifp->flags & IFA_F_TEMPORARY) &&\n \t\t\t    (ifa_flags & IFA_F_MANAGETEMPADDR))\n@@ -3037,7 +3037,7 @@ static int inet6_addr_del(struct net *net, int ifindex, u32 ifa_flags,\n \t\t\treturn 0;\n \t\t}\n \t}\n-\tread_unlock_bh(&idev->lock);\n+\t\n \treturn -EADDRNOTAVAIL;\n }\n \n@@ -4005,7 +4005,7 @@ static void addrconf_dad_begin(struct inet6_ifaddr *ifp)\n \t\tbump_id = ifp->flags & IFA_F_TENTATIVE;\n \t\tifp->flags &= ~(IFA_F_TENTATIVE|IFA_F_OPTIMISTIC|IFA_F_DADFAILED);\n \t\tspin_unlock(&ifp->lock);\n-\t\tread_unlock_bh(&idev->lock);\n+\t\t\n \n \t\taddrconf_dad_completed(ifp, bump_id, send_na);\n \t\treturn;\n@@ -4013,7 +4013,7 @@ static void addrconf_dad_begin(struct inet6_ifaddr *ifp)\n \n \tif (!(idev->if_flags & IF_READY)) {\n \t\tspin_unlock(&ifp->lock);\n-\t\tread_unlock_bh(&idev->lock);\n+\t\t\n \t\t/*\n \t\t * If the device is not ready:\n \t\t * - keep it tentative if it is a permanent address.\n@@ -4041,7 +4041,7 @@ static void addrconf_dad_begin(struct inet6_ifaddr *ifp)\n \taddrconf_dad_kick(ifp);\n out:\n \tspin_unlock(&ifp->lock);\n-\tread_unlock_bh(&idev->lock);\n+\t\n \tif (notify)\n \t\tipv6_ifa_notify(RTM_NEWADDR, ifp);\n }\n@@ -4279,7 +4279,7 @@ static void addrconf_dad_run(struct inet6_dev *idev, bool restart)\n \t\t}\n \t\tspin_unlock(&ifp->lock);\n \t}\n-\tread_unlock_bh(&idev->lock);\n+\t\n }\n \n #ifdef CONFIG_PROC_FS\n@@ -5164,7 +5164,7 @@ static int in6_dump_addrs(struct inet6_dev *idev, struct sk_buff *skb,\n \t\tbreak;\n \t}\n \tcase MULTICAST_ADDR:\n-\t\tread_unlock_bh(&idev->lock);\n+\t\t\n \t\tfillargs->event = RTM_GETMULTICAST;\n \n \t\t/* multicast address */\n@@ -5194,7 +5194,7 @@ static int in6_dump_addrs(struct inet6_dev *idev, struct sk_buff *skb,\n \tdefault:\n \t\tbreak;\n \t}\n-\tread_unlock_bh(&idev->lock);\n+\t\n \tcb->args[2] = ip_idx;\n \treturn err;\n }\n@@ -5698,7 +5698,7 @@ static int inet6_fill_ifla6_attrs(struct sk_buff *skb, struct inet6_dev *idev,\n \t\tgoto nla_put_failure;\n \tread_lock_bh(&idev->lock);\n \tmemcpy(nla_data(nla), idev->token.s6_addr, nla_len(nla));\n-\tread_unlock_bh(&idev->lock);\n+\t\n \n \tif (nla_put_u8(skb, IFLA_INET6_ADDR_GEN_MODE, idev->cnf.addr_gen_mode))\n \t\tgoto nla_put_failure;\n@@ -6545,7 +6545,7 @@ void addrconf_disable_policy_idev(struct inet6_dev *idev, int val)\n \t\t}\n \t\tspin_unlock(&ifa->lock);\n \t}\n-\tread_unlock_bh(&idev->lock);\n+\t\n }\n \n static\n",
                "error_message": "Failed to set up instance"
            },
            {
                "patch": "diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c\nindex 5864cbc30db6..cd83316156b9 100644\n--- a/net/ipv6/addrconf.c\n+++ b/net/ipv6/addrconf.c\n@@ -816,7 +816,8 @@ static void dev_forward_change(struct inet6_dev *idev)\n \t\t}\n \t}\n \n-\tread_lock_bh(&idev->lock);\n+\trcu_read_unlock();\n+        read_lock_bh(&idev->lock);\n \tlist_for_each_entry(ifa, &idev->addr_list, if_list) {\n \t\tif (ifa->flags&IFA_F_TENTATIVE)\n \t\t\tcontinue;\n@@ -1872,7 +1873,8 @@ int ipv6_get_lladdr(struct net_device *dev, struct in6_addr *addr,\n \trcu_read_lock();\n \tidev = __in6_dev_get(dev);\n \tif (idev) {\n-\t\tread_lock_bh(&idev->lock);\n+\t\trcu_read_unlock();\n+        read_lock_bh(&idev->lock);\n \t\terr = __ipv6_get_lladdr(idev, addr, banned_flags);\n \t\tread_unlock_bh(&idev->lock);\n \t}\n@@ -2342,7 +2344,8 @@ static int ipv6_inherit_eui64(u8 *eui, struct inet6_dev *idev)\n \tint err = -1;\n \tstruct inet6_ifaddr *ifp;\n \n-\tread_lock_bh(&idev->lock);\n+\trcu_read_unlock();\n+        read_lock_bh(&idev->lock);\n \tlist_for_each_entry_reverse(ifp, &idev->addr_list, if_list) {\n \t\tif (ifp->scope > IFA_LINK)\n \t\t\tbreak;\n@@ -2517,7 +2520,8 @@ static void manage_tempaddrs(struct inet6_dev *idev,\n \tu32 flags;\n \tstruct inet6_ifaddr *ift;\n \n-\tread_lock_bh(&idev->lock);\n+\trcu_read_unlock();\n+        read_lock_bh(&idev->lock);\n \t/* update all temporary addresses in the list */\n \tlist_for_each_entry(ift, &idev->tempaddr_list, tmp_list) {\n \t\tint age, max_valid, max_prefered;\n@@ -3017,7 +3021,8 @@ static int inet6_addr_del(struct net *net, int ifindex, u32 ifa_flags,\n \tif (!idev)\n \t\treturn -ENXIO;\n \n-\tread_lock_bh(&idev->lock);\n+\trcu_read_unlock();\n+        read_lock_bh(&idev->lock);\n \tlist_for_each_entry(ifp, &idev->addr_list, if_list) {\n \t\tif (ifp->prefix_len == plen &&\n \t\t    ipv6_addr_equal(pfx, &ifp->addr)) {\n@@ -3986,7 +3991,8 @@ static void addrconf_dad_begin(struct inet6_ifaddr *ifp)\n \n \taddrconf_join_solict(dev, &ifp->addr);\n \n-\tread_lock_bh(&idev->lock);\n+\trcu_read_unlock();\n+        read_lock_bh(&idev->lock);\n \tspin_lock(&ifp->lock);\n \tif (ifp->state == INET6_IFADDR_STATE_DEAD)\n \t\tgoto out;\n@@ -4268,7 +4274,8 @@ static void addrconf_dad_run(struct inet6_dev *idev, bool restart)\n {\n \tstruct inet6_ifaddr *ifp;\n \n-\tread_lock_bh(&idev->lock);\n+\trcu_read_unlock();\n+        read_lock_bh(&idev->lock);\n \tlist_for_each_entry(ifp, &idev->addr_list, if_list) {\n \t\tspin_lock(&ifp->lock);\n \t\tif ((ifp->flags & IFA_F_TENTATIVE &&\n@@ -5144,7 +5151,8 @@ static int in6_dump_addrs(struct inet6_dev *idev, struct sk_buff *skb,\n \tint ip_idx = 0;\n \tint err = 1;\n \n-\tread_lock_bh(&idev->lock);\n+\trcu_read_unlock();\n+        read_lock_bh(&idev->lock);\n \tswitch (fillargs->type) {\n \tcase UNICAST_ADDR: {\n \t\tstruct inet6_ifaddr *ifa;\n@@ -5166,6 +5174,7 @@ static int in6_dump_addrs(struct inet6_dev *idev, struct sk_buff *skb,\n \tcase MULTICAST_ADDR:\n \t\tread_unlock_bh(&idev->lock);\n \t\tfillargs->event = RTM_GETMULTICAST;\n+        rcu_read_lock();\n \n \t\t/* multicast address */\n \t\tfor (ifmca = rcu_dereference(idev->mc_list);\n@@ -5177,7 +5186,8 @@ 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\tread_lock_bh(&idev->lock);\n+\t\trcu_read_unlock();\n+        read_lock_bh(&idev->lock);\n \t\tbreak;\n \tcase ANYCAST_ADDR:\n \t\tfillargs->event = RTM_GETANYCAST;\n@@ -5696,7 +5706,8 @@ static int inet6_fill_ifla6_attrs(struct sk_buff *skb, struct inet6_dev *idev,\n \tnla = nla_reserve(skb, IFLA_INET6_TOKEN, sizeof(struct in6_addr));\n \tif (!nla)\n \t\tgoto nla_put_failure;\n-\tread_lock_bh(&idev->lock);\n+\trcu_read_unlock();\n+        read_lock_bh(&idev->lock);\n \tmemcpy(nla_data(nla), idev->token.s6_addr, nla_len(nla));\n \tread_unlock_bh(&idev->lock);\n \n@@ -6523,7 +6534,8 @@ void addrconf_disable_policy_idev(struct inet6_dev *idev, int val)\n {\n \tstruct inet6_ifaddr *ifa;\n \n-\tread_lock_bh(&idev->lock);\n+\trcu_read_unlock();\n+        read_lock_bh(&idev->lock);\n \tlist_for_each_entry(ifa, &idev->addr_list, if_list) {\n \t\tspin_lock(&ifa->lock);\n \t\tif (ifa->rt) {\n",
                "error_message": "Failed to set up instance"
            }
        ]
    },
    "f080ff8eb73ae6a29960594307de8e732db389d3": {
        "non_crash": [
            "diff --git a/fs/f2fs/extent_cache.c b/fs/f2fs/extent_cache.c\nindex 0e2d49140c07..48eafe4db154 100644\n--- a/fs/f2fs/extent_cache.c\n+++ b/fs/f2fs/extent_cache.c\n@@ -1094,7 +1094,7 @@ static void __drop_extent_tree(struct inode *inode, enum extent_type type)\n \tstruct extent_tree *et = F2FS_I(inode)->extent_tree[type];\n \tbool updated = false;\n \n-\tif (!__may_extent_tree(inode, type))\n+\tif (!et || !__may_extent_tree(inode, type))\n \t\treturn;\n \n \twrite_lock(&et->lock);\n",
            "diff --git a/fs/f2fs/extent_cache.c b/fs/f2fs/extent_cache.c\nindex 0e2d49140c07..48eafe4db154 100644\n--- a/fs/f2fs/extent_cache.c\n+++ b/fs/f2fs/extent_cache.c\n@@ -1094,7 +1094,7 @@ static void __drop_extent_tree(struct inode *inode, enum extent_type type)\n \tstruct extent_tree *et = F2FS_I(inode)->extent_tree[type];\n \tbool updated = false;\n \n-\tif (!__may_extent_tree(inode, type))\n+\tif (!et || !__may_extent_tree(inode, type))\n \t\treturn;\n \n \twrite_lock(&et->lock);\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/fs/f2fs/extent_cache.c b/fs/f2fs/extent_cache.c\nindex 0e2d49140c07..d118d1299f95 100644\n--- a/fs/f2fs/extent_cache.c\n+++ b/fs/f2fs/extent_cache.c\n@@ -421,7 +421,8 @@ 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+    write_lock(&et->lock);\n \tif (atomic_read(&et->node_cnt))\n \t\tgoto unlock_out;\n \n@@ -625,7 +626,8 @@ static void __update_extent_tree_range(struct inode *inode,\n \t\ttrace_f2fs_update_age_extent_tree_range(inode, fofs, len,\n \t\t\t\t\t\ttei->age, tei->last_blocks);\n \n-\twrite_lock(&et->lock);\n+\tif (et) {\n+    write_lock(&et->lock);\n \n \tif (type == EX_READ) {\n \t\tif (is_inode_flag_set(inode, FI_NO_EXTENT)) {\n@@ -783,7 +785,8 @@ void f2fs_update_read_extent_tree_range_compressed(struct inode *inode,\n \tif (is_inode_flag_set(inode, FI_NO_EXTENT))\n \t\treturn;\n \n-\twrite_lock(&et->lock);\n+\tif (et) {\n+    write_lock(&et->lock);\n \n \ten = __lookup_extent_node_ret(&et->root,\n \t\t\t\t\tet->cached_en, fofs,\n@@ -922,7 +925,8 @@ static unsigned int __shrink_extent_tree(struct f2fs_sb_info *sbi, int nr_shrink\n \t/* 1. remove unreferenced extent tree */\n \tlist_for_each_entry_safe(et, next, &eti->zombie_list, list) {\n \t\tif (atomic_read(&et->node_cnt)) {\n-\t\t\twrite_lock(&et->lock);\n+\t\t\tif (et) {\n+    write_lock(&et->lock);\n \t\t\tnode_cnt += __free_extent_tree(sbi, et);\n \t\t\twrite_unlock(&et->lock);\n \t\t}\n@@ -1075,7 +1079,8 @@ static unsigned int __destroy_extent_node(struct inode *inode,\n \tif (!et || !atomic_read(&et->node_cnt))\n \t\treturn 0;\n \n-\twrite_lock(&et->lock);\n+\tif (et) {\n+    write_lock(&et->lock);\n \tnode_cnt = __free_extent_tree(sbi, et);\n \twrite_unlock(&et->lock);\n \n@@ -1097,7 +1102,8 @@ 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+\tif (et) {\n+    write_lock(&et->lock);\n \t__free_extent_tree(sbi, et);\n \tif (type == EX_READ) {\n \t\tset_inode_flag(inode, FI_NO_EXTENT);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/f2fs/extent_cache.c b/fs/f2fs/extent_cache.c\nindex 0e2d49140c07..1cc37a6c4ddb 100644\n--- a/fs/f2fs/extent_cache.c\n+++ b/fs/f2fs/extent_cache.c\n@@ -1089,6 +1089,27 @@ void f2fs_destroy_extent_node(struct inode *inode)\n }\n \n static void __drop_extent_tree(struct inode *inode, enum extent_type type)\n+{\n+    struct f2fs_sb_info *sbi = F2FS_I_SB(inode);\n+    struct extent_tree *et = F2FS_I(inode)->extent_tree[type];\n+    bool updated = false;\n+\n+    if (!__may_extent_tree(inode, type) || !et)\n+        return;\n+\n+    write_lock(&et->lock);\n+    __free_extent_tree(sbi, et);\n+    if (type == EX_READ) {\n+        set_inode_flag(inode, FI_NO_EXTENT);\n+        if (et->largest.len) {\n+            et->largest.len = 0;\n+            updated = true;\n+        }\n+    }\n+    write_unlock(&et->lock);\n+    if (updated)\n+        f2fs_mark_inode_dirty_sync(inode, true);\n+}\n {\n \tstruct f2fs_sb_info *sbi = F2FS_I_SB(inode);\n \tstruct extent_tree *et = F2FS_I(inode)->extent_tree[type];\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/f2fs/extent_cache.c b/fs/f2fs/extent_cache.c\nindex 0e2d49140c07..faf056dd3581 100644\n--- a/fs/f2fs/extent_cache.c\n+++ b/fs/f2fs/extent_cache.c\n@@ -466,6 +466,7 @@ static bool __lookup_extent_tree(struct inode *inode, pgoff_t pgofs,\n \tstruct f2fs_sb_info *sbi = F2FS_I_SB(inode);\n \tstruct extent_tree_info *eti = &sbi->extent_tree[type];\n \tstruct extent_tree *et = F2FS_I(inode)->extent_tree[type];\n+    if (!et) return;\n \tstruct extent_node *en;\n \tbool ret = false;\n \n@@ -606,6 +607,7 @@ static void __update_extent_tree_range(struct inode *inode,\n {\n \tstruct f2fs_sb_info *sbi = F2FS_I_SB(inode);\n \tstruct extent_tree *et = F2FS_I(inode)->extent_tree[type];\n+    if (!et) return;\n \tstruct extent_node *en = NULL, *en1 = NULL;\n \tstruct extent_node *prev_en = NULL, *next_en = NULL;\n \tstruct extent_info ei, dei, prev;\n@@ -1070,6 +1072,7 @@ static unsigned int __destroy_extent_node(struct inode *inode,\n {\n \tstruct f2fs_sb_info *sbi = F2FS_I_SB(inode);\n \tstruct extent_tree *et = F2FS_I(inode)->extent_tree[type];\n+    if (!et) return;\n \tunsigned int node_cnt = 0;\n \n \tif (!et || !atomic_read(&et->node_cnt))\n@@ -1092,6 +1095,7 @@ static void __drop_extent_tree(struct inode *inode, enum extent_type type)\n {\n \tstruct f2fs_sb_info *sbi = F2FS_I_SB(inode);\n \tstruct extent_tree *et = F2FS_I(inode)->extent_tree[type];\n+    if (!et) return;\n \tbool updated = false;\n \n \tif (!__may_extent_tree(inode, type))\n@@ -1122,6 +1126,7 @@ static void __destroy_extent_tree(struct inode *inode, enum extent_type type)\n \tstruct f2fs_sb_info *sbi = F2FS_I_SB(inode);\n \tstruct extent_tree_info *eti = &sbi->extent_tree[type];\n \tstruct extent_tree *et = F2FS_I(inode)->extent_tree[type];\n+    if (!et) return;\n \tunsigned int node_cnt = 0;\n \n \tif (!et)\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "8db097bf9d28642881b6dee785166885150fbd86": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 9930fa901039..08cf676a16d9 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -227,7 +227,10 @@ int nilfs_dat_prepare_update(struct inode *dat,\n {\n \tint ret;\n \n-\tret = nilfs_dat_prepare_end(dat, oldreq);\n+\tret = nilfs_dat_prepare_entry(dat, oldreq, 0);\n+    if (ret == -ENOENT)\n+        return ret;\n+    ret = nilfs_dat_prepare_end(dat, oldreq);\n \tif (!ret) {\n \t\tret = nilfs_dat_prepare_alloc(dat, newreq);\n \t\tif (ret < 0)\n",
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 9930fa901039..99b014b601a5 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -155,7 +155,8 @@ 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\t// Entry not found, handle gracefully\n+return ret;\n \t\treturn ret;\n \t}\n \n",
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 9930fa901039..209e2e3dc970 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -126,7 +126,7 @@ int nilfs_dat_prepare_start(struct inode *dat, struct nilfs_palloc_req *req)\n \tint ret;\n \n \tret = nilfs_dat_prepare_entry(dat, req, 0);\n-\tWARN_ON(ret == -ENOENT);\n+\t\n \treturn ret;\n }\n \n@@ -155,7 +155,7 @@ 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\t\n \t\treturn ret;\n \t}\n \n",
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 9930fa901039..e6801bcb769d 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -126,7 +126,8 @@ int nilfs_dat_prepare_start(struct inode *dat, struct nilfs_palloc_req *req)\n \tint ret;\n \n \tret = nilfs_dat_prepare_entry(dat, req, 0);\n-\tWARN_ON(ret == -ENOENT);\n+\tpr_warn(\"nilfs_dat_prepare_end: entry not found\\n\");\n+        return ret;\n \treturn ret;\n }\n \n@@ -155,7 +156,8 @@ 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\tpr_warn(\"nilfs_dat_prepare_end: entry not found\\n\");\n+        return ret;\n \t\treturn ret;\n \t}\n \n",
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 9930fa901039..907ed544a275 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -126,6 +126,10 @@ int nilfs_dat_prepare_start(struct inode *dat, struct nilfs_palloc_req *req)\n \tint ret;\n \n \tret = nilfs_dat_prepare_entry(dat, req, 0);\n+    if (ret == -ENOENT) {\n+        /* Handle the non-existent block gracefully */\n+        return ret;\n+    }\n \tWARN_ON(ret == -ENOENT);\n \treturn ret;\n }\n@@ -154,6 +158,10 @@ int nilfs_dat_prepare_end(struct inode *dat, struct nilfs_palloc_req *req)\n \tint ret;\n \n \tret = nilfs_dat_prepare_entry(dat, req, 0);\n+    if (ret == -ENOENT) {\n+        /* Handle the non-existent block gracefully */\n+        return ret;\n+    }\n \tif (ret < 0) {\n \t\tWARN_ON(ret == -ENOENT);\n \t\treturn ret;\n"
        ],
        "error": []
    },
    "d21cb12ee03822236d82ba4e83a1f8968e7832fb": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/filemap.c b/mm/filemap.c\nindex a34abfe8c654..84b803a9c43f 100644\n--- a/mm/filemap.c\n+++ b/mm/filemap.c\n@@ -1932,7 +1932,7 @@ struct folio *__filemap_get_folio(struct address_space *mapping, pgoff_t index,\n \t\t}\n \n \t\t/* Has the page been truncated? */\n-\t\tif (unlikely(folio->mapping != mapping)) {\n+\t\tif (unlikely(!folio || folio->mapping != mapping)) {\n \t\t\tfolio_unlock(folio);\n \t\t\tfolio_put(folio);\n \t\t\tgoto repeat;\n@@ -3301,7 +3301,7 @@ vm_fault_t filemap_fault(struct vm_fault *vmf)\n \t\tgoto out_retry;\n \n \t/* Did it get truncated? */\n-\tif (unlikely(folio->mapping != mapping)) {\n+\tif (unlikely(!folio || folio->mapping != mapping)) {\n \t\tfolio_unlock(folio);\n \t\tfolio_put(folio);\n \t\tgoto retry_find;\n",
            "diff --git a/mm/filemap.c b/mm/filemap.c\nindex a34abfe8c654..4c80d096a253 100644\n--- a/mm/filemap.c\n+++ b/mm/filemap.c\n@@ -3260,6 +3260,10 @@ vm_fault_t filemap_fault(struct vm_fault *vmf)\n \t * Do we have something in the page cache already?\n \t */\n \tfolio = filemap_get_folio(mapping, index);\n+    if (!folio) {\n+        ret = VM_FAULT_SIGBUS;\n+        goto out_retry;\n+    }\n \tif (likely(!IS_ERR(folio))) {\n \t\t/*\n \t\t * We found the page, so try async readahead before waiting for\n",
            "diff --git a/mm/filemap.c b/mm/filemap.c\nindex a34abfe8c654..8dc08c970100 100644\n--- a/mm/filemap.c\n+++ b/mm/filemap.c\n@@ -1279,7 +1279,8 @@ static inline int folio_wait_bit_common(struct folio *folio, int bit_nr,\n \t * We can drop our reference to the folio.\n \t */\n \tif (behavior == DROP)\n-\t\tfolio_put(folio);\n+\t\tif (folio)\n+folio_put(folio);\n \n \t/*\n \t * Note that until the \"finish_wait()\", or until\n@@ -1548,7 +1549,8 @@ void folio_end_private_2(struct folio *folio)\n \tVM_BUG_ON_FOLIO(!folio_test_private_2(folio), folio);\n \tclear_bit_unlock(PG_private_2, folio_flags(folio, 0));\n \tfolio_wake_bit(folio, PG_private_2);\n-\tfolio_put(folio);\n+\tif (folio)\n+folio_put(folio);\n }\n EXPORT_SYMBOL(folio_end_private_2);\n \n@@ -1621,7 +1623,8 @@ void folio_end_writeback(struct folio *folio)\n \tsmp_mb__after_atomic();\n \tfolio_wake(folio, PG_writeback);\n \tacct_reclaim_writeback(folio);\n-\tfolio_put(folio);\n+\tif (folio)\n+folio_put(folio);\n }\n EXPORT_SYMBOL(folio_end_writeback);\n \n@@ -1869,7 +1872,8 @@ void *filemap_get_entry(struct address_space *mapping, pgoff_t index)\n \t\tgoto repeat;\n \n \tif (unlikely(folio != xas_reload(&xas))) {\n-\t\tfolio_put(folio);\n+\t\tif (folio)\n+folio_put(folio);\n \t\tgoto repeat;\n \t}\n out:\n@@ -1924,7 +1928,8 @@ struct folio *__filemap_get_folio(struct address_space *mapping, pgoff_t index,\n \tif (fgp_flags & FGP_LOCK) {\n \t\tif (fgp_flags & FGP_NOWAIT) {\n \t\t\tif (!folio_trylock(folio)) {\n-\t\t\t\tfolio_put(folio);\n+\t\t\t\tif (folio)\n+folio_put(folio);\n \t\t\t\treturn ERR_PTR(-EAGAIN);\n \t\t\t}\n \t\t} else {\n@@ -1934,7 +1939,8 @@ struct folio *__filemap_get_folio(struct address_space *mapping, pgoff_t index,\n \t\t/* Has the page been truncated? */\n \t\tif (unlikely(folio->mapping != mapping)) {\n \t\t\tfolio_unlock(folio);\n-\t\t\tfolio_put(folio);\n+\t\t\tif (folio)\n+folio_put(folio);\n \t\t\tgoto repeat;\n \t\t}\n \t\tVM_BUG_ON_FOLIO(!folio_contains(folio, index), folio);\n@@ -1975,7 +1981,8 @@ struct folio *__filemap_get_folio(struct address_space *mapping, pgoff_t index,\n \n \t\terr = filemap_add_folio(mapping, folio, index, gfp);\n \t\tif (unlikely(err)) {\n-\t\t\tfolio_put(folio);\n+\t\t\tif (folio)\n+folio_put(folio);\n \t\t\tfolio = NULL;\n \t\t\tif (err == -EEXIST)\n \t\t\t\tgoto repeat;\n@@ -2020,7 +2027,8 @@ static inline struct folio *find_get_entry(struct xa_state *xas, pgoff_t max,\n \t\tgoto reset;\n \n \tif (unlikely(folio != xas_reload(xas))) {\n-\t\tfolio_put(folio);\n+\t\tif (folio)\n+folio_put(folio);\n \t\tgoto reset;\n \t}\n \n@@ -2124,7 +2132,8 @@ unsigned find_lock_entries(struct address_space *mapping, pgoff_t *start,\n unlock:\n \t\tfolio_unlock(folio);\n put:\n-\t\tfolio_put(folio);\n+\t\tif (folio)\n+folio_put(folio);\n \t}\n \trcu_read_unlock();\n \n@@ -2260,7 +2269,8 @@ unsigned filemap_get_folios_contig(struct address_space *mapping,\n \t\t}\n \t\tcontinue;\n put_folio:\n-\t\tfolio_put(folio);\n+\t\tif (folio)\n+folio_put(folio);\n \n retry:\n \t\txas_reset(&xas);\n@@ -2394,7 +2404,8 @@ static void filemap_get_read_batch(struct address_space *mapping,\n \t\txas_advance(&xas, folio->index + folio_nr_pages(folio) - 1);\n \t\tcontinue;\n put_folio:\n-\t\tfolio_put(folio);\n+\t\tif (folio)\n+folio_put(folio);\n retry:\n \t\txas_reset(&xas);\n \t}\n@@ -2510,7 +2521,8 @@ static int filemap_update_page(struct kiocb *iocb,\n unlock_mapping:\n \tfilemap_invalidate_unlock_shared(mapping);\n \tif (error == AOP_TRUNCATED_PAGE)\n-\t\tfolio_put(folio);\n+\t\tif (folio)\n+folio_put(folio);\n \treturn error;\n }\n \n@@ -2555,7 +2567,8 @@ static int filemap_create_folio(struct file *file,\n \treturn 0;\n error:\n \tfilemap_invalidate_unlock_shared(mapping);\n-\tfolio_put(folio);\n+\tif (folio)\n+folio_put(folio);\n \treturn error;\n }\n \n@@ -2625,7 +2638,8 @@ static int filemap_get_pages(struct kiocb *iocb, size_t count,\n \treturn 0;\n err:\n \tif (err < 0)\n-\t\tfolio_put(folio);\n+\t\tif (folio)\n+folio_put(folio);\n \tif (likely(--fbatch->nr))\n \t\treturn 0;\n \tif (err == AOP_TRUNCATED_PAGE)\n@@ -3057,14 +3071,16 @@ loff_t mapping_seek_hole_data(struct address_space *mapping, loff_t start,\n \t\tif (seek_size > PAGE_SIZE)\n \t\t\txas_set(&xas, pos >> PAGE_SHIFT);\n \t\tif (!xa_is_value(folio))\n-\t\t\tfolio_put(folio);\n+\t\t\tif (folio)\n+folio_put(folio);\n \t}\n \tif (seek_data)\n \t\tstart = -ENXIO;\n unlock:\n \trcu_read_unlock();\n \tif (folio && !xa_is_value(folio))\n-\t\tfolio_put(folio);\n+\t\tif (folio)\n+folio_put(folio);\n \tif (start > end)\n \t\treturn end;\n \treturn start;\n@@ -3303,7 +3319,8 @@ vm_fault_t filemap_fault(struct vm_fault *vmf)\n \t/* Did it get truncated? */\n \tif (unlikely(folio->mapping != mapping)) {\n \t\tfolio_unlock(folio);\n-\t\tfolio_put(folio);\n+\t\tif (folio)\n+folio_put(folio);\n \t\tgoto retry_find;\n \t}\n \tVM_BUG_ON_FOLIO(!folio_contains(folio, index), folio);\n@@ -3321,7 +3338,8 @@ vm_fault_t filemap_fault(struct vm_fault *vmf)\n \t\t */\n \t\tif (!mapping_locked) {\n \t\t\tfolio_unlock(folio);\n-\t\t\tfolio_put(folio);\n+\t\t\tif (folio)\n+folio_put(folio);\n \t\t\tgoto retry_find;\n \t\t}\n \t\tgoto page_not_uptodate;\n@@ -3346,7 +3364,8 @@ vm_fault_t filemap_fault(struct vm_fault *vmf)\n \tmax_idx = DIV_ROUND_UP(i_size_read(inode), PAGE_SIZE);\n \tif (unlikely(index >= max_idx)) {\n \t\tfolio_unlock(folio);\n-\t\tfolio_put(folio);\n+\t\tif (folio)\n+folio_put(folio);\n \t\treturn VM_FAULT_SIGBUS;\n \t}\n \n@@ -3364,7 +3383,8 @@ vm_fault_t filemap_fault(struct vm_fault *vmf)\n \terror = filemap_read_folio(file, mapping->a_ops->read_folio, folio);\n \tif (fpin)\n \t\tgoto out_retry;\n-\tfolio_put(folio);\n+\tif (folio)\n+folio_put(folio);\n \n \tif (!error || error == AOP_TRUNCATED_PAGE)\n \t\tgoto retry_find;\n@@ -3379,7 +3399,8 @@ vm_fault_t filemap_fault(struct vm_fault *vmf)\n \t * page.\n \t */\n \tif (folio)\n-\t\tfolio_put(folio);\n+\t\tif (folio)\n+folio_put(folio);\n \tif (mapping_locked)\n \t\tfilemap_invalidate_unlock_shared(mapping);\n \tif (fpin)\n@@ -3396,7 +3417,8 @@ static bool filemap_map_pmd(struct vm_fault *vmf, struct folio *folio,\n \t/* Huge page is mapped? No need to proceed. */\n \tif (pmd_trans_huge(*vmf->pmd)) {\n \t\tfolio_unlock(folio);\n-\t\tfolio_put(folio);\n+\t\tif (folio)\n+folio_put(folio);\n \t\treturn true;\n \t}\n \n@@ -3416,7 +3438,8 @@ static bool filemap_map_pmd(struct vm_fault *vmf, struct folio *folio,\n \t/* See comment in handle_pte_fault() */\n \tif (pmd_devmap_trans_unstable(vmf->pmd)) {\n \t\tfolio_unlock(folio);\n-\t\tfolio_put(folio);\n+\t\tif (folio)\n+folio_put(folio);\n \t\treturn true;\n \t}\n \n@@ -3458,7 +3481,8 @@ static struct folio *next_uptodate_page(struct folio *folio,\n unlock:\n \t\tfolio_unlock(folio);\n skip:\n-\t\tfolio_put(folio);\n+\t\tif (folio)\n+folio_put(folio);\n \t} while ((folio = xas_next_entry(xas, end_pgoff)) != NULL);\n \n \treturn NULL;\n@@ -3547,7 +3571,8 @@ vm_fault_t filemap_map_pages(struct vm_fault *vmf,\n \t\t\tgoto again;\n \t\t}\n \t\tfolio_unlock(folio);\n-\t\tfolio_put(folio);\n+\t\tif (folio)\n+folio_put(folio);\n \t} while ((folio = next_map_page(mapping, &xas, end_pgoff)) != NULL);\n \tpte_unmap_unlock(vmf->pte, vmf->ptl);\n out:\n@@ -3646,7 +3671,8 @@ static struct folio *do_read_cache_folio(struct address_space *mapping,\n \t\t\treturn ERR_PTR(-ENOMEM);\n \t\terr = filemap_add_folio(mapping, folio, index, gfp);\n \t\tif (unlikely(err)) {\n-\t\t\tfolio_put(folio);\n+\t\t\tif (folio)\n+folio_put(folio);\n \t\t\tif (err == -EEXIST)\n \t\t\t\tgoto repeat;\n \t\t\t/* Presumably ENOMEM for xarray node */\n@@ -3666,7 +3692,8 @@ static struct folio *do_read_cache_folio(struct address_space *mapping,\n \t/* Folio was truncated from mapping */\n \tif (!folio->mapping) {\n \t\tfolio_unlock(folio);\n-\t\tfolio_put(folio);\n+\t\tif (folio)\n+folio_put(folio);\n \t\tgoto repeat;\n \t}\n \n@@ -3679,7 +3706,8 @@ static struct folio *do_read_cache_folio(struct address_space *mapping,\n filler:\n \terr = filemap_read_folio(file, filler, folio);\n \tif (err) {\n-\t\tfolio_put(folio);\n+\t\tif (folio)\n+folio_put(folio);\n \t\tif (err == AOP_TRUNCATED_PAGE)\n \t\t\tgoto repeat;\n \t\treturn ERR_PTR(err);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/mm/filemap.c b/mm/filemap.c\nindex a34abfe8c654..20d97f33b22a 100644\n--- a/mm/filemap.c\n+++ b/mm/filemap.c\n@@ -3260,6 +3260,13 @@ vm_fault_t filemap_fault(struct vm_fault *vmf)\n \t * Do we have something in the page cache already?\n \t */\n \tfolio = filemap_get_folio(mapping, index);\n+    if (!folio) {\n+        if (fpin)\n+            goto out_retry;\n+        if (mapping_locked)\n+            filemap_invalidate_unlock_shared(mapping);\n+        return VM_FAULT_OOM;\n+    }\n \tif (likely(!IS_ERR(folio))) {\n \t\t/*\n \t\t * We found the page, so try async readahead before waiting for\n@@ -3287,6 +3294,13 @@ vm_fault_t filemap_fault(struct vm_fault *vmf)\n \t\t\tmapping_locked = true;\n \t\t}\n \t\tfolio = __filemap_get_folio(mapping, index,\n+    if (!folio) {\n+        if (fpin)\n+            goto out_retry;\n+        if (mapping_locked)\n+            filemap_invalidate_unlock_shared(mapping);\n+        return VM_FAULT_OOM;\n+    }\n \t\t\t\t\t  FGP_CREAT|FGP_FOR_MMAP,\n \t\t\t\t\t  vmf->gfp_mask);\n \t\tif (IS_ERR(folio)) {\n@@ -3640,6 +3654,13 @@ static struct folio *do_read_cache_folio(struct address_space *mapping,\n \t\tfiller = mapping->a_ops->read_folio;\n repeat:\n \tfolio = filemap_get_folio(mapping, index);\n+    if (!folio) {\n+        if (fpin)\n+            goto out_retry;\n+        if (mapping_locked)\n+            filemap_invalidate_unlock_shared(mapping);\n+        return VM_FAULT_OOM;\n+    }\n \tif (IS_ERR(folio)) {\n \t\tfolio = filemap_alloc_folio(gfp, 0);\n \t\tif (!folio)\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "64619c0d6d2ef98d85b7bb4ff271bfa9df74ce03": {
        "non_crash": [
            "diff --git a/fs/ext4/mballoc.c b/fs/ext4/mballoc.c\nindex 9dad93059945..d53ddb7efdff 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+        /* Handle insufficient preallocated space */\n+        return; /* Or take appropriate action */\n+    }\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": [
            "diff --git a/fs/ext4/mballoc.c b/fs/ext4/mballoc.c\nindex 9dad93059945..190f7a9a18d7 100644\n--- a/fs/ext4/mballoc.c\n+++ b/fs/ext4/mballoc.c\n@@ -4291,7 +4291,9 @@ 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+\tmb_debug(ac->ac_sb, \"pa_free before: %u, len: %d\\n\", pa->pa_free, len);\n+    BUG_ON(pa->pa_free < len);\n+    mb_debug(ac->ac_sb, \"pa_free after: %u\\n\", pa->pa_free);\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..293f8fe88a29 100644\n--- a/fs/ext4/mballoc.c\n+++ b/fs/ext4/mballoc.c\n@@ -4291,7 +4291,11 @@ 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 (unlikely(pa->pa_free < len)) {\n+spin_unlock(&pa->pa_lock);\n+return;\n+}\n+pa->pa_free -= len;\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..cfd3a0c6a067 100644\n--- a/fs/ext4/mballoc.c\n+++ b/fs/ext4/mballoc.c\n@@ -4387,7 +4387,7 @@ ext4_mb_use_preallocated(struct ext4_allocation_context *ac)\n \n \t\t/* found preallocated blocks, use them */\n \t\tspin_lock(&pa->pa_lock);\n-\t\tif (pa->pa_deleted == 0 && pa->pa_free) {\n+\t\tif (pa->pa_deleted == 0 && pa->pa_free >= ac->ac_o_ex.fe_len) {\n \t\t\tatomic_inc(&pa->pa_count);\n \t\t\text4_mb_use_inode_pa(ac, pa);\n \t\t\tspin_unlock(&pa->pa_lock);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/mballoc.c b/fs/ext4/mballoc.c\nindex 9dad93059945..dd461a218ab2 100644\n--- a/fs/ext4/mballoc.c\n+++ b/fs/ext4/mballoc.c\n@@ -4291,7 +4291,11 @@ 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 (unlikely(pa->pa_free < len)) {\n+    pr_err(\"ext4_mb_use_inode_pa: insufficient free blocks, pa_free=%d, len=%d\\n\", pa->pa_free, len);\n+    return -ENOSPC;\n+}\n+\n \tpa->pa_free -= len;\n \n \tmb_debug(ac->ac_sb, \"use %llu/%d from inode pa %p\\n\", start, len, pa);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "e58343393efd3e0657ca37cf4466fc38d1f4d4df": {
        "non_crash": [
            "diff --git a/drivers/dma-buf/udmabuf.c b/drivers/dma-buf/udmabuf.c\nindex 38e8767ec371..f649ed31ede2 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 && !IS_ERR(ubuf->sg))\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..f6863fcb9ce7 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 && !IS_ERR_OR_NULL(ubuf->sg))\n \t\tput_sg_table(dev, ubuf->sg, DMA_BIDIRECTIONAL);\n \n \tfor (pg = 0; pg < ubuf->pagecount; pg++)\n"
        ],
        "special_crash": [],
        "crash": [
            "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"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/dma-buf/udmabuf.c b/drivers/dma-buf/udmabuf.c\nindex 38e8767ec371..3100475804a5 100644\n--- a/drivers/dma-buf/udmabuf.c\n+++ b/drivers/dma-buf/udmabuf.c\n@@ -48,6 +48,7 @@ static const struct vm_operations_struct udmabuf_vm_ops = {\n static int mmap_udmabuf(struct dma_buf *buf, struct vm_area_struct *vma)\n {\n \tstruct udmabuf *ubuf = buf->priv;\n+    if (!ubuf) return;\n \n \tif ((vma->vm_flags & (VM_SHARED | VM_MAYSHARE)) == 0)\n \t\treturn -EINVAL;\n@@ -61,6 +62,7 @@ static struct sg_table *get_sg_table(struct device *dev, struct dma_buf *buf,\n \t\t\t\t     enum dma_data_direction direction)\n {\n \tstruct udmabuf *ubuf = buf->priv;\n+    if (!ubuf) return;\n \tstruct sg_table *sg;\n \tint ret;\n \n@@ -107,6 +109,7 @@ 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+    if (!ubuf) return;\n \tstruct device *dev = ubuf->device->this_device;\n \tpgoff_t pg;\n \n@@ -123,6 +126,7 @@ static int begin_cpu_udmabuf(struct dma_buf *buf,\n \t\t\t     enum dma_data_direction direction)\n {\n \tstruct udmabuf *ubuf = buf->priv;\n+    if (!ubuf) return;\n \tstruct device *dev = ubuf->device->this_device;\n \n \tif (!ubuf->sg) {\n@@ -141,6 +145,7 @@ static int end_cpu_udmabuf(struct dma_buf *buf,\n \t\t\t   enum dma_data_direction direction)\n {\n \tstruct udmabuf *ubuf = buf->priv;\n+    if (!ubuf) return;\n \tstruct device *dev = ubuf->device->this_device;\n \n \tif (!ubuf->sg)\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "362b5b49fced29361c0ba3007a2b3e5cd13776b5": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c\nindex c447526288f4..91c3a1a908d7 100644\n--- a/drivers/infiniband/core/cma.c\n+++ b/drivers/infiniband/core/cma.c\n@@ -2596,7 +2596,9 @@ static int cma_listen_on_all(struct rdma_id_private *id_priv)\n \t\tif (ret) {\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\t\tmutex_lock(&lock);\n+list_del_init(&to_destroy->device_item);\n+mutex_unlock(&lock);\n \t\t\tgoto err_listen;\n \t\t}\n \t}\n",
            "diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c\nindex c447526288f4..45942a62f726 100644\n--- a/drivers/infiniband/core/cma.c\n+++ b/drivers/infiniband/core/cma.c\n@@ -2595,7 +2595,8 @@ 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\tmutex_lock(&lock);\n+    if (to_destroy)\n \t\t\t\tlist_del_init(&to_destroy->device_item);\n \t\t\tgoto err_listen;\n \t\t}\n@@ -2606,7 +2607,8 @@ static int cma_listen_on_all(struct rdma_id_private *id_priv)\n err_listen:\n \t_cma_cancel_listens(id_priv);\n \tmutex_unlock(&lock);\n-\tif (to_destroy)\n+\tmutex_lock(&lock);\n+    if (to_destroy)\n \t\trdma_destroy_id(&to_destroy->id);\n \treturn ret;\n }\n",
            "diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c\nindex c447526288f4..67c90bc5b1b3 100644\n--- a/drivers/infiniband/core/cma.c\n+++ b/drivers/infiniband/core/cma.c\n@@ -2608,6 +2608,8 @@ static int cma_listen_on_all(struct rdma_id_private *id_priv)\n \tmutex_unlock(&lock);\n \tif (to_destroy)\n \t\trdma_destroy_id(&to_destroy->id);\n+\n+to_destroy = NULL;\n \treturn ret;\n }\n \n",
            "diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c\nindex c447526288f4..8c83c36ec92f 100644\n--- a/drivers/infiniband/core/cma.c\n+++ b/drivers/infiniband/core/cma.c\n@@ -2608,6 +2608,7 @@ static int cma_listen_on_all(struct rdma_id_private *id_priv)\n \tmutex_unlock(&lock);\n \tif (to_destroy)\n \t\trdma_destroy_id(&to_destroy->id);\n+to_destroy = NULL;\n \treturn ret;\n }\n \n"
        ],
        "error": []
    },
    "ecd1f6c4b2442ea4c47c7331ed1c27c0cfdc627e": {
        "non_crash": [
            "diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c\nindex 2b5ef1b64249..ed5752190a03 100644\n--- a/fs/ext4/inode.c\n+++ b/fs/ext4/inode.c\n@@ -364,7 +364,8 @@ void ext4_da_update_reserve_space(struct inode *inode,\n \t\t\t \"with only %d reserved data blocks\",\n \t\t\t __func__, inode->i_ino, used,\n \t\t\t ei->i_reserved_data_blocks);\n-\t\tWARN_ON(1);\n+\t\t/* Log the mismatch without causing a crash */\n+ext4_warning(inode->i_sb, \"Mismatch in reserved blocks for inode: %lu\", inode->i_ino);\n \t\tused = ei->i_reserved_data_blocks;\n \t}\n \n@@ -579,7 +580,8 @@ int ext4_map_blocks(handle_t *handle, struct inode *inode,\n \t\t\t\t     \"ES len assertion failed for inode \"\n \t\t\t\t     \"%lu: retval %d != map->m_len %d\",\n \t\t\t\t     inode->i_ino, retval, map->m_len);\n-\t\t\tWARN_ON(1);\n+\t\t\t/* Log the mismatch without causing a crash */\n+ext4_warning(inode->i_sb, \"Mismatch in reserved blocks for inode: %lu\", inode->i_ino);\n \t\t}\n \n \t\tstatus = map->m_flags & EXT4_MAP_UNWRITTEN ?\n@@ -674,7 +676,8 @@ int ext4_map_blocks(handle_t *handle, struct inode *inode,\n \t\t\t\t     \"ES len assertion failed for inode \"\n \t\t\t\t     \"%lu: retval %d != map->m_len %d\",\n \t\t\t\t     inode->i_ino, retval, map->m_len);\n-\t\t\tWARN_ON(1);\n+\t\t\t/* Log the mismatch without causing a crash */\n+ext4_warning(inode->i_sb, \"Mismatch in reserved blocks for inode: %lu\", inode->i_ino);\n \t\t}\n \n \t\t/*\n@@ -1525,7 +1528,8 @@ void ext4_da_release_space(struct inode *inode, int to_free)\n \t\t\t \"ino %lu, to_free %d with only %d reserved \"\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/* Log the mismatch without causing a crash */\n+ext4_warning(inode->i_sb, \"Mismatch in reserved blocks for inode: %lu\", inode->i_ino);\n \t\tto_free = ei->i_reserved_data_blocks;\n \t}\n \tei->i_reserved_data_blocks -= to_free;\n@@ -1811,7 +1815,8 @@ static int ext4_da_map_blocks(struct inode *inode, sector_t iblock,\n \t\t\t\t     \"ES len assertion failed for inode \"\n \t\t\t\t     \"%lu: retval %d != map->m_len %d\",\n \t\t\t\t     inode->i_ino, retval, map->m_len);\n-\t\t\tWARN_ON(1);\n+\t\t\t/* Log the mismatch without causing a crash */\n+ext4_warning(inode->i_sb, \"Mismatch in reserved blocks for inode: %lu\", inode->i_ino);\n \t\t}\n \n \t\tstatus = map->m_flags & EXT4_MAP_UNWRITTEN ?\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c\nindex 2b5ef1b64249..f7d32758f3bd 100644\n--- a/fs/ext4/inode.c\n+++ b/fs/ext4/inode.c\n@@ -1514,7 +1514,7 @@ void ext4_da_release_space(struct inode *inode, int to_free)\n \tspin_lock(&EXT4_I(inode)->i_block_reservation_lock);\n \n \ttrace_ext4_da_release_space(inode, to_free);\n-\tif (unlikely(to_free > ei->i_reserved_data_blocks)) {\n+\tif (unlikely(to_free > ei->i_reserved_data_blocks) || ei->i_reserved_data_blocks < 0) {\n \t\t/*\n \t\t * if there aren't enough reserved blocks, then the\n \t\t * counter is messed up somewhere.  Since this\n",
            "diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c\nindex 2b5ef1b64249..de468ead8133 100644\n--- a/fs/ext4/inode.c\n+++ b/fs/ext4/inode.c\n@@ -1496,7 +1496,8 @@ static int ext4_da_reserve_space(struct inode *inode)\n \t\tdquot_release_reservation_block(inode, EXT4_C2B(sbi, 1));\n \t\treturn -ENOSPC;\n \t}\n-\tei->i_reserved_data_blocks++;\n+\tif (ei->i_reserved_data_blocks < UINT_MAX)\n+    ei->i_reserved_data_blocks++;\n \ttrace_ext4_da_reserve_space(inode);\n \tspin_unlock(&ei->i_block_reservation_lock);\n \n@@ -1528,7 +1529,10 @@ 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+    ei->i_reserved_data_blocks -= to_free;\n+else\n+    ei->i_reserved_data_blocks = 0;\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..af9c1bacbc2c 100644\n--- a/fs/ext4/inode.c\n+++ b/fs/ext4/inode.c\n@@ -1496,7 +1496,11 @@ static int ext4_da_reserve_space(struct inode *inode)\n \t\tdquot_release_reservation_block(inode, EXT4_C2B(sbi, 1));\n \t\treturn -ENOSPC;\n \t}\n-\tei->i_reserved_data_blocks++;\n+\tif (unlikely(ei->i_reserved_data_blocks == UINT_MAX)) {\n+        ext4_warning(inode->i_sb, \"ext4_da_reserve_space: inode %lu, exceeded max reserved blocks\", inode->i_ino);\n+        return -ENOSPC;\n+    }\n+ei->i_reserved_data_blocks++;\n \ttrace_ext4_da_reserve_space(inode);\n \tspin_unlock(&ei->i_block_reservation_lock);\n \n",
            "diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c\nindex 2b5ef1b64249..19c11cc51d98 100644\n--- a/fs/ext4/inode.c\n+++ b/fs/ext4/inode.c\n@@ -1496,7 +1496,11 @@ static int ext4_da_reserve_space(struct inode *inode)\n \t\tdquot_release_reservation_block(inode, EXT4_C2B(sbi, 1));\n \t\treturn -ENOSPC;\n \t}\n-\tei->i_reserved_data_blocks++;\n+\tif (unlikely(ei->i_reserved_data_blocks + 1 < ei->i_reserved_data_blocks)) {\n+        ext4_warning(inode->i_sb, \"ext4_da_reserve_space: potential overflow detected\");\n+        WARN_ON(1);\n+    }\n+    ei->i_reserved_data_blocks++;\n \ttrace_ext4_da_reserve_space(inode);\n \tspin_unlock(&ei->i_block_reservation_lock);\n \n"
        ],
        "error": []
    },
    "9b857c714d3e890900acbe48172866a93ab8589a": {
        "non_crash": [
            "diff --git a/sound/core/oss/pcm_plugin.c b/sound/core/oss/pcm_plugin.c\nindex d5ca161d588c..9a171793feac 100644\n--- a/sound/core/oss/pcm_plugin.c\n+++ b/sound/core/oss/pcm_plugin.c\n@@ -489,7 +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\tif (!snd_pcm_format_linear(srcformat.format)) {\n+            tmpformat.format = SNDRV_PCM_FORMAT_S16;\n+        }\n+        if (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",
            "diff --git a/sound/core/oss/mulaw.c b/sound/core/oss/mulaw.c\nindex 3788906421a7..85794e3150b6 100644\n--- a/sound/core/oss/mulaw.c\n+++ b/sound/core/oss/mulaw.c\n@@ -329,7 +329,10 @@ int snd_pcm_plugin_build_mulaw(struct snd_pcm_substream *plug,\n \t\tsnd_BUG();\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+    pr_warn(\"snd_pcm_plugin_build_mulaw: Non-linear format encountered\\n\");\n+    return -ENXIO;\n+}\n \t\treturn -ENXIO;\n \n \terr = snd_pcm_plugin_build(plug, \"Mu-Law<->linear conversion\",\n",
            "diff --git a/sound/core/oss/mulaw.c b/sound/core/oss/mulaw.c\nindex 3788906421a7..e74dc6725363 100644\n--- a/sound/core/oss/mulaw.c\n+++ b/sound/core/oss/mulaw.c\n@@ -329,7 +329,9 @@ int snd_pcm_plugin_build_mulaw(struct snd_pcm_substream *plug,\n \t\tsnd_BUG();\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+    return -EINVAL;\n+}\n \t\treturn -ENXIO;\n \n \terr = snd_pcm_plugin_build(plug, \"Mu-Law<->linear conversion\",\n",
            "diff --git a/sound/core/oss/mulaw.c b/sound/core/oss/mulaw.c\nindex 3788906421a7..e3a29b18d78c 100644\n--- a/sound/core/oss/mulaw.c\n+++ b/sound/core/oss/mulaw.c\n@@ -329,7 +329,10 @@ int snd_pcm_plugin_build_mulaw(struct snd_pcm_substream *plug,\n \t\tsnd_BUG();\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+        snd_BUG();\n+        return -EINVAL;\n+    }\n \t\treturn -ENXIO;\n \n \terr = snd_pcm_plugin_build(plug, \"Mu-Law<->linear conversion\",\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/sound/core/oss/mulaw.c b/sound/core/oss/mulaw.c\nindex 3788906421a7..cfc05d446b25 100644\n--- a/sound/core/oss/mulaw.c\n+++ b/sound/core/oss/mulaw.c\n@@ -90,7 +90,9 @@ static unsigned char linear2ulaw(int pcm_val)\t/* 2's complement (16-bit range) *\n \tif (pcm_val < 0) {\n \t\tpcm_val = BIAS - pcm_val;\n \t\tmask = 0x7F;\n-\t} else {\n+\t} else if (!snd_pcm_format_linear(src_format->format) || !snd_pcm_format_linear(dst_format->format)) {\n+        return -EINVAL;\n+    } else {\n \t\tpcm_val += BIAS;\n \t\tmask = 0xFF;\n \t}\n@@ -290,7 +292,9 @@ static void init_data(struct mulaw_priv *data, snd_pcm_format_t format)\n \tif (snd_pcm_format_little_endian(format)) {\n \t\tdata->native_ofs = data->native_bytes - data->copy_bytes;\n \t\tdata->copy_ofs = 2 - data->copy_bytes;\n-\t} else {\n+\t} else if (!snd_pcm_format_linear(src_format->format) || !snd_pcm_format_linear(dst_format->format)) {\n+        return -EINVAL;\n+    } else {\n \t\t/* S24 in 4bytes need an 1 byte offset */\n \t\tdata->native_ofs = data->native_bytes -\n \t\t\tsnd_pcm_format_width(format) / 8;\n@@ -325,7 +329,9 @@ 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+        return -EINVAL;\n+    } else {\n \t\tsnd_BUG();\n \t\treturn -EINVAL;\n \t}\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "0518799fc2250353125d212fc510c44adbde73c3": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/drivers/net/wireless/ath/ath9k/hif_usb.c b/drivers/net/wireless/ath/ath9k/hif_usb.c\nindex 86ede591dafa..564f5f950d69 100644\n--- a/drivers/net/wireless/ath/ath9k/hif_usb.c\n+++ b/drivers/net/wireless/ath/ath9k/hif_usb.c\n@@ -92,7 +92,8 @@ static void hif_usb_regout_cb(struct urb *urb)\n \t\tkfree(cmd);\n \t}\n \n-\treturn;\n+\tkfree_skb(skb);\n+return;\n free:\n \tkfree_skb(cmd->skb);\n \tkfree(cmd);\n@@ -142,7 +143,8 @@ static void hif_usb_mgmt_cb(struct urb *urb)\n \tbool txok = true;\n \n \tif (!cmd || !cmd->skb || !cmd->hif_dev)\n-\t\treturn;\n+\t\tkfree_skb(skb);\n+return;\n \n \thif_dev = cmd->hif_dev;\n \n@@ -164,7 +166,8 @@ static void hif_usb_mgmt_cb(struct urb *urb)\n \t\t\tspin_unlock_irqrestore(&hif_dev->tx.tx_lock, flags);\n \t\t\tdev_kfree_skb_any(cmd->skb);\n \t\t\tkfree(cmd);\n-\t\t\treturn;\n+\t\t\tkfree_skb(skb);\n+return;\n \t\t}\n \t\tspin_unlock_irqrestore(&hif_dev->tx.tx_lock, flags);\n \n@@ -259,7 +262,8 @@ static void hif_usb_tx_cb(struct urb *urb)\n \tbool txok = true;\n \n \tif (!tx_buf || !tx_buf->hif_dev)\n-\t\treturn;\n+\t\tkfree_skb(skb);\n+return;\n \n \thif_dev = tx_buf->hif_dev;\n \n@@ -280,7 +284,8 @@ static void hif_usb_tx_cb(struct urb *urb)\n \t\tif (hif_dev->tx.flags & HIF_USB_TX_FLUSH) {\n \t\t\tspin_unlock(&hif_dev->tx.tx_lock);\n \t\t\tath9k_skb_queue_purge(hif_dev, &tx_buf->skb_queue);\n-\t\t\treturn;\n+\t\t\tkfree_skb(skb);\n+return;\n \t\t}\n \t\tspin_unlock(&hif_dev->tx.tx_lock);\n \n@@ -586,14 +591,16 @@ static void ath9k_hif_usb_rx_stream(struct hif_device_usb *hif_dev,\n \n \t\tif (pkt_tag != ATH_USB_RX_STREAM_MODE_TAG) {\n \t\t\tRX_STAT_INC(hif_dev, skb_dropped);\n-\t\t\treturn;\n+\t\t\tkfree_skb(skb);\n+return;\n \t\t}\n \n \t\tif (pkt_len > 2 * MAX_RX_BUF_SIZE) {\n \t\t\tdev_err(&hif_dev->udev->dev,\n \t\t\t\t\"ath9k_htc: invalid pkt_len (%x)\\n\", pkt_len);\n \t\t\tRX_STAT_INC(hif_dev, skb_dropped);\n-\t\t\treturn;\n+\t\t\tkfree_skb(skb);\n+return;\n \t\t}\n \n \t\tpad_len = 4 - (pkt_len & 0x3);\n@@ -664,7 +671,8 @@ static void ath9k_hif_usb_rx_cb(struct urb *urb)\n \tint ret;\n \n \tif (!skb)\n-\t\treturn;\n+\t\tkfree_skb(skb);\n+return;\n \n \tif (!hif_dev)\n \t\tgoto free;\n@@ -697,7 +705,8 @@ static void ath9k_hif_usb_rx_cb(struct urb *urb)\n \t\tgoto free;\n \t}\n \n-\treturn;\n+\tkfree_skb(skb);\n+return;\n free:\n \tkfree_skb(skb);\n \tkfree(rx_buf);\n@@ -711,7 +720,8 @@ static void ath9k_hif_usb_reg_in_cb(struct urb *urb)\n \tint ret;\n \n \tif (!skb)\n-\t\treturn;\n+\t\tkfree_skb(skb);\n+return;\n \n \tif (!hif_dev)\n \t\tgoto free_skb;\n@@ -766,7 +776,8 @@ static void ath9k_hif_usb_reg_in_cb(struct urb *urb)\n \t\tgoto free_skb;\n \t}\n \n-\treturn;\n+\tkfree_skb(skb);\n+return;\n free_skb:\n \tkfree_skb(skb);\n free_rx_buf:\n@@ -1218,7 +1229,8 @@ static void ath9k_hif_usb_firmware_cb(const struct firmware *fw, void *context)\n \tif (!fw) {\n \t\tret = ath9k_hif_request_firmware(hif_dev, false);\n \t\tif (!ret)\n-\t\t\treturn;\n+\t\t\tkfree_skb(skb);\n+return;\n \n \t\tdev_err(&hif_dev->udev->dev,\n \t\t\t\"ath9k_htc: Failed to get firmware %s\\n\",\n@@ -1254,7 +1266,8 @@ static void ath9k_hif_usb_firmware_cb(const struct firmware *fw, void *context)\n \thif_dev->flags |= HIF_USB_READY;\n \tcomplete_all(&hif_dev->fw_done);\n \n-\treturn;\n+\tkfree_skb(skb);\n+return;\n \n err_htc_hw_init:\n \tath9k_hif_usb_dev_deinit(hif_dev);\n@@ -1388,7 +1401,8 @@ static void ath9k_hif_usb_reboot(struct usb_device *udev)\n \n \tbuf = kmemdup(&reboot_cmd, 4, GFP_KERNEL);\n \tif (!buf)\n-\t\treturn;\n+\t\tkfree_skb(skb);\n+return;\n \n \tret = usb_interrupt_msg(udev, usb_sndintpipe(udev, USB_REG_OUT_PIPE),\n \t\t\t   buf, 4, NULL, USB_MSG_TIMEOUT);\n@@ -1405,7 +1419,8 @@ static void ath9k_hif_usb_disconnect(struct usb_interface *interface)\n \tbool unplugged = (udev->state == USB_STATE_NOTATTACHED) ? true : false;\n \n \tif (!hif_dev)\n-\t\treturn;\n+\t\tkfree_skb(skb);\n+return;\n \n \twait_for_completion(&hif_dev->fw_done);\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/net/ethernet/intel/e1000e/netdev.c b/drivers/net/ethernet/intel/e1000e/netdev.c\nindex 36bc4fd91ef4..b36cd5215617 100644\n--- a/drivers/net/ethernet/intel/e1000e/netdev.c\n+++ b/drivers/net/ethernet/intel/e1000e/netdev.c\n@@ -679,6 +679,7 @@ static void e1000_alloc_rx_buffers(struct e1000_ring *rx_ring,\n \t\t\t\t\t\t  adapter->rx_buffer_len,\n \t\t\t\t\t\t  DMA_FROM_DEVICE);\n \t\tif (dma_mapping_error(&pdev->dev, buffer_info->dma)) {\n+kfree_skb(skb);) {\n \t\t\tdev_err(&pdev->dev, \"Rx DMA map failed\\n\");\n \t\t\tadapter->rx_dma_failed++;\n \t\t\tbreak;\n@@ -779,6 +780,7 @@ static void e1000_alloc_rx_buffers_ps(struct e1000_ring *rx_ring,\n \t\t\t\t\t\t  adapter->rx_ps_bsize0,\n \t\t\t\t\t\t  DMA_FROM_DEVICE);\n \t\tif (dma_mapping_error(&pdev->dev, buffer_info->dma)) {\n+kfree_skb(skb);) {\n \t\t\tdev_err(&pdev->dev, \"Rx DMA map failed\\n\");\n \t\t\tadapter->rx_dma_failed++;\n \t\t\t/* cleanup skb */\n@@ -865,6 +867,7 @@ static void e1000_alloc_jumbo_rx_buffers(struct e1000_ring *rx_ring,\n \t\t\t\t\t\t\tPAGE_SIZE,\n \t\t\t\t\t\t\tDMA_FROM_DEVICE);\n \t\t\tif (dma_mapping_error(&pdev->dev, buffer_info->dma)) {\n+kfree_skb(skb);) {\n \t\t\t\tadapter->alloc_rx_buff_failed++;\n \t\t\t\tbreak;\n \t\t\t}\n@@ -5594,7 +5597,8 @@ static int e1000_tx_map(struct e1000_ring *tx_ring, struct sk_buff *skb,\n \t\t\t\t\t\t  skb->data + offset,\n \t\t\t\t\t\t  size, DMA_TO_DEVICE);\n \t\tbuffer_info->mapped_as_page = false;\n-\t\tif (dma_mapping_error(&pdev->dev, buffer_info->dma))\n+\t\tif (dma_mapping_error(&pdev->dev, buffer_info->dma)) {\n+kfree_skb(skb);)\n \t\t\tgoto dma_error;\n \n \t\tlen -= size;\n@@ -5629,7 +5633,8 @@ static int e1000_tx_map(struct e1000_ring *tx_ring, struct sk_buff *skb,\n \t\t\t\t\t\t\t    offset, size,\n \t\t\t\t\t\t\t    DMA_TO_DEVICE);\n \t\t\tbuffer_info->mapped_as_page = true;\n-\t\t\tif (dma_mapping_error(&pdev->dev, buffer_info->dma))\n+\t\t\tif (dma_mapping_error(&pdev->dev, buffer_info->dma)) {\n+kfree_skb(skb);)\n \t\t\t\tgoto dma_error;\n \n \t\t\tlen -= size;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "0084fd109a7a10011e183a357715c91cff2cacb0": {
        "non_crash": [
            "diff --git a/mm/huge_memory.c b/mm/huge_memory.c\nindex f2d19e4fe854..390b0ea30a7f 100644\n--- a/mm/huge_memory.c\n+++ b/mm/huge_memory.c\n@@ -632,7 +632,11 @@ static vm_fault_t __do_huge_pmd_anonymous_page(struct vm_fault *vmf,\n static inline gfp_t alloc_hugepage_direct_gfpmask(struct vm_area_struct *vma, unsigned long addr)\n {\n \tconst bool vma_madvised = !!(vma->vm_flags & VM_HUGEPAGE);\n-\tconst gfp_t gfp_mask = GFP_TRANSHUGE_LIGHT | __GFP_THISNODE;\n+\tgfp_t gfp_mask = GFP_TRANSHUGE_LIGHT;\n+\n+/* Exclude __GFP_THISNODE if MPOL_BIND is active */\n+if (vma->vm_policy && vma->vm_policy->mode != MPOL_BIND)\n+gfp_mask |= __GFP_THISNODE;\n \n \t/* Always do synchronous compaction */\n \tif (test_bit(TRANSPARENT_HUGEPAGE_DEFRAG_DIRECT_FLAG, &transparent_hugepage_flags))\n",
            "diff --git a/mm/mempolicy.c b/mm/mempolicy.c\nindex 69e278b469ef..a1d592ab960e 100644\n--- a/mm/mempolicy.c\n+++ b/mm/mempolicy.c\n@@ -2040,7 +2040,10 @@ alloc_pages_vma(gfp_t gfp, int order, struct vm_area_struct *vma,\n \t}\n \n \tnmask = policy_nodemask(gfp, pol);\n-\tpreferred_nid = policy_node(gfp, pol, node);\n+\tif (!(pol->mode == MPOL_BIND && (gfp & __GFP_THISNODE)))\n+        preferred_nid = policy_node(gfp, pol, node);\n+    else\n+        preferred_nid = node;\n \tpage = __alloc_pages_nodemask(gfp, order, preferred_nid, nmask);\n \tmpol_cond_put(pol);\n out:\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/mm/huge_memory.c b/mm/huge_memory.c\nindex f2d19e4fe854..16bddef1b6fb 100644\n--- a/mm/huge_memory.c\n+++ b/mm/huge_memory.c\n@@ -632,7 +632,10 @@ static vm_fault_t __do_huge_pmd_anonymous_page(struct vm_fault *vmf,\n static inline gfp_t alloc_hugepage_direct_gfpmask(struct vm_area_struct *vma, unsigned long addr)\n {\n \tconst bool vma_madvised = !!(vma->vm_flags & VM_HUGEPAGE);\n-\tconst gfp_t gfp_mask = GFP_TRANSHUGE_LIGHT | __GFP_THISNODE;\n+\tgfp_t gfp_mask = GFP_TRANSHUGE_LIGHT;\n+    if (vma->vm_policy->mode != MPOL_BIND) {\n+        gfp_mask |= __GFP_THISNODE;\n+    }\n \n \t/* Always do synchronous compaction */\n \tif (test_bit(TRANSPARENT_HUGEPAGE_DEFRAG_DIRECT_FLAG, &transparent_hugepage_flags))\n",
                "error_message": "Failed to set up instance"
            },
            {
                "patch": "diff --git a/mm/mempolicy.c b/mm/mempolicy.c\nindex 69e278b469ef..bc68c50ac67d 100644\n--- a/mm/mempolicy.c\n+++ b/mm/mempolicy.c\n@@ -2040,7 +2040,10 @@ alloc_pages_vma(gfp_t gfp, int order, struct vm_area_struct *vma,\n \t}\n \n \tnmask = policy_nodemask(gfp, pol);\n-\tpreferred_nid = policy_node(gfp, pol, node);\n+\tpreferred_nid = if (pol->mode == MPOL_BIND) {\n+        gfp &= ~__GFP_THISNODE;\n+    }\n+    policy_node(gfp, pol, node);\n \tpage = __alloc_pages_nodemask(gfp, order, preferred_nid, nmask);\n \tmpol_cond_put(pol);\n out:\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/mm/mempolicy.c b/mm/mempolicy.c\nindex 69e278b469ef..ede7df57c812 100644\n--- a/mm/mempolicy.c\n+++ b/mm/mempolicy.c\n@@ -941,7 +941,7 @@ struct page *alloc_new_node_page(struct page *page, unsigned long node)\n \t\tstruct page *thp;\n \n \t\tthp = alloc_pages_node(node,\n-\t\t\t(GFP_TRANSHUGE | __GFP_THISNODE),\n+\t\t\t(GFP_TRANSHUGE | ((policy->mode != MPOL_BIND) ? __GFP_THISNODE : 0)),\n \t\t\tHPAGE_PMD_ORDER);\n \t\tif (!thp)\n \t\t\treturn NULL;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "4f6ce6f5223c2c8e75c92ce8cb619b227a8b0277": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/tipc/node.c b/net/tipc/node.c\nindex a4c2816c3746..74666d40b72d 100644\n--- a/net/tipc/node.c\n+++ b/net/tipc/node.c\n@@ -584,7 +584,7 @@ static void tipc_node_delete_from_list(struct tipc_node *node)\n {\n \tlist_del_rcu(&node->list);\n \thlist_del_rcu(&node->hash);\n-\ttipc_node_put(node);\n+\t// tipc_node_put(node);\n }\n \n static void tipc_node_delete(struct tipc_node *node)\n@@ -593,7 +593,7 @@ static void tipc_node_delete(struct tipc_node *node)\n \ttipc_node_delete_from_list(node);\n \n \tdel_timer_sync(&node->timer);\n-\ttipc_node_put(node);\n+\t// tipc_node_put(node);\n }\n \n void tipc_node_stop(struct net *net)\n@@ -670,7 +670,7 @@ int tipc_node_add_conn(struct net *net, u32 dnode, u32 port, u32 peer_port)\n \tlist_add_tail(&conn->list, &node->conn_sks);\n \ttipc_node_write_unlock(node);\n exit:\n-\ttipc_node_put(node);\n+\t// tipc_node_put(node);\n \treturn err;\n }\n \n@@ -694,7 +694,7 @@ void tipc_node_remove_conn(struct net *net, u32 dnode, u32 port)\n \t\tkfree(conn);\n \t}\n \ttipc_node_write_unlock(node);\n-\ttipc_node_put(node);\n+\t// tipc_node_put(node);\n }\n \n static void  tipc_node_clear_links(struct tipc_node *node)\n@@ -1538,7 +1538,7 @@ int tipc_node_get_linkname(struct net *net, u32 bearer_id, u32 addr,\n \t}\n \ttipc_node_read_unlock(node);\n exit:\n-\ttipc_node_put(node);\n+\t// tipc_node_put(node);\n \treturn err;\n }\n \n@@ -2253,7 +2253,7 @@ int tipc_nl_node_dump(struct sk_buff *skb, struct netlink_callback *cb)\n \t\t\tcb->prev_seq = 1;\n \t\t\treturn -EPIPE;\n \t\t}\n-\t\ttipc_node_put(node);\n+\t\t// tipc_node_put(node);\n \t}\n \n \tlist_for_each_entry_rcu(node, &tn->node_list, list) {\n@@ -2618,7 +2618,7 @@ 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+\t\t// tipc_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"
        ],
        "error": [
            {
                "patch": "diff --git a/net/tipc/node.c b/net/tipc/node.c\nindex a4c2816c3746..9b26508bc9bf 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] && !is_kmalloc_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"
            },
            {
                "patch": "diff --git a/net/tipc/node.c b/net/tipc/node.c\nindex a4c2816c3746..767f05148432 100644\n--- a/net/tipc/node.c\n+++ b/net/tipc/node.c\n@@ -2588,7 +2588,8 @@ int tipc_nl_node_dump_link(struct sk_buff *skb, struct netlink_callback *cb)\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\t\terr = nla_parse_nested_deprecated(link,\n+\t\t\terr = if (attrs[TIPC_NLA_LINK]) {\n+        err = 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 \t\t\t\t\t\t\t  tipc_nl_link_policy,\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/tipc/node.c b/net/tipc/node.c\nindex a4c2816c3746..0fbad53e0765 100644\n--- a/net/tipc/node.c\n+++ b/net/tipc/node.c\n@@ -584,7 +584,19 @@ static void tipc_node_delete_from_list(struct tipc_node *node)\n {\n \tlist_del_rcu(&node->list);\n \thlist_del_rcu(&node->hash);\n-\ttipc_node_put(node);\n+\t\n+        list_for_each_entry_continue_rcu(node, &tn->node_list, list) {\n+            tipc_node_read_lock(node);\n+            err = __tipc_nl_add_node_links(net, &msg, node,\n+                                           &prev_link, bc_link);\n+            tipc_node_read_unlock(node);\n+            if (err)\n+                goto out;\n+\n+            prev_node = node->addr;\n+        }\n+        tipc_node_put(node);\n+\n }\n \n static void tipc_node_delete(struct tipc_node *node)\n@@ -593,7 +605,19 @@ static void tipc_node_delete(struct tipc_node *node)\n \ttipc_node_delete_from_list(node);\n \n \tdel_timer_sync(&node->timer);\n-\ttipc_node_put(node);\n+\t\n+        list_for_each_entry_continue_rcu(node, &tn->node_list, list) {\n+            tipc_node_read_lock(node);\n+            err = __tipc_nl_add_node_links(net, &msg, node,\n+                                           &prev_link, bc_link);\n+            tipc_node_read_unlock(node);\n+            if (err)\n+                goto out;\n+\n+            prev_node = node->addr;\n+        }\n+        tipc_node_put(node);\n+\n }\n \n void tipc_node_stop(struct net *net)\n@@ -670,7 +694,19 @@ int tipc_node_add_conn(struct net *net, u32 dnode, u32 port, u32 peer_port)\n \tlist_add_tail(&conn->list, &node->conn_sks);\n \ttipc_node_write_unlock(node);\n exit:\n-\ttipc_node_put(node);\n+\t\n+        list_for_each_entry_continue_rcu(node, &tn->node_list, list) {\n+            tipc_node_read_lock(node);\n+            err = __tipc_nl_add_node_links(net, &msg, node,\n+                                           &prev_link, bc_link);\n+            tipc_node_read_unlock(node);\n+            if (err)\n+                goto out;\n+\n+            prev_node = node->addr;\n+        }\n+        tipc_node_put(node);\n+\n \treturn err;\n }\n \n@@ -694,7 +730,19 @@ void tipc_node_remove_conn(struct net *net, u32 dnode, u32 port)\n \t\tkfree(conn);\n \t}\n \ttipc_node_write_unlock(node);\n-\ttipc_node_put(node);\n+\t\n+        list_for_each_entry_continue_rcu(node, &tn->node_list, list) {\n+            tipc_node_read_lock(node);\n+            err = __tipc_nl_add_node_links(net, &msg, node,\n+                                           &prev_link, bc_link);\n+            tipc_node_read_unlock(node);\n+            if (err)\n+                goto out;\n+\n+            prev_node = node->addr;\n+        }\n+        tipc_node_put(node);\n+\n }\n \n static void  tipc_node_clear_links(struct tipc_node *node)\n@@ -1538,7 +1586,19 @@ int tipc_node_get_linkname(struct net *net, u32 bearer_id, u32 addr,\n \t}\n \ttipc_node_read_unlock(node);\n exit:\n-\ttipc_node_put(node);\n+\t\n+        list_for_each_entry_continue_rcu(node, &tn->node_list, list) {\n+            tipc_node_read_lock(node);\n+            err = __tipc_nl_add_node_links(net, &msg, node,\n+                                           &prev_link, bc_link);\n+            tipc_node_read_unlock(node);\n+            if (err)\n+                goto out;\n+\n+            prev_node = node->addr;\n+        }\n+        tipc_node_put(node);\n+\n \treturn err;\n }\n \n@@ -2253,7 +2313,19 @@ int tipc_nl_node_dump(struct sk_buff *skb, struct netlink_callback *cb)\n \t\t\tcb->prev_seq = 1;\n \t\t\treturn -EPIPE;\n \t\t}\n-\t\ttipc_node_put(node);\n+\t\t\n+        list_for_each_entry_continue_rcu(node, &tn->node_list, list) {\n+            tipc_node_read_lock(node);\n+            err = __tipc_nl_add_node_links(net, &msg, node,\n+                                           &prev_link, bc_link);\n+            tipc_node_read_unlock(node);\n+            if (err)\n+                goto out;\n+\n+            prev_node = node->addr;\n+        }\n+        tipc_node_put(node);\n+\n \t}\n \n \tlist_for_each_entry_rcu(node, &tn->node_list, list) {\n@@ -2618,7 +2690,19 @@ 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+\t\t\n+        list_for_each_entry_continue_rcu(node, &tn->node_list, list) {\n+            tipc_node_read_lock(node);\n+            err = __tipc_nl_add_node_links(net, &msg, node,\n+                                           &prev_link, bc_link);\n+            tipc_node_read_unlock(node);\n+            if (err)\n+                goto out;\n+\n+            prev_node = node->addr;\n+        }\n+        tipc_node_put(node);\n+\n \n \t\tlist_for_each_entry_continue_rcu(node, &tn->node_list,\n \t\t\t\t\t\t list) {\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/tipc/node.c b/net/tipc/node.c\nindex a4c2816c3746..99be70541f27 100644\n--- a/net/tipc/node.c\n+++ b/net/tipc/node.c\n@@ -2588,7 +2588,8 @@ int tipc_nl_node_dump_link(struct sk_buff *skb, struct netlink_callback *cb)\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\t\terr = nla_parse_nested_deprecated(link,\n+\t\t\tif (link) {\n+err = 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 \t\t\t\t\t\t\t  tipc_nl_link_policy,\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "b5d799a2cc619607ed6e322f97f78eaf534451e1": {
        "non_crash": [
            "diff --git a/fs/namei.c b/fs/namei.c\nindex 0cab6494978c..f9519f0ddc52 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -214,6 +214,8 @@ getname(const char __user * filename)\n struct filename *\n getname_kernel(const char * filename)\n {\n+    if (unlikely(!filename))\n+        return ERR_PTR(-EINVAL);\n \tstruct filename *result;\n \tint len = strlen(filename) + 1;\n \n",
            "diff --git a/fs/namei.c b/fs/namei.c\nindex 0cab6494978c..255723885e72 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -215,7 +215,9 @@ struct filename *\n getname_kernel(const char * filename)\n {\n \tstruct filename *result;\n-\tint len = strlen(filename) + 1;\n+\tif (!filename)\n+        return ERR_PTR(-EINVAL);\n+    int len = strlen(filename) + 1;\n \n \tresult = __getname();\n \tif (unlikely(!result))\n",
            "diff --git a/fs/namei.c b/fs/namei.c\nindex 0cab6494978c..01a5c7144409 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -215,7 +215,9 @@ struct filename *\n getname_kernel(const char * filename)\n {\n \tstruct filename *result;\n-\tint len = strlen(filename) + 1;\n+\tif (unlikely(!filename))\n+    return ERR_PTR(-EINVAL);\n+int len = strlen(filename) + 1;\n \n \tresult = __getname();\n \tif (unlikely(!result))\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/fs/namei.c b/fs/namei.c\nindex 0cab6494978c..c931f237243e 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -213,6 +213,9 @@ getname(const char __user * filename)\n \n struct filename *\n getname_kernel(const char * filename)\n+{\n+    if (unlikely(!filename))\n+        return ERR_PTR(-EINVAL);\n {\n \tstruct filename *result;\n \tint len = strlen(filename) + 1;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/namei.c b/fs/namei.c\nindex 0cab6494978c..f52350ac8b0b 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -213,6 +213,9 @@ getname(const char __user * filename)\n \n struct filename *\n getname_kernel(const char * filename)\n+{\n+    if (!filename)\n+        return ERR_PTR(-EINVAL);\n {\n \tstruct filename *result;\n \tint len = strlen(filename) + 1;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "2e1c26930cc57edee80734ae71bf020493b32306": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/ipv6/exthdrs.c b/net/ipv6/exthdrs.c\nindex 5a8bbcdcaf2b..ce7178126ddc 100644\n--- a/net/ipv6/exthdrs.c\n+++ b/net/ipv6/exthdrs.c\n@@ -1353,7 +1353,8 @@ struct in6_addr *fl6_update_dst(struct flowi6 *fl6,\n \t{\n \t\tstruct ipv6_sr_hdr *srh = (struct ipv6_sr_hdr *)opt->srcrt;\n \n-\t\tfl6->daddr = srh->segments[srh->segments_left];\n+\t\tif (srh->segments_left < srh->hdrlen / sizeof(struct in6_addr))\n+        fl6->daddr = srh->segments[srh->segments_left];\n \t\tbreak;\n \t}\n \tdefault:\n",
            "diff --git a/net/ipv6/exthdrs.c b/net/ipv6/exthdrs.c\nindex 5a8bbcdcaf2b..a976237bf1ac 100644\n--- a/net/ipv6/exthdrs.c\n+++ b/net/ipv6/exthdrs.c\n@@ -1353,7 +1353,8 @@ struct in6_addr *fl6_update_dst(struct flowi6 *fl6,\n \t{\n \t\tstruct ipv6_sr_hdr *srh = (struct ipv6_sr_hdr *)opt->srcrt;\n \n-\t\tfl6->daddr = srh->segments[srh->segments_left];\n+\t\tif (srh->segments_left < 0 || srh->segments_left >= srh->hdrlen) return NULL;\n+        fl6->daddr = srh->segments[srh->segments_left];\n \t\tbreak;\n \t}\n \tdefault:\n",
            "diff --git a/net/ipv6/exthdrs.c b/net/ipv6/exthdrs.c\nindex 5a8bbcdcaf2b..a976237bf1ac 100644\n--- a/net/ipv6/exthdrs.c\n+++ b/net/ipv6/exthdrs.c\n@@ -1353,7 +1353,8 @@ struct in6_addr *fl6_update_dst(struct flowi6 *fl6,\n \t{\n \t\tstruct ipv6_sr_hdr *srh = (struct ipv6_sr_hdr *)opt->srcrt;\n \n-\t\tfl6->daddr = srh->segments[srh->segments_left];\n+\t\tif (srh->segments_left < 0 || srh->segments_left >= srh->hdrlen) return NULL;\n+        fl6->daddr = srh->segments[srh->segments_left];\n \t\tbreak;\n \t}\n \tdefault:\n",
            "diff --git a/net/ipv6/exthdrs.c b/net/ipv6/exthdrs.c\nindex 5a8bbcdcaf2b..444efbd82836 100644\n--- a/net/ipv6/exthdrs.c\n+++ b/net/ipv6/exthdrs.c\n@@ -1353,7 +1353,11 @@ struct in6_addr *fl6_update_dst(struct flowi6 *fl6,\n \t{\n \t\tstruct ipv6_sr_hdr *srh = (struct ipv6_sr_hdr *)opt->srcrt;\n \n-\t\tfl6->daddr = srh->segments[srh->segments_left];\n+\t\tif (srh->segments_left < srh->hdrlen) {\n+            fl6->daddr = srh->segments[srh->segments_left];\n+        } else {\n+            return NULL;\n+        }\n \t\tbreak;\n \t}\n \tdefault:\n",
            "diff --git a/net/ipv6/exthdrs.c b/net/ipv6/exthdrs.c\nindex 5a8bbcdcaf2b..559a4f215a3e 100644\n--- a/net/ipv6/exthdrs.c\n+++ b/net/ipv6/exthdrs.c\n@@ -1353,7 +1353,11 @@ struct in6_addr *fl6_update_dst(struct flowi6 *fl6,\n \t{\n \t\tstruct ipv6_sr_hdr *srh = (struct ipv6_sr_hdr *)opt->srcrt;\n \n-\t\tfl6->daddr = srh->segments[srh->segments_left];\n+\t\tif (srh->segments_left < srh->hdrlen / 2) {\n+        fl6->daddr = srh->segments[srh->segments_left];\n+    } else {\n+        return NULL;\n+    }\n \t\tbreak;\n \t}\n \tdefault:\n"
        ],
        "error": []
    },
    "731e35eeed762019e385baa96953d9ec8eb63c10": {
        "non_crash": [
            "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex d3dfc51a43c5..2c8c7e9ad0f3 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 + EXT4_SB(inode->i_sb)->s_inode_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",
            "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex d3dfc51a43c5..2d371cd44683 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 + min_offs; 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",
            "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex d3dfc51a43c5..509b5a99175b 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 + EXT4_SB(inode->i_sb)->s_inode_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": [],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex d3dfc51a43c5..68d27d21b419 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) && (char *)entry < (char *)header + allocated_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",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex d3dfc51a43c5..569ba60b3ba3 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 (; (void *)entry < (void *)raw_inode + iloc.size && !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",
                "error_message": "Failed to build"
            }
        ]
    },
    "47ff89a13ed39d393e043ec2715452a5b23ce8b2": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/mm/mmap.c b/mm/mmap.c\nindex 740b54be3ed4..88f745962559 100644\n--- a/mm/mmap.c\n+++ b/mm/mmap.c\n@@ -3019,6 +3019,11 @@ void exit_mmap(struct mm_struct *mm)\n \tmmu_notifier_release(mm);\n \n \tmmap_read_lock(mm);\n+    if (!vma) {\n+        mmap_read_unlock(mm);\n+        return;\n+    }\n+\n \tarch_exit_mmap(mm);\n \n \tvma = mas_find(&mas, ULONG_MAX);\n",
                "error_message": "Failed to set up instance"
            },
            {
                "patch": "diff --git a/kernel/exit.c b/kernel/exit.c\nindex f2afdb0add7c..45488cff3fe5 100644\n--- a/kernel/exit.c\n+++ b/kernel/exit.c\n@@ -536,7 +536,12 @@ static void exit_mm(void)\n \tif (!mm)\n \t\treturn;\n \tsync_mm_rss(mm);\n-\tmmap_read_lock(mm);\n+\tif (!mmap_read_trylock(mm)) {\n+        if (wait_for_timeout_or_retry()) {\n+            // handle timeout or retry logic\n+            return;\n+        }\n+    }\n \tmmgrab(mm);\n \tBUG_ON(mm != current->active_mm);\n \t/* more a memory barrier than a real lock */\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/kernel/exit.c b/kernel/exit.c\nindex f2afdb0add7c..d1918bfdd62b 100644\n--- a/kernel/exit.c\n+++ b/kernel/exit.c\n@@ -559,6 +559,7 @@ static void exit_mm(void)\n \tlocal_irq_enable();\n \ttask_unlock(current);\n \tmmap_read_unlock(mm);\n+BUG_ON(!rwsem_is_locked(&mm->mmap_lock));\n \tmm_update_next_owner(mm);\n \tmmput(mm);\n \tif (test_thread_flag(TIF_MEMDIE))\n",
                "error_message": "Failed to set up instance"
            }
        ]
    },
    "37556d70764e226e660023fad17c9c0316cb6f1d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/fs-writeback.c b/fs/fs-writeback.c\nindex 443f83382b9b..cf762aebbf39 100644\n--- a/fs/fs-writeback.c\n+++ b/fs/fs-writeback.c\n@@ -1367,7 +1367,8 @@ 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\tatomic_inc(&inode->i_count);\n+        list_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@@ -1396,6 +1397,7 @@ static int move_expired_inodes(struct list_head *delaying_queue,\n \t\t\tinode = wb_inode(pos);\n \t\t\tif (inode->i_sb == sb)\n \t\t\t\tlist_move(&inode->i_io_list, dispatch_queue);\n+                atomic_dec(&inode->i_count);\n \t\t}\n \t}\n out:\n",
            "diff --git a/fs/fs-writeback.c b/fs/fs-writeback.c\nindex 443f83382b9b..879659b6558c 100644\n--- a/fs/fs-writeback.c\n+++ b/fs/fs-writeback.c\n@@ -1367,7 +1367,9 @@ 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\tif (inode) {\n+            list_move(&inode->i_io_list, &tmp);\n+        }\n \t\tmoved++;\n \t\tinode->i_state |= I_SYNC_QUEUED;\n \t\tspin_unlock(&inode->i_lock);\n",
            "diff --git a/fs/fs-writeback.c b/fs/fs-writeback.c\nindex 443f83382b9b..4b0b2ccbb0b8 100644\n--- a/fs/fs-writeback.c\n+++ b/fs/fs-writeback.c\n@@ -1363,6 +1363,9 @@ static int move_expired_inodes(struct list_head *delaying_queue,\n \tint moved = 0;\n \n \twhile (!list_empty(delaying_queue)) {\n+    inode = wb_inode(delaying_queue->prev);\n+    if (!atomic_read(&inode->i_count))\n+        continue;\n \t\tinode = wb_inode(delaying_queue->prev);\n \t\tif (inode_dirtied_after(inode, dirtied_before))\n \t\t\tbreak;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/fs-writeback.c b/fs/fs-writeback.c\nindex 443f83382b9b..ee7bd5792ba6 100644\n--- a/fs/fs-writeback.c\n+++ b/fs/fs-writeback.c\n@@ -1363,6 +1363,7 @@ static int move_expired_inodes(struct list_head *delaying_queue,\n \tint moved = 0;\n \n \twhile (!list_empty(delaying_queue)) {\n+atomic_inc(&inode->i_count);\n \t\tinode = wb_inode(delaying_queue->prev);\n \t\tif (inode_dirtied_after(inode, dirtied_before))\n \t\t\tbreak;\n",
                "error_message": "Failed to set up instance"
            },
            {
                "patch": "diff --git a/fs/fs-writeback.c b/fs/fs-writeback.c\nindex 443f83382b9b..961c20c92cfb 100644\n--- a/fs/fs-writeback.c\n+++ b/fs/fs-writeback.c\n@@ -1367,7 +1367,8 @@ 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\trefcount_inc(&inode->i_count);\n+        list_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",
                "error_message": "Failed to build"
            }
        ]
    },
    "31a3f2ad09a571fb7a5212efc400ce6bfc82e04c": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/extents_status.c b/fs/ext4/extents_status.c\nindex 9a3a8996aacf..115fff13919d 100644\n--- a/fs/ext4/extents_status.c\n+++ b/fs/ext4/extents_status.c\n@@ -896,7 +896,10 @@ void ext4_es_cache_extent(struct inode *inode, ext4_lblk_t lblk,\n \tif (!len)\n \t\treturn;\n \n-\tBUG_ON(end < lblk);\n+\tif (end < lblk) {\n+pr_err(\"Invalid extent range: end < lblk\\n\");\n+return;\n+}\n \n \twrite_lock(&EXT4_I(inode)->i_es_lock);\n \n",
            "diff --git a/fs/ext4/extents_status.c b/fs/ext4/extents_status.c\nindex 9a3a8996aacf..51f509426274 100644\n--- a/fs/ext4/extents_status.c\n+++ b/fs/ext4/extents_status.c\n@@ -827,7 +827,7 @@ int ext4_es_insert_extent(struct inode *inode, ext4_lblk_t lblk,\n \tes_debug(\"add [%u/%u) %llu %x to extent status tree of inode %lu\\n\",\n \t\t lblk, len, pblk, status, inode->i_ino);\n \n-\tif (!len)\n+\tif (len <= 0)\n \t\treturn 0;\n \n \tBUG_ON(end < lblk);\n@@ -893,7 +893,7 @@ void ext4_es_cache_extent(struct inode *inode, ext4_lblk_t lblk,\n \text4_es_store_pblock_status(&newes, pblk, status);\n \ttrace_ext4_es_cache_extent(inode, &newes);\n \n-\tif (!len)\n+\tif (len <= 0)\n \t\treturn;\n \n \tBUG_ON(end < lblk);\n@@ -1444,7 +1444,7 @@ int ext4_es_remove_extent(struct inode *inode, ext4_lblk_t lblk,\n \tes_debug(\"remove [%u/%u) from extent status tree of inode %lu\\n\",\n \t\t lblk, len, inode->i_ino);\n \n-\tif (!len)\n+\tif (len <= 0)\n \t\treturn err;\n \n \tend = lblk + len - 1;\n",
            "diff --git a/fs/ext4/extents_status.c b/fs/ext4/extents_status.c\nindex 9a3a8996aacf..51f509426274 100644\n--- a/fs/ext4/extents_status.c\n+++ b/fs/ext4/extents_status.c\n@@ -827,7 +827,7 @@ int ext4_es_insert_extent(struct inode *inode, ext4_lblk_t lblk,\n \tes_debug(\"add [%u/%u) %llu %x to extent status tree of inode %lu\\n\",\n \t\t lblk, len, pblk, status, inode->i_ino);\n \n-\tif (!len)\n+\tif (len <= 0)\n \t\treturn 0;\n \n \tBUG_ON(end < lblk);\n@@ -893,7 +893,7 @@ void ext4_es_cache_extent(struct inode *inode, ext4_lblk_t lblk,\n \text4_es_store_pblock_status(&newes, pblk, status);\n \ttrace_ext4_es_cache_extent(inode, &newes);\n \n-\tif (!len)\n+\tif (len <= 0)\n \t\treturn;\n \n \tBUG_ON(end < lblk);\n@@ -1444,7 +1444,7 @@ int ext4_es_remove_extent(struct inode *inode, ext4_lblk_t lblk,\n \tes_debug(\"remove [%u/%u) from extent status tree of inode %lu\\n\",\n \t\t lblk, len, inode->i_ino);\n \n-\tif (!len)\n+\tif (len <= 0)\n \t\treturn err;\n \n \tend = lblk + len - 1;\n",
            "diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c\nindex 474479ce76e0..c8c5a9a6896d 100644\n--- a/fs/ext4/extents.c\n+++ b/fs/ext4/extents.c\n@@ -510,7 +510,8 @@ static void ext4_cache_extents(struct inode *inode,\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\tif (lblk > prev)\n+            ext4_es_cache_extent(inode, prev, lblk - prev, ~0,\n \t\t\t\t\t     EXTENT_STATUS_HOLE);\n \n \t\tif (ext4_ext_is_unwritten(ex))\n",
            "diff --git a/fs/ext4/extents_status.c b/fs/ext4/extents_status.c\nindex 9a3a8996aacf..0e6579c2778a 100644\n--- a/fs/ext4/extents_status.c\n+++ b/fs/ext4/extents_status.c\n@@ -896,7 +896,8 @@ void ext4_es_cache_extent(struct inode *inode, ext4_lblk_t lblk,\n \tif (!len)\n \t\treturn;\n \n-\tBUG_ON(end < lblk);\n+\tpr_debug(\"Potential BUG_ON trigger: lblk=%llu, len=%llu, end=%llu\\n\", lblk, len, end);\n+BUG_ON(end < lblk);\n \n \twrite_lock(&EXT4_I(inode)->i_es_lock);\n \n"
        ],
        "error": []
    },
    "641c688b5c5a0c80d5d5832c5cd9f361c1cbb0a9": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/usb/gadget/legacy/raw_gadget.c b/drivers/usb/gadget/legacy/raw_gadget.c\nindex 2acece16b890..c6c8b61d47dd 100644\n--- a/drivers/usb/gadget/legacy/raw_gadget.c\n+++ b/drivers/usb/gadget/legacy/raw_gadget.c\n@@ -661,12 +661,14 @@ static int raw_process_ep0_io(struct raw_dev *dev, struct usb_raw_ep_io *io,\n \tif (WARN_ON(in && dev->ep0_out_pending)) {\n \t\tret = -ENODEV;\n \t\tdev->state = STATE_DEV_FAILED;\n-\t\tgoto out_done;\n+\t\tkfree(data);\n+goto out_done;\n \t}\n \tif (WARN_ON(!in && dev->ep0_in_pending)) {\n \t\tret = -ENODEV;\n \t\tdev->state = STATE_DEV_FAILED;\n-\t\tgoto out_done;\n+\t\tkfree(data);\n+goto out_done;\n \t}\n \n \tdev->req->buf = data;\n@@ -681,7 +683,8 @@ static int raw_process_ep0_io(struct raw_dev *dev, struct usb_raw_ep_io *io,\n \t\t\t\t\"fail, usb_ep_queue returned %d\\n\", ret);\n \t\tspin_lock_irqsave(&dev->lock, flags);\n \t\tdev->state = STATE_DEV_FAILED;\n-\t\tgoto out_done;\n+\t\tkfree(data);\n+goto out_done;\n \t}\n \n \tret = wait_for_completion_interruptible(&dev->ep0_done);\n@@ -690,7 +693,8 @@ static int raw_process_ep0_io(struct raw_dev *dev, struct usb_raw_ep_io *io,\n \t\tusb_ep_dequeue(dev->gadget->ep0, dev->req);\n \t\twait_for_completion(&dev->ep0_done);\n \t\tspin_lock_irqsave(&dev->lock, flags);\n-\t\tgoto out_done;\n+\t\tkfree(data);\n+goto out_done;\n \t}\n \n \tspin_lock_irqsave(&dev->lock, flags);\n@@ -1065,7 +1069,8 @@ static int raw_process_ep_io(struct raw_dev *dev, struct usb_raw_ep_io *io,\n \t\t\t\t\"fail, usb_ep_queue returned %d\\n\", ret);\n \t\tspin_lock_irqsave(&dev->lock, flags);\n \t\tdev->state = STATE_DEV_FAILED;\n-\t\tgoto out_done;\n+\t\tkfree(data);\n+goto out_done;\n \t}\n \n \tret = wait_for_completion_interruptible(&done);\n@@ -1074,7 +1079,8 @@ static int raw_process_ep_io(struct raw_dev *dev, struct usb_raw_ep_io *io,\n \t\tusb_ep_dequeue(ep->ep, ep->req);\n \t\twait_for_completion(&done);\n \t\tspin_lock_irqsave(&dev->lock, flags);\n-\t\tgoto out_done;\n+\t\tkfree(data);\n+goto out_done;\n \t}\n \n \tspin_lock_irqsave(&dev->lock, flags);\n"
        ],
        "error": []
    },
    "4d35dd2768109c21f717806fb4274293758d65cf": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/mmap.c b/mm/mmap.c\nindex 51e70fa98450..0b2199a9e4f2 100644\n--- a/mm/mmap.c\n+++ b/mm/mmap.c\n@@ -934,7 +934,10 @@ struct vm_area_struct *vma_merge(struct vma_iterator *vmi, struct mm_struct *mm,\n \tVM_WARN_ON(addr >= end);\n \n \tif (!merge_prev && !merge_next)\n-\t\treturn NULL; /* Not mergeable. */\n+\t\tif (merge_prev && merge_next) {\n+        mm->map_count--;\n+    }\n+    return NULL; /* Not mergeable. */\n \n \tres = vma = prev;\n \tremove = remove2 = adjust = NULL;\n"
        ],
        "error": []
    },
    "30f3a18df370dd15cce6f725620ac001e57dbee1": {
        "non_crash": [
            "diff --git a/fs/hfs/bnode.c b/fs/hfs/bnode.c\nindex 2015e42e752a..3635c577fe82 100644\n--- a/fs/hfs/bnode.c\n+++ b/fs/hfs/bnode.c\n@@ -463,7 +463,7 @@ void hfs_bnode_put(struct hfs_bnode *node)\n \t\thfs_dbg(BNODE_REFS, \"put_node(%d:%d): %d\\n\",\n \t\t\tnode->tree->cnid, node->this,\n \t\t\tatomic_read(&node->refcnt));\n-\t\tBUG_ON(!atomic_read(&node->refcnt));\n+\t\tif (!atomic_read(&node->refcnt)) return; // Avoid BUG_ON with zero refcnt\n \t\tif (!atomic_dec_and_lock(&node->refcnt, &tree->hash_lock))\n \t\t\treturn;\n \t\tfor (i = 0; i < tree->pages_per_bnode; i++) {\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/hfs/brec.c b/fs/hfs/brec.c\nindex 896396554bcc..0e4690ac1c36 100644\n--- a/fs/hfs/brec.c\n+++ b/fs/hfs/brec.c\n@@ -200,7 +200,8 @@ 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_put(node);\n+\t\tif (atomic_read(&node->refcnt) > 0)\n+        hfs_bnode_put(node);\n \t\tnode = fd->bnode = parent;\n \n \t\t__hfs_brec_find(node, fd);\n@@ -256,7 +257,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_put(node);\n+\t\tif (atomic_read(&node->refcnt) > 0)\n+        hfs_bnode_put(node);\n \t\thfs_bnode_put(new_node);\n \t\treturn next_node;\n \t}\n@@ -272,7 +274,8 @@ 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\tif (atomic_read(&node->refcnt) > 0)\n+        hfs_bnode_put(node);\n \t\thfs_bnode_put(new_node);\n \t\tif (next_node)\n \t\t\thfs_bnode_put(next_node);\n@@ -287,7 +290,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\tif (atomic_read(&node->refcnt) > 0)\n+        hfs_bnode_put(node);\n \t\thfs_bnode_get(new_node);\n \t\tfd->bnode = new_node;\n \t\tfd->record -= num_recs;\n@@ -344,7 +348,8 @@ static struct hfs_bnode *hfs_bnode_split(struct hfs_find_data *fd)\n \n \thfs_bnode_dump(node);\n \thfs_bnode_dump(new_node);\n-\thfs_bnode_put(node);\n+\tif (atomic_read(&node->refcnt) > 0)\n+        hfs_bnode_put(node);\n \n \treturn new_node;\n }\n@@ -419,7 +424,8 @@ static int hfs_brec_update_parent(struct hfs_find_data *fd)\n \t\thfs_bnode_write_u8(parent, fd->keyoffset, newkeylen - 1);\n \thfs_bnode_dump(parent);\n \n-\thfs_bnode_put(node);\n+\tif (atomic_read(&node->refcnt) > 0)\n+        hfs_bnode_put(node);\n \tnode = parent;\n \n \tif (new_node) {\n@@ -470,7 +476,8 @@ static int hfs_btree_inc_height(struct hfs_btree *tree)\n \t}\n \tnew_node = hfs_bmap_alloc(tree);\n \tif (IS_ERR(new_node)) {\n-\t\thfs_bnode_put(node);\n+\t\tif (atomic_read(&node->refcnt) > 0)\n+        hfs_bnode_put(node);\n \t\treturn PTR_ERR(new_node);\n \t}\n \n@@ -520,7 +527,8 @@ static int hfs_btree_inc_height(struct hfs_btree *tree)\n \t\trec -= 2;\n \t\thfs_bnode_write_u16(new_node, rec, 14 + key_size + 4);\n \n-\t\thfs_bnode_put(node);\n+\t\tif (atomic_read(&node->refcnt) > 0)\n+        hfs_bnode_put(node);\n \t}\n \thfs_bnode_put(new_node);\n \tmark_inode_dirty(tree->inode);\n",
            "diff --git a/fs/hfs/brec.c b/fs/hfs/brec.c\nindex 896396554bcc..4692158b2436 100644\n--- a/fs/hfs/brec.c\n+++ b/fs/hfs/brec.c\n@@ -100,7 +100,10 @@ int hfs_brec_insert(struct hfs_find_data *fd, void *entry, int entry_len)\n \t\tif (new_node)\n \t\t\tpanic(\"not enough room!\\n\");\n \t\tnew_node = hfs_bnode_split(fd);\n-\t\tif (IS_ERR(new_node))\n+\t\tif (IS_ERR(new_node)) {\n+        hfs_bnode_put(fd->bnode);\n+        return PTR_ERR(new_node);\n+    }\n \t\t\treturn PTR_ERR(new_node);\n \t\tgoto again;\n \t}\n",
            "diff --git a/fs/hfs/bnode.c b/fs/hfs/bnode.c\nindex 2015e42e752a..3a0d1f8c5ca7 100644\n--- a/fs/hfs/bnode.c\n+++ b/fs/hfs/bnode.c\n@@ -190,7 +190,8 @@ void hfs_bnode_unlink(struct hfs_bnode *node)\n \t\ttmp->next = node->next;\n \t\tcnid = cpu_to_be32(tmp->next);\n \t\thfs_bnode_write(tmp, &cnid, offsetof(struct hfs_bnode_desc, next), 4);\n-\t\thfs_bnode_put(tmp);\n+\t\tif (atomic_read(&tmp->refcnt) > 0)\n+hfs_bnode_put(tmp);\n \t} else if (node->type == HFS_NODE_LEAF)\n \t\ttree->leaf_head = node->next;\n \n@@ -201,7 +202,8 @@ void hfs_bnode_unlink(struct hfs_bnode *node)\n \t\ttmp->prev = node->prev;\n \t\tcnid = cpu_to_be32(tmp->prev);\n \t\thfs_bnode_write(tmp, &cnid, offsetof(struct hfs_bnode_desc, prev), 4);\n-\t\thfs_bnode_put(tmp);\n+\t\tif (atomic_read(&tmp->refcnt) > 0)\n+hfs_bnode_put(tmp);\n \t} else if (node->type == HFS_NODE_LEAF)\n \t\ttree->leaf_tail = node->prev;\n \n@@ -393,7 +395,8 @@ struct hfs_bnode *hfs_bnode_find(struct hfs_btree *tree, u32 num)\n \tset_bit(HFS_BNODE_ERROR, &node->flags);\n \tclear_bit(HFS_BNODE_NEW, &node->flags);\n \twake_up(&node->lock_wq);\n-\thfs_bnode_put(node);\n+\tif (atomic_read(&node->refcnt) > 0)\n+hfs_bnode_put(node);\n \treturn ERR_PTR(-EIO);\n }\n \n@@ -425,7 +428,8 @@ struct hfs_bnode *hfs_bnode_create(struct hfs_btree *tree, u32 num)\n \tif (!node)\n \t\treturn ERR_PTR(-ENOMEM);\n \tif (test_bit(HFS_BNODE_ERROR, &node->flags)) {\n-\t\thfs_bnode_put(node);\n+\t\tif (atomic_read(&node->refcnt) > 0)\n+hfs_bnode_put(node);\n \t\treturn ERR_PTR(-EIO);\n \t}\n \n",
            "diff --git a/fs/hfs/brec.c b/fs/hfs/brec.c\nindex 896396554bcc..f24803f6ecc6 100644\n--- a/fs/hfs/brec.c\n+++ b/fs/hfs/brec.c\n@@ -200,7 +200,8 @@ 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_put(node);\n+\t\thfs_bnode_get(node);\n+    hfs_bnode_put(node);\n \t\tnode = fd->bnode = parent;\n \n \t\t__hfs_brec_find(node, fd);\n@@ -256,7 +257,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_put(node);\n+\t\thfs_bnode_get(node);\n+    hfs_bnode_put(node);\n \t\thfs_bnode_put(new_node);\n \t\treturn next_node;\n \t}\n@@ -272,7 +274,8 @@ 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_get(node);\n+    hfs_bnode_put(node);\n \t\thfs_bnode_put(new_node);\n \t\tif (next_node)\n \t\t\thfs_bnode_put(next_node);\n@@ -287,7 +290,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(node);\n+    hfs_bnode_put(node);\n \t\thfs_bnode_get(new_node);\n \t\tfd->bnode = new_node;\n \t\tfd->record -= num_recs;\n@@ -344,7 +348,8 @@ static struct hfs_bnode *hfs_bnode_split(struct hfs_find_data *fd)\n \n \thfs_bnode_dump(node);\n \thfs_bnode_dump(new_node);\n-\thfs_bnode_put(node);\n+\thfs_bnode_get(node);\n+    hfs_bnode_put(node);\n \n \treturn new_node;\n }\n@@ -419,7 +424,8 @@ static int hfs_brec_update_parent(struct hfs_find_data *fd)\n \t\thfs_bnode_write_u8(parent, fd->keyoffset, newkeylen - 1);\n \thfs_bnode_dump(parent);\n \n-\thfs_bnode_put(node);\n+\thfs_bnode_get(node);\n+    hfs_bnode_put(node);\n \tnode = parent;\n \n \tif (new_node) {\n@@ -470,7 +476,8 @@ static int hfs_btree_inc_height(struct hfs_btree *tree)\n \t}\n \tnew_node = hfs_bmap_alloc(tree);\n \tif (IS_ERR(new_node)) {\n-\t\thfs_bnode_put(node);\n+\t\thfs_bnode_get(node);\n+    hfs_bnode_put(node);\n \t\treturn PTR_ERR(new_node);\n \t}\n \n@@ -520,7 +527,8 @@ static int hfs_btree_inc_height(struct hfs_btree *tree)\n \t\trec -= 2;\n \t\thfs_bnode_write_u16(new_node, rec, 14 + key_size + 4);\n \n-\t\thfs_bnode_put(node);\n+\t\thfs_bnode_get(node);\n+    hfs_bnode_put(node);\n \t}\n \thfs_bnode_put(new_node);\n \tmark_inode_dirty(tree->inode);\n"
        ],
        "error": []
    },
    "0cd33d8e114be941da0773f8980488e1ca71ed58": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/rxrpc/recvmsg.c b/net/rxrpc/recvmsg.c\nindex eaf19ebaa964..eb52fe46f8b9 100644\n--- a/net/rxrpc/recvmsg.c\n+++ b/net/rxrpc/recvmsg.c\n@@ -594,6 +594,7 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \t} else {\n \t\trxrpc_put_call(call, rxrpc_call_put);\n \t}\n+lock_sock(&rx->sk);\n error_no_call:\n \trelease_sock(&rx->sk);\n \ttrace_rxrpc_recvmsg(call, rxrpc_recvmsg_return, 0, 0, 0, ret);\n",
            "diff --git a/net/rxrpc/recvmsg.c b/net/rxrpc/recvmsg.c\nindex eaf19ebaa964..43edf48cd4df 100644\n--- a/net/rxrpc/recvmsg.c\n+++ b/net/rxrpc/recvmsg.c\n@@ -447,6 +447,9 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \n try_again:\n \tlock_sock(&rx->sk);\n+    if (mutex_trylock(&call->user_mutex)) {\n+        mutex_unlock(&call->user_mutex);\n+    }\n \n \t/* Return immediately if a client socket has no outstanding calls */\n \tif (RB_EMPTY_ROOT(&rx->calls) &&\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/rxrpc/recvmsg.c b/net/rxrpc/recvmsg.c\nindex eaf19ebaa964..1587e0a17d06 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+    release_sock(&rx->sk);\n \t\treturn -ENODATA;\n \t}\n \n@@ -463,7 +464,8 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \t\t\tgoto error_no_call;\n \t\t}\n \n-\t\trelease_sock(&rx->sk);\n+\t\tif (lockdep_is_held(&rx->sk.lock))\n+    release_sock(&rx->sk);\n \n \t\t/* Wait for something to happen */\n \t\tprepare_to_wait_exclusive(sk_sleep(&rx->sk), &wait,\n@@ -509,7 +511,8 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \t\t\tgoto error_requeue_call;\n \t}\n \n-\trelease_sock(&rx->sk);\n+\tif (lockdep_is_held(&rx->sk.lock))\n+    release_sock(&rx->sk);\n \n \tif (test_bit(RXRPC_CALL_RELEASED, &call->flags))\n \t\tBUG();\n@@ -595,7 +598,8 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \t\trxrpc_put_call(call, rxrpc_call_put);\n \t}\n error_no_call:\n-\trelease_sock(&rx->sk);\n+\tif (lockdep_is_held(&rx->sk.lock))\n+    release_sock(&rx->sk);\n \ttrace_rxrpc_recvmsg(call, rxrpc_recvmsg_return, 0, 0, 0, ret);\n \treturn ret;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/rxrpc/recvmsg.c b/net/rxrpc/recvmsg.c\nindex eaf19ebaa964..768a4f06406f 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+        release_sock(&rx->sk);\n \t\treturn -ENODATA;\n \t}\n \n@@ -463,7 +464,8 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \t\t\tgoto error_no_call;\n \t\t}\n \n-\t\trelease_sock(&rx->sk);\n+\t\tif (lockdep_is_held(&rx->sk.lock))\n+        release_sock(&rx->sk);\n \n \t\t/* Wait for something to happen */\n \t\tprepare_to_wait_exclusive(sk_sleep(&rx->sk), &wait,\n@@ -509,7 +511,8 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \t\t\tgoto error_requeue_call;\n \t}\n \n-\trelease_sock(&rx->sk);\n+\tif (lockdep_is_held(&rx->sk.lock))\n+        release_sock(&rx->sk);\n \n \tif (test_bit(RXRPC_CALL_RELEASED, &call->flags))\n \t\tBUG();\n@@ -595,7 +598,8 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \t\trxrpc_put_call(call, rxrpc_call_put);\n \t}\n error_no_call:\n-\trelease_sock(&rx->sk);\n+\tif (lockdep_is_held(&rx->sk.lock))\n+        release_sock(&rx->sk);\n \ttrace_rxrpc_recvmsg(call, rxrpc_recvmsg_return, 0, 0, 0, ret);\n \treturn ret;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/rxrpc/recvmsg.c b/net/rxrpc/recvmsg.c\nindex eaf19ebaa964..fb7d70e2192d 100644\n--- a/net/rxrpc/recvmsg.c\n+++ b/net/rxrpc/recvmsg.c\n@@ -427,6 +427,18 @@ static int rxrpc_recvmsg_data(struct socket *sock, struct rxrpc_call *call,\n  *   simultaneously\n  */\n int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n+          int flags) {\n+    struct rxrpc_call *call;\n+    struct rxrpc_sock *rx = rxrpc_sk(sock->sk);\n+    struct list_head *l;\n+    size_t copied = 0;\n+    long timeo;\n+    int ret;\n+    bool lock_acquired = false;\n+\n+    DEFINE_WAIT(wait);\n+\n+    trace_rxrpc_recvmsg(NULL, rxrpc_recvmsg_enter, 0, 0, 0, 0);\n \t\t  int flags)\n {\n \tstruct rxrpc_call *call;\n@@ -447,12 +459,16 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \n try_again:\n \tlock_sock(&rx->sk);\n+    lock_acquired = true;\n \n \t/* Return immediately if a client socket has no outstanding calls */\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_acquired) {\n+    release_sock(&rx->sk);\n+    lock_acquired = false;\n+}\n \t\treturn -ENODATA;\n \t}\n \n@@ -463,7 +479,10 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \t\t\tgoto error_no_call;\n \t\t}\n \n-\t\trelease_sock(&rx->sk);\n+\t\tif (lock_acquired) {\n+    release_sock(&rx->sk);\n+    lock_acquired = false;\n+}\n \n \t\t/* Wait for something to happen */\n \t\tprepare_to_wait_exclusive(sk_sleep(&rx->sk), &wait,\n@@ -509,7 +528,10 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \t\t\tgoto error_requeue_call;\n \t}\n \n-\trelease_sock(&rx->sk);\n+\tif (lock_acquired) {\n+    release_sock(&rx->sk);\n+    lock_acquired = false;\n+}\n \n \tif (test_bit(RXRPC_CALL_RELEASED, &call->flags))\n \t\tBUG();\n@@ -595,7 +617,10 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \t\trxrpc_put_call(call, rxrpc_call_put);\n \t}\n error_no_call:\n-\trelease_sock(&rx->sk);\n+\tif (lock_acquired) {\n+    release_sock(&rx->sk);\n+    lock_acquired = false;\n+}\n \ttrace_rxrpc_recvmsg(call, rxrpc_recvmsg_return, 0, 0, 0, ret);\n \treturn ret;\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "f0ec9a394925aafbdf13d0a7e6af4cff860f0ed6": {
        "non_crash": [
            "diff --git a/net/bluetooth/hci_sysfs.c b/net/bluetooth/hci_sysfs.c\nindex 9874844a95a9..944a725a680a 100644\n--- a/net/bluetooth/hci_sysfs.c\n+++ b/net/bluetooth/hci_sysfs.c\n@@ -50,6 +50,11 @@ void hci_conn_add_sysfs(struct hci_conn *conn)\n \n \tdev_set_name(&conn->dev, \"%s:%d\", hdev->name, conn->handle);\n \n+    if (device_is_registered(&conn->dev)) {\n+        bt_dev_err(hdev, \"connection device already registered\");\n+        return;\n+    }\n+\n \tif (device_add(&conn->dev) < 0) {\n \t\tbt_dev_err(hdev, \"failed to register connection device\");\n \t\treturn;\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/bluetooth/hci_sysfs.c b/net/bluetooth/hci_sysfs.c\nindex 9874844a95a9..c3001bb78ffd 100644\n--- a/net/bluetooth/hci_sysfs.c\n+++ b/net/bluetooth/hci_sysfs.c\n@@ -43,6 +43,25 @@ void hci_conn_init_sysfs(struct hci_conn *conn)\n }\n \n void hci_conn_add_sysfs(struct hci_conn *conn)\n+{\n+struct hci_dev *hdev = conn->hdev;\n+\n+BT_DBG(\"conn %p\", conn);\n+\n+if (device_is_registered(&conn->dev)) {\n+bt_dev_err(hdev, \"connection device already registered\");\n+return;\n+}\n+\n+dev_set_name(&conn->dev, \"%s:%d\", hdev->name, conn->handle);\n+\n+if (device_add(&conn->dev) < 0) {\n+bt_dev_err(hdev, \"failed to register connection device\");\n+return;\n+}\n+\n+hci_dev_hold(hdev);\n+}\n {\n \tstruct hci_dev *hdev = conn->hdev;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/bluetooth/hci_sysfs.c b/net/bluetooth/hci_sysfs.c\nindex 9874844a95a9..91fa92827433 100644\n--- a/net/bluetooth/hci_sysfs.c\n+++ b/net/bluetooth/hci_sysfs.c\n@@ -43,6 +43,9 @@ void hci_conn_init_sysfs(struct hci_conn *conn)\n }\n \n void hci_conn_add_sysfs(struct hci_conn *conn)\n+{\n+    if (device_is_registered(&conn->dev))\n+        return;\n {\n \tstruct hci_dev *hdev = conn->hdev;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/bluetooth/hci_sysfs.c b/net/bluetooth/hci_sysfs.c\nindex 9874844a95a9..91fa92827433 100644\n--- a/net/bluetooth/hci_sysfs.c\n+++ b/net/bluetooth/hci_sysfs.c\n@@ -43,6 +43,9 @@ void hci_conn_init_sysfs(struct hci_conn *conn)\n }\n \n void hci_conn_add_sysfs(struct hci_conn *conn)\n+{\n+    if (device_is_registered(&conn->dev))\n+        return;\n {\n \tstruct hci_dev *hdev = conn->hdev;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c\nindex bd306ba3ade5..e1ee347b51a1 100644\n--- a/net/bluetooth/hci_event.c\n+++ b/net/bluetooth/hci_event.c\n@@ -2617,7 +2617,9 @@ static void hci_conn_complete_evt(struct hci_dev *hdev, struct sk_buff *skb)\n \t\t\tconn->state = BT_CONNECTED;\n \n \t\thci_debugfs_create_conn(conn);\n-\t\thci_conn_add_sysfs(conn);\n+\t\tif (!is_conn_in_sysfs(conn)) {\n+            hci_conn_add_sysfs(conn);\n+        }\n \n \t\tif (test_bit(HCI_AUTH, &hdev->flags))\n \t\t\tset_bit(HCI_CONN_AUTH, &conn->flags);\n@@ -4326,7 +4328,9 @@ static void hci_sync_conn_complete_evt(struct hci_dev *hdev,\n \t\tconn->type   = ev->link_type;\n \n \t\thci_debugfs_create_conn(conn);\n-\t\thci_conn_add_sysfs(conn);\n+\t\tif (!is_conn_in_sysfs(conn)) {\n+            hci_conn_add_sysfs(conn);\n+        }\n \t\tbreak;\n \n \tcase 0x10:\t/* Connection Accept Timeout */\n@@ -5161,7 +5165,9 @@ static void le_conn_complete_evt(struct hci_dev *hdev, u8 status,\n \tconn->le_supv_timeout = supervision_timeout;\n \n \thci_debugfs_create_conn(conn);\n-\thci_conn_add_sysfs(conn);\n+\tif (!is_conn_in_sysfs(conn)) {\n+            hci_conn_add_sysfs(conn);\n+        }\n \n \t/* The remote features procedure is defined for master\n \t * role only. So only in case of an initiated connection\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "4157935be2e32fae6b62aa95bb0a08b07160b986": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ntfs3/fsntfs.c b/fs/ntfs3/fsntfs.c\nindex 3de5700a9b83..b5c64e353f00 100644\n--- a/fs/ntfs3/fsntfs.c\n+++ b/fs/ntfs3/fsntfs.c\n@@ -863,7 +863,12 @@ 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+            memcpy(bh2->b_data, bh1->b_data, blocksize);\n+        } else {\n+            err = -EIO;\n+            goto out;\n+        }\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..fdc31005f63f 100644\n--- a/fs/ntfs3/fsntfs.c\n+++ b/fs/ntfs3/fsntfs.c\n@@ -863,7 +863,9 @@ 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+            memcpy(bh2->b_data, bh1->b_data, blocksize);\n+        }\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..1ea4b7140bd9 100644\n--- a/fs/ntfs3/fsntfs.c\n+++ b/fs/ntfs3/fsntfs.c\n@@ -863,7 +863,18 @@ 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+            memcpy(bh2->b_data, bh1->b_data, blocksize);\n+            set_buffer_uptodate(bh2);\n+            mark_buffer_dirty(bh2);\n+            unlock_buffer(bh2);\n+        }\n+        else {\n+            err = -EIO;\n+            if (bh1) put_bh(bh1);\n+            if (bh2) put_bh(bh2);\n+            goto out;\n+        }\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..cc0e81dbf060 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->b_data && bh2->b_data) {\n+    memcpy(bh2->b_data, bh1->b_data, blocksize);\n+} else {\n+    printk(KERN_ERR \"ntfs_update_mftmirr: null b_data pointer encountered\\n\");\n+    err = -EFAULT;\n+    goto out;\n+}\n \t\tset_buffer_uptodate(bh2);\n \t\tmark_buffer_dirty(bh2);\n \t\tunlock_buffer(bh2);\n"
        ],
        "error": []
    },
    "3f5d1a7de17359e085f9a912eae7bf7e89dc7435": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 2c351765c409..c78b411b6915 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -225,7 +225,7 @@ void __post_watch_notification(struct watch_list *wlist,\n \t\tif (security_post_notification(watch->cred, cred, n) < 0)\n \t\t\tcontinue;\n \n-\t\tif (lock_wqueue(wqueue)) {\n+\t\tif (lock_wqueue(wqueue) && !wqueue->defunct) {\n \t\t\tpost_one_notification(wqueue, n);\n \t\t\tunlock_wqueue(wqueue);\n \t\t}\n@@ -487,7 +487,7 @@ int add_watch_to_object(struct watch *watch, struct watch_list *wlist)\n \t\treturn -EAGAIN;\n \t}\n \n-\tif (lock_wqueue(wqueue)) {\n+\tif (lock_wqueue(wqueue) && !wqueue->defunct) {\n \t\tkref_get(&wqueue->usage);\n \t\tkref_get(&watch->usage);\n \t\thlist_add_head(&watch->queue_node, &wqueue->watches);\n@@ -546,7 +546,7 @@ int remove_watch_from_object(struct watch_list *wlist, struct watch_queue *wq,\n \n \twqueue = rcu_dereference(watch->queue);\n \n-\tif (lock_wqueue(wqueue)) {\n+\tif (lock_wqueue(wqueue) && !wqueue->defunct) {\n \t\tpost_one_notification(wqueue, &n.watch);\n \n \t\tif (!hlist_unhashed(&watch->queue_node)) {\n"
        ],
        "error": [
            {
                "patch": "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 2c351765c409..4e6f4cf8bb57 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -218,6 +218,8 @@ void __post_watch_notification(struct watch_list *wlist,\n \t\tn->info |= watch->info_id;\n \n \t\twqueue = rcu_dereference(watch->queue);\n+if (!wqueue || kref_read(&wqueue->usage) == 0 || wqueue->defunct)\n+continue;\n \t\twf = rcu_dereference(wqueue->filter);\n \t\tif (wf && !filter_watch_notification(wf, n))\n \t\t\tcontinue;\n@@ -545,6 +547,8 @@ int remove_watch_from_object(struct watch_list *wlist, struct watch_queue *wq,\n \t\tn.watch.info = watch->info_id | watch_sizeof(n);\n \n \twqueue = rcu_dereference(watch->queue);\n+if (!wqueue || kref_read(&wqueue->usage) == 0 || wqueue->defunct)\n+continue;\n \n \tif (lock_wqueue(wqueue)) {\n \t\tpost_one_notification(wqueue, &n.watch);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 2c351765c409..c7797565f531 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -218,6 +218,8 @@ void __post_watch_notification(struct watch_list *wlist,\n \t\tn->info |= watch->info_id;\n \n \t\twqueue = rcu_dereference(watch->queue);\n+if (!wqueue || !kref_get_unless_zero(&wqueue->usage))\n+continue;\n \t\twf = rcu_dereference(wqueue->filter);\n \t\tif (wf && !filter_watch_notification(wf, n))\n \t\t\tcontinue;\n@@ -545,6 +547,8 @@ int remove_watch_from_object(struct watch_list *wlist, struct watch_queue *wq,\n \t\tn.watch.info = watch->info_id | watch_sizeof(n);\n \n \twqueue = rcu_dereference(watch->queue);\n+if (!wqueue || !kref_get_unless_zero(&wqueue->usage))\n+continue;\n \n \tif (lock_wqueue(wqueue)) {\n \t\tpost_one_notification(wqueue, &n.watch);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 2c351765c409..2f46b9e74d65 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -218,6 +218,7 @@ void __post_watch_notification(struct watch_list *wlist,\n \t\tn->info |= watch->info_id;\n \n \t\twqueue = rcu_dereference(watch->queue);\n+kref_get(&wqueue->usage);\n \t\twf = rcu_dereference(wqueue->filter);\n \t\tif (wf && !filter_watch_notification(wf, n))\n \t\t\tcontinue;\n@@ -231,7 +232,8 @@ void __post_watch_notification(struct watch_list *wlist,\n \t\t}\n \t}\n \n-\trcu_read_unlock();\n+\tkref_put(&wqueue->usage);\n+rcu_read_unlock();\n }\n EXPORT_SYMBOL(__post_watch_notification);\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 2c351765c409..341479cc5db8 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -41,6 +41,10 @@ MODULE_LICENSE(\"GPL\");\n  * turn makes sure that the notification pipe still exists.\n  */\n static inline bool lock_wqueue(struct watch_queue *wqueue)\n+{\n+    if (!kref_get_unless_zero(&wqueue->usage)) {\n+        return false;\n+    }\n {\n \tspin_lock_bh(&wqueue->lock);\n \tif (unlikely(wqueue->defunct)) {\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "ef9605001826ed9db7e9ae5b0c08ec9b347a5148": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 300455b4bc12..b913ccdd5c46 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -53,6 +53,7 @@ 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+    if (!ctx) return;\n \tstruct io_sq_data *sq = NULL;\n \tstruct io_overflow_cqe *ocqe;\n \tstruct io_rings *r = ctx->rings;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 300455b4bc12..c5b06e821917 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -51,6 +51,12 @@ static __cold int io_uring_show_cred(struct seq_file *m, unsigned int id,\n  * anything else to get an extra reference.\n  */\n __cold void io_uring_show_fdinfo(struct seq_file *m, struct file *f)\n+{\n+    struct io_ring_ctx *ctx = f->private_data;\n+    if (!ctx || !ctx->rings) {\n+        seq_printf(m, \"Invalid io_uring context\\n\");\n+        return;\n+    }\n {\n \tstruct io_ring_ctx *ctx = f->private_data;\n \tstruct io_sq_data *sq = NULL;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 300455b4bc12..9ae2b4723859 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -51,6 +51,12 @@ static __cold int io_uring_show_cred(struct seq_file *m, unsigned int id,\n  * anything else to get an extra reference.\n  */\n __cold void io_uring_show_fdinfo(struct seq_file *m, struct file *f)\n+{\n+    struct io_ring_ctx *ctx = f->private_data;\n+    if (!ctx) {\n+        seq_printf(m, \"Error: io_ring_ctx is null\\n\");\n+        return;\n+    }\n {\n \tstruct io_ring_ctx *ctx = f->private_data;\n \tstruct io_sq_data *sq = NULL;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 300455b4bc12..ac89cc79f0cf 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -51,6 +51,10 @@ static __cold int io_uring_show_cred(struct seq_file *m, unsigned int id,\n  * anything else to get an extra reference.\n  */\n __cold void io_uring_show_fdinfo(struct seq_file *m, struct file *f)\n+{\n+    if (!f || !f->private_data) return;\n+    struct io_ring_ctx *ctx = f->private_data;\n+    if (!ctx || !ctx->rings) return;\n {\n \tstruct io_ring_ctx *ctx = f->private_data;\n \tstruct io_sq_data *sq = NULL;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "4894a6d412735394296e80976329c1a6848acc14": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/file_table.c b/fs/file_table.c\nindex e06c68e2d757..36fb200ae1a0 100644\n--- a/fs/file_table.c\n+++ b/fs/file_table.c\n@@ -160,7 +160,8 @@ 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\tput_cred(f->f_cred);\n+        kmem_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..07d8e21b1e9d 100644\n--- a/fs/file_table.c\n+++ b/fs/file_table.c\n@@ -160,7 +160,9 @@ 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\tif (f->f_cred) {\n+            file_free_rcu(&f->f_rcuhead);\n+        }\n \t\treturn error;\n \t}\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/file_table.c b/fs/file_table.c\nindex e06c68e2d757..4d7f1c8b9cc7 100644\n--- a/fs/file_table.c\n+++ b/fs/file_table.c\n@@ -160,7 +160,9 @@ 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\tif (f->f_flags & FMODE_INIT_DONE) {\n+            file_free_rcu(&f->f_rcuhead);\n+        }\n \t\treturn error;\n \t}\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/file_table.c b/fs/file_table.c\nindex e06c68e2d757..51a5616a4fd8 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\tif (f->f_rcuhead) file_free_rcu(&f->f_rcuhead);\n \t\treturn error;\n \t}\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "80b047eb9aff0254f4adc620c6891c0ca3276309": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/tipc/monitor.c b/net/tipc/monitor.c\nindex 6dce2abf436e..1b42e1cca32f 100644\n--- a/net/tipc/monitor.c\n+++ b/net/tipc/monitor.c\n@@ -716,7 +716,7 @@ static int __tipc_nl_add_monitor_peer(struct tipc_peer *peer,\n \n \thdr = genlmsg_put(msg->skb, msg->portid, msg->seq, &tipc_genl_family,\n \t\t\t  NLM_F_MULTI, TIPC_NL_MON_PEER_GET);\n-\tif (!hdr)\n+\tif (!hdr || !msg->skb)\n \t\treturn -EMSGSIZE;\n \n \tattrs = nla_nest_start_noflag(msg->skb, TIPC_NLA_MON_PEER);\n@@ -805,7 +805,7 @@ int __tipc_nl_add_monitor(struct net *net, struct tipc_nl_msg *msg,\n \n \thdr = genlmsg_put(msg->skb, msg->portid, msg->seq, &tipc_genl_family,\n \t\t\t  NLM_F_MULTI, TIPC_NL_MON_GET);\n-\tif (!hdr)\n+\tif (!hdr || !msg->skb)\n \t\treturn -EMSGSIZE;\n \n \tattrs = nla_nest_start_noflag(msg->skb, TIPC_NLA_MON);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/tipc/monitor.c b/net/tipc/monitor.c\nindex 6dce2abf436e..c1ce8849640f 100644\n--- a/net/tipc/monitor.c\n+++ b/net/tipc/monitor.c\n@@ -556,6 +556,7 @@ void tipc_mon_prep(struct net *net, void *data, int *dlen,\n \t}\n \t/* Send the full record */\n \tread_lock_bh(&mon->lock);\n+    atomic_inc(&peer->refcnt);\n \tlen = ntohs(mon->cache.len);\n \t*dlen = len;\n \tmemcpy(data, &mon->cache, len);\n@@ -583,6 +584,7 @@ void tipc_mon_get_state(struct net *net, u32 addr,\n \t\treturn;\n \n \tread_lock_bh(&mon->lock);\n+    atomic_inc(&peer->refcnt);\n \tpeer = get_peer(mon, addr);\n \tif (peer) {\n \t\tstate->probing = state->acked_gen != mon->dom_gen;\n@@ -771,6 +773,7 @@ int tipc_nl_add_monitor_peer(struct net *net, struct tipc_nl_msg *msg,\n \t\treturn -EINVAL;\n \n \tread_lock_bh(&mon->lock);\n+    atomic_inc(&peer->refcnt);\n \tpeer = mon->self;\n \tdo {\n \t\tif (*prev_node) {\n@@ -813,6 +816,7 @@ int __tipc_nl_add_monitor(struct net *net, struct tipc_nl_msg *msg,\n \t\tgoto msg_full;\n \n \tread_lock_bh(&mon->lock);\n+    atomic_inc(&peer->refcnt);\n \tif (nla_put_u32(msg->skb, TIPC_NLA_MON_REF, bearer_id))\n \t\tgoto attr_msg_full;\n \tif (tipc_mon_is_active(net, mon))\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/tipc/node.c b/net/tipc/node.c\nindex a4c2816c3746..de40c2b5c843 100644\n--- a/net/tipc/node.c\n+++ b/net/tipc/node.c\n@@ -2768,7 +2768,11 @@ int tipc_nl_node_dump_monitor(struct sk_buff *skb, struct netlink_callback *cb)\n \treturn skb->len;\n }\n \n-int tipc_nl_node_dump_monitor_peer(struct sk_buff *skb,\n+int /* Ensure skb is not accessed after being freed */\n+    if (!skb || !skb->data)\n+        return -EINVAL;\n+\n+    tipc_nl_node_dump_monitor_peer(struct sk_buff *skb,\n \t\t\t\t   struct netlink_callback *cb)\n {\n \tstruct net *net = sock_net(skb->sk);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "fea1767458f80cd02b783a4a317e76c229ffddab": {
        "non_crash": [
            "diff --git a/net/netfilter/nf_conntrack_proto_icmp.c b/net/netfilter/nf_conntrack_proto_icmp.c\nindex de64d8a5fdfd..a213d7c11503 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+    if (!timeout)\n+        return -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..d96a7f474acb 100644\n--- a/net/netfilter/nf_conntrack_proto_icmp.c\n+++ b/net/netfilter/nf_conntrack_proto_icmp.c\n@@ -289,7 +289,7 @@ icmp_timeout_obj_to_nlattr(struct sk_buff *skb, const void *data)\n {\n \tconst unsigned int *timeout = data;\n \n-\tif (nla_put_be32(skb, CTA_TIMEOUT_ICMP_TIMEOUT, htonl(*timeout / HZ)))\n+\tif (!timeout || nla_put_be32(skb, CTA_TIMEOUT_ICMP_TIMEOUT, htonl(*timeout / HZ)))\n \t\tgoto nla_put_failure;\n \treturn 0;\n \n",
            "diff --git a/net/netfilter/nf_conntrack_proto_icmp.c b/net/netfilter/nf_conntrack_proto_icmp.c\nindex de64d8a5fdfd..d96a7f474acb 100644\n--- a/net/netfilter/nf_conntrack_proto_icmp.c\n+++ b/net/netfilter/nf_conntrack_proto_icmp.c\n@@ -289,7 +289,7 @@ icmp_timeout_obj_to_nlattr(struct sk_buff *skb, const void *data)\n {\n \tconst unsigned int *timeout = data;\n \n-\tif (nla_put_be32(skb, CTA_TIMEOUT_ICMP_TIMEOUT, htonl(*timeout / HZ)))\n+\tif (!timeout || nla_put_be32(skb, CTA_TIMEOUT_ICMP_TIMEOUT, htonl(*timeout / HZ)))\n \t\tgoto nla_put_failure;\n \treturn 0;\n \n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/netfilter/nf_conntrack_proto_icmp.c b/net/netfilter/nf_conntrack_proto_icmp.c\nindex de64d8a5fdfd..ea94d3200625 100644\n--- a/net/netfilter/nf_conntrack_proto_icmp.c\n+++ b/net/netfilter/nf_conntrack_proto_icmp.c\n@@ -286,6 +286,10 @@ static int icmp_timeout_nlattr_to_obj(struct nlattr *tb[],\n \n static int\n icmp_timeout_obj_to_nlattr(struct sk_buff *skb, const void *data)\n+{\n+    if (!data) {\n+        return -EINVAL;\n+    }\n {\n \tconst unsigned int *timeout = data;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/netfilter/nf_conntrack_proto_icmp.c b/net/netfilter/nf_conntrack_proto_icmp.c\nindex de64d8a5fdfd..c3c4f202e8ef 100644\n--- a/net/netfilter/nf_conntrack_proto_icmp.c\n+++ b/net/netfilter/nf_conntrack_proto_icmp.c\n@@ -286,6 +286,19 @@ static int icmp_timeout_nlattr_to_obj(struct nlattr *tb[],\n \n static int\n icmp_timeout_obj_to_nlattr(struct sk_buff *skb, const void *data)\n+{\n+    const unsigned int *timeout = data;\n+    \n+    if (!timeout)\n+        return -EINVAL;\n+    \n+    if (nla_put_be32(skb, CTA_TIMEOUT_ICMP_TIMEOUT, htonl(*timeout / HZ)))\n+        goto nla_put_failure;\n+    return 0;\n+\n+nla_put_failure:\n+    return -ENOSPC;\n+}\n {\n \tconst unsigned int *timeout = data;\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "625eef83808cdc8a4d6775801b04e985eb32fcf7": {
        "non_crash": [
            "diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c\nindex 19c707bc8801..02cb15446e2f 100644\n--- a/fs/btrfs/inode.c\n+++ b/fs/btrfs/inode.c\n@@ -2622,7 +2622,8 @@ 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 (len >= ordered->num_bytes) return -EINVAL;\n+    ret = btrfs_split_ordered_extent(ordered, len);\n \tif (ret)\n \t\treturn ret;\n \n",
            "diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c\nindex 19c707bc8801..7f07a2c754e6 100644\n--- a/fs/btrfs/inode.c\n+++ b/fs/btrfs/inode.c\n@@ -2622,7 +2622,9 @@ 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 (len >= ordered->num_bytes)\n+return -EINVAL;\n+ret = btrfs_split_ordered_extent(ordered, len);\n \tif (ret)\n \t\treturn ret;\n \n",
            "diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c\nindex 19c707bc8801..6da94d6b4062 100644\n--- a/fs/btrfs/inode.c\n+++ b/fs/btrfs/inode.c\n@@ -2622,7 +2622,10 @@ 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 (len >= ordered->num_bytes) {\n+        return -EINVAL;\n+    }\n+    ret = btrfs_split_ordered_extent(ordered, len);\n \tif (ret)\n \t\treturn ret;\n \n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/fs/btrfs/ordered-data.c b/fs/btrfs/ordered-data.c\nindex a9778a91511e..dab45bdf3d4f 100644\n--- a/fs/btrfs/ordered-data.c\n+++ b/fs/btrfs/ordered-data.c\n@@ -1118,6 +1118,9 @@ bool btrfs_try_lock_ordered_range(struct btrfs_inode *inode, u64 start, u64 end,\n \n /* Split out a new ordered extent for this first @len bytes of @ordered. */\n int btrfs_split_ordered_extent(struct btrfs_ordered_extent *ordered, u64 len)\n+{\n+if (len >= ordered->num_bytes)\n+return -EINVAL;\n {\n \tstruct inode *inode = ordered->inode;\n \tstruct btrfs_ordered_inode_tree *tree = &BTRFS_I(inode)->ordered_tree;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "c7c63c2548579c7e4718d2f8bc079a6e152e4ac8": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 354cb472f386..e510032264f7 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -260,7 +260,8 @@ static void *__nf_hook_entries_try_shrink(struct nf_hook_entries *old,\n \thooks_validate(new);\n out_assign:\n \trcu_assign_pointer(*pp, new);\n-\treturn old;\n+\tnf_hook_entries_free(old);\n+return NULL;\n }\n \n static struct nf_hook_entries __rcu **\n",
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 354cb472f386..76660225fd4d 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -105,6 +105,7 @@ nf_hook_entries_grow(const struct nf_hook_entries *old,\n \t\t     const struct nf_hook_ops *reg)\n {\n \tunsigned int i, alloc_entries, nhooks, old_entries;\n+    smp_mb(); /* Ensure memory barrier for proper synchronization */\n \tstruct nf_hook_ops **orig_ops = NULL;\n \tstruct nf_hook_ops **new_ops;\n \tstruct nf_hook_entries *new;\n",
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 354cb472f386..f458f35ac0ce 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -188,7 +188,9 @@ int nf_hook_entries_insert_raw(struct nf_hook_entries __rcu **pp,\n \tstruct nf_hook_entries *new_hooks;\n \tstruct nf_hook_entries *p;\n \n-\tp = rcu_dereference_raw(*pp);\n+\trcu_read_lock();\n+    p = rcu_dereference(*pp);\n+    rcu_read_unlock();\n \tnew_hooks = nf_hook_entries_grow(p, reg);\n \tif (IS_ERR(new_hooks))\n \t\treturn PTR_ERR(new_hooks);\n",
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 354cb472f386..7ae3db74b9e6 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -101,7 +101,7 @@ static const struct nf_hook_ops dummy_ops = {\n };\n \n static struct nf_hook_entries *\n-nf_hook_entries_grow(const struct nf_hook_entries *old,\n+nf_hook_entries_grow(const struct nf_hook_entries __rcu *old,\n \t\t     const struct nf_hook_ops *reg)\n {\n \tunsigned int i, alloc_entries, nhooks, old_entries;\n",
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 354cb472f386..8e8ec78a516a 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -198,7 +198,8 @@ int nf_hook_entries_insert_raw(struct nf_hook_entries __rcu **pp,\n \trcu_assign_pointer(*pp, new_hooks);\n \n \tBUG_ON(p == new_hooks);\n-\tnf_hook_entries_free(p);\n+\tsynchronize_rcu();\n+    nf_hook_entries_free(p);\n \treturn 0;\n }\n EXPORT_SYMBOL_GPL(nf_hook_entries_insert_raw);\n"
        ],
        "error": []
    },
    "e9f526f59d5b25decd3b91d4270b5da2aa23c8f6": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/drivers/media/common/videobuf2/videobuf2-vmalloc.c b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\nindex 6dfbd5b05907..3f88cc59b329 100644\n--- a/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n+++ b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n@@ -126,6 +126,9 @@ static void *vb2_vmalloc_get_userptr(struct device *dev, unsigned long vaddr,\n }\n \n static void vb2_vmalloc_put_userptr(void *buf_priv)\n+{\n+if (!buf_priv || !((struct vb2_vmalloc_buf *)buf_priv)->vec)\n+return;\n {\n \tstruct vb2_vmalloc_buf *buf = buf_priv;\n \tunsigned long vaddr = (unsigned long)buf->vaddr & PAGE_MASK;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/media/common/videobuf2/videobuf2-vmalloc.c b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\nindex 6dfbd5b05907..bb7db3eafd72 100644\n--- a/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n+++ b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n@@ -126,6 +126,16 @@ static void *vb2_vmalloc_get_userptr(struct device *dev, unsigned long vaddr,\n }\n \n static void vb2_vmalloc_put_userptr(void *buf_priv)\n+{\n+    if (!buf_priv) {\n+        pr_err(\"Invalid buffer pointer\\n\");\n+        return;\n+    }\n+    struct vb2_vmalloc_buf *buf = buf_priv;\n+    if (!buf->vec) {\n+        pr_err(\"Invalid frame vector\\n\");\n+        return;\n+    }\n {\n \tstruct vb2_vmalloc_buf *buf = buf_priv;\n \tunsigned long vaddr = (unsigned long)buf->vaddr & PAGE_MASK;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/media/common/videobuf2/videobuf2-vmalloc.c b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\nindex 6dfbd5b05907..79646dacce3f 100644\n--- a/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n+++ b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n@@ -126,6 +126,12 @@ static void *vb2_vmalloc_get_userptr(struct device *dev, unsigned long vaddr,\n }\n \n static void vb2_vmalloc_put_userptr(void *buf_priv)\n+{\n+    struct vb2_vmalloc_buf *buf = buf_priv;\n+    if (!buf->vec) {\n+        pr_err(\"Attempting to release a buffer with a NULL frame vector\\n\");\n+        return;\n+    }\n {\n \tstruct vb2_vmalloc_buf *buf = buf_priv;\n \tunsigned long vaddr = (unsigned long)buf->vaddr & PAGE_MASK;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/media/common/videobuf2/videobuf2-vmalloc.c b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\nindex 6dfbd5b05907..5a557909f28d 100644\n--- a/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n+++ b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n@@ -126,6 +126,16 @@ static void *vb2_vmalloc_get_userptr(struct device *dev, unsigned long vaddr,\n }\n \n static void vb2_vmalloc_put_userptr(void *buf_priv)\n+{\n+    struct vb2_vmalloc_buf *buf = buf_priv;\n+    if (!buf || !buf->vec || !buf->vaddr) {\n+        pr_err(\"Invalid buffer or vector or address, cannot put user pointer\\n\");\n+        return;\n+    }\n+    unsigned long vaddr = (unsigned long)buf->vaddr & PAGE_MASK;\n+    unsigned int i;\n+    struct page **pages;\n+    unsigned int n_pages;\n {\n \tstruct vb2_vmalloc_buf *buf = buf_priv;\n \tunsigned long vaddr = (unsigned long)buf->vaddr & PAGE_MASK;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/media/common/videobuf2/videobuf2-vmalloc.c b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\nindex 6dfbd5b05907..0a51cdfd6ce8 100644\n--- a/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n+++ b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n@@ -126,6 +126,13 @@ static void *vb2_vmalloc_get_userptr(struct device *dev, unsigned long vaddr,\n }\n \n static void vb2_vmalloc_put_userptr(void *buf_priv)\n+{\n+    struct vb2_vmalloc_buf *buf = buf_priv;\n+\n+    if (IS_ERR_OR_NULL(buf->vec)) {\n+        kfree(buf);\n+        return;\n+    }\n {\n \tstruct vb2_vmalloc_buf *buf = buf_priv;\n \tunsigned long vaddr = (unsigned long)buf->vaddr & PAGE_MASK;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "49b6f675bead6969f913a3f7dcef4d28fdd13296": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/mmap.c b/mm/mmap.c\nindex 51e70fa98450..3122beeea49e 100644\n--- a/mm/mmap.c\n+++ b/mm/mmap.c\n@@ -333,7 +333,7 @@ static void validate_mm(struct mm_struct *mm)\n #endif\n \t\ti++;\n \t}\n-\tif (i != mm->map_count) {\n+\tif (i < mm->map_count) {\n \t\tpr_emerg(\"map_count %d vma iterator %d\\n\", mm->map_count, i);\n \t\tbug = 1;\n \t}\n"
        ],
        "error": []
    },
    "02617ac69815ae324053c954118c2dc7ba0e59b2": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/tls/tls_sw.c b/net/tls/tls_sw.c\nindex 0024a692f0f8..b953f199ce98 100644\n--- a/net/tls/tls_sw.c\n+++ b/net/tls/tls_sw.c\n@@ -1486,7 +1486,12 @@ static int decrypt_internal(struct sock *sk, struct sk_buff *skb,\n \t}\n \n \t/* Prepare IV */\n-\terr = skb_copy_bits(skb, rxm->offset + TLS_HEADER_SIZE,\n+\tif (unlikely(rxm->offset + TLS_HEADER_SIZE + prot->iv_size > skb->len)) {\n+kfree(mem);\n+return -EFAULT;\n+}\n+\n+err = skb_copy_bits(skb, rxm->offset + TLS_HEADER_SIZE,\n \t\t\t    iv + iv_offset + prot->salt_size,\n \t\t\t    prot->iv_size);\n \tif (err < 0) {\n",
            "diff --git a/net/tls/tls_sw.c b/net/tls/tls_sw.c\nindex 0024a692f0f8..3b805aa4e729 100644\n--- a/net/tls/tls_sw.c\n+++ b/net/tls/tls_sw.c\n@@ -1487,7 +1487,7 @@ static int decrypt_internal(struct sock *sk, struct sk_buff *skb,\n \n \t/* Prepare IV */\n \terr = skb_copy_bits(skb, rxm->offset + TLS_HEADER_SIZE,\n-\t\t\t    iv + iv_offset + prot->salt_size,\n+\t\t\t    iv + iv_offset,\n \t\t\t    prot->iv_size);\n \tif (err < 0) {\n \t\tkfree(mem);\n",
            "diff --git a/net/tls/tls_sw.c b/net/tls/tls_sw.c\nindex 0024a692f0f8..35cf249e26cd 100644\n--- a/net/tls/tls_sw.c\n+++ b/net/tls/tls_sw.c\n@@ -1486,7 +1486,8 @@ static int decrypt_internal(struct sock *sk, struct sk_buff *skb,\n \t}\n \n \t/* Prepare IV */\n-\terr = skb_copy_bits(skb, rxm->offset + TLS_HEADER_SIZE,\n+\tif (rxm->offset + TLS_HEADER_SIZE + prot->salt_size + prot->iv_size <= skb->len)\n+        err = skb_copy_bits(skb, rxm->offset + TLS_HEADER_SIZE,\n \t\t\t    iv + iv_offset + prot->salt_size,\n \t\t\t    prot->iv_size);\n \tif (err < 0) {\n"
        ],
        "error": []
    },
    "e0623166295289b0b91d327386331328f3f2505d": {
        "non_crash": [
            "diff --git a/net/hsr/hsr_device.c b/net/hsr/hsr_device.c\nindex 478852ef98ef..906c9ae91b0f 100644\n--- a/net/hsr/hsr_device.c\n+++ b/net/hsr/hsr_device.c\n@@ -480,7 +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+\thsr_del_ports(hsr);\n+    unregister_netdevice(hsr_dev);\n err_unregister:\n \thsr_del_ports(hsr);\n err_add_master:\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/hsr/hsr_device.c b/net/hsr/hsr_device.c\nindex 478852ef98ef..429d5eb3883e 100644\n--- a/net/hsr/hsr_device.c\n+++ b/net/hsr/hsr_device.c\n@@ -480,10 +480,13 @@ int hsr_dev_finalize(struct net_device *hsr_dev, struct net_device *slave[2],\n \treturn 0;\n \n err_add_slaves:\n+    pr_info(\"HSR: Failed to add slave ports, cleaning up.\");\n \tunregister_netdevice(hsr_dev);\n err_unregister:\n+    pr_info(\"HSR: Failed to register netdevice, cleaning up.\");\n \thsr_del_ports(hsr);\n err_add_master:\n+    pr_info(\"HSR: Failed to add master port, cleaning up.\");\n \thsr_del_self_node(hsr);\n \n \treturn res;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/hsr/hsr_framereg.c b/net/hsr/hsr_framereg.c\nindex 03b891904314..30866ccf334b 100644\n--- a/net/hsr/hsr_framereg.c\n+++ b/net/hsr/hsr_framereg.c\n@@ -118,6 +118,17 @@ void hsr_del_self_node(struct hsr_priv *hsr)\n }\n \n void hsr_del_nodes(struct list_head *node_db)\n+{\n+    struct hsr_node *node;\n+    struct hsr_node *tmp;\n+\n+    spin_lock_bh(&hsr->list_lock);\n+    list_for_each_entry_safe(node, tmp, node_db, mac_list) {\n+        list_del_rcu(&node->mac_list);\n+        kfree_rcu(node, rcu_head);\n+    }\n+    spin_unlock_bh(&hsr->list_lock);\n+}\n {\n \tstruct hsr_node *node;\n \tstruct hsr_node *tmp;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/hsr/hsr_device.c b/net/hsr/hsr_device.c\nindex 478852ef98ef..314d23317abd 100644\n--- a/net/hsr/hsr_device.c\n+++ b/net/hsr/hsr_device.c\n@@ -480,7 +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+\thsr_dev->state = NETDEV_UNREGISTERED;\n+    unregister_netdevice(hsr_dev);\n err_unregister:\n \thsr_del_ports(hsr);\n err_add_master:\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "4b5b6bdc090752dbcdd7e220a4703fed752cdfe7": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/fs/nilfs2/page.c b/fs/nilfs2/page.c\nindex 5cf30827f244..af598c5eebd2 100644\n--- a/fs/nilfs2/page.c\n+++ b/fs/nilfs2/page.c\n@@ -384,6 +384,12 @@ void nilfs_clear_dirty_pages(struct address_space *mapping, bool silent)\n  * @silent: suppress [true] or print [false] warning messages\n  */\n void nilfs_clear_dirty_page(struct page *page, bool silent)\n+{\n+    if (!page->mapping) {\n+        if (!silent)\n+            printk(KERN_WARNING \"nilfs_clear_dirty_page: page->mapping is NULL\\n\");\n+        return;\n+    }\n {\n \tstruct inode *inode = page->mapping->host;\n \tstruct super_block *sb = inode->i_sb;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/nilfs2/page.c b/fs/nilfs2/page.c\nindex 5cf30827f244..699d06980c02 100644\n--- a/fs/nilfs2/page.c\n+++ b/fs/nilfs2/page.c\n@@ -384,6 +384,10 @@ void nilfs_clear_dirty_pages(struct address_space *mapping, bool silent)\n  * @silent: suppress [true] or print [false] warning messages\n  */\n void nilfs_clear_dirty_page(struct page *page, bool silent)\n+{\n+    if (!page || !page->mapping) {\n+        return;\n+    }\n {\n \tstruct inode *inode = page->mapping->host;\n \tstruct super_block *sb = inode->i_sb;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/nilfs2/page.c b/fs/nilfs2/page.c\nindex 5cf30827f244..d98cd988b25f 100644\n--- a/fs/nilfs2/page.c\n+++ b/fs/nilfs2/page.c\n@@ -384,6 +384,12 @@ void nilfs_clear_dirty_pages(struct address_space *mapping, bool silent)\n  * @silent: suppress [true] or print [false] warning messages\n  */\n void nilfs_clear_dirty_page(struct page *page, bool silent)\n+{\n+    if (!page->mapping) {\n+        if (!silent)\n+            pr_warn(\"nilfs_clear_dirty_page: page mapping is NULL\\n\");\n+        return;\n+    }\n {\n \tstruct inode *inode = page->mapping->host;\n \tstruct super_block *sb = inode->i_sb;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/nilfs2/page.c b/fs/nilfs2/page.c\nindex 5cf30827f244..811c63d5c8d4 100644\n--- a/fs/nilfs2/page.c\n+++ b/fs/nilfs2/page.c\n@@ -384,6 +384,10 @@ void nilfs_clear_dirty_pages(struct address_space *mapping, bool silent)\n  * @silent: suppress [true] or print [false] warning messages\n  */\n void nilfs_clear_dirty_page(struct page *page, bool silent)\n+{\n+    if (!page->mapping) {\n+        return;\n+    }\n {\n \tstruct inode *inode = page->mapping->host;\n \tstruct super_block *sb = inode->i_sb;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/nilfs2/page.c b/fs/nilfs2/page.c\nindex 5cf30827f244..1d95ae7c3812 100644\n--- a/fs/nilfs2/page.c\n+++ b/fs/nilfs2/page.c\n@@ -384,6 +384,8 @@ void nilfs_clear_dirty_pages(struct address_space *mapping, bool silent)\n  * @silent: suppress [true] or print [false] warning messages\n  */\n void nilfs_clear_dirty_page(struct page *page, bool silent)\n+{\n+    if (!page->mapping) return;\n {\n \tstruct inode *inode = page->mapping->host;\n \tstruct super_block *sb = inode->i_sb;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "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..f8b3d8fcb5a5 100644\n--- a/drivers/net/can/usb/gs_usb.c\n+++ b/drivers/net/can/usb/gs_usb.c\n@@ -956,7 +956,8 @@ static struct gs_can *gs_make_candev(unsigned int channel,\n \t\t\t\"Couldn't get bit timing const for channel (err=%d)\\n\",\n \t\t\trc);\n \t\tkfree(bt_const);\n-\t\treturn ERR_PTR(rc);\n+\t\tfree_candev(netdev);\n+return ERR_PTR(rc);\n \t}\n \n \t/* create netdev */\n@@ -1078,7 +1079,8 @@ static struct gs_can *gs_make_candev(unsigned int channel,\n \t\t\t\t\"Couldn't get extended bit timing const for channel (err=%d)\\n\",\n \t\t\t\trc);\n \t\t\tkfree(bt_const_extended);\n-\t\t\treturn ERR_PTR(rc);\n+\t\t\tfree_candev(netdev);\n+return ERR_PTR(rc);\n \t\t}\n \n \t\tstrcpy(dev->data_bt_const.name, \"gs_usb\");\n@@ -1100,7 +1102,8 @@ static struct gs_can *gs_make_candev(unsigned int channel,\n \tif (rc) {\n \t\tfree_candev(dev->netdev);\n \t\tdev_err(&intf->dev, \"Couldn't register candev (err=%d)\\n\", rc);\n-\t\treturn ERR_PTR(rc);\n+\t\tfree_candev(netdev);\n+return ERR_PTR(rc);\n \t}\n \n \treturn dev;\n",
            "diff --git a/drivers/net/can/usb/gs_usb.c b/drivers/net/can/usb/gs_usb.c\nindex 67408e316062..3b76c9aaa3e7 100644\n--- a/drivers/net/can/usb/gs_usb.c\n+++ b/drivers/net/can/usb/gs_usb.c\n@@ -956,7 +956,8 @@ static struct gs_can *gs_make_candev(unsigned int channel,\n \t\t\t\"Couldn't get bit timing const for channel (err=%d)\\n\",\n \t\t\trc);\n \t\tkfree(bt_const);\n-\t\treturn ERR_PTR(rc);\n+\t\tkfree(netdev);\n+        return ERR_PTR(rc);\n \t}\n \n \t/* create netdev */\n",
            "diff --git a/drivers/net/can/usb/gs_usb.c b/drivers/net/can/usb/gs_usb.c\nindex 67408e316062..d8828e81447b 100644\n--- a/drivers/net/can/usb/gs_usb.c\n+++ b/drivers/net/can/usb/gs_usb.c\n@@ -956,7 +956,8 @@ static struct gs_can *gs_make_candev(unsigned int channel,\n \t\t\t\"Couldn't get bit timing const for channel (err=%d)\\n\",\n \t\t\trc);\n \t\tkfree(bt_const);\n-\t\treturn ERR_PTR(rc);\n+\t\tfree_candev(netdev);\n+        return ERR_PTR(rc);\n \t}\n \n \t/* create netdev */\n@@ -1078,7 +1079,8 @@ static struct gs_can *gs_make_candev(unsigned int channel,\n \t\t\t\t\"Couldn't get extended bit timing const for channel (err=%d)\\n\",\n \t\t\t\trc);\n \t\t\tkfree(bt_const_extended);\n-\t\t\treturn ERR_PTR(rc);\n+\t\t\tfree_candev(netdev);\n+        return ERR_PTR(rc);\n \t\t}\n \n \t\tstrcpy(dev->data_bt_const.name, \"gs_usb\");\n@@ -1100,7 +1102,8 @@ static struct gs_can *gs_make_candev(unsigned int channel,\n \tif (rc) {\n \t\tfree_candev(dev->netdev);\n \t\tdev_err(&intf->dev, \"Couldn't register candev (err=%d)\\n\", rc);\n-\t\treturn ERR_PTR(rc);\n+\t\tfree_candev(netdev);\n+        return ERR_PTR(rc);\n \t}\n \n \treturn dev;\n",
            "diff --git a/drivers/net/can/usb/gs_usb.c b/drivers/net/can/usb/gs_usb.c\nindex 67408e316062..f8b3d8fcb5a5 100644\n--- a/drivers/net/can/usb/gs_usb.c\n+++ b/drivers/net/can/usb/gs_usb.c\n@@ -956,7 +956,8 @@ static struct gs_can *gs_make_candev(unsigned int channel,\n \t\t\t\"Couldn't get bit timing const for channel (err=%d)\\n\",\n \t\t\trc);\n \t\tkfree(bt_const);\n-\t\treturn ERR_PTR(rc);\n+\t\tfree_candev(netdev);\n+return ERR_PTR(rc);\n \t}\n \n \t/* create netdev */\n@@ -1078,7 +1079,8 @@ static struct gs_can *gs_make_candev(unsigned int channel,\n \t\t\t\t\"Couldn't get extended bit timing const for channel (err=%d)\\n\",\n \t\t\t\trc);\n \t\t\tkfree(bt_const_extended);\n-\t\t\treturn ERR_PTR(rc);\n+\t\t\tfree_candev(netdev);\n+return ERR_PTR(rc);\n \t\t}\n \n \t\tstrcpy(dev->data_bt_const.name, \"gs_usb\");\n@@ -1100,7 +1102,8 @@ static struct gs_can *gs_make_candev(unsigned int channel,\n \tif (rc) {\n \t\tfree_candev(dev->netdev);\n \t\tdev_err(&intf->dev, \"Couldn't register candev (err=%d)\\n\", rc);\n-\t\treturn ERR_PTR(rc);\n+\t\tfree_candev(netdev);\n+return ERR_PTR(rc);\n \t}\n \n \treturn dev;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/net/can/usb/gs_usb.c b/drivers/net/can/usb/gs_usb.c\nindex 67408e316062..dab2f47d9706 100644\n--- a/drivers/net/can/usb/gs_usb.c\n+++ b/drivers/net/can/usb/gs_usb.c\n@@ -334,7 +334,8 @@ static int gs_cmd_reset(struct gs_can *gsdev)\n \n \tdm = kzalloc(sizeof(*dm), GFP_KERNEL);\n \tif (!dm)\n-\t\treturn -ENOMEM;\n+\t\tkfree(dconf);\n+    return -ENOMEM;\n \n \tdm->mode = GS_CAN_MODE_RESET;\n \n@@ -515,7 +516,8 @@ static int gs_usb_set_bittiming(struct net_device *netdev)\n \n \tdbt = kmalloc(sizeof(*dbt), GFP_KERNEL);\n \tif (!dbt)\n-\t\treturn -ENOMEM;\n+\t\tkfree(dconf);\n+    return -ENOMEM;\n \n \tdbt->prop_seg = cpu_to_le32(bt->prop_seg);\n \tdbt->phase_seg1 = cpu_to_le32(bt->phase_seg1);\n@@ -550,7 +552,8 @@ static int gs_usb_set_data_bittiming(struct net_device *netdev)\n \n \tdbt = kmalloc(sizeof(*dbt), GFP_KERNEL);\n \tif (!dbt)\n-\t\treturn -ENOMEM;\n+\t\tkfree(dconf);\n+    return -ENOMEM;\n \n \tdbt->prop_seg = cpu_to_le32(bt->prop_seg);\n \tdbt->phase_seg1 = cpu_to_le32(bt->phase_seg1);\n@@ -746,7 +749,8 @@ static int gs_can_open(struct net_device *netdev)\n \t\t\t/* alloc rx urb */\n \t\t\turb = usb_alloc_urb(0, GFP_KERNEL);\n \t\t\tif (!urb)\n-\t\t\t\treturn -ENOMEM;\n+\t\t\t\tkfree(dconf);\n+    return -ENOMEM;\n \n \t\t\t/* alloc rx buffer */\n \t\t\tbuf = usb_alloc_coherent(dev->udev,\n@@ -757,7 +761,8 @@ static int gs_can_open(struct net_device *netdev)\n \t\t\t\tnetdev_err(netdev,\n \t\t\t\t\t   \"No memory left for USB buffer\\n\");\n \t\t\t\tusb_free_urb(urb);\n-\t\t\t\treturn -ENOMEM;\n+\t\t\t\tkfree(dconf);\n+    return -ENOMEM;\n \t\t\t}\n \n \t\t\t/* fill, anchor, and submit rx urb */\n@@ -794,7 +799,8 @@ static int gs_can_open(struct net_device *netdev)\n \n \tdm = kmalloc(sizeof(*dm), GFP_KERNEL);\n \tif (!dm)\n-\t\treturn -ENOMEM;\n+\t\tkfree(dconf);\n+    return -ENOMEM;\n \n \t/* flags */\n \tif (ctrlmode & CAN_CTRLMODE_LOOPBACK)\n@@ -887,7 +893,8 @@ static int gs_usb_set_identify(struct net_device *netdev, bool do_identify)\n \timode = kmalloc(sizeof(*imode), GFP_KERNEL);\n \n \tif (!imode)\n-\t\treturn -ENOMEM;\n+\t\tkfree(dconf);\n+    return -ENOMEM;\n \n \tif (do_identify)\n \t\timode->mode = cpu_to_le32(GS_CAN_IDENTIFY_ON);\n@@ -1126,7 +1133,8 @@ static int gs_usb_probe(struct usb_interface *intf,\n \n \thconf = kmalloc(sizeof(*hconf), GFP_KERNEL);\n \tif (!hconf)\n-\t\treturn -ENOMEM;\n+\t\tkfree(dconf);\n+    return -ENOMEM;\n \n \thconf->byte_order = cpu_to_le32(0x0000beef);\n \n@@ -1146,7 +1154,8 @@ static int gs_usb_probe(struct usb_interface *intf,\n \n \tdconf = kmalloc(sizeof(*dconf), GFP_KERNEL);\n \tif (!dconf)\n-\t\treturn -ENOMEM;\n+\t\tkfree(dconf);\n+    return -ENOMEM;\n \n \t/* read device config */\n \trc = usb_control_msg(udev, usb_rcvctrlpipe(udev, 0),\n@@ -1175,7 +1184,8 @@ static int gs_usb_probe(struct usb_interface *intf,\n \tdev = kzalloc(sizeof(*dev), GFP_KERNEL);\n \tif (!dev) {\n \t\tkfree(dconf);\n-\t\treturn -ENOMEM;\n+\t\tkfree(dconf);\n+    return -ENOMEM;\n \t}\n \n \tinit_usb_anchor(&dev->rx_submitted);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "95277dbea9484baea60662d0243a93011a21ceb5": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex ce5dfa3babd2..ffe7765531e7 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1165,7 +1165,8 @@ static void __ebt_unregister_table(struct net *net, struct ebt_table *table)\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+\tif (!table->private->entries || table->private->entries_size == 0) return;\n+    EBT_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",
            "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex ce5dfa3babd2..b4273fa36f9c 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1213,7 +1213,11 @@ int ebt_register_table(struct net *net, const struct ebt_table *input_table,\n \tmemcpy(p, repl->entries, repl->entries_size);\n \tnewinfo->entries = p;\n \n-\tnewinfo->entries_size = repl->entries_size;\n+\tif (repl->entries_size < sizeof(struct ebt_entry) * repl->nentries) {\n+        vfree(p);\n+        goto free_newinfo;\n+    }\n+    newinfo->entries_size = repl->entries_size;\n \tnewinfo->nentries = repl->nentries;\n \n \tif (countersize)\n",
            "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex ce5dfa3babd2..703c59e66175 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1213,7 +1213,11 @@ int ebt_register_table(struct net *net, const struct ebt_table *input_table,\n \tmemcpy(p, repl->entries, repl->entries_size);\n \tnewinfo->entries = p;\n \n-\tnewinfo->entries_size = repl->entries_size;\n+\tif (repl->entries_size > sizeof(*newinfo)) {\n+        printk(KERN_ERR \"entries_size exceeds allocated memory bounds\\n\");\n+        goto free_table;\n+    }\n+    newinfo->entries_size = repl->entries_size;\n \tnewinfo->nentries = repl->nentries;\n \n \tif (countersize)\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex ce5dfa3babd2..cb25ddd847c6 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1165,7 +1165,8 @@ static void __ebt_unregister_table(struct net *net, struct ebt_table *table)\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+\tif (table->private->entries_size > 0) {\n+        EBT_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",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex ce5dfa3babd2..8fa47e05e38e 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1189,6 +1189,7 @@ int ebt_register_table(struct net *net, const struct ebt_table *input_table,\n \tvoid *p;\n \n \tif (input_table == NULL || (repl = input_table->table) == NULL ||\n+    repl->entries_size > MAX_ENTRIES_SIZE ||\n \t    repl->entries == NULL || repl->entries_size == 0 ||\n \t    repl->counters != NULL || input_table->private != NULL)\n \t\treturn -EINVAL;\n",
                "error_message": "Failed to build"
            }
        ]
    }
}