{
    "e8fc405587520f9442d64d47321fd53cef0f9bde": {
        "non_crash": [
            "diff --git a/drivers/block/zram/zram_drv.c b/drivers/block/zram/zram_drv.c\nindex f6d90f1ba5cf..414fd2b7b66c 100644\n--- a/drivers/block/zram/zram_drv.c\n+++ b/drivers/block/zram/zram_drv.c\n@@ -1359,7 +1359,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 (!init_done(zram)) return -EINVAL;\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"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/block/zram/zram_drv.c b/drivers/block/zram/zram_drv.c\nindex f6d90f1ba5cf..e9e9661e2512 100644\n--- a/drivers/block/zram/zram_drv.c\n+++ b/drivers/block/zram/zram_drv.c\n@@ -645,7 +645,8 @@ static ssize_t writeback_store(struct device *dev,\n \t\tgoto release_init_lock;\n \t}\n \n-\tfor (; nr_pages != 0; index++, nr_pages--) {\n+\tdown_read(&zram->init_lock);\n+    for (; nr_pages != 0; index++, nr_pages--) {\n \t\tspin_lock(&zram->wb_limit_lock);\n \t\tif (zram->wb_limit_enable && !zram->bd_wb_limit) {\n \t\t\tspin_unlock(&zram->wb_limit_lock);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/block/zram/zram_drv.c b/drivers/block/zram/zram_drv.c\nindex f6d90f1ba5cf..b509225ae877 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"
            },
            {
                "patch": "diff --git a/drivers/block/zram/zram_drv.c b/drivers/block/zram/zram_drv.c\nindex f6d90f1ba5cf..a74351e0f83d 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 >= num_pages) 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_message": "Failed to build"
            }
        ]
    },
    "daa1858cc0258eb026f89eecf342f6b3fdad7b05": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/sched/em_cmp.c b/net/sched/em_cmp.c\nindex f17b049ea530..57c7ba609434 100644\n--- a/net/sched/em_cmp.c\n+++ b/net/sched/em_cmp.c\n@@ -23,6 +23,8 @@ 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+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..3b7659928819 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 *base_ptr = tcf_get_base_ptr(skb, cmp->layer);\n+if (!base_ptr)\n+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..194ac9cffcd1 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 *base_ptr = tcf_get_base_ptr(skb, cmp->layer);\n+    if (!base_ptr)\n+        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": [
            {
                "patch": "diff --git a/net/sched/em_cmp.c b/net/sched/em_cmp.c\nindex f17b049ea530..c8d5967b1c80 100644\n--- a/net/sched/em_cmp.c\n+++ b/net/sched/em_cmp.c\n@@ -22,6 +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+    unsigned char *ptr = tcf_get_base_ptr(skb, cmp->layer) + cmp->off;\n+    if (!ptr || !tcf_valid_offset(skb, ptr, cmp->align))\n+        return 0;\n \tunsigned char *ptr = tcf_get_base_ptr(skb, cmp->layer) + cmp->off;\n \tu32 val = 0;\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "59174b68c3c9d5d3ecc323e0b0a0c5466b0e7d18": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/fs/nilfs2/sufile.c b/fs/nilfs2/sufile.c\nindex dc359b56fdfa..1fcb18a14879 100644\n--- a/fs/nilfs2/sufile.c\n+++ b/fs/nilfs2/sufile.c\n@@ -169,6 +169,55 @@ int nilfs_sufile_updatev(struct inode *sufile, __u64 *segnumv, size_t nsegs,\n \t\tgoto out;\n \n \tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+    for (seg = segnumv; seg < segnumv + nsegs; seg++) {\n+        if (unlikely(*seg >= nilfs_sufile_get_nsegments(sufile))) {\n+            nilfs_warn(sufile->i_sb,\n+                       \"%s: invalid segment number: %llu\",\n+                       __func__, (unsigned long long)*seg);\n+            nerr++;\n+        }\n+    }\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+    if (nerr > 0) {\n+        ret = -EINVAL;\n+        goto out;\n+    }\n+\n+    ret = nilfs_sufile_get_header_block(sufile, &header_bh);\n+    if (ret < 0)\n+        goto out;\n+\n+    seg = segnumv;\n+\n+    while (seg < segnumv + nsegs) {\n+        down_write(&NILFS_MDT(sufile)->mi_sem);\n+        blkoff = nilfs_sufile_get_blkoff(sufile, *seg);\n+        ret = nilfs_mdt_get_block(sufile, blkoff, create, NULL, &bh);\n+        if (ret < 0) {\n+            up_write(&NILFS_MDT(sufile)->mi_sem);\n+            break;\n+        }\n+\n+        dofunc(sufile, *seg, header_bh, bh);\n+        up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+        prev_blkoff = blkoff;\n+        seg++;\n+        blkoff = nilfs_sufile_get_blkoff(sufile, *seg);\n+        if (blkoff != prev_blkoff) {\n+            brelse(bh);\n+        }\n+    }\n+\n+    brelse(header_bh);\n+\n+out:\n+    n = seg - segnumv;\n+    if (ndone)\n+        *ndone = n;\n+    return ret;\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n \tfor (seg = segnumv; seg < segnumv + nsegs; seg++) {\n \t\tif (unlikely(*seg >= nilfs_sufile_get_nsegments(sufile))) {\n \t\t\tnilfs_warn(sufile->i_sb,\n@@ -235,6 +284,55 @@ int nilfs_sufile_update(struct inode *sufile, __u64 segnum, int create,\n \t\treturn -EINVAL;\n \t}\n \tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+    for (seg = segnumv; seg < segnumv + nsegs; seg++) {\n+        if (unlikely(*seg >= nilfs_sufile_get_nsegments(sufile))) {\n+            nilfs_warn(sufile->i_sb,\n+                       \"%s: invalid segment number: %llu\",\n+                       __func__, (unsigned long long)*seg);\n+            nerr++;\n+        }\n+    }\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+    if (nerr > 0) {\n+        ret = -EINVAL;\n+        goto out;\n+    }\n+\n+    ret = nilfs_sufile_get_header_block(sufile, &header_bh);\n+    if (ret < 0)\n+        goto out;\n+\n+    seg = segnumv;\n+\n+    while (seg < segnumv + nsegs) {\n+        down_write(&NILFS_MDT(sufile)->mi_sem);\n+        blkoff = nilfs_sufile_get_blkoff(sufile, *seg);\n+        ret = nilfs_mdt_get_block(sufile, blkoff, create, NULL, &bh);\n+        if (ret < 0) {\n+            up_write(&NILFS_MDT(sufile)->mi_sem);\n+            break;\n+        }\n+\n+        dofunc(sufile, *seg, header_bh, bh);\n+        up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+        prev_blkoff = blkoff;\n+        seg++;\n+        blkoff = nilfs_sufile_get_blkoff(sufile, *seg);\n+        if (blkoff != prev_blkoff) {\n+            brelse(bh);\n+        }\n+    }\n+\n+    brelse(header_bh);\n+\n+out:\n+    n = seg - segnumv;\n+    if (ndone)\n+        *ndone = n;\n+    return ret;\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n \n \tret = nilfs_sufile_get_header_block(sufile, &header_bh);\n \tif (ret < 0)\n@@ -270,6 +368,55 @@ int nilfs_sufile_set_alloc_range(struct inode *sufile, __u64 start, __u64 end)\n \tint ret = -ERANGE;\n \n \tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+    for (seg = segnumv; seg < segnumv + nsegs; seg++) {\n+        if (unlikely(*seg >= nilfs_sufile_get_nsegments(sufile))) {\n+            nilfs_warn(sufile->i_sb,\n+                       \"%s: invalid segment number: %llu\",\n+                       __func__, (unsigned long long)*seg);\n+            nerr++;\n+        }\n+    }\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+    if (nerr > 0) {\n+        ret = -EINVAL;\n+        goto out;\n+    }\n+\n+    ret = nilfs_sufile_get_header_block(sufile, &header_bh);\n+    if (ret < 0)\n+        goto out;\n+\n+    seg = segnumv;\n+\n+    while (seg < segnumv + nsegs) {\n+        down_write(&NILFS_MDT(sufile)->mi_sem);\n+        blkoff = nilfs_sufile_get_blkoff(sufile, *seg);\n+        ret = nilfs_mdt_get_block(sufile, blkoff, create, NULL, &bh);\n+        if (ret < 0) {\n+            up_write(&NILFS_MDT(sufile)->mi_sem);\n+            break;\n+        }\n+\n+        dofunc(sufile, *seg, header_bh, bh);\n+        up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+        prev_blkoff = blkoff;\n+        seg++;\n+        blkoff = nilfs_sufile_get_blkoff(sufile, *seg);\n+        if (blkoff != prev_blkoff) {\n+            brelse(bh);\n+        }\n+    }\n+\n+    brelse(header_bh);\n+\n+out:\n+    n = seg - segnumv;\n+    if (ndone)\n+        *ndone = n;\n+    return ret;\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n \tnsegs = nilfs_sufile_get_nsegments(sufile);\n \n \tif (start <= end && end < nsegs) {\n@@ -311,6 +458,55 @@ int nilfs_sufile_alloc(struct inode *sufile, __u64 *segnump)\n \tint ret, j;\n \n \tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+    for (seg = segnumv; seg < segnumv + nsegs; seg++) {\n+        if (unlikely(*seg >= nilfs_sufile_get_nsegments(sufile))) {\n+            nilfs_warn(sufile->i_sb,\n+                       \"%s: invalid segment number: %llu\",\n+                       __func__, (unsigned long long)*seg);\n+            nerr++;\n+        }\n+    }\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+    if (nerr > 0) {\n+        ret = -EINVAL;\n+        goto out;\n+    }\n+\n+    ret = nilfs_sufile_get_header_block(sufile, &header_bh);\n+    if (ret < 0)\n+        goto out;\n+\n+    seg = segnumv;\n+\n+    while (seg < segnumv + nsegs) {\n+        down_write(&NILFS_MDT(sufile)->mi_sem);\n+        blkoff = nilfs_sufile_get_blkoff(sufile, *seg);\n+        ret = nilfs_mdt_get_block(sufile, blkoff, create, NULL, &bh);\n+        if (ret < 0) {\n+            up_write(&NILFS_MDT(sufile)->mi_sem);\n+            break;\n+        }\n+\n+        dofunc(sufile, *seg, header_bh, bh);\n+        up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+        prev_blkoff = blkoff;\n+        seg++;\n+        blkoff = nilfs_sufile_get_blkoff(sufile, *seg);\n+        if (blkoff != prev_blkoff) {\n+            brelse(bh);\n+        }\n+    }\n+\n+    brelse(header_bh);\n+\n+out:\n+    n = seg - segnumv;\n+    if (ndone)\n+        *ndone = n;\n+    return ret;\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n \n \tret = nilfs_sufile_get_header_block(sufile, &header_bh);\n \tif (ret < 0)\n@@ -500,6 +696,55 @@ int nilfs_sufile_mark_dirty(struct inode *sufile, __u64 segnum)\n \tint ret;\n \n \tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+    for (seg = segnumv; seg < segnumv + nsegs; seg++) {\n+        if (unlikely(*seg >= nilfs_sufile_get_nsegments(sufile))) {\n+            nilfs_warn(sufile->i_sb,\n+                       \"%s: invalid segment number: %llu\",\n+                       __func__, (unsigned long long)*seg);\n+            nerr++;\n+        }\n+    }\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+    if (nerr > 0) {\n+        ret = -EINVAL;\n+        goto out;\n+    }\n+\n+    ret = nilfs_sufile_get_header_block(sufile, &header_bh);\n+    if (ret < 0)\n+        goto out;\n+\n+    seg = segnumv;\n+\n+    while (seg < segnumv + nsegs) {\n+        down_write(&NILFS_MDT(sufile)->mi_sem);\n+        blkoff = nilfs_sufile_get_blkoff(sufile, *seg);\n+        ret = nilfs_mdt_get_block(sufile, blkoff, create, NULL, &bh);\n+        if (ret < 0) {\n+            up_write(&NILFS_MDT(sufile)->mi_sem);\n+            break;\n+        }\n+\n+        dofunc(sufile, *seg, header_bh, bh);\n+        up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+        prev_blkoff = blkoff;\n+        seg++;\n+        blkoff = nilfs_sufile_get_blkoff(sufile, *seg);\n+        if (blkoff != prev_blkoff) {\n+            brelse(bh);\n+        }\n+    }\n+\n+    brelse(header_bh);\n+\n+out:\n+    n = seg - segnumv;\n+    if (ndone)\n+        *ndone = n;\n+    return ret;\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n \tret = nilfs_sufile_get_segment_usage_block(sufile, segnum, 0, &bh);\n \tif (!ret) {\n \t\tmark_buffer_dirty(bh);\n@@ -530,6 +775,55 @@ int nilfs_sufile_set_segment_usage(struct inode *sufile, __u64 segnum,\n \tint ret;\n \n \tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+    for (seg = segnumv; seg < segnumv + nsegs; seg++) {\n+        if (unlikely(*seg >= nilfs_sufile_get_nsegments(sufile))) {\n+            nilfs_warn(sufile->i_sb,\n+                       \"%s: invalid segment number: %llu\",\n+                       __func__, (unsigned long long)*seg);\n+            nerr++;\n+        }\n+    }\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+    if (nerr > 0) {\n+        ret = -EINVAL;\n+        goto out;\n+    }\n+\n+    ret = nilfs_sufile_get_header_block(sufile, &header_bh);\n+    if (ret < 0)\n+        goto out;\n+\n+    seg = segnumv;\n+\n+    while (seg < segnumv + nsegs) {\n+        down_write(&NILFS_MDT(sufile)->mi_sem);\n+        blkoff = nilfs_sufile_get_blkoff(sufile, *seg);\n+        ret = nilfs_mdt_get_block(sufile, blkoff, create, NULL, &bh);\n+        if (ret < 0) {\n+            up_write(&NILFS_MDT(sufile)->mi_sem);\n+            break;\n+        }\n+\n+        dofunc(sufile, *seg, header_bh, bh);\n+        up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+        prev_blkoff = blkoff;\n+        seg++;\n+        blkoff = nilfs_sufile_get_blkoff(sufile, *seg);\n+        if (blkoff != prev_blkoff) {\n+            brelse(bh);\n+        }\n+    }\n+\n+    brelse(header_bh);\n+\n+out:\n+    n = seg - segnumv;\n+    if (ndone)\n+        *ndone = n;\n+    return ret;\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n \tret = nilfs_sufile_get_segment_usage_block(sufile, segnum, 0, &bh);\n \tif (ret < 0)\n \t\tgoto out_sem;\n@@ -757,6 +1051,55 @@ int nilfs_sufile_resize(struct inode *sufile, __u64 newnsegs)\n \tint ret = 0;\n \n \tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+    for (seg = segnumv; seg < segnumv + nsegs; seg++) {\n+        if (unlikely(*seg >= nilfs_sufile_get_nsegments(sufile))) {\n+            nilfs_warn(sufile->i_sb,\n+                       \"%s: invalid segment number: %llu\",\n+                       __func__, (unsigned long long)*seg);\n+            nerr++;\n+        }\n+    }\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+    if (nerr > 0) {\n+        ret = -EINVAL;\n+        goto out;\n+    }\n+\n+    ret = nilfs_sufile_get_header_block(sufile, &header_bh);\n+    if (ret < 0)\n+        goto out;\n+\n+    seg = segnumv;\n+\n+    while (seg < segnumv + nsegs) {\n+        down_write(&NILFS_MDT(sufile)->mi_sem);\n+        blkoff = nilfs_sufile_get_blkoff(sufile, *seg);\n+        ret = nilfs_mdt_get_block(sufile, blkoff, create, NULL, &bh);\n+        if (ret < 0) {\n+            up_write(&NILFS_MDT(sufile)->mi_sem);\n+            break;\n+        }\n+\n+        dofunc(sufile, *seg, header_bh, bh);\n+        up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+        prev_blkoff = blkoff;\n+        seg++;\n+        blkoff = nilfs_sufile_get_blkoff(sufile, *seg);\n+        if (blkoff != prev_blkoff) {\n+            brelse(bh);\n+        }\n+    }\n+\n+    brelse(header_bh);\n+\n+out:\n+    n = seg - segnumv;\n+    if (ndone)\n+        *ndone = n;\n+    return ret;\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n \n \tnsegs = nilfs_sufile_get_nsegments(sufile);\n \tif (nsegs == newnsegs)\n@@ -919,6 +1262,55 @@ ssize_t nilfs_sufile_set_suinfo(struct inode *sufile, void *buf,\n \t}\n \n \tdown_write(&NILFS_MDT(sufile)->mi_sem);\n+    for (seg = segnumv; seg < segnumv + nsegs; seg++) {\n+        if (unlikely(*seg >= nilfs_sufile_get_nsegments(sufile))) {\n+            nilfs_warn(sufile->i_sb,\n+                       \"%s: invalid segment number: %llu\",\n+                       __func__, (unsigned long long)*seg);\n+            nerr++;\n+        }\n+    }\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+    if (nerr > 0) {\n+        ret = -EINVAL;\n+        goto out;\n+    }\n+\n+    ret = nilfs_sufile_get_header_block(sufile, &header_bh);\n+    if (ret < 0)\n+        goto out;\n+\n+    seg = segnumv;\n+\n+    while (seg < segnumv + nsegs) {\n+        down_write(&NILFS_MDT(sufile)->mi_sem);\n+        blkoff = nilfs_sufile_get_blkoff(sufile, *seg);\n+        ret = nilfs_mdt_get_block(sufile, blkoff, create, NULL, &bh);\n+        if (ret < 0) {\n+            up_write(&NILFS_MDT(sufile)->mi_sem);\n+            break;\n+        }\n+\n+        dofunc(sufile, *seg, header_bh, bh);\n+        up_write(&NILFS_MDT(sufile)->mi_sem);\n+\n+        prev_blkoff = blkoff;\n+        seg++;\n+        blkoff = nilfs_sufile_get_blkoff(sufile, *seg);\n+        if (blkoff != prev_blkoff) {\n+            brelse(bh);\n+        }\n+    }\n+\n+    brelse(header_bh);\n+\n+out:\n+    n = seg - segnumv;\n+    if (ndone)\n+        *ndone = n;\n+    return ret;\n+    up_write(&NILFS_MDT(sufile)->mi_sem);\n \n \tret = nilfs_sufile_get_header_block(sufile, &header_bh);\n \tif (ret < 0)\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/nilfs2/sufile.c b/fs/nilfs2/sufile.c\nindex dc359b56fdfa..01cddf771d86 100644\n--- a/fs/nilfs2/sufile.c\n+++ b/fs/nilfs2/sufile.c\n@@ -168,7 +168,7 @@ 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+\tdown_write_timeout(&NILFS_MDT(sufile)->mi_sem, 100);\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 +234,7 @@ 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+\tdown_write_timeout(&NILFS_MDT(sufile)->mi_sem, 100);\n \n \tret = nilfs_sufile_get_header_block(sufile, &header_bh);\n \tif (ret < 0)\n@@ -269,7 +269,7 @@ 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+\tdown_write_timeout(&NILFS_MDT(sufile)->mi_sem, 100);\n \tnsegs = nilfs_sufile_get_nsegments(sufile);\n \n \tif (start <= end && end < nsegs) {\n@@ -310,7 +310,7 @@ 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+\tdown_write_timeout(&NILFS_MDT(sufile)->mi_sem, 100);\n \n \tret = nilfs_sufile_get_header_block(sufile, &header_bh);\n \tif (ret < 0)\n@@ -499,7 +499,7 @@ 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+\tdown_write_timeout(&NILFS_MDT(sufile)->mi_sem, 100);\n \tret = nilfs_sufile_get_segment_usage_block(sufile, segnum, 0, &bh);\n \tif (!ret) {\n \t\tmark_buffer_dirty(bh);\n@@ -529,7 +529,7 @@ 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+\tdown_write_timeout(&NILFS_MDT(sufile)->mi_sem, 100);\n \tret = nilfs_sufile_get_segment_usage_block(sufile, segnum, 0, &bh);\n \tif (ret < 0)\n \t\tgoto out_sem;\n@@ -756,7 +756,7 @@ 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+\tdown_write_timeout(&NILFS_MDT(sufile)->mi_sem, 100);\n \n \tnsegs = nilfs_sufile_get_nsegments(sufile);\n \tif (nsegs == newnsegs)\n@@ -918,7 +918,7 @@ 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+\tdown_write_timeout(&NILFS_MDT(sufile)->mi_sem, 100);\n \n \tret = nilfs_sufile_get_header_block(sufile, &header_bh);\n \tif (ret < 0)\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..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": [
            "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",
            "diff --git a/net/sched/act_pedit.c b/net/sched/act_pedit.c\nindex fb93d4c1faca..48daf3f49693 100644\n--- a/net/sched/act_pedit.c\n+++ b/net/sched/act_pedit.c\n@@ -157,6 +157,7 @@ static int tcf_pedit_init(struct net *net, struct nlattr *nla,\n \tstruct tc_action_net *tn = net_generic(net, act_pedit_ops.net_id);\n \tbool bind = flags & TCA_ACT_FLAGS_BIND;\n \tstruct tcf_chain *goto_ch = NULL;\n+    struct tcf_pedit_parms *parms_to_free = NULL;\n \tstruct tcf_pedit_parms *oparms, *nparms;\n \tstruct nlattr *tb[TCA_PEDIT_MAX + 1];\n \tstruct tc_pedit *parm;\n@@ -229,7 +230,8 @@ 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\tparms_to_free = nparms;\n+        goto out_free;\n \t}\n \n \terr = tcf_action_check_ctrlact(parm->action, tp, &goto_ch, extack);\n@@ -299,6 +301,11 @@ static int tcf_pedit_init(struct net *net, struct nlattr *nla,\n out_free:\n \tkfree(nparms);\n out_release:\n+    if (parms_to_free) {\n+        kfree(parms_to_free->tcfp_keys_ex);\n+        kfree(parms_to_free->tcfp_keys);\n+        kfree(parms_to_free);\n+    }\n \ttcf_idr_release(*a, bind);\n \treturn ret;\n }\n",
            "diff --git a/net/sched/act_pedit.c b/net/sched/act_pedit.c\nindex fb93d4c1faca..46e801394fb1 100644\n--- a/net/sched/act_pedit.c\n+++ b/net/sched/act_pedit.c\n@@ -201,7 +201,8 @@ static int tcf_pedit_init(struct net *net, struct nlattr *nla,\n \t\t\treturn 0;\n \t\tif (!(flags & TCA_ACT_FLAGS_REPLACE)) {\n \t\t\tret = -EEXIST;\n-\t\t\tgoto out_release;\n+\t\t\tkfree(nparms);\n+    goto out_release;\n \t\t}\n \t} else {\n \t\treturn err;\n@@ -210,19 +211,22 @@ static int tcf_pedit_init(struct net *net, struct nlattr *nla,\n \tif (!parm->nkeys) {\n \t\tNL_SET_ERR_MSG_MOD(extack, \"Pedit requires keys to be passed\");\n \t\tret = -EINVAL;\n-\t\tgoto out_release;\n+\t\tkfree(nparms);\n+    goto out_release;\n \t}\n \tksize = parm->nkeys * sizeof(struct tc_pedit_key);\n \tif (nla_len(pattr) < sizeof(*parm) + ksize) {\n \t\tNL_SET_ERR_MSG_ATTR(extack, pattr, \"Length of TCA_PEDIT_PARMS or TCA_PEDIT_PARMS_EX pedit attribute is invalid\");\n \t\tret = -EINVAL;\n-\t\tgoto out_release;\n+\t\tkfree(nparms);\n+    goto out_release;\n \t}\n \n \tnparms = kzalloc(sizeof(*nparms), GFP_KERNEL);\n \tif (!nparms) {\n \t\tret = -ENOMEM;\n-\t\tgoto out_release;\n+\t\tkfree(nparms);\n+    goto out_release;\n \t}\n \n \tnparms->tcfp_keys_ex =\n",
            "diff --git a/net/sched/act_pedit.c b/net/sched/act_pedit.c\nindex fb93d4c1faca..46e801394fb1 100644\n--- a/net/sched/act_pedit.c\n+++ b/net/sched/act_pedit.c\n@@ -201,7 +201,8 @@ static int tcf_pedit_init(struct net *net, struct nlattr *nla,\n \t\t\treturn 0;\n \t\tif (!(flags & TCA_ACT_FLAGS_REPLACE)) {\n \t\t\tret = -EEXIST;\n-\t\t\tgoto out_release;\n+\t\t\tkfree(nparms);\n+    goto out_release;\n \t\t}\n \t} else {\n \t\treturn err;\n@@ -210,19 +211,22 @@ static int tcf_pedit_init(struct net *net, struct nlattr *nla,\n \tif (!parm->nkeys) {\n \t\tNL_SET_ERR_MSG_MOD(extack, \"Pedit requires keys to be passed\");\n \t\tret = -EINVAL;\n-\t\tgoto out_release;\n+\t\tkfree(nparms);\n+    goto out_release;\n \t}\n \tksize = parm->nkeys * sizeof(struct tc_pedit_key);\n \tif (nla_len(pattr) < sizeof(*parm) + ksize) {\n \t\tNL_SET_ERR_MSG_ATTR(extack, pattr, \"Length of TCA_PEDIT_PARMS or TCA_PEDIT_PARMS_EX pedit attribute is invalid\");\n \t\tret = -EINVAL;\n-\t\tgoto out_release;\n+\t\tkfree(nparms);\n+    goto out_release;\n \t}\n \n \tnparms = kzalloc(sizeof(*nparms), GFP_KERNEL);\n \tif (!nparms) {\n \t\tret = -ENOMEM;\n-\t\tgoto out_release;\n+\t\tkfree(nparms);\n+    goto out_release;\n \t}\n \n \tnparms->tcfp_keys_ex =\n"
        ],
        "error": []
    },
    "5d48b50ed679f22d7d4a4b578da8559d34b104ac": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/lib/percpu-refcount.c b/lib/percpu-refcount.c\nindex af9302141bcf..82b698b08cad 100644\n--- a/lib/percpu-refcount.c\n+++ b/lib/percpu-refcount.c\n@@ -70,7 +70,7 @@ int percpu_ref_init(struct percpu_ref *ref, percpu_ref_func_t *release,\n \n \tref->percpu_count_ptr = (unsigned long)\n \t\t__alloc_percpu_gfp(sizeof(unsigned long), align, gfp);\n-\tif (!ref->percpu_count_ptr)\n+\tif (!ref->percpu_count_ptr || !percpu_count_ptr_valid(ref->percpu_count_ptr))\n \t\treturn -ENOMEM;\n \n \tdata = kzalloc(sizeof(*ref->data), gfp);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "89740d8d8416726adeba5953543037142b3b20be": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/security/keys/keyctl_pkey.c b/security/keys/keyctl_pkey.c\nindex 70e65a2ff207..6460218af115 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 || !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..a4d5ea655a37 100644\n--- a/security/keys/keyctl_pkey.c\n+++ b/security/keys/keyctl_pkey.c\n@@ -92,6 +92,8 @@ static int keyctl_pkey_params_get(key_serial_t id,\n \tif (IS_ERR(p))\n \t\treturn PTR_ERR(p);\n \tparams->info = p;\n+if (!params->info)\n+    return -ENOMEM;\n \n \tret = keyctl_pkey_params_parse(params);\n \tif (ret < 0)\n",
            "diff --git a/security/keys/keyctl_pkey.c b/security/keys/keyctl_pkey.c\nindex 70e65a2ff207..eeb7a7d767f0 100644\n--- a/security/keys/keyctl_pkey.c\n+++ b/security/keys/keyctl_pkey.c\n@@ -43,7 +43,9 @@ static int keyctl_pkey_params_parse(struct kernel_pkey_params *params)\n {\n \tunsigned long token_mask = 0;\n \tsubstring_t args[MAX_OPT_ARGS];\n-\tchar *c = params->info, *p, *q;\n+\tif (!params->info)\n+        return -EINVAL;\n+    char *c = params->info, *p, *q;\n \tint token;\n \n \twhile ((p = strsep(&c, \" \\t\"))) {\n",
            "diff --git a/security/keys/keyctl_pkey.c b/security/keys/keyctl_pkey.c\nindex 70e65a2ff207..626ee3d3e83a 100644\n--- a/security/keys/keyctl_pkey.c\n+++ b/security/keys/keyctl_pkey.c\n@@ -43,7 +43,9 @@ static int keyctl_pkey_params_parse(struct kernel_pkey_params *params)\n {\n \tunsigned long token_mask = 0;\n \tsubstring_t args[MAX_OPT_ARGS];\n-\tchar *c = params->info, *p, *q;\n+\tif (!params->info)\n+return -EINVAL;\n+char *c = params->info, *p, *q;\n \tint token;\n \n \twhile ((p = strsep(&c, \" \\t\"))) {\n"
        ],
        "error": [
            {
                "patch": "diff --git a/security/keys/keyctl_pkey.c b/security/keys/keyctl_pkey.c\nindex 70e65a2ff207..e6ae99dfb1dc 100644\n--- a/security/keys/keyctl_pkey.c\n+++ b/security/keys/keyctl_pkey.c\n@@ -40,6 +40,9 @@ static const match_table_t param_keys = {\n  * Parse the information string which consists of key=val pairs.\n  */\n static int keyctl_pkey_params_parse(struct kernel_pkey_params *params)\n+{\n+    if (!params || !params->info || !params->info[0])\n+        return -EINVAL;\n {\n \tunsigned long token_mask = 0;\n \tsubstring_t args[MAX_OPT_ARGS];\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "f9cfa5c5564ffc453258d835293bf6e9881c5b1c": {
        "non_crash": [
            "diff --git a/net/sctp/stream_sched_rr.c b/net/sctp/stream_sched_rr.c\nindex 52ba743fa7a7..55d8b43895b7 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+        goto out;\n+    ch = list_entry(soute->outq.next, struct sctp_chunk, stream_list);\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..ce83fd3e3053 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",
            "diff --git a/net/sctp/stream_sched_rr.c b/net/sctp/stream_sched_rr.c\nindex 52ba743fa7a7..4c2994be4419 100644\n--- a/net/sctp/stream_sched_rr.c\n+++ b/net/sctp/stream_sched_rr.c\n@@ -138,7 +138,11 @@ 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+    } 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..42430b2d8a6f 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) goto out;\n+    ch = list_entry(soute->outq.next, struct sctp_chunk, stream_list);\n \n \tsctp_sched_dequeue_common(q, ch);\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/sctp/stream_sched_rr.c b/net/sctp/stream_sched_rr.c\nindex 52ba743fa7a7..557de8d0ee84 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"
        ],
        "error": []
    },
    "5eb8a5d29d77f8a364cf3270bf9625eb4d4ffc52": {
        "non_crash": [
            "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..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..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": []
    },
    "76c0afb6e24e6dc4093c36801d0b3a61b486ec4d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/segment.c b/fs/nilfs2/segment.c\nindex ac949fd7603f..43d27777f403 100644\n--- a/fs/nilfs2/segment.c\n+++ b/fs/nilfs2/segment.c\n@@ -1409,7 +1409,10 @@ 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);\n+        }\n \t\tWARN_ON(ret); /* never fails */\n \t}\n \tnilfs_destroy_logs(&list);\n@@ -1425,7 +1428,10 @@ 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);\n+        }\n \t\tWARN_ON(ret); /* never fails */\n \t}\n \tif (atomic_read(&segbuf->sb_err)) {\n@@ -1444,7 +1450,10 @@ 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);\n+        }\n \t\t\tWARN_ON(ret); /* never fails */\n \t\t}\n \t\tif (atomic_read(&segbuf->sb_err) &&\n@@ -1499,7 +1508,10 @@ 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);\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..ebaa9bdf59f5 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 (segbuf->sb_nextnum >= 0) {\n+            ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+        }\n+        else {\n+            pr_warn(\"Invalid segment number: %lu\\n\", 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 (segbuf->sb_nextnum >= 0) {\n+            ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+        }\n+        else {\n+            pr_warn(\"Invalid segment number: %lu\\n\", 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 (segbuf->sb_nextnum >= 0) {\n+            ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+        }\n+        else {\n+            pr_warn(\"Invalid segment number: %lu\\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 +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 (segbuf->sb_nextnum >= 0) {\n+            ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+        }\n+        else {\n+            pr_warn(\"Invalid segment number: %lu\\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..a5c12a2a403d 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 (segbuf->sb_nextnum >= 0) {\n+            ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+            WARN_ON(ret);\n+        } else {\n+            pr_warn(\"Invalid segment number: %d\\n\", 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 (segbuf->sb_nextnum >= 0) {\n+            ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+            WARN_ON(ret);\n+        } else {\n+            pr_warn(\"Invalid segment number: %d\\n\", 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 (segbuf->sb_nextnum >= 0) {\n+            ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+            WARN_ON(ret);\n+        } else {\n+            pr_warn(\"Invalid segment number: %d\\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 +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 (segbuf->sb_nextnum >= 0) {\n+            ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\n+            WARN_ON(ret);\n+        } else {\n+            pr_warn(\"Invalid segment number: %d\\n\", 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..23088519398c 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\tif (segbuf->sb_nextnum < 0 || segbuf->sb_nextnum >= nilfs->ns_nsegments) {\n+            pr_warn(\"invalid segment number: %ld\\n\", segbuf->sb_nextnum);\n+            continue;\n+        }\n+        ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\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\tif (segbuf->sb_nextnum < 0 || segbuf->sb_nextnum >= nilfs->ns_nsegments) {\n+            pr_warn(\"invalid segment number: %ld\\n\", segbuf->sb_nextnum);\n+            continue;\n+        }\n+        ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\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\tif (segbuf->sb_nextnum < 0 || segbuf->sb_nextnum >= nilfs->ns_nsegments) {\n+            pr_warn(\"invalid segment number: %ld\\n\", segbuf->sb_nextnum);\n+            continue;\n+        }\n+        ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\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\tif (segbuf->sb_nextnum < 0 || segbuf->sb_nextnum >= nilfs->ns_nsegments) {\n+            pr_warn(\"invalid segment number: %ld\\n\", segbuf->sb_nextnum);\n+            continue;\n+        }\n+        ret = nilfs_sufile_free(sufile, segbuf->sb_nextnum);\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"
        ],
        "error": []
    },
    "1860a98f3556d97065ad773d095aa1d7eb5fbafa": {
        "non_crash": [
            "diff --git a/net/smc/af_smc.c b/net/smc/af_smc.c\nindex 14ddc40149e8..3a6d861b329b 100644\n--- a/net/smc/af_smc.c\n+++ b/net/smc/af_smc.c\n@@ -3085,7 +3085,10 @@ static int __smc_create(struct net *net, struct socket *sock, int protocol,\n \trc = -ENOBUFS;\n \tsock->ops = &smc_sock_ops;\n \tsk = smc_sock_alloc(net, sock, protocol);\n-\tif (!sk)\n+\tif (!sk) {\n+    sk_common_release(sk);\n+    goto out;\n+}\n \t\tgoto out;\n \n \t/* create internal TCP socket for CLC handshake and fallback */\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/smc/af_smc.c b/net/smc/af_smc.c\nindex 14ddc40149e8..4e3df8177cff 100644\n--- a/net/smc/af_smc.c\n+++ b/net/smc/af_smc.c\n@@ -73,7 +73,10 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\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 +301,10 @@ static int smc_release(struct socket *sock)\n \tint old_state, rc = 0;\n \n \tif (!sk)\n-\t\tgoto out;\n+\t\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \n \tsock_hold(sk); /* sock_put below */\n \tsmc = smc_sk(sk);\n@@ -390,17 +396,26 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\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\tif (sk) {\n+        sock_put(sk);\n+    }\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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \n \tlock_sock(sk);\n \n@@ -489,14 +504,20 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \t}\n \trmb_desc->is_conf_rkey = true;\n out:\n@@ -731,7 +752,10 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\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 +814,18 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \t}\n \tclcsk = smc->clcsock->sk;\n \n \tif (smc->use_fallback)\n-\t\tgoto out;\n+\t\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \tsmc->use_fallback = true;\n \tsmc->fallback_rsn = reason_code;\n \tsmc_stat_fallback(smc);\n@@ -1068,7 +1098,10 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \n \talt_ini->vlan_id = lgr->vlan_id;\n \talt_ini->check_smcrv2 = true;\n@@ -1076,7 +1109,10 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \n \tmemcpy(gidlist->list[gidlist->len++], alt_ini->smcrv2.ib_gid_v2,\n \t       SMC_GID_SIZE);\n@@ -1478,7 +1514,10 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \t}\n \n \trc = __smc_connect(smc);\n@@ -1515,10 +1554,16 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \tcase SMC_ACTIVE:\n \t\trc = -EISCONN;\n-\t\tgoto out;\n+\t\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \tcase SMC_INIT:\n \t\tbreak;\n \t}\n@@ -1527,15 +1572,24 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\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\tif (sk) {\n+        sock_put(sk);\n+    }\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\tif (sk) {\n+        sock_put(sk);\n+    }\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 +1597,10 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \t\telse\n \t\t\trc = 0; /* success cases including fallback */\n \t}\n@@ -1568,7 +1625,10 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \t}\n \t*new_smc = smc_sk(new_sk);\n \n@@ -1587,7 +1647,10 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \t}\n \n \t/* new clcsock has inherited the smc listen-specific sk_data_ready\n@@ -1806,14 +1869,20 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\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\tif (sk) {\n+        sock_put(sk);\n+    }\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 +2395,10 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \t\tif (!new_smc)\n \t\t\tcontinue;\n \n@@ -2378,12 +2450,18 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\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\tif (sk) {\n+        sock_put(sk);\n+    }\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 +2492,10 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \t}\n \tsk->sk_max_ack_backlog = backlog;\n \tsk->sk_ack_backlog = 0;\n@@ -2441,7 +2522,10 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \t}\n \n \t/* Wait for an incoming connection */\n@@ -2470,7 +2554,10 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\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 +2607,25 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \t\t} else {\n \t\t\trc = -EINVAL;\n-\t\t\tgoto out;\n+\t\t\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \t\t}\n \t}\n \n@@ -2556,16 +2652,25 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \n \tif (sk->sk_state == SMC_PEERFINCLOSEWAIT) {\n \t\trc = 0;\n-\t\tgoto out;\n+\t\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \t}\n \n \tif (smc->use_fallback) {\n@@ -2670,13 +2775,19 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \t}\n \tswitch (how) {\n \tcase SHUT_RDWR:\t\t/* shutdown in both directions */\n@@ -2809,7 +2920,10 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \tswitch (optname) {\n \tcase TCP_FASTOPEN:\n \tcase TCP_FASTOPEN_CONNECT:\n@@ -2974,7 +3088,10 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \t}\n \trelease_sock(sk);\n \tif (smc->use_fallback) {\n@@ -3010,16 +3127,25 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \n \tif (sk->sk_state == SMC_PEERFINCLOSEWAIT) {\n \t\trc = 0;\n-\t\tgoto out;\n+\t\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \t}\n \n \tif (smc->use_fallback) {\n@@ -3028,7 +3154,10 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \t\t}\n \t\tif (flags & SPLICE_F_NONBLOCK)\n \t\t\tflags = MSG_DONTWAIT;\n@@ -3076,17 +3205,26 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \n \trc = -EPROTONOSUPPORT;\n \tif (protocol != SMCPROTO_SMC && protocol != SMCPROTO_SMC6)\n-\t\tgoto out;\n+\t\tif (sk) {\n+        sock_put(sk);\n+    }\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\tif (sk) {\n+        sock_put(sk);\n+    }\n+    goto out;\n \n \t/* create internal TCP socket for CLC handshake and fallback */\n \tsmc = smc_sk(sk);\n@@ -3102,7 +3240,10 @@ 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\tif (sk) {\n+        sock_put(sk);\n+    }\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..402a4e4028ee 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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_common_release(sk);\n+goto out;\n \tcase SMC_ACTIVE:\n \t\trc = -EISCONN;\n-\t\tgoto out;\n+\t\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_common_release(sk);\n+goto out;\n \t\t} else {\n \t\t\trc = -EINVAL;\n-\t\t\tgoto out;\n+\t\t\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_common_release(sk);\n+goto out;\n \n \tif (sk->sk_state == SMC_PEERFINCLOSEWAIT) {\n \t\trc = 0;\n-\t\tgoto out;\n+\t\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_common_release(sk);\n+goto out;\n \n \tif (sk->sk_state == SMC_PEERFINCLOSEWAIT) {\n \t\trc = 0;\n-\t\tgoto out;\n+\t\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_common_release(sk);\n+goto out;\n \n \trc = -EPROTONOSUPPORT;\n \tif (protocol != SMCPROTO_SMC && protocol != SMCPROTO_SMC6)\n-\t\tgoto out;\n+\t\tif (sk) sk_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\tif (sk) sk_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\tif (sk) sk_common_release(sk);\n+goto out;\n \t\t}\n \t} else {\n \t\tsmc->clcsock = clcsock;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "a59816f87c8e514d1b5ed891ae85341fbef1e553": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/block/blk-core.c b/block/blk-core.c\nindex f305cb66c72a..cf2be77f98af 100644\n--- a/block/blk-core.c\n+++ b/block/blk-core.c\n@@ -660,7 +660,8 @@ static void __submit_bio(struct bio *bio)\n \tstruct gendisk *disk = bio->bi_bdev->bd_disk;\n \n \tif (unlikely(!blk_crypto_bio_prep(&bio)))\n-\t\treturn;\n+\t\trcu_read_unlock();\n+    return;\n \n \tif (!disk->fops->submit_bio) {\n \t\tblk_mq_submit_bio(bio);\n@@ -772,6 +773,8 @@ void submit_bio_noacct_nocheck(struct bio *bio)\n  * submit_bio() instead.\n  */\n void submit_bio_noacct(struct bio *bio)\n+{\n+    rcu_read_lock();\n {\n \tstruct block_device *bdev = bio->bi_bdev;\n \tstruct request_queue *q = bdev_get_queue(bdev);\n@@ -789,7 +792,8 @@ void submit_bio_noacct(struct bio *bio)\n \t * if queue does not support NOWAIT.\n \t */\n \tif ((bio->bi_opf & REQ_NOWAIT) && !blk_queue_nowait(q))\n-\t\tgoto not_supported;\n+\t\trcu_read_unlock();\n+    goto not_supported;\n \n \tif (should_fail_bio(bio))\n \t\tgoto end_io;\n@@ -821,11 +825,13 @@ void submit_bio_noacct(struct bio *bio)\n \tswitch (bio_op(bio)) {\n \tcase REQ_OP_DISCARD:\n \t\tif (!bdev_max_discard_sectors(bdev))\n-\t\t\tgoto not_supported;\n+\t\t\trcu_read_unlock();\n+    goto not_supported;\n \t\tbreak;\n \tcase REQ_OP_SECURE_ERASE:\n \t\tif (!bdev_max_secure_erase_sectors(bdev))\n-\t\t\tgoto not_supported;\n+\t\t\trcu_read_unlock();\n+    goto not_supported;\n \t\tbreak;\n \tcase REQ_OP_ZONE_APPEND:\n \t\tstatus = blk_check_zone_append(q, bio);\n@@ -837,22 +843,26 @@ void submit_bio_noacct(struct bio *bio)\n \tcase REQ_OP_ZONE_CLOSE:\n \tcase REQ_OP_ZONE_FINISH:\n \t\tif (!blk_queue_is_zoned(q))\n-\t\t\tgoto not_supported;\n+\t\t\trcu_read_unlock();\n+    goto not_supported;\n \t\tbreak;\n \tcase REQ_OP_ZONE_RESET_ALL:\n \t\tif (!blk_queue_is_zoned(q) || !blk_queue_zone_resetall(q))\n-\t\t\tgoto not_supported;\n+\t\t\trcu_read_unlock();\n+    goto not_supported;\n \t\tbreak;\n \tcase REQ_OP_WRITE_ZEROES:\n \t\tif (!q->limits.max_write_zeroes_sectors)\n-\t\t\tgoto not_supported;\n+\t\t\trcu_read_unlock();\n+    goto not_supported;\n \t\tbreak;\n \tdefault:\n \t\tbreak;\n \t}\n \n \tif (blk_throtl_bio(bio))\n-\t\treturn;\n+\t\trcu_read_unlock();\n+    return;\n \n \tblk_cgroup_bio_start(bio);\n \tblkcg_bio_issue_init(bio);\n@@ -865,7 +875,8 @@ void submit_bio_noacct(struct bio *bio)\n \t\tbio_set_flag(bio, BIO_TRACE_COMPLETION);\n \t}\n \tsubmit_bio_noacct_nocheck(bio);\n-\treturn;\n+\trcu_read_unlock();\n+    return;\n \n not_supported:\n \tstatus = BLK_STS_NOTSUPP;\n@@ -891,7 +902,8 @@ EXPORT_SYMBOL(submit_bio_noacct);\n void submit_bio(struct bio *bio)\n {\n \tif (blkcg_punt_bio_submit(bio))\n-\t\treturn;\n+\t\trcu_read_unlock();\n+    return;\n \n \t/*\n \t * If it's a regular read/write or a barrier with data attached,\n@@ -921,7 +933,8 @@ void submit_bio(struct bio *bio)\n \t\tpsi_memstall_enter(&pflags);\n \t\tsubmit_bio_noacct(bio);\n \t\tpsi_memstall_leave(&pflags);\n-\t\treturn;\n+\t\trcu_read_unlock();\n+    return;\n \t}\n \n \tsubmit_bio_noacct(bio);\n@@ -1135,7 +1148,8 @@ void blk_start_plug_nr_ios(struct blk_plug *plug, unsigned short nr_ios)\n \t * If this is a nested plug, don't actually assign it.\n \t */\n \tif (tsk->plug)\n-\t\treturn;\n+\t\trcu_read_unlock();\n+    return;\n \n \tplug->mq_list = NULL;\n \tplug->cached_rq = NULL;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/block/blk-core.c b/block/blk-core.c\nindex f305cb66c72a..60f7b65c6c33 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+if (!bio || !bio->bi_bdev) {\n+return 0;\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..cda79c8c7188 100644\n--- a/block/blk-core.c\n+++ b/block/blk-core.c\n@@ -941,6 +941,8 @@ 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 {\n \tstruct request_queue *q = bdev_get_queue(bio->bi_bdev);\n \tblk_qc_t cookie = READ_ONCE(bio->bi_cookie);\n@@ -963,6 +965,7 @@ int bio_poll(struct bio *bio, struct io_comp_batch *iob, unsigned int flags)\n \t\t\tret = disk->fops->poll_bio(bio, iob, flags);\n \t}\n \tblk_queue_exit(q);\n+    rcu_read_unlock();\n \treturn ret;\n }\n EXPORT_SYMBOL_GPL(bio_poll);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "67d3719a7490d99812faae7f9c2c26e9f386c1a6": {
        "non_crash": [
            "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..d12032b57b92 100644\n--- a/fs/hfs/trans.c\n+++ b/fs/hfs/trans.c\n@@ -130,7 +130,8 @@ 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) goto out;\n+                *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..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"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/hfs/trans.c b/fs/hfs/trans.c\nindex 39f5e343bf4d..b26eca616c11 100644\n--- a/fs/hfs/trans.c\n+++ b/fs/hfs/trans.c\n@@ -140,7 +140,8 @@ void hfs_asc2mac(struct super_block *sb, struct hfs_name *out, const struct qstr\n \t\tif (dstlen > srclen)\n \t\t\tdstlen = srclen;\n \t\twhile (--dstlen >= 0)\n-\t\t\t*dst++ = (ch = *src++) == ':' ? '/' : ch;\n+\t\t\tif (dstlen > 0)\n+*dst++ = (ch = *src++) == ':' ? '/' : ch;\n \t}\n out:\n \tout->len = dst - (char *)out->name;\n"
        ],
        "error": []
    },
    "1bb19c23cbf08cedbc6bbe5d4b7e07f6403fa35e": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex 9e2735cbc2b4..e31d3eb416f4 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -853,7 +853,7 @@ static inline void *mas_slot(struct ma_state *mas, void __rcu **slots,\n  */\n static inline void *mas_root(struct ma_state *mas)\n {\n-\treturn rcu_dereference_check(mas->tree->ma_root, mt_locked(mas->tree));\n+\treturn rcu_dereference_check(mas->tree->ma_root, lockdep_is_held(&mas->tree->ma_lock) || mt_external_lock(mas->tree));\n }\n \n static inline void *mt_root_locked(struct maple_tree *mt)\n",
            "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex 9e2735cbc2b4..bfd2aa16732c 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -846,12 +846,12 @@ static inline void *mas_slot(struct ma_state *mas, void __rcu **slots,\n }\n \n /*\n- * mas_root() - Get the maple tree root.\n+ * mas_root_locked() - Get the maple tree root.\n  * @mas: The maple state.\n  *\n  * Return: The pointer to the root of the tree\n  */\n-static inline void *mas_root(struct ma_state *mas)\n+static inline void *mas_root_locked(struct ma_state *mas)\n {\n \treturn rcu_dereference_check(mas->tree->ma_root, mt_locked(mas->tree));\n }\n@@ -862,12 +862,12 @@ static inline void *mt_root_locked(struct maple_tree *mt)\n }\n \n /*\n- * mas_root_locked() - Get the maple tree root when holding the maple tree lock.\n+ * mas_root_locked_locked() - Get the maple tree root when holding the maple tree lock.\n  * @mas: The maple state.\n  *\n  * Return: The pointer to the root of the tree\n  */\n-static inline void *mas_root_locked(struct ma_state *mas)\n+static inline void *mas_root_locked_locked(struct ma_state *mas)\n {\n \treturn mt_root_locked(mas->tree);\n }\n@@ -1354,7 +1354,7 @@ 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\troot = mas_root_locked(mas);\n \t\t/* Tree with nodes */\n \t\tif (likely(xa_is_node(root))) {\n \t\t\tmas->depth = 1;\n@@ -1704,7 +1704,7 @@ static inline void mas_replace(struct ma_state *mas, bool advanced)\n \tvoid __rcu **slots = NULL;\n \n \tif (ma_is_root(mn)) {\n-\t\told_enode = mas_root_locked(mas);\n+\t\told_enode = mas_root_locked_locked(mas);\n \t} else {\n \t\toffset = mte_parent_slot(mas->node);\n \t\tslots = ma_slots(mte_parent(mas->node),\n@@ -3619,13 +3619,13 @@ static noinline_for_kasan int mas_commit_b_node(struct ma_wr_state *wr_mas,\n }\n \n /*\n- * mas_root_expand() - Expand a root to a node\n+ * mas_root_locked_expand() - Expand a root to a node\n  * @mas: The maple state\n  * @entry: The entry to store into the tree\n  */\n-static inline int mas_root_expand(struct ma_state *mas, void *entry)\n+static inline int mas_root_locked_expand(struct ma_state *mas, void *entry)\n {\n-\tvoid *contents = mas_root_locked(mas);\n+\tvoid *contents = mas_root_locked_locked(mas);\n \tenum maple_type type = maple_leaf_64;\n \tstruct maple_node *node;\n \tvoid __rcu **slots;\n@@ -3669,9 +3669,9 @@ static inline int mas_root_expand(struct ma_state *mas, void *entry)\n static inline void mas_store_root(struct ma_state *mas, void *entry)\n {\n \tif (likely((mas->last != 0) || (mas->index != 0)))\n-\t\tmas_root_expand(mas, entry);\n+\t\tmas_root_locked_expand(mas, entry);\n \telse if (((unsigned long) (entry) & 3) == 2)\n-\t\tmas_root_expand(mas, entry);\n+\t\tmas_root_locked_expand(mas, entry);\n \telse {\n \t\trcu_assign_pointer(mas->tree->ma_root, entry);\n \t\tmas->node = MAS_START;\n@@ -3912,7 +3912,7 @@ static inline void *mtree_lookup_walk(struct ma_state *mas)\n  */\n static inline int mas_new_root(struct ma_state *mas, void *entry)\n {\n-\tstruct maple_enode *root = mas_root_locked(mas);\n+\tstruct maple_enode *root = mas_root_locked_locked(mas);\n \tenum maple_type type = maple_leaf_64;\n \tstruct maple_node *node;\n \tvoid __rcu **slots;\n@@ -5341,7 +5341,7 @@ static inline int mas_alloc(struct ma_state *mas, void *entry,\n \n \tmas_start(mas);\n \tif (mas_is_none(mas) || mas_is_ptr(mas)) {\n-\t\tmas_root_expand(mas, entry);\n+\t\tmas_root_locked_expand(mas, entry);\n \t\tif (mas_is_err(mas))\n \t\t\treturn xa_err(mas->node);\n \n@@ -5935,7 +5935,7 @@ void *mas_prev(struct ma_state *mas, unsigned long min)\n \t\t}\n \n \t\tmas->index = mas->last = 0;\n-\t\treturn mas_root_locked(mas);\n+\t\treturn mas_root_locked_locked(mas);\n \t}\n \treturn mas_prev_entry(mas, min);\n }\n",
            "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex 9e2735cbc2b4..bca5eec77fbf 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -853,7 +853,10 @@ 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+\tif (mt_locked(mas->tree))\n+        return rcu_dereference_check(mas->tree->ma_root, true);\n+    else\n+        return rcu_dereference_check(mas->tree->ma_root, false);\n }\n \n static inline void *mt_root_locked(struct maple_tree *mt)\n"
        ],
        "error": []
    },
    "2e1943a94647f7732dd6fc60368642d6e8dc91b1": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c\nindex b0d9c36acc03..14669df0650d 100644\n--- a/net/bluetooth/hci_core.c\n+++ b/net/bluetooth/hci_core.c\n@@ -104,7 +104,8 @@ static ssize_t dut_mode_write(struct file *file, const char __user *user_buf,\n \tif (IS_ERR(skb))\n \t\treturn PTR_ERR(skb);\n \n-\tkfree_skb(skb);\n+\t/* Ensure skb is not prematurely freed */\n+    kfree_skb(skb);\n \n \thci_dev_change_flag(hdev, HCI_DUT_MODE);\n \n@@ -4078,7 +4079,8 @@ int hci_recv_frame(struct hci_dev *hdev, struct sk_buff *skb)\n {\n \tif (!hdev || (!test_bit(HCI_UP, &hdev->flags)\n \t\t      && !test_bit(HCI_INIT, &hdev->flags))) {\n-\t\tkfree_skb(skb);\n+\t\t/* Ensure skb is not prematurely freed */\n+    kfree_skb(skb);\n \t\treturn -ENXIO;\n \t}\n \n@@ -4086,7 +4088,8 @@ int hci_recv_frame(struct hci_dev *hdev, struct sk_buff *skb)\n \t    hci_skb_pkt_type(skb) != HCI_ACLDATA_PKT &&\n \t    hci_skb_pkt_type(skb) != HCI_SCODATA_PKT &&\n \t    hci_skb_pkt_type(skb) != HCI_ISODATA_PKT) {\n-\t\tkfree_skb(skb);\n+\t\t/* Ensure skb is not prematurely freed */\n+    kfree_skb(skb);\n \t\treturn -EINVAL;\n \t}\n \n@@ -4189,14 +4192,16 @@ static void hci_send_frame(struct hci_dev *hdev, struct sk_buff *skb)\n \tskb_orphan(skb);\n \n \tif (!test_bit(HCI_RUNNING, &hdev->flags)) {\n-\t\tkfree_skb(skb);\n+\t\t/* Ensure skb is not prematurely freed */\n+    kfree_skb(skb);\n \t\treturn;\n \t}\n \n \terr = hdev->send(hdev, skb);\n \tif (err < 0) {\n \t\tbt_dev_err(hdev, \"sending frame failed (%d)\", err);\n-\t\tkfree_skb(skb);\n+\t\t/* Ensure skb is not prematurely freed */\n+    kfree_skb(skb);\n \t}\n }\n \n@@ -4906,7 +4911,8 @@ static void hci_acldata_packet(struct hci_dev *hdev, struct sk_buff *skb)\n \t\t\t   handle);\n \t}\n \n-\tkfree_skb(skb);\n+\t/* Ensure skb is not prematurely freed */\n+    kfree_skb(skb);\n }\n \n /* SCO data packet */\n@@ -4941,7 +4947,8 @@ static void hci_scodata_packet(struct hci_dev *hdev, struct sk_buff *skb)\n \t\t\t   handle);\n \t}\n \n-\tkfree_skb(skb);\n+\t/* Ensure skb is not prematurely freed */\n+    kfree_skb(skb);\n }\n \n static bool hci_req_is_complete(struct hci_dev *hdev)\n@@ -5037,7 +5044,8 @@ void hci_req_cmd_complete(struct hci_dev *hdev, u16 opcode, u8 status,\n \t\t\t*req_complete_skb = bt_cb(skb)->hci.req_complete_skb;\n \t\telse\n \t\t\t*req_complete = bt_cb(skb)->hci.req_complete;\n-\t\tkfree_skb(skb);\n+\t\t/* Ensure skb is not prematurely freed */\n+    kfree_skb(skb);\n \t}\n \tspin_unlock_irqrestore(&hdev->cmd_q.lock, flags);\n }\n@@ -5066,7 +5074,8 @@ static void hci_rx_work(struct work_struct *work)\n \t\t */\n \t\tif (hci_dev_test_flag(hdev, HCI_USER_CHANNEL) &&\n \t\t    !test_bit(HCI_INIT, &hdev->flags)) {\n-\t\t\tkfree_skb(skb);\n+\t\t\t/* Ensure skb is not prematurely freed */\n+    kfree_skb(skb);\n \t\t\tcontinue;\n \t\t}\n \n@@ -5076,7 +5085,8 @@ static void hci_rx_work(struct work_struct *work)\n \t\t\tcase HCI_ACLDATA_PKT:\n \t\t\tcase HCI_SCODATA_PKT:\n \t\t\tcase HCI_ISODATA_PKT:\n-\t\t\t\tkfree_skb(skb);\n+\t\t\t\t/* Ensure skb is not prematurely freed */\n+    kfree_skb(skb);\n \t\t\t\tcontinue;\n \t\t\t}\n \t\t}\n@@ -5099,7 +5109,8 @@ static void hci_rx_work(struct work_struct *work)\n \t\t\tbreak;\n \n \t\tdefault:\n-\t\t\tkfree_skb(skb);\n+\t\t\t/* Ensure skb is not prematurely freed */\n+    kfree_skb(skb);\n \t\t\tbreak;\n \t\t}\n \t}\n",
            "diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c\nindex b0d9c36acc03..02419f2fe516 100644\n--- a/net/bluetooth/hci_core.c\n+++ b/net/bluetooth/hci_core.c\n@@ -4374,7 +4374,8 @@ void hci_send_acl(struct hci_chan *chan, struct sk_buff *skb, __u16 flags)\n \n \tBT_DBG(\"%s chan %p flags 0x%4.4x\", hdev->name, chan, flags);\n \n-\thci_queue_acl(chan, &chan->data_q, skb, flags);\n+\tskb_get(skb);\n+    hci_queue_acl(chan, &chan->data_q, skb, flags);\n \n \tqueue_work(hdev->workqueue, &hdev->tx_work);\n }\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c\nindex b0d9c36acc03..f783a92d14fe 100644\n--- a/net/bluetooth/hci_core.c\n+++ b/net/bluetooth/hci_core.c\n@@ -4368,7 +4368,9 @@ static void hci_queue_acl(struct hci_chan *chan, struct sk_buff_head *queue,\n \t}\n }\n \n-void hci_send_acl(struct hci_chan *chan, struct sk_buff *skb, __u16 flags)\n+void if (!skb || skb_is_nonlinear(skb)) return -ENOMEM;\n+\n+hci_send_acl(struct hci_chan *chan, struct sk_buff *skb, __u16 flags)\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..02dafdc06746 100644\n--- a/net/bluetooth/hci_core.c\n+++ b/net/bluetooth/hci_core.c\n@@ -4369,6 +4369,10 @@ 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+        return;\n+    }\n {\n \tstruct hci_dev *hdev = chan->conn->hdev;\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..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..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..f544d2a78c0e 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..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..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": []
    },
    "c861c927f694825cea94240c7acf698eccb2a8c2": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/fs/nilfs2/alloc.c b/fs/nilfs2/alloc.c\nindex 6ce8617b562d..e0c42b668bb3 100644\n--- a/fs/nilfs2/alloc.c\n+++ b/fs/nilfs2/alloc.c\n@@ -596,6 +596,14 @@ 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+{\n+    if (!req || !req->pr_desc_bh || !req->pr_bitmap_bh) {\n+        nilfs_warn(inode->i_sb,\n+                   \"%s (ino=%lu): invalid buffer heads\",\n+                   __func__, inode->i_ino);\n+        return;\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"
            },
            {
                "patch": "diff --git a/fs/nilfs2/alloc.c b/fs/nilfs2/alloc.c\nindex 6ce8617b562d..5b882ec425c1 100644\n--- a/fs/nilfs2/alloc.c\n+++ b/fs/nilfs2/alloc.c\n@@ -596,6 +596,13 @@ 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,\n+                   \"%s (ino=%lu): null buffer heads\",\n+                   __func__, inode->i_ino);\n+        return;\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"
            },
            {
                "patch": "diff --git a/fs/nilfs2/alloc.c b/fs/nilfs2/alloc.c\nindex 6ce8617b562d..11399e7e39db 100644\n--- a/fs/nilfs2/alloc.c\n+++ b/fs/nilfs2/alloc.c\n@@ -596,6 +596,14 @@ 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+{\n+if (!req->pr_desc_bh || !req->pr_bitmap_bh) {\n+nilfs_warn(inode->i_sb,\n+\"%s (ino=%lu): invalid buffer head(s)\",\n+__func__, inode->i_ino);\n+return;\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"
            },
            {
                "patch": "diff --git a/fs/nilfs2/alloc.c b/fs/nilfs2/alloc.c\nindex 6ce8617b562d..02e3a7811782 100644\n--- a/fs/nilfs2/alloc.c\n+++ b/fs/nilfs2/alloc.c\n@@ -596,6 +596,13 @@ 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,\n+                  \"%s (ino=%lu): invalid buffer heads\",\n+                  __func__, inode->i_ino);\n+        return;\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"
            },
            {
                "patch": "diff --git a/fs/nilfs2/alloc.c b/fs/nilfs2/alloc.c\nindex 6ce8617b562d..12a18c73f2c5 100644\n--- a/fs/nilfs2/alloc.c\n+++ b/fs/nilfs2/alloc.c\n@@ -596,6 +596,10 @@ 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+{\n+    if (!req->pr_desc_bh) return;\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"
            }
        ]
    },
    "32577e96d88447ded2d3b76d71254fb855245837": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "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..6dd2da36770a 100644\n--- a/drivers/video/fbdev/core/bitblit.c\n+++ b/drivers/video/fbdev/core/bitblit.c\n@@ -140,6 +140,8 @@ static inline void bit_putcs_unaligned(struct vc_data *vc,\n \n }\n \n+static DEFINE_SPINLOCK(bit_putcs_lock);\n+\n static void bit_putcs(struct vc_data *vc, struct fb_info *info,\n \t\t      const unsigned short *s, int count, int yy, int xx,\n \t\t      int fg, int bg)\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..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"
        ],
        "error": []
    },
    "bb281e89381b9ed55728c274447a575e69a96c35": {
        "non_crash": [
            "diff --git a/fs/overlayfs/util.c b/fs/overlayfs/util.c\nindex 81a57a8d80d9..31b5006085fa 100644\n--- a/fs/overlayfs/util.c\n+++ b/fs/overlayfs/util.c\n@@ -210,7 +210,9 @@ 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+\tif (!dentry || !d_inode(dentry))\n+    return NULL;\n+return ovl_upperdentry_dereference(OVL_I(d_inode(dentry)));\n }\n \n struct dentry *ovl_dentry_lower(struct dentry *dentry)\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/overlayfs/util.c b/fs/overlayfs/util.c\nindex 81a57a8d80d9..55852828d152 100644\n--- a/fs/overlayfs/util.c\n+++ b/fs/overlayfs/util.c\n@@ -210,7 +210,8 @@ enum ovl_path_type ovl_path_realdata(struct dentry *dentry, struct path *path)\n \n struct dentry *ovl_dentry_upper(struct dentry *dentry)\n {\n-\treturn ovl_upperdentry_dereference(OVL_I(d_inode(dentry)));\n+\tif (dentry == NULL) return NULL;\n+    return ovl_upperdentry_dereference(OVL_I(d_inode(dentry)));\n }\n \n struct dentry *ovl_dentry_lower(struct dentry *dentry)\n",
            "diff --git a/fs/overlayfs/ovl_entry.h b/fs/overlayfs/ovl_entry.h\nindex e1af8f660698..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",
            "diff --git a/fs/overlayfs/ovl_entry.h b/fs/overlayfs/ovl_entry.h\nindex e1af8f660698..3369ec8c53ca 100644\n--- a/fs/overlayfs/ovl_entry.h\n+++ b/fs/overlayfs/ovl_entry.h\n@@ -147,5 +147,6 @@ static inline struct ovl_inode *OVL_I(struct inode *inode)\n \n static inline struct dentry *ovl_upperdentry_dereference(struct ovl_inode *oi)\n {\n-\treturn READ_ONCE(oi->__upperdentry);\n+\tif (!oi) return NULL;\n+    return READ_ONCE(oi->__upperdentry);\n }\n",
            "diff --git a/fs/overlayfs/util.c b/fs/overlayfs/util.c\nindex 81a57a8d80d9..8f3f3b06cf94 100644\n--- a/fs/overlayfs/util.c\n+++ b/fs/overlayfs/util.c\n@@ -210,7 +210,10 @@ enum ovl_path_type ovl_path_realdata(struct dentry *dentry, struct path *path)\n \n struct dentry *ovl_dentry_upper(struct dentry *dentry)\n {\n-\treturn ovl_upperdentry_dereference(OVL_I(d_inode(dentry)));\n+\tstruct ovl_inode *oi = OVL_I(d_inode(dentry));\n+    if (!oi)\n+        return NULL;\n+    return ovl_upperdentry_dereference(oi);\n }\n \n struct dentry *ovl_dentry_lower(struct dentry *dentry)\n"
        ],
        "error": []
    },
    "08bcc3eb4d1892c93490ce2924713568b1fed364": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/f2fs/acl.c b/fs/f2fs/acl.c\nindex ec2aeccb69a3..9a2d3a803c4b 100644\n--- a/fs/f2fs/acl.c\n+++ b/fs/f2fs/acl.c\n@@ -417,7 +417,9 @@ int f2fs_init_acl(struct inode *inode, struct inode *dir, struct page *ipage,\n \tstruct posix_acl *default_acl = NULL, *acl = NULL;\n \tint error;\n \n-\terror = f2fs_acl_create(dir, &inode->i_mode, &default_acl, &acl, dpage);\n+\tf2fs_down_read(&F2FS_I(inode)->i_xattr_sem);\n+    error = f2fs_acl_create(dir, &inode->i_mode, &default_acl, &acl, dpage);\n+    f2fs_up_read(&F2FS_I(inode)->i_xattr_sem);\n \tif (error)\n \t\treturn error;\n \n",
            "diff --git a/fs/f2fs/dir.c b/fs/f2fs/dir.c\nindex d635c58cf5a3..b20c119e8452 100644\n--- a/fs/f2fs/dir.c\n+++ b/fs/f2fs/dir.c\n@@ -736,7 +736,7 @@ 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 \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 +835,7 @@ 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 \tpage = f2fs_init_inode_metadata(inode, dir, NULL, NULL);\n \tif (IS_ERR(page)) {\n \t\terr = PTR_ERR(page);\n@@ -854,7 +854,7 @@ 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 \n \tif (S_ISDIR(inode->i_mode))\n \t\tf2fs_i_links_write(dir, false);\n"
        ],
        "error": []
    },
    "41a6b5d4917c0412eb3b3c3c604965bed7d7420b": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dadad29bd81b..12652632cdf5 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -642,6 +642,10 @@ ext4_xattr_block_get(struct inode *inode, int name_index, const char *name,\n \terror = size;\n \n cleanup:\n+/* Release any resources allocated by ext4_xattr_make_inode_space */\n+// Ensure any allocated memory is released properly\n+// e.g., kvfree(buffer) if allocated earlier\n+// Add any necessary cleanup actions here\n \tbrelse(bh);\n \treturn error;\n }\n@@ -697,6 +701,10 @@ ext4_xattr_ibody_get(struct inode *inode, int name_index, const char *name,\n \terror = size;\n \n cleanup:\n+/* Release any resources allocated by ext4_xattr_make_inode_space */\n+// Ensure any allocated memory is released properly\n+// e.g., kvfree(buffer) if allocated earlier\n+// Add any necessary cleanup actions here\n \tbrelse(iloc.bh);\n \treturn error;\n }\n@@ -788,6 +796,10 @@ ext4_xattr_block_list(struct dentry *dentry, char *buffer, size_t buffer_size)\n \terror = ext4_xattr_list_entries(dentry, BFIRST(bh), buffer,\n \t\t\t\t\tbuffer_size);\n cleanup:\n+/* Release any resources allocated by ext4_xattr_make_inode_space */\n+// Ensure any allocated memory is released properly\n+// e.g., kvfree(buffer) if allocated earlier\n+// Add any necessary cleanup actions here\n \tbrelse(bh);\n \treturn error;\n }\n@@ -817,6 +829,10 @@ ext4_xattr_ibody_list(struct dentry *dentry, char *buffer, size_t buffer_size)\n \t\t\t\t\tbuffer, buffer_size);\n \n cleanup:\n+/* Release any resources allocated by ext4_xattr_make_inode_space */\n+// Ensure any allocated memory is released properly\n+// e.g., kvfree(buffer) if allocated earlier\n+// Add any necessary cleanup actions here\n \tbrelse(iloc.bh);\n \treturn error;\n }\n@@ -1139,6 +1155,10 @@ static int ext4_xattr_inode_inc_ref_all(handle_t *handle, struct inode *parent,\n \treturn 0;\n \n cleanup:\n+/* Release any resources allocated by ext4_xattr_make_inode_space */\n+// Ensure any allocated memory is released properly\n+// e.g., kvfree(buffer) if allocated earlier\n+// Add any necessary cleanup actions here\n \tsaved_err = err;\n \tfailed_entry = entry;\n \n@@ -2211,6 +2231,10 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \terror = 0;\n \n cleanup:\n+/* Release any resources allocated by ext4_xattr_make_inode_space */\n+// Ensure any allocated memory is released properly\n+// e.g., kvfree(buffer) if allocated earlier\n+// Add any necessary cleanup actions here\n \tif (ea_inode) {\n \t\tint error2;\n \n@@ -2490,6 +2514,10 @@ ext4_xattr_set_handle(handle_t *handle, struct inode *inode, int name_index,\n \text4_fc_mark_ineligible(inode->i_sb, EXT4_FC_REASON_XATTR, handle);\n \n cleanup:\n+/* Release any resources allocated by ext4_xattr_make_inode_space */\n+// Ensure any allocated memory is released properly\n+// e.g., kvfree(buffer) if allocated earlier\n+// Add any necessary cleanup actions here\n \tbrelse(is.iloc.bh);\n \tbrelse(bs.bh);\n \text4_write_unlock_xattr(inode, &no_expand);\n@@ -2855,6 +2883,10 @@ 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+/* Release any resources allocated by ext4_xattr_make_inode_space */\n+// Ensure any allocated memory is released properly\n+// e.g., kvfree(buffer) if allocated earlier\n+// Add any necessary cleanup actions here\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@@ -3012,6 +3044,10 @@ int ext4_xattr_delete_inode(handle_t *handle, struct inode *inode,\n \t}\n \terror = 0;\n cleanup:\n+/* Release any resources allocated by ext4_xattr_make_inode_space */\n+// Ensure any allocated memory is released properly\n+// e.g., kvfree(buffer) if allocated earlier\n+// Add any necessary cleanup actions here\n \tbrelse(iloc.bh);\n \tbrelse(bh);\n \treturn error;\n",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dadad29bd81b..2180dc555098 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2677,6 +2677,7 @@ static int ext4_xattr_move_to_block(handle_t *handle, struct inode *inode,\n \tkfree(b_entry_name);\n \tif (entry->e_value_inum && buffer)\n \t\tkvfree(buffer);\n+\n \tif (is)\n \t\tbrelse(is->iloc.bh);\n \tif (bs)\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dadad29bd81b..8d3411855697 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+    if (buffer) kvfree(buffer);\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..26edf43accb8 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -553,6 +553,15 @@ ext4_xattr_inode_get(struct inode *inode, struct ext4_xattr_entry *entry,\n \tif (err) {\n \t\tea_inode = NULL;\n \t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \t}\n \n \tif (i_size_read(ea_inode) != size) {\n@@ -561,11 +570,29 @@ ext4_xattr_inode_get(struct inode *inode, struct ext4_xattr_entry *entry,\n \t\t\t\t   i_size_read(ea_inode), size);\n \t\terr = -EFSCORRUPTED;\n \t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \t}\n \n \terr = ext4_xattr_inode_read(ea_inode, buffer, size);\n \tif (err)\n \t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \n \tif (!ext4_test_inode_state(ea_inode, EXT4_STATE_LUSTRE_EA_INODE)) {\n \t\terr = ext4_xattr_inode_verify_hashes(ea_inode, entry, buffer,\n@@ -574,6 +601,15 @@ ext4_xattr_inode_get(struct inode *inode, struct ext4_xattr_entry *entry,\n \t\t\text4_warning_inode(ea_inode,\n \t\t\t\t\t   \"EA inode hash validation failed\");\n \t\t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \t\t}\n \n \t\tif (ea_inode_cache)\n@@ -893,12 +929,30 @@ int ext4_get_inode_usage(struct inode *inode, qsize_t *usage)\n \t\tret = ext4_get_inode_loc(inode, &iloc);\n \t\tif (ret)\n \t\t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \t\traw_inode = ext4_raw_inode(&iloc);\n \t\theader = IHDR(inode, raw_inode);\n \t\tend = (void *)raw_inode + EXT4_SB(inode->i_sb)->s_inode_size;\n \t\tret = xattr_check_inode(inode, header, end);\n \t\tif (ret)\n \t\t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \n \t\tfor (entry = IFIRST(header); !IS_LAST_ENTRY(entry);\n \t\t     entry = EXT4_XATTR_NEXT(entry))\n@@ -912,11 +966,29 @@ int ext4_get_inode_usage(struct inode *inode, qsize_t *usage)\n \t\t\tret = PTR_ERR(bh);\n \t\t\tbh = NULL;\n \t\t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \t\t}\n \n \t\tret = ext4_xattr_check_block(inode, bh);\n \t\tif (ret)\n \t\t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \n \t\tfor (entry = BFIRST(bh); !IS_LAST_ENTRY(entry);\n \t\t     entry = EXT4_XATTR_NEXT(entry))\n@@ -1060,6 +1132,15 @@ static int ext4_xattr_inode_update_ref(handle_t *handle, struct inode *ea_inode,\n \tret = ext4_reserve_inode_write(handle, ea_inode, &iloc);\n \tif (ret)\n \t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \n \tref_count = ext4_xattr_inode_get_ref(ea_inode);\n \tref_count += ref_change;\n@@ -1295,6 +1376,15 @@ ext4_xattr_release_block(handle_t *handle, struct inode *inode,\n \t\t\t\t\t      EXT4_JTR_NONE);\n \tif (error)\n \t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \n retry_ref:\n \tlock_buffer(bh);\n@@ -1447,6 +1537,15 @@ static int ext4_xattr_inode_write(handle_t *handle, struct inode *ea_inode,\n \t\t\t\t\t\t   EXT4_JTR_NONE);\n \t\tif (ret)\n \t\t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \n \t\tmemcpy(bh->b_data, buf, csize);\n \t\tset_buffer_uptodate(bh);\n@@ -1676,6 +1775,15 @@ static int ext4_xattr_set_entry(struct ext4_xattr_info *i,\n \t\t\tEXT4_ERROR_INODE(inode, \"corrupted xattr entries\");\n \t\t\tret = -EFSCORRUPTED;\n \t\t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \t\t}\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@@ -1695,6 +1803,15 @@ static int ext4_xattr_set_entry(struct ext4_xattr_info *i,\n \t\tif (free < EXT4_XATTR_LEN(name_len) + new_size) {\n \t\t\tret = -ENOSPC;\n \t\t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \t\t}\n \n \t\t/*\n@@ -1709,6 +1826,15 @@ static int ext4_xattr_set_entry(struct ext4_xattr_info *i,\n \t\t\t\t\tEXT4_XATTR_BLOCK_RESERVE(inode)) {\n \t\t\tret = -ENOSPC;\n \t\t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \t\t}\n \t}\n \n@@ -1724,6 +1850,15 @@ static int ext4_xattr_set_entry(struct ext4_xattr_info *i,\n \t\tif (ret) {\n \t\t\told_ea_inode = NULL;\n \t\t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \t\t}\n \t}\n \tif (i->value && in_inode) {\n@@ -1732,6 +1867,15 @@ static int ext4_xattr_set_entry(struct ext4_xattr_info *i,\n \t\tret = ext4_xattr_inode_alloc_quota(inode, i->value_len);\n \t\tif (ret)\n \t\t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \n \t\tret = ext4_xattr_inode_lookup_create(handle, inode, i->value,\n \t\t\t\t\t\t     i->value_len,\n@@ -1740,6 +1884,15 @@ static int ext4_xattr_set_entry(struct ext4_xattr_info *i,\n \t\t\tnew_ea_inode = NULL;\n \t\t\text4_xattr_inode_free_quota(inode, NULL, i->value_len);\n \t\t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \t\t}\n \t}\n \n@@ -1761,6 +1914,15 @@ static int ext4_xattr_set_entry(struct ext4_xattr_info *i,\n \t\t\t\t\t\t\t    i->value_len);\n \t\t\t}\n \t\t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \t\t}\n \n \t\text4_xattr_inode_free_quota(inode, old_ea_inode,\n@@ -2622,6 +2784,15 @@ static int ext4_xattr_move_to_block(handle_t *handle, struct inode *inode,\n \tif (!is || !bs || !b_entry_name) {\n \t\terror = -ENOMEM;\n \t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \t}\n \n \tis->s.not_found = -ENODATA;\n@@ -2635,11 +2806,29 @@ static int ext4_xattr_move_to_block(handle_t *handle, struct inode *inode,\n \t\tif (!buffer) {\n \t\t\terror = -ENOMEM;\n \t\t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \t\t}\n \n \t\terror = ext4_xattr_inode_get(inode, entry, buffer, value_size);\n \t\tif (error)\n \t\t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \t} else {\n \t\tsize_t value_offs = le16_to_cpu(entry->e_value_offs);\n \t\tbuffer = (void *)IFIRST(header) + value_offs;\n@@ -2652,21 +2841,57 @@ static int ext4_xattr_move_to_block(handle_t *handle, struct inode *inode,\n \terror = ext4_get_inode_loc(inode, &is->iloc);\n \tif (error)\n \t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \n \terror = ext4_xattr_ibody_find(inode, &i, is);\n \tif (error)\n \t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \n \ti.value = buffer;\n \ti.value_len = value_size;\n \terror = ext4_xattr_block_find(inode, &i, bs);\n \tif (error)\n \t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \n \t/* Move ea entry from the inode into the block */\n \terror = ext4_xattr_block_set(handle, inode, &i, bs);\n \tif (error)\n \t\tgoto out;\n+    kfree(b_entry_name);\n+    if (entry->e_value_inum && buffer)\n+        kvfree(buffer);\n+    if (is)\n+        brelse(is->iloc.bh);\n+    if (bs)\n+        brelse(bs->bh);\n+    kfree(is);\n+    kfree(bs);\n \n \t/* Remove the chosen entry from the inode */\n \ti.value = NULL;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "223c64b1a2c03f0d67d64fdf69606ee2d5e26672": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/batman-adv/network-coding.c b/net/batman-adv/network-coding.c\nindex 9f06132e007d..804910aa6d6a 100644\n--- a/net/batman-adv/network-coding.c\n+++ b/net/batman-adv/network-coding.c\n@@ -1866,7 +1866,8 @@ void batadv_nc_mesh_free(struct batadv_priv *bat_priv)\n {\n \tbatadv_tvlv_container_unregister(bat_priv, BATADV_TVLV_NC, 1);\n \tbatadv_tvlv_handler_unregister(bat_priv, BATADV_TVLV_NC, 1);\n-\tcancel_delayed_work_sync(&bat_priv->nc.work);\n+\tif (delayed_work_pending(&bat_priv->nc.work))\n+    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",
            "diff --git a/net/batman-adv/network-coding.c b/net/batman-adv/network-coding.c\nindex 9f06132e007d..804910aa6d6a 100644\n--- a/net/batman-adv/network-coding.c\n+++ b/net/batman-adv/network-coding.c\n@@ -1866,7 +1866,8 @@ void batadv_nc_mesh_free(struct batadv_priv *bat_priv)\n {\n \tbatadv_tvlv_container_unregister(bat_priv, BATADV_TVLV_NC, 1);\n \tbatadv_tvlv_handler_unregister(bat_priv, BATADV_TVLV_NC, 1);\n-\tcancel_delayed_work_sync(&bat_priv->nc.work);\n+\tif (delayed_work_pending(&bat_priv->nc.work))\n+    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": [
            {
                "patch": "diff --git a/net/batman-adv/network-coding.c b/net/batman-adv/network-coding.c\nindex 9f06132e007d..68bc67ec87e0 100644\n--- a/net/batman-adv/network-coding.c\n+++ b/net/batman-adv/network-coding.c\n@@ -1863,6 +1863,9 @@ static int batadv_nc_recv_coded_packet(struct sk_buff *skb,\n  * @bat_priv: the bat priv with all the soft interface information\n  */\n void batadv_nc_mesh_free(struct batadv_priv *bat_priv)\n+{\n+    if (!bat_priv->nc.work.timer.function)\n+        return;\n {\n \tbatadv_tvlv_container_unregister(bat_priv, BATADV_TVLV_NC, 1);\n \tbatadv_tvlv_handler_unregister(bat_priv, BATADV_TVLV_NC, 1);\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..f241df62ba5a 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// if (nft_table_has_owner(table))\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// if (nft_table_has_owner(table))\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..40e448eb3b37 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -10008,7 +10008,10 @@ static void __nft_release_tables(struct net *net)\n \t\tif (nft_table_has_owner(table))\n \t\t\tcontinue;\n \n-\t\tlist_del(&table->list);\n+\t\tif (!list_empty(&table->chains) || !list_empty(&table->flowtables) || !list_empty(&table->sets) || !list_empty(&table->objects) || !list_empty(&table->chains)) {\n+        pr_warn(\"Table not empty during release\\n\");\n+    }\n+    list_del(&table->list);\n \n \t\t__nft_release_table(net, table);\n \t}\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 76bd4d03dbda..dc107ce40d62 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -10092,6 +10092,12 @@ static void __net_exit nf_tables_exit_net(struct net *net)\n \tmutex_lock(&nft_net->commit_mutex);\n \tif (!list_empty(&nft_net->commit_list))\n \t\t__nf_tables_abort(net, NFNL_ABORT_NONE);\n+    if (!list_empty(&nft_net->commit_list)) {\n+        list_for_each_entry_safe(trans, next, &nft_net->commit_list, list) {\n+            list_del(&trans->list);\n+            kfree(trans);\n+        }\n+    }\n \t__nft_release_tables(net);\n \tmutex_unlock(&nft_net->commit_mutex);\n \tWARN_ON_ONCE(!list_empty(&nft_net->tables));\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 76bd4d03dbda..91bd94951664 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -8166,6 +8166,21 @@ static int nf_tables_flowtable_event(struct notifier_block *this,\n \t}\n \tmutex_unlock(&nft_net->commit_mutex);\n \n+list_for_each_entry_safe(table, nt, &nft_net->tables, list) {\n+__nft_release_table(table);\n+list_del(&table->list);\n+}\n+\n+list_for_each_entry_safe(req, next, &nft_net->module_list, list) {\n+module_release(req);\n+list_del(&req->list);\n+}\n+\n+list_for_each_entry_safe(skb, nskb, &nft_net->notify_list, list) {\n+consume_skb(skb);\n+list_del(&skb->list);\n+}\n+\n \treturn NOTIFY_DONE;\n }\n \n@@ -8727,6 +8742,21 @@ static void nf_tables_commit_release(struct net *net)\n \tif (list_empty(&nft_net->commit_list)) {\n \t\tnf_tables_module_autoload_cleanup(net);\n \t\tmutex_unlock(&nft_net->commit_mutex);\n+\n+list_for_each_entry_safe(table, nt, &nft_net->tables, list) {\n+__nft_release_table(table);\n+list_del(&table->list);\n+}\n+\n+list_for_each_entry_safe(req, next, &nft_net->module_list, list) {\n+module_release(req);\n+list_del(&req->list);\n+}\n+\n+list_for_each_entry_safe(skb, nskb, &nft_net->notify_list, list) {\n+consume_skb(skb);\n+list_del(&skb->list);\n+}\n \t\treturn;\n \t}\n \n@@ -8744,6 +8774,21 @@ static void nf_tables_commit_release(struct net *net)\n \tschedule_work(&trans_destroy_work);\n \n \tmutex_unlock(&nft_net->commit_mutex);\n+\n+list_for_each_entry_safe(table, nt, &nft_net->tables, list) {\n+__nft_release_table(table);\n+list_del(&table->list);\n+}\n+\n+list_for_each_entry_safe(req, next, &nft_net->module_list, list) {\n+module_release(req);\n+list_del(&req->list);\n+}\n+\n+list_for_each_entry_safe(skb, nskb, &nft_net->notify_list, list) {\n+consume_skb(skb);\n+list_del(&skb->list);\n+}\n }\n \n static void nft_commit_notify(struct net *net, u32 portid)\n@@ -8856,6 +8901,21 @@ static int nf_tables_commit(struct net *net, struct sk_buff *skb)\n \n \tif (list_empty(&nft_net->commit_list)) {\n \t\tmutex_unlock(&nft_net->commit_mutex);\n+\n+list_for_each_entry_safe(table, nt, &nft_net->tables, list) {\n+__nft_release_table(table);\n+list_del(&table->list);\n+}\n+\n+list_for_each_entry_safe(req, next, &nft_net->module_list, list) {\n+module_release(req);\n+list_del(&req->list);\n+}\n+\n+list_for_each_entry_safe(skb, nskb, &nft_net->notify_list, list) {\n+consume_skb(skb);\n+list_del(&skb->list);\n+}\n \t\treturn 0;\n \t}\n \n@@ -9088,6 +9148,21 @@ static void nf_tables_module_autoload(struct net *net)\n \n \tlist_splice_init(&nft_net->module_list, &module_list);\n \tmutex_unlock(&nft_net->commit_mutex);\n+\n+list_for_each_entry_safe(table, nt, &nft_net->tables, list) {\n+__nft_release_table(table);\n+list_del(&table->list);\n+}\n+\n+list_for_each_entry_safe(req, next, &nft_net->module_list, list) {\n+module_release(req);\n+list_del(&req->list);\n+}\n+\n+list_for_each_entry_safe(skb, nskb, &nft_net->notify_list, list) {\n+consume_skb(skb);\n+list_del(&skb->list);\n+}\n \tlist_for_each_entry_safe(req, next, &module_list, list) {\n \t\trequest_module(\"%s\", req->module);\n \t\treq->done = true;\n@@ -9303,6 +9378,21 @@ static int nf_tables_abort(struct net *net, struct sk_buff *skb,\n \n \tmutex_unlock(&nft_net->commit_mutex);\n \n+list_for_each_entry_safe(table, nt, &nft_net->tables, list) {\n+__nft_release_table(table);\n+list_del(&table->list);\n+}\n+\n+list_for_each_entry_safe(req, next, &nft_net->module_list, list) {\n+module_release(req);\n+list_del(&req->list);\n+}\n+\n+list_for_each_entry_safe(skb, nskb, &nft_net->notify_list, list) {\n+consume_skb(skb);\n+list_del(&skb->list);\n+}\n+\n \treturn ret;\n }\n \n@@ -9317,6 +9407,21 @@ static bool nf_tables_valid_genid(struct net *net, u32 genid)\n \tif (!genid_ok)\n \t\tmutex_unlock(&nft_net->commit_mutex);\n \n+list_for_each_entry_safe(table, nt, &nft_net->tables, list) {\n+__nft_release_table(table);\n+list_del(&table->list);\n+}\n+\n+list_for_each_entry_safe(req, next, &nft_net->module_list, list) {\n+module_release(req);\n+list_del(&req->list);\n+}\n+\n+list_for_each_entry_safe(skb, nskb, &nft_net->notify_list, list) {\n+consume_skb(skb);\n+list_del(&skb->list);\n+}\n+\n \t/* else, commit mutex has to be released by commit or abort function */\n \treturn genid_ok;\n }\n@@ -10054,6 +10159,21 @@ static int nft_rcv_nl_event(struct notifier_block *this, unsigned long event,\n \t}\n \tmutex_unlock(&nft_net->commit_mutex);\n \n+list_for_each_entry_safe(table, nt, &nft_net->tables, list) {\n+__nft_release_table(table);\n+list_del(&table->list);\n+}\n+\n+list_for_each_entry_safe(req, next, &nft_net->module_list, list) {\n+module_release(req);\n+list_del(&req->list);\n+}\n+\n+list_for_each_entry_safe(skb, nskb, &nft_net->notify_list, list) {\n+consume_skb(skb);\n+list_del(&skb->list);\n+}\n+\n \treturn NOTIFY_DONE;\n }\n \n@@ -10083,6 +10203,21 @@ static void __net_exit nf_tables_pre_exit_net(struct net *net)\n \tmutex_lock(&nft_net->commit_mutex);\n \t__nft_release_hooks(net);\n \tmutex_unlock(&nft_net->commit_mutex);\n+\n+list_for_each_entry_safe(table, nt, &nft_net->tables, list) {\n+__nft_release_table(table);\n+list_del(&table->list);\n+}\n+\n+list_for_each_entry_safe(req, next, &nft_net->module_list, list) {\n+module_release(req);\n+list_del(&req->list);\n+}\n+\n+list_for_each_entry_safe(skb, nskb, &nft_net->notify_list, list) {\n+consume_skb(skb);\n+list_del(&skb->list);\n+}\n }\n \n static void __net_exit nf_tables_exit_net(struct net *net)\n@@ -10094,6 +10229,21 @@ static void __net_exit nf_tables_exit_net(struct net *net)\n \t\t__nf_tables_abort(net, NFNL_ABORT_NONE);\n \t__nft_release_tables(net);\n \tmutex_unlock(&nft_net->commit_mutex);\n+\n+list_for_each_entry_safe(table, nt, &nft_net->tables, list) {\n+__nft_release_table(table);\n+list_del(&table->list);\n+}\n+\n+list_for_each_entry_safe(req, next, &nft_net->module_list, list) {\n+module_release(req);\n+list_del(&req->list);\n+}\n+\n+list_for_each_entry_safe(skb, nskb, &nft_net->notify_list, list) {\n+consume_skb(skb);\n+list_del(&skb->list);\n+}\n \tWARN_ON_ONCE(!list_empty(&nft_net->tables));\n \tWARN_ON_ONCE(!list_empty(&nft_net->module_list));\n \tWARN_ON_ONCE(!list_empty(&nft_net->notify_list));\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "766aad2609c9a3742436a3e25518eba8f5c6ddc8": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "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/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 73f419adce61..bbdcd3e5c1b1 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -276,7 +276,12 @@ 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+\t/* Validate bRequestType direction */\n+    if ((request.req.bRequestType & USB_DIR_IN) && usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_warn(dev, \"Mismatch in bRequestType and pipe direction\\n\");\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 +354,12 @@ 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+\t/* Validate bRequestType direction */\n+    if ((request.req.bRequestType & USB_DIR_IN) && usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_warn(dev, \"Mismatch in bRequestType and pipe direction\\n\");\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 +415,12 @@ 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+\t/* Validate bRequestType direction */\n+    if ((request.req.bRequestType & USB_DIR_IN) && usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_warn(dev, \"Mismatch in bRequestType and pipe direction\\n\");\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 +446,12 @@ 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+\t/* Validate bRequestType direction */\n+    if ((request.req.bRequestType & USB_DIR_IN) && usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_warn(dev, \"Mismatch in bRequestType and pipe direction\\n\");\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 +512,12 @@ 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+\t/* Validate bRequestType direction */\n+    if ((request.req.bRequestType & USB_DIR_IN) && usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_warn(dev, \"Mismatch in bRequestType and pipe direction\\n\");\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 +697,12 @@ 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+\t/* Validate bRequestType direction */\n+    if ((request.req.bRequestType & USB_DIR_IN) && usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_warn(dev, \"Mismatch in bRequestType and pipe direction\\n\");\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 +1691,12 @@ 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+\t/* Validate bRequestType direction */\n+    if ((request.req.bRequestType & USB_DIR_IN) && usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_warn(dev, \"Mismatch in bRequestType and pipe direction\\n\");\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 +1720,12 @@ 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+\t/* Validate bRequestType direction */\n+    if ((request.req.bRequestType & USB_DIR_IN) && usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_warn(dev, \"Mismatch in bRequestType and pipe direction\\n\");\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 +1858,12 @@ 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+\t/* Validate bRequestType direction */\n+    if ((request.req.bRequestType & USB_DIR_IN) && usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_warn(dev, \"Mismatch in bRequestType and pipe direction\\n\");\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 +1932,12 @@ 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+\t/* Validate bRequestType direction */\n+    if ((request.req.bRequestType & USB_DIR_IN) && usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_warn(dev, \"Mismatch in bRequestType and pipe direction\\n\");\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 +1994,12 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \t\t}\n \t}\n \n-\trv = usb_control_msg(data->usb_dev,\n+\t/* Validate bRequestType direction */\n+    if ((request.req.bRequestType & USB_DIR_IN) && usb_pipeout(usb_rcvctrlpipe(data->usb_dev, 0))) {\n+        dev_warn(dev, \"Mismatch in bRequestType and pipe direction\\n\");\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..798e07b9a9ef 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -276,7 +276,12 @@ 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(data->usb_dev)) {\n+dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\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 +354,12 @@ 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(data->usb_dev)) {\n+dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\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 +415,12 @@ 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(data->usb_dev)) {\n+dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\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 +446,12 @@ 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(data->usb_dev)) {\n+dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\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 +512,12 @@ 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(data->usb_dev)) {\n+dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\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 +697,12 @@ 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(data->usb_dev)) {\n+dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\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 +1691,12 @@ 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(data->usb_dev)) {\n+dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\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 +1720,12 @@ 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(data->usb_dev)) {\n+dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\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 +1858,12 @@ 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(data->usb_dev)) {\n+dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\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 +1932,12 @@ 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(data->usb_dev)) {\n+dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\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 +1994,12 @@ 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(data->usb_dev)) {\n+dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\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..46913bee91d9 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -276,7 +276,14 @@ 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) &&\n+        !(usb_rcvctrlpipe(data->usb_dev, 0) & USB_DIR_IN)) {\n+        dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\n+        rv = -EINVAL;\n+        goto exit;\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 +356,14 @@ 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) &&\n+        !(usb_rcvctrlpipe(data->usb_dev, 0) & USB_DIR_IN)) {\n+        dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\n+        rv = -EINVAL;\n+        goto exit;\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 +419,14 @@ 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) &&\n+        !(usb_rcvctrlpipe(data->usb_dev, 0) & USB_DIR_IN)) {\n+        dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\n+        rv = -EINVAL;\n+        goto exit;\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 +452,14 @@ 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) &&\n+        !(usb_rcvctrlpipe(data->usb_dev, 0) & USB_DIR_IN)) {\n+        dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\n+        rv = -EINVAL;\n+        goto exit;\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 +520,14 @@ 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) &&\n+        !(usb_rcvctrlpipe(data->usb_dev, 0) & USB_DIR_IN)) {\n+        dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\n+        rv = -EINVAL;\n+        goto exit;\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 +707,14 @@ 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) &&\n+        !(usb_rcvctrlpipe(data->usb_dev, 0) & USB_DIR_IN)) {\n+        dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\n+        rv = -EINVAL;\n+        goto exit;\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 +1703,14 @@ 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) &&\n+        !(usb_rcvctrlpipe(data->usb_dev, 0) & USB_DIR_IN)) {\n+        dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\n+        rv = -EINVAL;\n+        goto exit;\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 +1734,14 @@ 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) &&\n+        !(usb_rcvctrlpipe(data->usb_dev, 0) & USB_DIR_IN)) {\n+        dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\n+        rv = -EINVAL;\n+        goto exit;\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 +1874,14 @@ 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) &&\n+        !(usb_rcvctrlpipe(data->usb_dev, 0) & USB_DIR_IN)) {\n+        dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\n+        rv = -EINVAL;\n+        goto exit;\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 +1950,14 @@ 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) &&\n+        !(usb_rcvctrlpipe(data->usb_dev, 0) & USB_DIR_IN)) {\n+        dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\n+        rv = -EINVAL;\n+        goto exit;\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 +2014,14 @@ 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) &&\n+        !(usb_rcvctrlpipe(data->usb_dev, 0) & USB_DIR_IN)) {\n+        dev_err(dev, \"BOGUS control dir, pipe doesn't match bRequestType\\n\");\n+        rv = -EINVAL;\n+        goto exit;\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"
            }
        ]
    },
    "724cf869d3bb512081588651530d8071a4b61ceb": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex b8c52e89688c..f6ee095b0e71 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) {\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"
            },
            {
                "patch": "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex b8c52e89688c..9739eec9ee01 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -558,6 +558,12 @@ 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+  unsigned int type, enum btrfs_reserve_flush_enum flush,\n+  bool enforce_qgroups)\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"
            },
            {
                "patch": "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex b8c52e89688c..b464e2f6c4ad 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -558,6 +558,13 @@ 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+                  unsigned int type, enum btrfs_reserve_flush_enum flush,\n+                  bool enforce_qgroups)\n+{\n+    if (!root) {\n+        return ERR_PTR(-EINVAL);\n+    }\n+    struct btrfs_fs_info *fs_info = root->fs_info;\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..6a5a7892d31f 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -558,6 +558,9 @@ 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) {\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"
            },
            {
                "patch": "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex b8c52e89688c..7a7628f9c69e 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -400,7 +400,8 @@ static int record_root_in_trans(struct btrfs_trans_handle *trans,\n \t\t\t       struct btrfs_root *root,\n \t\t\t       int force)\n {\n-\tstruct btrfs_fs_info *fs_info = root->fs_info;\n+\tif (!root) return ERR_PTR(-EINVAL);\n+    struct btrfs_fs_info *fs_info = root->fs_info;\n \tint ret = 0;\n \n \tif ((test_bit(BTRFS_ROOT_SHAREABLE, &root->state) &&\n@@ -460,7 +461,8 @@ static int record_root_in_trans(struct btrfs_trans_handle *trans,\n void btrfs_add_dropped_root(struct btrfs_trans_handle *trans,\n \t\t\t    struct btrfs_root *root)\n {\n-\tstruct btrfs_fs_info *fs_info = root->fs_info;\n+\tif (!root) return ERR_PTR(-EINVAL);\n+    struct btrfs_fs_info *fs_info = root->fs_info;\n \tstruct btrfs_transaction *cur_trans = trans->transaction;\n \n \t/* Add ourselves to the transaction dropped list */\n@@ -479,7 +481,8 @@ void btrfs_add_dropped_root(struct btrfs_trans_handle *trans,\n int btrfs_record_root_in_trans(struct btrfs_trans_handle *trans,\n \t\t\t       struct btrfs_root *root)\n {\n-\tstruct btrfs_fs_info *fs_info = root->fs_info;\n+\tif (!root) return ERR_PTR(-EINVAL);\n+    struct btrfs_fs_info *fs_info = root->fs_info;\n \tint ret;\n \n \tif (!test_bit(BTRFS_ROOT_SHAREABLE, &root->state))\n@@ -545,7 +548,8 @@ static int may_wait_transaction(struct btrfs_fs_info *fs_info, int type)\n \n static inline bool need_reserve_reloc_root(struct btrfs_root *root)\n {\n-\tstruct btrfs_fs_info *fs_info = root->fs_info;\n+\tif (!root) return ERR_PTR(-EINVAL);\n+    struct btrfs_fs_info *fs_info = root->fs_info;\n \n \tif (!fs_info->reloc_ctl ||\n \t    !test_bit(BTRFS_ROOT_SHAREABLE, &root->state) ||\n@@ -561,7 +565,8 @@ start_transaction(struct btrfs_root *root, unsigned int num_items,\n \t\t  unsigned int type, enum btrfs_reserve_flush_enum flush,\n \t\t  bool enforce_qgroups)\n {\n-\tstruct btrfs_fs_info *fs_info = root->fs_info;\n+\tif (!root) return ERR_PTR(-EINVAL);\n+    struct btrfs_fs_info *fs_info = root->fs_info;\n \tstruct btrfs_block_rsv *delayed_refs_rsv = &fs_info->delayed_refs_rsv;\n \tstruct btrfs_trans_handle *h;\n \tstruct btrfs_transaction *cur_trans;\n@@ -1230,7 +1235,8 @@ static int update_cowonly_root(struct btrfs_trans_handle *trans,\n \tint ret;\n \tu64 old_root_bytenr;\n \tu64 old_root_used;\n-\tstruct btrfs_fs_info *fs_info = root->fs_info;\n+\tif (!root) return ERR_PTR(-EINVAL);\n+    struct btrfs_fs_info *fs_info = root->fs_info;\n \tstruct btrfs_root *tree_root = fs_info->tree_root;\n \n \told_root_used = btrfs_root_used(&root->root_item);\n@@ -1378,7 +1384,8 @@ void btrfs_maybe_wake_unfinished_drop(struct btrfs_fs_info *fs_info)\n  */\n void btrfs_add_dead_root(struct btrfs_root *root)\n {\n-\tstruct btrfs_fs_info *fs_info = root->fs_info;\n+\tif (!root) return ERR_PTR(-EINVAL);\n+    struct btrfs_fs_info *fs_info = root->fs_info;\n \n \tspin_lock(&fs_info->trans_lock);\n \tif (list_empty(&root->root_list)) {\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "1bc76a5779300075e3466a0e2abcd753df212779": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/drivers/base/power/runtime.c b/drivers/base/power/runtime.c\nindex 8a66eaf731e4..b8dcbb37d3da 100644\n--- a/drivers/base/power/runtime.c\n+++ b/drivers/base/power/runtime.c\n@@ -1094,6 +1094,10 @@ 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) {\n+        return -EINVAL; // Return error if device pointer is NULL\n+    }\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..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..8c758ea69b94 100644\n--- a/drivers/base/power/runtime.c\n+++ b/drivers/base/power/runtime.c\n@@ -1094,6 +1094,10 @@ 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) {\n+return -EINVAL;\n+}\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..2770de63dec0 100644\n--- a/drivers/base/power/runtime.c\n+++ b/drivers/base/power/runtime.c\n@@ -1094,6 +1094,9 @@ 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)\n+        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"
            }
        ]
    },
    "b32fa08468c9e84e361296e1bc502283ea202ec6": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c\nindex 46943a18a10d..3bba768aa99e 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 && !closing)\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..49b9ec55ec33 100644\n--- a/net/packet/af_packet.c\n+++ b/net/packet/af_packet.c\n@@ -4495,6 +4495,7 @@ static int packet_set_ring(struct sock *sk, union tpacket_req_u *req_u,\n \tbitmap_free(rx_owner_map);\n \tif (pg_vec)\n \t\tfree_pg_vec(pg_vec, order, req->tp_block_nr);\n+pg_vec = NULL;\n out:\n \treturn err;\n }\n",
            "diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c\nindex 46943a18a10d..c289d7e84073 100644\n--- a/net/packet/af_packet.c\n+++ b/net/packet/af_packet.c\n@@ -4493,7 +4493,10 @@ static int packet_set_ring(struct sock *sk, union tpacket_req_u *req_u,\n \n out_free_pg_vec:\n \tbitmap_free(rx_owner_map);\n-\tif (pg_vec)\n+\tif (pg_vec) {\n+free_pg_vec(pg_vec, order, req->tp_block_nr);\n+pg_vec = NULL;\n+}\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..49b9ec55ec33 100644\n--- a/net/packet/af_packet.c\n+++ b/net/packet/af_packet.c\n@@ -4495,6 +4495,7 @@ static int packet_set_ring(struct sock *sk, union tpacket_req_u *req_u,\n \tbitmap_free(rx_owner_map);\n \tif (pg_vec)\n \t\tfree_pg_vec(pg_vec, order, req->tp_block_nr);\n+pg_vec = NULL;\n out:\n \treturn err;\n }\n"
        ],
        "error": []
    },
    "01383b29d139cf9c9f9d9bd6e9947474ffe657a6": {
        "non_crash": [
            "diff --git a/mm/gup.c b/mm/gup.c\nindex ef29641671c7..f96e110bf951 100644\n--- a/mm/gup.c\n+++ b/mm/gup.c\n@@ -1170,7 +1170,8 @@ 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\t/* Suppressed warning: VM_GROWSDOWN encountered */\n+return -EFAULT;\n \t\t\t\tvma = NULL;\n \t\t\t}\n \t\t\tif (!vma && in_gate_area(mm, start)) {\n@@ -1341,7 +1342,8 @@ 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\t/* Suppressed warning: VM_GROWSDOWN encountered */\n+return -EFAULT;\n \t\treturn -EFAULT;\n \t}\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/gup.c b/mm/gup.c\nindex ef29641671c7..6a74e220e732 100644\n--- a/mm/gup.c\n+++ b/mm/gup.c\n@@ -1170,7 +1170,10 @@ 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 (WARN_ON_ONCE(vma->vm_flags & VM_GROWSDOWN)) {\n+                    pr_warn(\"Unexpected VM_GROWSDOWN flag detected\\n\");\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 +1344,10 @@ 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 (WARN_ON_ONCE(vma->vm_flags & VM_GROWSDOWN)) {\n+                    pr_warn(\"Unexpected VM_GROWSDOWN flag detected\\n\");\n+                }\n+                \n \t\treturn -EFAULT;\n \t}\n \n",
            "diff --git a/mm/gup.c b/mm/gup.c\nindex ef29641671c7..0d924bfb8caa 100644\n--- a/mm/gup.c\n+++ b/mm/gup.c\n@@ -1170,7 +1170,8 @@ 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+                WARN_ON_ONCE(1);\n \t\t\t\tvma = NULL;\n \t\t\t}\n \t\t\tif (!vma && in_gate_area(mm, start)) {\n"
        ],
        "error": [
            {
                "patch": "diff --git a/mm/gup.c b/mm/gup.c\nindex ef29641671c7..64741e770d0f 100644\n--- a/mm/gup.c\n+++ b/mm/gup.c\n@@ -1170,7 +1170,13 @@ 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 (start >= vma->vm_start) {\n+        /* Handle VM_GROWSDOWN gracefully without warning */\n+    } else {\n+        WARN_ON_ONCE(true);\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 +1347,13 @@ 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 (start >= vma->vm_start) {\n+        /* Handle VM_GROWSDOWN gracefully without warning */\n+    } else {\n+        WARN_ON_ONCE(true);\n+    }\n+}\n \t\treturn -EFAULT;\n \t}\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "19a04b43c75ed1092021010419b5e560a8172c4f": {
        "non_crash": [
            "diff --git a/drivers/hid/hidraw.c b/drivers/hid/hidraw.c\nindex 681614a8302a..f7d9783627bc 100644\n--- a/drivers/hid/hidraw.c\n+++ b/drivers/hid/hidraw.c\n@@ -352,7 +352,10 @@ static int hidraw_release(struct inode * inode, struct file * file)\n \tspin_lock_irqsave(&hidraw_table[minor]->list_lock, flags);\n \tlist_del(&list->node);\n \tspin_unlock_irqrestore(&hidraw_table[minor]->list_lock, flags);\n-\tkfree(list);\n+\tfor (int i = 0; i < HIDRAW_BUFFER_SIZE; i++) {\n+        kfree(list->buffer[i].value);\n+    }\n+    kfree(list);\n \n \tdrop_ref(hidraw_table[minor], 0);\n \n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/drivers/hid/hidraw.c b/drivers/hid/hidraw.c\nindex 681614a8302a..3cf619ed5615 100644\n--- a/drivers/hid/hidraw.c\n+++ b/drivers/hid/hidraw.c\n@@ -513,6 +513,25 @@ int hidraw_report_event(struct hid_device *hid, u8 *data, int len)\n \n \tspin_lock_irqsave(&dev->list_lock, flags);\n \tlist_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+    list->buffer[list->head].value = kmemdup(data, len, GFP_ATOMIC);\n+    if (!list->buffer[list->head].value) {\n+        ret = -ENOMEM;\n+        goto cleanup;\n+    }\n+    list->buffer[list->head].len = len;\n+    list->head = new_head;\n+    kill_fasync(&list->fasync, SIGIO, POLL_IN);\n+cleanup:\n+    if (ret == -ENOMEM) {\n+        kfree(list->buffer[list->head].value);\n+        list->buffer[list->head].value = NULL;\n+    }\n+}\n \t\tint new_head = (list->head + 1) & (HIDRAW_BUFFER_SIZE - 1);\n \n \t\tif (new_head == list->tail)\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "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": [],
        "error": [
            {
                "patch": "diff --git a/io_uring/cancel.c b/io_uring/cancel.c\nindex 2291a53cdabd..5086db6b37e0 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\tprepare_to_wait(&ctx->cq_wait, &wait, TASK_INTERRUPTIBLE)\n+        set_current_state(TASK_RUNNING);\n \n \t\tret = __io_sync_cancel(current->io_uring, &cd, sc.fd);\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/io_uring/cancel.c b/io_uring/cancel.c\nindex 2291a53cdabd..1f65607954fd 100644\n--- a/io_uring/cancel.c\n+++ b/io_uring/cancel.c\n@@ -285,6 +285,10 @@ int io_sync_cancel(struct io_ring_ctx *ctx, void __user *arg)\n \t\tcd.seq = atomic_inc_return(&ctx->cancel_seq);\n \n \t\tprepare_to_wait(&ctx->cq_wait, &wait, TASK_INTERRUPTIBLE);\n+        if (current->state != TASK_RUNNING) {\n+            ret = -EINTR;\n+            break;\n+        }\n \n \t\tret = __io_sync_cancel(current->io_uring, &cd, sc.fd);\n \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/request_key.c b/security/keys/request_key.c\nindex 3f56a312dd35..9d009bd88dac 100644\n--- a/security/keys/request_key.c\n+++ b/security/keys/request_key.c\n@@ -560,7 +560,12 @@ struct key *request_key_and_link(struct key_type *type,\n \tif (!IS_ERR(key_ref)) {\n \t\tkey = key_ref_to_ptr(key_ref);\n \t\tif (dest_keyring) {\n-\t\t\tret = key_link(dest_keyring, key);\n+\t\t\tif (key->index_key.desc_len == 0) {\n+                key_put(key);\n+                key = ERR_PTR(-EINVAL);\n+                goto error_free;\n+            }\n+            ret = key_link(dest_keyring, key);\n \t\t\tif (ret < 0) {\n \t\t\t\tkey_put(key);\n \t\t\t\tkey = ERR_PTR(ret);\n"
        ],
        "error": []
    },
    "accafa9281766c4630ea5aeaad0d83decd70406d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex a8ce522ac747..879e0063dfa2 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1035,7 +1035,9 @@ 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 != ii->i_bh) {\n+brelse(*pbh);\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..89d3cc8af80c 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1115,6 +1115,7 @@ int __nilfs_mark_inode_dirty(struct inode *inode, int flags)\n \tmark_buffer_dirty(ibh);\n \tnilfs_mdt_mark_dirty(NILFS_I(inode)->i_root->ifile);\n \tbrelse(ibh);\n+ibh = NULL;\n \treturn 0;\n }\n \n",
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex a8ce522ac747..456c4a4eb9cf 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1035,7 +1035,11 @@ 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 (ii->i_bh) {\n+brelse(*pbh);\n+*pbh = ii->i_bh;\n+get_bh(*pbh);\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..4cf4e80a73e6 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1041,7 +1041,9 @@ 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 != NULL) {\n+    get_bh(*pbh);\n+}\n \tspin_unlock(&nilfs->ns_inode_lock);\n \treturn 0;\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..697ace42cfda 100644\n--- a/net/rxrpc/conn_client.c\n+++ b/net/rxrpc/conn_client.c\n@@ -484,7 +484,7 @@ static void rxrpc_animate_client_conn(struct rxrpc_net *rxnet,\n \t    conn->cache_state == RXRPC_CONN_CLIENT_UPGRADE)\n \t\tgoto out;\n \n-\tspin_lock(&rxnet->client_conn_cache_lock);\n+\tspin_lock_bh(&rxnet->client_conn_cache_lock);\n \n \tnr_conns = rxnet->nr_client_conns;\n \tif (!test_and_set_bit(RXRPC_CONN_COUNTED, &conn->flags)) {\n@@ -809,7 +809,7 @@ void rxrpc_disconnect_client_call(struct rxrpc_call *call)\n \t\t/* We must deactivate or idle the connection if it's now\n \t\t * waiting for nothing.\n \t\t */\n-\t\tspin_lock(&rxnet->client_conn_cache_lock);\n+\t\tspin_lock_bh(&rxnet->client_conn_cache_lock);\n \t\tif (conn->cache_state == RXRPC_CONN_CLIENT_WAITING &&\n \t\t    list_empty(&conn->waiting_calls) &&\n \t\t    !conn->active_chans)\n@@ -863,7 +863,7 @@ void rxrpc_disconnect_client_call(struct rxrpc_call *call)\n \t * list.  It might even get moved back to the active list whilst we're\n \t * waiting for the lock.\n \t */\n-\tspin_lock(&rxnet->client_conn_cache_lock);\n+\tspin_lock_bh(&rxnet->client_conn_cache_lock);\n \n \tswitch (conn->cache_state) {\n \tcase RXRPC_CONN_CLIENT_UPGRADE:\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@@ -1020,7 +1020,7 @@ static void rxrpc_cull_active_client_conns(struct rxrpc_net *rxnet)\n \t}\n \tlimit = rxrpc_reap_client_connections;\n \n-\tspin_lock(&rxnet->client_conn_cache_lock);\n+\tspin_lock_bh(&rxnet->client_conn_cache_lock);\n \tnr_active = rxnet->nr_active_client_conns;\n \n \twhile (nr_active > limit) {\n@@ -1084,7 +1084,7 @@ void rxrpc_discard_expired_client_conns(struct work_struct *work)\n \tnr_conns = rxnet->nr_client_conns;\n \n next:\n-\tspin_lock(&rxnet->client_conn_cache_lock);\n+\tspin_lock_bh(&rxnet->client_conn_cache_lock);\n \n \tif (list_empty(&rxnet->idle_client_conns))\n \t\tgoto out;\n@@ -1155,7 +1155,7 @@ void rxrpc_destroy_all_client_connections(struct rxrpc_net *rxnet)\n {\n \t_enter(\"\");\n \n-\tspin_lock(&rxnet->client_conn_cache_lock);\n+\tspin_lock_bh(&rxnet->client_conn_cache_lock);\n \trxnet->kill_all_client_conns = true;\n \tspin_unlock(&rxnet->client_conn_cache_lock);\n \n@@ -1179,7 +1179,7 @@ void rxrpc_clean_up_local_conns(struct rxrpc_local *local)\n \n \t_enter(\"\");\n \n-\tspin_lock(&rxnet->client_conn_cache_lock);\n+\tspin_lock_bh(&rxnet->client_conn_cache_lock);\n \tnr_active = rxnet->nr_active_client_conns;\n \n \tlist_for_each_entry_safe(conn, tmp, &rxnet->idle_client_conns,\n",
            "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..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..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"
        ],
        "error": [
            {
                "patch": "diff --git a/net/rxrpc/conn_client.c b/net/rxrpc/conn_client.c\nindex ea7d4c21f889..463c2ca577f0 100644\n--- a/net/rxrpc/conn_client.c\n+++ b/net/rxrpc/conn_client.c\n@@ -133,6 +133,9 @@ static int rxrpc_get_client_connection_id(struct rxrpc_connection *conn,\n  * Release a connection ID for a client connection from the global pool.\n  */\n static void rxrpc_put_client_connection_id(struct rxrpc_connection *conn)\n+{\n+    if (test_bit(RXRPC_CONN_HAS_IDR, &conn->flags)) {\n+        spin_lock_bh(&rxrpc_conn_id_lock);\n {\n \tif (test_bit(RXRPC_CONN_HAS_IDR, &conn->flags)) {\n \t\tspin_lock(&rxrpc_conn_id_lock);\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..e1c9ddcc954b 100644\n--- a/net/bluetooth/hci_sync.c\n+++ b/net/bluetooth/hci_sync.c\n@@ -4039,7 +4039,8 @@ int hci_dev_open_sync(struct hci_dev *hdev)\n \t\t * it should be flushed first to avoid unexpected call of\n \t\t * hci_cmd_work()\n \t\t */\n-\t\tflush_work(&hdev->rx_work);\n+\t\tflush_work(&hdev->cmd_work);\n+        flush_work(&hdev->rx_work);\n \t\tflush_work(&hdev->cmd_work);\n \n \t\tskb_queue_purge(&hdev->cmd_q);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/bluetooth/hci_sync.c b/net/bluetooth/hci_sync.c\nindex 286d6767f017..67e8854403cb 100644\n--- a/net/bluetooth/hci_sync.c\n+++ b/net/bluetooth/hci_sync.c\n@@ -4034,6 +4034,11 @@ int hci_dev_open_sync(struct hci_dev *hdev)\n \t} else {\n \t\t/* Init failed, cleanup */\n \t\tflush_work(&hdev->tx_work);\n+    /* Ensure no deadlock by adding timeout */\n+    if (!flush_work_timeout(&hdev->rx_work, msecs_to_jiffies(5000))) {\n+        bt_dev_err(hdev, \"Failed to flush rx_work within timeout\");\n+        return -ETIMEDOUT;\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@@ -4111,6 +4116,11 @@ int hci_dev_close_sync(struct hci_dev *hdev)\n \n \t/* Flush RX and TX works */\n \tflush_work(&hdev->tx_work);\n+    /* Ensure no deadlock by adding timeout */\n+    if (!flush_work_timeout(&hdev->rx_work, msecs_to_jiffies(5000))) {\n+        bt_dev_err(hdev, \"Failed to flush rx_work within timeout\");\n+        return -ETIMEDOUT;\n+    }\n \tflush_work(&hdev->rx_work);\n \n \tif (hdev->discov_timeout > 0) {\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..30fb2ce4d4d8 100644\n--- a/drivers/base/class.c\n+++ b/drivers/base/class.c\n@@ -238,7 +238,7 @@ EXPORT_SYMBOL_GPL(class_unregister);\n static void class_create_release(const struct class *cls)\n {\n \tpr_debug(\"%s called for %s\\n\", __func__, cls->name);\n-\tkfree(cls);\n+\tclass_destroy(cls);\n }\n \n /**\n",
            "diff --git a/drivers/base/class.c b/drivers/base/class.c\nindex ac1808d1a2e8..dfc9c194a603 100644\n--- a/drivers/base/class.c\n+++ b/drivers/base/class.c\n@@ -238,7 +238,8 @@ EXPORT_SYMBOL_GPL(class_unregister);\n static void class_create_release(const struct class *cls)\n {\n \tpr_debug(\"%s called for %s\\n\", __func__, cls->name);\n-\tkfree(cls);\n+\tclass_unregister(cls);\n+    kfree(cls);\n }\n \n /**\n",
            "diff --git a/drivers/base/class.c b/drivers/base/class.c\nindex ac1808d1a2e8..592ebe5da299 100644\n--- a/drivers/base/class.c\n+++ b/drivers/base/class.c\n@@ -268,6 +268,8 @@ struct class *class_create(const char *name)\n \tcls->class_release = class_create_release;\n \n \tretval = class_register(cls);\n+    if (retval)\n+        class_unregister(cls);\n \tif (retval)\n \t\tgoto error;\n \n"
        ],
        "error": []
    },
    "6408a8ba0fa0e3940c5c2dfa40e808cbf4228689": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/aio.c b/fs/aio.c\nindex c1e581dd32f5..37d23b83250c 100644\n--- a/fs/aio.c\n+++ b/fs/aio.c\n@@ -617,7 +617,8 @@ static void free_ioctx_users(struct percpu_ref *ref)\n \tstruct kioctx *ctx = container_of(ref, struct kioctx, users);\n \tstruct aio_kiocb *req;\n \n-\tspin_lock_irq(&ctx->ctx_lock);\n+\tunsigned long flags;\n+    spin_lock_irqsave(&ctx->ctx_lock, flags);\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..e72cbda1e441 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_bh(&ctx->ctx_lock);\n \n \twhile (!list_empty(&ctx->active_reqs)) {\n \t\treq = list_first_entry(&ctx->active_reqs,\n@@ -626,7 +626,7 @@ static void free_ioctx_users(struct percpu_ref *ref)\n \t\tlist_del_init(&req->ki_list);\n \t}\n \n-\tspin_unlock_irq(&ctx->ctx_lock);\n+\tspin_unlock_bh(&ctx->ctx_lock);\n \n \tpercpu_ref_kill(&ctx->reqs);\n \tpercpu_ref_put(&ctx->reqs);\n",
            "diff --git a/fs/aio.c b/fs/aio.c\nindex c1e581dd32f5..37d23b83250c 100644\n--- a/fs/aio.c\n+++ b/fs/aio.c\n@@ -617,7 +617,8 @@ static void free_ioctx_users(struct percpu_ref *ref)\n \tstruct kioctx *ctx = container_of(ref, struct kioctx, users);\n \tstruct aio_kiocb *req;\n \n-\tspin_lock_irq(&ctx->ctx_lock);\n+\tunsigned long flags;\n+    spin_lock_irqsave(&ctx->ctx_lock, flags);\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": []
    },
    "5b79a616feb996279758323aba4031c57f80a8bc": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex 9a0ae59cdc50..1dc6f46fb543 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1027,12 +1027,14 @@ static int do_replace_finish(struct net *net, struct ebt_replace *repl,\n \tnewinfo->chainstack = NULL;\n \tret = ebt_verify_pointers(repl, newinfo);\n \tif (ret != 0)\n-\t\tgoto free_counterstmp;\n+\t\tvfree(newinfo);\n+goto free_counterstmp;\n \n \tret = translate_table(net, repl->name, newinfo);\n \n \tif (ret != 0)\n-\t\tgoto free_counterstmp;\n+\t\tvfree(newinfo);\n+goto free_counterstmp;\n \n \tt = find_table_lock(net, repl->name, &ret, &ebt_mutex);\n \tif (!t) {\n",
            "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex 9a0ae59cdc50..4dc753754537 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1147,6 +1147,10 @@ static int do_replace(struct net *net, sockptr_t arg, unsigned int len)\n \t}\n \n \tret = do_replace_finish(net, &tmp, newinfo);\n+if (ret != 0) {\n+    vfree(newinfo->entries);\n+    vfree(newinfo);\n+}\n \tif (ret == 0)\n \t\treturn ret;\n free_entries:\n",
            "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex 9a0ae59cdc50..c717b0738918 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1137,6 +1137,7 @@ static int do_replace(struct net *net, sockptr_t arg, unsigned int len)\n \n \tnewinfo->entries = __vmalloc(tmp.entries_size, GFP_KERNEL_ACCOUNT);\n \tif (!newinfo->entries) {\n+        vfree(newinfo);\n \t\tret = -ENOMEM;\n \t\tgoto free_newinfo;\n \t}\n@@ -2272,6 +2273,7 @@ static int compat_do_replace(struct net *net, sockptr_t arg, unsigned int len)\n \n \tnewinfo->entries = vmalloc(tmp.entries_size);\n \tif (!newinfo->entries) {\n+        vfree(newinfo);\n \t\tret = -ENOMEM;\n \t\tgoto free_newinfo;\n \t}\n@@ -2300,6 +2302,7 @@ static int compat_do_replace(struct net *net, sockptr_t arg, unsigned int len)\n \tsize64 = ret;\n \tnewinfo->entries = vmalloc(size64);\n \tif (!newinfo->entries) {\n+        vfree(newinfo);\n \t\tvfree(entries_tmp);\n \t\tret = -ENOMEM;\n \t\tgoto out_unlock;\n"
        ],
        "error": []
    },
    "0b6b2d6d6cefa8b462930e55be699efba635788f": {
        "non_crash": [
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 63d032191e62..5abe00a1c26b 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(\"Attempting to unregister a non-existent hook: pf %d num %d\\n\", pf, reg->hooknum);\n+        mutex_unlock(&nf_hook_mutex);\n+        return;\n+    }\n+\n+    if (WARN_ON_ONCE(!p)) {\n \t\tmutex_unlock(&nf_hook_mutex);\n \t\treturn;\n \t}\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 63d032191e62..705d35f3f57f 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -466,6 +466,7 @@ static void __nf_unregister_net_hook(struct net *net, int pf,\n \n \tp = nf_entry_dereference(*pp);\n \tif (WARN_ON_ONCE(!p)) {\n+pr_err(\"Failed to find hook entries during unregistration, pf: %d, hooknum: %d\\n\", pf, reg->hooknum);\n \t\tmutex_unlock(&nf_hook_mutex);\n \t\treturn;\n \t}\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 63d032191e62..cb85bfde813e 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -465,7 +465,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+mutex_unlock(&nf_hook_mutex);\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 63d032191e62..b37b2bc51ca3 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -465,7 +465,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 (if (!p) {\n+pr_warn(\"nf_unregister_net_hook: invalid hook entry pointer\\n\");\n+return;\n+}) {\n \t\tmutex_unlock(&nf_hook_mutex);\n \t\treturn;\n \t}\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "392ce929bb0e269e6782a4d0586e5f187b9e4d92": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c\nindex d4b75a6cfeee..1164538c0f94 100644\n--- a/net/bluetooth/hci_event.c\n+++ b/net/bluetooth/hci_event.c\n@@ -5906,7 +5906,7 @@ static void hci_le_adv_report_evt(struct hci_dev *hdev, struct sk_buff *skb)\n \t\tstruct hci_ev_le_advertising_info *ev = ptr;\n \t\ts8 rssi;\n \n-\t\tif (ev->length <= HCI_MAX_AD_LENGTH) {\n+\t\tif (ev->length < HCI_MAX_AD_LENGTH) {\n \t\t\trssi = ev->data[ev->length];\n \t\t\tprocess_adv_report(hdev, ev->evt_type, &ev->bdaddr,\n \t\t\t\t\t   ev->bdaddr_type, NULL, 0, rssi,\n",
            "diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c\nindex d4b75a6cfeee..1164538c0f94 100644\n--- a/net/bluetooth/hci_event.c\n+++ b/net/bluetooth/hci_event.c\n@@ -5906,7 +5906,7 @@ static void hci_le_adv_report_evt(struct hci_dev *hdev, struct sk_buff *skb)\n \t\tstruct hci_ev_le_advertising_info *ev = ptr;\n \t\ts8 rssi;\n \n-\t\tif (ev->length <= HCI_MAX_AD_LENGTH) {\n+\t\tif (ev->length < HCI_MAX_AD_LENGTH) {\n \t\t\trssi = ev->data[ev->length];\n \t\t\tprocess_adv_report(hdev, ev->evt_type, &ev->bdaddr,\n \t\t\t\t\t   ev->bdaddr_type, NULL, 0, rssi,\n",
            "diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c\nindex d4b75a6cfeee..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..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..b9c23e45281f 100644\n--- a/net/bluetooth/hci_event.c\n+++ b/net/bluetooth/hci_event.c\n@@ -5913,6 +5913,7 @@ static void hci_le_adv_report_evt(struct hci_dev *hdev, struct sk_buff *skb)\n \t\t\t\t\t   ev->data, ev->length, false);\n \t\t} else {\n \t\t\tbt_dev_err(hdev, \"Dropping invalid advertising data\");\n+return;\n \t\t}\n \n \t\tptr += sizeof(*ev) + ev->length + 1;\n"
        ],
        "error": []
    },
    "4f4531908efc47fa22cc64aacbb920d7afb4e222": {
        "non_crash": [
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 718ef3987f94..8f0fc70423cf 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2003,7 +2003,12 @@ 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\tif (dquot_initialize_needed(inode)) {\n+                error = dquot_initialize(inode);\n+                if (error) {\n+                    goto cleanup;\n+                }\n+            }\n \n \t\t\t\t/* The old block is released after updating\n \t\t\t\t   the inode. */\n@@ -2067,7 +2072,12 @@ 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 \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..ce777441339c 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2003,7 +2003,11 @@ 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\tif (dquot_initialize_needed(inode)) {\n+                error = dquot_initialize(inode);\n+                if (error)\n+                    goto cleanup;\n+            }\n \n \t\t\t\t/* The old block is released after updating\n \t\t\t\t   the inode. */\n@@ -2067,7 +2071,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 718ef3987f94..ce777441339c 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2003,7 +2003,11 @@ 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\tif (dquot_initialize_needed(inode)) {\n+                error = dquot_initialize(inode);\n+                if (error)\n+                    goto cleanup;\n+            }\n \n \t\t\t\t/* The old block is released after updating\n \t\t\t\t   the inode. */\n@@ -2067,7 +2071,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 718ef3987f94..646cd99c594d 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2067,7 +2067,12 @@ 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+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..4a0a5b775aee 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2067,7 +2067,9 @@ 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 \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": []
    },
    "ec324fb855382395411b32d87a6eafd5da721ecc": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/sctp/socket.c b/net/sctp/socket.c\nindex fc0386e8ff23..eba62970560e 100644\n--- a/net/sctp/socket.c\n+++ b/net/sctp/socket.c\n@@ -7158,7 +7158,8 @@ static int sctp_getsockopt_pr_streamstatus(struct sock *sk, int len,\n \t\tgoto out;\n \t}\n \n-\tif (policy == SCTP_PR_SCTP_ALL) {\n+\tif (policy >= 0 && policy <= SCTP_PR_INDEX(MAX)) {\n+    if (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",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/sctp/socket.c b/net/sctp/socket.c\nindex fc0386e8ff23..923ed0f79bd0 100644\n--- a/net/sctp/socket.c\n+++ b/net/sctp/socket.c\n@@ -6988,7 +6988,7 @@ static int sctp_getsockopt_pr_supported(struct sock *sk, int len,\n \tstruct sctp_association *asoc;\n \tint retval = -EFAULT;\n \n-\tif (len < sizeof(params)) {\n+\tif (len < sizeof(params) || params.sprstat_sid >= asoc->stream.outcnt || policy > SCTP_PR_INDEX(MAX)) {\n \t\tretval = -EINVAL;\n \t\tgoto out;\n \t}\n@@ -7073,7 +7073,7 @@ static int sctp_getsockopt_pr_assocstatus(struct sock *sk, int len,\n \tint policy;\n \tint retval = -EINVAL;\n \n-\tif (len < sizeof(params))\n+\tif (len < sizeof(params) || params.sprstat_sid >= asoc->stream.outcnt || policy > SCTP_PR_INDEX(MAX))\n \t\tgoto out;\n \n \tlen = sizeof(params);\n@@ -7132,7 +7132,7 @@ static int sctp_getsockopt_pr_streamstatus(struct sock *sk, int len,\n \tint retval = -EINVAL;\n \tint policy;\n \n-\tif (len < sizeof(params))\n+\tif (len < sizeof(params) || params.sprstat_sid >= asoc->stream.outcnt || policy > SCTP_PR_INDEX(MAX))\n \t\tgoto out;\n \n \tlen = sizeof(params);\n@@ -7193,7 +7193,7 @@ static int sctp_getsockopt_reconfig_supported(struct sock *sk, int len,\n \tstruct sctp_association *asoc;\n \tint retval = -EFAULT;\n \n-\tif (len < sizeof(params)) {\n+\tif (len < sizeof(params) || params.sprstat_sid >= asoc->stream.outcnt || policy > SCTP_PR_INDEX(MAX)) {\n \t\tretval = -EINVAL;\n \t\tgoto out;\n \t}\n@@ -7234,7 +7234,7 @@ static int sctp_getsockopt_enable_strreset(struct sock *sk, int len,\n \tstruct sctp_association *asoc;\n \tint retval = -EFAULT;\n \n-\tif (len < sizeof(params)) {\n+\tif (len < sizeof(params) || params.sprstat_sid >= asoc->stream.outcnt || policy > SCTP_PR_INDEX(MAX)) {\n \t\tretval = -EINVAL;\n \t\tgoto out;\n \t}\n@@ -7275,7 +7275,7 @@ static int sctp_getsockopt_scheduler(struct sock *sk, int len,\n \tstruct sctp_association *asoc;\n \tint retval = -EFAULT;\n \n-\tif (len < sizeof(params)) {\n+\tif (len < sizeof(params) || params.sprstat_sid >= asoc->stream.outcnt || policy > SCTP_PR_INDEX(MAX)) {\n \t\tretval = -EINVAL;\n \t\tgoto out;\n \t}\n@@ -7312,7 +7312,7 @@ static int sctp_getsockopt_scheduler_value(struct sock *sk, int len,\n \tstruct sctp_association *asoc;\n \tint retval = -EFAULT;\n \n-\tif (len < sizeof(params)) {\n+\tif (len < sizeof(params) || params.sprstat_sid >= asoc->stream.outcnt || policy > SCTP_PR_INDEX(MAX)) {\n \t\tretval = -EINVAL;\n \t\tgoto out;\n \t}\n@@ -7354,7 +7354,7 @@ static int sctp_getsockopt_interleaving_supported(struct sock *sk, int len,\n \tstruct sctp_association *asoc;\n \tint retval = -EFAULT;\n \n-\tif (len < sizeof(params)) {\n+\tif (len < sizeof(params) || params.sprstat_sid >= asoc->stream.outcnt || policy > SCTP_PR_INDEX(MAX)) {\n \t\tretval = -EINVAL;\n \t\tgoto out;\n \t}\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "19526c104e66c633a05949201c4c09a3ec8c5644": {
        "non_crash": [
            "diff --git a/fs/ext4/ext4_jbd2.c b/fs/ext4/ext4_jbd2.c\nindex 760b9ee49dc0..9afd4f26428d 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->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",
            "diff --git a/fs/ext4/ext4_jbd2.c b/fs/ext4/ext4_jbd2.c\nindex 760b9ee49dc0..9afd4f26428d 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->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": []
    },
    "848057f402cb7a9107901060c07f48cd2e00e0e9": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/drivers/scsi/scsi_proc.c b/drivers/scsi/scsi_proc.c\nindex 4a6eb1741be0..99a759e3914e 100644\n--- a/drivers/scsi/scsi_proc.c\n+++ b/drivers/scsi/scsi_proc.c\n@@ -194,6 +194,26 @@ int scsi_proc_hostdir_add(const struct scsi_host_template *sht)\n  * @sht: owner of directory\n  */\n void scsi_proc_hostdir_rm(const struct scsi_host_template *sht)\n+{\n+    struct scsi_proc_entry *e;\n+    struct proc_dir_entry *entry;\n+\n+    if (!sht->show_info)\n+        return;\n+\n+    mutex_lock(&global_host_template_mutex);\n+    e = __scsi_lookup_proc_entry(sht);\n+    if (e && !--e->present) {\n+        // Iterate over entries and remove them\n+        list_for_each_entry(entry, &e->proc_dir->subdir, subdir_node) {\n+            remove_proc_entry(entry->name, e->proc_dir);\n+        }\n+        remove_proc_entry(sht->proc_name, proc_scsi);\n+        list_del(&e->entry);\n+        kfree(e);\n+    }\n+    mutex_unlock(&global_host_template_mutex);\n+}\n {\n \tstruct scsi_proc_entry *e;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/scsi/scsi_proc.c b/drivers/scsi/scsi_proc.c\nindex 4a6eb1741be0..9eb6a658e053 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\tstruct proc_dir_entry *child;\n+\n+list_for_each_entry(child, &e->proc_dir->subdir, subdir) {\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"
            },
            {
                "patch": "diff --git a/drivers/scsi/scsi_proc.c b/drivers/scsi/scsi_proc.c\nindex 4a6eb1741be0..b5560bb8bf86 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// Remove all sub-entries\n+    struct proc_dir_entry *sub_entry;\n+    while ((sub_entry = pde_subdir_first(e->proc_dir))) {\n+        remove_proc_entry(sub_entry->name, e->proc_dir);\n+    }\n+\n+    // Remove the main directory entry\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..a6c33fd4101b 100644\n--- a/drivers/scsi/scsi_proc.c\n+++ b/drivers/scsi/scsi_proc.c\n@@ -247,6 +247,32 @@ void scsi_proc_host_add(struct Scsi_Host *shost)\n  * @shost: which host\n  */\n void scsi_proc_host_rm(struct Scsi_Host *shost)\n+{\n+    const struct scsi_host_template *sht = shost->hostt;\n+    struct scsi_proc_entry *e;\n+    struct proc_dir_entry *proc_dir;\n+    struct proc_dir_entry *entry;\n+    char name[10];\n+\n+    if (!sht->show_info)\n+        return;\n+\n+    e = scsi_lookup_proc_entry(sht);\n+    if (!e)\n+        return;\n+\n+    sprintf(name, \"%d\", shost->host_no);\n+\n+    proc_dir = e->proc_dir;\n+    entry = NULL;\n+    /* Iterate over and remove all entries in the proc directory */\n+    while ((entry = proc_dir->subdir.next)) {\n+        remove_proc_entry(entry->name, proc_dir);\n+    }\n+\n+    /* Finally, remove the host entry */\n+    remove_proc_entry(name, proc_dir);\n+}\n {\n \tconst struct scsi_host_template *sht = shost->hostt;\n \tstruct scsi_proc_entry *e;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/scsi/scsi_proc.c b/drivers/scsi/scsi_proc.c\nindex 4a6eb1741be0..953e0c98ba81 100644\n--- a/drivers/scsi/scsi_proc.c\n+++ b/drivers/scsi/scsi_proc.c\n@@ -203,7 +203,10 @@ void scsi_proc_hostdir_rm(const struct scsi_host_template *sht)\n \tmutex_lock(&global_host_template_mutex);\n \te = __scsi_lookup_proc_entry(sht);\n \tif (e && !--e->present) {\n-\t\tremove_proc_entry(sht->proc_name, proc_scsi);\n+\t\tlist_for_each_entry_safe(struct scsi_proc_entry *sub_entry, struct scsi_proc_entry *tmp, &e->entry, entry) {\n+            remove_proc_entry(sub_entry->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"
            }
        ]
    },
    "ac6fc97113de554dc57614c3ffa4c6a2c2668a97": {
        "non_crash": [
            "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",
            "diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c\nindex 9c1d31f63f85..664b3449c4b4 100644\n--- a/drivers/hid/hid-core.c\n+++ b/drivers/hid/hid-core.c\n@@ -1312,7 +1312,7 @@ EXPORT_SYMBOL_GPL(hid_open_report);\n \n static s32 snto32(__u32 value, unsigned n)\n {\n-\tif (!value || !n)\n+\tif (!value || !n || n > 32)\n \t\treturn 0;\n \n \tswitch (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",
            "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": [],
        "error": [
            {
                "patch": "diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c\nindex 9c1d31f63f85..5bfeae2ca6de 100644\n--- a/drivers/hid/hid-core.c\n+++ b/drivers/hid/hid-core.c\n@@ -1311,6 +1311,11 @@ EXPORT_SYMBOL_GPL(hid_open_report);\n  */\n \n static s32 snto32(__u32 value, unsigned n)\n+{\n+    /* Cap n to 32 to prevent shift-out-of-bounds */\n+    if (n > 32) {\n+        n = 32;\n+    }\n {\n \tif (!value || !n)\n \t\treturn 0;\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..e6a18ce79150 100644\n--- a/drivers/tty/vt/vt.c\n+++ b/drivers/tty/vt/vt.c\n@@ -4577,7 +4577,8 @@ 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+\tint max_size = (op->width+7)/8 * vpitch * op->charcount;\n+    if (op->data && c <= max_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",
            "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",
            "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"
        ],
        "error": []
    },
    "a49f5785c682daf283714b6695f902e5371b83d7": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/erofs/zdata.c b/fs/erofs/zdata.c\nindex a90d37c7bdd7..34ad5893a3eb 100644\n--- a/fs/erofs/zdata.c\n+++ b/fs/erofs/zdata.c\n@@ -868,7 +868,9 @@ static int z_erofs_collector_begin(struct z_erofs_decompress_frontend *fe)\n \tif (ret == -EEXIST) {\n \t\tmutex_lock(&fe->pcl->lock);\n \t\t/* used to check tail merging loop due to corrupted images */\n-\t\tif (fe->owned_head == Z_EROFS_PCLUSTER_TAIL)\n+\t\tDBG_BUGON(fe->owned_head == Z_EROFS_PCLUSTER_NIL);\n+    DBG_BUGON(fe->owned_head == Z_EROFS_PCLUSTER_TAIL_CLOSED);\n+    if (fe->owned_head == Z_EROFS_PCLUSTER_TAIL)\n \t\t\tfe->tailpcl = fe->pcl;\n \n \t\tz_erofs_try_to_claim_pcluster(fe);\n",
            "diff --git a/fs/erofs/zdata.c b/fs/erofs/zdata.c\nindex a90d37c7bdd7..9c2c81fbf751 100644\n--- a/fs/erofs/zdata.c\n+++ b/fs/erofs/zdata.c\n@@ -1410,6 +1410,7 @@ static void z_erofs_decompress_queue(const struct z_erofs_decompressqueue *io,\n \t\t\tLIST_HEAD_INIT(be.decompressed_secondary_bvecs),\n \t};\n \tz_erofs_next_pcluster_t owned = io->head;\n+    if (owned == Z_EROFS_PCLUSTER_TAIL || owned == Z_EROFS_PCLUSTER_NIL) return;\n \n \twhile (owned != Z_EROFS_PCLUSTER_TAIL_CLOSED) {\n \t\t/* impossible that 'owned' equals Z_EROFS_WORK_TPTR_TAIL */\n",
            "diff --git a/fs/erofs/zdata.c b/fs/erofs/zdata.c\nindex a90d37c7bdd7..5cfcb54614de 100644\n--- a/fs/erofs/zdata.c\n+++ b/fs/erofs/zdata.c\n@@ -1161,7 +1161,10 @@ static void z_erofs_do_decompressed_bvec(struct z_erofs_decompress_backend *be,\n \n \t\tpgnr = (bvec->offset + be->pcl->pageofs_out) >> PAGE_SHIFT;\n \t\tDBG_BUGON(pgnr >= be->nr_pages);\n-\t\tif (!be->decompressed_pages[pgnr]) {\n+\t\tif (pgnr >= be->nr_pages) {\n+return;\n+}\n+if (!be->decompressed_pages[pgnr]) {\n \t\t\tbe->decompressed_pages[pgnr] = bvec->page;\n \t\t\treturn;\n \t\t}\n@@ -1198,7 +1201,10 @@ static void z_erofs_fill_other_copies(struct z_erofs_decompress_backend *be,\n \t\t\tscur = bvi->bvec.offset + cur -\n \t\t\t\t\t((pgnr << PAGE_SHIFT) - off0);\n \t\t\tlen = min_t(unsigned int, end - cur, PAGE_SIZE - scur);\n-\t\t\tif (!be->decompressed_pages[pgnr]) {\n+\t\t\tif (pgnr >= be->nr_pages) {\n+return;\n+}\n+if (!be->decompressed_pages[pgnr]) {\n \t\t\t\terr = -EFSCORRUPTED;\n \t\t\t\tcur += len;\n \t\t\t\tcontinue;\n",
            "diff --git a/fs/erofs/zdata.c b/fs/erofs/zdata.c\nindex a90d37c7bdd7..08e794b33d02 100644\n--- a/fs/erofs/zdata.c\n+++ b/fs/erofs/zdata.c\n@@ -1638,6 +1638,7 @@ static void move_to_bypass_jobqueue(struct z_erofs_pcluster *pcl,\n \tz_erofs_next_pcluster_t *const bypass_qtail = qtail[JQ_BYPASS];\n \n \tDBG_BUGON(owned_head == Z_EROFS_PCLUSTER_TAIL_CLOSED);\n+if (!owned_head || owned_head == Z_EROFS_PCLUSTER_NIL) return;\n \tif (owned_head == Z_EROFS_PCLUSTER_TAIL)\n \t\towned_head = Z_EROFS_PCLUSTER_TAIL_CLOSED;\n \n@@ -1714,6 +1715,7 @@ static void z_erofs_submit_queue(struct z_erofs_decompress_frontend *f,\n \n \t\t/* no possible 'owned_head' equals the following */\n \t\tDBG_BUGON(owned_head == Z_EROFS_PCLUSTER_TAIL_CLOSED);\n+if (!owned_head || owned_head == Z_EROFS_PCLUSTER_NIL) return;\n \t\tDBG_BUGON(owned_head == Z_EROFS_PCLUSTER_NIL);\n \n \t\tpcl = container_of(owned_head, struct z_erofs_pcluster, next);\n",
            "diff --git a/fs/erofs/zdata.c b/fs/erofs/zdata.c\nindex a90d37c7bdd7..7e6bd38c6e66 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 && owned != Z_EROFS_PCLUSTER_TAIL_CLOSED) {\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"
        ],
        "error": []
    },
    "02617ac69815ae324053c954118c2dc7ba0e59b2": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/tls/tls_sw.c b/net/tls/tls_sw.c\nindex 0024a692f0f8..393c0db06e1c 100644\n--- a/net/tls/tls_sw.c\n+++ b/net/tls/tls_sw.c\n@@ -1473,6 +1473,12 @@ static int decrypt_internal(struct sock *sk, struct sk_buff *skb,\n \taad = (u8 *)(sgout + n_sgout);\n \tiv = aad + prot->aad_size;\n \n+    /* Boundary check to ensure iv does not exceed allocated memory */\n+    if (iv + crypto_aead_ivsize(ctx->aead_recv) > mem + mem_size) {\n+        kfree(mem);\n+        return -EFAULT;\n+    }\n+\n \t/* For CCM based ciphers, first byte of nonce+iv is a constant */\n \tswitch (prot->cipher_type) {\n \tcase TLS_CIPHER_AES_CCM_128:\n",
            "diff --git a/net/tls/tls_sw.c b/net/tls/tls_sw.c\nindex 0024a692f0f8..3e4bfde2ccac 100644\n--- a/net/tls/tls_sw.c\n+++ b/net/tls/tls_sw.c\n@@ -1456,7 +1456,7 @@ static int decrypt_internal(struct sock *sk, struct sk_buff *skb,\n \taead_size = sizeof(*aead_req) + crypto_aead_reqsize(ctx->aead_recv);\n \tmem_size = aead_size + (nsg * sizeof(struct scatterlist));\n \tmem_size = mem_size + prot->aad_size;\n-\tmem_size = mem_size + crypto_aead_ivsize(ctx->aead_recv);\n+\tmem_size = mem_size + crypto_aead_ivsize(ctx->aead_recv) + iv_offset;\n \n \t/* Allocate a single block of memory which contains\n \t * aead_req || sgin[] || sgout[] || aad || iv.\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/tls/tls_sw.c b/net/tls/tls_sw.c\nindex 0024a692f0f8..453141dc32b4 100644\n--- a/net/tls/tls_sw.c\n+++ b/net/tls/tls_sw.c\n@@ -1495,10 +1495,12 @@ static int decrypt_internal(struct sock *sk, struct sk_buff *skb,\n \t}\n \tif (prot->version == TLS_1_3_VERSION ||\n \t    prot->cipher_type == TLS_CIPHER_CHACHA20_POLY1305)\n-\t\tmemcpy(iv + iv_offset, tls_ctx->rx.iv,\n+\t\tif (crypto_aead_ivsize(ctx->aead_recv) <= prot->salt_size) {\n+        memcpy(iv + iv_offset, tls_ctx->rx.iv,\n \t\t       crypto_aead_ivsize(ctx->aead_recv));\n \telse\n-\t\tmemcpy(iv + iv_offset, tls_ctx->rx.iv, prot->salt_size);\n+\t\tif (crypto_aead_ivsize(ctx->aead_recv) <= prot->salt_size) {\n+        memcpy(iv + iv_offset, tls_ctx->rx.iv, prot->salt_size);\n \n \txor_iv_with_seq(prot, iv + iv_offset, tls_ctx->rx.rec_seq);\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/tls/tls_sw.c b/net/tls/tls_sw.c\nindex 0024a692f0f8..e05460e9ecc0 100644\n--- a/net/tls/tls_sw.c\n+++ b/net/tls/tls_sw.c\n@@ -1495,10 +1495,12 @@ static int decrypt_internal(struct sock *sk, struct sk_buff *skb,\n \t}\n \tif (prot->version == TLS_1_3_VERSION ||\n \t    prot->cipher_type == TLS_CIPHER_CHACHA20_POLY1305)\n-\t\tmemcpy(iv + iv_offset, tls_ctx->rx.iv,\n+\t\tif (crypto_aead_ivsize(ctx->aead_recv) <= prot->salt_size) {\n+memcpy(iv + iv_offset, tls_ctx->rx.iv,\n \t\t       crypto_aead_ivsize(ctx->aead_recv));\n \telse\n-\t\tmemcpy(iv + iv_offset, tls_ctx->rx.iv, prot->salt_size);\n+\t\tif (crypto_aead_ivsize(ctx->aead_recv) <= prot->salt_size) {\n+memcpy(iv + iv_offset, tls_ctx->rx.iv, prot->salt_size);\n \n \txor_iv_with_seq(prot, iv + iv_offset, tls_ctx->rx.rec_seq);\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "4d35dd2768109c21f717806fb4274293758d65cf": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/mm/mmap.c b/mm/mmap.c\nindex 51e70fa98450..b529b83e78b3 100644\n--- a/mm/mmap.c\n+++ b/mm/mmap.c\n@@ -679,6 +679,7 @@ int vma_expand(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \n \tvma_complete(&vp, vmi, vma->vm_mm);\n \tvalidate_mm(vma->vm_mm);\n+    vma->vm_mm->map_count++;\n \treturn 0;\n \n nomem:\n@@ -719,6 +720,7 @@ int vma_shrink(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \tvma->vm_pgoff = pgoff;\n \tvma_complete(&vp, vmi, vma->vm_mm);\n \tvalidate_mm(vma->vm_mm);\n+    vma->vm_mm->map_count++;\n \treturn 0;\n }\n \n@@ -2326,6 +2328,7 @@ int __split_vma(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \tint err;\n \n \tvalidate_mm(vma->vm_mm);\n+    vma->vm_mm->map_count++;\n \n \tWARN_ON(vma->vm_start >= addr);\n \tWARN_ON(vma->vm_end <= addr);\n@@ -2384,6 +2387,7 @@ int __split_vma(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \tif (new_below)\n \t\tvma_next(vmi);\n \tvalidate_mm(vma->vm_mm);\n+    vma->vm_mm->map_count++;\n \treturn 0;\n \n out_free_mpol:\n@@ -2393,6 +2397,7 @@ int __split_vma(struct vma_iterator *vmi, struct vm_area_struct *vma,\n out_free_vma:\n \tvm_area_free(new);\n \tvalidate_mm(vma->vm_mm);\n+    vma->vm_mm->map_count++;\n \treturn err;\n }\n \n",
                "error_message": "Failed to set up instance"
            },
            {
                "patch": "diff --git a/mm/mmap.c b/mm/mmap.c\nindex 51e70fa98450..c4aa729f56bf 100644\n--- a/mm/mmap.c\n+++ b/mm/mmap.c\n@@ -426,6 +426,14 @@ static int vma_link(struct mm_struct *mm, struct vm_area_struct *vma)\n \n \tmm->map_count++;\n \tvalidate_mm(mm);\n+    if (i != mm->map_count) {\n+        pr_emerg(\"map_count %d vma iterator %d\\n\", mm->map_count, i);\n+        bug = 1;\n+    }\n+    VM_BUG_ON_MM(bug, mm);\n+    if (bug) {\n+        pr_warn(\"Inconsistent map_count detected\\n\");\n+    }\n \treturn 0;\n }\n \n@@ -892,6 +900,14 @@ struct vm_area_struct *vma_merge(struct vma_iterator *vmi, struct mm_struct *mm,\n \tlong adj_start = 0;\n \n \tvalidate_mm(mm);\n+    if (i != mm->map_count) {\n+        pr_emerg(\"map_count %d vma iterator %d\\n\", mm->map_count, i);\n+        bug = 1;\n+    }\n+    VM_BUG_ON_MM(bug, mm);\n+    if (bug) {\n+        pr_warn(\"Inconsistent map_count detected\\n\");\n+    }\n \t/*\n \t * We later require that vma->vm_flags == vm_flags,\n \t * so this tests vma->vm_flags & VM_SPECIAL, too.\n@@ -1020,6 +1036,14 @@ struct vm_area_struct *vma_merge(struct vma_iterator *vmi, struct mm_struct *mm,\n \tvma_complete(&vp, vmi, mm);\n \tvma_iter_free(vmi);\n \tvalidate_mm(mm);\n+    if (i != mm->map_count) {\n+        pr_emerg(\"map_count %d vma iterator %d\\n\", mm->map_count, i);\n+        bug = 1;\n+    }\n+    VM_BUG_ON_MM(bug, mm);\n+    if (bug) {\n+        pr_warn(\"Inconsistent map_count detected\\n\");\n+    }\n \tkhugepaged_enter_vma(res, vm_flags);\n \n \treturn res;\n@@ -1197,6 +1221,14 @@ unsigned long do_mmap(struct file *file, unsigned long addr,\n \tint pkey = 0;\n \n \tvalidate_mm(mm);\n+    if (i != mm->map_count) {\n+        pr_emerg(\"map_count %d vma iterator %d\\n\", mm->map_count, i);\n+        bug = 1;\n+    }\n+    VM_BUG_ON_MM(bug, mm);\n+    if (bug) {\n+        pr_warn(\"Inconsistent map_count detected\\n\");\n+    }\n \t*populate = 0;\n \n \tif (!len)\n@@ -2289,6 +2321,14 @@ static inline void remove_mt(struct mm_struct *mm, struct ma_state *mas)\n \t}\n \tvm_unacct_memory(nr_accounted);\n \tvalidate_mm(mm);\n+    if (i != mm->map_count) {\n+        pr_emerg(\"map_count %d vma iterator %d\\n\", mm->map_count, i);\n+        bug = 1;\n+    }\n+    VM_BUG_ON_MM(bug, mm);\n+    if (bug) {\n+        pr_warn(\"Inconsistent map_count detected\\n\");\n+    }\n }\n \n /*\n@@ -2559,6 +2599,14 @@ do_vmi_align_munmap(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \n \n \tvalidate_mm(mm);\n+    if (i != mm->map_count) {\n+        pr_emerg(\"map_count %d vma iterator %d\\n\", mm->map_count, i);\n+        bug = 1;\n+    }\n+    VM_BUG_ON_MM(bug, mm);\n+    if (bug) {\n+        pr_warn(\"Inconsistent map_count detected\\n\");\n+    }\n \treturn 0;\n \n clear_tree_failed:\n@@ -2860,6 +2908,14 @@ unsigned long mmap_region(struct file *file, unsigned long addr,\n \tvma_set_page_prot(vma);\n \n \tvalidate_mm(mm);\n+    if (i != mm->map_count) {\n+        pr_emerg(\"map_count %d vma iterator %d\\n\", mm->map_count, i);\n+        bug = 1;\n+    }\n+    VM_BUG_ON_MM(bug, mm);\n+    if (bug) {\n+        pr_warn(\"Inconsistent map_count detected\\n\");\n+    }\n \treturn addr;\n \n close_and_free_vma:\n@@ -2883,6 +2939,14 @@ unsigned long mmap_region(struct file *file, unsigned long addr,\n \tif (charged)\n \t\tvm_unacct_memory(charged);\n \tvalidate_mm(mm);\n+    if (i != mm->map_count) {\n+        pr_emerg(\"map_count %d vma iterator %d\\n\", mm->map_count, i);\n+        bug = 1;\n+    }\n+    VM_BUG_ON_MM(bug, mm);\n+    if (bug) {\n+        pr_warn(\"Inconsistent map_count detected\\n\");\n+    }\n \treturn error;\n }\n \n@@ -3025,6 +3089,14 @@ int do_vma_munmap(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \tarch_unmap(mm, start, end);\n \tret = do_vmi_align_munmap(vmi, vma, mm, start, end, uf, unlock);\n \tvalidate_mm(mm);\n+    if (i != mm->map_count) {\n+        pr_emerg(\"map_count %d vma iterator %d\\n\", mm->map_count, i);\n+        bug = 1;\n+    }\n+    VM_BUG_ON_MM(bug, mm);\n+    if (bug) {\n+        pr_warn(\"Inconsistent map_count detected\\n\");\n+    }\n \treturn ret;\n }\n \n@@ -3047,6 +3119,14 @@ static int do_brk_flags(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \tstruct vma_prepare vp;\n \n \tvalidate_mm(mm);\n+    if (i != mm->map_count) {\n+        pr_emerg(\"map_count %d vma iterator %d\\n\", mm->map_count, i);\n+        bug = 1;\n+    }\n+    VM_BUG_ON_MM(bug, mm);\n+    if (bug) {\n+        pr_warn(\"Inconsistent map_count detected\\n\");\n+    }\n \t/*\n \t * Check against address space limits by the changed size\n \t * Note: This happens *after* clearing old mappings in some code paths.\n@@ -3107,6 +3187,14 @@ static int do_brk_flags(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \t\tmm->locked_vm += (len >> PAGE_SHIFT);\n \tvm_flags_set(vma, VM_SOFTDIRTY);\n \tvalidate_mm(mm);\n+    if (i != mm->map_count) {\n+        pr_emerg(\"map_count %d vma iterator %d\\n\", mm->map_count, i);\n+        bug = 1;\n+    }\n+    VM_BUG_ON_MM(bug, mm);\n+    if (bug) {\n+        pr_warn(\"Inconsistent map_count detected\\n\");\n+    }\n \treturn 0;\n \n mas_store_fail:\n@@ -3288,6 +3376,14 @@ struct vm_area_struct *copy_vma(struct vm_area_struct **vmap,\n \tVMA_ITERATOR(vmi, mm, addr);\n \n \tvalidate_mm(mm);\n+    if (i != mm->map_count) {\n+        pr_emerg(\"map_count %d vma iterator %d\\n\", mm->map_count, i);\n+        bug = 1;\n+    }\n+    VM_BUG_ON_MM(bug, mm);\n+    if (bug) {\n+        pr_warn(\"Inconsistent map_count detected\\n\");\n+    }\n \t/*\n \t * If anonymous vma has not yet been faulted, update new pgoff\n \t * to match new location, to increase its chance of merging.\n@@ -3347,6 +3443,14 @@ struct vm_area_struct *copy_vma(struct vm_area_struct **vmap,\n \t\t*need_rmap_locks = false;\n \t}\n \tvalidate_mm(mm);\n+    if (i != mm->map_count) {\n+        pr_emerg(\"map_count %d vma iterator %d\\n\", mm->map_count, i);\n+        bug = 1;\n+    }\n+    VM_BUG_ON_MM(bug, mm);\n+    if (bug) {\n+        pr_warn(\"Inconsistent map_count detected\\n\");\n+    }\n \treturn new_vma;\n \n out_vma_link:\n@@ -3363,6 +3467,14 @@ struct vm_area_struct *copy_vma(struct vm_area_struct **vmap,\n \tvm_area_free(new_vma);\n out:\n \tvalidate_mm(mm);\n+    if (i != mm->map_count) {\n+        pr_emerg(\"map_count %d vma iterator %d\\n\", mm->map_count, i);\n+        bug = 1;\n+    }\n+    VM_BUG_ON_MM(bug, mm);\n+    if (bug) {\n+        pr_warn(\"Inconsistent map_count detected\\n\");\n+    }\n \treturn NULL;\n }\n \n@@ -3500,6 +3612,14 @@ static struct vm_area_struct *__install_special_mapping(\n \tstruct vm_area_struct *vma;\n \n \tvalidate_mm(mm);\n+    if (i != mm->map_count) {\n+        pr_emerg(\"map_count %d vma iterator %d\\n\", mm->map_count, i);\n+        bug = 1;\n+    }\n+    VM_BUG_ON_MM(bug, mm);\n+    if (bug) {\n+        pr_warn(\"Inconsistent map_count detected\\n\");\n+    }\n \tvma = vm_area_alloc(mm);\n \tif (unlikely(vma == NULL))\n \t\treturn ERR_PTR(-ENOMEM);\n@@ -3523,11 +3643,27 @@ static struct vm_area_struct *__install_special_mapping(\n \tperf_event_mmap(vma);\n \n \tvalidate_mm(mm);\n+    if (i != mm->map_count) {\n+        pr_emerg(\"map_count %d vma iterator %d\\n\", mm->map_count, i);\n+        bug = 1;\n+    }\n+    VM_BUG_ON_MM(bug, mm);\n+    if (bug) {\n+        pr_warn(\"Inconsistent map_count detected\\n\");\n+    }\n \treturn vma;\n \n out:\n \tvm_area_free(vma);\n \tvalidate_mm(mm);\n+    if (i != mm->map_count) {\n+        pr_emerg(\"map_count %d vma iterator %d\\n\", mm->map_count, i);\n+        bug = 1;\n+    }\n+    VM_BUG_ON_MM(bug, mm);\n+    if (bug) {\n+        pr_warn(\"Inconsistent map_count detected\\n\");\n+    }\n \treturn ERR_PTR(ret);\n }\n \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..26e54a2b6d7e 100644\n--- a/drivers/net/wireless/virtual/mac80211_hwsim.c\n+++ b/drivers/net/wireless/virtual/mac80211_hwsim.c\n@@ -5347,6 +5347,7 @@ static int mac80211_hwsim_new_radio(struct genl_info *info,\n \tdebugfs_remove_recursive(data->debugfs);\n \tieee80211_unregister_hw(data->hw);\n failed_hw:\n+    kfree(param->pmsr_capa);\n \tdevice_release_driver(data->dev);\n failed_bind:\n \tdevice_unregister(data->dev);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/net/wireless/virtual/mac80211_hwsim.c b/drivers/net/wireless/virtual/mac80211_hwsim.c\nindex 9a8faaf4c6b6..1f144866f5b3 100644\n--- a/drivers/net/wireless/virtual/mac80211_hwsim.c\n+++ b/drivers/net/wireless/virtual/mac80211_hwsim.c\n@@ -920,14 +920,16 @@ static int hwsim_tx_virtio(struct mac80211_hwsim_data *data,\n \tspin_lock_irqsave(&hwsim_virtio_lock, flags);\n \tif (!hwsim_virtio_enabled) {\n \t\terr = -ENODEV;\n-\t\tgoto out_free;\n+\t\tkfree(pmsr_capa);\n+            goto out_free;\n \t}\n \n \tsg_init_one(sg, skb->head, skb_end_offset(skb));\n \terr = virtqueue_add_outbuf(hwsim_vqs[HWSIM_VQ_TX], sg, 1, skb,\n \t\t\t\t   GFP_ATOMIC);\n \tif (err)\n-\t\tgoto out_free;\n+\t\tkfree(pmsr_capa);\n+            goto out_free;\n \tvirtqueue_kick(hwsim_vqs[HWSIM_VQ_TX]);\n \tspin_unlock_irqrestore(&hwsim_virtio_lock, flags);\n \treturn 0;\n@@ -3406,14 +3408,16 @@ static int mac80211_hwsim_start_pmsr(struct ieee80211_hw *hw,\n \n \tif (data->pmsr_request) {\n \t\terr = -EBUSY;\n-\t\tgoto out_free;\n+\t\tkfree(pmsr_capa);\n+            goto out_free;\n \t}\n \n \tskb = genlmsg_new(GENLMSG_DEFAULT_SIZE, GFP_KERNEL);\n \n \tif (!skb) {\n \t\terr = -ENOMEM;\n-\t\tgoto out_free;\n+\t\tkfree(pmsr_capa);\n+            goto out_free;\n \t}\n \n \tmsg_head = genlmsg_put(skb, 0, 0, &hwsim_genl_family, 0, HWSIM_CMD_START_PMSR);\n@@ -3421,18 +3425,21 @@ static int mac80211_hwsim_start_pmsr(struct ieee80211_hw *hw,\n \tif (nla_put(skb, HWSIM_ATTR_ADDR_TRANSMITTER,\n \t\t    ETH_ALEN, data->addresses[1].addr)) {\n \t\terr = -ENOMEM;\n-\t\tgoto out_free;\n+\t\tkfree(pmsr_capa);\n+            goto out_free;\n \t}\n \n \tpmsr = nla_nest_start(skb, HWSIM_ATTR_PMSR_REQUEST);\n \tif (!pmsr) {\n \t\terr = -ENOMEM;\n-\t\tgoto out_free;\n+\t\tkfree(pmsr_capa);\n+            goto out_free;\n \t}\n \n \terr = mac80211_hwsim_send_pmsr_request(skb, request);\n \tif (err)\n-\t\tgoto out_free;\n+\t\tkfree(pmsr_capa);\n+            goto out_free;\n \n \tnla_nest_end(skb, pmsr);\n \n@@ -5962,11 +5969,13 @@ static int hwsim_new_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \t\tpmsr_capa = kmalloc(sizeof(*pmsr_capa), GFP_KERNEL);\n \t\tif (!pmsr_capa) {\n \t\t\tret = -ENOMEM;\n-\t\t\tgoto out_free;\n+\t\t\tkfree(pmsr_capa);\n+            goto out_free;\n \t\t}\n \t\tret = parse_pmsr_capa(info->attrs[HWSIM_ATTR_PMSR_SUPPORT], pmsr_capa, info);\n \t\tif (ret)\n-\t\t\tgoto out_free;\n+\t\t\tkfree(pmsr_capa);\n+            goto out_free;\n \t\tparam.pmsr_capa = pmsr_capa;\n \t}\n \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..89e9301335f0 100644\n--- a/drivers/net/wireless/virtual/mac80211_hwsim.c\n+++ b/drivers/net/wireless/virtual/mac80211_hwsim.c\n@@ -564,7 +564,9 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\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 +1083,15 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \n \tif (val == PS_MANUAL_POLL) {\n \t\tif (data->ps != PS_ENABLED)\n-\t\t\treturn -EINVAL;\n+\t\t\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \t\tlocal_bh_disable();\n \t\tieee80211_iterate_active_interfaces_atomic(\n \t\t\tdata->hw, IEEE80211_IFACE_ITER_NORMAL,\n@@ -1157,7 +1163,9 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \n \tdata->rx_rssi = rssi;\n \treturn 0;\n@@ -2751,12 +2759,16 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\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 +3266,9 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \n \tftm = nla_nest_start(msg, NL80211_PMSR_TYPE_FTM);\n \tif (!ftm)\n@@ -3716,7 +3730,9 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \t\t}\n \t}\n \n@@ -3731,7 +3747,9 @@ static int mac80211_hwsim_parse_pmsr_result(struct nlattr *peer,\n \tint ret;\n \n \tif (!peer)\n-\t\treturn -EINVAL;\n+\t\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\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 +3779,16 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \n \tmutex_lock(&data->mutex);\n \tif (!data->pmsr_request) {\n@@ -4948,7 +4970,9 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \n \tspin_lock_bh(&hwsim_radio_lock);\n \tidx = hwsim_radio_idx++;\n@@ -5591,7 +5615,9 @@ 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+\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \n }\n \n@@ -5706,7 +5732,9 @@ 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+\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n }\n \n static int hwsim_register_received_nl(struct sk_buff *skb_2,\n@@ -5773,7 +5801,9 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \t}\n \n \tout->ftm.supported = 1;\n@@ -5808,7 +5838,9 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \t}\n \n \tif (tb[NL80211_PMSR_ATTR_MAX_PEERS])\n@@ -5819,7 +5851,9 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \t}\n \n \tnla_for_each_nested(nla, tb[NL80211_PMSR_ATTR_TYPE_CAPA], size) {\n@@ -5829,7 +5863,9 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \t\t}\n \t}\n \n@@ -5853,7 +5889,9 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \t}\n \n \tif (info->attrs[HWSIM_ATTR_NO_VIF])\n@@ -5872,7 +5910,9 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \n \t\tidx = array_index_nospec(idx,\n \t\t\t\t\t ARRAY_SIZE(hwsim_world_regdom_custom));\n@@ -5885,7 +5925,9 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \t\t}\n \n \t\tparam.perm_addr = nla_data(info->attrs[HWSIM_ATTR_PERM_ADDR]);\n@@ -5899,7 +5941,9 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \t\t}\n \t} else {\n \t\tparam.iftypes = HWSIM_IFTYPE_SUPPORT_MASK;\n@@ -5922,7 +5966,9 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \t\t}\n \n \t\tparam.n_ciphers = len / sizeof(u32);\n@@ -5931,14 +5977,18 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \t\t}\n \t}\n \n@@ -5993,7 +6043,9 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \n \tspin_lock_bh(&hwsim_radio_lock);\n \tlist_for_each_entry(data, &hwsim_radios, list) {\n@@ -6032,7 +6084,9 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \tidx = nla_get_u32(info->attrs[HWSIM_ATTR_RADIO_ID]);\n \n \tspin_lock_bh(&hwsim_radio_lock);\n@@ -6241,7 +6295,9 @@ 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+\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n }\n \n static __net_init int hwsim_init_net(struct net *net)\n@@ -6320,7 +6376,9 @@ 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\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \n \terr = genlmsg_parse(nlh, &hwsim_genl_family, tb, HWSIM_ATTR_MAX,\n \t\t\t    hwsim_genl_policy, NULL);\n@@ -6531,10 +6589,14 @@ static int __init init_mac80211_hwsim(void)\n \tint i, err;\n \n \tif (radios < 0 || radios > 100)\n-\t\treturn -EINVAL;\n+\t\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\n \n \tif (channels < 1)\n-\t\treturn -EINVAL;\n+\t\tkfree(hwname);\n+    kfree(param.pmsr_capa);\n+    return -EINVAL;\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..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..93170837a188 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"
            }
        ]
    },
    "72c3096dbc86cdffde7afa178a39dc1a29dec67a": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/exfat/dir.c b/fs/exfat/dir.c\nindex bc48f3329921..b7eac37b3842 100644\n--- a/fs/exfat/dir.c\n+++ b/fs/exfat/dir.c\n@@ -289,7 +289,7 @@ static int exfat_iterate(struct file *file, struct dir_context *ctx)\n \tmutex_unlock(&EXFAT_SB(sb)->s_lock);\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+\t\tgoto unlock;\n \tmutex_lock(&EXFAT_SB(sb)->s_lock);\n \tctx->pos = cpos;\n \tgoto get_new;\n",
            "diff --git a/fs/exfat/dir.c b/fs/exfat/dir.c\nindex bc48f3329921..98aa86eaa072 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 s_lock before operations that might require mmap_lock\n+mutex_unlock(&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 s_lock before operations that might require mmap_lock\n+mutex_unlock(&EXFAT_SB(sb)->s_lock);\n \tctx->pos = cpos;\n \tgoto get_new;\n \n"
        ],
        "error": []
    },
    "1a351beaed9d438481f1fc96aa336a25f71a2ae1": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex fbde494444b8..a141954191cc 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -160,7 +160,11 @@ static inline int mt_alloc_bulk(gfp_t gfp, size_t size, void **nodes)\n \n static inline void mt_free_bulk(size_t size, void __rcu **nodes)\n {\n-\tkmem_cache_free_bulk(maple_node_cache, size, (void **)nodes);\n+\tfor (size_t i = 0; i < size; i++) {\n+        struct maple_node *node = (struct maple_node *)nodes[i];\n+        node->parent = node;\n+    }\n+    kmem_cache_free_bulk(maple_node_cache, size, (void **)nodes);\n }\n \n static void mt_free_rcu(struct rcu_head *head)\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex fbde494444b8..f899c7cb971d 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -1007,6 +1007,10 @@ static inline void mas_descend(struct ma_state *mas)\n \tvoid __rcu **slots;\n \n \tnode = mas_mn(mas);\n+    if (unlikely(ma_dead_node(node))) {\n+        mas_rewalk(mas, last);\n+        goto retry;\n+    }\n \ttype = mte_node_type(mas->node);\n \tpivots = ma_pivots(node, type);\n \tslots = ma_slots(node, type);\n@@ -1058,6 +1062,10 @@ static int mas_ascend(struct ma_state *mas)\n \tbool set_max = false, set_min = false;\n \n \ta_node = mas_mn(mas);\n+    if (unlikely(ma_dead_node(node))) {\n+        mas_rewalk(mas, last);\n+        goto retry;\n+    }\n \tif (ma_is_root(a_node)) {\n \t\tmas->offset = 0;\n \t\treturn 0;\n@@ -1429,6 +1437,10 @@ static inline unsigned char mas_data_end(struct ma_state *mas)\n \n \ttype = mte_node_type(mas->node);\n \tnode = mas_mn(mas);\n+    if (unlikely(ma_dead_node(node))) {\n+        mas_rewalk(mas, last);\n+        goto retry;\n+    }\n \tif (type == maple_arange_64)\n \t\treturn ma_meta_end(node, type);\n \n@@ -1569,6 +1581,10 @@ static inline unsigned long mas_max_gap(struct ma_state *mas)\n \t\treturn mas_leaf_max_gap(mas);\n \n \tnode = mas_mn(mas);\n+    if (unlikely(ma_dead_node(node))) {\n+        mas_rewalk(mas, last);\n+        goto retry;\n+    }\n \toffset = ma_meta_gap(node, mt);\n \tif (offset == MAPLE_ARANGE64_META_MAX)\n \t\treturn 0;\n@@ -1673,6 +1689,10 @@ static inline void mas_adopt_children(struct ma_state *mas,\n {\n \tenum maple_type type = mte_node_type(parent);\n \tstruct maple_node *node = mas_mn(mas);\n+    if (unlikely(ma_dead_node(node))) {\n+        mas_rewalk(mas, last);\n+        goto retry;\n+    }\n \tvoid __rcu **slots = ma_slots(node, type);\n \tunsigned long *pivots = ma_pivots(node, type);\n \tstruct maple_enode *child;\n@@ -1743,6 +1763,10 @@ static inline bool mas_new_child(struct ma_state *mas, struct ma_state *child)\n \n \tmt = mte_node_type(mas->node);\n \tnode = mas_mn(mas);\n+    if (unlikely(ma_dead_node(node))) {\n+        mas_rewalk(mas, last);\n+        goto retry;\n+    }\n \tslots = ma_slots(node, mt);\n \tpivots = ma_pivots(node, mt);\n \tend = ma_data_end(node, mt, pivots, mas->max);\n@@ -1915,6 +1939,10 @@ static inline void mas_mab_cp(struct ma_state *mas, unsigned char mas_start,\n \tunsigned char piv_end;\n \n \tnode = mas_mn(mas);\n+    if (unlikely(ma_dead_node(node))) {\n+        mas_rewalk(mas, last);\n+        goto retry;\n+    }\n \tmt = mte_node_type(mas->node);\n \tpivots = ma_pivots(node, mt);\n \tif (!i) {\n@@ -3190,6 +3218,10 @@ static inline void mas_destroy_rebalance(struct ma_state *mas, unsigned char end\n \t}\n \n \tnode = mas_mn(mas);\n+    if (unlikely(ma_dead_node(node))) {\n+        mas_rewalk(mas, last);\n+        goto retry;\n+    }\n \tnewnode->parent = node->parent;\n \tslots = ma_slots(newnode, mt);\n \tpivs = ma_pivots(newnode, mt);\n@@ -4488,6 +4520,10 @@ static inline int mas_prev_node(struct ma_state *mas, unsigned long min)\n \tlevel = 0;\n \tdo {\n \t\tnode = mas_mn(mas);\n+    if (unlikely(ma_dead_node(node))) {\n+        mas_rewalk(mas, last);\n+        goto retry;\n+    }\n \t\tif (ma_is_root(node))\n \t\t\tgoto no_entry;\n \n@@ -4501,6 +4537,10 @@ static inline int mas_prev_node(struct ma_state *mas, unsigned long min)\n \toffset--;\n \tmt = mte_node_type(mas->node);\n \tnode = mas_mn(mas);\n+    if (unlikely(ma_dead_node(node))) {\n+        mas_rewalk(mas, last);\n+        goto retry;\n+    }\n \tslots = ma_slots(node, mt);\n \tpivots = ma_pivots(node, mt);\n \tmas->max = pivots[offset];\n@@ -4521,6 +4561,10 @@ static inline int mas_prev_node(struct ma_state *mas, unsigned long min)\n \t\tmas->node = enode;\n \t\tmt = mte_node_type(mas->node);\n \t\tnode = mas_mn(mas);\n+    if (unlikely(ma_dead_node(node))) {\n+        mas_rewalk(mas, last);\n+        goto retry;\n+    }\n \t\tslots = ma_slots(node, mt);\n \t\tpivots = ma_pivots(node, mt);\n \t\toffset = ma_data_end(node, mt, pivots, mas->max);\n@@ -4593,6 +4637,10 @@ static inline int mas_next_node(struct ma_state *mas, struct maple_node *node,\n \t\toffset = mas->offset;\n \t\tlevel++;\n \t\tnode = mas_mn(mas);\n+    if (unlikely(ma_dead_node(node))) {\n+        mas_rewalk(mas, last);\n+        goto retry;\n+    }\n \t\tmt = mte_node_type(mas->node);\n \t\tpivots = ma_pivots(node, mt);\n \t} while (unlikely(offset == ma_data_end(node, mt, pivots, mas->max)));\n@@ -4608,6 +4656,10 @@ static inline int mas_next_node(struct ma_state *mas, struct maple_node *node,\n \t\tmas->node = enode;\n \t\tlevel--;\n \t\tnode = mas_mn(mas);\n+    if (unlikely(ma_dead_node(node))) {\n+        mas_rewalk(mas, last);\n+        goto retry;\n+    }\n \t\tmt = mte_node_type(mas->node);\n \t\tslots = ma_slots(node, mt);\n \t\tpivots = ma_pivots(node, mt);\n@@ -4746,6 +4798,10 @@ static inline void *mas_next_entry(struct ma_state *mas, unsigned long limit)\n \toffset = mas->offset;\n \tprev_node = mas->node;\n \tnode = mas_mn(mas);\n+    if (unlikely(ma_dead_node(node))) {\n+        mas_rewalk(mas, last);\n+        goto retry;\n+    }\n \tmt = mte_node_type(mas->node);\n \tmas->offset++;\n \tif (unlikely(mas->offset >= mt_slots[mt])) {\n@@ -4775,6 +4831,10 @@ static inline void *mas_next_entry(struct ma_state *mas, unsigned long limit)\n \t\t}\n \t\tmas->offset = 0;\n \t\tnode = mas_mn(mas);\n+    if (unlikely(ma_dead_node(node))) {\n+        mas_rewalk(mas, last);\n+        goto retry;\n+    }\n \t\tmt = mte_node_type(mas->node);\n \t}\n \n@@ -4883,6 +4943,10 @@ static bool mas_rev_awalk(struct ma_state *mas, unsigned long size)\n {\n \tenum maple_type type = mte_node_type(mas->node);\n \tstruct maple_node *node = mas_mn(mas);\n+    if (unlikely(ma_dead_node(node))) {\n+        mas_rewalk(mas, last);\n+        goto retry;\n+    }\n \tunsigned long *pivots, *gaps;\n \tvoid __rcu **slots;\n \tunsigned long gap = 0;\n@@ -5448,6 +5512,10 @@ static void __rcu **mas_dead_walk(struct ma_state *mas, unsigned char offset)\n \tdo {\n \t\tmas->node = ma_enode_ptr(next);\n \t\tnode = mas_mn(mas);\n+    if (unlikely(ma_dead_node(node))) {\n+        mas_rewalk(mas, last);\n+        goto retry;\n+    }\n \t\tslots = ma_slots(node, node->type);\n \t\tnext = mas_slot_locked(mas, slots, offset);\n \t\toffset = 0;\n@@ -5510,6 +5578,10 @@ static inline void __rcu **mas_destroy_descend(struct ma_state *mas,\n \tdo {\n \t\tmas->node = next;\n \t\tnode = mas_mn(mas);\n+    if (unlikely(ma_dead_node(node))) {\n+        mas_rewalk(mas, last);\n+        goto retry;\n+    }\n \t\tslots = ma_slots(node, mte_node_type(mas->node));\n \t\tnext = mas_slot_locked(mas, slots, 0);\n \t\tif ((mte_dead_node(next)))\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex fbde494444b8..dc3e5ea5b38a 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -4721,7 +4721,13 @@ static inline void mas_rewalk(struct ma_state *mas, unsigned long index)\n }\n \n /*\n- * mas_next_entry() - Internal function to get the next entry.\n+ * mas_next_entry\n+{\n+    if (!mas->node || mte_is_dead(mas->node)) {\n+        mas_set_err(mas, -EFAULT);\n+        return NULL;\n+    }\n+() - Internal function to get the next entry.\n  * @mas: The maple state\n  * @limit: The maximum range start.\n  *\n@@ -4732,7 +4738,13 @@ static inline void mas_rewalk(struct ma_state *mas, unsigned long index)\n  *\n  * Return: the next entry or %NULL.\n  */\n-static inline void *mas_next_entry(struct ma_state *mas, unsigned long limit)\n+static inline void *mas_next_entry\n+{\n+    if (!mas->node || mte_is_dead(mas->node)) {\n+        mas_set_err(mas, -EFAULT);\n+        return NULL;\n+    }\n+(struct ma_state *mas, unsigned long limit)\n {\n \tvoid *entry = NULL;\n \tstruct maple_enode *prev_node;\n@@ -5864,8 +5876,20 @@ void *mas_next(struct ma_state *mas, unsigned long max)\n \tif (mas->last == ULONG_MAX)\n \t\treturn NULL;\n \n-\t/* Retries on dead nodes handled by mas_next_entry */\n-\treturn mas_next_entry(mas, max);\n+\t/* Retries on dead nodes handled by mas_next_entry\n+{\n+    if (!mas->node || mte_is_dead(mas->node)) {\n+        mas_set_err(mas, -EFAULT);\n+        return NULL;\n+    }\n+ */\n+\treturn mas_next_entry\n+{\n+    if (!mas->node || mte_is_dead(mas->node)) {\n+        mas_set_err(mas, -EFAULT);\n+        return NULL;\n+    }\n+(mas, max);\n }\n EXPORT_SYMBOL_GPL(mas_next);\n \n@@ -6010,8 +6034,20 @@ void *mas_find(struct ma_state *mas, unsigned long max)\n \tif (unlikely(!mas_searchable(mas)))\n \t\treturn NULL;\n \n-\t/* Retries on dead nodes handled by mas_next_entry */\n-\treturn mas_next_entry(mas, max);\n+\t/* Retries on dead nodes handled by mas_next_entry\n+{\n+    if (!mas->node || mte_is_dead(mas->node)) {\n+        mas_set_err(mas, -EFAULT);\n+        return NULL;\n+    }\n+ */\n+\treturn mas_next_entry\n+{\n+    if (!mas->node || mte_is_dead(mas->node)) {\n+        mas_set_err(mas, -EFAULT);\n+        return NULL;\n+    }\n+(mas, max);\n }\n \n /**\n@@ -6056,7 +6092,13 @@ void *mas_find_rev(struct ma_state *mas, unsigned long min)\n \tif (mas->index < min)\n \t\treturn NULL;\n \n-\t/* Retries on dead nodes handled by mas_next_entry */\n+\t/* Retries on dead nodes handled by mas_next_entry\n+{\n+    if (!mas->node || mte_is_dead(mas->node)) {\n+        mas_set_err(mas, -EFAULT);\n+        return NULL;\n+    }\n+ */\n \treturn mas_prev_entry(mas, min);\n }\n EXPORT_SYMBOL_GPL(mas_find);\n@@ -6442,7 +6484,13 @@ void *mt_find(struct maple_tree *mt, unsigned long *index, unsigned long max)\n \t\tgoto unlock;\n \n \twhile (mas_searchable(&mas) && (mas.index < max)) {\n-\t\tentry = mas_next_entry(&mas, max);\n+\t\tentry = mas_next_entry\n+{\n+    if (!mas->node || mte_is_dead(mas->node)) {\n+        mas_set_err(mas, -EFAULT);\n+        return NULL;\n+    }\n+(&mas, max);\n \t\tif (likely(entry && !xa_is_zero(entry)))\n \t\t\tbreak;\n \t}\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex fbde494444b8..d739348464ed 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -3838,7 +3838,8 @@ static inline void *mas_state_walk(struct ma_state *mas)\n \t\treturn NULL;\n \n \tif (mas_is_ptr(mas))\n-\t\treturn entry;\n+\t\tatomic_dec(&mas->node->ref_count);\n+        return entry;\n \n \treturn mtree_range_walk(mas);\n }\n@@ -4704,7 +4705,8 @@ static inline void *mas_next_nentry(struct ma_state *mas,\n \n found:\n \tmas->last = pivot;\n-\treturn entry;\n+\tatomic_dec(&mas->node->ref_count);\n+        return entry;\n }\n \n static inline void mas_rewalk(struct ma_state *mas, unsigned long index)\n@@ -4733,6 +4735,8 @@ static inline void mas_rewalk(struct ma_state *mas, unsigned long index)\n  * Return: the next entry or %NULL.\n  */\n static inline void *mas_next_entry(struct ma_state *mas, unsigned long limit)\n+{\n+    atomic_inc(&mas->node->ref_count);\n {\n \tvoid *entry = NULL;\n \tstruct maple_enode *prev_node;\n@@ -4761,7 +4765,8 @@ static inline void *mas_next_entry(struct ma_state *mas, unsigned long limit)\n \t\t}\n \n \t\tif (likely(entry))\n-\t\t\treturn entry;\n+\t\t\tatomic_dec(&mas->node->ref_count);\n+        return entry;\n \n \t\tif (unlikely((mas->index > limit)))\n \t\t\tbreak;\n@@ -4840,7 +4845,8 @@ static inline void *mas_prev_nentry(struct ma_state *mas, unsigned long limit,\n \t\tmas->last = pivot;\n \t\tmas->index = min;\n \t}\n-\treturn entry;\n+\tatomic_dec(&mas->node->ref_count);\n+        return entry;\n }\n \n static inline void *mas_prev_entry(struct ma_state *mas, unsigned long min)\n@@ -4854,7 +4860,8 @@ static inline void *mas_prev_entry(struct ma_state *mas, unsigned long min)\n \t\t\tgoto not_found;\n \n \t\tif (likely(entry))\n-\t\t\treturn entry;\n+\t\t\tatomic_dec(&mas->node->ref_count);\n+        return entry;\n \n \t\tif (unlikely(mas_prev_node(mas, min))) {\n \t\t\tmas_rewalk(mas, mas->index);\n@@ -5055,7 +5062,8 @@ void *mas_walk(struct ma_state *mas)\n \t\t\tmas->index = 1;\n \t\t\tmas->last = ULONG_MAX;\n \t\t}\n-\t\treturn entry;\n+\t\tatomic_dec(&mas->node->ref_count);\n+        return entry;\n \t}\n \n \tif (mas_is_none(mas)) {\n@@ -5063,7 +5071,8 @@ void *mas_walk(struct ma_state *mas)\n \t\tmas->last = ULONG_MAX;\n \t}\n \n-\treturn entry;\n+\tatomic_dec(&mas->node->ref_count);\n+        return entry;\n }\n \n static inline bool mas_rewind_node(struct ma_state *mas)\n@@ -5885,7 +5894,8 @@ void *mt_next(struct maple_tree *mt, unsigned long index, unsigned long max)\n \trcu_read_lock();\n \tentry = mas_next(&mas, max);\n \trcu_read_unlock();\n-\treturn entry;\n+\tatomic_dec(&mas->node->ref_count);\n+        return entry;\n }\n EXPORT_SYMBOL_GPL(mt_next);\n \n@@ -5949,7 +5959,8 @@ void *mt_prev(struct maple_tree *mt, unsigned long index, unsigned long min)\n \trcu_read_lock();\n \tentry = mas_prev(&mas, min);\n \trcu_read_unlock();\n-\treturn entry;\n+\tatomic_dec(&mas->node->ref_count);\n+        return entry;\n }\n EXPORT_SYMBOL_GPL(mt_prev);\n \n@@ -6004,7 +6015,8 @@ void *mas_find(struct ma_state *mas, unsigned long max)\n \n \t\tentry = mas_walk(mas);\n \t\tif (entry)\n-\t\t\treturn entry;\n+\t\t\tatomic_dec(&mas->node->ref_count);\n+        return entry;\n \t}\n \n \tif (unlikely(!mas_searchable(mas)))\n@@ -6047,7 +6059,8 @@ void *mas_find_rev(struct ma_state *mas, unsigned long min)\n \n \t\tentry = mas_walk(mas);\n \t\tif (entry)\n-\t\t\treturn entry;\n+\t\t\tatomic_dec(&mas->node->ref_count);\n+        return entry;\n \t}\n \n \tif (unlikely(!mas_searchable(mas)))\n@@ -6093,7 +6106,8 @@ void *mas_erase(struct ma_state *mas)\n \tif (mas_nomem(mas, GFP_KERNEL))\n \t\tgoto write_retry;\n \n-\treturn entry;\n+\tatomic_dec(&mas->node->ref_count);\n+        return entry;\n }\n EXPORT_SYMBOL_GPL(mas_erase);\n \n@@ -6168,7 +6182,8 @@ void *mtree_load(struct maple_tree *mt, unsigned long index)\n \tif (xa_is_zero(entry))\n \t\treturn NULL;\n \n-\treturn entry;\n+\tatomic_dec(&mas->node->ref_count);\n+        return entry;\n }\n EXPORT_SYMBOL(mtree_load);\n \n@@ -6370,7 +6385,8 @@ void *mtree_erase(struct maple_tree *mt, unsigned long index)\n \tentry = mas_erase(&mas);\n \tmtree_unlock(mt);\n \n-\treturn entry;\n+\tatomic_dec(&mas->node->ref_count);\n+        return entry;\n }\n EXPORT_SYMBOL(mtree_erase);\n \n@@ -6461,7 +6477,8 @@ void *mt_find(struct maple_tree *mt, unsigned long *index, unsigned long max)\n #endif\n \t}\n \n-\treturn entry;\n+\tatomic_dec(&mas->node->ref_count);\n+        return entry;\n }\n EXPORT_SYMBOL(mt_find);\n \n@@ -6608,7 +6625,8 @@ static inline void *mas_first_entry(struct ma_state *mas, struct maple_node *mn,\n \t\tgoto none;\n \n \tif (likely(entry))\n-\t\treturn entry;\n+\t\tatomic_dec(&mas->node->ref_count);\n+        return entry;\n \n \tpivots = ma_pivots(mn, mt);\n \tmas->index = pivots[0] + 1;\n@@ -6621,7 +6639,8 @@ static inline void *mas_first_entry(struct ma_state *mas, struct maple_node *mn,\n \t\tgoto none;\n \n \tif (likely(entry))\n-\t\treturn entry;\n+\t\tatomic_dec(&mas->node->ref_count);\n+        return entry;\n \n none:\n \tif (likely(!ma_dead_node(mn)))\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex fbde494444b8..d836c45268dd 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -4780,7 +4780,8 @@ static inline void *mas_next_entry(struct ma_state *mas, unsigned long limit)\n \n \tmas->index = mas->last = limit;\n \tmas->offset = offset;\n-\tmas->node = prev_node;\n+\tif (!ma_dead_node(prev_node))\n+        mas->node = prev_node;\n \treturn NULL;\n }\n \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..c7f882f0f379 100644\n--- a/fs/btrfs/ordered-data.c\n+++ b/fs/btrfs/ordered-data.c\n@@ -310,7 +310,10 @@ static bool can_finish_ordered_extent(struct btrfs_ordered_extent *ordered,\n \tstruct btrfs_inode *inode = BTRFS_I(ordered->inode);\n \tstruct btrfs_fs_info *fs_info = inode->root->fs_info;\n \n-\tlockdep_assert_held(&inode->ordered_tree.lock);\n+\tif (!ordered || !ordered->inode) {\n+        return false;\n+    }\n+    lockdep_assert_held(&inode->ordered_tree.lock);\n \n \tif (page) {\n \t\tASSERT(page->mapping);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/btrfs/ordered-data.c b/fs/btrfs/ordered-data.c\nindex a629532283bc..ceecec802d43 100644\n--- a/fs/btrfs/ordered-data.c\n+++ b/fs/btrfs/ordered-data.c\n@@ -369,6 +369,11 @@ 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+ struct page *page, u64 file_offset, u64 len,\n+ bool uptodate) {\n+if (!ordered) {\n+return false;\n+}\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..2eca3d9c5e04 100644\n--- a/fs/btrfs/ordered-data.c\n+++ b/fs/btrfs/ordered-data.c\n@@ -369,6 +369,9 @@ 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+{\n+    if (!ordered)\n+        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..6b59a25fd0fe 100644\n--- a/fs/btrfs/ordered-data.c\n+++ b/fs/btrfs/ordered-data.c\n@@ -369,6 +369,11 @@ 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+                                      struct page *page, u64 file_offset, u64 len,\n+                                      bool uptodate) {\n+    if (!ordered || !ordered->inode) {\n+        return false; // Prevent null pointer dereference\n+    }\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..a78ed047ec19 100644\n--- a/fs/btrfs/ordered-data.c\n+++ b/fs/btrfs/ordered-data.c\n@@ -369,6 +369,11 @@ 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+ struct page *page, u64 file_offset, u64 len,\n+ bool uptodate) {\n+if (!ordered || !ordered->inode) {\n+return false;\n+}\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"
            }
        ]
    },
    "789df5b54ebd19aec0b5c3900c933d1910db8ec5": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 6bdd502527f8..a3ac20bc0835 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2716,6 +2716,10 @@ int ext4_expand_extra_isize_ea(struct inode *inode, int new_extra_isize,\n \t\tgoto cleanup;\n \n \tifree = ext4_xattr_free_space(base, &min_offs, base, &total_ino);\n+    if (min_offs <= 0) {\n+        error = -ENOSPC;\n+        goto cleanup;\n+    }\n \tif (ifree >= isize_diff)\n \t\tgoto shift;\n \n",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 6bdd502527f8..fda706a94bcd 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -1328,7 +1328,7 @@ static size_t ext4_xattr_free_space(struct ext4_xattr_entry *last,\n \t\t\t\t*min_offs = offs;\n \t\t}\n \t\tif (total)\n-\t\t\t*total += EXT4_XATTR_LEN(last->e_name_len);\n+\t\t\t*total += EXT4_XATTR_LEN(last->e_name_len) + sizeof(*last);\n \t}\n \treturn (*min_offs - ((void *)last - base) - sizeof(__u32));\n }\n@@ -2637,7 +2637,7 @@ static int ext4_xattr_make_inode_space(handle_t *handle, struct inode *inode,\n \t\t\t    (last->e_name_index == EXT4_XATTR_INDEX_SYSTEM) &&\n \t\t\t    !memcmp(last->e_name, \"data\", 4))\n \t\t\t\tcontinue;\n-\t\t\ttotal_size = EXT4_XATTR_LEN(last->e_name_len);\n+\t\t\ttotal_size = EXT4_XATTR_LEN(last->e_name_len) + sizeof(*last);\n \t\t\tif (!last->e_value_inum)\n \t\t\t\ttotal_size += EXT4_XATTR_SIZE(\n \t\t\t\t\t       le32_to_cpu(last->e_value_size));\n",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 6bdd502527f8..074f6d1eb177 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2548,7 +2548,7 @@ static int ext4_xattr_move_to_block(handle_t *handle, struct inode *inode,\n \n \tis = kzalloc(sizeof(struct ext4_xattr_ibody_find), GFP_NOFS);\n \tbs = kzalloc(sizeof(struct ext4_xattr_block_find), GFP_NOFS);\n-\tbuffer = kmalloc(value_size, GFP_NOFS);\n+\tbuffer = kmalloc(value_size ? value_size : 1, GFP_NOFS);\n \tb_entry_name = kmalloc(entry->e_name_len + 1, GFP_NOFS);\n \tif (!is || !bs || !buffer || !b_entry_name) {\n \t\terror = -ENOMEM;\n",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 6bdd502527f8..0ef290af902b 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -1330,7 +1330,7 @@ static size_t ext4_xattr_free_space(struct ext4_xattr_entry *last,\n \t\tif (total)\n \t\t\t*total += EXT4_XATTR_LEN(last->e_name_len);\n \t}\n-\treturn (*min_offs - ((void *)last - base) - sizeof(__u32));\n+\treturn max(0, *min_offs - ((void *)last - base) - sizeof(__u32));\n }\n \n /*\n"
        ],
        "error": []
    },
    "3443d3a1fa6d964dd7310a0cb1696d165a3e07c4": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/video/fbdev/core/cfbfillrect.c b/drivers/video/fbdev/core/cfbfillrect.c\nindex ba9f58b2a5e8..05f96282d8ea 100644\n--- a/drivers/video/fbdev/core/cfbfillrect.c\n+++ b/drivers/video/fbdev/core/cfbfillrect.c\n@@ -295,7 +295,8 @@ void cfb_fillrect(struct fb_info *p, const struct fb_fillrect *rect)\n \n \tpat = pixel_to_pat(bpp, fg);\n \n-\tdst = (unsigned long __iomem *)((unsigned long)p->screen_base & ~(bytes-1));\n+\tif (!p->screen_base) return;\n+dst = (unsigned long __iomem *)((unsigned long)p->screen_base & ~(bytes-1));\n \tdst_idx = ((unsigned long)p->screen_base & (bytes - 1))*8;\n \tdst_idx += rect->dy*p->fix.line_length*8+rect->dx*bpp;\n \t/* FIXME For now we support 1-32 bpp only */\n",
            "diff --git a/drivers/video/fbdev/core/cfbfillrect.c b/drivers/video/fbdev/core/cfbfillrect.c\nindex ba9f58b2a5e8..62e5cb7225a1 100644\n--- a/drivers/video/fbdev/core/cfbfillrect.c\n+++ b/drivers/video/fbdev/core/cfbfillrect.c\n@@ -60,7 +60,8 @@ bitfill_aligned(struct fb_info *p, unsigned long __iomem *dst, int dst_idx,\n \n \t\t// Main chunk\n \t\tn /= bits;\n-\t\twhile (n >= 8) {\n+\t\tif (!dst) return; // Ensure dst is valid\n+        while (n >= 8) {\n \t\t\tFB_WRITEL(pat, dst++);\n \t\t\tFB_WRITEL(pat, dst++);\n \t\t\tFB_WRITEL(pat, dst++);\n@@ -174,7 +175,8 @@ bitfill_aligned_rev(struct fb_info *p, unsigned long __iomem *dst,\n \n \t\t// Main chunk\n \t\tn /= bits;\n-\t\twhile (n >= 8) {\n+\t\tif (!dst) return; // Ensure dst is valid\n+        while (n >= 8) {\n \t\t\tFB_WRITEL(FB_READL(dst) ^ val, dst);\n \t\t\tdst++;\n \t\t\tFB_WRITEL(FB_READL(dst) ^ val, dst);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/video/fbdev/core/cfbfillrect.c b/drivers/video/fbdev/core/cfbfillrect.c\nindex ba9f58b2a5e8..7cab39b9705d 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_idx + n > MAX_ALLOWED_SIZE)\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_idx + n > MAX_ALLOWED_SIZE)\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_idx + n > MAX_ALLOWED_SIZE)\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_idx + n > MAX_ALLOWED_SIZE)\n \t\treturn;\n \n \tfirst = FB_SHIFT_HIGH(p, ~0UL, dst_idx);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "9e03d0567a2ff908a4bcf8bc378c03be4afdd75d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/rcu/tree_stall.h b/kernel/rcu/tree_stall.h\nindex 5653560573e2..e41f40959032 100644\n--- a/kernel/rcu/tree_stall.h\n+++ b/kernel/rcu/tree_stall.h\n@@ -715,7 +715,7 @@ static void check_cpu_stall(struct rcu_data *rdp)\n \t * and rcu_state.gp_start suffice to forestall false positives.\n \t */\n \tgs1 = READ_ONCE(rcu_state.gp_seq);\n-\tsmp_rmb(); /* Pick up ->gp_seq first... */\n+\tsmp_mb(); /* Ensure all prior updates are visible... */\n \tjs = READ_ONCE(rcu_state.jiffies_stall);\n \tsmp_rmb(); /* ...then ->jiffies_stall before the rest... */\n \tgps = READ_ONCE(rcu_state.gp_start);\n",
            "diff --git a/kernel/rcu/rcutorture.c b/kernel/rcu/rcutorture.c\nindex 634df26a2c27..0e16b7c7df4b 100644\n--- a/kernel/rcu/rcutorture.c\n+++ b/kernel/rcu/rcutorture.c\n@@ -108,7 +108,7 @@ torture_param(int, read_exit_delay, 13, \"Delay between read-then-exit episodes (\n torture_param(int, read_exit_burst, 16, \"# of read-then-exit bursts per episode, zero to disable\");\n torture_param(int, shuffle_interval, 3, \"Number of seconds between shuffles\");\n torture_param(int, shutdown_secs, 0, \"Shutdown time (s), <= zero to disable.\");\n-torture_param(int, stall_cpu, 0, \"Stall duration (s), zero to disable.\");\n+torture_param(int, stall_cpu, 1, \"Stall duration (s), zero to disable.\");\n torture_param(int, stall_cpu_holdoff, 10, \"Time to wait before starting stall (s).\");\n torture_param(bool, stall_no_softlockup, false, \"Avoid softlockup warning during cpu stall.\");\n torture_param(int, stall_cpu_irqsoff, 0, \"Disable interrupts while stalling.\");\n",
            "diff --git a/kernel/rcu/tree_stall.h b/kernel/rcu/tree_stall.h\nindex 5653560573e2..ba52884751b4 100644\n--- a/kernel/rcu/tree_stall.h\n+++ b/kernel/rcu/tree_stall.h\n@@ -314,7 +314,7 @@ static int rcu_print_task_stall(struct rcu_node *rnp, unsigned long flags)\n \t\tif (task_call_func(t, check_slow_task, &rscr))\n \t\t\tpr_cont(\" P%d\", t->pid);\n \t\telse\n-\t\t\tpr_cont(\" P%d/%d:%c%c%c%c\",\n+\t\t\tpr_cont(\"Task PID: %d, Nesting: %d, Blocked: %c, Need QS: %c, Exp Hint: %c, On Blocked List: %c\",\n \t\t\t\tt->pid, rscr.nesting,\n \t\t\t\t\".b\"[rscr.rs.b.blocked],\n \t\t\t\t\".q\"[rscr.rs.b.need_qs],\n",
            "diff --git a/kernel/rcu/tree_stall.h b/kernel/rcu/tree_stall.h\nindex 5653560573e2..8c15683774cf 100644\n--- a/kernel/rcu/tree_stall.h\n+++ b/kernel/rcu/tree_stall.h\n@@ -66,7 +66,7 @@ int rcu_jiffies_till_stall_check(void)\n \t\tWRITE_ONCE(rcu_cpu_stall_timeout, 3);\n \t\ttill_stall_check = 3;\n \t} else if (till_stall_check > 300) {\n-\t\tWRITE_ONCE(rcu_cpu_stall_timeout, 300);\n+\t\tWRITE_ONCE(rcu_cpu_stall_timeout, 500);\n \t\ttill_stall_check = 300;\n \t}\n \treturn till_stall_check * HZ + RCU_STALL_DELAY_DELTA;\n"
        ],
        "error": []
    },
    "30f3a18df370dd15cce6f725620ac001e57dbee1": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/hfs/bfind.c b/fs/hfs/bfind.c\nindex ef9498a6e88a..4502efa636fa 100644\n--- a/fs/hfs/bfind.c\n+++ b/fs/hfs/bfind.c\n@@ -144,7 +144,7 @@ int hfs_brec_find(struct hfs_find_data *fd)\n \t\tparent = nidx;\n \t\thfs_bnode_read(bnode, &data, fd->entryoffset, 4);\n \t\tnidx = be32_to_cpu(data);\n-\t\thfs_bnode_put(bnode);\n+\t\tif (atomic_read(&bnode->refcnt) > 0) hfs_bnode_put(bnode);\n \t}\n \tfd->bnode = bnode;\n \treturn res;\n@@ -154,7 +154,7 @@ int hfs_brec_find(struct hfs_find_data *fd)\n \t       height, bnode->height, bnode->type, nidx, parent);\n \tres = -EIO;\n release:\n-\thfs_bnode_put(bnode);\n+\tif (atomic_read(&bnode->refcnt) > 0) hfs_bnode_put(bnode);\n \treturn res;\n }\n \n@@ -191,7 +191,7 @@ int hfs_brec_goto(struct hfs_find_data *fd, int cnt)\n \t\t\t\tres = -ENOENT;\n \t\t\t\tgoto out;\n \t\t\t}\n-\t\t\thfs_bnode_put(bnode);\n+\t\t\tif (atomic_read(&bnode->refcnt) > 0) hfs_bnode_put(bnode);\n \t\t\tbnode = hfs_bnode_find(tree, idx);\n \t\t\tif (IS_ERR(bnode)) {\n \t\t\t\tres = PTR_ERR(bnode);\n@@ -209,7 +209,7 @@ int hfs_brec_goto(struct hfs_find_data *fd, int cnt)\n \t\t\t\tres = -ENOENT;\n \t\t\t\tgoto out;\n \t\t\t}\n-\t\t\thfs_bnode_put(bnode);\n+\t\t\tif (atomic_read(&bnode->refcnt) > 0) hfs_bnode_put(bnode);\n \t\t\tbnode = hfs_bnode_find(tree, idx);\n \t\t\tif (IS_ERR(bnode)) {\n \t\t\t\tres = PTR_ERR(bnode);\n",
            "diff --git a/fs/hfs/brec.c b/fs/hfs/brec.c\nindex 896396554bcc..ebdd5c07390d 100644\n--- a/fs/hfs/brec.c\n+++ b/fs/hfs/brec.c\n@@ -200,7 +200,7 @@ int hfs_brec_remove(struct hfs_find_data *fd)\n \t\tparent = hfs_bnode_find(tree, node->parent);\n \t\tif (IS_ERR(parent))\n \t\t\treturn PTR_ERR(parent);\n-\t\thfs_bnode_put(node);\n+\t\tif (atomic_read(&node->refcnt) > 1) hfs_bnode_put(node); else atomic_set(&node->refcnt, 1);\n \t\tnode = fd->bnode = parent;\n \n \t\t__hfs_brec_find(node, fd);\n@@ -256,7 +256,7 @@ 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) > 1) hfs_bnode_put(node); else atomic_set(&node->refcnt, 1);\n \t\thfs_bnode_put(new_node);\n \t\treturn next_node;\n \t}\n@@ -272,7 +272,7 @@ 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) > 1) hfs_bnode_put(node); else atomic_set(&node->refcnt, 1);\n \t\thfs_bnode_put(new_node);\n \t\tif (next_node)\n \t\t\thfs_bnode_put(next_node);\n@@ -287,7 +287,7 @@ 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) > 1) hfs_bnode_put(node); else atomic_set(&node->refcnt, 1);\n \t\thfs_bnode_get(new_node);\n \t\tfd->bnode = new_node;\n \t\tfd->record -= num_recs;\n@@ -344,7 +344,7 @@ 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) > 1) hfs_bnode_put(node); else atomic_set(&node->refcnt, 1);\n \n \treturn new_node;\n }\n@@ -419,7 +419,7 @@ 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) > 1) hfs_bnode_put(node); else atomic_set(&node->refcnt, 1);\n \tnode = parent;\n \n \tif (new_node) {\n@@ -470,7 +470,7 @@ 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) > 1) hfs_bnode_put(node); else atomic_set(&node->refcnt, 1);\n \t\treturn PTR_ERR(new_node);\n \t}\n \n@@ -520,7 +520,7 @@ 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) > 1) hfs_bnode_put(node); else atomic_set(&node->refcnt, 1);\n \t}\n \thfs_bnode_put(new_node);\n \tmark_inode_dirty(tree->inode);\n"
        ],
        "error": []
    },
    "d1975758ab72f25acdc552246472398abe66c7fd": {
        "non_crash": [
            "diff --git a/drivers/iommu/iommufd/selftest.c b/drivers/iommu/iommufd/selftest.c\nindex 74c2076105d4..d958ed2cd20e 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(\"Unexpected number of pages: %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",
            "diff --git a/drivers/iommu/iommufd/selftest.c b/drivers/iommu/iommufd/selftest.c\nindex 74c2076105d4..995a6a39712c 100644\n--- a/drivers/iommu/iommufd/selftest.c\n+++ b/drivers/iommu/iommufd/selftest.c\n@@ -756,7 +756,8 @@ 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 (!access_ok(uptr, PAGE_SIZE)) return -EFAULT;\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..b8312165afea 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_warn(\"Expected 1 page, but got %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..e828bd3146ef 100644\n--- a/drivers/iommu/iommufd/selftest.c\n+++ b/drivers/iommu/iommufd/selftest.c\n@@ -756,7 +756,8 @@ 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 (!uptr) 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"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/iommu/iommufd/selftest.c b/drivers/iommu/iommufd/selftest.c\nindex 74c2076105d4..8482480fb121 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\trc = if (!access_ok(uptr, PAGE_SIZE))\n+            return -EFAULT;\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",
                "error_message": "Failed to build"
            }
        ]
    },
    "e90732b9b16086b7f6207149157d36c0faea59f1": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/crypto/api.c b/crypto/api.c\nindex 64f2d365a8e9..560b20e29788 100644\n--- a/crypto/api.c\n+++ b/crypto/api.c\n@@ -502,6 +502,8 @@ void *crypto_create_tfm_node(struct crypto_alg *alg,\n \ttotal = tfmsize + sizeof(*tfm) + frontend->extsize(alg);\n \n \tmem = kzalloc_node(total, GFP_KERNEL, node);\n+    if (!mem)\n+        return ERR_PTR(-ENOMEM);\n \tif (mem == NULL)\n \t\tgoto out_err;\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/crypto/acompress.c b/crypto/acompress.c\nindex c32c72048a1c..81536c9e6b7c 100644\n--- a/crypto/acompress.c\n+++ b/crypto/acompress.c\n@@ -193,6 +193,11 @@ void crypto_unregister_acomps(struct acomp_alg *algs, int count)\n \t\tcrypto_unregister_acomp(&algs[i]);\n }\n EXPORT_SYMBOL_GPL(crypto_unregister_acomps);\n+void crypto_free_acomp(struct crypto_acomp *acomp)\n+{\n+    crypto_destroy_tfm(crypto_acomp_tfm(acomp));\n+}\n+EXPORT_SYMBOL_GPL(crypto_free_acomp);\n \n MODULE_LICENSE(\"GPL\");\n MODULE_DESCRIPTION(\"Asynchronous compression type\");\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "67d5dc5f84651b05fc3c2cb3d163037f414a10f4": {
        "non_crash": [
            "diff --git a/net/qrtr/tun.c b/net/qrtr/tun.c\nindex 15ce9b642b25..cac1c1019fd0 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_BUFFER_SIZE 4096\n \n struct qrtr_tun {\n \tstruct qrtr_endpoint ep;\n@@ -80,7 +81,9 @@ 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_BUFFER_SIZE) return -EINVAL;\n+\n+    kbuf = kzalloc(len, GFP_KERNEL);\n \tif (!kbuf)\n \t\treturn -ENOMEM;\n \n",
            "diff --git a/net/qrtr/tun.c b/net/qrtr/tun.c\nindex 15ce9b642b25..d7e54d875902 100644\n--- a/net/qrtr/tun.c\n+++ b/net/qrtr/tun.c\n@@ -9,6 +9,7 @@\n \n #include \"qrtr.h\"\n \n+#define MAX_ALLOWED_LEN 4096\n struct qrtr_tun {\n \tstruct qrtr_endpoint ep;\n \n@@ -80,7 +81,10 @@ 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_LEN)\n+        return -EINVAL;\n+\n+    kbuf = kzalloc(len, GFP_KERNEL);\n \tif (!kbuf)\n \t\treturn -ENOMEM;\n \n",
            "diff --git a/net/qrtr/tun.c b/net/qrtr/tun.c\nindex 15ce9b642b25..0401a5b15a43 100644\n--- a/net/qrtr/tun.c\n+++ b/net/qrtr/tun.c\n@@ -77,6 +77,8 @@ static ssize_t qrtr_tun_write_iter(struct kiocb *iocb, struct iov_iter *from)\n \tstruct file *filp = iocb->ki_filp;\n \tstruct qrtr_tun *tun = filp->private_data;\n \tsize_t len = iov_iter_count(from);\n+    size_t max_len = 4096; // Define a reasonable maximum size for allocation\n+    len = min(len, max_len);\n \tssize_t ret;\n \tvoid *kbuf;\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"
        ],
        "error": [
            {
                "patch": "diff --git a/net/qrtr/tun.c b/net/qrtr/tun.c\nindex 15ce9b642b25..197f50530921 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(min(len, MAX_ALLOC_SIZE), GFP_KERNEL);\n \tif (!kbuf)\n \t\treturn -ENOMEM;\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "5c8b4f0ea10c23945625f4187bac8e6e471d732c": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/util.c b/mm/util.c\nindex 7e43369064c8..91809235e18a 100644\n--- a/mm/util.c\n+++ b/mm/util.c\n@@ -734,7 +734,8 @@ int __page_mapcount(struct page *page)\n \t\treturn ret;\n \tpage = compound_head(page);\n \tret += atomic_read(compound_mapcount_ptr(page)) + 1;\n-\tif (PageDoubleMap(page))\n+\t/* Validate page state before checking double map */\n+    if (!PageHead(page) && PageDoubleMap(page))\n \t\tret--;\n \treturn ret;\n }\n",
            "diff --git a/mm/rmap.c b/mm/rmap.c\nindex 6a1e8c7f6213..4c1ad87187bd 100644\n--- a/mm/rmap.c\n+++ b/mm/rmap.c\n@@ -1264,7 +1264,9 @@ void page_add_file_rmap(struct page *page, bool compound)\n \n \t\t\tVM_WARN_ON_ONCE(!PageLocked(page));\n \n-\t\t\tSetPageDoubleMap(head);\n+\t\t\tlock_page(head);\n+            SetPageDoubleMap(head);\n+            unlock_page(head);\n \t\t\tif (PageMlocked(page))\n \t\t\t\tclear_page_mlock(head);\n \t\t}\n",
            "diff --git a/mm/util.c b/mm/util.c\nindex 7e43369064c8..aab08094603a 100644\n--- a/mm/util.c\n+++ b/mm/util.c\n@@ -734,7 +734,7 @@ int __page_mapcount(struct page *page)\n \t\treturn ret;\n \tpage = compound_head(page);\n \tret += atomic_read(compound_mapcount_ptr(page)) + 1;\n-\tif (PageDoubleMap(page))\n+\tif (PageDoubleMap(page) && PageCompound(page))\n \t\tret--;\n \treturn ret;\n }\n"
        ],
        "error": []
    },
    "12be9aa373be9d8727cdd172f190de39528a413a": {
        "non_crash": [
            "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..5987ca2b5a97 100644\n--- a/security/selinux/hooks.c\n+++ b/security/selinux/hooks.c\n@@ -4838,7 +4838,8 @@ static int selinux_socket_sendmsg(struct socket *sock, struct msghdr *msg,\n static int selinux_socket_recvmsg(struct socket *sock, struct msghdr *msg,\n \t\t\t\t  int size, int flags)\n {\n-\treturn sock_has_perm(sock->sk, SOCKET__READ);\n+\tif (!sock) 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..7eedd824fe57 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"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/security/selinux/hooks.c b/security/selinux/hooks.c\nindex 4c037c2545c1..5849a89f52a2 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->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..5849a89f52a2 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->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"
        ],
        "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..0c79ca160f2f 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -2542,6 +2542,8 @@ 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)\n+        return -EFAULT;\n \n \tif (fileio) {\n \t\tvb2_core_streamoff(q, q->type);\n@@ -2595,6 +2597,8 @@ 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)\n+        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..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..815b2ee1651f 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -2595,6 +2595,8 @@ 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)\n+        return -EINVAL;\n \n \t/*\n \t * Check if we need to dequeue the buffer.\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex b98ec6e1a222..6ef35a1c2902 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 (!fileio || index >= q->num_buffers) {\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 (!fileio || index >= q->num_buffers) {\n \t\tstruct vb2_buffer *b;\n \n \t\t/*\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex b98ec6e1a222..1c3f577f41d3 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -2541,7 +2541,12 @@ static int __vb2_init_fileio(struct vb2_queue *q, int read)\n  */\n static int __vb2_cleanup_fileio(struct vb2_queue *q)\n {\n-\tstruct vb2_fileio_data *fileio = q->fileio;\n+\tstruct vb2_fileio_data *if (!q->fileio) {\n+        ret = __vb2_init_fileio(q, read);\n+        if (ret)\n+            return ret;\n+    }\n+    fileio = q->fileio;\n \n \tif (fileio) {\n \t\tvb2_core_streamoff(q, q->type);\n@@ -2594,7 +2599,12 @@ 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) {\n+        ret = __vb2_init_fileio(q, read);\n+        if (ret)\n+            return ret;\n+    }\n+    fileio = q->fileio;\n \n \t/*\n \t * Check if we need to dequeue the buffer.\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "6fe3c93209dfd48301d1cad0ab1efd53c87462e1": {
        "non_crash": [
            "diff --git a/kernel/module/main.c b/kernel/module/main.c\nindex 834de86ebe35..7b60cf7d0e8f 100644\n--- a/kernel/module/main.c\n+++ b/kernel/module/main.c\n@@ -3118,6 +3118,11 @@ static int init_module_from_file(struct file *f, const char __user * uargs, int\n \tvoid *buf = NULL;\n \tint len, ret;\n \n+    /* Validate buffer before use */\n+    if (!buf) {\n+        return -ENOMEM; /* Return error if buffer is not allocated */\n+    }\n+\n \tif (!f || !(f->f_mode & FMODE_READ))\n \t\treturn -EBADF;\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/module/main.c b/kernel/module/main.c\nindex 834de86ebe35..92a9d3dc1e50 100644\n--- a/kernel/module/main.c\n+++ b/kernel/module/main.c\n@@ -2838,6 +2838,7 @@ static int load_module(struct load_info *info, const char __user *uargs,\n \t * checks against info->len more correct.\n \t */\n \terr = module_sig_check(info, flags);\n+    if (!access_ok(info->hdr, info->len)) return -EFAULT;\n \tif (err)\n \t\tgoto free_copy;\n \n",
            "diff --git a/kernel/module/main.c b/kernel/module/main.c\nindex 834de86ebe35..bfdb826db1fe 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 (!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..65914690173a 100644\n--- a/kernel/module/main.c\n+++ b/kernel/module/main.c\n@@ -2818,6 +2818,8 @@ static int early_mod_check(struct load_info *info, int flags)\n  * zero, and we rely on this for optional sections.\n  */\n static int load_module(struct load_info *info, const char __user *uargs,\n+{\n+    if (!access_ok(uargs, sizeof(uargs))) return -EFAULT;\n \t\t       int flags)\n {\n \tstruct module *mod;\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..6bbb064a48df 100644\n--- a/net/nfc/nci/core.c\n+++ b/net/nfc/nci/core.c\n@@ -542,7 +542,11 @@ 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+\n+ndev->ops->close(ndev);\n+\n+mutex_lock(&ndev->req_lock);\n \t\tndev->flags = 0;\n \t}\n \n@@ -590,7 +594,11 @@ 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+\n+ndev->ops->close(ndev);\n+\n+mutex_lock(&ndev->req_lock);\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..2c1af4f53fa2 100644\n--- a/net/nfc/nci/core.c\n+++ b/net/nfc/nci/core.c\n@@ -560,6 +560,9 @@ 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 prevent deadlock */\n+    mutex_unlock(&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"
        ],
        "error": [
            {
                "patch": "diff --git a/net/nfc/nci/core.c b/net/nfc/nci/core.c\nindex dbe5258e13ff..63cfea5df796 100644\n--- a/net/nfc/nci/core.c\n+++ b/net/nfc/nci/core.c\n@@ -147,6 +147,11 @@ inline int nci_request(struct nci_dev *ndev,\n \n \t/* Serialize all requests */\n \tmutex_lock(&ndev->req_lock);\n+\n+    /* Unlock req_lock before calling close to prevent deadlock */\n+    mutex_unlock(&ndev->req_lock);\n+    ndev->ops->close(ndev);\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 +482,11 @@ static int nci_open_device(struct nci_dev *ndev)\n \n \tmutex_lock(&ndev->req_lock);\n \n+    /* Unlock req_lock before calling close to prevent deadlock */\n+    mutex_unlock(&ndev->req_lock);\n+    ndev->ops->close(ndev);\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 +570,11 @@ static int nci_close_device(struct nci_dev *ndev)\n \t */\n \tmutex_lock(&ndev->req_lock);\n \n+    /* Unlock req_lock before calling close to prevent deadlock */\n+    mutex_unlock(&ndev->req_lock);\n+    ndev->ops->close(ndev);\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 +1300,11 @@ 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+    /* Unlock req_lock before calling close to prevent deadlock */\n+    mutex_unlock(&ndev->req_lock);\n+    ndev->ops->close(ndev);\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"
            },
            {
                "patch": "diff --git a/net/nfc/nci/core.c b/net/nfc/nci/core.c\nindex dbe5258e13ff..4c1abf34bfe5 100644\n--- a/net/nfc/nci/core.c\n+++ b/net/nfc/nci/core.c\n@@ -558,7 +558,8 @@ static int nci_close_device(struct nci_dev *ndev)\n \t/* This mutex needs to be held as a barrier for\n \t * caller nci_unregister_device\n \t */\n-\tmutex_lock(&ndev->req_lock);\n+\tmutex_lock(&nci_mutex);\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",
                "error_message": "Failed to build"
            }
        ]
    },
    "0cd33d8e114be941da0773f8980488e1ca71ed58": {
        "non_crash": [
            "diff --git a/net/rxrpc/recvmsg.c b/net/rxrpc/recvmsg.c\nindex eaf19ebaa964..64ce7a3d4748 100644\n--- a/net/rxrpc/recvmsg.c\n+++ b/net/rxrpc/recvmsg.c\n@@ -447,12 +447,16 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \n try_again:\n \tlock_sock(&rx->sk);\n+    bool sock_locked = 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 (sock_locked) {\n+    release_sock(&rx->sk);\n+    sock_locked = false;\n+}\n \t\treturn -ENODATA;\n \t}\n \n@@ -463,7 +467,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 (sock_locked) {\n+    release_sock(&rx->sk);\n+    sock_locked = 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 +516,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 (sock_locked) {\n+    release_sock(&rx->sk);\n+    sock_locked = false;\n+}\n \n \tif (test_bit(RXRPC_CALL_RELEASED, &call->flags))\n \t\tBUG();\n@@ -595,7 +605,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 (sock_locked) {\n+    release_sock(&rx->sk);\n+    sock_locked = false;\n+}\n \ttrace_rxrpc_recvmsg(call, rxrpc_recvmsg_return, 0, 0, 0, ret);\n \treturn ret;\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/rxrpc/recvmsg.c b/net/rxrpc/recvmsg.c\nindex eaf19ebaa964..acaad2298ca9 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 (sock_owned_by_user(&rx->sk))\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 (sock_owned_by_user(&rx->sk))\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 (sock_owned_by_user(&rx->sk))\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 (sock_owned_by_user(&rx->sk))\n+    release_sock(&rx->sk);\n \ttrace_rxrpc_recvmsg(call, rxrpc_recvmsg_return, 0, 0, 0, ret);\n \treturn ret;\n \n",
            "diff --git a/net/rxrpc/recvmsg.c b/net/rxrpc/recvmsg.c\nindex eaf19ebaa964..e960dffa7641 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 (sock_owned_by_user(&rx->sk))\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 (sock_owned_by_user(&rx->sk))\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 (sock_owned_by_user(&rx->sk))\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 (sock_owned_by_user(&rx->sk))\n+        release_sock(&rx->sk);\n \ttrace_rxrpc_recvmsg(call, rxrpc_recvmsg_return, 0, 0, 0, ret);\n \treturn ret;\n \n",
            "diff --git a/net/rxrpc/recvmsg.c b/net/rxrpc/recvmsg.c\nindex eaf19ebaa964..6623b7e81f67 100644\n--- a/net/rxrpc/recvmsg.c\n+++ b/net/rxrpc/recvmsg.c\n@@ -460,7 +460,8 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \t\tret = -EWOULDBLOCK;\n \t\tif (timeo == 0) {\n \t\t\tcall = NULL;\n-\t\t\tgoto error_no_call;\n+\t\t\trelease_sock(&rx->sk);\n+goto error_no_call;\n \t\t}\n \n \t\trelease_sock(&rx->sk);\n@@ -604,7 +605,8 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n wait_error:\n \tfinish_wait(sk_sleep(&rx->sk), &wait);\n \tcall = NULL;\n-\tgoto error_no_call;\n+\trelease_sock(&rx->sk);\n+goto error_no_call;\n }\n \n /**\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/rxrpc/recvmsg.c b/net/rxrpc/recvmsg.c\nindex eaf19ebaa964..139cbfae8d7b 100644\n--- a/net/rxrpc/recvmsg.c\n+++ b/net/rxrpc/recvmsg.c\n@@ -452,7 +452,7 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \tif (RB_EMPTY_ROOT(&rx->calls) &&\n \t    list_empty(&rx->recvmsg_q) &&\n \t    rx->sk.sk_state != RXRPC_SERVER_LISTENING) {\n-\t\trelease_sock(&rx->sk);\n+\t\tif (lock_sock_held(&rx->sk)) release_sock(&rx->sk);\n \t\treturn -ENODATA;\n \t}\n \n@@ -463,7 +463,7 @@ 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_sock_held(&rx->sk)) 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 +509,7 @@ 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_sock_held(&rx->sk)) release_sock(&rx->sk);\n \n \tif (test_bit(RXRPC_CALL_RELEASED, &call->flags))\n \t\tBUG();\n@@ -595,7 +595,7 @@ 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_sock_held(&rx->sk)) 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"
            }
        ]
    },
    "f07cf3e7df6d272b92ccdabfeef07ae06c014ca5": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/namei.c b/fs/ext4/namei.c\nindex e8f429330f3c..636ea3eb5577 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\t/* Delayed inode lock to prevent deadlock */\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"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/namei.c b/fs/ext4/namei.c\nindex e8f429330f3c..16ceddc6269c 100644\n--- a/fs/ext4/namei.c\n+++ b/fs/ext4/namei.c\n@@ -2818,7 +2818,8 @@ static int ext4_create(struct user_namespace *mnt_userns, struct inode *dir,\n \t\t\text4_fc_track_create(handle, dentry);\n \t}\n \tif (handle)\n-\t\text4_journal_stop(handle);\n+\t\tinode_unlock(old.inode);\n+    ext4_journal_stop(handle);\n \tif (!IS_ERR_OR_NULL(inode))\n \t\tiput(inode);\n \tif (err == -ENOSPC && ext4_should_retry_alloc(dir->i_sb, &retries))\n@@ -2852,7 +2853,8 @@ static int ext4_mknod(struct user_namespace *mnt_userns, struct inode *dir,\n \t\t\text4_fc_track_create(handle, dentry);\n \t}\n \tif (handle)\n-\t\text4_journal_stop(handle);\n+\t\tinode_unlock(old.inode);\n+    ext4_journal_stop(handle);\n \tif (!IS_ERR_OR_NULL(inode))\n \t\tiput(inode);\n \tif (err == -ENOSPC && ext4_should_retry_alloc(dir->i_sb, &retries))\n@@ -2891,12 +2893,14 @@ static int ext4_tmpfile(struct user_namespace *mnt_userns, struct inode *dir,\n \t\tunlock_new_inode(inode);\n \t}\n \tif (handle)\n-\t\text4_journal_stop(handle);\n+\t\tinode_unlock(old.inode);\n+    ext4_journal_stop(handle);\n \tif (err == -ENOSPC && ext4_should_retry_alloc(dir->i_sb, &retries))\n \t\tgoto retry;\n \treturn finish_open_simple(file, err);\n err_unlock_inode:\n-\text4_journal_stop(handle);\n+\tinode_unlock(old.inode);\n+    ext4_journal_stop(handle);\n \tunlock_new_inode(inode);\n \treturn err;\n }\n@@ -3012,7 +3016,8 @@ static int ext4_mkdir(struct user_namespace *mnt_userns, struct inode *dir,\n \t\terr2 = ext4_mark_inode_dirty(handle, inode);\n \t\tif (unlikely(err2))\n \t\t\terr = err2;\n-\t\text4_journal_stop(handle);\n+\t\tinode_unlock(old.inode);\n+    ext4_journal_stop(handle);\n \t\tiput(inode);\n \t\tgoto out_retry;\n \t}\n@@ -3029,7 +3034,8 @@ static int ext4_mkdir(struct user_namespace *mnt_userns, struct inode *dir,\n \n out_stop:\n \tif (handle)\n-\t\text4_journal_stop(handle);\n+\t\tinode_unlock(old.inode);\n+    ext4_journal_stop(handle);\n out_retry:\n \tif (err == -ENOSPC && ext4_should_retry_alloc(dir->i_sb, &retries))\n \t\tgoto retry;\n@@ -3199,7 +3205,8 @@ static int ext4_rmdir(struct inode *dir, struct dentry *dentry)\n end_rmdir:\n \tbrelse(bh);\n \tif (handle)\n-\t\text4_journal_stop(handle);\n+\t\tinode_unlock(old.inode);\n+    ext4_journal_stop(handle);\n \treturn retval;\n }\n \n@@ -3270,7 +3277,8 @@ int __ext4_unlink(struct inode *dir, const struct qstr *d_name,\n \tif (dentry && !retval)\n \t\text4_fc_track_unlink(handle, dentry);\n out_handle:\n-\text4_journal_stop(handle);\n+\tinode_unlock(old.inode);\n+    ext4_journal_stop(handle);\n out_bh:\n \tbrelse(bh);\n \treturn retval;\n@@ -3375,7 +3383,8 @@ static int ext4_symlink(struct user_namespace *mnt_userns, struct inode *dir,\n \thandle = ext4_journal_current_handle();\n \tif (IS_ERR(inode)) {\n \t\tif (handle)\n-\t\t\text4_journal_stop(handle);\n+\t\t\tinode_unlock(old.inode);\n+    ext4_journal_stop(handle);\n \t\terr = PTR_ERR(inode);\n \t\tgoto out_retry;\n \t}\n@@ -3409,7 +3418,8 @@ static int ext4_symlink(struct user_namespace *mnt_userns, struct inode *dir,\n \t}\n \terr = ext4_add_nondir(handle, dentry, &inode);\n \tif (handle)\n-\t\text4_journal_stop(handle);\n+\t\tinode_unlock(old.inode);\n+    ext4_journal_stop(handle);\n \tiput(inode);\n \tgoto out_retry;\n \n@@ -3418,7 +3428,8 @@ static int ext4_symlink(struct user_namespace *mnt_userns, struct inode *dir,\n \text4_orphan_add(handle, inode);\n \tunlock_new_inode(inode);\n \tif (handle)\n-\t\text4_journal_stop(handle);\n+\t\tinode_unlock(old.inode);\n+    ext4_journal_stop(handle);\n \tiput(inode);\n out_retry:\n \tif (err == -ENOSPC && ext4_should_retry_alloc(dir->i_sb, &retries))\n@@ -3460,7 +3471,8 @@ int __ext4_link(struct inode *dir, struct inode *inode, struct dentry *dentry)\n \t\tdrop_nlink(inode);\n \t\tiput(inode);\n \t}\n-\text4_journal_stop(handle);\n+\tinode_unlock(old.inode);\n+    ext4_journal_stop(handle);\n \tif (err == -ENOSPC && ext4_should_retry_alloc(dir->i_sb, &retries))\n \t\tgoto retry;\n \treturn err;\n@@ -3743,7 +3755,8 @@ static struct inode *ext4_whiteout_for_rename(struct user_namespace *mnt_userns,\n \thandle = ext4_journal_current_handle();\n \tif (IS_ERR(wh)) {\n \t\tif (handle)\n-\t\t\text4_journal_stop(handle);\n+\t\t\tinode_unlock(old.inode);\n+    ext4_journal_stop(handle);\n \t\tif (PTR_ERR(wh) == -ENOSPC &&\n \t\t    ext4_should_retry_alloc(ent->dir->i_sb, &retries))\n \t\t\tgoto retry;\n@@ -4009,10 +4022,12 @@ static int ext4_rename(struct user_namespace *mnt_userns, struct inode *old_dir,\n \t\t\text4_orphan_add(handle, whiteout);\n \t\t}\n \t\tunlock_new_inode(whiteout);\n-\t\text4_journal_stop(handle);\n+\t\tinode_unlock(old.inode);\n+    ext4_journal_stop(handle);\n \t\tiput(whiteout);\n \t} else {\n-\t\text4_journal_stop(handle);\n+\t\tinode_unlock(old.inode);\n+    ext4_journal_stop(handle);\n \t}\n \tif (old.dir_bh)\n \t\tinode_unlock(old.inode);\n@@ -4164,7 +4179,8 @@ static int ext4_cross_rename(struct inode *old_dir, struct dentry *old_dentry,\n \tbrelse(old.bh);\n \tbrelse(new.bh);\n \tif (handle)\n-\t\text4_journal_stop(handle);\n+\t\tinode_unlock(old.inode);\n+    ext4_journal_stop(handle);\n \treturn retval;\n }\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/ext4/namei.c b/fs/ext4/namei.c\nindex e8f429330f3c..da2219d5acf6 100644\n--- a/fs/ext4/namei.c\n+++ b/fs/ext4/namei.c\n@@ -3846,7 +3846,9 @@ static int ext4_rename(struct user_namespace *mnt_userns, struct inode *old_dir,\n \tcredits = (2 * EXT4_DATA_TRANS_BLOCKS(old.dir->i_sb) +\n \t\t   EXT4_INDEX_EXTRA_TRANS_BLOCKS + 2);\n \tif (!(flags & RENAME_WHITEOUT)) {\n-\t\thandle = ext4_journal_start(old.dir, EXT4_HT_DIR, credits);\n+\t\thandle = inode_unlock(old.inode);\n+inode_unlock(new.inode);\n+handle = ext4_journal_start(old.dir, EXT4_HT_DIR, credits);\n \t\tif (IS_ERR(handle)) {\n \t\t\tretval = PTR_ERR(handle);\n \t\t\tgoto release_bh;\n@@ -4082,7 +4084,9 @@ static int ext4_cross_rename(struct inode *old_dir, struct dentry *old_dentry,\n \tif (!new.bh || le32_to_cpu(new.de->inode) != new.inode->i_ino)\n \t\tgoto end_rename;\n \n-\thandle = ext4_journal_start(old.dir, EXT4_HT_DIR,\n+\thandle = inode_unlock(old.inode);\n+inode_unlock(new.inode);\n+handle = ext4_journal_start(old.dir, EXT4_HT_DIR,\n \t\t(2 * EXT4_DATA_TRANS_BLOCKS(old.dir->i_sb) +\n \t\t 2 * EXT4_INDEX_EXTRA_TRANS_BLOCKS + 2));\n \tif (IS_ERR(handle)) {\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/ext4/namei.c b/fs/ext4/namei.c\nindex e8f429330f3c..8c4c7fbbd913 100644\n--- a/fs/ext4/namei.c\n+++ b/fs/ext4/namei.c\n@@ -3878,6 +3878,7 @@ static int ext4_rename(struct user_namespace *mnt_userns, struct inode *old_dir,\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+    jbd2_handle_lock_nested(journal, JBD2_HANDLE_NONDIR2);\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"
            }
        ]
    },
    "8dc7a6aed7b8ead4c982ecdf2cd1ea5a4c3b57bb": {
        "non_crash": [
            "diff --git a/fs/inode.c b/fs/inode.c\nindex b608528efd3a..55e7d5017b35 100644\n--- a/fs/inode.c\n+++ b/fs/inode.c\n@@ -2006,11 +2006,14 @@ static int __remove_privs(struct user_namespace *mnt_userns,\n \tstruct iattr newattrs;\n \n \tnewattrs.ia_valid = ATTR_FORCE | kill;\n+    inode_lock(d_inode(dentry));\n \t/*\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+\tint ret = notify_change(mnt_userns, dentry, &newattrs, NULL);\n+    inode_unlock(d_inode(dentry));\n+    return ret;\n }\n \n static int __file_remove_privs(struct file *file, unsigned int flags)\n",
            "diff --git a/fs/inode.c b/fs/inode.c\nindex b608528efd3a..2e55ef15066c 100644\n--- a/fs/inode.c\n+++ b/fs/inode.c\n@@ -2006,11 +2006,14 @@ static int __remove_privs(struct user_namespace *mnt_userns,\n \tstruct iattr newattrs;\n \n \tnewattrs.ia_valid = ATTR_FORCE | kill;\n+inode_lock(d_inode(dentry));\n \t/*\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+\tint ret = notify_change(mnt_userns, dentry, &newattrs, NULL);\n+inode_unlock(d_inode(dentry));\n+return ret;\n }\n \n static int __file_remove_privs(struct file *file, unsigned int flags)\n",
            "diff --git a/fs/inode.c b/fs/inode.c\nindex b608528efd3a..3dfb68f0f2f5 100644\n--- a/fs/inode.c\n+++ b/fs/inode.c\n@@ -2028,11 +2028,12 @@ static int __file_remove_privs(struct file *file, unsigned int flags)\n \t\treturn kill;\n \n \tif (kill) {\n+inode_lock(inode);\n \t\tif (flags & IOCB_NOWAIT)\n \t\t\treturn -EAGAIN;\n \n \t\terror = __remove_privs(file_mnt_user_ns(file), dentry, kill);\n-\t}\n+inode_unlock(inode);\t}\n \n \tif (!error)\n \t\tinode_has_no_xattr(inode);\n",
            "diff --git a/fs/inode.c b/fs/inode.c\nindex b608528efd3a..2c52b838979d 100644\n--- a/fs/inode.c\n+++ b/fs/inode.c\n@@ -2031,7 +2031,9 @@ static int __file_remove_privs(struct file *file, unsigned int flags)\n \t\tif (flags & IOCB_NOWAIT)\n \t\t\treturn -EAGAIN;\n \n-\t\terror = __remove_privs(file_mnt_user_ns(file), dentry, kill);\n+\t\tinode_lock(inode);\n+error = __remove_privs(file_mnt_user_ns(file), dentry, kill);\n+inode_unlock(inode);\n \t}\n \n \tif (!error)\n"
        ],
        "special_crash": [],
        "crash": [],
        "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..ac69b26ae5b6 100644\n--- a/drivers/usb/gadget/legacy/raw_gadget.c\n+++ b/drivers/usb/gadget/legacy/raw_gadget.c\n@@ -387,6 +387,11 @@ static int raw_open(struct inode *inode, struct file *fd)\n \t\treturn -ENOMEM;\n \tfd->private_data = dev;\n \tdev->state = STATE_DEV_OPENED;\n+    /* Ensure releasing resources in case of failure */\n+    if (unlikely(dev->state != STATE_DEV_OPENED)) {\n+        kref_put(&dev->count, dev_free);\n+        return -EINVAL;\n+    }\n \tdev->dev = raw_misc_device.this_device;\n \treturn 0;\n }\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/usb/gadget/legacy/raw_gadget.c b/drivers/usb/gadget/legacy/raw_gadget.c\nindex 2acece16b890..62bfbac3a4f2 100644\n--- a/drivers/usb/gadget/legacy/raw_gadget.c\n+++ b/drivers/usb/gadget/legacy/raw_gadget.c\n@@ -184,7 +184,25 @@ struct raw_dev {\n \tstruct raw_event_queue\t\tqueue;\n };\n \n-static struct raw_dev *dev_new(void)\n+static struct raw_dev *dev_new()\n+{\n+    struct raw_dev *dev;\n+\n+    dev = kzalloc(sizeof(*dev), GFP_KERNEL);\n+    if (!dev)\n+        return NULL;\n+    /* Matches kref_put() in raw_release(). */\n+    kref_init(&dev->count);\n+    spin_lock_init(&dev->lock);\n+    init_completion(&dev->ep0_done);\n+    raw_event_queue_init(&dev->queue);\n+    dev->driver_id_number = -1;\n+    dev->udc_name = NULL;\n+    dev->driver.udc_name = NULL;\n+    dev->driver.driver.name = NULL;\n+    dev->req = NULL;\n+    return dev;\n+}(void)\n {\n \tstruct raw_dev *dev;\n \n@@ -382,7 +400,25 @@ static int raw_open(struct inode *inode, struct file *fd)\n \tif (fd->f_flags & O_NONBLOCK)\n \t\treturn -EINVAL;\n \n-\tdev = dev_new();\n+\tdev = dev_new()\n+{\n+    struct raw_dev *dev;\n+\n+    dev = kzalloc(sizeof(*dev), GFP_KERNEL);\n+    if (!dev)\n+        return NULL;\n+    /* Matches kref_put() in raw_release(). */\n+    kref_init(&dev->count);\n+    spin_lock_init(&dev->lock);\n+    init_completion(&dev->ep0_done);\n+    raw_event_queue_init(&dev->queue);\n+    dev->driver_id_number = -1;\n+    dev->udc_name = NULL;\n+    dev->driver.udc_name = NULL;\n+    dev->driver.driver.name = NULL;\n+    dev->req = NULL;\n+    return dev;\n+}();\n \tif (!dev)\n \t\treturn -ENOMEM;\n \tfd->private_data = dev;\n@@ -420,7 +456,25 @@ static int raw_release(struct inode *inode, struct file *fd)\n \t}\n \n out_put:\n-\t/* Matches dev_new() in raw_open(). */\n+\t/* Matches dev_new()\n+{\n+    struct raw_dev *dev;\n+\n+    dev = kzalloc(sizeof(*dev), GFP_KERNEL);\n+    if (!dev)\n+        return NULL;\n+    /* Matches kref_put() in raw_release(). */\n+    kref_init(&dev->count);\n+    spin_lock_init(&dev->lock);\n+    init_completion(&dev->ep0_done);\n+    raw_event_queue_init(&dev->queue);\n+    dev->driver_id_number = -1;\n+    dev->udc_name = NULL;\n+    dev->driver.udc_name = NULL;\n+    dev->driver.driver.name = NULL;\n+    dev->req = NULL;\n+    return dev;\n+}() in raw_open(). */\n \tkref_put(&dev->count, dev_free);\n \treturn ret;\n }\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..1b9901dfabc2 100644\n--- a/drivers/media/usb/siano/smsusb.c\n+++ b/drivers/media/usb/siano/smsusb.c\n@@ -144,7 +144,9 @@ static void smsusb_onresponse(struct urb *urb)\n \n exit_and_resubmit:\n \tINIT_WORK(&surb->wq, do_submit_urb);\n-\tschedule_work(&surb->wq);\n+\tif (surb->cb) {\n+    schedule_work(&surb->wq);\n+}\n }\n \n static int smsusb_submit_urb(struct smsusb_device_t *dev,\n",
            "diff --git a/drivers/media/usb/siano/smsusb.c b/drivers/media/usb/siano/smsusb.c\nindex 6f443c542c6d..12128b92c8ed 100644\n--- a/drivers/media/usb/siano/smsusb.c\n+++ b/drivers/media/usb/siano/smsusb.c\n@@ -177,6 +177,11 @@ static void smsusb_stop_streaming(struct smsusb_device_t *dev)\n {\n \tint i;\n \n+    pr_debug(\"Killing URBs and canceling work item\\n\");\n+    usb_kill_urb(&dev->surbs[i].urb);\n+    pr_debug(\"URBs killed\\n\");\n+    cancel_work_sync(&dev->surbs[i].wq);\n+    pr_debug(\"Work item canceled\\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",
            "diff --git a/drivers/media/usb/siano/smsusb.c b/drivers/media/usb/siano/smsusb.c\nindex 6f443c542c6d..9d27a9f35bf8 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+flush_work(&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..81c86d2f2850 100644\n--- a/drivers/media/usb/siano/smsusb.c\n+++ b/drivers/media/usb/siano/smsusb.c\n@@ -47,6 +47,7 @@ struct smsusb_urb_t {\n };\n \n struct smsusb_device_t {\n+bool terminating;\n \tstruct usb_device *udev;\n \tstruct smscore_device_t *coredev;\n \n@@ -144,7 +145,9 @@ static void smsusb_onresponse(struct urb *urb)\n \n exit_and_resubmit:\n \tINIT_WORK(&surb->wq, do_submit_urb);\n-\tschedule_work(&surb->wq);\n+\tif (!dev->terminating) {\n+        schedule_work(&surb->wq);\n+    }\n }\n \n static int smsusb_submit_urb(struct smsusb_device_t *dev,\n@@ -174,6 +177,8 @@ static int smsusb_submit_urb(struct smsusb_device_t *dev,\n }\n \n static void smsusb_stop_streaming(struct smsusb_device_t *dev)\n+{\n+    dev->terminating = true;\n {\n \tint i;\n \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..05f709ba2612 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.work.func)\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"
            }
        ]
    },
    "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"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/ieee802154/nl802154.c b/net/ieee802154/nl802154.c\nindex 2215f576ee37..95230aa3c289 100644\n--- a/net/ieee802154/nl802154.c\n+++ b/net/ieee802154/nl802154.c\n@@ -1068,6 +1068,10 @@ static int nl802154_set_pan_id(struct sk_buff *skb, struct genl_info *info)\n {\n \tstruct cfg802154_registered_device *rdev = info->user_ptr[0];\n \tstruct net_device *dev = info->user_ptr[1];\n+    if (!dev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid net_device pointer\");\n+        return -EINVAL;\n+    }\n \tstruct wpan_dev *wpan_dev = dev->ieee802154_ptr;\n \t__le16 pan_id;\n \n@@ -1104,6 +1108,10 @@ static int nl802154_set_short_addr(struct sk_buff *skb, struct genl_info *info)\n {\n \tstruct cfg802154_registered_device *rdev = info->user_ptr[0];\n \tstruct net_device *dev = info->user_ptr[1];\n+    if (!dev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid net_device pointer\");\n+        return -EINVAL;\n+    }\n \tstruct wpan_dev *wpan_dev = dev->ieee802154_ptr;\n \t__le16 short_addr;\n \n@@ -1146,6 +1154,10 @@ nl802154_set_backoff_exponent(struct sk_buff *skb, struct genl_info *info)\n {\n \tstruct cfg802154_registered_device *rdev = info->user_ptr[0];\n \tstruct net_device *dev = info->user_ptr[1];\n+    if (!dev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid net_device pointer\");\n+        return -EINVAL;\n+    }\n \tstruct wpan_dev *wpan_dev = dev->ieee802154_ptr;\n \tu8 min_be, max_be;\n \n@@ -1176,6 +1188,10 @@ nl802154_set_max_csma_backoffs(struct sk_buff *skb, struct genl_info *info)\n {\n \tstruct cfg802154_registered_device *rdev = info->user_ptr[0];\n \tstruct net_device *dev = info->user_ptr[1];\n+    if (!dev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid net_device pointer\");\n+        return -EINVAL;\n+    }\n \tstruct wpan_dev *wpan_dev = dev->ieee802154_ptr;\n \tu8 max_csma_backoffs;\n \n@@ -1202,6 +1218,10 @@ nl802154_set_max_frame_retries(struct sk_buff *skb, struct genl_info *info)\n {\n \tstruct cfg802154_registered_device *rdev = info->user_ptr[0];\n \tstruct net_device *dev = info->user_ptr[1];\n+    if (!dev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid net_device pointer\");\n+        return -EINVAL;\n+    }\n \tstruct wpan_dev *wpan_dev = dev->ieee802154_ptr;\n \ts8 max_frame_retries;\n \n@@ -1226,6 +1246,10 @@ static int nl802154_set_lbt_mode(struct sk_buff *skb, struct genl_info *info)\n {\n \tstruct cfg802154_registered_device *rdev = info->user_ptr[0];\n \tstruct net_device *dev = info->user_ptr[1];\n+    if (!dev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid net_device pointer\");\n+        return -EINVAL;\n+    }\n \tstruct wpan_dev *wpan_dev = dev->ieee802154_ptr;\n \tint mode;\n \n@@ -1251,6 +1275,10 @@ nl802154_set_ackreq_default(struct sk_buff *skb, struct genl_info *info)\n {\n \tstruct cfg802154_registered_device *rdev = info->user_ptr[0];\n \tstruct net_device *dev = info->user_ptr[1];\n+    if (!dev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid net_device pointer\");\n+        return -EINVAL;\n+    }\n \tstruct wpan_dev *wpan_dev = dev->ieee802154_ptr;\n \tint ackreq;\n \n@@ -1401,6 +1429,10 @@ static int nl802154_trigger_scan(struct sk_buff *skb, struct genl_info *info)\n {\n \tstruct cfg802154_registered_device *rdev = info->user_ptr[0];\n \tstruct net_device *dev = info->user_ptr[1];\n+    if (!dev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid net_device pointer\");\n+        return -EINVAL;\n+    }\n \tstruct wpan_dev *wpan_dev = dev->ieee802154_ptr;\n \tstruct wpan_phy *wpan_phy = &rdev->wpan_phy;\n \tstruct cfg802154_scan_request *request;\n@@ -1557,6 +1589,10 @@ static int nl802154_abort_scan(struct sk_buff *skb, struct genl_info *info)\n {\n \tstruct cfg802154_registered_device *rdev = info->user_ptr[0];\n \tstruct net_device *dev = info->user_ptr[1];\n+    if (!dev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid net_device pointer\");\n+        return -EINVAL;\n+    }\n \tstruct wpan_dev *wpan_dev = dev->ieee802154_ptr;\n \n \t/* Resources are released in the notification helper above */\n@@ -1568,6 +1604,10 @@ nl802154_send_beacons(struct sk_buff *skb, struct genl_info *info)\n {\n \tstruct cfg802154_registered_device *rdev = info->user_ptr[0];\n \tstruct net_device *dev = info->user_ptr[1];\n+    if (!dev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid net_device pointer\");\n+        return -EINVAL;\n+    }\n \tstruct wpan_dev *wpan_dev = dev->ieee802154_ptr;\n \tstruct wpan_phy *wpan_phy = &rdev->wpan_phy;\n \tstruct cfg802154_beacon_request *request;\n@@ -1621,6 +1661,10 @@ nl802154_stop_beacons(struct sk_buff *skb, struct genl_info *info)\n {\n \tstruct cfg802154_registered_device *rdev = info->user_ptr[0];\n \tstruct net_device *dev = info->user_ptr[1];\n+    if (!dev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid net_device pointer\");\n+        return -EINVAL;\n+    }\n \tstruct wpan_dev *wpan_dev = dev->ieee802154_ptr;\n \n \t/* Resources are released in the notification helper above */\n@@ -1731,6 +1775,10 @@ static int nl802154_set_llsec_params(struct sk_buff *skb,\n {\n \tstruct cfg802154_registered_device *rdev = info->user_ptr[0];\n \tstruct net_device *dev = info->user_ptr[1];\n+    if (!dev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid net_device pointer\");\n+        return -EINVAL;\n+    }\n \tstruct wpan_dev *wpan_dev = dev->ieee802154_ptr;\n \tstruct ieee802154_llsec_params params;\n \tu32 changed = 0;\n@@ -1898,6 +1946,10 @@ static int nl802154_add_llsec_key(struct sk_buff *skb, struct genl_info *info)\n {\n \tstruct cfg802154_registered_device *rdev = info->user_ptr[0];\n \tstruct net_device *dev = info->user_ptr[1];\n+    if (!dev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid net_device pointer\");\n+        return -EINVAL;\n+    }\n \tstruct wpan_dev *wpan_dev = dev->ieee802154_ptr;\n \tstruct nlattr *attrs[NL802154_KEY_ATTR_MAX + 1];\n \tstruct ieee802154_llsec_key key = { };\n@@ -1952,6 +2004,10 @@ static int nl802154_del_llsec_key(struct sk_buff *skb, struct genl_info *info)\n {\n \tstruct cfg802154_registered_device *rdev = info->user_ptr[0];\n \tstruct net_device *dev = info->user_ptr[1];\n+    if (!dev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid net_device pointer\");\n+        return -EINVAL;\n+    }\n \tstruct wpan_dev *wpan_dev = dev->ieee802154_ptr;\n \tstruct nlattr *attrs[NL802154_KEY_ATTR_MAX + 1];\n \tstruct ieee802154_llsec_key_id id;\n@@ -2112,6 +2168,10 @@ static int nl802154_add_llsec_dev(struct sk_buff *skb, struct genl_info *info)\n {\n \tstruct cfg802154_registered_device *rdev = info->user_ptr[0];\n \tstruct net_device *dev = info->user_ptr[1];\n+    if (!dev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid net_device pointer\");\n+        return -EINVAL;\n+    }\n \tstruct wpan_dev *wpan_dev = dev->ieee802154_ptr;\n \tstruct ieee802154_llsec_device dev_desc;\n \n@@ -2129,6 +2189,10 @@ static int nl802154_del_llsec_dev(struct sk_buff *skb, struct genl_info *info)\n {\n \tstruct cfg802154_registered_device *rdev = info->user_ptr[0];\n \tstruct net_device *dev = info->user_ptr[1];\n+    if (!dev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid net_device pointer\");\n+        return -EINVAL;\n+    }\n \tstruct wpan_dev *wpan_dev = dev->ieee802154_ptr;\n \tstruct nlattr *attrs[NL802154_DEV_ATTR_MAX + 1];\n \t__le64 extended_addr;\n@@ -2262,6 +2326,10 @@ static int nl802154_add_llsec_devkey(struct sk_buff *skb, struct genl_info *info\n {\n \tstruct cfg802154_registered_device *rdev = info->user_ptr[0];\n \tstruct net_device *dev = info->user_ptr[1];\n+    if (!dev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid net_device pointer\");\n+        return -EINVAL;\n+    }\n \tstruct wpan_dev *wpan_dev = dev->ieee802154_ptr;\n \tstruct nlattr *attrs[NL802154_DEVKEY_ATTR_MAX + 1];\n \tstruct ieee802154_llsec_device_key key;\n@@ -2296,6 +2364,10 @@ static int nl802154_del_llsec_devkey(struct sk_buff *skb, struct genl_info *info\n {\n \tstruct cfg802154_registered_device *rdev = info->user_ptr[0];\n \tstruct net_device *dev = info->user_ptr[1];\n+    if (!dev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid net_device pointer\");\n+        return -EINVAL;\n+    }\n \tstruct wpan_dev *wpan_dev = dev->ieee802154_ptr;\n \tstruct nlattr *attrs[NL802154_DEVKEY_ATTR_MAX + 1];\n \tstruct ieee802154_llsec_device_key key;\n@@ -2464,6 +2536,10 @@ static int nl802154_add_llsec_seclevel(struct sk_buff *skb,\n {\n \tstruct cfg802154_registered_device *rdev = info->user_ptr[0];\n \tstruct net_device *dev = info->user_ptr[1];\n+    if (!dev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid net_device pointer\");\n+        return -EINVAL;\n+    }\n \tstruct wpan_dev *wpan_dev = dev->ieee802154_ptr;\n \tstruct ieee802154_llsec_seclevel sl;\n \n@@ -2482,6 +2558,10 @@ static int nl802154_del_llsec_seclevel(struct sk_buff *skb,\n {\n \tstruct cfg802154_registered_device *rdev = info->user_ptr[0];\n \tstruct net_device *dev = info->user_ptr[1];\n+    if (!dev) {\n+        NL_SET_ERR_MSG(info->extack, \"Invalid net_device pointer\");\n+        return -EINVAL;\n+    }\n \tstruct wpan_dev *wpan_dev = dev->ieee802154_ptr;\n \tstruct ieee802154_llsec_seclevel sl;\n \n"
        ],
        "error": []
    },
    "33e08264ba252fcf3ed89b69fd088ac976363535": {
        "non_crash": [
            "diff --git a/fs/udf/inode.c b/fs/udf/inode.c\nindex 31965c3798f2..709f72cf1ee4 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 (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"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "2ebf4e2ffdaf022d2aac190c391ecb56689b6fc4": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/udf/namei.c b/fs/udf/namei.c\nindex fb4c30e05245..d85afda07b9f 100644\n--- a/fs/udf/namei.c\n+++ b/fs/udf/namei.c\n@@ -247,6 +247,12 @@ static struct fileIdentDesc *udf_find_entry(struct inode *dir,\n \t\t\t\t\t\tgoto out_err;\n \t\t\t\t\t}\n \t\t\t\t}\n+if (poffset < lfi) {\n+memcpy(nameptr, udf_get_fi_ident(fi),\n+lfi - poffset);\n+memcpy(nameptr + lfi - poffset,\n+fibh->ebh->b_data, poffset);\n+}\n \t\t\t\tnameptr = copy_name;\n \t\t\t\tmemcpy(nameptr, udf_get_fi_ident(fi),\n \t\t\t\t\tlfi - poffset);\n"
        ],
        "error": []
    },
    "9a58b47cdbbb40f7679a00991cac436716c70192": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/udf/directory.c b/fs/udf/directory.c\nindex e7e8b30876d9..7f35ba12def6 100644\n--- a/fs/udf/directory.c\n+++ b/fs/udf/directory.c\n@@ -505,7 +505,7 @@ struct long_ad *udf_get_filelongad(uint8_t *ptr, int maxoffset, uint32_t *offset\n \tif ((*offset + sizeof(struct long_ad)) > maxoffset)\n \t\treturn NULL;\n \telse {\n-\t\tla = (struct long_ad *)ptr;\n+\t\tla = (struct long_ad *)(ptr + *offset);\n \t\tif (la->extLength == 0)\n \t\t\treturn NULL;\n \t}\n",
            "diff --git a/fs/udf/directory.c b/fs/udf/directory.c\nindex e7e8b30876d9..79d1ca8a71b7 100644\n--- a/fs/udf/directory.c\n+++ b/fs/udf/directory.c\n@@ -502,7 +502,7 @@ struct long_ad *udf_get_filelongad(uint8_t *ptr, int maxoffset, uint32_t *offset\n \t\treturn NULL;\n \t}\n \n-\tif ((*offset + sizeof(struct long_ad)) > maxoffset)\n+\tif ((*offset + sizeof(struct long_ad)) > maxoffset || !la)\n \t\treturn NULL;\n \telse {\n \t\tla = (struct long_ad *)ptr;\n",
            "diff --git a/fs/udf/directory.c b/fs/udf/directory.c\nindex e7e8b30876d9..7f35ba12def6 100644\n--- a/fs/udf/directory.c\n+++ b/fs/udf/directory.c\n@@ -505,7 +505,7 @@ struct long_ad *udf_get_filelongad(uint8_t *ptr, int maxoffset, uint32_t *offset\n \tif ((*offset + sizeof(struct long_ad)) > maxoffset)\n \t\treturn NULL;\n \telse {\n-\t\tla = (struct long_ad *)ptr;\n+\t\tla = (struct long_ad *)(ptr + *offset);\n \t\tif (la->extLength == 0)\n \t\t\treturn NULL;\n \t}\n",
            "diff --git a/fs/udf/directory.c b/fs/udf/directory.c\nindex e7e8b30876d9..47452c184f01 100644\n--- a/fs/udf/directory.c\n+++ b/fs/udf/directory.c\n@@ -502,7 +502,7 @@ struct long_ad *udf_get_filelongad(uint8_t *ptr, int maxoffset, uint32_t *offset\n \t\treturn NULL;\n \t}\n \n-\tif ((*offset + sizeof(struct long_ad)) > maxoffset)\n+\tif ((!ptr) || (!offset) || (*offset + sizeof(struct long_ad)) > maxoffset)\n \t\treturn NULL;\n \telse {\n \t\tla = (struct long_ad *)ptr;\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": []
    },
    "d5cd7bc74de1e50a5139d45189395427cc5c3f63": {
        "non_crash": [
            "diff --git a/kernel/bpf/btf.c b/kernel/bpf/btf.c\nindex cad09858a5f2..2e5e44e39e5c 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\");\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\");\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",
            "diff --git a/kernel/bpf/btf.c b/kernel/bpf/btf.c\nindex cad09858a5f2..4685ac9f0180 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, \"NULL 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, \"NULL 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",
            "diff --git a/kernel/bpf/btf.c b/kernel/bpf/btf.c\nindex cad09858a5f2..2dec1d62a7e2 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\");\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\");\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": [
            "diff --git a/kernel/bpf/btf.c b/kernel/bpf/btf.c\nindex cad09858a5f2..642de7f4e6a2 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, \"NULL 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, \"NULL 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"
        ],
        "error": [
            {
                "patch": "diff --git a/kernel/bpf/btf.c b/kernel/bpf/btf.c\nindex cad09858a5f2..3cf6b3c0dad5 100644\n--- a/kernel/bpf/btf.c\n+++ b/kernel/bpf/btf.c\n@@ -1917,6 +1917,13 @@ 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 \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"
            }
        ]
    },
    "507c1be447a4c69f108a0b8cd281fcab44eaf774": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 928446fe1319..5299005665e5 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -9620,7 +9620,12 @@ 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+\t// Ensure all resource lists are empty before freeing context\n+    if (!list_empty(&ctx->rsrc_ref_list) || !llist_empty(&ctx->rsrc_put_llist) || !list_empty(&ctx->ltimeout_list)) {\n+        WARN_ON_ONCE(1);\n+        return;\n+    }\n+    io_ring_ctx_free(ctx);\n }\n \n /* Returns true if we found and killed one or more timeouts */\n",
            "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 928446fe1319..7adc7d440d6d 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+\tif (!list_empty(&ctx->rsrc_ref_list) || !llist_empty(&ctx->rsrc_put_llist) || !list_empty(&ctx->ltimeout_list)) {\n+    /* Add cleanup or handling code here to ensure lists are cleared */\n+}\n+io_ring_ctx_free(ctx);\n }\n \n /* Returns true if we found and killed one or more timeouts */\n",
            "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 928446fe1319..c1936cd4f9c0 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -9620,7 +9620,9 @@ 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+\tif (!list_empty(&ctx->rsrc_ref_list) || !llist_empty(&ctx->rsrc_put_llist) || !list_empty(&ctx->ltimeout_list)) {\n+        io_ring_ctx_free(ctx);\n+    }\n }\n \n /* Returns true if we found and killed one or more timeouts */\n"
        ],
        "error": []
    },
    "64182208616de0ae5ebd9b1652cb213485d61fce": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "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",
            "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"
            },
            {
                "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"
            }
        ]
    },
    "deb061ff946b02c2f4821f91683d89a68b2f45f8": {
        "non_crash": [
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..df50dab40f93 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 insufficient 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": [
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..b8db66939639 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -613,7 +613,8 @@ 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 < 0 || fd.entrylength > sizeof(struct hfsplus_cat_file)) return -EIO;\n+    WARN_ON(fd.entrylength < sizeof(struct hfsplus_cat_file));\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",
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..ada29417dc7f 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -613,7 +613,8 @@ 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+        return -EIO;\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",
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..d4d16bb669bd 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -613,7 +613,8 @@ 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+        return -EINVAL;\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"
        ],
        "error": []
    },
    "cd246a3e7f0fd69a115b910b3b2cf6fa96351278": {
        "non_crash": [],
        "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..c78a4b502374 100644\n--- a/fs/nilfs2/btree.c\n+++ b/fs/nilfs2/btree.c\n@@ -415,7 +415,10 @@ 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) {\n+    return NULL; // or handle the error appropriately\n+}\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..e991875fd721 100644\n--- a/fs/nilfs2/btree.c\n+++ b/fs/nilfs2/btree.c\n@@ -1235,7 +1235,11 @@ static int nilfs_btree_insert(struct nilfs_bmap *btree, __u64 key, __u64 ptr)\n \t\tgoto out;\n \t}\n \n-\tret = nilfs_btree_prepare_insert(btree, path, &level, key, ptr, &stats);\n+\tret = if (!path) {\n+        ret = -ENOMEM;\n+        goto out;\n+    }\n+    ret = nilfs_btree_prepare_insert(btree, path, &level, key, ptr, &stats);\n \tif (ret < 0)\n \t\tgoto out;\n \tnilfs_btree_commit_insert(btree, path, level, key, ptr);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/nilfs2/btree.c b/fs/nilfs2/btree.c\nindex b9d15c3df3cc..d6a847a35c74 100644\n--- a/fs/nilfs2/btree.c\n+++ b/fs/nilfs2/btree.c\n@@ -440,7 +440,11 @@ nilfs_btree_get_node(const struct nilfs_bmap *btree,\n \t\tnode = nilfs_btree_get_root(btree);\n \t\t*ncmaxp = NILFS_BTREE_ROOT_NCHILDREN_MAX;\n \t} else {\n-\t\tnode = nilfs_btree_get_nonroot_node(path, level);\n+\t\tif (path[level].bp_bh == NULL) {\n+            ret = -EINVAL;\n+            goto out;\n+        }\n+        node = nilfs_btree_get_nonroot_node(path, level);\n \t\t*ncmaxp = nilfs_btree_nchildren_per_block(btree);\n \t}\n \treturn node;\n@@ -571,7 +575,11 @@ static int nilfs_btree_do_lookup(const struct nilfs_bmap *btree,\n \t\tif (ret < 0)\n \t\t\treturn ret;\n \n-\t\tnode = nilfs_btree_get_nonroot_node(path, level);\n+\t\tif (path[level].bp_bh == NULL) {\n+            ret = -EINVAL;\n+            goto out;\n+        }\n+        node = nilfs_btree_get_nonroot_node(path, level);\n \t\tif (nilfs_btree_bad_node(btree, node, level))\n \t\t\treturn -EINVAL;\n \t\tif (!found)\n@@ -619,7 +627,11 @@ static int nilfs_btree_do_lookup_last(const struct nilfs_bmap *btree,\n \t\tret = nilfs_btree_get_block(btree, ptr, &path[level].bp_bh);\n \t\tif (ret < 0)\n \t\t\treturn ret;\n-\t\tnode = nilfs_btree_get_nonroot_node(path, level);\n+\t\tif (path[level].bp_bh == NULL) {\n+            ret = -EINVAL;\n+            goto out;\n+        }\n+        node = nilfs_btree_get_nonroot_node(path, level);\n \t\tif (nilfs_btree_bad_node(btree, node, level))\n \t\t\treturn -EINVAL;\n \t\tindex = nilfs_btree_node_get_nchildren(node) - 1;\n@@ -659,7 +671,11 @@ static int nilfs_btree_get_next_key(const struct nilfs_bmap *btree,\n \t\tif (level == maxlevel)\n \t\t\tnode = nilfs_btree_get_root(btree);\n \t\telse\n-\t\t\tnode = nilfs_btree_get_nonroot_node(path, level);\n+\t\t\tif (path[level].bp_bh == NULL) {\n+            ret = -EINVAL;\n+            goto out;\n+        }\n+        node = nilfs_btree_get_nonroot_node(path, level);\n \n \t\tindex = path[level].bp_index + next_adj;\n \t\tif (index < nilfs_btree_node_get_nchildren(node)) {\n@@ -761,7 +777,11 @@ static int nilfs_btree_lookup_contig(const struct nilfs_bmap *btree,\n \t\t\t\t\t      &p);\n \t\tif (ret < 0)\n \t\t\tgoto out;\n-\t\tnode = nilfs_btree_get_nonroot_node(path, level);\n+\t\tif (path[level].bp_bh == NULL) {\n+            ret = -EINVAL;\n+            goto out;\n+        }\n+        node = nilfs_btree_get_nonroot_node(path, level);\n \t\tncmax = nilfs_btree_nchildren_per_block(btree);\n \t\tindex = 0;\n \t\tpath[level].bp_index = index;\n@@ -804,7 +824,11 @@ static void nilfs_btree_do_insert(struct nilfs_bmap *btree,\n \tint ncblk;\n \n \tif (level < nilfs_btree_height(btree) - 1) {\n-\t\tnode = nilfs_btree_get_nonroot_node(path, level);\n+\t\tif (path[level].bp_bh == NULL) {\n+            ret = -EINVAL;\n+            goto out;\n+        }\n+        node = nilfs_btree_get_nonroot_node(path, level);\n \t\tncblk = nilfs_btree_nchildren_per_block(btree);\n \t\tnilfs_btree_node_insert(node, path[level].bp_index,\n \t\t\t\t\t*keyp, *ptrp, ncblk);\n@@ -830,7 +854,11 @@ static void nilfs_btree_carry_left(struct nilfs_bmap *btree,\n \tstruct nilfs_btree_node *node, *left;\n \tint nchildren, lnchildren, n, move, ncblk;\n \n-\tnode = nilfs_btree_get_nonroot_node(path, level);\n+\tif (path[level].bp_bh == NULL) {\n+            ret = -EINVAL;\n+            goto out;\n+        }\n+        node = nilfs_btree_get_nonroot_node(path, level);\n \tleft = nilfs_btree_get_sib_node(path, level);\n \tnchildren = nilfs_btree_node_get_nchildren(node);\n \tlnchildren = nilfs_btree_node_get_nchildren(left);\n@@ -876,7 +904,11 @@ static void nilfs_btree_carry_right(struct nilfs_bmap *btree,\n \tstruct nilfs_btree_node *node, *right;\n \tint nchildren, rnchildren, n, move, ncblk;\n \n-\tnode = nilfs_btree_get_nonroot_node(path, level);\n+\tif (path[level].bp_bh == NULL) {\n+            ret = -EINVAL;\n+            goto out;\n+        }\n+        node = nilfs_btree_get_nonroot_node(path, level);\n \tright = nilfs_btree_get_sib_node(path, level);\n \tnchildren = nilfs_btree_node_get_nchildren(node);\n \trnchildren = nilfs_btree_node_get_nchildren(right);\n@@ -923,7 +955,11 @@ static void nilfs_btree_split(struct nilfs_bmap *btree,\n \tstruct nilfs_btree_node *node, *right;\n \tint nchildren, n, move, ncblk;\n \n-\tnode = nilfs_btree_get_nonroot_node(path, level);\n+\tif (path[level].bp_bh == NULL) {\n+            ret = -EINVAL;\n+            goto out;\n+        }\n+        node = nilfs_btree_get_nonroot_node(path, level);\n \tright = nilfs_btree_get_sib_node(path, level);\n \tnchildren = nilfs_btree_node_get_nchildren(node);\n \tncblk = nilfs_btree_nchildren_per_block(btree);\n@@ -1074,7 +1110,11 @@ static int nilfs_btree_prepare_insert(struct nilfs_bmap *btree,\n \tfor (level = NILFS_BTREE_LEVEL_NODE_MIN;\n \t     level < nilfs_btree_height(btree) - 1;\n \t     level++) {\n-\t\tnode = nilfs_btree_get_nonroot_node(path, level);\n+\t\tif (path[level].bp_bh == NULL) {\n+            ret = -EINVAL;\n+            goto out;\n+        }\n+        node = nilfs_btree_get_nonroot_node(path, level);\n \t\tif (nilfs_btree_node_get_nchildren(node) < ncblk) {\n \t\t\tpath[level].bp_op = nilfs_btree_do_insert;\n \t\t\tstats->bs_nblocks++;\n@@ -1254,7 +1294,11 @@ static void nilfs_btree_do_delete(struct nilfs_bmap *btree,\n \tint ncblk;\n \n \tif (level < nilfs_btree_height(btree) - 1) {\n-\t\tnode = nilfs_btree_get_nonroot_node(path, level);\n+\t\tif (path[level].bp_bh == NULL) {\n+            ret = -EINVAL;\n+            goto out;\n+        }\n+        node = nilfs_btree_get_nonroot_node(path, level);\n \t\tncblk = nilfs_btree_nchildren_per_block(btree);\n \t\tnilfs_btree_node_delete(node, path[level].bp_index,\n \t\t\t\t\tkeyp, ptrp, ncblk);\n@@ -1280,7 +1324,11 @@ static void nilfs_btree_borrow_left(struct nilfs_bmap *btree,\n \n \tnilfs_btree_do_delete(btree, path, level, keyp, ptrp);\n \n-\tnode = nilfs_btree_get_nonroot_node(path, level);\n+\tif (path[level].bp_bh == NULL) {\n+            ret = -EINVAL;\n+            goto out;\n+        }\n+        node = nilfs_btree_get_nonroot_node(path, level);\n \tleft = nilfs_btree_get_sib_node(path, level);\n \tnchildren = nilfs_btree_node_get_nchildren(node);\n \tlnchildren = nilfs_btree_node_get_nchildren(left);\n@@ -1312,7 +1360,11 @@ static void nilfs_btree_borrow_right(struct nilfs_bmap *btree,\n \n \tnilfs_btree_do_delete(btree, path, level, keyp, ptrp);\n \n-\tnode = nilfs_btree_get_nonroot_node(path, level);\n+\tif (path[level].bp_bh == NULL) {\n+            ret = -EINVAL;\n+            goto out;\n+        }\n+        node = nilfs_btree_get_nonroot_node(path, level);\n \tright = nilfs_btree_get_sib_node(path, level);\n \tnchildren = nilfs_btree_node_get_nchildren(node);\n \trnchildren = nilfs_btree_node_get_nchildren(right);\n@@ -1345,7 +1397,11 @@ static void nilfs_btree_concat_left(struct nilfs_bmap *btree,\n \n \tnilfs_btree_do_delete(btree, path, level, keyp, ptrp);\n \n-\tnode = nilfs_btree_get_nonroot_node(path, level);\n+\tif (path[level].bp_bh == NULL) {\n+            ret = -EINVAL;\n+            goto out;\n+        }\n+        node = nilfs_btree_get_nonroot_node(path, level);\n \tleft = nilfs_btree_get_sib_node(path, level);\n \tncblk = nilfs_btree_nchildren_per_block(btree);\n \n@@ -1371,7 +1427,11 @@ static void nilfs_btree_concat_right(struct nilfs_bmap *btree,\n \n \tnilfs_btree_do_delete(btree, path, level, keyp, ptrp);\n \n-\tnode = nilfs_btree_get_nonroot_node(path, level);\n+\tif (path[level].bp_bh == NULL) {\n+            ret = -EINVAL;\n+            goto out;\n+        }\n+        node = nilfs_btree_get_nonroot_node(path, level);\n \tright = nilfs_btree_get_sib_node(path, level);\n \tncblk = nilfs_btree_nchildren_per_block(btree);\n \n@@ -1436,7 +1496,11 @@ static int nilfs_btree_prepare_delete(struct nilfs_bmap *btree,\n \tfor (level = NILFS_BTREE_LEVEL_NODE_MIN, dindex = path[level].bp_index;\n \t     level < nilfs_btree_height(btree) - 1;\n \t     level++) {\n-\t\tnode = nilfs_btree_get_nonroot_node(path, level);\n+\t\tif (path[level].bp_bh == NULL) {\n+            ret = -EINVAL;\n+            goto out;\n+        }\n+        node = nilfs_btree_get_nonroot_node(path, level);\n \t\tpath[level].bp_oldreq.bpr_ptr =\n \t\t\tnilfs_btree_node_get_ptr(node, dindex, ncblk);\n \t\tret = nilfs_bmap_prepare_end_ptr(btree,\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "6513f6cb5cd6b5fc9f37e3bb70d273b94be9c34c": {
        "non_crash": [
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dfc2e223bd10..97bb5a487a5e 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2073,7 +2073,12 @@ 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\tif (dquot_initialize_needed(inode)) {\n+    error = dquot_initialize(inode);\n+    if (error) {\n+        goto cleanup;\n+    }\n+}\n \n \t\t\t\t/* The old block is released after updating\n \t\t\t\t   the inode. */\n@@ -2137,7 +2142,12 @@ 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 \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..3fa983979025 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2073,7 +2073,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@@ -2137,7 +2140,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 dfc2e223bd10..a9812e01118a 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2428,7 +2428,12 @@ 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\tif (dquot_initialize_needed(inode)) {\n+                error = dquot_initialize(inode);\n+                if (error)\n+                    goto cleanup;\n+            }\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@@ -2445,7 +2450,12 @@ 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\tif (dquot_initialize_needed(inode)) {\n+                error = dquot_initialize(inode);\n+                if (error)\n+                    goto cleanup;\n+            }\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@@ -2454,7 +2464,12 @@ 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\tif (dquot_initialize_needed(inode)) {\n+                error = dquot_initialize(inode);\n+                if (error)\n+                    goto cleanup;\n+            }\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",
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dfc2e223bd10..71818f4074f9 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2137,7 +2137,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 dfc2e223bd10..7a7b9c83552d 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2139,7 +2139,11 @@ ext4_xattr_block_set(handle_t *handle, struct inode *inode,\n \n \t\t\tWARN_ON_ONCE(dquot_initialize_needed(inode));\n \n-\t\t\tgoal = ext4_group_first_block_no(sb,\n+\t\t\terror = dquot_initialize(inode);\n+    if (error)\n+        goto cleanup;\n+\n+    goal = ext4_group_first_block_no(sb,\n \t\t\t\t\t\tEXT4_I(inode)->i_block_group);\n \t\t\tblock = ext4_new_meta_blocks(handle, inode, goal, 0,\n \t\t\t\t\t\t     NULL, &error);\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..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..9f44298a2979 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..9f44298a2979 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"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "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..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",
            "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..3a78b672bc50 100644\n--- a/net/vmw_vsock/virtio_transport_common.c\n+++ b/net/vmw_vsock/virtio_transport_common.c\n@@ -1368,6 +1368,8 @@ 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+if (!skb->sk)\n+continue;\n \t\tif (vsock_sk(skb->sk) != vsk)\n \t\t\tcontinue;\n \n"
        ],
        "error": []
    },
    "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"
        ],
        "error": []
    },
    "7b2aea1ce02f87c175f94492d21d04a34bc99b5e": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/vhost/vsock.c b/drivers/vhost/vsock.c\nindex 37f0b4274113..5cc0456ffe16 100644\n--- a/drivers/vhost/vsock.c\n+++ b/drivers/vhost/vsock.c\n@@ -579,7 +579,8 @@ 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 \tret = vhost_dev_check_owner(&vsock->dev);\n \tif (ret)\n@@ -634,7 +635,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_trylock(&vsock->dev.mutex))\n+        return -EBUSY;\n \n \tif (check_owner) {\n \t\tret = vhost_dev_check_owner(&vsock->dev);\n@@ -826,7 +828,8 @@ 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 \tif ((features & (1 << VHOST_F_LOG_ALL)) &&\n \t    !vhost_log_access_ok(&vsock->dev)) {\n \t\tgoto err;\n@@ -898,7 +901,8 @@ 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 \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..85990b905669 100644\n--- a/drivers/vhost/vsock.c\n+++ b/drivers/vhost/vsock.c\n@@ -635,6 +635,7 @@ static int vhost_vsock_stop(struct vhost_vsock *vsock, bool check_owner)\n \tint ret = 0;\n \n \tmutex_lock(&vsock->dev.mutex);\n+pr_info(\"Acquired vsock->dev.mutex\\n\");\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..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",
            "diff --git a/drivers/vhost/vsock.c b/drivers/vhost/vsock.c\nindex 37f0b4274113..3a86d5a49bec 100644\n--- a/drivers/vhost/vsock.c\n+++ b/drivers/vhost/vsock.c\n@@ -579,7 +579,8 @@ 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_lock_interruptible(&vsock->dev.mutex))\n+        return -ERESTARTSYS;\n \n \tret = vhost_dev_check_owner(&vsock->dev);\n \tif (ret)\n@@ -634,7 +635,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@@ -826,7 +828,8 @@ 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_lock_interruptible(&vsock->dev.mutex))\n+        return -ERESTARTSYS;\n \tif ((features & (1 << VHOST_F_LOG_ALL)) &&\n \t    !vhost_log_access_ok(&vsock->dev)) {\n \t\tgoto err;\n@@ -898,7 +901,8 @@ 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_lock_interruptible(&vsock->dev.mutex))\n+        return -ERESTARTSYS;\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"
        ],
        "error": []
    },
    "212130bd8af05df1d923b02f9a71db6e8208e40d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/block/loop.c b/drivers/block/loop.c\nindex 204558d7a81d..12b4f6534a2d 100644\n--- a/drivers/block/loop.c\n+++ b/drivers/block/loop.c\n@@ -1143,7 +1143,8 @@ 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+\tmutex_unlock(&lo->lo_disk->open_mutex);\n+destroy_workqueue(lo->workqueue);\n \tloop_free_idle_workers(lo, true);\n \tdel_timer_sync(&lo->timer);\n \n",
            "diff --git a/drivers/block/loop.c b/drivers/block/loop.c\nindex 204558d7a81d..9bc19d43e05f 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+\tmutex_unlock(&lo->lo_disk->open_mutex);\n+    destroy_workqueue(lo->workqueue);\n+    mutex_lock(&lo->lo_disk->open_mutex);\n \tloop_free_idle_workers(lo, true);\n \tdel_timer_sync(&lo->timer);\n \n",
            "diff --git a/drivers/block/loop.c b/drivers/block/loop.c\nindex 204558d7a81d..bd3ef53d6e17 100644\n--- a/drivers/block/loop.c\n+++ b/drivers/block/loop.c\n@@ -1740,7 +1740,8 @@ static void lo_release(struct gendisk *disk, fmode_t mode)\n \t\t * In autoclear mode, stop the loop thread\n \t\t * and remove configuration after last close.\n \t\t */\n-\t\t__loop_clr_fd(lo, true);\n+\t\tmutex_unlock(&lo->lo_mutex);\n+        __loop_clr_fd(lo, true);\n \t\treturn;\n \t}\n \tmutex_unlock(&lo->lo_mutex);\n"
        ],
        "error": []
    },
    "e1306831b0c04a2ee7705d93be9747c870cadfd5": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/xattr.c b/fs/xattr.c\nindex 5c8c5175b385..e59e5e7ed2a8 100644\n--- a/fs/xattr.c\n+++ b/fs/xattr.c\n@@ -298,7 +298,8 @@ vfs_setxattr(struct user_namespace *mnt_userns, struct dentry *dentry,\n \n retry_deleg:\n \tinode_lock(inode);\n-\terror = __vfs_setxattr_locked(mnt_userns, dentry, name, value, size,\n+\trcu_read_lock();\n+    error = __vfs_setxattr_locked(mnt_userns, dentry, name, value, size,\n \t\t\t\t      flags, &delegated_inode);\n \tinode_unlock(inode);\n \n",
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex a0a36bfa3aa0..ea20f31caf74 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -391,6 +391,7 @@ int mnt_want_write(struct vfsmount *m)\n \tint ret;\n \n \tsb_start_write(m->mnt_sb);\n+cond_resched();\n \tret = __mnt_want_write(m);\n \tif (ret)\n \t\tsb_end_write(m->mnt_sb);\n"
        ],
        "error": []
    },
    "cdc284a3166b0aa5c8797071e971fd0606769e61": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/core/neighbour.c b/net/core/neighbour.c\nindex 952a54763358..1bbdb546dac3 100644\n--- a/net/core/neighbour.c\n+++ b/net/core/neighbour.c\n@@ -738,6 +738,8 @@ ___neigh_create(struct neigh_table *tbl, const void *pkey,\n out_tbl_unlock:\n \twrite_unlock_bh(&tbl->lock);\n out_neigh_release:\n+if (!exempt_from_gc)\n+atomic_dec(&tbl->gc_entries);\n \tif (!exempt_from_gc)\n \t\tatomic_dec(&tbl->gc_entries);\n \tneigh_release(n);\n"
        ],
        "error": []
    },
    "699e4f546c33df9781a67891d42766bbbe3ca30b": {
        "non_crash": [
            "diff --git a/fs/fuse/dir.c b/fs/fuse/dir.c\nindex 2798fbe8d001..81799b747a75 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_PARENT);\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..49bae8d54fa0 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_subclass(&d_inode(entry)->i_rwsem, 1);\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"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/fs/fuse/dir.c b/fs/fuse/dir.c\nindex 2798fbe8d001..8505a1ae319f 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(&d_inode(entry)->i_mutex); \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"
            },
            {
                "patch": "diff --git a/fs/fuse/dir.c b/fs/fuse/dir.c\nindex 2798fbe8d001..ca0d7eac0ba1 100644\n--- a/fs/fuse/dir.c\n+++ b/fs/fuse/dir.c\n@@ -1079,7 +1079,8 @@ 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+\tlockdep_set_class_and_subclass(&parent->i_mutex, &fuse_dir_key, 0);\n+inode_lock(parent);\n \tif (!S_ISDIR(parent->i_mode))\n \t\tgoto unlock;\n \n@@ -1098,7 +1099,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_class_and_subclass(&d_inode(entry)->i_mutex, &fuse_dir_key, 1);\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"
            }
        ]
    },
    "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..6009eb7b78b7 100644\n--- a/drivers/media/platform/vivid/vivid-vid-cap.c\n+++ b/drivers/media/platform/vivid/vivid-vid-cap.c\n@@ -1079,7 +1079,7 @@ 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 && access_ok(VERIFY_WRITE, 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",
            "diff --git a/arch/x86/lib/copy_user_64.S b/arch/x86/lib/copy_user_64.S\nindex db4e5aa0858b..33ff748a95fc 100644\n--- a/arch/x86/lib/copy_user_64.S\n+++ b/arch/x86/lib/copy_user_64.S\n@@ -134,6 +134,10 @@ EXPORT_SYMBOL(copy_user_generic_unrolled)\n  * eax uncopied bytes or 0 if successful.\n  */\n ENTRY(copy_user_generic_string)\n+    /* Validate user space address before copying */\n+    test %rsi, %rsi\n+    jz 3f\n+3:\n \tASM_STAC\n \tcmpl $8,%edx\n \tjb 2f\t\t/* less than 8 bytes, go to byte copy loop */\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..50fa2c52cf6e 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@@ -1163,7 +1163,7 @@ int vidioc_s_fmt_vid_overlay(struct file *file, void *priv,\n \tif (ret)\n \t\treturn ret;\n \n-\tif (win->bitmap) {\n+\tif (win->bitmap && access_ok(win->bitmap, ((compose->width + 7) / 8) * compose->height)) {\n \t\tnew_bitmap = vzalloc(bitmap_size);\n \n \t\tif (new_bitmap == NULL)\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..f8d0c054fe99 100644\n--- a/drivers/media/platform/vivid/vivid-vid-cap.c\n+++ b/drivers/media/platform/vivid/vivid-vid-cap.c\n@@ -1083,7 +1083,7 @@ int vidioc_g_fmt_vid_overlay(struct file *file, void *priv,\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"
            }
        ]
    },
    "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/xattr.c b/fs/ext4/xattr.c\nindex ff7ab63c5b4f..047a4622e578 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -61,6 +61,7 @@\n #include \"ext4.h\"\n #include \"xattr.h\"\n #include \"acl.h\"\n+static struct lock_class_key ext4_xattr_lock_key;\n \n #ifdef EXT4_XATTR_DEBUG\n # define ea_idebug(inode, fmt, ...)\t\t\t\t\t\\\n@@ -121,7 +122,7 @@ ext4_expand_inode_array(struct ext4_xattr_inode_array **ea_inode_array,\n #ifdef CONFIG_LOCKDEP\n void ext4_xattr_inode_set_class(struct inode *ea_inode)\n {\n-\tlockdep_set_subclass(&ea_inode->i_rwsem, 1);\n+\tlockdep_set_class(&ea_inode->i_rwsem, &ext4_xattr_lock_key);\n }\n #endif\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/ext4.h b/fs/ext4/ext4.h\nindex 9525c52b78dc..98e6a0a3c972 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_RWSEM_XATTR  - 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_RWSEM_XATTR,\n };\n \n \n"
        ],
        "error": []
    },
    "5e2e50e2c145ca06459e9e0900c20eefd1a0877e": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "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",
            "diff --git a/net/9p/trans_fd.c b/net/9p/trans_fd.c\nindex 56a186768750..5e7569302579 100644\n--- a/net/9p/trans_fd.c\n+++ b/net/9p/trans_fd.c\n@@ -211,7 +211,8 @@ 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 \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 +701,8 @@ 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 \t\treq->status = REQ_STATUS_FLSHD;\n \t\tp9_req_put(client, req);\n \t\tret = 0;\n@@ -729,7 +731,8 @@ 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 \treq->status = REQ_STATUS_FLSHD;\n \tspin_unlock(&m->req_lock);\n \n"
        ],
        "error": []
    },
    "96e0ffd75bd9a59edf367decb7583c8994e48cd6": {
        "non_crash": [
            "diff --git a/fs/ntfs3/bitmap.c b/fs/ntfs3/bitmap.c\nindex 629c1ee97268..dd98d8c6d17b 100644\n--- a/fs/ntfs3/bitmap.c\n+++ b/fs/ntfs3/bitmap.c\n@@ -661,7 +661,12 @@ int wnd_init(struct wnd_bitmap *wnd, struct super_block *sb, size_t nbits)\n \tif (!wnd->bits_last)\n \t\twnd->bits_last = wbits;\n \n-\twnd->free_bits = kcalloc(wnd->nwnd, sizeof(u16), GFP_NOFS);\n+\tif (blocksize != 512) {\n+        pr_warn(\"Different NTFS' sector size (%u) and media sector size (512)\\n\", blocksize);\n+        return -EINVAL;\n+    }\n+\n+    wnd->free_bits = kcalloc(wnd->nwnd, sizeof(u16), GFP_NOFS);\n \tif (!wnd->free_bits)\n \t\treturn -ENOMEM;\n \n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/fs/ntfs3/super.c b/fs/ntfs3/super.c\nindex 1e2c04e48f98..56261c3597f5 100644\n--- a/fs/ntfs3/super.c\n+++ b/fs/ntfs3/super.c\n@@ -1081,7 +1081,12 @@ static int ntfs_fill_super(struct super_block *sb, struct fs_context *fc)\n \ttt = inode->i_size >> sbi->record_bits;\n \tsbi->mft.next_free = MFT_REC_USER;\n \n-\terr = wnd_init(&sbi->mft.bitmap, sb, tt);\n+\tif (tt > MAX_BITMAP_SIZE) { \n+ntfs_err(sb, \"Bitmap size too large.\"); \n+err = -EINVAL; \n+goto put_inode_out; \n+}\n+err = wnd_init(&sbi->mft.bitmap, sb, tt);\n \tif (err)\n \t\tgoto put_inode_out;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/ntfs3/bitmap.c b/fs/ntfs3/bitmap.c\nindex 629c1ee97268..ce5efcbf0796 100644\n--- a/fs/ntfs3/bitmap.c\n+++ b/fs/ntfs3/bitmap.c\n@@ -661,7 +661,8 @@ int wnd_init(struct wnd_bitmap *wnd, struct super_block *sb, size_t nbits)\n \tif (!wnd->bits_last)\n \t\twnd->bits_last = wbits;\n \n-\twnd->free_bits = kcalloc(wnd->nwnd, sizeof(u16), GFP_NOFS);\n+\tif (wnd->nwnd > MAX_WND_SIZE) return -EINVAL;\n+    wnd->free_bits = kcalloc(wnd->nwnd, sizeof(u16), GFP_NOFS);\n \tif (!wnd->free_bits)\n \t\treturn -ENOMEM;\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "75a2a727e4636c7a34dbd49197b15c3de92a8f7f": {
        "non_crash": [
            "diff --git a/mm/hugetlb.c b/mm/hugetlb.c\nindex 9d97c9a2a15d..4ce832c1a913 100644\n--- a/mm/hugetlb.c\n+++ b/mm/hugetlb.c\n@@ -5320,7 +5320,10 @@ static vm_fault_t hugetlb_wp(struct mm_struct *mm, struct vm_area_struct *vma,\n \t * hugetlb does not support FOLL_FORCE-style write faults that keep the\n \t * PTE mapped R/O such as maybe_mkwrite() would do.\n \t */\n-\tif (WARN_ON_ONCE(!unshare && !(vma->vm_flags & VM_WRITE)))\n+\tif (!unshare && !(vma->vm_flags & VM_WRITE)) {\n+        printk(KERN_WARNING \"hugetlb_wp: unexpected write fault without unshare or VM_WRITE\\n\");\n+        return VM_FAULT_SIGSEGV;\n+    }\n \t\treturn VM_FAULT_SIGSEGV;\n \n \t/* Let's take out MAP_SHARED mappings first. */\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/hugetlb.c b/mm/hugetlb.c\nindex 9d97c9a2a15d..9b180ca35f6c 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) && (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) && (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..9b180ca35f6c 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) && (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) && (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": []
    },
    "0ec05481e31f2772a2c6f16aecb38f48467da26e": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 1971ca325fb4..727ceddbb228 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -5117,7 +5117,7 @@ static int do_check(struct bpf_verifier_env *env)\n \t\tu8 class;\n \t\tint err;\n \n-\t\tif (insn_idx >= insn_cnt) {\n+\t\tif (insn_idx < 0 || insn_idx >= insn_cnt) {\n \t\t\tverbose(env, \"invalid insn idx %d insn_cnt %d\\n\",\n \t\t\t\tinsn_idx, insn_cnt);\n \t\t\treturn -EFAULT;\n",
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 1971ca325fb4..59de1d6e778b 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -4554,7 +4554,11 @@ static int check_cfg(struct bpf_verifier_env *env)\n \t\t\t\tenv->explored_states[t + 1] = STATE_LIST_MARK;\n \t\t\tif (insns[t].src_reg == BPF_PSEUDO_CALL) {\n \t\t\t\tenv->explored_states[t] = STATE_LIST_MARK;\n-\t\t\t\tret = push_insn(t, t + insns[t].imm + 1, BRANCH, env);\n+\t\t\t\tif (insns[t].imm < 0 || t + insns[t].imm + 1 >= insn_cnt) {\n+    verbose(env, \"invalid BPF_CALL immediate %d at insn %d\\n\", insns[t].imm, t);\n+    return -EINVAL;\n+}\n+ret = push_insn(t, t + insns[t].imm + 1, BRANCH, env);\n \t\t\t\tif (ret == 1)\n \t\t\t\t\tgoto peek_stack;\n \t\t\t\telse if (ret < 0)\n",
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 1971ca325fb4..727ceddbb228 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -5117,7 +5117,7 @@ static int do_check(struct bpf_verifier_env *env)\n \t\tu8 class;\n \t\tint err;\n \n-\t\tif (insn_idx >= insn_cnt) {\n+\t\tif (insn_idx < 0 || insn_idx >= insn_cnt) {\n \t\t\tverbose(env, \"invalid insn idx %d insn_cnt %d\\n\",\n \t\t\t\tinsn_idx, insn_cnt);\n \t\t\treturn -EFAULT;\n",
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 1971ca325fb4..507ad050866a 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -5117,7 +5117,7 @@ static int do_check(struct bpf_verifier_env *env)\n \t\tu8 class;\n \t\tint err;\n \n-\t\tif (insn_idx >= insn_cnt) {\n+\t\tif (insn_idx >= insn_cnt || insn_idx < 0) {\n \t\t\tverbose(env, \"invalid insn idx %d insn_cnt %d\\n\",\n \t\t\t\tinsn_idx, insn_cnt);\n \t\t\treturn -EFAULT;\n"
        ],
        "error": []
    },
    "4d37ad3f55c09b663fe33db0a19fc9684e805a81": {
        "non_crash": [
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 1e7f653c1df7..ae15f7318818 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -194,7 +194,10 @@ void nilfs_dat_commit_end(struct inode *dat, struct nilfs_palloc_req *req,\n \tkaddr = kmap_atomic(req->pr_entry_bh->b_page);\n \tentry = nilfs_palloc_block_get_entry(dat, req->pr_entry_nr,\n \t\t\t\t\t     req->pr_entry_bh, kaddr);\n-\tend = start = le64_to_cpu(entry->de_start);\n+\tstart = le64_to_cpu(entry->de_start);\n+    if (start > nilfs_mdt_cno(dat))\n+        start = nilfs_mdt_cno(dat);\n+    end = start;\n \tif (!dead) {\n \t\tend = nilfs_mdt_cno(dat);\n \t\tWARN_ON(start > end);\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 1e7f653c1df7..0fc12643760d 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -194,7 +194,9 @@ void nilfs_dat_commit_end(struct inode *dat, struct nilfs_palloc_req *req,\n \tkaddr = kmap_atomic(req->pr_entry_bh->b_page);\n \tentry = nilfs_palloc_block_get_entry(dat, req->pr_entry_nr,\n \t\t\t\t\t     req->pr_entry_bh, kaddr);\n-\tend = start = le64_to_cpu(entry->de_start);\n+\tend = le64_to_cpu(entry->de_start);\n+    start = le64_to_cpu(entry->de_start);\n+    if (start > end) start = end;\n \tif (!dead) {\n \t\tend = nilfs_mdt_cno(dat);\n \t\tWARN_ON(start > end);\n"
        ],
        "error": []
    },
    "cfec079d55325bc20e929c60cc2dca149448f9b1": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 3990e4df3d7b..37ee3cb42c7c 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -275,6 +275,9 @@ long watch_queue_set_size(struct pipe_inode_info *pipe, unsigned int nr_notes)\n \t\t__free_page(pages[i]);\n \tkfree(pages);\n error:\n+    while (--i >= 0)\n+        __free_page(pages[i]);\n+    kfree(pages);\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",
            "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 3990e4df3d7b..c870593d3461 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -271,6 +271,8 @@ long watch_queue_set_size(struct pipe_inode_info *pipe, unsigned int nr_notes)\n \treturn 0;\n \n error_p:\n+if (bitmap)\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..de0720392878 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+if (pages) kfree(pages);\n \t(void) account_pipe_buffers(pipe->user, nr_pages, pipe->nr_accounted);\n \treturn ret;\n }\n"
        ],
        "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..4d6f533c2516 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",
            "diff --git a/fs/xfs/libxfs/xfs_btree.c b/fs/xfs/libxfs/xfs_btree.c\nindex c4649cc624e1..fdad520d3296 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 < 0 || level >= cur->bc_nlevels) return -EINVAL;\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..16af6a5b809f 100644\n--- a/fs/xfs/libxfs/xfs_btree.c\n+++ b/fs/xfs/libxfs/xfs_btree.c\n@@ -1788,6 +1788,10 @@ xfs_btree_decrement(\n \n int\n xfs_btree_lookup_get_block(\n+{\n+if (level < 0 || level >= cur->bc_nlevels) {\n+return -EINVAL;\n+}\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",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/xfs/libxfs/xfs_btree.c b/fs/xfs/libxfs/xfs_btree.c\nindex c4649cc624e1..8b2d905b8ea2 100644\n--- a/fs/xfs/libxfs/xfs_btree.c\n+++ b/fs/xfs/libxfs/xfs_btree.c\n@@ -1814,7 +1814,7 @@ xfs_btree_lookup_get_block(\n \terror = xfs_btree_ptr_to_daddr(cur, pp, &daddr);\n \tif (error)\n \t\treturn error;\n-\tif (bp && xfs_buf_daddr(bp) == daddr) {\n+\tif (bp && xfs_buf_daddr(bp) == daddr && XFS_BUF_IS_VALID(bp)) {\n \t\t*blkp = XFS_BUF_TO_BLOCK(bp);\n \t\treturn 0;\n \t}\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..8c1c78055450 100644\n--- a/net/core/devlink.c\n+++ b/net/core/devlink.c\n@@ -124,7 +124,7 @@ static struct devlink *devlink_get_from_attrs(struct net *net,\n \tif (!attrs[DEVLINK_ATTR_BUS_NAME] || !attrs[DEVLINK_ATTR_DEV_NAME])\n \t\treturn ERR_PTR(-EINVAL);\n \n-\tbusname = nla_data(attrs[DEVLINK_ATTR_BUS_NAME]);\n+\tbusname = kstrdup(nla_data(attrs[DEVLINK_ATTR_BUS_NAME]), GFP_KERNEL);\n \tdevname = nla_data(attrs[DEVLINK_ATTR_DEV_NAME]);\n \n \tlockdep_assert_held(&devlink_mutex);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/core/devlink.c b/net/core/devlink.c\nindex 2cafbc808b09..f0a49b2bd77e 100644\n--- a/net/core/devlink.c\n+++ b/net/core/devlink.c\n@@ -4269,6 +4269,8 @@ 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 (!IS_ERR(devlink))\n+        refcount_inc(&devlink->refcount);\n \tif (IS_ERR(devlink)) {\n \t\terr = PTR_ERR(devlink);\n \t\tgoto out_dev;\n@@ -5485,6 +5487,8 @@ devlink_health_reporter_get_from_cb(struct netlink_callback *cb)\n \n \tmutex_lock(&devlink_mutex);\n \tdevlink = devlink_get_from_attrs(sock_net(cb->skb->sk), attrs);\n+    if (!IS_ERR(devlink))\n+        refcount_inc(&devlink->refcount);\n \tif (IS_ERR(devlink))\n \t\tgoto unlock;\n \n@@ -7084,6 +7088,33 @@ static struct genl_family devlink_nl_family __ro_after_init = {\n  *\tand name.\n  */\n struct devlink *devlink_alloc(const struct devlink_ops *ops, size_t priv_size)\n+{\n+    struct devlink *devlink;\n+\n+    if (WARN_ON(!ops))\n+        return NULL;\n+\n+    devlink = kzalloc(sizeof(*devlink) + priv_size, GFP_KERNEL);\n+    if (!devlink)\n+        return NULL;\n+    devlink->ops = ops;\n+    xa_init_flags(&devlink->snapshot_ids, XA_FLAGS_ALLOC);\n+    __devlink_net_set(devlink, &init_net);\n+    INIT_LIST_HEAD(&devlink->port_list);\n+    INIT_LIST_HEAD(&devlink->sb_list);\n+    INIT_LIST_HEAD_RCU(&devlink->dpipe_table_list);\n+    INIT_LIST_HEAD(&devlink->resource_list);\n+    INIT_LIST_HEAD(&devlink->param_list);\n+    INIT_LIST_HEAD(&devlink->region_list);\n+    INIT_LIST_HEAD(&devlink->reporter_list);\n+    INIT_LIST_HEAD(&devlink->trap_list);\n+    INIT_LIST_HEAD(&devlink->trap_group_list);\n+    INIT_LIST_HEAD(&devlink->trap_policer_list);\n+    mutex_init(&devlink->lock);\n+    mutex_init(&devlink->reporters_lock);\n+    refcount_set(&devlink->refcount, 1);\n+    return devlink;\n+}\n {\n \tstruct devlink *devlink;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/core/devlink.c b/net/core/devlink.c\nindex 2cafbc808b09..1a05b5c8972c 100644\n--- a/net/core/devlink.c\n+++ b/net/core/devlink.c\n@@ -121,7 +121,8 @@ static struct devlink *devlink_get_from_attrs(struct net *net,\n \tchar *busname;\n \tchar *devname;\n \n-\tif (!attrs[DEVLINK_ATTR_BUS_NAME] || !attrs[DEVLINK_ATTR_DEV_NAME])\n+\tif (!attrs[DEVLINK_ATTR_BUS_NAME] || !attrs[DEVLINK_ATTR_DEV_NAME] ||\n+    !netlink_validate_attrs(attrs))\n \t\treturn ERR_PTR(-EINVAL);\n \n \tbusname = nla_data(attrs[DEVLINK_ATTR_BUS_NAME]);\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..d9ddae07bc86 100644\n--- a/net/bluetooth/hci_sysfs.c\n+++ b/net/bluetooth/hci_sysfs.c\n@@ -50,7 +50,9 @@ void hci_conn_add_sysfs(struct hci_conn *conn)\n \n \tdev_set_name(&conn->dev, \"%s:%d\", hdev->name, conn->handle);\n \n-\tif (device_add(&conn->dev) < 0) {\n+\tif (device_is_registered(&conn->dev)) return;\n+\n+    if (device_add(&conn->dev) < 0) {\n \t\tbt_dev_err(hdev, \"failed to register connection device\");\n \t\treturn;\n \t}\n",
            "diff --git a/net/bluetooth/hci_sysfs.c b/net/bluetooth/hci_sysfs.c\nindex 9874844a95a9..2bebab697dc7 100644\n--- a/net/bluetooth/hci_sysfs.c\n+++ b/net/bluetooth/hci_sysfs.c\n@@ -50,7 +50,7 @@ void hci_conn_add_sysfs(struct hci_conn *conn)\n \n \tdev_set_name(&conn->dev, \"%s:%d\", hdev->name, conn->handle);\n \n-\tif (device_add(&conn->dev) < 0) {\n+\tif (device_is_registered(&conn->dev) || device_add(&conn->dev) < 0) {\n \t\tbt_dev_err(hdev, \"failed to register connection device\");\n \t\treturn;\n \t}\n",
            "diff --git a/net/bluetooth/hci_sysfs.c b/net/bluetooth/hci_sysfs.c\nindex 9874844a95a9..2bebab697dc7 100644\n--- a/net/bluetooth/hci_sysfs.c\n+++ b/net/bluetooth/hci_sysfs.c\n@@ -50,7 +50,7 @@ void hci_conn_add_sysfs(struct hci_conn *conn)\n \n \tdev_set_name(&conn->dev, \"%s:%d\", hdev->name, conn->handle);\n \n-\tif (device_add(&conn->dev) < 0) {\n+\tif (device_is_registered(&conn->dev) || device_add(&conn->dev) < 0) {\n \t\tbt_dev_err(hdev, \"failed to register connection device\");\n \t\treturn;\n \t}\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/bluetooth/hci_sysfs.c b/net/bluetooth/hci_sysfs.c\nindex 9874844a95a9..f53463bb0a13 100644\n--- a/net/bluetooth/hci_sysfs.c\n+++ b/net/bluetooth/hci_sysfs.c\n@@ -43,6 +43,16 @@ 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 {\n \tstruct hci_dev *hdev = conn->hdev;\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "ef9605001826ed9db7e9ae5b0c08ec9b347a5148": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 300455b4bc12..06c6828cd65d 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, \"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..a49ae976e382 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -51,6 +51,29 @@ 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+    struct io_sq_data *sq = NULL;\n+    struct io_overflow_cqe *ocqe;\n+    struct io_rings *r;\n+    unsigned int sq_mask, cq_mask;\n+    unsigned int sq_head, sq_tail;\n+    unsigned int cq_head, cq_tail;\n+    unsigned int cq_shift = 0;\n+    unsigned int sq_shift = 0;\n+    unsigned int sq_entries, cq_entries;\n+    bool has_lock;\n+    unsigned int i;\n+\n+    if (!ctx || !(r = ctx->rings))\n+        return;\n+\n+    sq_mask = ctx->sq_entries - 1;\n+    cq_mask = ctx->cq_entries - 1;\n+    sq_head = READ_ONCE(r->sq.head);\n+    sq_tail = READ_ONCE(r->sq.tail);\n+    cq_head = READ_ONCE(r->cq.head);\n+    cq_tail = READ_ONCE(r->cq.tail);\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..2a7c6b903d10 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -51,6 +51,22 @@ 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) return;\n+    struct io_sq_data *sq = NULL;\n+    struct io_overflow_cqe *ocqe;\n+    struct io_rings *r = ctx->rings;\n+    unsigned int sq_mask = ctx->sq_entries - 1, cq_mask = ctx->cq_entries - 1;\n+    unsigned int sq_head = READ_ONCE(r->sq.head);\n+    unsigned int sq_tail = READ_ONCE(r->sq.tail);\n+    unsigned int cq_head = READ_ONCE(r->cq.head);\n+    unsigned int cq_tail = READ_ONCE(r->cq.tail);\n+    unsigned int cq_shift = 0;\n+    unsigned int sq_shift = 0;\n+    unsigned int sq_entries, cq_entries;\n+    bool has_lock;\n+    unsigned int i;\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..5f0bb6ecfe44 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -51,6 +51,25 @@ 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_puts(m, \"Invalid io_uring context\\n\");\n+return;\n+}\n+struct io_sq_data *sq = NULL;\n+struct io_overflow_cqe *ocqe;\n+struct io_rings *r = ctx->rings;\n+unsigned int sq_mask = ctx->sq_entries - 1, cq_mask = ctx->cq_entries - 1;\n+unsigned int sq_head = READ_ONCE(r->sq.head);\n+unsigned int sq_tail = READ_ONCE(r->sq.tail);\n+unsigned int cq_head = READ_ONCE(r->cq.head);\n+unsigned int cq_tail = READ_ONCE(r->cq.tail);\n+unsigned int cq_shift = 0;\n+unsigned int sq_shift = 0;\n+unsigned int sq_entries, cq_entries;\n+bool has_lock;\n+unsigned int i;\n {\n \tstruct io_ring_ctx *ctx = f->private_data;\n \tstruct io_sq_data *sq = NULL;\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..2f5d21d97da1 100644\n--- a/fs/ntfs3/fsntfs.c\n+++ b/fs/ntfs3/fsntfs.c\n@@ -847,12 +847,21 @@ int ntfs_update_mftmirr(struct ntfs_sb_info *sbi, int wait)\n \t\tstruct buffer_head *bh1, *bh2;\n \n \t\tbh1 = sb_bread(sb, block1++);\n+        if (!bh1 || !bh1->b_data) {\n+            err = -EIO;\n+            goto out;\n+        }\n \t\tif (!bh1) {\n \t\t\terr = -EIO;\n \t\t\tgoto out;\n \t\t}\n \n \t\tbh2 = sb_getblk(sb, block2++);\n+        if (!bh2 || !bh2->b_data) {\n+            put_bh(bh1);\n+            err = -EIO;\n+            goto out;\n+        }\n \t\tif (!bh2) {\n \t\t\tput_bh(bh1);\n \t\t\terr = -EIO;\n",
            "diff --git a/fs/ntfs3/fsntfs.c b/fs/ntfs3/fsntfs.c\nindex 3de5700a9b83..e57a49cea058 100644\n--- a/fs/ntfs3/fsntfs.c\n+++ b/fs/ntfs3/fsntfs.c\n@@ -863,7 +863,8 @@ 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 \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..6eef1975d26b 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"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/ntfs3/fsntfs.c b/fs/ntfs3/fsntfs.c\nindex 3de5700a9b83..cfdda6c68bf3 100644\n--- a/fs/ntfs3/fsntfs.c\n+++ b/fs/ntfs3/fsntfs.c\n@@ -847,6 +847,37 @@ int ntfs_update_mftmirr(struct ntfs_sb_info *sbi, int wait)\n \t\tstruct buffer_head *bh1, *bh2;\n \n \t\tbh1 = sb_bread(sb, block1++);\n+        if (!bh1) {\n+            err = -EIO;\n+            goto out;\n+        }\n+\n+        bh2 = sb_getblk(sb, block2++);\n+        if (!bh2) {\n+            put_bh(bh1);\n+            err = -EIO;\n+            goto out;\n+        }\n+\n+        if (buffer_locked(bh2))\n+            __wait_on_buffer(bh2);\n+\n+        lock_buffer(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+        put_bh(bh1);\n+        bh1 = NULL;\n+\n+        if (wait)\n+            err = sync_dirty_buffer(bh2);\n+\n+        put_bh(bh2);\n+        if (err)\n+            goto out;\n+    }\n \t\tif (!bh1) {\n \t\t\terr = -EIO;\n \t\t\tgoto out;\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..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..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"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/qrtr/ns.c b/net/qrtr/ns.c\nindex d8252fdab851..8a41c7ba2316 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,11 @@ 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+\t    }\n+    rcu_read_unlock();\n+\n+    /* Empty notification, to indicate end of listing */\n+    lookup_notify(from, NULL, true);\n \n \treturn 0;\n }\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/qrtr/ns.c b/net/qrtr/ns.c\nindex d8252fdab851..75bf02332699 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(radix_tree_deref_slot(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(radix_tree_deref_slot(srv_slot));\n \t\t\tif (!server_match(srv, &filter))\n \t\t\t\tcontinue;\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "7d3c28ba3d4bf4b26e89ed1f1ca146e0223a2d36": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/security/keys/keyctl.c b/security/keys/keyctl.c\nindex 96a92a645216..cfe522d4eadc 100644\n--- a/security/keys/keyctl.c\n+++ b/security/keys/keyctl.c\n@@ -1838,6 +1838,10 @@ long keyctl_watch_key(key_serial_t id, int watch_queue_fd, int watch_id)\n err_wqueue:\n \tput_watch_queue(wqueue);\n err_key:\n+    if (watch)\n+        kfree(watch);\n+    if (wlist)\n+        kfree(wlist);\n \tkey_put(key);\n \treturn ret;\n }\n",
            "diff --git a/security/keys/keyctl.c b/security/keys/keyctl.c\nindex 96a92a645216..c23865492ee9 100644\n--- a/security/keys/keyctl.c\n+++ b/security/keys/keyctl.c\n@@ -1793,7 +1793,8 @@ long keyctl_watch_key(key_serial_t id, int watch_queue_fd, int watch_id)\n \t\tif (!key->watchers) {\n \t\t\twlist = kzalloc(sizeof(*wlist), GFP_KERNEL);\n \t\t\tif (!wlist)\n-\t\t\t\tgoto err_wqueue;\n+\t\t\t\tkfree(wlist);\n+goto err_wqueue;\n \t\t\tinit_watch_list(wlist, NULL);\n \t\t}\n \n"
        ],
        "error": []
    },
    "1bb51491ca5df96a5f724899d1dbb87afda61419": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "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..3d4c9150b98b 100644\n--- a/net/bluetooth/hci_conn.c\n+++ b/net/bluetooth/hci_conn.c\n@@ -199,7 +199,9 @@ static void le_scan_cleanup(struct work_struct *work)\n \n \tif (c == conn) {\n \t\thci_connect_le_scan_cleanup(conn, 0x00);\n-\t\thci_conn_cleanup(conn);\n+\t\tif (conn) {\n+        hci_conn_cleanup(conn);\n+    }\n \t}\n \n \thci_dev_unlock(hdev);\n@@ -1162,7 +1164,9 @@ int hci_conn_del(struct hci_conn *conn)\n \t * BT_CONNECT_SCAN we *only* want the cleanup part without the\n \t * rest of hci_conn_del.\n \t */\n-\thci_conn_cleanup(conn);\n+\tif (conn) {\n+        hci_conn_cleanup(conn);\n+    }\n \n \treturn 0;\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..255537530bc6 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+n = list_next_entry(c, list);\n \t}\n }\n \n"
        ],
        "error": []
    },
    "4894a6d412735394296e80976329c1a6848acc14": {
        "non_crash": [
            "diff --git a/fs/file_table.c b/fs/file_table.c\nindex e06c68e2d757..efe7a01465a3 100644\n--- a/fs/file_table.c\n+++ b/fs/file_table.c\n@@ -160,7 +160,12 @@ 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->f_rcuhead.func) {\n+    file_free_rcu(&f->f_rcuhead);\n+}\n+else {\n+    pr_warn(\"Attempted to free an invalid file structure\\n\");\n+}\n \t\treturn error;\n \t}\n \n",
            "diff --git a/fs/file_table.c b/fs/file_table.c\nindex e06c68e2d757..de2d8f5faa3d 100644\n--- a/fs/file_table.c\n+++ b/fs/file_table.c\n@@ -160,8 +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\treturn error;\n+\t\t\t\treturn error;\n \t}\n \n \tatomic_long_set(&f->f_count, 1);\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/file_table.c b/fs/file_table.c\nindex e06c68e2d757..5a279de94939 100644\n--- a/fs/file_table.c\n+++ b/fs/file_table.c\n@@ -65,7 +65,8 @@ static void file_free_rcu(struct rcu_head *head)\n {\n \tstruct file *f = container_of(head, struct file, f_rcuhead);\n \n-\tput_cred(f->f_cred);\n+\tif (f->f_cred)\n+    put_cred(f->f_cred);\n \tif (unlikely(f->f_mode & FMODE_BACKING))\n \t\tkfree(backing_file(f));\n \telse\n",
            "diff --git a/fs/file_table.c b/fs/file_table.c\nindex e06c68e2d757..d7ebb5299cb3 100644\n--- a/fs/file_table.c\n+++ b/fs/file_table.c\n@@ -160,7 +160,7 @@ static int init_file(struct file *f, int flags, const struct cred *cred)\n \tf->f_cred = get_cred(cred);\n \terror = security_file_alloc(f);\n \tif (unlikely(error)) {\n-\t\tfile_free_rcu(&f->f_rcuhead);\n+\t\tkmem_cache_free(filp_cachep, f);\n \t\treturn error;\n \t}\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/file_table.c b/fs/file_table.c\nindex e06c68e2d757..5788350d1e4a 100644\n--- a/fs/file_table.c\n+++ b/fs/file_table.c\n@@ -154,6 +154,8 @@ fs_initcall(init_fs_stat_sysctls);\n #endif\n \n static int init_file(struct file *f, int flags, const struct cred *cred)\n+{\n+    INIT_RCU_HEAD(&f->f_rcuhead)\n {\n \tint error;\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "e1c3525a4f4e2e4b6c1f73611ceaf61ef462700c": {
        "non_crash": [
            "diff --git a/drivers/hid/hid-thrustmaster.c b/drivers/hid/hid-thrustmaster.c\nindex a4e20f9e598b..85c0383f57b5 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 <= 1) {\n+        hid_err(hdev, \"Invalid endpoint index\\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",
            "diff --git a/drivers/hid/hid-thrustmaster.c b/drivers/hid/hid-thrustmaster.c\nindex a4e20f9e598b..e0207aad8df8 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+        hid_err(hdev, \"Invalid endpoint index\\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..d4b339b25e6e 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 <= 1) {\n+        hid_err(hdev, \"invalid endpoint index\\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",
            "diff --git a/drivers/hid/hid-thrustmaster.c b/drivers/hid/hid-thrustmaster.c\nindex a4e20f9e598b..58c966922a5a 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 <= 1) {\n+        hid_err(hdev, \"not enough endpoints available\\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..93b21ad5ea33 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 array size exceeds buffer size\\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"
        ],
        "error": []
    },
    "1a201ce4f0f4ab2f165b93d0ce5c15ebe1a5b321": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/sys.c b/kernel/sys.c\nindex 5fd54bf0e886..58f3ce6dce8b 100644\n--- a/kernel/sys.c\n+++ b/kernel/sys.c\n@@ -2331,7 +2331,8 @@ static int prctl_set_vma(unsigned long opt, unsigned long addr,\n \t\tmmap_write_lock(mm);\n \t\terror = madvise_set_anon_name(mm, addr, size, anon_name);\n \t\tmmap_write_unlock(mm);\n-\t\tanon_vma_name_put(anon_name);\n+\t\tif (anon_name)\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..d83dcee12d6c 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..e881de80621a 100644\n--- a/kernel/sys.c\n+++ b/kernel/sys.c\n@@ -2331,7 +2331,8 @@ static int prctl_set_vma(unsigned long opt, unsigned long addr,\n \t\tmmap_write_lock(mm);\n \t\terror = madvise_set_anon_name(mm, addr, size, anon_name);\n \t\tmmap_write_unlock(mm);\n-\t\tanon_vma_name_put(anon_name);\n+\t\tif (anon_name)\n+        anon_vma_name_put(anon_name);\n \t\tbreak;\n \tdefault:\n \t\terror = -EINVAL;\n"
        ],
        "error": []
    },
    "4a547542bb29dc957c096f0c95ef9154e93d68d3": {
        "non_crash": [
            "diff --git a/fs/ext4/indirect.c b/fs/ext4/indirect.c\nindex 07a8c75b65ed..db7516a7d444 100644\n--- a/fs/ext4/indirect.c\n+++ b/fs/ext4/indirect.c\n@@ -1241,7 +1241,12 @@ 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 path depths: start depth %d, end depth %d\", n, n2);\n+    return -EINVAL;\n+}\n+\n+BUG_ON(n > n2);\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..44dc9a6f4edf 100644\n--- a/fs/ext4/indirect.c\n+++ b/fs/ext4/indirect.c\n@@ -1241,7 +1241,8 @@ 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+return -EINVAL;\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..a5dd66c3baf4 100644\n--- a/fs/ext4/indirect.c\n+++ b/fs/ext4/indirect.c\n@@ -1238,7 +1238,8 @@ int ext4_ind_remove_space(handle_t *handle, struct inode *inode,\n \tif ((start >= end) || (start > max_block))\n \t\treturn 0;\n \n-\tn = ext4_block_to_path(inode, start, offsets, NULL);\n+\tif (start > max_block || end > max_block) return -EINVAL;\n+    n = 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"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/indirect.c b/fs/ext4/indirect.c\nindex 07a8c75b65ed..d02245882ef5 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 block range: 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",
                "error_message": "Failed to pull the latest syzkaller"
            }
        ]
    },
    "f7c5a86e747f9b7ce333e7295875cd4ede2c7a0d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/xdp/xdp_umem.c b/net/xdp/xdp_umem.c\nindex f01ef6bda390..8b038928a49d 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 | __GFP_NOWARN | __GFP_RETRY_MAYFAIL);\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..b7cc0a9847bf 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 | __GFP_RETRY_MAYFAIL);\n \tif (!umem->pgs)\n \t\treturn -ENOMEM;\n \n",
            "diff --git a/net/xdp/xdp_umem.c b/net/xdp/xdp_umem.c\nindex f01ef6bda390..0cf9910bb1e7 100644\n--- a/net/xdp/xdp_umem.c\n+++ b/net/xdp/xdp_umem.c\n@@ -99,7 +99,7 @@ static int xdp_umem_pin_pages(struct xdp_umem *umem, unsigned long address)\n \tlong npgs;\n \tint err;\n \n-\tumem->pgs = kvcalloc(umem->npgs, sizeof(*umem->pgs), GFP_KERNEL | __GFP_NOWARN);\n+\tumem->pgs = kvcalloc(umem->npgs, sizeof(*umem->pgs), GFP_KERNEL);\n \tif (!umem->pgs)\n \t\treturn -ENOMEM;\n \n",
            "diff --git a/net/xdp/xdp_umem.c b/net/xdp/xdp_umem.c\nindex f01ef6bda390..0cf9910bb1e7 100644\n--- a/net/xdp/xdp_umem.c\n+++ b/net/xdp/xdp_umem.c\n@@ -99,7 +99,7 @@ static int xdp_umem_pin_pages(struct xdp_umem *umem, unsigned long address)\n \tlong npgs;\n \tint err;\n \n-\tumem->pgs = kvcalloc(umem->npgs, sizeof(*umem->pgs), GFP_KERNEL | __GFP_NOWARN);\n+\tumem->pgs = kvcalloc(umem->npgs, sizeof(*umem->pgs), GFP_KERNEL);\n \tif (!umem->pgs)\n \t\treturn -ENOMEM;\n \n",
            "diff --git a/net/xdp/xdp_umem.c b/net/xdp/xdp_umem.c\nindex f01ef6bda390..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": []
    },
    "14f3125f37b7c76896b25c222159f6c205ff7e08": {
        "non_crash": [
            "diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c\nindex 7da343efd090..96993bdc63be 100644\n--- a/net/mac80211/cfg.c\n+++ b/net/mac80211/cfg.c\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 < 4)\n \t\tkey->conf.flags |= IEEE80211_KEY_FLAG_PAIRWISE;\n \n \tif (params->mode == NL80211_KEY_NO_TX)\n@@ -517,7 +517,7 @@ 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 < 4)\n \t\t\tkey = key_mtx_dereference(local, sta->ptk[key_idx]);\n \t\telse\n \t\t\tkey = key_mtx_dereference(local, sta->gtk[key_idx]);\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c\nindex 7da343efd090..b8c786eeacf9 100644\n--- a/net/mac80211/cfg.c\n+++ b/net/mac80211/cfg.c\n@@ -426,7 +426,12 @@ 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 (key_idx >= 4) {\n+        ret = -EINVAL;\n+        goto out_unlock;\n+    }\n+\n+    if (pairwise)\n \t\tkey->conf.flags |= IEEE80211_KEY_FLAG_PAIRWISE;\n \n \tif (params->mode == NL80211_KEY_NO_TX)\n@@ -517,7 +522,12 @@ 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 (key_idx >= 4) {\n+        ret = -EINVAL;\n+        goto out_unlock;\n+    }\n+\n+    if (pairwise)\n \t\t\tkey = key_mtx_dereference(local, sta->ptk[key_idx]);\n \t\telse\n \t\t\tkey = key_mtx_dereference(local, sta->gtk[key_idx]);\n",
                "error_message": "Failed to build"
            },
            {
                "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..fb8e4a629440 100644\n--- a/net/mac80211/cfg.c\n+++ b/net/mac80211/cfg.c\n@@ -499,6 +499,10 @@ static int ieee80211_add_key(struct wiphy *wiphy, struct net_device *dev,\n }\n \n static int ieee80211_del_key(struct wiphy *wiphy, struct net_device *dev,\n+int key_idx) {\n+if (key_idx >= NUM_DEFAULT_KEYS && key_idx >= NUM_DEFAULT_MGMT_KEYS && key_idx >= NUM_DEFAULT_BEACON_KEYS) {\n+return -EINVAL;\n+}\n \t\t\t     u8 key_idx, bool pairwise, const u8 *mac_addr)\n {\n \tstruct ieee80211_sub_if_data *sdata = IEEE80211_DEV_TO_SUB_IF(dev);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "cdaf5ed409125df023889aefe50b4cc4a41c0973": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/namei.c b/fs/namei.c\nindex edfedfbccaef..5e1af48be800 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -4165,7 +4165,7 @@ int do_rmdir(int dfd, struct filename *name)\n \tif (error)\n \t\tgoto exit2;\n \n-\tinode_lock_nested(path.dentry->d_inode, I_MUTEX_PARENT);\n+\tinode_lock(path.dentry->d_inode);\n \tdentry = __lookup_hash(&last, path.dentry, lookup_flags);\n \terror = PTR_ERR(dentry);\n \tif (IS_ERR(dentry))\n@@ -4298,7 +4298,7 @@ int do_unlinkat(int dfd, struct filename *name)\n \tif (error)\n \t\tgoto exit2;\n retry_deleg:\n-\tinode_lock_nested(path.dentry->d_inode, I_MUTEX_PARENT);\n+\tinode_lock(path.dentry->d_inode);\n \tdentry = __lookup_hash(&last, path.dentry, lookup_flags);\n \terror = PTR_ERR(dentry);\n \tif (!IS_ERR(dentry)) {\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/namei.c b/fs/namei.c\nindex edfedfbccaef..5f07355acd00 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -2573,7 +2573,8 @@ 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\tif (rwsem_owner(&path->dentry->d_inode->i_rwsem) == current)\n+        inode_unlock(path->dentry->d_inode);\n \t\tpath_put(path);\n \t}\n \treturn d;\n@@ -3833,7 +3834,8 @@ 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+\tif (rwsem_owner(&path->dentry->d_inode->i_rwsem) == current)\n+        inode_unlock(path->dentry->d_inode);\n \tif (!err2)\n \t\tmnt_drop_write(path->mnt);\n out:\n@@ -3855,7 +3857,8 @@ EXPORT_SYMBOL(kern_path_create);\n void done_path_create(struct path *path, struct dentry *dentry)\n {\n \tdput(dentry);\n-\tinode_unlock(path->dentry->d_inode);\n+\tif (rwsem_owner(&path->dentry->d_inode->i_rwsem) == current)\n+        inode_unlock(path->dentry->d_inode);\n \tmnt_drop_write(path->mnt);\n \tpath_put(path);\n }\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/namei.c b/fs/namei.c\nindex edfedfbccaef..b26af4a33450 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -4403,6 +4403,44 @@ int vfs_symlink(struct mnt_idmap *idmap, struct inode *dir,\n EXPORT_SYMBOL(vfs_symlink);\n \n int do_symlinkat(struct filename *from, int newdfd, struct filename *to)\n+{\n+    struct inode *inode;\n+    int error;\n+    struct dentry *dentry;\n+    struct path path;\n+    unsigned int lookup_flags = 0;\n+\n+    if (IS_ERR(from)) {\n+        error = PTR_ERR(from);\n+        goto out_putnames;\n+    }\n+\n+retry:\n+    dentry = filename_create(newdfd, to, &path, lookup_flags);\n+    error = PTR_ERR(dentry);\n+    if (IS_ERR(dentry))\n+        goto out_putnames;\n+\n+    inode = dentry->d_inode;\n+    inode_lock(inode);\n+\n+    error = security_path_symlink(&path, dentry, from->name);\n+    if (!error)\n+        error = vfs_symlink(mnt_idmap(path.mnt), path.dentry->d_inode, dentry, from->name);\n+\n+    inode_unlock(inode);\n+\n+    done_path_create(&path, dentry);\n+    if (retry_estale(error, lookup_flags)) {\n+        lookup_flags |= LOOKUP_REVAL;\n+        goto retry;\n+    }\n+\n+out_putnames:\n+    putname(to);\n+    putname(from);\n+    return error;\n+}\n {\n \tint error;\n \tstruct dentry *dentry;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/namei.c b/fs/namei.c\nindex edfedfbccaef..de1bb4338f3b 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -3950,6 +3950,7 @@ static int do_mknodat(int dfd, struct filename *name, umode_t mode,\n \tif (error)\n \t\tgoto out1;\n retry:\n+inode_lock_nested(path.dentry->d_inode, I_MUTEX_PARENT);\n \tdentry = filename_create(dfd, name, &path, lookup_flags);\n \terror = PTR_ERR(dentry);\n \tif (IS_ERR(dentry))\n@@ -4050,6 +4051,7 @@ int do_mkdirat(int dfd, struct filename *name, umode_t mode)\n \tunsigned int lookup_flags = LOOKUP_DIRECTORY;\n \n retry:\n+inode_lock_nested(path.dentry->d_inode, I_MUTEX_PARENT);\n \tdentry = filename_create(dfd, name, &path, lookup_flags);\n \terror = PTR_ERR(dentry);\n \tif (IS_ERR(dentry))\n@@ -4145,6 +4147,7 @@ int do_rmdir(int dfd, struct filename *name)\n \tint type;\n \tunsigned int lookup_flags = 0;\n retry:\n+inode_lock_nested(path.dentry->d_inode, I_MUTEX_PARENT);\n \terror = filename_parentat(dfd, name, lookup_flags, &path, &last, &type);\n \tif (error)\n \t\tgoto exit1;\n@@ -4286,6 +4289,7 @@ int do_unlinkat(int dfd, struct filename *name)\n \tstruct inode *delegated_inode = NULL;\n \tunsigned int lookup_flags = 0;\n retry:\n+inode_lock_nested(path.dentry->d_inode, I_MUTEX_PARENT);\n \terror = filename_parentat(dfd, name, lookup_flags, &path, &last, &type);\n \tif (error)\n \t\tgoto exit1;\n@@ -4414,6 +4418,7 @@ int do_symlinkat(struct filename *from, int newdfd, struct filename *to)\n \t\tgoto out_putnames;\n \t}\n retry:\n+inode_lock_nested(path.dentry->d_inode, I_MUTEX_PARENT);\n \tdentry = filename_create(newdfd, to, &path, lookup_flags);\n \terror = PTR_ERR(dentry);\n \tif (IS_ERR(dentry))\n@@ -4570,6 +4575,7 @@ int do_linkat(int olddfd, struct filename *old, int newdfd,\n \tif (flags & AT_SYMLINK_FOLLOW)\n \t\thow |= LOOKUP_FOLLOW;\n retry:\n+inode_lock_nested(path.dentry->d_inode, I_MUTEX_PARENT);\n \terror = filename_lookup(olddfd, old, how, &old_path, NULL);\n \tif (error)\n \t\tgoto out_putnames;\n@@ -4833,6 +4839,7 @@ int do_renameat2(int olddfd, struct filename *from, int newdfd,\n \t\ttarget_flags = 0;\n \n retry:\n+inode_lock_nested(path.dentry->d_inode, I_MUTEX_PARENT);\n \terror = filename_parentat(olddfd, from, lookup_flags, &old_path,\n \t\t\t\t  &old_last, &old_type);\n \tif (error)\n@@ -5109,6 +5116,7 @@ int page_symlink(struct inode *inode, const char *symname, int len)\n \tunsigned int flags;\n \n retry:\n+inode_lock_nested(path.dentry->d_inode, I_MUTEX_PARENT);\n \tif (nofs)\n \t\tflags = memalloc_nofs_save();\n \terr = aops->write_begin(NULL, mapping, 0, len-1, &page, &fsdata);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "ca2299cf11b3e3d3d0f44ac479410a14eecbd326": {
        "non_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",
            "diff --git a/net/qrtr/qrtr.c b/net/qrtr/qrtr.c\nindex b4c0db0b7d31..0e0f065e2ce6 100644\n--- a/net/qrtr/qrtr.c\n+++ b/net/qrtr/qrtr.c\n@@ -695,7 +695,12 @@ 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+        mutex_unlock(&qrtr_port_lock);\n+        return -EINVAL;\n+    }\n+\n+    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"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/qrtr/qrtr.c b/net/qrtr/qrtr.c\nindex b4c0db0b7d31..042fbe87e58f 100644\n--- a/net/qrtr/qrtr.c\n+++ b/net/qrtr/qrtr.c\n@@ -691,6 +691,9 @@ static void qrtr_port_remove(struct qrtr_sock *ipc)\n  *   >QRTR_MIN_EPH_SOCKET: Specified; available to all\n  */\n static int qrtr_port_assign(struct qrtr_sock *ipc, int *port)\n+{\n+    if (*port < 0)\n+        return -EINVAL;\n {\n \tint rc;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/qrtr/qrtr.c b/net/qrtr/qrtr.c\nindex b4c0db0b7d31..fc1b467396eb 100644\n--- a/net/qrtr/qrtr.c\n+++ b/net/qrtr/qrtr.c\n@@ -691,6 +691,10 @@ static void qrtr_port_remove(struct qrtr_sock *ipc)\n  *   >QRTR_MIN_EPH_SOCKET: Specified; available to all\n  */\n static int qrtr_port_assign(struct qrtr_sock *ipc, int *port)\n+{\n+    if (*port < 0) {\n+        return -EINVAL;\n+    }\n {\n \tint rc;\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "e675fbaf856bd1465eed8b8f51ae182b58b8d656": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex bc0f15257b49..59fe58e352ff 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -2090,7 +2090,7 @@ static void cleanup_group_ids(struct mount *mnt, struct mount *end)\n \n \tfor (p = mnt; p != end; p = next_mnt(p, mnt)) {\n \t\tif (p->mnt_group_id && !IS_MNT_SHARED(p))\n-\t\t\tmnt_release_group_id(p);\n+\t\t\tif (p) mnt_release_group_id(p);\n \t}\n }\n \n",
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex bc0f15257b49..f1d1e22bcabd 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -2089,7 +2089,7 @@ static void cleanup_group_ids(struct mount *mnt, struct mount *end)\n \tstruct mount *p;\n \n \tfor (p = mnt; p != end; p = next_mnt(p, mnt)) {\n-\t\tif (p->mnt_group_id && !IS_MNT_SHARED(p))\n+\t\tif (p->mnt_group_id > 0 && !IS_MNT_SHARED(p))\n \t\t\tmnt_release_group_id(p);\n \t}\n }\n",
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex bc0f15257b49..1b9eb20ab047 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -2099,7 +2099,7 @@ static int invent_group_ids(struct mount *mnt, bool recurse)\n \tstruct mount *p;\n \n \tfor (p = mnt; p; p = recurse ? next_mnt(p, mnt) : NULL) {\n-\t\tif (!p->mnt_group_id && !IS_MNT_SHARED(p)) {\n+\t\tif (p && !p->mnt_group_id && !IS_MNT_SHARED(p)) {\n \t\t\tint err = mnt_alloc_group_id(p);\n \t\t\tif (err) {\n \t\t\t\tcleanup_group_ids(mnt, p);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/namespace.c b/fs/namespace.c\nindex bc0f15257b49..d4986009c30f 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -156,6 +156,13 @@ 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->mnt_group_id == 0)\n+        return;\n+    ida_free(&mnt_group_ida, mnt->mnt_group_id);\n+    mnt->mnt_group_id = 0;\n+}\n+\n {\n \tida_free(&mnt_group_ida, mnt->mnt_group_id);\n \tmnt->mnt_group_id = 0;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "0987d64a09e1eb9642824a088eb331dbdb2db644": {
        "non_crash": [
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 0194a36d0b36..3ee70a2b66de 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -12645,7 +12645,8 @@ static int check_map_prog_compatibility(struct bpf_verifier_env *env,\n \t\t\tverbose(env, \"perf_event programs can only use preallocated hash map\\n\");\n \t\t\treturn -EINVAL;\n \t\t}\n-\t\tif (IS_ENABLED(CONFIG_PREEMPT_RT)) {\n+\t\t// Enforce preallocated maps for all trace type programs\n+if (true) {\n \t\t\tverbose(env, \"trace type programs can only use preallocated hash map\\n\");\n \t\t\treturn -EINVAL;\n \t\t}\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 0194a36d0b36..eb85177344f7 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -12641,6 +12641,7 @@ static int check_map_prog_compatibility(struct bpf_verifier_env *env,\n \t * the unsafety and can fix their programs before this is enforced.\n \t */\n \tif (is_tracing_prog_type(prog_type) && !is_preallocated_map(map)) {\n+verbose(env, \"trace type programs must use preallocated hash maps. Ensure all maps are preallocated.\");\n \t\tif (prog_type == BPF_PROG_TYPE_PERF_EVENT) {\n \t\t\tverbose(env, \"perf_event programs can only use preallocated hash map\\n\");\n \t\t\treturn -EINVAL;\n",
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 0194a36d0b36..4a5da85c6300 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 configuring your program to use preallocated maps for enhanced safety.\\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",
            "diff --git a/Documentation/bpf/map_hash.rst b/Documentation/bpf/map_hash.rst\nindex e85120878b27..c4cb52c72fc4 100644\n--- a/Documentation/bpf/map_hash.rst\n+++ b/Documentation/bpf/map_hash.rst\n@@ -63,6 +63,12 @@ Hash entries can be deleted using the ``bpf_map_delete_elem()``\n helper. This helper will return 0 on success, or negative error in case\n of failure.\n \n+Preallocation Guidance\n+----------------------\n+\n+For trace-type BPF programs, it is crucial to use preallocated hash maps to ensure safety and compatibility, especially in real-time kernels. Avoid setting the BPF_F_NO_PREALLOC flag for maps used by trace-type BPF programs, as runtime allocation can lead to unsafe behavior.\n+\n+Ensure map types and flags are configured to enable preallocation whenever trace-type programs are involved. This practice helps prevent warnings and potential issues related to run-time allocations.\n Per CPU Hashes\n --------------\n \n"
        ],
        "error": []
    },
    "17ba20e86ace8566cff1a3ace9042a779bd8bb7c": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/drivers/char/hw_random/core.c b/drivers/char/hw_random/core.c\nindex a3db27916256..2229b498952c 100644\n--- a/drivers/char/hw_random/core.c\n+++ b/drivers/char/hw_random/core.c\n@@ -214,11 +214,11 @@ static ssize_t rng_dev_read(struct file *filp, char __user *buf,\n \t\trng = get_current_rng();\n \t\tif (IS_ERR(rng)) {\n \t\t\terr = PTR_ERR(rng);\n-\t\t\tgoto out;\n+\t\t\tgoto out_unlock;\n \t\t}\n \t\tif (!rng) {\n \t\t\terr = -ENODEV;\n-\t\t\tgoto out;\n+\t\t\tgoto out_unlock;\n \t\t}\n \n \t\tif (mutex_lock_interruptible(&reading_mutex)) {\n@@ -266,7 +266,7 @@ static ssize_t rng_dev_read(struct file *filp, char __user *buf,\n \n \t\tif (signal_pending(current)) {\n \t\t\terr = -ERESTARTSYS;\n-\t\t\tgoto out;\n+\t\t\tgoto out_unlock;\n \t\t}\n \t}\n out:\n@@ -276,7 +276,7 @@ static ssize_t rng_dev_read(struct file *filp, char __user *buf,\n \tmutex_unlock(&reading_mutex);\n out_put:\n \tput_rng(rng);\n-\tgoto out;\n+\tgoto out_unlock;\n }\n \n static const struct file_operations rng_chrdev_ops = {\n@@ -467,7 +467,7 @@ int hwrng_register(struct hwrng *rng)\n \tbool is_new_current = false;\n \n \tif (!rng->name || (!rng->data_read && !rng->read))\n-\t\tgoto out;\n+\t\tgoto out_unlock;\n \n \tmutex_lock(&rng_mutex);\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/usb/misc/chaoskey.c b/drivers/usb/misc/chaoskey.c\nindex 87067c3d6109..2dfb8ca43698 100644\n--- a/drivers/usb/misc/chaoskey.c\n+++ b/drivers/usb/misc/chaoskey.c\n@@ -234,7 +234,21 @@ static void chaoskey_disconnect(struct usb_interface *interface)\n \tusb_deregister_dev(interface, &chaoskey_class);\n \n \tusb_set_intfdata(interface, NULL);\n-\tmutex_lock(&dev->lock);\n+\tmutex_unlock(&dev->rng_lock);\n+\n+    // Release rng_lock before lengthy wait operation\n+    mutex_unlock(&dev->lock);\n+\n+    result = wait_event_interruptible_timeout(\n+        dev->wait_q,\n+        !dev->reading,\n+        (started ? NAK_TIMEOUT : ALEA_FIRST_TIMEOUT) );\n+\n+    // Re-acquire locks after wait\n+    mutex_lock(&dev->lock);\n+    mutex_lock(&dev->rng_lock);\n+\n+    mutex_unlock(&dev->rng_lock);;\n \n \tdev->present = false;\n \tusb_poison_urb(dev->urb);\n@@ -267,7 +281,21 @@ static int chaoskey_open(struct inode *inode, struct file *file)\n \t}\n \n \tfile->private_data = dev;\n-\tmutex_lock(&dev->lock);\n+\tmutex_unlock(&dev->rng_lock);\n+\n+    // Release rng_lock before lengthy wait operation\n+    mutex_unlock(&dev->lock);\n+\n+    result = wait_event_interruptible_timeout(\n+        dev->wait_q,\n+        !dev->reading,\n+        (started ? NAK_TIMEOUT : ALEA_FIRST_TIMEOUT) );\n+\n+    // Re-acquire locks after wait\n+    mutex_lock(&dev->lock);\n+    mutex_lock(&dev->rng_lock);\n+\n+    mutex_unlock(&dev->rng_lock);;\n \t++dev->open;\n \tmutex_unlock(&dev->lock);\n \n@@ -287,7 +315,21 @@ static int chaoskey_release(struct inode *inode, struct file *file)\n \n \tusb_dbg(interface, \"release\");\n \n-\tmutex_lock(&dev->lock);\n+\tmutex_unlock(&dev->rng_lock);\n+\n+    // Release rng_lock before lengthy wait operation\n+    mutex_unlock(&dev->lock);\n+\n+    result = wait_event_interruptible_timeout(\n+        dev->wait_q,\n+        !dev->reading,\n+        (started ? NAK_TIMEOUT : ALEA_FIRST_TIMEOUT) );\n+\n+    // Re-acquire locks after wait\n+    mutex_lock(&dev->lock);\n+    mutex_lock(&dev->rng_lock);\n+\n+    mutex_unlock(&dev->rng_lock);;\n \n \tusb_dbg(interface, \"open count at release is %d\", dev->open);\n \n@@ -495,7 +537,21 @@ static int chaoskey_rng_read(struct hwrng *rng, void *data,\n \t */\n \tmutex_lock(&dev->rng_lock);\n \n-\tmutex_lock(&dev->lock);\n+\tmutex_unlock(&dev->rng_lock);\n+\n+    // Release rng_lock before lengthy wait operation\n+    mutex_unlock(&dev->lock);\n+\n+    result = wait_event_interruptible_timeout(\n+        dev->wait_q,\n+        !dev->reading,\n+        (started ? NAK_TIMEOUT : ALEA_FIRST_TIMEOUT) );\n+\n+    // Re-acquire locks after wait\n+    mutex_lock(&dev->lock);\n+    mutex_lock(&dev->rng_lock);\n+\n+    mutex_unlock(&dev->rng_lock);;\n \n \tmutex_unlock(&dev->rng_lock);\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/char/hw_random/core.c b/drivers/char/hw_random/core.c\nindex a3db27916256..019c4e511232 100644\n--- a/drivers/char/hw_random/core.c\n+++ b/drivers/char/hw_random/core.c\n@@ -138,7 +138,8 @@ 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+\tif (mutex_lock_interruptible(&rng_mutex))\n+        return -ERESTARTSYS;\n \tif (rng)\n \t\tkref_put(&rng->ref, cleanup_rng);\n \tmutex_unlock(&rng_mutex);\n@@ -469,7 +470,8 @@ 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+\tif (mutex_lock_interruptible(&rng_mutex))\n+        return -ERESTARTSYS;\n \n \t/* Must not register two RNGs with the same name. */\n \terr = -EEXIST;\n@@ -531,7 +533,8 @@ void hwrng_unregister(struct hwrng *rng)\n \tstruct hwrng *old_rng, *new_rng;\n \tint err;\n \n-\tmutex_lock(&rng_mutex);\n+\tif (mutex_lock_interruptible(&rng_mutex))\n+        return -ERESTARTSYS;\n \n \told_rng = current_rng;\n \tlist_del(&rng->list);\n@@ -629,7 +632,8 @@ static int __init hwrng_modinit(void)\n \n static void __exit hwrng_modexit(void)\n {\n-\tmutex_lock(&rng_mutex);\n+\tif (mutex_lock_interruptible(&rng_mutex))\n+        return -ERESTARTSYS;\n \tBUG_ON(current_rng);\n \tkfree(rng_buffer);\n \tkfree(rng_fillbuf);\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..d8f1b8ab31da 100644\n--- a/net/netfilter/ipset/ip_set_core.c\n+++ b/net/netfilter/ipset/ip_set_core.c\n@@ -354,6 +354,8 @@ ip_set_init_comment(struct ip_set *set, struct ip_set_comment *comment,\n \t\t    const struct ip_set_ext *ext)\n {\n \tstruct ip_set_comment_rcu *c = rcu_dereference_protected(comment->c, 1);\n+if (unlikely(!c || !c->str))\n+return;\n \tsize_t len = ext->comment ? strlen(ext->comment) : 0;\n \n \tif (unlikely(c)) {\n@@ -397,6 +399,8 @@ ip_set_comment_free(struct ip_set *set, void *ptr)\n \tstruct ip_set_comment_rcu *c;\n \n \tc = rcu_dereference_protected(comment->c, 1);\n+if (unlikely(!c || !c->str))\n+return;\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..2ba1dd098d31 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",
            "diff --git a/net/netfilter/ipset/ip_set_core.c b/net/netfilter/ipset/ip_set_core.c\nindex 8dd17589217d..1aa7b88e86ee 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 (likely(c && 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 (likely(c && 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..7d2c486261e7 100644\n--- a/net/netfilter/ipset/ip_set_core.c\n+++ b/net/netfilter/ipset/ip_set_core.c\n@@ -354,7 +354,7 @@ ip_set_init_comment(struct ip_set *set, struct ip_set_comment *comment,\n \t\t    const struct ip_set_ext *ext)\n {\n \tstruct ip_set_comment_rcu *c = rcu_dereference_protected(comment->c, 1);\n-\tsize_t len = ext->comment ? strlen(ext->comment) : 0;\n+\tsize_t len = ext->comment && ext->comment[0] ? strlen(ext->comment) : 0;\n \n \tif (unlikely(c)) {\n \t\tset->ext_size -= sizeof(*c) + strlen(c->str) + 1;\n"
        ],
        "error": []
    },
    "4b5b6bdc090752dbcdd7e220a4703fed752cdfe7": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/page.c b/fs/nilfs2/page.c\nindex 5cf30827f244..a18e5d7adb08 100644\n--- a/fs/nilfs2/page.c\n+++ b/fs/nilfs2/page.c\n@@ -385,7 +385,8 @@ void nilfs_clear_dirty_pages(struct address_space *mapping, bool silent)\n  */\n void nilfs_clear_dirty_page(struct page *page, bool silent)\n {\n-\tstruct inode *inode = page->mapping->host;\n+\tif (!page->mapping) return;\n+    struct inode *inode = page->mapping->host;\n \tstruct super_block *sb = inode->i_sb;\n \n \tBUG_ON(!PageLocked(page));\n",
            "diff --git a/fs/nilfs2/page.c b/fs/nilfs2/page.c\nindex 5cf30827f244..35d114e44061 100644\n--- a/fs/nilfs2/page.c\n+++ b/fs/nilfs2/page.c\n@@ -385,7 +385,11 @@ void nilfs_clear_dirty_pages(struct address_space *mapping, bool silent)\n  */\n void nilfs_clear_dirty_page(struct page *page, bool silent)\n {\n-\tstruct inode *inode = page->mapping->host;\n+\tstruct inode *inode;\n+\n+    if (!page->mapping)\n+        return;\n+    inode = page->mapping->host;\n \tstruct super_block *sb = inode->i_sb;\n \n \tBUG_ON(!PageLocked(page));\n",
            "diff --git a/fs/nilfs2/page.c b/fs/nilfs2/page.c\nindex 5cf30827f244..a18e5d7adb08 100644\n--- a/fs/nilfs2/page.c\n+++ b/fs/nilfs2/page.c\n@@ -385,7 +385,8 @@ void nilfs_clear_dirty_pages(struct address_space *mapping, bool silent)\n  */\n void nilfs_clear_dirty_page(struct page *page, bool silent)\n {\n-\tstruct inode *inode = page->mapping->host;\n+\tif (!page->mapping) return;\n+    struct inode *inode = page->mapping->host;\n \tstruct super_block *sb = inode->i_sb;\n \n \tBUG_ON(!PageLocked(page));\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/nilfs2/page.c b/fs/nilfs2/page.c\nindex 5cf30827f244..69dbb46a68db 100644\n--- a/fs/nilfs2/page.c\n+++ b/fs/nilfs2/page.c\n@@ -168,7 +168,8 @@ void nilfs_page_bug(struct page *page)\n \t       page, page_ref_count(page),\n \t       (unsigned long long)page->index, page->flags, m, ino);\n \n-\tif (page_has_buffers(page)) {\n+\tif (!page_has_buffers(page)) return;\n+    if (page_has_buffers(page)) {\n \t\tstruct buffer_head *bh, *head;\n \t\tint i = 0;\n \n@@ -384,6 +385,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@@ -397,7 +400,8 @@ void nilfs_clear_dirty_page(struct page *page, bool silent)\n \tClearPageUptodate(page);\n \tClearPageMappedToDisk(page);\n \n-\tif (page_has_buffers(page)) {\n+\tif (!page_has_buffers(page)) return;\n+    if (page_has_buffers(page)) {\n \t\tstruct buffer_head *bh, *head;\n \t\tconst unsigned long clear_bits =\n \t\t\t(BIT(BH_Uptodate) | BIT(BH_Dirty) | BIT(BH_Mapped) |\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/nilfs2/page.c b/fs/nilfs2/page.c\nindex 5cf30827f244..bf322ddf4291 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; // Prevent null pointer dereference\n+    }\n {\n \tstruct inode *inode = page->mapping->host;\n \tstruct super_block *sb = inode->i_sb;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "39b560f8c5d46a5c107b83c6a1e8ae4051826de0": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/ethtool/pse-pd.c b/net/ethtool/pse-pd.c\nindex 5a471e115b66..47ace3539faf 100644\n--- a/net/ethtool/pse-pd.c\n+++ b/net/ethtool/pse-pd.c\n@@ -60,7 +60,9 @@ static int pse_prepare_data(const struct ethnl_req_info *req_base,\n \tstruct net_device *dev = reply_base->dev;\n \tint ret;\n \n-\tret = ethnl_ops_begin(dev);\n+\tif (!dev) return -ENODEV;\n+\n+    ret = ethnl_ops_begin(dev);\n \tif (ret < 0)\n \t\treturn ret;\n \n",
            "diff --git a/net/ethtool/pse-pd.c b/net/ethtool/pse-pd.c\nindex 5a471e115b66..c2973b2c1250 100644\n--- a/net/ethtool/pse-pd.c\n+++ b/net/ethtool/pse-pd.c\n@@ -64,7 +64,13 @@ 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+        NL_SET_ERR_MSG(info->extack, \"No valid PSE is attached\");\n+        ethnl_ops_complete(dev);\n+        return -EOPNOTSUPP;\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..0760292258d5 100644\n--- a/net/ethtool/pse-pd.c\n+++ b/net/ethtool/pse-pd.c\n@@ -58,6 +58,10 @@ static int pse_prepare_data(const struct ethnl_req_info *req_base,\n {\n \tstruct pse_reply_data *data = PSE_REPDATA(reply_base);\n \tstruct net_device *dev = reply_base->dev;\n+    if (!dev->phydev) {\n+        NL_SET_ERR_MSG(info->extack, \"No PHY is attached\");\n+        return -EOPNOTSUPP;\n+    }\n \tint ret;\n \n \tret = ethnl_ops_begin(dev);\n",
            "diff --git a/net/ethtool/pse-pd.c b/net/ethtool/pse-pd.c\nindex 5a471e115b66..1435db6971fe 100644\n--- a/net/ethtool/pse-pd.c\n+++ b/net/ethtool/pse-pd.c\n@@ -60,6 +60,9 @@ static int pse_prepare_data(const struct ethnl_req_info *req_base,\n \tstruct net_device *dev = reply_base->dev;\n \tint ret;\n \n+if (!dev)\n+return -EINVAL;\n+\n \tret = ethnl_ops_begin(dev);\n \tif (ret < 0)\n \t\treturn ret;\n"
        ],
        "error": []
    },
    "544afab64e441605326c54f7c2d4aa9bab2419ff": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netrom/af_netrom.c b/net/netrom/af_netrom.c\nindex 6f7f4392cffb..e08a28859206 100644\n--- a/net/netrom/af_netrom.c\n+++ b/net/netrom/af_netrom.c\n@@ -431,6 +431,8 @@ 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+    if (!sk)\n+        return -ENOMEM;\n \tif (sk  == NULL)\n \t\treturn -ENOMEM;\n \n"
        ],
        "error": []
    },
    "3f5d1a7de17359e085f9a912eae7bf7e89dc7435": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 2c351765c409..2300d25a5091 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 (!wqueue->defunct && lock_wqueue(wqueue)) {\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 (!wqueue->defunct && lock_wqueue(wqueue)) {\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 (!wqueue->defunct && lock_wqueue(wqueue)) {\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..952ed7e9b852 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -217,7 +217,7 @@ void __post_watch_notification(struct watch_list *wlist,\n \t\tn->info &= ~WATCH_INFO_ID;\n \t\tn->info |= watch->info_id;\n \n-\t\twqueue = rcu_dereference(watch->queue);\n+\t\twqueue = get_watch_queue(watch->queue);\n \t\twf = rcu_dereference(wqueue->filter);\n \t\tif (wf && !filter_watch_notification(wf, n))\n \t\t\tcontinue;\n@@ -544,7 +544,7 @@ int remove_watch_from_object(struct watch_list *wlist, struct watch_queue *wq,\n \tif (id != 0)\n \t\tn.watch.info = watch->info_id | watch_sizeof(n);\n \n-\twqueue = rcu_dereference(watch->queue);\n+\twqueue = get_watch_queue(watch->queue);\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..7eb34db4688f 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 (unlikely(!wqueue || 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 (unlikely(!wqueue || wqueue->defunct))\n+            continue;\n \n \tif (lock_wqueue(wqueue)) {\n \t\tpost_one_notification(wqueue, &n.watch);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "384b9a05e5d4c3e74e31427e43a08f40f71db54a": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/fs/afs/super.c b/fs/afs/super.c\nindex 95d713074dc8..e81c4eeca190 100644\n--- a/fs/afs/super.c\n+++ b/fs/afs/super.c\n@@ -427,7 +427,11 @@ static int afs_test_super(struct super_block *sb, struct fs_context *fc)\n \t\t!as->dyn_root);\n }\n \n-static int afs_dynroot_test_super(struct super_block *sb, struct fs_context *fc)\n+static int afs_dynroot_test_super(struct super_block *sb, struct fs_context *fc) {\n+    struct afs_super_info *as = AFS_FS_S(sb);\n+    if (!as) {\n+        return 0; // Invalid or freed super_info\n+    }\n {\n \tstruct afs_super_info *as = AFS_FS_S(sb);\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/afs/super.c b/fs/afs/super.c\nindex 95d713074dc8..666d23129846 100644\n--- a/fs/afs/super.c\n+++ b/fs/afs/super.c\n@@ -428,6 +428,10 @@ 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+    struct afs_super_info *as = AFS_FS_S(sb);\n+\n+    if (!as || !as->dyn_root) return 0;\n {\n \tstruct afs_super_info *as = AFS_FS_S(sb);\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/afs/super.c b/fs/afs/super.c\nindex 95d713074dc8..7d13fec4a394 100644\n--- a/fs/afs/super.c\n+++ b/fs/afs/super.c\n@@ -40,6 +40,13 @@ static int afs_show_options(struct seq_file *m, struct dentry *root);\n static int afs_init_fs_context(struct fs_context *fc);\n static const struct fs_parameter_spec afs_fs_parameters[];\n \n+struct afs_super_info {\n+    struct net *net_ns;\n+    struct afs_cell *cell;\n+    struct afs_volume *volume;\n+    bool dyn_root;\n+    atomic_t refcount;\n+};\n struct file_system_type afs_fs_type = {\n \t.owner\t\t\t= THIS_MODULE,\n \t.name\t\t\t= \"afs\",\n@@ -507,6 +514,7 @@ static struct afs_super_info *afs_alloc_sbi(struct fs_context *fc)\n \tstruct afs_super_info *as;\n \n \tas = kzalloc(sizeof(struct afs_super_info), GFP_KERNEL);\n+    atomic_set(&as->refcount, 1);\n \tif (as) {\n \t\tas->net_ns = get_net(fc->net_ns);\n \t\tas->flock_mode = ctx->flock_mode;\n@@ -528,7 +536,8 @@ static void afs_destroy_sbi(struct afs_super_info *as)\n \t\tafs_put_volume(net, as->volume, afs_volume_trace_put_destroy_sbi);\n \t\tafs_unuse_cell(net, as->cell, afs_cell_trace_unuse_sbi);\n \t\tput_net(as->net_ns);\n-\t\tkfree(as);\n+\t\tif (atomic_dec_and_test(&as->refcount))\n+        kfree(as);\n \t}\n }\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/afs/super.c b/fs/afs/super.c\nindex 95d713074dc8..7a69e107837e 100644\n--- a/fs/afs/super.c\n+++ b/fs/afs/super.c\n@@ -505,8 +505,10 @@ static struct afs_super_info *afs_alloc_sbi(struct fs_context *fc)\n {\n \tstruct afs_fs_context *ctx = fc->fs_private;\n \tstruct afs_super_info *as;\n+atomic_t refcount;\n \n \tas = kzalloc(sizeof(struct afs_super_info), GFP_KERNEL);\n+atomic_set(&as->refcount, 1);\n \tif (as) {\n \t\tas->net_ns = get_net(fc->net_ns);\n \t\tas->flock_mode = ctx->flock_mode;\n@@ -528,7 +530,8 @@ static void afs_destroy_sbi(struct afs_super_info *as)\n \t\tafs_put_volume(net, as->volume, afs_volume_trace_put_destroy_sbi);\n \t\tafs_unuse_cell(net, as->cell, afs_cell_trace_unuse_sbi);\n \t\tput_net(as->net_ns);\n-\t\tkfree(as);\n+\t\tif (atomic_dec_and_test(&as->refcount))\n+kfree(as);\n \t}\n }\n \n@@ -558,6 +561,7 @@ static int afs_get_tree(struct fs_context *fc)\n \tstruct afs_fs_context *ctx = fc->fs_private;\n \tstruct super_block *sb;\n \tstruct afs_super_info *as;\n+atomic_t refcount;\n \tint ret;\n \n \tret = afs_validate_fc(fc);\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..f13b7f048b24 100644\n--- a/drivers/net/can/usb/gs_usb.c\n+++ b/drivers/net/can/usb/gs_usb.c\n@@ -1187,7 +1187,11 @@ static int gs_usb_probe(struct usb_interface *intf,\n \tusb_set_intfdata(intf, dev);\n \tdev->udev = udev;\n \n-\tfor (i = 0; i < icount; i++) {\n+\tfor (i = 0; i < icount; i++)\n+    {\n+        if (dev->canch[i])\n+            gs_destroy_candev(dev->canch[i]);\n+    } {\n \t\tdev->canch[i] = gs_make_candev(i, intf, dconf);\n \t\tif (IS_ERR_OR_NULL(dev->canch[i])) {\n \t\t\t/* save error code to return later */\n@@ -1196,6 +1200,10 @@ static int gs_usb_probe(struct usb_interface *intf,\n \t\t\t/* on failure destroy previously created candevs */\n \t\t\ticount = i;\n \t\t\tfor (i = 0; i < icount; i++)\n+    {\n+        if (dev->canch[i])\n+            gs_destroy_candev(dev->canch[i]);\n+    }\n \t\t\t\tgs_destroy_candev(dev->canch[i]);\n \n \t\t\tusb_kill_anchored_urbs(&dev->rx_submitted);\n",
            "diff --git a/drivers/net/can/usb/gs_usb.c b/drivers/net/can/usb/gs_usb.c\nindex 67408e316062..f9e6c2bfc382 100644\n--- a/drivers/net/can/usb/gs_usb.c\n+++ b/drivers/net/can/usb/gs_usb.c\n@@ -1195,6 +1195,7 @@ static int gs_usb_probe(struct usb_interface *intf,\n \n \t\t\t/* on failure destroy previously created candevs */\n \t\t\ticount = i;\n+kfree(dconf);\n \t\t\tfor (i = 0; i < icount; i++)\n \t\t\t\tgs_destroy_candev(dev->canch[i]);\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/net/can/usb/gs_usb.c b/drivers/net/can/usb/gs_usb.c\nindex 67408e316062..567da5b52c36 100644\n--- a/drivers/net/can/usb/gs_usb.c\n+++ b/drivers/net/can/usb/gs_usb.c\n@@ -346,7 +346,11 @@ static int gs_cmd_reset(struct gs_can *gsdev)\n \n \tkfree(dm);\n \n-\treturn rc;\n+\tdev_err(&intf->dev, \"Cleanup on error: freeing resources\\n\");\n+usb_kill_anchored_urbs(&dev->rx_submitted);\n+kfree(dconf);\n+kfree(dev);\n+return rc;\n }\n \n static void gs_update_state(struct gs_can *dev, struct can_frame *cf)\n@@ -721,7 +725,11 @@ static int gs_can_open(struct net_device *netdev)\n \n \trc = open_candev(netdev);\n \tif (rc)\n-\t\treturn rc;\n+\t\tdev_err(&intf->dev, \"Cleanup on error: freeing resources\\n\");\n+usb_kill_anchored_urbs(&dev->rx_submitted);\n+kfree(dconf);\n+kfree(dev);\n+return rc;\n \n \tctrlmode = dev->can.ctrlmode;\n \tif (ctrlmode & CAN_CTRLMODE_FD) {\n@@ -823,7 +831,11 @@ static int gs_can_open(struct net_device *netdev)\n \tif (rc < 0) {\n \t\tnetdev_err(netdev, \"Couldn't start device (err=%d)\\n\", rc);\n \t\tkfree(dm);\n-\t\treturn rc;\n+\t\tdev_err(&intf->dev, \"Cleanup on error: freeing resources\\n\");\n+usb_kill_anchored_urbs(&dev->rx_submitted);\n+kfree(dconf);\n+kfree(dev);\n+return rc;\n \t}\n \n \tkfree(dm);\n@@ -922,7 +934,11 @@ static int gs_usb_set_phys_id(struct net_device *dev,\n \t\tbreak;\n \t}\n \n-\treturn rc;\n+\tdev_err(&intf->dev, \"Cleanup on error: freeing resources\\n\");\n+usb_kill_anchored_urbs(&dev->rx_submitted);\n+kfree(dconf);\n+kfree(dev);\n+return rc;\n }\n \n static const struct ethtool_ops gs_usb_ethtool_ops = {\n@@ -1141,7 +1157,11 @@ static int gs_usb_probe(struct usb_interface *intf,\n \n \tif (rc < 0) {\n \t\tdev_err(&intf->dev, \"Couldn't send data format (err=%d)\\n\", rc);\n-\t\treturn rc;\n+\t\tdev_err(&intf->dev, \"Cleanup on error: freeing resources\\n\");\n+usb_kill_anchored_urbs(&dev->rx_submitted);\n+kfree(dconf);\n+kfree(dev);\n+return rc;\n \t}\n \n \tdconf = kmalloc(sizeof(*dconf), GFP_KERNEL);\n@@ -1158,7 +1178,11 @@ static int gs_usb_probe(struct usb_interface *intf,\n \t\tdev_err(&intf->dev, \"Couldn't get device config: (err=%d)\\n\",\n \t\t\trc);\n \t\tkfree(dconf);\n-\t\treturn rc;\n+\t\tdev_err(&intf->dev, \"Cleanup on error: freeing resources\\n\");\n+usb_kill_anchored_urbs(&dev->rx_submitted);\n+kfree(dconf);\n+kfree(dev);\n+return rc;\n \t}\n \n \ticount = dconf->icount + 1;\n@@ -1201,7 +1225,11 @@ static int gs_usb_probe(struct usb_interface *intf,\n \t\t\tusb_kill_anchored_urbs(&dev->rx_submitted);\n \t\t\tkfree(dconf);\n \t\t\tkfree(dev);\n-\t\t\treturn rc;\n+\t\t\tdev_err(&intf->dev, \"Cleanup on error: freeing resources\\n\");\n+usb_kill_anchored_urbs(&dev->rx_submitted);\n+kfree(dconf);\n+kfree(dev);\n+return rc;\n \t\t}\n \t\tdev->canch[i]->parent = dev;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/net/can/usb/gs_usb.c b/drivers/net/can/usb/gs_usb.c\nindex 67408e316062..632cfba68709 100644\n--- a/drivers/net/can/usb/gs_usb.c\n+++ b/drivers/net/can/usb/gs_usb.c\n@@ -346,7 +346,8 @@ static int gs_cmd_reset(struct gs_can *gsdev)\n \n \tkfree(dm);\n \n-\treturn rc;\n+\tkfree(dconf);\n+return rc;\n }\n \n static void gs_update_state(struct gs_can *dev, struct can_frame *cf)\n@@ -721,7 +722,8 @@ static int gs_can_open(struct net_device *netdev)\n \n \trc = open_candev(netdev);\n \tif (rc)\n-\t\treturn rc;\n+\t\tkfree(dconf);\n+return rc;\n \n \tctrlmode = dev->can.ctrlmode;\n \tif (ctrlmode & CAN_CTRLMODE_FD) {\n@@ -823,7 +825,8 @@ static int gs_can_open(struct net_device *netdev)\n \tif (rc < 0) {\n \t\tnetdev_err(netdev, \"Couldn't start device (err=%d)\\n\", rc);\n \t\tkfree(dm);\n-\t\treturn rc;\n+\t\tkfree(dconf);\n+return rc;\n \t}\n \n \tkfree(dm);\n@@ -922,7 +925,8 @@ static int gs_usb_set_phys_id(struct net_device *dev,\n \t\tbreak;\n \t}\n \n-\treturn rc;\n+\tkfree(dconf);\n+return rc;\n }\n \n static const struct ethtool_ops gs_usb_ethtool_ops = {\n@@ -1141,7 +1145,8 @@ static int gs_usb_probe(struct usb_interface *intf,\n \n \tif (rc < 0) {\n \t\tdev_err(&intf->dev, \"Couldn't send data format (err=%d)\\n\", rc);\n-\t\treturn rc;\n+\t\tkfree(dconf);\n+return rc;\n \t}\n \n \tdconf = kmalloc(sizeof(*dconf), GFP_KERNEL);\n@@ -1158,7 +1163,8 @@ static int gs_usb_probe(struct usb_interface *intf,\n \t\tdev_err(&intf->dev, \"Couldn't get device config: (err=%d)\\n\",\n \t\t\trc);\n \t\tkfree(dconf);\n-\t\treturn rc;\n+\t\tkfree(dconf);\n+return rc;\n \t}\n \n \ticount = dconf->icount + 1;\n@@ -1201,7 +1207,8 @@ static int gs_usb_probe(struct usb_interface *intf,\n \t\t\tusb_kill_anchored_urbs(&dev->rx_submitted);\n \t\t\tkfree(dconf);\n \t\t\tkfree(dev);\n-\t\t\treturn rc;\n+\t\t\tkfree(dconf);\n+return rc;\n \t\t}\n \t\tdev->canch[i]->parent = dev;\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "80b047eb9aff0254f4adc620c6891c0ca3276309": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/tipc/monitor.c b/net/tipc/monitor.c\nindex 6dce2abf436e..01b8d5d4f416 100644\n--- a/net/tipc/monitor.c\n+++ b/net/tipc/monitor.c\n@@ -556,6 +556,22 @@ 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+peer = mon->self;\n+while (peer) {\n+if (*prev_node) {\n+if (peer->addr == *prev_node)\n+*prev_node = 0;\n+else\n+continue;\n+}\n+if (__tipc_nl_add_monitor_peer(peer, msg)) {\n+*prev_node = peer->addr;\n+read_unlock_bh(&mon->lock);\n+return -EMSGSIZE;\n+}\n+peer = peer_nxt(peer);\n+}\n+read_unlock_bh(&mon->lock);\n \tlen = ntohs(mon->cache.len);\n \t*dlen = len;\n \tmemcpy(data, &mon->cache, len);\n@@ -583,6 +599,22 @@ void tipc_mon_get_state(struct net *net, u32 addr,\n \t\treturn;\n \n \tread_lock_bh(&mon->lock);\n+peer = mon->self;\n+while (peer) {\n+if (*prev_node) {\n+if (peer->addr == *prev_node)\n+*prev_node = 0;\n+else\n+continue;\n+}\n+if (__tipc_nl_add_monitor_peer(peer, msg)) {\n+*prev_node = peer->addr;\n+read_unlock_bh(&mon->lock);\n+return -EMSGSIZE;\n+}\n+peer = peer_nxt(peer);\n+}\n+read_unlock_bh(&mon->lock);\n \tpeer = get_peer(mon, addr);\n \tif (peer) {\n \t\tstate->probing = state->acked_gen != mon->dom_gen;\n@@ -771,6 +803,22 @@ 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+peer = mon->self;\n+while (peer) {\n+if (*prev_node) {\n+if (peer->addr == *prev_node)\n+*prev_node = 0;\n+else\n+continue;\n+}\n+if (__tipc_nl_add_monitor_peer(peer, msg)) {\n+*prev_node = peer->addr;\n+read_unlock_bh(&mon->lock);\n+return -EMSGSIZE;\n+}\n+peer = peer_nxt(peer);\n+}\n+read_unlock_bh(&mon->lock);\n \tpeer = mon->self;\n \tdo {\n \t\tif (*prev_node) {\n@@ -813,6 +861,22 @@ 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+peer = mon->self;\n+while (peer) {\n+if (*prev_node) {\n+if (peer->addr == *prev_node)\n+*prev_node = 0;\n+else\n+continue;\n+}\n+if (__tipc_nl_add_monitor_peer(peer, msg)) {\n+*prev_node = peer->addr;\n+read_unlock_bh(&mon->lock);\n+return -EMSGSIZE;\n+}\n+peer = peer_nxt(peer);\n+}\n+read_unlock_bh(&mon->lock);\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"
            }
        ]
    },
    "e9d3ca982b76224e183481018baa693a26655ac4": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex 1602d74b5eeb..9c45ded7937d 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -341,7 +341,12 @@ 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+    len -= EXT4_MIN_INLINE_DATA_SIZE;\n+} else {\n+    error = -EINVAL;\n+    goto out;\n+}\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..0bf01f1e11dd 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -274,7 +274,12 @@ static int ext4_create_inline_data(handle_t *handle,\n \n \tif (len > EXT4_MIN_INLINE_DATA_SIZE) {\n \t\tvalue = EXT4_ZERO_XATTR_VALUE;\n-\t\tlen -= EXT4_MIN_INLINE_DATA_SIZE;\n+\t\tif (len > EXT4_MIN_INLINE_DATA_SIZE) {\n+    len -= EXT4_MIN_INLINE_DATA_SIZE;\n+} else {\n+    error = -EINVAL;\n+    goto out;\n+}\n \t} else {\n \t\tvalue = \"\";\n \t\tlen = 0;\n@@ -341,7 +346,12 @@ 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+    len -= EXT4_MIN_INLINE_DATA_SIZE;\n+} else {\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..82aa6d68a755 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 > MAX_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",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex 1602d74b5eeb..fa5c2fcb32f9 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+\tvalue = if (len <= 0 || len > MAX_INLINE_DATA_LEN) {\n+        error = -EINVAL;\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"
            },
            {
                "patch": "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex 1602d74b5eeb..43a18667b6c0 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -274,7 +274,8 @@ static int ext4_create_inline_data(handle_t *handle,\n \n \tif (len > EXT4_MIN_INLINE_DATA_SIZE) {\n \t\tvalue = EXT4_ZERO_XATTR_VALUE;\n-\t\tlen -= EXT4_MIN_INLINE_DATA_SIZE;\n+\t\tif (len > MAX_INLINE_DATA_SIZE) return -EINVAL;\n+    len -= EXT4_MIN_INLINE_DATA_SIZE;\n \t} else {\n \t\tvalue = \"\";\n \t\tlen = 0;\n@@ -341,7 +342,8 @@ 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 > MAX_INLINE_DATA_SIZE) return -EINVAL;\n+    len -= EXT4_MIN_INLINE_DATA_SIZE;\n \tvalue = kzalloc(len, GFP_NOFS);\n \tif (!value) {\n \t\terror = -ENOMEM;\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..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..52f44990524f 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\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..9ae35b9e60ed 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -126,7 +126,11 @@ 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/* Handle unexpected -ENOENT error more gracefully */\n+        if (ret == -ENOENT) {\n+            printk(KERN_WARNING \"nilfs_dat_prepare_end: unexpected -ENOENT encountered\\n\");\n+            return ret;\n+        }\n \treturn ret;\n }\n \n@@ -155,7 +159,11 @@ int nilfs_dat_prepare_end(struct inode *dat, struct nilfs_palloc_req *req)\n \n \tret = nilfs_dat_prepare_entry(dat, req, 0);\n \tif (ret < 0) {\n-\t\tWARN_ON(ret == -ENOENT);\n+\t\t/* Handle unexpected -ENOENT error more gracefully */\n+        if (ret == -ENOENT) {\n+            printk(KERN_WARNING \"nilfs_dat_prepare_end: unexpected -ENOENT encountered\\n\");\n+            return ret;\n+        }\n \t\treturn ret;\n \t}\n \n",
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 9930fa901039..f1930f667e0a 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\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\tpr_warn(\"nilfs_dat_prepare_end: Entry not found, ret=%d\\n\", ret);\n \t\treturn ret;\n \t}\n \n"
        ],
        "error": []
    },
    "f080ff8eb73ae6a29960594307de8e732db389d3": {
        "non_crash": [
            "diff --git a/fs/f2fs/extent_cache.c b/fs/f2fs/extent_cache.c\nindex 0e2d49140c07..9e47467a76fc 100644\n--- a/fs/f2fs/extent_cache.c\n+++ b/fs/f2fs/extent_cache.c\n@@ -613,6 +613,8 @@ static void __update_extent_tree_range(struct inode *inode,\n \tunsigned int fofs = tei->fofs, len = tei->len;\n \tunsigned int end = fofs + len;\n \tbool updated = false;\n+\n+    if (!et) return;\n \tbool leftmost = false;\n \n \tif (!et)\n@@ -1094,6 +1096,8 @@ 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+    if (!et) return;\n+\n \tif (!__may_extent_tree(inode, type))\n \t\treturn;\n \n",
            "diff --git a/fs/f2fs/extent_cache.c b/fs/f2fs/extent_cache.c\nindex 0e2d49140c07..7cf320149d6f 100644\n--- a/fs/f2fs/extent_cache.c\n+++ b/fs/f2fs/extent_cache.c\n@@ -1090,6 +1090,8 @@ void f2fs_destroy_extent_node(struct inode *inode)\n \n static void __drop_extent_tree(struct inode *inode, enum extent_type type)\n {\n+    if (!inode || !F2FS_I(inode)->extent_tree[type])\n+        return;\n \tstruct f2fs_sb_info *sbi = F2FS_I_SB(inode);\n \tstruct extent_tree *et = F2FS_I(inode)->extent_tree[type];\n \tbool updated = false;\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/fs/f2fs/extent_cache.c b/fs/f2fs/extent_cache.c\nindex 0e2d49140c07..2cb7fd1ab6e5 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 (!et || !__may_extent_tree(inode, type))\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..df6898e45cd3 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) return;\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) return;\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) return;\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) return;\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) return;\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) return;\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"
            }
        ]
    },
    "f55849742bdcdf58f6eaae61e747ac00e5c061f4": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/mm/mprotect.c b/mm/mprotect.c\nindex 461dcbd4f21a..1d41ec8a0689 100644\n--- a/mm/mprotect.c\n+++ b/mm/mprotect.c\n@@ -240,7 +240,19 @@ 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+if (pte_marker_entry_uffd_wp(entry)) {\n+/* If this is uffd-wp pte marker and we'd like\n+ * to unprotect it, drop it; the next page\n+ * fault will trigger without uffd trapping.\n+ */\n+if (uffd_wp_resolve) {\n+pte_clear(vma->vm_mm, addr, pte);\n+pages++;\n+}\n+continue;\n+}\n+#endif /* CONFIG_PTE_MARKER */) {\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 +287,11 @@ 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+set_pte_at(vma->vm_mm, addr, pte,\n+make_pte_marker(PTE_MARKER_UFFD_WP));\n+pages++;\n+#endif /* CONFIG_PTE_MARKER */);\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..dbfde7b36a04 100644\n--- a/mm/mprotect.c\n+++ b/mm/mprotect.c\n@@ -275,7 +275,11 @@ 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+                set_pte_at(vma->vm_mm, addr, pte,\n+                           make_pte_marker(PTE_MARKER_UFFD_WP));\n+                pages++;\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..9d0bc72d7b3a 100644\n--- a/mm/mprotect.c\n+++ b/mm/mprotect.c\n@@ -267,7 +267,9 @@ 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+#endif\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"
            }
        ]
    },
    "d58fe2a53afa4ffbfaf3df368acb70d137e46c9f": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "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..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..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..9cca416b88c5 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 >= 923)\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..8b9c4c939630 100644\n--- a/fs/f2fs/f2fs.h\n+++ b/fs/f2fs/f2fs.h\n@@ -3272,7 +3272,11 @@ 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+        return NULL; /* or handle the error appropriately */\n+    }\n+    return (void *)&(ri->i_addr[index]);\n }\n \n static inline int f2fs_has_inline_dentry(struct inode *inode)\n"
        ],
        "error": []
    },
    "5091eca677b6821339a9491de5b4151c5be85ae7": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/ipv6/mcast.c b/net/ipv6/mcast.c\nindex 87c699d57b36..eb119a1d5bac 100644\n--- a/net/ipv6/mcast.c\n+++ b/net/ipv6/mcast.c\n@@ -1850,7 +1850,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@@ -1907,6 +1908,8 @@ 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+                return NULL;\n \t\t}\n \t}\n \tfirst = 1;\n",
            "diff --git a/net/ipv6/mcast.c b/net/ipv6/mcast.c\nindex 87c699d57b36..bee4f869c245 100644\n--- a/net/ipv6/mcast.c\n+++ b/net/ipv6/mcast.c\n@@ -1906,6 +1906,8 @@ static struct sk_buff *add_grec(struct sk_buff *skb, struct ifmcaddr6 *pmc,\n \t\t    AVAILABLE(skb) < grec_size(pmc, type, gdeleted, sdeleted)) {\n \t\t\tif (skb)\n \t\t\t\tmld_sendpack(skb);\n+if (!skb)\n+kfree_skb(skb);\n \t\t\tskb = mld_newpack(idev, mtu);\n \t\t}\n \t}\n@@ -1944,6 +1946,8 @@ static struct sk_buff *add_grec(struct sk_buff *skb, struct ifmcaddr6 *pmc,\n \t\t\t\tpgr->grec_nsrcs = htons(scount);\n \t\t\tif (skb)\n \t\t\t\tmld_sendpack(skb);\n+if (!skb)\n+kfree_skb(skb);\n \t\t\tskb = mld_newpack(idev, mtu);\n \t\t\tfirst = 1;\n \t\t\tscount = 0;\n@@ -1984,6 +1988,8 @@ static struct sk_buff *add_grec(struct sk_buff *skb, struct ifmcaddr6 *pmc,\n \t\t\t/* make sure we have room for group header */\n \t\t\tif (skb && AVAILABLE(skb) < sizeof(struct mld2_grec)) {\n \t\t\t\tmld_sendpack(skb);\n+if (!skb)\n+kfree_skb(skb);\n \t\t\t\tskb = NULL; /* add_grhead will get a new one */\n \t\t\t}\n \t\t\tskb = add_grhead(skb, pmc, type, &pgr, mtu);\n@@ -2022,6 +2028,8 @@ static void mld_send_report(struct inet6_dev *idev, struct ifmcaddr6 *pmc)\n \t}\n \tif (skb)\n \t\tmld_sendpack(skb);\n+if (!skb)\n+kfree_skb(skb);\n }\n \n /*\n@@ -2119,6 +2127,8 @@ static void mld_send_cr(struct inet6_dev *idev)\n \tif (!skb)\n \t\treturn;\n \t(void) mld_sendpack(skb);\n+if (!skb)\n+kfree_skb(skb);\n }\n \n static void igmp6_send(struct in6_addr *addr, struct net_device *dev, int type)\n@@ -2237,6 +2247,8 @@ static void mld_send_initial_cr(struct inet6_dev *idev)\n \t}\n \tif (skb)\n \t\tmld_sendpack(skb);\n+if (!skb)\n+kfree_skb(skb);\n }\n \n void ipv6_mc_dad_complete(struct inet6_dev *idev)\n",
            "diff --git a/net/ipv6/mcast.c b/net/ipv6/mcast.c\nindex 87c699d57b36..967398ff69db 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",
            "diff --git a/net/ipv6/mcast.c b/net/ipv6/mcast.c\nindex 87c699d57b36..35f08b6fc7ee 100644\n--- a/net/ipv6/mcast.c\n+++ b/net/ipv6/mcast.c\n@@ -1774,7 +1774,11 @@ static struct sk_buff *mld_newpack(struct inet6_dev *idev, unsigned int mtu)\n \tpmr->mld2r_cksum = 0;\n \tpmr->mld2r_resv2 = 0;\n \tpmr->mld2r_ngrec = 0;\n-\treturn skb;\n+\tif (!skb) {\n+        kfree_skb(skb);\n+        return NULL;\n+    }\n+    return skb;\n }\n \n static void mld_sendpack(struct sk_buff *skb)\n"
        ],
        "error": []
    },
    "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..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"
        ],
        "error": [
            {
                "patch": "diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c\nindex 5864cbc30db6..0c210f92affe 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@@ -5168,7 +5176,8 @@ 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\trcu_read_lock();\n+        for (ifmca = rcu_dereference(idev->mc_list);\n \t\t     ifmca;\n \t\t     ifmca = rcu_dereference(ifmca->next), ip_idx++) {\n \t\t\tif (ip_idx < s_ip_idx)\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"
            },
            {
                "patch": "diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c\nindex 5864cbc30db6..0c210f92affe 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@@ -5168,7 +5176,8 @@ 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\trcu_read_lock();\n+        for (ifmca = rcu_dereference(idev->mc_list);\n \t\t     ifmca;\n \t\t     ifmca = rcu_dereference(ifmca->next), ip_idx++) {\n \t\t\tif (ip_idx < s_ip_idx)\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"
            },
            {
                "patch": "diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c\nindex 5864cbc30db6..a193f24f90c1 100644\n--- a/net/ipv6/addrconf.c\n+++ b/net/ipv6/addrconf.c\n@@ -816,7 +816,7 @@ static void dev_forward_change(struct inet6_dev *idev)\n \t\t}\n \t}\n \n-\tread_lock_bh(&idev->lock);\n+\trcu_read_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 +1872,7 @@ 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_lock();\n \t\terr = __ipv6_get_lladdr(idev, addr, banned_flags);\n \t\tread_unlock_bh(&idev->lock);\n \t}\n@@ -2342,7 +2342,7 @@ 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_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 +2517,7 @@ 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_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 +3017,7 @@ 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_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 +3986,7 @@ 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_lock();\n \tspin_lock(&ifp->lock);\n \tif (ifp->state == INET6_IFADDR_STATE_DEAD)\n \t\tgoto out;\n@@ -4268,7 +4268,7 @@ 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_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 +5144,7 @@ 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_lock();\n \tswitch (fillargs->type) {\n \tcase UNICAST_ADDR: {\n \t\tstruct inet6_ifaddr *ifa;\n@@ -5177,7 +5177,7 @@ static int in6_dump_addrs(struct inet6_dev *idev, struct sk_buff *skb,\n \t\t\tif (err < 0)\n \t\t\t\tbreak;\n \t\t}\n-\t\tread_lock_bh(&idev->lock);\n+\t\trcu_read_lock();\n \t\tbreak;\n \tcase ANYCAST_ADDR:\n \t\tfillargs->event = RTM_GETANYCAST;\n@@ -5696,7 +5696,7 @@ 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_lock();\n \tmemcpy(nla_data(nla), idev->token.s6_addr, nla_len(nla));\n \tread_unlock_bh(&idev->lock);\n \n@@ -6523,7 +6523,7 @@ 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_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"
            }
        ]
    },
    "2db2545ff94291fabe4a5dd4ee182db44ef35d4b": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/hid/uhid.c b/drivers/hid/uhid.c\nindex 3c5507313606..17012b38104a 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(VERIFY_READ, 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",
            "diff --git a/drivers/hid/uhid.c b/drivers/hid/uhid.c\nindex 3c5507313606..3df40eceb320 100644\n--- a/drivers/hid/uhid.c\n+++ b/drivers/hid/uhid.c\n@@ -537,7 +537,7 @@ static int uhid_dev_create(struct uhid_device *uhid,\n \n \torig = ev->u.create;\n \n-\tif (orig.rd_size <= 0 || orig.rd_size > HID_MAX_DESCRIPTOR_SIZE)\n+\tif (!orig.rd_data || 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 \t\treturn -EFAULT;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/hid/uhid.c b/drivers/hid/uhid.c\nindex 3c5507313606..0bc8800ba064 100644\n--- a/drivers/hid/uhid.c\n+++ b/drivers/hid/uhid.c\n@@ -537,7 +537,7 @@ static int uhid_dev_create(struct uhid_device *uhid,\n \n \torig = ev->u.create;\n \n-\tif (orig.rd_size <= 0 || orig.rd_size > HID_MAX_DESCRIPTOR_SIZE)\n+\tif (orig.rd_size <= 0 || orig.rd_size > HID_MAX_DESCRIPTOR_SIZE || !access_ok(orig.rd_data, orig.rd_size))\n \t\treturn -EINVAL;\n \tif (copy_from_user(&ev->u.create2.rd_data, orig.rd_data, orig.rd_size))\n \t\treturn -EFAULT;\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..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"
            }
        ]
    },
    "36a409539269df8733aaba8c3b36cf2fc7091cf7": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/sched/cls_tcindex.c b/net/sched/cls_tcindex.c\nindex eb0e9458e722..ddcbc618118e 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 (f) 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..4ad22d14ca1a 100644\n--- a/net/sched/cls_tcindex.c\n+++ b/net/sched/cls_tcindex.c\n@@ -329,6 +329,7 @@ static int tcindex_alloc_perfect_hash(struct net *net, struct tcindex_data *cp)\n \n static int\n tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n+    \n \t\t  u32 handle, struct tcindex_data *p,\n \t\t  struct tcindex_filter_result *r, struct nlattr **tb,\n \t\t  struct nlattr *est, u32 flags, struct netlink_ext_ack *extack)\n@@ -402,6 +403,7 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \terr = tcindex_filter_result_init(&new_filter_result, cp, net);\n \tif (err < 0)\n \t\tgoto errout_alloc;\n+    kfree(cp);\n \tif (old_r)\n \t\tcr = r->res;\n \n@@ -414,8 +416,10 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \t\tif (!valid_perfect_hash(cp) ||\n \t\t    cp->hash > cp->alloc_hash)\n \t\t\tgoto errout_alloc;\n+    kfree(cp);\n \t} else if (cp->h && cp->hash != cp->alloc_hash) {\n \t\tgoto errout_alloc;\n+    kfree(cp);\n \t}\n \n \terr = -EINVAL;\n@@ -433,6 +437,7 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \tif (cp->perfect || valid_perfect_hash(cp))\n \t\tif (handle >= cp->alloc_hash)\n \t\t\tgoto errout_alloc;\n+    kfree(cp);\n \n \n \terr = -ENOMEM;\n@@ -440,6 +445,7 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\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+    kfree(cp);\n \t\t\tballoc = 1;\n \t\t} else {\n \t\t\tstruct tcindex_filter __rcu **hash;\n@@ -450,6 +456,7 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \n \t\t\tif (!hash)\n \t\t\t\tgoto errout_alloc;\n+    kfree(cp);\n \n \t\t\tcp->h = hash;\n \t\t\tballoc = 2;\n@@ -465,12 +472,14 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \t\tf = kzalloc(sizeof(*f), GFP_KERNEL);\n \t\tif (!f)\n \t\t\tgoto errout_alloc;\n+    kfree(cp);\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+    kfree(cp);\n \t\t}\n \t}\n \n@@ -484,6 +493,7 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \t\tif (err < 0) {\n \t\t\tkfree(f);\n \t\t\tgoto errout_alloc;\n+    kfree(cp);\n \t\t}\n \t}\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/sched/cls_tcindex.c b/net/sched/cls_tcindex.c\nindex eb0e9458e722..170ce6e67dc1 100644\n--- a/net/sched/cls_tcindex.c\n+++ b/net/sched/cls_tcindex.c\n@@ -401,7 +401,12 @@ 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\tgoto errout_alloc:\n+if (cp) kfree(cp);\n+if (balloc == 1) tcindex_free_perfect_hash(cp);\n+else if (balloc == 2) kfree(cp->h);\n+tcf_exts_destroy(&e);\n+return err;;\n \tif (old_r)\n \t\tcr = r->res;\n \n@@ -413,9 +418,19 @@ 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\tgoto errout_alloc:\n+if (cp) kfree(cp);\n+if (balloc == 1) tcindex_free_perfect_hash(cp);\n+else if (balloc == 2) kfree(cp->h);\n+tcf_exts_destroy(&e);\n+return err;;\n \t} else if (cp->h && cp->hash != cp->alloc_hash) {\n-\t\tgoto errout_alloc;\n+\t\tgoto errout_alloc:\n+if (cp) kfree(cp);\n+if (balloc == 1) tcindex_free_perfect_hash(cp);\n+else if (balloc == 2) kfree(cp->h);\n+tcf_exts_destroy(&e);\n+return err;;\n \t}\n \n \terr = -EINVAL;\n@@ -432,14 +447,24 @@ 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\tgoto errout_alloc:\n+if (cp) kfree(cp);\n+if (balloc == 1) tcindex_free_perfect_hash(cp);\n+else if (balloc == 2) kfree(cp->h);\n+tcf_exts_destroy(&e);\n+return err;;\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\tgoto errout_alloc:\n+if (cp) kfree(cp);\n+if (balloc == 1) tcindex_free_perfect_hash(cp);\n+else if (balloc == 2) kfree(cp->h);\n+tcf_exts_destroy(&e);\n+return err;;\n \t\t\tballoc = 1;\n \t\t} else {\n \t\t\tstruct tcindex_filter __rcu **hash;\n@@ -449,7 +474,12 @@ 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\tgoto errout_alloc:\n+if (cp) kfree(cp);\n+if (balloc == 1) tcindex_free_perfect_hash(cp);\n+else if (balloc == 2) kfree(cp->h);\n+tcf_exts_destroy(&e);\n+return err;;\n \n \t\t\tcp->h = hash;\n \t\t\tballoc = 2;\n@@ -464,13 +494,23 @@ 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\tgoto errout_alloc:\n+if (cp) kfree(cp);\n+if (balloc == 1) tcindex_free_perfect_hash(cp);\n+else if (balloc == 2) kfree(cp->h);\n+tcf_exts_destroy(&e);\n+return err;;\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\tgoto errout_alloc:\n+if (cp) kfree(cp);\n+if (balloc == 1) tcindex_free_perfect_hash(cp);\n+else if (balloc == 2) kfree(cp->h);\n+tcf_exts_destroy(&e);\n+return err;;\n \t\t}\n \t}\n \n@@ -483,7 +523,12 @@ 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\tgoto errout_alloc:\n+if (cp) kfree(cp);\n+if (balloc == 1) tcindex_free_perfect_hash(cp);\n+else if (balloc == 2) kfree(cp->h);\n+tcf_exts_destroy(&e);\n+return err;;\n \t\t}\n \t}\n \n@@ -516,6 +561,11 @@ 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+if (balloc == 1) tcindex_free_perfect_hash(cp);\n+else if (balloc == 2) kfree(cp->h);\n+tcf_exts_destroy(&e);\n+return err;:\n \tif (balloc == 1)\n \t\ttcindex_free_perfect_hash(cp);\n \telse if (balloc == 2)\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/sched/cls_tcindex.c b/net/sched/cls_tcindex.c\nindex eb0e9458e722..74fafbb1ba38 100644\n--- a/net/sched/cls_tcindex.c\n+++ b/net/sched/cls_tcindex.c\n@@ -323,6 +323,15 @@ static int tcindex_alloc_perfect_hash(struct net *net, struct tcindex_data *cp)\n \treturn 0;\n \n errout:\n+    if (cp) {\n+        if (balloc == 1)\n+            tcindex_free_perfect_hash(cp);\n+        else if (balloc == 2)\n+            kfree(cp->h);\n+        kfree(cp);\n+    }\n+    if (f)\n+        kfree(f);\n \ttcindex_free_perfect_hash(cp);\n \treturn err;\n }\n@@ -522,6 +531,15 @@ 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+    if (cp) {\n+        if (balloc == 1)\n+            tcindex_free_perfect_hash(cp);\n+        else if (balloc == 2)\n+            kfree(cp->h);\n+        kfree(cp);\n+    }\n+    if (f)\n+        kfree(f);\n \tkfree(cp);\n \ttcf_exts_destroy(&e);\n \treturn err;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/sched/cls_tcindex.c b/net/sched/cls_tcindex.c\nindex eb0e9458e722..fb0b79fe648d 100644\n--- a/net/sched/cls_tcindex.c\n+++ b/net/sched/cls_tcindex.c\n@@ -401,7 +401,9 @@ 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\tgoto errout_alloc:\n+    kfree(cp);\n+;\n \tif (old_r)\n \t\tcr = r->res;\n \n@@ -413,9 +415,13 @@ 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\tgoto errout_alloc:\n+    kfree(cp);\n+;\n \t} else if (cp->h && cp->hash != cp->alloc_hash) {\n-\t\tgoto errout_alloc;\n+\t\tgoto errout_alloc:\n+    kfree(cp);\n+;\n \t}\n \n \terr = -EINVAL;\n@@ -432,14 +438,18 @@ 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\tgoto errout_alloc:\n+    kfree(cp);\n+;\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\tgoto errout_alloc:\n+    kfree(cp);\n+;\n \t\t\tballoc = 1;\n \t\t} else {\n \t\t\tstruct tcindex_filter __rcu **hash;\n@@ -449,7 +459,9 @@ 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\tgoto errout_alloc:\n+    kfree(cp);\n+;\n \n \t\t\tcp->h = hash;\n \t\t\tballoc = 2;\n@@ -464,13 +476,17 @@ 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\tgoto errout_alloc:\n+    kfree(cp);\n+;\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\tgoto errout_alloc:\n+    kfree(cp);\n+;\n \t\t}\n \t}\n \n@@ -483,7 +499,9 @@ 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\tgoto errout_alloc:\n+    kfree(cp);\n+;\n \t\t}\n \t}\n \n@@ -516,6 +534,8 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \treturn 0;\n \n errout_alloc:\n+    kfree(cp);\n+:\n \tif (balloc == 1)\n \t\ttcindex_free_perfect_hash(cp);\n \telse if (balloc == 2)\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..5bcfe17cee6e 100644\n--- a/sound/core/seq/seq_ports.c\n+++ b/sound/core/seq/seq_ports.c\n@@ -150,7 +150,8 @@ 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+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..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..5bcfe17cee6e 100644\n--- a/sound/core/seq/seq_ports.c\n+++ b/sound/core/seq/seq_ports.c\n@@ -150,7 +150,8 @@ 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+goto unlock;\n \t\t}\n \t\tif (p->addr.port > num)\n \t\t\tbreak;\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/sound/core/seq/seq_ports.c b/sound/core/seq/seq_ports.c\nindex 9b80f8275026..cf2126a543e1 100644\n--- a/sound/core/seq/seq_ports.c\n+++ b/sound/core/seq/seq_ports.c\n@@ -134,7 +134,8 @@ int snd_seq_create_port(struct snd_seq_client *client, int port,\n \t/* create a new port */\n \tnew_port = kzalloc(sizeof(*new_port), GFP_KERNEL);\n \tif (!new_port)\n-\t\treturn -ENOMEM;\t/* failure, out of memory */\n+\t\tkfree(new_port);\n+        return -ENOMEM;\t/* failure, out of memory */\n \t/* init port data */\n \tnew_port->addr.client = client->number;\n \tnew_port->addr.port = -1;\n@@ -593,7 +594,8 @@ int snd_seq_port_connect(struct snd_seq_client *connector,\n \n \tsubs = kzalloc(sizeof(*subs), GFP_KERNEL);\n \tif (!subs)\n-\t\treturn -ENOMEM;\n+\t\tkfree(new_port);\n+        return -ENOMEM;\n \n \tsubs->info = *info;\n \tatomic_set(&subs->ref_count, 0);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/sound/core/seq/seq_ports.c b/sound/core/seq/seq_ports.c\nindex 9b80f8275026..20ac7407ca02 100644\n--- a/sound/core/seq/seq_ports.c\n+++ b/sound/core/seq/seq_ports.c\n@@ -124,15 +124,26 @@ int snd_seq_create_port(struct snd_seq_client *client, int port,\n \n \t/* sanity check */\n \tif (snd_BUG_ON(!client))\n-\t\treturn -EINVAL;\n+\t\tCLEANUP_ON_ERROR();\n+return -EINVAL;\n \n \tif (client->num_ports >= SNDRV_SEQ_MAX_PORTS) {\n \t\tpr_warn(\"ALSA: seq: too many ports for client %d\\n\", client->number);\n-\t\treturn -EINVAL;\n+\t\tCLEANUP_ON_ERROR();\n+return -EINVAL;\n \t}\n \n \t/* create a new port */\n \tnew_port = kzalloc(sizeof(*new_port), GFP_KERNEL);\n+if (!new_port)\n+    return -ENOMEM; /* failure, out of memory */\n+\n+/* Cleanup allocated memory on error */\n+#define CLEANUP_ON_ERROR() \\\n+    do { \\\n+        if (new_port) \\\n+            kfree(new_port); \\\n+    } while (0)\n \tif (!new_port)\n \t\treturn -ENOMEM;\t/* failure, out of memory */\n \t/* init port data */\n@@ -334,7 +345,8 @@ int snd_seq_set_port_info(struct snd_seq_client_port * port,\n \t\t\t  struct snd_seq_port_info * info)\n {\n \tif (snd_BUG_ON(!port || !info))\n-\t\treturn -EINVAL;\n+\t\tCLEANUP_ON_ERROR();\n+return -EINVAL;\n \n \t/* set port name */\n \tif (info->name[0])\n@@ -378,7 +390,8 @@ int snd_seq_get_port_info(struct snd_seq_client_port * port,\n \t\t\t  struct snd_seq_port_info * info)\n {\n \tif (snd_BUG_ON(!port || !info))\n-\t\treturn -EINVAL;\n+\t\tCLEANUP_ON_ERROR();\n+return -EINVAL;\n \n \t/* get port name */\n \tstrscpy(info->name, port->name, sizeof(info->name));\n@@ -460,7 +473,8 @@ static int unsubscribe_port(struct snd_seq_client *client,\n \tint err = 0;\n \n \tif (! grp->count)\n-\t\treturn -EINVAL;\n+\t\tCLEANUP_ON_ERROR();\n+return -EINVAL;\n \tgrp->count--;\n \tif (grp->close && grp->count == 0)\n \t\terr = grp->close(port->private_data, info);\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..289a0beaec75 100644\n--- a/net/sctp/stream_sched_prio.c\n+++ b/net/sctp/stream_sched_prio.c\n@@ -158,7 +158,11 @@ static int sctp_sched_prio_set(struct sctp_stream *stream, __u16 sid,\n \n \tprio_head = sctp_sched_prio_get_head(stream, prio, gfp);\n \tif (!prio_head)\n-\t\treturn -ENOMEM;\n+\t\tif (!reschedule) {\n+        kfree(prio_head);\n+        return -ENOMEM;\n+    }\n+    return -ENOMEM;\n \n \treschedule = sctp_sched_prio_unsched(soute);\n \told = soute->prio_head;\n",
            "diff --git a/net/sctp/stream_sched_prio.c b/net/sctp/stream_sched_prio.c\nindex 80b5a2c4cbc7..a69c51c6ba79 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 || old == prio_head)\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..9383d526c2ee 100644\n--- a/net/sctp/stream_sched_prio.c\n+++ b/net/sctp/stream_sched_prio.c\n@@ -178,7 +178,8 @@ static int sctp_sched_prio_set(struct sctp_stream *stream, __u16 sid,\n \t}\n \n \t/* No hits, we are good to free it. */\n-\tkfree(old);\n+\tpr_info(\"Freeing old priority head\\n\");\n+kfree(old);\n \n \treturn 0;\n }\n"
        ],
        "error": []
    },
    "e2fdad19640cdf94dec600b3c67260b6095e5f7d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 4eae088046d0..1448d18befc2 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -202,7 +202,10 @@ __cold void io_uring_show_fdinfo(struct seq_file *m, struct file *f)\n {\n \tstruct io_ring_ctx *ctx = f->private_data;\n \n-\tif (percpu_ref_tryget(&ctx->refs)) {\n+\tif (!percpu_ref_tryget(&ctx->refs)) {\n+    return;\n+}\n+\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..26d2c08e9502 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) && !refcount_dec_and_test(&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/io_uring.c b/io_uring/io_uring.c\nindex de08d9902b30..246c99cbd050 100644\n--- a/io_uring/io_uring.c\n+++ b/io_uring/io_uring.c\n@@ -3299,7 +3299,8 @@ static const struct file_operations io_uring_fops = {\n #endif\n \t.poll\t\t= io_uring_poll,\n #ifdef CONFIG_PROC_FS\n-\t.show_fdinfo\t= io_uring_show_fdinfo,\n+\t.show_fdinfo\t= io_uring_show_fdinfo\n+if (!percpu_ref_tryget(&ctx->refs)) return -EFAULT;,\n #endif\n };\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "6cd217d3878763ebef28a8fd279c88e791c1c9ef": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/fork.c b/kernel/fork.c\nindex f68954d05e89..be16fe15bc0a 100644\n--- a/kernel/fork.c\n+++ b/kernel/fork.c\n@@ -2282,6 +2282,7 @@ static __latent_entropy struct task_struct *copy_process(\n \tstackleak_task_init(p);\n \n \tif (pid != &init_struct_pid) {\n+    pr_info(\"PID allocated successfully: %d\\n\", pid_nr(pid));\n \t\tpid = alloc_pid(p->nsproxy->pid_ns_for_children, args->set_tid,\n \t\t\t\targs->set_tid_size);\n \t\tif (IS_ERR(pid)) {\n"
        ],
        "error": []
    },
    "a9412f636e2d733130f8def7975897d0b57f6e37": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/autofs/waitq.c b/fs/autofs/waitq.c\nindex 54c1f8b8b075..3e4ae2399373 100644\n--- a/fs/autofs/waitq.c\n+++ b/fs/autofs/waitq.c\n@@ -423,6 +423,8 @@ int autofs_wait(struct autofs_sb_info *sbi,\n \t\t * autofs_notify_daemon() may block; it will unlock ->wq_mutex\n \t\t */\n \t\tautofs_notify_daemon(sbi, wq, type);\n+if (!--wq->wait_ctr)\n+kfree(wq);\n \t} else {\n \t\twq->wait_ctr++;\n \t\tpr_debug(\"existing wait id = 0x%08lx, name = %.*s, nfy=%d\\n\",\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/autofs/waitq.c b/fs/autofs/waitq.c\nindex 54c1f8b8b075..a5d26d1ca92a 100644\n--- a/fs/autofs/waitq.c\n+++ b/fs/autofs/waitq.c\n@@ -208,7 +208,8 @@ static int validate_request(struct autofs_wait_queue **wait,\n \tstruct autofs_info *ino;\n \n \tif (sbi->flags & AUTOFS_SBI_CATATONIC)\n-\t\treturn -ENOENT;\n+\t\tkfree(wq);\n+    return -ENOENT;\n \n \t/* Wait in progress, continue; */\n \twq = autofs_find_wait(sbi, qstr);\n@@ -243,7 +244,8 @@ static int validate_request(struct autofs_wait_queue **wait,\n \t\t\t\treturn -EINTR;\n \n \t\t\tif (sbi->flags & AUTOFS_SBI_CATATONIC)\n-\t\t\t\treturn -ENOENT;\n+\t\t\t\tkfree(wq);\n+    return -ENOENT;\n \n \t\t\twq = autofs_find_wait(sbi, qstr);\n \t\t\tif (wq) {\n@@ -313,7 +315,8 @@ int autofs_wait(struct autofs_sb_info *sbi,\n \n \t/* In catatonic mode, we don't wait for nobody */\n \tif (sbi->flags & AUTOFS_SBI_CATATONIC)\n-\t\treturn -ENOENT;\n+\t\tkfree(wq);\n+    return -ENOENT;\n \n \t/*\n \t * Try translating pids to the namespace of the daemon.\n@@ -323,7 +326,8 @@ int autofs_wait(struct autofs_sb_info *sbi,\n \tpid = task_pid_nr_ns(current, ns_of_pid(sbi->oz_pgrp));\n \ttgid = task_tgid_nr_ns(current, ns_of_pid(sbi->oz_pgrp));\n \tif (pid == 0 || tgid == 0)\n-\t\treturn -ENOENT;\n+\t\tkfree(wq);\n+    return -ENOENT;\n \n \tif (d_really_is_negative(dentry)) {\n \t\t/*\n@@ -335,9 +339,11 @@ int autofs_wait(struct autofs_sb_info *sbi,\n \t\t * in the root of the autofs file system may be negative.\n \t\t */\n \t\tif (autofs_type_trigger(sbi->type))\n-\t\t\treturn -ENOENT;\n+\t\t\tkfree(wq);\n+    return -ENOENT;\n \t\telse if (!IS_ROOT(dentry->d_parent))\n-\t\t\treturn -ENOENT;\n+\t\t\tkfree(wq);\n+    return -ENOENT;\n \t}\n \n \tname = kmalloc(NAME_MAX + 1, GFP_KERNEL);\n@@ -352,7 +358,8 @@ int autofs_wait(struct autofs_sb_info *sbi,\n \t\tchar *p = dentry_path_raw(dentry, name, NAME_MAX);\n \t\tif (IS_ERR(p)) {\n \t\t\tkfree(name);\n-\t\t\treturn -ENOENT;\n+\t\t\tkfree(wq);\n+    return -ENOENT;\n \t\t}\n \t\tqstr.name = ++p; // skip the leading slash\n \t\tqstr.len = strlen(p);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/autofs/waitq.c b/fs/autofs/waitq.c\nindex 54c1f8b8b075..6f76bbbc15b9 100644\n--- a/fs/autofs/waitq.c\n+++ b/fs/autofs/waitq.c\n@@ -374,9 +374,19 @@ int autofs_wait(struct autofs_sb_info *sbi,\n \t}\n \n \tif (!wq) {\n+if (ret != -EINTR) {\n+mutex_unlock(&sbi->wq_mutex);\n+kfree(name);\n+}\n+return ret;\n \t\t/* Create a new wait queue */\n \t\twq = kmalloc(sizeof(struct autofs_wait_queue), GFP_KERNEL);\n \t\tif (!wq) {\n+if (ret != -EINTR) {\n+mutex_unlock(&sbi->wq_mutex);\n+kfree(name);\n+}\n+return ret;\n \t\t\tkfree(name);\n \t\t\tmutex_unlock(&sbi->wq_mutex);\n \t\t\treturn -ENOMEM;\n@@ -495,6 +505,11 @@ int autofs_wait_release(struct autofs_sb_info *sbi,\n \t}\n \n \tif (!wq) {\n+if (ret != -EINTR) {\n+mutex_unlock(&sbi->wq_mutex);\n+kfree(name);\n+}\n+return ret;\n \t\tmutex_unlock(&sbi->wq_mutex);\n \t\treturn -EINVAL;\n \t}\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "ffb9228cab75ad9d812af93d19e9637873d18439": {
        "non_crash": [
            "diff --git a/net/ipv4/ip_gre.c b/net/ipv4/ip_gre.c\nindex 7e474a85deaf..e0d988d314af 100644\n--- a/net/ipv4/ip_gre.c\n+++ b/net/ipv4/ip_gre.c\n@@ -636,7 +636,7 @@ static netdev_tx_t ipgre_xmit(struct sk_buff *skb,\n \n \t\ttnl_params = (const struct iphdr *)skb->data;\n \n-\t\tif (pull_len > skb_transport_offset(skb))\n+\t\tif (!skb_transport_header_was_set(skb) || pull_len > skb_transport_offset(skb))\n \t\t\tgoto free_skb;\n \n \t\t/* Pull skb since ip_tunnel_xmit() needs skb->data pointing\n",
            "diff --git a/net/ipv4/ip_gre.c b/net/ipv4/ip_gre.c\nindex 7e474a85deaf..0c9b460dfd1e 100644\n--- a/net/ipv4/ip_gre.c\n+++ b/net/ipv4/ip_gre.c\n@@ -636,7 +636,7 @@ static netdev_tx_t ipgre_xmit(struct sk_buff *skb,\n \n \t\ttnl_params = (const struct iphdr *)skb->data;\n \n-\t\tif (pull_len > skb_transport_offset(skb))\n+\t\tif (skb_transport_header_was_set(skb) && pull_len > skb_transport_offset(skb))\n \t\t\tgoto free_skb;\n \n \t\t/* Pull skb since ip_tunnel_xmit() needs skb->data pointing\n",
            "diff --git a/net/ipv4/ip_gre.c b/net/ipv4/ip_gre.c\nindex 7e474a85deaf..248cb2d34dca 100644\n--- a/net/ipv4/ip_gre.c\n+++ b/net/ipv4/ip_gre.c\n@@ -629,6 +629,7 @@ static netdev_tx_t ipgre_xmit(struct sk_buff *skb,\n \t}\n \n \tif (dev->header_ops) {\n+        skb_set_transport_header(skb, tunnel->hlen);\n \t\tconst int pull_len = tunnel->hlen + sizeof(struct iphdr);\n \n \t\tif (skb_cow_head(skb, 0))\n",
            "diff --git a/net/ipv4/ip_gre.c b/net/ipv4/ip_gre.c\nindex 7e474a85deaf..e0d988d314af 100644\n--- a/net/ipv4/ip_gre.c\n+++ b/net/ipv4/ip_gre.c\n@@ -636,7 +636,7 @@ static netdev_tx_t ipgre_xmit(struct sk_buff *skb,\n \n \t\ttnl_params = (const struct iphdr *)skb->data;\n \n-\t\tif (pull_len > skb_transport_offset(skb))\n+\t\tif (!skb_transport_header_was_set(skb) || pull_len > skb_transport_offset(skb))\n \t\t\tgoto free_skb;\n \n \t\t/* Pull skb since ip_tunnel_xmit() needs skb->data pointing\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/ipv4/ip_gre.c b/net/ipv4/ip_gre.c\nindex 7e474a85deaf..ffdc345c5899 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_offset(skb) < 0 || 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": []
    },
    "8e9ea22655c782ac9af556ba3d4d822530a59390": {
        "non_crash": [
            "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 4bb6d304eb4b..f1aa1e769d5a 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 (is_in && (usb_pipeout(pipe) != 0)) {\n+dev_err(dev, \"Direction mismatch: pipe is OUT but request is IN\\n\");\n+return -EINVAL;\n+}\n \telse\n \t\tpipe = usb_sndctrlpipe(data->usb_dev, 0);\n \trv = usb_control_msg(data->usb_dev,\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 4bb6d304eb4b..ff72f723639d 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -1948,7 +1948,15 @@ 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 (request.req.bRequestType & USB_DIR_IN) {\n+        pipe = usb_rcvctrlpipe(data->usb_dev, 0);\n+    } else if (request.req.bRequestType & USB_DIR_OUT) {\n+        pipe = usb_sndctrlpipe(data->usb_dev, 0);\n+    } else {\n+        dev_err(dev, \"Invalid control direction: %x\\n\", request.req.bRequestType);\n+        rv = -EINVAL;\n+        goto exit;\n+    }\n \telse\n \t\tpipe = usb_sndctrlpipe(data->usb_dev, 0);\n \trv = usb_control_msg(data->usb_dev,\n"
        ],
        "error": []
    },
    "943853d124b5c70143eb385e993d35cb42a883c7": {
        "non_crash": [
            "diff --git a/net/qrtr/af_qrtr.c b/net/qrtr/af_qrtr.c\nindex 5c2fb992803b..2ccd884547c1 100644\n--- a/net/qrtr/af_qrtr.c\n+++ b/net/qrtr/af_qrtr.c\n@@ -1067,7 +1067,8 @@ static int qrtr_recvmsg(struct socket *sock, struct msghdr *msg,\n \n out:\n \tif (cb->confirm_rx)\n-\t\tqrtr_send_resume_tx(cb);\n+\t\tif (qrtr_node_lookup(cb->src_node))\n+        qrtr_send_resume_tx(cb);\n \n \tskb_free_datagram(sk, skb);\n \trelease_sock(sk);\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/qrtr/af_qrtr.c b/net/qrtr/af_qrtr.c\nindex 5c2fb992803b..e1d13fe8a9c6 100644\n--- a/net/qrtr/af_qrtr.c\n+++ b/net/qrtr/af_qrtr.c\n@@ -1001,6 +1001,10 @@ static int qrtr_send_resume_tx(struct qrtr_cb *cb)\n \tint ret;\n \n \tnode = qrtr_node_lookup(remote.sq_node);\n+    if (!node || refcount_read(&node->ref) == 0) {\n+        pr_warn(\"Attempt to acquire a node with zero refcount\\n\");\n+        return -EINVAL;\n+    }\n \tif (!node)\n \t\treturn -EINVAL;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/qrtr/af_qrtr.c b/net/qrtr/af_qrtr.c\nindex 5c2fb992803b..1f835264191f 100644\n--- a/net/qrtr/af_qrtr.c\n+++ b/net/qrtr/af_qrtr.c\n@@ -646,7 +646,9 @@ void qrtr_endpoint_unregister(struct qrtr_endpoint *ep)\n \t}\n \tmutex_unlock(&node->qrtr_tx_lock);\n \n-\tqrtr_node_release(node);\n+\tif (node && refcount_read(&node->ref) > 1) {\n+        qrtr_node_release(node);\n+    }\n \tep->node = NULL;\n }\n EXPORT_SYMBOL_GPL(qrtr_endpoint_unregister);\n@@ -985,7 +987,9 @@ static int qrtr_sendmsg(struct socket *sock, struct msghdr *msg, size_t len)\n \t\trc = len;\n \n out_node:\n-\tqrtr_node_release(node);\n+\tif (node && refcount_read(&node->ref) > 1) {\n+        qrtr_node_release(node);\n+    }\n \trelease_sock(sk);\n \n \treturn rc;\n@@ -1014,7 +1018,9 @@ static int qrtr_send_resume_tx(struct qrtr_cb *cb)\n \n \tret = qrtr_node_enqueue(node, skb, QRTR_TYPE_RESUME_TX, &local, &remote);\n \n-\tqrtr_node_release(node);\n+\tif (node && refcount_read(&node->ref) > 1) {\n+        qrtr_node_release(node);\n+    }\n \n \treturn ret;\n }\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/qrtr/af_qrtr.c b/net/qrtr/af_qrtr.c\nindex 5c2fb992803b..9ba066ad05c2 100644\n--- a/net/qrtr/af_qrtr.c\n+++ b/net/qrtr/af_qrtr.c\n@@ -646,7 +646,9 @@ void qrtr_endpoint_unregister(struct qrtr_endpoint *ep)\n \t}\n \tmutex_unlock(&node->qrtr_tx_lock);\n \n-\tqrtr_node_release(node);\n+\tif (refcount_read(&node->refcount) > 0) {\n+qrtr_node_release(node);\n+}\n \tep->node = NULL;\n }\n EXPORT_SYMBOL_GPL(qrtr_endpoint_unregister);\n@@ -985,7 +987,9 @@ static int qrtr_sendmsg(struct socket *sock, struct msghdr *msg, size_t len)\n \t\trc = len;\n \n out_node:\n-\tqrtr_node_release(node);\n+\tif (refcount_read(&node->refcount) > 0) {\n+qrtr_node_release(node);\n+}\n \trelease_sock(sk);\n \n \treturn rc;\n@@ -1014,7 +1018,9 @@ static int qrtr_send_resume_tx(struct qrtr_cb *cb)\n \n \tret = qrtr_node_enqueue(node, skb, QRTR_TYPE_RESUME_TX, &local, &remote);\n \n-\tqrtr_node_release(node);\n+\tif (refcount_read(&node->refcount) > 0) {\n+qrtr_node_release(node);\n+}\n \n \treturn ret;\n }\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..5ab2e4471b4a 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -355,6 +355,7 @@ static int nft_delchain(struct nft_ctx *ctx)\n \n \tctx->table->use--;\n \tnft_deactivate_next(ctx->net, ctx->chain);\n+    nft_chain_release_hook(ctx->chain);\n \n \treturn 0;\n }\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..68bdfc96dff8 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -218,7 +218,8 @@ static int nft_netdev_register_hooks(struct net *net,\n \n \t\tnf_unregister_net_hook(net, &hook->ops);\n \t}\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static void nft_netdev_unregister_hooks(struct net *net,\n@@ -318,10 +319,12 @@ static int nft_deltable(struct nft_ctx *ctx)\n \n \terr = nft_trans_table_add(ctx, NFT_MSG_DELTABLE);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \tnft_deactivate_next(ctx->net, ctx->table);\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static struct nft_trans *nft_trans_chain_add(struct nft_ctx *ctx, int msg_type)\n@@ -442,7 +445,8 @@ static int nft_delrule(struct nft_ctx *ctx, struct nft_rule *rule)\n \terr = nf_tables_delrule_deactivate(ctx, rule);\n \tif (err < 0) {\n \t\tnft_trans_destroy(trans);\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \t}\n \tnft_rule_expr_deactivate(ctx, rule, NFT_TRANS_PREPARE);\n \n@@ -460,7 +464,8 @@ static int nft_delrule_by_chain(struct nft_ctx *ctx)\n \n \t\terr = nft_delrule(ctx, rule);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t}\n \treturn 0;\n }\n@@ -491,12 +496,14 @@ static int nft_delset(const struct nft_ctx *ctx, struct nft_set *set)\n \n \terr = nft_trans_set_add(ctx, NFT_MSG_DELSET, set);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \tnft_deactivate_next(ctx->net, set);\n \tctx->table->use--;\n \n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static int nft_trans_obj_add(struct nft_ctx *ctx, int msg_type,\n@@ -523,12 +530,14 @@ static int nft_delobj(struct nft_ctx *ctx, struct nft_object *obj)\n \n \terr = nft_trans_obj_add(ctx, NFT_MSG_DELOBJ, obj);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \tnft_deactivate_next(ctx->net, obj);\n \tctx->table->use--;\n \n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static int nft_trans_flowtable_add(struct nft_ctx *ctx, int msg_type,\n@@ -558,12 +567,14 @@ static int nft_delflowtable(struct nft_ctx *ctx,\n \n \terr = nft_trans_flowtable_add(ctx, NFT_MSG_DELFLOWTABLE, flowtable);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \tnft_deactivate_next(ctx->net, flowtable);\n \tctx->table->use--;\n \n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static void __nft_reg_track_clobber(struct nft_regs_track *track, u8 dreg)\n@@ -932,7 +943,8 @@ static int nft_netlink_dump_start_rcu(struct sock *nlsk, struct sk_buff *skb,\n \trcu_read_lock();\n \tmodule_put(THIS_MODULE);\n \n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n /* called with rcu_read_lock held */\n@@ -976,7 +988,8 @@ static int nf_tables_gettable(struct sk_buff *skb, const struct nfnl_info *info,\n \n err_fill_table_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static void nft_table_disable(struct net *net, struct nft_table *table, u32 cnt)\n@@ -1019,7 +1032,8 @@ static int nf_tables_table_enable(struct net *net, struct nft_table *table)\n err_register_hooks:\n \tif (i)\n \t\tnft_table_disable(net, table, i);\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static void nf_tables_table_disable(struct net *net, struct nft_table *table)\n@@ -1254,7 +1268,8 @@ static int nf_tables_newtable(struct sk_buff *skb, const struct nfnl_info *info,\n err_strdup:\n \tkfree(table);\n err_kzalloc:\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static int nft_flush_table(struct nft_ctx *ctx)\n@@ -1326,7 +1341,8 @@ static int nft_flush_table(struct nft_ctx *ctx)\n \n \terr = nft_deltable(ctx);\n out:\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static int nft_flush(struct nft_ctx *ctx, int family)\n@@ -1359,7 +1375,8 @@ static int nft_flush(struct nft_ctx *ctx, int family)\n \t\t\tgoto out;\n \t}\n out:\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static int nf_tables_deltable(struct sk_buff *skb, const struct nfnl_info *info,\n@@ -1786,7 +1803,8 @@ static int nf_tables_getchain(struct sk_buff *skb, const struct nfnl_info *info,\n \n err_fill_chain_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static const struct nla_policy nft_counter_policy[NFTA_COUNTER_MAX + 1] = {\n@@ -1977,7 +1995,8 @@ static int nf_tables_parse_netdev_hooks(struct net *net,\n \t\tlist_del(&hook->list);\n \t\tkfree(hook);\n \t}\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n struct nft_chain_hook {\n@@ -2004,7 +2023,8 @@ static int nft_chain_parse_netdev(struct net *net,\n \t\terr = nf_tables_parse_netdev_hooks(net, tb[NFTA_HOOK_DEVS],\n \t\t\t\t\t\t   hook_list);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \n \t\tif (list_empty(hook_list))\n \t\t\treturn -EINVAL;\n@@ -2032,7 +2052,8 @@ static int nft_chain_parse_hook(struct net *net,\n \t\t\t\t\t  nla[NFTA_CHAIN_HOOK],\n \t\t\t\t\t  nft_hook_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \tif (ha[NFTA_HOOK_HOOKNUM] == NULL ||\n \t    ha[NFTA_HOOK_PRIORITY] == NULL)\n@@ -2073,7 +2094,8 @@ 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-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t\t}\n \t} else if (ha[NFTA_HOOK_DEV] || ha[NFTA_HOOK_DEVS]) {\n \t\tmodule_put(type->owner);\n@@ -2181,7 +2203,8 @@ static int nft_chain_add(struct nft_table *table, struct nft_chain *chain)\n \terr = rhltable_insert_key(&table->chains_ht, chain->name,\n \t\t\t\t  &chain->rhlhead, nft_chain_ht_params);\n \tif (err)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \tlist_add_tail_rcu(&chain->list, &table->chains);\n \n@@ -2218,7 +2241,8 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n \t\terr = nft_chain_parse_hook(net, nla, &hook, family, extack,\n \t\t\t\t\t   true);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \n \t\tbasechain = kzalloc(sizeof(*basechain), GFP_KERNEL_ACCOUNT);\n \t\tif (basechain == NULL) {\n@@ -2241,7 +2265,8 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n \t\tif (err < 0) {\n \t\t\tnft_chain_release_hook(&hook);\n \t\t\tkfree(basechain);\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t\t}\n \t} else {\n \t\tif (flags & NFT_CHAIN_BASE)\n@@ -2328,7 +2353,8 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n err_destroy_chain:\n \tnf_tables_chain_destroy(ctx);\n \n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static bool nft_hook_list_equal(struct list_head *hook_list1,\n@@ -2375,7 +2401,8 @@ static int nf_tables_updchain(struct nft_ctx *ctx, u8 genmask, u8 policy,\n \t\terr = nft_chain_parse_hook(ctx->net, nla, &hook, ctx->family,\n \t\t\t\t\t   extack, false);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \n \t\tbasechain = nft_base_chain(chain);\n \t\tif (basechain->type != hook.type) {\n@@ -2470,7 +2497,8 @@ static int nf_tables_updchain(struct nft_ctx *ctx, u8 genmask, u8 policy,\n err:\n \tfree_percpu(stats);\n \tkfree(trans);\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static struct nft_chain *nft_chain_lookup_byid(const struct net *net,\n@@ -2643,7 +2671,8 @@ static int nf_tables_delchain(struct sk_buff *skb, const struct nfnl_info *info,\n \n \t\terr = nft_delrule(&ctx, rule);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t}\n \n \t/* There are rules and elements that are still holding references to us,\n@@ -2813,7 +2842,8 @@ static int nf_tables_expr_parse(const struct nft_ctx *ctx,\n \terr = nla_parse_nested_deprecated(tb, NFTA_EXPR_MAX, nla,\n \t\t\t\t\t  nft_expr_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \ttype = nft_expr_type_get(ctx->net, ctx->family, tb[NFTA_EXPR_NAME]);\n \tif (IS_ERR(type))\n@@ -2852,7 +2882,8 @@ static int nf_tables_expr_parse(const struct nft_ctx *ctx,\n \n err1:\n \tmodule_put(type->owner);\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static int nf_tables_newexpr(const struct nft_ctx *ctx,\n@@ -2872,7 +2903,8 @@ static int nf_tables_newexpr(const struct nft_ctx *ctx,\n \treturn 0;\n err1:\n \texpr->ops = NULL;\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static void nf_tables_expr_destroy(const struct nft_ctx *ctx,\n@@ -2931,7 +2963,8 @@ int nft_expr_clone(struct nft_expr *dst, struct nft_expr *src)\n \t\tdst->ops = src->ops;\n \t\terr = src->ops->clone(dst, src);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t} else {\n \t\tmemcpy(dst, src, src->ops->size);\n \t}\n@@ -3298,7 +3331,8 @@ static int nf_tables_getrule(struct sk_buff *skb, const struct nfnl_info *info,\n \n err_fill_rule_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static void nf_tables_rule_destroy(const struct nft_ctx *ctx,\n@@ -3345,7 +3379,8 @@ int nft_chain_validate(const struct nft_ctx *ctx, const struct nft_chain *chain)\n \n \t\t\terr = expr->ops->validate(ctx, expr, &data);\n \t\t\tif (err < 0)\n-\t\t\t\treturn err;\n+\t\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t\t}\n \n \t\tcond_resched();\n@@ -3371,7 +3406,8 @@ static int nft_table_validate(struct net *net, const struct nft_table *table)\n \t\tctx.chain = chain;\n \t\terr = nft_chain_validate(&ctx, chain);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t}\n \n \treturn 0;\n@@ -3608,7 +3644,8 @@ static int nf_tables_newrule(struct sk_buff *skb, const struct nfnl_info *info,\n \t}\n \tkvfree(expr_info);\n \n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static struct nft_rule *nft_rule_lookup_byid(const struct net *net,\n@@ -3695,7 +3732,8 @@ static int nf_tables_delrule(struct sk_buff *skb, const struct nfnl_info *info,\n \t\t}\n \t}\n \n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n /*\n@@ -4261,7 +4299,8 @@ static int nf_tables_getset(struct sk_buff *skb, const struct nfnl_info *info,\n \n err_fill_set_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static const struct nla_policy nft_concat_policy[NFTA_SET_FIELD_MAX + 1] = {\n@@ -4281,7 +4320,8 @@ static int nft_set_desc_concat_parse(const struct nlattr *attr,\n \terr = nla_parse_nested_deprecated(tb, NFTA_SET_FIELD_MAX, attr,\n \t\t\t\t\t  nft_concat_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \tif (!tb[NFTA_SET_FIELD_LEN])\n \t\treturn -EINVAL;\n@@ -4308,7 +4348,8 @@ static int nft_set_desc_concat(struct nft_set_desc *desc,\n \n \t\terr = nft_set_desc_concat_parse(attr, desc);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t}\n \n \tfor (i = 0; i < desc->field_count; i++)\n@@ -4329,14 +4370,16 @@ static int nf_tables_set_desc_parse(struct nft_set_desc *desc,\n \terr = nla_parse_nested_deprecated(da, NFTA_SET_DESC_MAX, nla,\n \t\t\t\t\t  nft_set_desc_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \tif (da[NFTA_SET_DESC_SIZE] != NULL)\n \t\tdesc->size = ntohl(nla_get_be32(da[NFTA_SET_DESC_SIZE]));\n \tif (da[NFTA_SET_DESC_CONCAT])\n \t\terr = nft_set_desc_concat(desc, da[NFTA_SET_DESC_CONCAT]);\n \n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static int nf_tables_newset(struct sk_buff *skb, const struct nfnl_info *info,\n@@ -4438,7 +4481,8 @@ static int nf_tables_newset(struct sk_buff *skb, const struct nfnl_info *info,\n \n \t\terr = nf_msecs_to_jiffies64(nla[NFTA_SET_TIMEOUT], &timeout);\n \t\tif (err)\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t}\n \tgc_int = 0;\n \tif (nla[NFTA_SET_GC_INTERVAL] != NULL) {\n@@ -4454,7 +4498,8 @@ static int nf_tables_newset(struct sk_buff *skb, const struct nfnl_info *info,\n \tif (nla[NFTA_SET_DESC] != NULL) {\n \t\terr = nf_tables_set_desc_parse(&desc, nla[NFTA_SET_DESC]);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \n \t\tif (desc.field_count > 1 && !(flags & NFT_SET_CONCAT))\n \t\t\treturn -EINVAL;\n@@ -4611,7 +4656,8 @@ static int nf_tables_newset(struct sk_buff *skb, const struct nfnl_info *info,\n \tkfree(set->name);\n err_set_name:\n \tkvfree(set);\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n struct nft_set_elem_catchall {\n@@ -5298,11 +5344,13 @@ static int nft_get_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \terr = nla_parse_nested_deprecated(nla, NFTA_SET_ELEM_MAX, attr,\n \t\t\t\t\t  nft_set_elem_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \terr = nft_setelem_parse_flags(set, nla[NFTA_SET_ELEM_FLAGS], &flags);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \tif (!nla[NFTA_SET_ELEM_KEY] && !(flags & NFT_SET_ELEM_CATCHALL))\n \t\treturn -EINVAL;\n@@ -5311,24 +5359,28 @@ static int nft_get_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \t\terr = nft_setelem_parse_key(ctx, set, &elem.key.val,\n \t\t\t\t\t    nla[NFTA_SET_ELEM_KEY]);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t}\n \n \tif (nla[NFTA_SET_ELEM_KEY_END]) {\n \t\terr = nft_setelem_parse_key(ctx, set, &elem.key_end.val,\n \t\t\t\t\t    nla[NFTA_SET_ELEM_KEY_END]);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t}\n \n \terr = nft_setelem_get(ctx, set, &elem, flags);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \terr = -ENOMEM;\n \tskb = nlmsg_new(NLMSG_GOODSIZE, GFP_ATOMIC);\n \tif (skb == NULL)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \terr = nf_tables_fill_setelem_info(skb, ctx, ctx->seq, ctx->portid,\n \t\t\t\t\t  NFT_MSG_NEWSETELEM, 0, set, &elem);\n@@ -5339,7 +5391,8 @@ static int nft_get_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \n err_fill_setelem:\n \tkfree_skb(skb);\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n /* called with rcu_read_lock held */\n@@ -5397,7 +5450,8 @@ static int nf_tables_getsetelem(struct sk_buff *skb,\n \t\t}\n \t}\n \n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static void nf_tables_setelem_notify(const struct nft_ctx *ctx,\n@@ -5898,13 +5952,15 @@ static int nft_add_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \terr = nla_parse_nested_deprecated(nla, NFTA_SET_ELEM_MAX, attr,\n \t\t\t\t\t  nft_set_elem_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \tnft_set_ext_prepare(&tmpl);\n \n \terr = nft_setelem_parse_flags(set, nla[NFTA_SET_ELEM_FLAGS], &flags);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \tif (!nla[NFTA_SET_ELEM_KEY] && !(flags & NFT_SET_ELEM_CATCHALL))\n \t\treturn -EINVAL;\n@@ -5912,7 +5968,8 @@ static int nft_add_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \tif (flags != 0) {\n \t\terr = nft_set_ext_add(&tmpl, NFT_SET_EXT_FLAGS);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t}\n \n \tif (set->flags & NFT_SET_MAP) {\n@@ -5954,7 +6011,8 @@ static int nft_add_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \t\terr = nf_msecs_to_jiffies64(nla[NFTA_SET_ELEM_TIMEOUT],\n \t\t\t\t\t    &timeout);\n \t\tif (err)\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t} else if (set->flags & NFT_SET_TIMEOUT) {\n \t\ttimeout = set->timeout;\n \t}\n@@ -5966,7 +6024,8 @@ static int nft_add_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \t\terr = nf_msecs_to_jiffies64(nla[NFTA_SET_ELEM_EXPIRATION],\n \t\t\t\t\t    &expiration);\n \t\tif (err)\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t}\n \n \tif (nla[NFTA_SET_ELEM_EXPR]) {\n@@ -6231,7 +6290,8 @@ static int nft_add_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \tfor (i = 0; i < num_exprs && expr_array[i]; i++)\n \t\tnft_expr_destroy(ctx, expr_array[i]);\n err_set_elem_expr_clone:\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static int nf_tables_newsetelem(struct sk_buff *skb,\n@@ -6273,7 +6333,8 @@ static int nf_tables_newsetelem(struct sk_buff *skb,\n \t\terr = nft_add_set_elem(&ctx, set, attr, info->nlh->nlmsg_flags);\n \t\tif (err < 0) {\n \t\t\tNL_SET_BAD_ATTR(extack, attr);\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t\t}\n \t}\n \n@@ -6357,11 +6418,13 @@ static int nft_del_setelem(struct nft_ctx *ctx, struct nft_set *set,\n \terr = nla_parse_nested_deprecated(nla, NFTA_SET_ELEM_MAX, attr,\n \t\t\t\t\t  nft_set_elem_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \terr = nft_setelem_parse_flags(set, nla[NFTA_SET_ELEM_FLAGS], &flags);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \tif (!nla[NFTA_SET_ELEM_KEY] && !(flags & NFT_SET_ELEM_CATCHALL))\n \t\treturn -EINVAL;\n@@ -6374,14 +6437,16 @@ static int nft_del_setelem(struct nft_ctx *ctx, struct nft_set *set,\n \tif (flags != 0) {\n \t\terr = nft_set_ext_add(&tmpl, NFT_SET_EXT_FLAGS);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t}\n \n \tif (nla[NFTA_SET_ELEM_KEY]) {\n \t\terr = nft_setelem_parse_key(ctx, set, &elem.key.val,\n \t\t\t\t\t    nla[NFTA_SET_ELEM_KEY]);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \n \t\terr = nft_set_ext_add_length(&tmpl, NFT_SET_EXT_KEY, set->klen);\n \t\tif (err < 0)\n@@ -6434,7 +6499,8 @@ static int nft_del_setelem(struct nft_ctx *ctx, struct nft_set *set,\n \tnft_data_release(&elem.key_end.val, NFT_DATA_VALUE);\n fail_elem:\n \tnft_data_release(&elem.key.val, NFT_DATA_VALUE);\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static int nft_setelem_flush(const struct nft_ctx *ctx,\n@@ -6464,7 +6530,8 @@ static int nft_setelem_flush(const struct nft_ctx *ctx,\n \treturn 0;\n err1:\n \tkfree(trans);\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static int __nft_set_catchall_flush(const struct nft_ctx *ctx,\n@@ -6563,7 +6630,8 @@ static int nf_tables_delsetelem(struct sk_buff *skb,\n \t\t\tbreak;\n \t\t}\n \t}\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n void nft_set_gc_batch_release(struct rcu_head *rcu)\n@@ -6821,7 +6889,8 @@ static int nf_tables_updobj(const struct nft_ctx *ctx,\n \tkfree(trans);\n err_trans:\n \tmodule_put(type->owner);\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static int nf_tables_newobj(struct sk_buff *skb, const struct nfnl_info *info,\n@@ -6856,7 +6925,8 @@ static int nf_tables_newobj(struct sk_buff *skb, const struct nfnl_info *info,\n \t\terr = PTR_ERR(obj);\n \t\tif (err != -ENOENT) {\n \t\t\tNL_SET_BAD_ATTR(extack, nla[NFTA_OBJ_NAME]);\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t\t}\n \t} else {\n \t\tif (info->nlh->nlmsg_flags & NLM_F_EXCL) {\n@@ -6915,7 +6985,8 @@ static int nf_tables_newobj(struct sk_buff *skb, const struct nfnl_info *info,\n err_obj_ht:\n \t/* queued in transaction log */\n \tINIT_LIST_HEAD(&obj->list);\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n err_trans:\n \tkfree(obj->udata);\n err_userdata:\n@@ -6926,7 +6997,8 @@ 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-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static int nf_tables_fill_obj_info(struct sk_buff *skb, struct net *net,\n@@ -7154,7 +7226,8 @@ static int nf_tables_getobj(struct sk_buff *skb, const struct nfnl_info *info,\n \n err_fill_obj_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static void nft_obj_destroy(const struct nft_ctx *ctx, struct nft_object *obj)\n@@ -7364,7 +7437,8 @@ static int nft_flowtable_parse_hook(const struct nft_ctx *ctx,\n \terr = nla_parse_nested_deprecated(tb, NFTA_FLOWTABLE_HOOK_MAX, attr,\n \t\t\t\t\t  nft_flowtable_hook_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \tif (add) {\n \t\tif (!tb[NFTA_FLOWTABLE_HOOK_NUM] ||\n@@ -7401,7 +7475,8 @@ static int nft_flowtable_parse_hook(const struct nft_ctx *ctx,\n \t\t\t\t\t\t   tb[NFTA_FLOWTABLE_HOOK_DEVS],\n \t\t\t\t\t\t   &flowtable_hook->list);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t}\n \n \tlist_for_each_entry(hook, &flowtable_hook->list, list) {\n@@ -7412,7 +7487,8 @@ static int nft_flowtable_parse_hook(const struct nft_ctx *ctx,\n \t\thook->ops.hook\t\t= flowtable->data.type->hook;\n \t}\n \n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static const struct nf_flowtable_type *__nft_flowtable_type_get(u8 family)\n@@ -7528,7 +7604,8 @@ static int nft_register_flowtable_net_hooks(struct net *net,\n \t\tkfree_rcu(hook, rcu);\n \t}\n \n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static void nft_flowtable_hooks_destroy(struct list_head *hook_list)\n@@ -7555,7 +7632,8 @@ static int nft_flowtable_update(struct nft_ctx *ctx, const struct nlmsghdr *nlh,\n \terr = nft_flowtable_parse_hook(ctx, nla[NFTA_FLOWTABLE_HOOK],\n \t\t\t\t       &flowtable_hook, flowtable, false);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \tlist_for_each_entry_safe(hook, next, &flowtable_hook.list, list) {\n \t\tif (nft_hook_list_find(&flowtable->hook_list, hook)) {\n@@ -7610,7 +7688,8 @@ static int nft_flowtable_update(struct nft_ctx *ctx, const struct nlmsghdr *nlh,\n \t\tkfree_rcu(hook, rcu);\n \t}\n \n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n \n }\n \n@@ -7648,7 +7727,8 @@ static int nf_tables_newflowtable(struct sk_buff *skb,\n \t\terr = PTR_ERR(flowtable);\n \t\tif (err != -ENOENT) {\n \t\t\tNL_SET_BAD_ATTR(extack, nla[NFTA_FLOWTABLE_NAME]);\n-\t\t\treturn err;\n+\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t\t}\n \t} else {\n \t\tif (info->nlh->nlmsg_flags & NLM_F_EXCL) {\n@@ -7737,7 +7817,8 @@ static int nf_tables_newflowtable(struct sk_buff *skb,\n \tkfree(flowtable->name);\n err1:\n \tkfree(flowtable);\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static void nft_flowtable_hook_release(struct nft_flowtable_hook *flowtable_hook)\n@@ -7763,7 +7844,8 @@ static int nft_delflowtable_hook(struct nft_ctx *ctx,\n \terr = nft_flowtable_parse_hook(ctx, nla[NFTA_FLOWTABLE_HOOK],\n \t\t\t\t       &flowtable_hook, flowtable, false);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \tlist_for_each_entry(this, &flowtable_hook.list, list) {\n \t\thook = nft_hook_list_find(&flowtable->hook_list, this);\n@@ -7795,7 +7877,8 @@ static int nft_delflowtable_hook(struct nft_ctx *ctx,\n \tlist_splice(&flowtable_del_list, &flowtable->hook_list);\n \tnft_flowtable_hook_release(&flowtable_hook);\n \n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static int nf_tables_delflowtable(struct sk_buff *skb,\n@@ -8044,7 +8127,8 @@ static int nf_tables_getflowtable(struct sk_buff *skb,\n \n err_fill_flowtable_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static void nf_tables_flowtable_notify(struct nft_ctx *ctx,\n@@ -8219,7 +8303,8 @@ static int nf_tables_getgen(struct sk_buff *skb, const struct nfnl_info *info,\n \n err_fill_gen_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static const struct nfnl_callback nf_tables_cb[NFT_MSG_MAX] = {\n@@ -8865,7 +8950,8 @@ static int nf_tables_commit(struct net *net, struct sk_buff *skb)\n \n \terr = nft_flow_rule_offload_commit(net);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \t/* 1.  Allocate space for next generation rules_gen_X[] */\n \tlist_for_each_entry_safe(trans, next, &nft_net->commit_list, list) {\n@@ -9461,7 +9547,8 @@ static int nf_tables_check_loops(const struct nft_ctx *ctx,\n \t\t\t\terr = nf_tables_check_loops(ctx,\n \t\t\t\t\t\t\tdata->verdict.chain);\n \t\t\t\tif (err < 0)\n-\t\t\t\t\treturn err;\n+\t\t\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t\t\t\tbreak;\n \t\t\tdefault:\n \t\t\t\tbreak;\n@@ -9584,11 +9671,13 @@ int nft_parse_register_load(const struct nlattr *attr, u8 *sreg, u32 len)\n \n \terr = nft_parse_register(attr, &reg);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \terr = nft_validate_register_load(reg, len);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \t*sreg = reg;\n \treturn 0;\n@@ -9613,7 +9702,8 @@ static int nft_validate_register_store(const struct nft_ctx *ctx,\n \t\t     data->verdict.code == NFT_JUMP)) {\n \t\t\terr = nf_tables_check_loops(ctx, data->verdict.chain);\n \t\t\tif (err < 0)\n-\t\t\t\treturn err;\n+\t\t\t\tnft_chain_release_hook(hook);\n+return err;\n \t\t}\n \n \t\treturn 0;\n@@ -9642,11 +9732,13 @@ int nft_parse_register_store(const struct nft_ctx *ctx,\n \n \terr = nft_parse_register(attr, &reg);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \terr = nft_validate_register_store(ctx, reg, data, type, len);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \t*dreg = reg;\n \treturn 0;\n@@ -9671,7 +9763,8 @@ static int nft_verdict_init(const struct nft_ctx *ctx, struct nft_data *data,\n \terr = nla_parse_nested_deprecated(tb, NFTA_VERDICT_MAX, nla,\n \t\t\t\t\t  nft_verdict_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \tif (!tb[NFTA_VERDICT_CODE])\n \t\treturn -EINVAL;\n@@ -9835,7 +9928,8 @@ int nft_data_init(const struct nft_ctx *ctx, struct nft_data *data,\n \terr = nla_parse_nested_deprecated(tb, NFTA_DATA_MAX, nla,\n \t\t\t\t\t  nft_data_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \tif (tb[NFTA_DATA_VALUE]) {\n \t\tif (desc->type != NFT_DATA_VALUE)\n@@ -9851,7 +9945,8 @@ int nft_data_init(const struct nft_ctx *ctx, struct nft_data *data,\n \t\terr = -EINVAL;\n \t}\n \n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n EXPORT_SYMBOL_GPL(nft_data_init);\n \n@@ -9900,7 +9995,8 @@ int nft_data_dump(struct sk_buff *skb, int attr, const struct nft_data *data,\n \t}\n \n \tnla_nest_end(skb, nest);\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n EXPORT_SYMBOL_GPL(nft_data_dump);\n \n@@ -10108,7 +10204,8 @@ static int __init nf_tables_module_init(void)\n \n \terr = register_pernet_subsys(&nf_tables_net_ops);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tnft_chain_release_hook(hook);\n+return err;\n \n \terr = nft_chain_filter_init();\n \tif (err < 0)\n@@ -10141,7 +10238,8 @@ static int __init nf_tables_module_init(void)\n \n \tnft_chain_route_init();\n \n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n \n err_nfnl_subsys:\n \tnetlink_unregister_notifier(&nft_nl_notifier);\n@@ -10157,7 +10255,8 @@ static int __init nf_tables_module_init(void)\n \tnft_chain_filter_fini();\n err_chain_filter:\n \tunregister_pernet_subsys(&nf_tables_net_ops);\n-\treturn err;\n+\tnft_chain_release_hook(hook);\n+return err;\n }\n \n static void __exit nf_tables_module_exit(void)\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..537a61e86aac 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -218,7 +218,7 @@ static int nft_netdev_register_hooks(struct net *net,\n \n \t\tnf_unregister_net_hook(net, &hook->ops);\n \t}\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static void nft_netdev_unregister_hooks(struct net *net,\n@@ -318,10 +318,10 @@ static int nft_deltable(struct nft_ctx *ctx)\n \n \terr = nft_trans_table_add(ctx, NFT_MSG_DELTABLE);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \tnft_deactivate_next(ctx->net, ctx->table);\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static struct nft_trans *nft_trans_chain_add(struct nft_ctx *ctx, int msg_type)\n@@ -442,7 +442,7 @@ static int nft_delrule(struct nft_ctx *ctx, struct nft_rule *rule)\n \terr = nf_tables_delrule_deactivate(ctx, rule);\n \tif (err < 0) {\n \t\tnft_trans_destroy(trans);\n-\t\treturn err;\n+\t\tgoto err_hook;\n \t}\n \tnft_rule_expr_deactivate(ctx, rule, NFT_TRANS_PREPARE);\n \n@@ -460,7 +460,7 @@ static int nft_delrule_by_chain(struct nft_ctx *ctx)\n \n \t\terr = nft_delrule(ctx, rule);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \t}\n \treturn 0;\n }\n@@ -491,12 +491,12 @@ static int nft_delset(const struct nft_ctx *ctx, struct nft_set *set)\n \n \terr = nft_trans_set_add(ctx, NFT_MSG_DELSET, set);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \tnft_deactivate_next(ctx->net, set);\n \tctx->table->use--;\n \n-\treturn err;\n+\tgoto err_hook;\n }\n \n static int nft_trans_obj_add(struct nft_ctx *ctx, int msg_type,\n@@ -523,12 +523,12 @@ static int nft_delobj(struct nft_ctx *ctx, struct nft_object *obj)\n \n \terr = nft_trans_obj_add(ctx, NFT_MSG_DELOBJ, obj);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \tnft_deactivate_next(ctx->net, obj);\n \tctx->table->use--;\n \n-\treturn err;\n+\tgoto err_hook;\n }\n \n static int nft_trans_flowtable_add(struct nft_ctx *ctx, int msg_type,\n@@ -558,12 +558,12 @@ static int nft_delflowtable(struct nft_ctx *ctx,\n \n \terr = nft_trans_flowtable_add(ctx, NFT_MSG_DELFLOWTABLE, flowtable);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \tnft_deactivate_next(ctx->net, flowtable);\n \tctx->table->use--;\n \n-\treturn err;\n+\tgoto err_hook;\n }\n \n static void __nft_reg_track_clobber(struct nft_regs_track *track, u8 dreg)\n@@ -932,7 +932,7 @@ static int nft_netlink_dump_start_rcu(struct sock *nlsk, struct sk_buff *skb,\n \trcu_read_lock();\n \tmodule_put(THIS_MODULE);\n \n-\treturn err;\n+\tgoto err_hook;\n }\n \n /* called with rcu_read_lock held */\n@@ -976,7 +976,7 @@ static int nf_tables_gettable(struct sk_buff *skb, const struct nfnl_info *info,\n \n err_fill_table_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static void nft_table_disable(struct net *net, struct nft_table *table, u32 cnt)\n@@ -1019,7 +1019,7 @@ static int nf_tables_table_enable(struct net *net, struct nft_table *table)\n err_register_hooks:\n \tif (i)\n \t\tnft_table_disable(net, table, i);\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static void nf_tables_table_disable(struct net *net, struct nft_table *table)\n@@ -1254,7 +1254,7 @@ static int nf_tables_newtable(struct sk_buff *skb, const struct nfnl_info *info,\n err_strdup:\n \tkfree(table);\n err_kzalloc:\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static int nft_flush_table(struct nft_ctx *ctx)\n@@ -1326,7 +1326,7 @@ static int nft_flush_table(struct nft_ctx *ctx)\n \n \terr = nft_deltable(ctx);\n out:\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static int nft_flush(struct nft_ctx *ctx, int family)\n@@ -1359,7 +1359,7 @@ static int nft_flush(struct nft_ctx *ctx, int family)\n \t\t\tgoto out;\n \t}\n out:\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static int nf_tables_deltable(struct sk_buff *skb, const struct nfnl_info *info,\n@@ -1786,7 +1786,7 @@ static int nf_tables_getchain(struct sk_buff *skb, const struct nfnl_info *info,\n \n err_fill_chain_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static const struct nla_policy nft_counter_policy[NFTA_COUNTER_MAX + 1] = {\n@@ -1977,7 +1977,7 @@ static int nf_tables_parse_netdev_hooks(struct net *net,\n \t\tlist_del(&hook->list);\n \t\tkfree(hook);\n \t}\n-\treturn err;\n+\tgoto err_hook;\n }\n \n struct nft_chain_hook {\n@@ -2004,7 +2004,7 @@ static int nft_chain_parse_netdev(struct net *net,\n \t\terr = nf_tables_parse_netdev_hooks(net, tb[NFTA_HOOK_DEVS],\n \t\t\t\t\t\t   hook_list);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \n \t\tif (list_empty(hook_list))\n \t\t\treturn -EINVAL;\n@@ -2032,7 +2032,7 @@ static int nft_chain_parse_hook(struct net *net,\n \t\t\t\t\t  nla[NFTA_CHAIN_HOOK],\n \t\t\t\t\t  nft_hook_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \tif (ha[NFTA_HOOK_HOOKNUM] == NULL ||\n \t    ha[NFTA_HOOK_PRIORITY] == NULL)\n@@ -2073,7 +2073,7 @@ 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-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \t\t}\n \t} else if (ha[NFTA_HOOK_DEV] || ha[NFTA_HOOK_DEVS]) {\n \t\tmodule_put(type->owner);\n@@ -2181,7 +2181,7 @@ static int nft_chain_add(struct nft_table *table, struct nft_chain *chain)\n \terr = rhltable_insert_key(&table->chains_ht, chain->name,\n \t\t\t\t  &chain->rhlhead, nft_chain_ht_params);\n \tif (err)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \tlist_add_tail_rcu(&chain->list, &table->chains);\n \n@@ -2218,7 +2218,7 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n \t\terr = nft_chain_parse_hook(net, nla, &hook, family, extack,\n \t\t\t\t\t   true);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \n \t\tbasechain = kzalloc(sizeof(*basechain), GFP_KERNEL_ACCOUNT);\n \t\tif (basechain == NULL) {\n@@ -2241,7 +2241,7 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n \t\tif (err < 0) {\n \t\t\tnft_chain_release_hook(&hook);\n \t\t\tkfree(basechain);\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \t\t}\n \t} else {\n \t\tif (flags & NFT_CHAIN_BASE)\n@@ -2328,7 +2328,7 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n err_destroy_chain:\n \tnf_tables_chain_destroy(ctx);\n \n-\treturn err;\n+\tgoto err_hook;\n }\n \n static bool nft_hook_list_equal(struct list_head *hook_list1,\n@@ -2375,7 +2375,7 @@ static int nf_tables_updchain(struct nft_ctx *ctx, u8 genmask, u8 policy,\n \t\terr = nft_chain_parse_hook(ctx->net, nla, &hook, ctx->family,\n \t\t\t\t\t   extack, false);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \n \t\tbasechain = nft_base_chain(chain);\n \t\tif (basechain->type != hook.type) {\n@@ -2470,7 +2470,7 @@ static int nf_tables_updchain(struct nft_ctx *ctx, u8 genmask, u8 policy,\n err:\n \tfree_percpu(stats);\n \tkfree(trans);\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static struct nft_chain *nft_chain_lookup_byid(const struct net *net,\n@@ -2643,7 +2643,7 @@ static int nf_tables_delchain(struct sk_buff *skb, const struct nfnl_info *info,\n \n \t\terr = nft_delrule(&ctx, rule);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \t}\n \n \t/* There are rules and elements that are still holding references to us,\n@@ -2813,7 +2813,7 @@ static int nf_tables_expr_parse(const struct nft_ctx *ctx,\n \terr = nla_parse_nested_deprecated(tb, NFTA_EXPR_MAX, nla,\n \t\t\t\t\t  nft_expr_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \ttype = nft_expr_type_get(ctx->net, ctx->family, tb[NFTA_EXPR_NAME]);\n \tif (IS_ERR(type))\n@@ -2852,7 +2852,7 @@ static int nf_tables_expr_parse(const struct nft_ctx *ctx,\n \n err1:\n \tmodule_put(type->owner);\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static int nf_tables_newexpr(const struct nft_ctx *ctx,\n@@ -2872,7 +2872,7 @@ static int nf_tables_newexpr(const struct nft_ctx *ctx,\n \treturn 0;\n err1:\n \texpr->ops = NULL;\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static void nf_tables_expr_destroy(const struct nft_ctx *ctx,\n@@ -2931,7 +2931,7 @@ int nft_expr_clone(struct nft_expr *dst, struct nft_expr *src)\n \t\tdst->ops = src->ops;\n \t\terr = src->ops->clone(dst, src);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \t} else {\n \t\tmemcpy(dst, src, src->ops->size);\n \t}\n@@ -3298,7 +3298,7 @@ static int nf_tables_getrule(struct sk_buff *skb, const struct nfnl_info *info,\n \n err_fill_rule_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static void nf_tables_rule_destroy(const struct nft_ctx *ctx,\n@@ -3345,7 +3345,7 @@ int nft_chain_validate(const struct nft_ctx *ctx, const struct nft_chain *chain)\n \n \t\t\terr = expr->ops->validate(ctx, expr, &data);\n \t\t\tif (err < 0)\n-\t\t\t\treturn err;\n+\t\t\t\tgoto err_hook;\n \t\t}\n \n \t\tcond_resched();\n@@ -3371,7 +3371,7 @@ static int nft_table_validate(struct net *net, const struct nft_table *table)\n \t\tctx.chain = chain;\n \t\terr = nft_chain_validate(&ctx, chain);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \t}\n \n \treturn 0;\n@@ -3608,7 +3608,7 @@ static int nf_tables_newrule(struct sk_buff *skb, const struct nfnl_info *info,\n \t}\n \tkvfree(expr_info);\n \n-\treturn err;\n+\tgoto err_hook;\n }\n \n static struct nft_rule *nft_rule_lookup_byid(const struct net *net,\n@@ -3695,7 +3695,7 @@ static int nf_tables_delrule(struct sk_buff *skb, const struct nfnl_info *info,\n \t\t}\n \t}\n \n-\treturn err;\n+\tgoto err_hook;\n }\n \n /*\n@@ -4261,7 +4261,7 @@ static int nf_tables_getset(struct sk_buff *skb, const struct nfnl_info *info,\n \n err_fill_set_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static const struct nla_policy nft_concat_policy[NFTA_SET_FIELD_MAX + 1] = {\n@@ -4281,7 +4281,7 @@ static int nft_set_desc_concat_parse(const struct nlattr *attr,\n \terr = nla_parse_nested_deprecated(tb, NFTA_SET_FIELD_MAX, attr,\n \t\t\t\t\t  nft_concat_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \tif (!tb[NFTA_SET_FIELD_LEN])\n \t\treturn -EINVAL;\n@@ -4308,7 +4308,7 @@ static int nft_set_desc_concat(struct nft_set_desc *desc,\n \n \t\terr = nft_set_desc_concat_parse(attr, desc);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \t}\n \n \tfor (i = 0; i < desc->field_count; i++)\n@@ -4329,14 +4329,14 @@ static int nf_tables_set_desc_parse(struct nft_set_desc *desc,\n \terr = nla_parse_nested_deprecated(da, NFTA_SET_DESC_MAX, nla,\n \t\t\t\t\t  nft_set_desc_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \tif (da[NFTA_SET_DESC_SIZE] != NULL)\n \t\tdesc->size = ntohl(nla_get_be32(da[NFTA_SET_DESC_SIZE]));\n \tif (da[NFTA_SET_DESC_CONCAT])\n \t\terr = nft_set_desc_concat(desc, da[NFTA_SET_DESC_CONCAT]);\n \n-\treturn err;\n+\tgoto err_hook;\n }\n \n static int nf_tables_newset(struct sk_buff *skb, const struct nfnl_info *info,\n@@ -4438,7 +4438,7 @@ static int nf_tables_newset(struct sk_buff *skb, const struct nfnl_info *info,\n \n \t\terr = nf_msecs_to_jiffies64(nla[NFTA_SET_TIMEOUT], &timeout);\n \t\tif (err)\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \t}\n \tgc_int = 0;\n \tif (nla[NFTA_SET_GC_INTERVAL] != NULL) {\n@@ -4454,7 +4454,7 @@ static int nf_tables_newset(struct sk_buff *skb, const struct nfnl_info *info,\n \tif (nla[NFTA_SET_DESC] != NULL) {\n \t\terr = nf_tables_set_desc_parse(&desc, nla[NFTA_SET_DESC]);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \n \t\tif (desc.field_count > 1 && !(flags & NFT_SET_CONCAT))\n \t\t\treturn -EINVAL;\n@@ -4611,7 +4611,7 @@ static int nf_tables_newset(struct sk_buff *skb, const struct nfnl_info *info,\n \tkfree(set->name);\n err_set_name:\n \tkvfree(set);\n-\treturn err;\n+\tgoto err_hook;\n }\n \n struct nft_set_elem_catchall {\n@@ -5298,11 +5298,11 @@ static int nft_get_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \terr = nla_parse_nested_deprecated(nla, NFTA_SET_ELEM_MAX, attr,\n \t\t\t\t\t  nft_set_elem_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \terr = nft_setelem_parse_flags(set, nla[NFTA_SET_ELEM_FLAGS], &flags);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \tif (!nla[NFTA_SET_ELEM_KEY] && !(flags & NFT_SET_ELEM_CATCHALL))\n \t\treturn -EINVAL;\n@@ -5311,24 +5311,24 @@ static int nft_get_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \t\terr = nft_setelem_parse_key(ctx, set, &elem.key.val,\n \t\t\t\t\t    nla[NFTA_SET_ELEM_KEY]);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \t}\n \n \tif (nla[NFTA_SET_ELEM_KEY_END]) {\n \t\terr = nft_setelem_parse_key(ctx, set, &elem.key_end.val,\n \t\t\t\t\t    nla[NFTA_SET_ELEM_KEY_END]);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \t}\n \n \terr = nft_setelem_get(ctx, set, &elem, flags);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \terr = -ENOMEM;\n \tskb = nlmsg_new(NLMSG_GOODSIZE, GFP_ATOMIC);\n \tif (skb == NULL)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \terr = nf_tables_fill_setelem_info(skb, ctx, ctx->seq, ctx->portid,\n \t\t\t\t\t  NFT_MSG_NEWSETELEM, 0, set, &elem);\n@@ -5339,7 +5339,7 @@ static int nft_get_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \n err_fill_setelem:\n \tkfree_skb(skb);\n-\treturn err;\n+\tgoto err_hook;\n }\n \n /* called with rcu_read_lock held */\n@@ -5397,7 +5397,7 @@ static int nf_tables_getsetelem(struct sk_buff *skb,\n \t\t}\n \t}\n \n-\treturn err;\n+\tgoto err_hook;\n }\n \n static void nf_tables_setelem_notify(const struct nft_ctx *ctx,\n@@ -5898,13 +5898,13 @@ static int nft_add_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \terr = nla_parse_nested_deprecated(nla, NFTA_SET_ELEM_MAX, attr,\n \t\t\t\t\t  nft_set_elem_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \tnft_set_ext_prepare(&tmpl);\n \n \terr = nft_setelem_parse_flags(set, nla[NFTA_SET_ELEM_FLAGS], &flags);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \tif (!nla[NFTA_SET_ELEM_KEY] && !(flags & NFT_SET_ELEM_CATCHALL))\n \t\treturn -EINVAL;\n@@ -5912,7 +5912,7 @@ static int nft_add_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \tif (flags != 0) {\n \t\terr = nft_set_ext_add(&tmpl, NFT_SET_EXT_FLAGS);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \t}\n \n \tif (set->flags & NFT_SET_MAP) {\n@@ -5954,7 +5954,7 @@ static int nft_add_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \t\terr = nf_msecs_to_jiffies64(nla[NFTA_SET_ELEM_TIMEOUT],\n \t\t\t\t\t    &timeout);\n \t\tif (err)\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \t} else if (set->flags & NFT_SET_TIMEOUT) {\n \t\ttimeout = set->timeout;\n \t}\n@@ -5966,7 +5966,7 @@ static int nft_add_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \t\terr = nf_msecs_to_jiffies64(nla[NFTA_SET_ELEM_EXPIRATION],\n \t\t\t\t\t    &expiration);\n \t\tif (err)\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \t}\n \n \tif (nla[NFTA_SET_ELEM_EXPR]) {\n@@ -6231,7 +6231,7 @@ static int nft_add_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \tfor (i = 0; i < num_exprs && expr_array[i]; i++)\n \t\tnft_expr_destroy(ctx, expr_array[i]);\n err_set_elem_expr_clone:\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static int nf_tables_newsetelem(struct sk_buff *skb,\n@@ -6273,7 +6273,7 @@ static int nf_tables_newsetelem(struct sk_buff *skb,\n \t\terr = nft_add_set_elem(&ctx, set, attr, info->nlh->nlmsg_flags);\n \t\tif (err < 0) {\n \t\t\tNL_SET_BAD_ATTR(extack, attr);\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \t\t}\n \t}\n \n@@ -6357,11 +6357,11 @@ static int nft_del_setelem(struct nft_ctx *ctx, struct nft_set *set,\n \terr = nla_parse_nested_deprecated(nla, NFTA_SET_ELEM_MAX, attr,\n \t\t\t\t\t  nft_set_elem_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \terr = nft_setelem_parse_flags(set, nla[NFTA_SET_ELEM_FLAGS], &flags);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \tif (!nla[NFTA_SET_ELEM_KEY] && !(flags & NFT_SET_ELEM_CATCHALL))\n \t\treturn -EINVAL;\n@@ -6374,14 +6374,14 @@ static int nft_del_setelem(struct nft_ctx *ctx, struct nft_set *set,\n \tif (flags != 0) {\n \t\terr = nft_set_ext_add(&tmpl, NFT_SET_EXT_FLAGS);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \t}\n \n \tif (nla[NFTA_SET_ELEM_KEY]) {\n \t\terr = nft_setelem_parse_key(ctx, set, &elem.key.val,\n \t\t\t\t\t    nla[NFTA_SET_ELEM_KEY]);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \n \t\terr = nft_set_ext_add_length(&tmpl, NFT_SET_EXT_KEY, set->klen);\n \t\tif (err < 0)\n@@ -6434,7 +6434,7 @@ static int nft_del_setelem(struct nft_ctx *ctx, struct nft_set *set,\n \tnft_data_release(&elem.key_end.val, NFT_DATA_VALUE);\n fail_elem:\n \tnft_data_release(&elem.key.val, NFT_DATA_VALUE);\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static int nft_setelem_flush(const struct nft_ctx *ctx,\n@@ -6464,7 +6464,7 @@ static int nft_setelem_flush(const struct nft_ctx *ctx,\n \treturn 0;\n err1:\n \tkfree(trans);\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static int __nft_set_catchall_flush(const struct nft_ctx *ctx,\n@@ -6563,7 +6563,7 @@ static int nf_tables_delsetelem(struct sk_buff *skb,\n \t\t\tbreak;\n \t\t}\n \t}\n-\treturn err;\n+\tgoto err_hook;\n }\n \n void nft_set_gc_batch_release(struct rcu_head *rcu)\n@@ -6821,7 +6821,7 @@ static int nf_tables_updobj(const struct nft_ctx *ctx,\n \tkfree(trans);\n err_trans:\n \tmodule_put(type->owner);\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static int nf_tables_newobj(struct sk_buff *skb, const struct nfnl_info *info,\n@@ -6856,7 +6856,7 @@ static int nf_tables_newobj(struct sk_buff *skb, const struct nfnl_info *info,\n \t\terr = PTR_ERR(obj);\n \t\tif (err != -ENOENT) {\n \t\t\tNL_SET_BAD_ATTR(extack, nla[NFTA_OBJ_NAME]);\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \t\t}\n \t} else {\n \t\tif (info->nlh->nlmsg_flags & NLM_F_EXCL) {\n@@ -6915,7 +6915,7 @@ static int nf_tables_newobj(struct sk_buff *skb, const struct nfnl_info *info,\n err_obj_ht:\n \t/* queued in transaction log */\n \tINIT_LIST_HEAD(&obj->list);\n-\treturn err;\n+\tgoto err_hook;\n err_trans:\n \tkfree(obj->udata);\n err_userdata:\n@@ -6926,7 +6926,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-\treturn err;\n+\tgoto err_hook;\n }\n \n static int nf_tables_fill_obj_info(struct sk_buff *skb, struct net *net,\n@@ -7154,7 +7154,7 @@ static int nf_tables_getobj(struct sk_buff *skb, const struct nfnl_info *info,\n \n err_fill_obj_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static void nft_obj_destroy(const struct nft_ctx *ctx, struct nft_object *obj)\n@@ -7364,7 +7364,7 @@ static int nft_flowtable_parse_hook(const struct nft_ctx *ctx,\n \terr = nla_parse_nested_deprecated(tb, NFTA_FLOWTABLE_HOOK_MAX, attr,\n \t\t\t\t\t  nft_flowtable_hook_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \tif (add) {\n \t\tif (!tb[NFTA_FLOWTABLE_HOOK_NUM] ||\n@@ -7401,7 +7401,7 @@ static int nft_flowtable_parse_hook(const struct nft_ctx *ctx,\n \t\t\t\t\t\t   tb[NFTA_FLOWTABLE_HOOK_DEVS],\n \t\t\t\t\t\t   &flowtable_hook->list);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \t}\n \n \tlist_for_each_entry(hook, &flowtable_hook->list, list) {\n@@ -7412,7 +7412,7 @@ static int nft_flowtable_parse_hook(const struct nft_ctx *ctx,\n \t\thook->ops.hook\t\t= flowtable->data.type->hook;\n \t}\n \n-\treturn err;\n+\tgoto err_hook;\n }\n \n static const struct nf_flowtable_type *__nft_flowtable_type_get(u8 family)\n@@ -7528,7 +7528,7 @@ static int nft_register_flowtable_net_hooks(struct net *net,\n \t\tkfree_rcu(hook, rcu);\n \t}\n \n-\treturn err;\n+\tgoto err_hook;\n }\n \n static void nft_flowtable_hooks_destroy(struct list_head *hook_list)\n@@ -7555,7 +7555,7 @@ static int nft_flowtable_update(struct nft_ctx *ctx, const struct nlmsghdr *nlh,\n \terr = nft_flowtable_parse_hook(ctx, nla[NFTA_FLOWTABLE_HOOK],\n \t\t\t\t       &flowtable_hook, flowtable, false);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \tlist_for_each_entry_safe(hook, next, &flowtable_hook.list, list) {\n \t\tif (nft_hook_list_find(&flowtable->hook_list, hook)) {\n@@ -7610,7 +7610,7 @@ static int nft_flowtable_update(struct nft_ctx *ctx, const struct nlmsghdr *nlh,\n \t\tkfree_rcu(hook, rcu);\n \t}\n \n-\treturn err;\n+\tgoto err_hook;\n \n }\n \n@@ -7648,7 +7648,7 @@ static int nf_tables_newflowtable(struct sk_buff *skb,\n \t\terr = PTR_ERR(flowtable);\n \t\tif (err != -ENOENT) {\n \t\t\tNL_SET_BAD_ATTR(extack, nla[NFTA_FLOWTABLE_NAME]);\n-\t\t\treturn err;\n+\t\t\tgoto err_hook;\n \t\t}\n \t} else {\n \t\tif (info->nlh->nlmsg_flags & NLM_F_EXCL) {\n@@ -7737,7 +7737,7 @@ static int nf_tables_newflowtable(struct sk_buff *skb,\n \tkfree(flowtable->name);\n err1:\n \tkfree(flowtable);\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static void nft_flowtable_hook_release(struct nft_flowtable_hook *flowtable_hook)\n@@ -7763,7 +7763,7 @@ static int nft_delflowtable_hook(struct nft_ctx *ctx,\n \terr = nft_flowtable_parse_hook(ctx, nla[NFTA_FLOWTABLE_HOOK],\n \t\t\t\t       &flowtable_hook, flowtable, false);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \tlist_for_each_entry(this, &flowtable_hook.list, list) {\n \t\thook = nft_hook_list_find(&flowtable->hook_list, this);\n@@ -7795,7 +7795,7 @@ static int nft_delflowtable_hook(struct nft_ctx *ctx,\n \tlist_splice(&flowtable_del_list, &flowtable->hook_list);\n \tnft_flowtable_hook_release(&flowtable_hook);\n \n-\treturn err;\n+\tgoto err_hook;\n }\n \n static int nf_tables_delflowtable(struct sk_buff *skb,\n@@ -8044,7 +8044,7 @@ static int nf_tables_getflowtable(struct sk_buff *skb,\n \n err_fill_flowtable_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static void nf_tables_flowtable_notify(struct nft_ctx *ctx,\n@@ -8219,7 +8219,7 @@ static int nf_tables_getgen(struct sk_buff *skb, const struct nfnl_info *info,\n \n err_fill_gen_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static const struct nfnl_callback nf_tables_cb[NFT_MSG_MAX] = {\n@@ -8865,7 +8865,7 @@ static int nf_tables_commit(struct net *net, struct sk_buff *skb)\n \n \terr = nft_flow_rule_offload_commit(net);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \t/* 1.  Allocate space for next generation rules_gen_X[] */\n \tlist_for_each_entry_safe(trans, next, &nft_net->commit_list, list) {\n@@ -9461,7 +9461,7 @@ static int nf_tables_check_loops(const struct nft_ctx *ctx,\n \t\t\t\terr = nf_tables_check_loops(ctx,\n \t\t\t\t\t\t\tdata->verdict.chain);\n \t\t\t\tif (err < 0)\n-\t\t\t\t\treturn err;\n+\t\t\t\t\tgoto err_hook;\n \t\t\t\tbreak;\n \t\t\tdefault:\n \t\t\t\tbreak;\n@@ -9584,11 +9584,11 @@ int nft_parse_register_load(const struct nlattr *attr, u8 *sreg, u32 len)\n \n \terr = nft_parse_register(attr, &reg);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \terr = nft_validate_register_load(reg, len);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \t*sreg = reg;\n \treturn 0;\n@@ -9613,7 +9613,7 @@ static int nft_validate_register_store(const struct nft_ctx *ctx,\n \t\t     data->verdict.code == NFT_JUMP)) {\n \t\t\terr = nf_tables_check_loops(ctx, data->verdict.chain);\n \t\t\tif (err < 0)\n-\t\t\t\treturn err;\n+\t\t\t\tgoto err_hook;\n \t\t}\n \n \t\treturn 0;\n@@ -9642,11 +9642,11 @@ int nft_parse_register_store(const struct nft_ctx *ctx,\n \n \terr = nft_parse_register(attr, &reg);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \terr = nft_validate_register_store(ctx, reg, data, type, len);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \t*dreg = reg;\n \treturn 0;\n@@ -9671,7 +9671,7 @@ static int nft_verdict_init(const struct nft_ctx *ctx, struct nft_data *data,\n \terr = nla_parse_nested_deprecated(tb, NFTA_VERDICT_MAX, nla,\n \t\t\t\t\t  nft_verdict_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \tif (!tb[NFTA_VERDICT_CODE])\n \t\treturn -EINVAL;\n@@ -9835,7 +9835,7 @@ int nft_data_init(const struct nft_ctx *ctx, struct nft_data *data,\n \terr = nla_parse_nested_deprecated(tb, NFTA_DATA_MAX, nla,\n \t\t\t\t\t  nft_data_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \tif (tb[NFTA_DATA_VALUE]) {\n \t\tif (desc->type != NFT_DATA_VALUE)\n@@ -9851,7 +9851,7 @@ int nft_data_init(const struct nft_ctx *ctx, struct nft_data *data,\n \t\terr = -EINVAL;\n \t}\n \n-\treturn err;\n+\tgoto err_hook;\n }\n EXPORT_SYMBOL_GPL(nft_data_init);\n \n@@ -9900,7 +9900,7 @@ int nft_data_dump(struct sk_buff *skb, int attr, const struct nft_data *data,\n \t}\n \n \tnla_nest_end(skb, nest);\n-\treturn err;\n+\tgoto err_hook;\n }\n EXPORT_SYMBOL_GPL(nft_data_dump);\n \n@@ -10108,7 +10108,7 @@ static int __init nf_tables_module_init(void)\n \n \terr = register_pernet_subsys(&nf_tables_net_ops);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tgoto err_hook;\n \n \terr = nft_chain_filter_init();\n \tif (err < 0)\n@@ -10141,7 +10141,7 @@ static int __init nf_tables_module_init(void)\n \n \tnft_chain_route_init();\n \n-\treturn err;\n+\tgoto err_hook;\n \n err_nfnl_subsys:\n \tnetlink_unregister_notifier(&nft_nl_notifier);\n@@ -10157,7 +10157,7 @@ static int __init nf_tables_module_init(void)\n \tnft_chain_filter_fini();\n err_chain_filter:\n \tunregister_pernet_subsys(&nf_tables_net_ops);\n-\treturn err;\n+\tgoto err_hook;\n }\n \n static void __exit nf_tables_module_exit(void)\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..6589dec09d55 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -218,7 +218,11 @@ static int nft_netdev_register_hooks(struct net *net,\n \n \t\tnf_unregister_net_hook(net, &hook->ops);\n \t}\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static void nft_netdev_unregister_hooks(struct net *net,\n@@ -318,10 +322,18 @@ static int nft_deltable(struct nft_ctx *ctx)\n \n \terr = nft_trans_table_add(ctx, NFT_MSG_DELTABLE);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \tnft_deactivate_next(ctx->net, ctx->table);\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static struct nft_trans *nft_trans_chain_add(struct nft_ctx *ctx, int msg_type)\n@@ -442,7 +454,11 @@ static int nft_delrule(struct nft_ctx *ctx, struct nft_rule *rule)\n \terr = nf_tables_delrule_deactivate(ctx, rule);\n \tif (err < 0) {\n \t\tnft_trans_destroy(trans);\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t}\n \tnft_rule_expr_deactivate(ctx, rule, NFT_TRANS_PREPARE);\n \n@@ -460,7 +476,11 @@ static int nft_delrule_by_chain(struct nft_ctx *ctx)\n \n \t\terr = nft_delrule(ctx, rule);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t}\n \treturn 0;\n }\n@@ -491,12 +511,20 @@ static int nft_delset(const struct nft_ctx *ctx, struct nft_set *set)\n \n \terr = nft_trans_set_add(ctx, NFT_MSG_DELSET, set);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \tnft_deactivate_next(ctx->net, set);\n \tctx->table->use--;\n \n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static int nft_trans_obj_add(struct nft_ctx *ctx, int msg_type,\n@@ -523,12 +551,20 @@ static int nft_delobj(struct nft_ctx *ctx, struct nft_object *obj)\n \n \terr = nft_trans_obj_add(ctx, NFT_MSG_DELOBJ, obj);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \tnft_deactivate_next(ctx->net, obj);\n \tctx->table->use--;\n \n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static int nft_trans_flowtable_add(struct nft_ctx *ctx, int msg_type,\n@@ -558,12 +594,20 @@ static int nft_delflowtable(struct nft_ctx *ctx,\n \n \terr = nft_trans_flowtable_add(ctx, NFT_MSG_DELFLOWTABLE, flowtable);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \tnft_deactivate_next(ctx->net, flowtable);\n \tctx->table->use--;\n \n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static void __nft_reg_track_clobber(struct nft_regs_track *track, u8 dreg)\n@@ -932,7 +976,11 @@ static int nft_netlink_dump_start_rcu(struct sock *nlsk, struct sk_buff *skb,\n \trcu_read_lock();\n \tmodule_put(THIS_MODULE);\n \n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n /* called with rcu_read_lock held */\n@@ -976,7 +1024,11 @@ static int nf_tables_gettable(struct sk_buff *skb, const struct nfnl_info *info,\n \n err_fill_table_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static void nft_table_disable(struct net *net, struct nft_table *table, u32 cnt)\n@@ -1019,7 +1071,11 @@ static int nf_tables_table_enable(struct net *net, struct nft_table *table)\n err_register_hooks:\n \tif (i)\n \t\tnft_table_disable(net, table, i);\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static void nf_tables_table_disable(struct net *net, struct nft_table *table)\n@@ -1254,7 +1310,11 @@ static int nf_tables_newtable(struct sk_buff *skb, const struct nfnl_info *info,\n err_strdup:\n \tkfree(table);\n err_kzalloc:\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static int nft_flush_table(struct nft_ctx *ctx)\n@@ -1326,7 +1386,11 @@ static int nft_flush_table(struct nft_ctx *ctx)\n \n \terr = nft_deltable(ctx);\n out:\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static int nft_flush(struct nft_ctx *ctx, int family)\n@@ -1359,7 +1423,11 @@ static int nft_flush(struct nft_ctx *ctx, int family)\n \t\t\tgoto out;\n \t}\n out:\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static int nf_tables_deltable(struct sk_buff *skb, const struct nfnl_info *info,\n@@ -1786,7 +1854,11 @@ static int nf_tables_getchain(struct sk_buff *skb, const struct nfnl_info *info,\n \n err_fill_chain_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static const struct nla_policy nft_counter_policy[NFTA_COUNTER_MAX + 1] = {\n@@ -1977,7 +2049,11 @@ static int nf_tables_parse_netdev_hooks(struct net *net,\n \t\tlist_del(&hook->list);\n \t\tkfree(hook);\n \t}\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n struct nft_chain_hook {\n@@ -2004,7 +2080,11 @@ static int nft_chain_parse_netdev(struct net *net,\n \t\terr = nf_tables_parse_netdev_hooks(net, tb[NFTA_HOOK_DEVS],\n \t\t\t\t\t\t   hook_list);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \t\tif (list_empty(hook_list))\n \t\t\treturn -EINVAL;\n@@ -2032,7 +2112,11 @@ static int nft_chain_parse_hook(struct net *net,\n \t\t\t\t\t  nla[NFTA_CHAIN_HOOK],\n \t\t\t\t\t  nft_hook_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \tif (ha[NFTA_HOOK_HOOKNUM] == NULL ||\n \t    ha[NFTA_HOOK_PRIORITY] == NULL)\n@@ -2073,7 +2157,11 @@ 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-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t\t}\n \t} else if (ha[NFTA_HOOK_DEV] || ha[NFTA_HOOK_DEVS]) {\n \t\tmodule_put(type->owner);\n@@ -2181,7 +2269,11 @@ static int nft_chain_add(struct nft_table *table, struct nft_chain *chain)\n \terr = rhltable_insert_key(&table->chains_ht, chain->name,\n \t\t\t\t  &chain->rhlhead, nft_chain_ht_params);\n \tif (err)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \tlist_add_tail_rcu(&chain->list, &table->chains);\n \n@@ -2218,7 +2310,11 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n \t\terr = nft_chain_parse_hook(net, nla, &hook, family, extack,\n \t\t\t\t\t   true);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \t\tbasechain = kzalloc(sizeof(*basechain), GFP_KERNEL_ACCOUNT);\n \t\tif (basechain == NULL) {\n@@ -2241,7 +2337,11 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n \t\tif (err < 0) {\n \t\t\tnft_chain_release_hook(&hook);\n \t\t\tkfree(basechain);\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t\t}\n \t} else {\n \t\tif (flags & NFT_CHAIN_BASE)\n@@ -2328,7 +2428,11 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n err_destroy_chain:\n \tnf_tables_chain_destroy(ctx);\n \n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static bool nft_hook_list_equal(struct list_head *hook_list1,\n@@ -2375,7 +2479,11 @@ static int nf_tables_updchain(struct nft_ctx *ctx, u8 genmask, u8 policy,\n \t\terr = nft_chain_parse_hook(ctx->net, nla, &hook, ctx->family,\n \t\t\t\t\t   extack, false);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \t\tbasechain = nft_base_chain(chain);\n \t\tif (basechain->type != hook.type) {\n@@ -2470,7 +2578,11 @@ static int nf_tables_updchain(struct nft_ctx *ctx, u8 genmask, u8 policy,\n err:\n \tfree_percpu(stats);\n \tkfree(trans);\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static struct nft_chain *nft_chain_lookup_byid(const struct net *net,\n@@ -2643,7 +2755,11 @@ static int nf_tables_delchain(struct sk_buff *skb, const struct nfnl_info *info,\n \n \t\terr = nft_delrule(&ctx, rule);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t}\n \n \t/* There are rules and elements that are still holding references to us,\n@@ -2813,7 +2929,11 @@ static int nf_tables_expr_parse(const struct nft_ctx *ctx,\n \terr = nla_parse_nested_deprecated(tb, NFTA_EXPR_MAX, nla,\n \t\t\t\t\t  nft_expr_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \ttype = nft_expr_type_get(ctx->net, ctx->family, tb[NFTA_EXPR_NAME]);\n \tif (IS_ERR(type))\n@@ -2852,7 +2972,11 @@ static int nf_tables_expr_parse(const struct nft_ctx *ctx,\n \n err1:\n \tmodule_put(type->owner);\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static int nf_tables_newexpr(const struct nft_ctx *ctx,\n@@ -2872,7 +2996,11 @@ static int nf_tables_newexpr(const struct nft_ctx *ctx,\n \treturn 0;\n err1:\n \texpr->ops = NULL;\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static void nf_tables_expr_destroy(const struct nft_ctx *ctx,\n@@ -2931,7 +3059,11 @@ int nft_expr_clone(struct nft_expr *dst, struct nft_expr *src)\n \t\tdst->ops = src->ops;\n \t\terr = src->ops->clone(dst, src);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t} else {\n \t\tmemcpy(dst, src, src->ops->size);\n \t}\n@@ -3298,7 +3430,11 @@ static int nf_tables_getrule(struct sk_buff *skb, const struct nfnl_info *info,\n \n err_fill_rule_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static void nf_tables_rule_destroy(const struct nft_ctx *ctx,\n@@ -3345,7 +3481,11 @@ int nft_chain_validate(const struct nft_ctx *ctx, const struct nft_chain *chain)\n \n \t\t\terr = expr->ops->validate(ctx, expr, &data);\n \t\t\tif (err < 0)\n-\t\t\t\treturn err;\n+\t\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t\t}\n \n \t\tcond_resched();\n@@ -3371,7 +3511,11 @@ static int nft_table_validate(struct net *net, const struct nft_table *table)\n \t\tctx.chain = chain;\n \t\terr = nft_chain_validate(&ctx, chain);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t}\n \n \treturn 0;\n@@ -3608,7 +3752,11 @@ static int nf_tables_newrule(struct sk_buff *skb, const struct nfnl_info *info,\n \t}\n \tkvfree(expr_info);\n \n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static struct nft_rule *nft_rule_lookup_byid(const struct net *net,\n@@ -3695,7 +3843,11 @@ static int nf_tables_delrule(struct sk_buff *skb, const struct nfnl_info *info,\n \t\t}\n \t}\n \n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n /*\n@@ -4261,7 +4413,11 @@ static int nf_tables_getset(struct sk_buff *skb, const struct nfnl_info *info,\n \n err_fill_set_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static const struct nla_policy nft_concat_policy[NFTA_SET_FIELD_MAX + 1] = {\n@@ -4281,7 +4437,11 @@ static int nft_set_desc_concat_parse(const struct nlattr *attr,\n \terr = nla_parse_nested_deprecated(tb, NFTA_SET_FIELD_MAX, attr,\n \t\t\t\t\t  nft_concat_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \tif (!tb[NFTA_SET_FIELD_LEN])\n \t\treturn -EINVAL;\n@@ -4308,7 +4468,11 @@ static int nft_set_desc_concat(struct nft_set_desc *desc,\n \n \t\terr = nft_set_desc_concat_parse(attr, desc);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t}\n \n \tfor (i = 0; i < desc->field_count; i++)\n@@ -4329,14 +4493,22 @@ static int nf_tables_set_desc_parse(struct nft_set_desc *desc,\n \terr = nla_parse_nested_deprecated(da, NFTA_SET_DESC_MAX, nla,\n \t\t\t\t\t  nft_set_desc_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \tif (da[NFTA_SET_DESC_SIZE] != NULL)\n \t\tdesc->size = ntohl(nla_get_be32(da[NFTA_SET_DESC_SIZE]));\n \tif (da[NFTA_SET_DESC_CONCAT])\n \t\terr = nft_set_desc_concat(desc, da[NFTA_SET_DESC_CONCAT]);\n \n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static int nf_tables_newset(struct sk_buff *skb, const struct nfnl_info *info,\n@@ -4438,7 +4610,11 @@ static int nf_tables_newset(struct sk_buff *skb, const struct nfnl_info *info,\n \n \t\terr = nf_msecs_to_jiffies64(nla[NFTA_SET_TIMEOUT], &timeout);\n \t\tif (err)\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t}\n \tgc_int = 0;\n \tif (nla[NFTA_SET_GC_INTERVAL] != NULL) {\n@@ -4454,7 +4630,11 @@ static int nf_tables_newset(struct sk_buff *skb, const struct nfnl_info *info,\n \tif (nla[NFTA_SET_DESC] != NULL) {\n \t\terr = nf_tables_set_desc_parse(&desc, nla[NFTA_SET_DESC]);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \t\tif (desc.field_count > 1 && !(flags & NFT_SET_CONCAT))\n \t\t\treturn -EINVAL;\n@@ -4611,7 +4791,11 @@ static int nf_tables_newset(struct sk_buff *skb, const struct nfnl_info *info,\n \tkfree(set->name);\n err_set_name:\n \tkvfree(set);\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n struct nft_set_elem_catchall {\n@@ -5298,11 +5482,19 @@ static int nft_get_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \terr = nla_parse_nested_deprecated(nla, NFTA_SET_ELEM_MAX, attr,\n \t\t\t\t\t  nft_set_elem_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \terr = nft_setelem_parse_flags(set, nla[NFTA_SET_ELEM_FLAGS], &flags);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \tif (!nla[NFTA_SET_ELEM_KEY] && !(flags & NFT_SET_ELEM_CATCHALL))\n \t\treturn -EINVAL;\n@@ -5311,24 +5503,40 @@ static int nft_get_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \t\terr = nft_setelem_parse_key(ctx, set, &elem.key.val,\n \t\t\t\t\t    nla[NFTA_SET_ELEM_KEY]);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t}\n \n \tif (nla[NFTA_SET_ELEM_KEY_END]) {\n \t\terr = nft_setelem_parse_key(ctx, set, &elem.key_end.val,\n \t\t\t\t\t    nla[NFTA_SET_ELEM_KEY_END]);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t}\n \n \terr = nft_setelem_get(ctx, set, &elem, flags);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \terr = -ENOMEM;\n \tskb = nlmsg_new(NLMSG_GOODSIZE, GFP_ATOMIC);\n \tif (skb == NULL)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \terr = nf_tables_fill_setelem_info(skb, ctx, ctx->seq, ctx->portid,\n \t\t\t\t\t  NFT_MSG_NEWSETELEM, 0, set, &elem);\n@@ -5339,7 +5547,11 @@ static int nft_get_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \n err_fill_setelem:\n \tkfree_skb(skb);\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n /* called with rcu_read_lock held */\n@@ -5397,7 +5609,11 @@ static int nf_tables_getsetelem(struct sk_buff *skb,\n \t\t}\n \t}\n \n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static void nf_tables_setelem_notify(const struct nft_ctx *ctx,\n@@ -5898,13 +6114,21 @@ static int nft_add_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \terr = nla_parse_nested_deprecated(nla, NFTA_SET_ELEM_MAX, attr,\n \t\t\t\t\t  nft_set_elem_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \tnft_set_ext_prepare(&tmpl);\n \n \terr = nft_setelem_parse_flags(set, nla[NFTA_SET_ELEM_FLAGS], &flags);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \tif (!nla[NFTA_SET_ELEM_KEY] && !(flags & NFT_SET_ELEM_CATCHALL))\n \t\treturn -EINVAL;\n@@ -5912,7 +6136,11 @@ static int nft_add_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \tif (flags != 0) {\n \t\terr = nft_set_ext_add(&tmpl, NFT_SET_EXT_FLAGS);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t}\n \n \tif (set->flags & NFT_SET_MAP) {\n@@ -5954,7 +6182,11 @@ static int nft_add_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \t\terr = nf_msecs_to_jiffies64(nla[NFTA_SET_ELEM_TIMEOUT],\n \t\t\t\t\t    &timeout);\n \t\tif (err)\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t} else if (set->flags & NFT_SET_TIMEOUT) {\n \t\ttimeout = set->timeout;\n \t}\n@@ -5966,7 +6198,11 @@ static int nft_add_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \t\terr = nf_msecs_to_jiffies64(nla[NFTA_SET_ELEM_EXPIRATION],\n \t\t\t\t\t    &expiration);\n \t\tif (err)\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t}\n \n \tif (nla[NFTA_SET_ELEM_EXPR]) {\n@@ -6231,7 +6467,11 @@ static int nft_add_set_elem(struct nft_ctx *ctx, struct nft_set *set,\n \tfor (i = 0; i < num_exprs && expr_array[i]; i++)\n \t\tnft_expr_destroy(ctx, expr_array[i]);\n err_set_elem_expr_clone:\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static int nf_tables_newsetelem(struct sk_buff *skb,\n@@ -6273,7 +6513,11 @@ static int nf_tables_newsetelem(struct sk_buff *skb,\n \t\terr = nft_add_set_elem(&ctx, set, attr, info->nlh->nlmsg_flags);\n \t\tif (err < 0) {\n \t\t\tNL_SET_BAD_ATTR(extack, attr);\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t\t}\n \t}\n \n@@ -6357,11 +6601,19 @@ static int nft_del_setelem(struct nft_ctx *ctx, struct nft_set *set,\n \terr = nla_parse_nested_deprecated(nla, NFTA_SET_ELEM_MAX, attr,\n \t\t\t\t\t  nft_set_elem_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \terr = nft_setelem_parse_flags(set, nla[NFTA_SET_ELEM_FLAGS], &flags);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \tif (!nla[NFTA_SET_ELEM_KEY] && !(flags & NFT_SET_ELEM_CATCHALL))\n \t\treturn -EINVAL;\n@@ -6374,14 +6626,22 @@ static int nft_del_setelem(struct nft_ctx *ctx, struct nft_set *set,\n \tif (flags != 0) {\n \t\terr = nft_set_ext_add(&tmpl, NFT_SET_EXT_FLAGS);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t}\n \n \tif (nla[NFTA_SET_ELEM_KEY]) {\n \t\terr = nft_setelem_parse_key(ctx, set, &elem.key.val,\n \t\t\t\t\t    nla[NFTA_SET_ELEM_KEY]);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \t\terr = nft_set_ext_add_length(&tmpl, NFT_SET_EXT_KEY, set->klen);\n \t\tif (err < 0)\n@@ -6434,7 +6694,11 @@ static int nft_del_setelem(struct nft_ctx *ctx, struct nft_set *set,\n \tnft_data_release(&elem.key_end.val, NFT_DATA_VALUE);\n fail_elem:\n \tnft_data_release(&elem.key.val, NFT_DATA_VALUE);\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static int nft_setelem_flush(const struct nft_ctx *ctx,\n@@ -6464,7 +6728,11 @@ static int nft_setelem_flush(const struct nft_ctx *ctx,\n \treturn 0;\n err1:\n \tkfree(trans);\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static int __nft_set_catchall_flush(const struct nft_ctx *ctx,\n@@ -6563,7 +6831,11 @@ static int nf_tables_delsetelem(struct sk_buff *skb,\n \t\t\tbreak;\n \t\t}\n \t}\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n void nft_set_gc_batch_release(struct rcu_head *rcu)\n@@ -6821,7 +7093,11 @@ static int nf_tables_updobj(const struct nft_ctx *ctx,\n \tkfree(trans);\n err_trans:\n \tmodule_put(type->owner);\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static int nf_tables_newobj(struct sk_buff *skb, const struct nfnl_info *info,\n@@ -6856,7 +7132,11 @@ static int nf_tables_newobj(struct sk_buff *skb, const struct nfnl_info *info,\n \t\terr = PTR_ERR(obj);\n \t\tif (err != -ENOENT) {\n \t\t\tNL_SET_BAD_ATTR(extack, nla[NFTA_OBJ_NAME]);\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t\t}\n \t} else {\n \t\tif (info->nlh->nlmsg_flags & NLM_F_EXCL) {\n@@ -6915,7 +7195,11 @@ static int nf_tables_newobj(struct sk_buff *skb, const struct nfnl_info *info,\n err_obj_ht:\n \t/* queued in transaction log */\n \tINIT_LIST_HEAD(&obj->list);\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n err_trans:\n \tkfree(obj->udata);\n err_userdata:\n@@ -6926,7 +7210,11 @@ 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-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static int nf_tables_fill_obj_info(struct sk_buff *skb, struct net *net,\n@@ -7154,7 +7442,11 @@ static int nf_tables_getobj(struct sk_buff *skb, const struct nfnl_info *info,\n \n err_fill_obj_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static void nft_obj_destroy(const struct nft_ctx *ctx, struct nft_object *obj)\n@@ -7364,7 +7656,11 @@ static int nft_flowtable_parse_hook(const struct nft_ctx *ctx,\n \terr = nla_parse_nested_deprecated(tb, NFTA_FLOWTABLE_HOOK_MAX, attr,\n \t\t\t\t\t  nft_flowtable_hook_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \tif (add) {\n \t\tif (!tb[NFTA_FLOWTABLE_HOOK_NUM] ||\n@@ -7401,7 +7697,11 @@ static int nft_flowtable_parse_hook(const struct nft_ctx *ctx,\n \t\t\t\t\t\t   tb[NFTA_FLOWTABLE_HOOK_DEVS],\n \t\t\t\t\t\t   &flowtable_hook->list);\n \t\tif (err < 0)\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t}\n \n \tlist_for_each_entry(hook, &flowtable_hook->list, list) {\n@@ -7412,7 +7712,11 @@ static int nft_flowtable_parse_hook(const struct nft_ctx *ctx,\n \t\thook->ops.hook\t\t= flowtable->data.type->hook;\n \t}\n \n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static const struct nf_flowtable_type *__nft_flowtable_type_get(u8 family)\n@@ -7528,7 +7832,11 @@ static int nft_register_flowtable_net_hooks(struct net *net,\n \t\tkfree_rcu(hook, rcu);\n \t}\n \n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static void nft_flowtable_hooks_destroy(struct list_head *hook_list)\n@@ -7555,7 +7863,11 @@ static int nft_flowtable_update(struct nft_ctx *ctx, const struct nlmsghdr *nlh,\n \terr = nft_flowtable_parse_hook(ctx, nla[NFTA_FLOWTABLE_HOOK],\n \t\t\t\t       &flowtable_hook, flowtable, false);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \tlist_for_each_entry_safe(hook, next, &flowtable_hook.list, list) {\n \t\tif (nft_hook_list_find(&flowtable->hook_list, hook)) {\n@@ -7610,7 +7922,11 @@ static int nft_flowtable_update(struct nft_ctx *ctx, const struct nlmsghdr *nlh,\n \t\tkfree_rcu(hook, rcu);\n \t}\n \n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n }\n \n@@ -7648,7 +7964,11 @@ static int nf_tables_newflowtable(struct sk_buff *skb,\n \t\terr = PTR_ERR(flowtable);\n \t\tif (err != -ENOENT) {\n \t\t\tNL_SET_BAD_ATTR(extack, nla[NFTA_FLOWTABLE_NAME]);\n-\t\t\treturn err;\n+\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t\t}\n \t} else {\n \t\tif (info->nlh->nlmsg_flags & NLM_F_EXCL) {\n@@ -7737,7 +8057,11 @@ static int nf_tables_newflowtable(struct sk_buff *skb,\n \tkfree(flowtable->name);\n err1:\n \tkfree(flowtable);\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static void nft_flowtable_hook_release(struct nft_flowtable_hook *flowtable_hook)\n@@ -7763,7 +8087,11 @@ static int nft_delflowtable_hook(struct nft_ctx *ctx,\n \terr = nft_flowtable_parse_hook(ctx, nla[NFTA_FLOWTABLE_HOOK],\n \t\t\t\t       &flowtable_hook, flowtable, false);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \tlist_for_each_entry(this, &flowtable_hook.list, list) {\n \t\thook = nft_hook_list_find(&flowtable->hook_list, this);\n@@ -7795,7 +8123,11 @@ static int nft_delflowtable_hook(struct nft_ctx *ctx,\n \tlist_splice(&flowtable_del_list, &flowtable->hook_list);\n \tnft_flowtable_hook_release(&flowtable_hook);\n \n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static int nf_tables_delflowtable(struct sk_buff *skb,\n@@ -8044,7 +8376,11 @@ static int nf_tables_getflowtable(struct sk_buff *skb,\n \n err_fill_flowtable_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static void nf_tables_flowtable_notify(struct nft_ctx *ctx,\n@@ -8219,7 +8555,11 @@ static int nf_tables_getgen(struct sk_buff *skb, const struct nfnl_info *info,\n \n err_fill_gen_info:\n \tkfree_skb(skb2);\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static const struct nfnl_callback nf_tables_cb[NFT_MSG_MAX] = {\n@@ -8865,7 +9205,11 @@ static int nf_tables_commit(struct net *net, struct sk_buff *skb)\n \n \terr = nft_flow_rule_offload_commit(net);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \t/* 1.  Allocate space for next generation rules_gen_X[] */\n \tlist_for_each_entry_safe(trans, next, &nft_net->commit_list, list) {\n@@ -9461,7 +9805,11 @@ static int nf_tables_check_loops(const struct nft_ctx *ctx,\n \t\t\t\terr = nf_tables_check_loops(ctx,\n \t\t\t\t\t\t\tdata->verdict.chain);\n \t\t\t\tif (err < 0)\n-\t\t\t\t\treturn err;\n+\t\t\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t\t\t\tbreak;\n \t\t\tdefault:\n \t\t\t\tbreak;\n@@ -9584,11 +9932,19 @@ int nft_parse_register_load(const struct nlattr *attr, u8 *sreg, u32 len)\n \n \terr = nft_parse_register(attr, &reg);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \terr = nft_validate_register_load(reg, len);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \t*sreg = reg;\n \treturn 0;\n@@ -9613,7 +9969,11 @@ static int nft_validate_register_store(const struct nft_ctx *ctx,\n \t\t     data->verdict.code == NFT_JUMP)) {\n \t\t\terr = nf_tables_check_loops(ctx, data->verdict.chain);\n \t\t\tif (err < 0)\n-\t\t\t\treturn err;\n+\t\t\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \t\t}\n \n \t\treturn 0;\n@@ -9642,11 +10002,19 @@ int nft_parse_register_store(const struct nft_ctx *ctx,\n \n \terr = nft_parse_register(attr, &reg);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \terr = nft_validate_register_store(ctx, reg, data, type, len);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \t*dreg = reg;\n \treturn 0;\n@@ -9671,7 +10039,11 @@ static int nft_verdict_init(const struct nft_ctx *ctx, struct nft_data *data,\n \terr = nla_parse_nested_deprecated(tb, NFTA_VERDICT_MAX, nla,\n \t\t\t\t\t  nft_verdict_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \tif (!tb[NFTA_VERDICT_CODE])\n \t\treturn -EINVAL;\n@@ -9835,7 +10207,11 @@ int nft_data_init(const struct nft_ctx *ctx, struct nft_data *data,\n \terr = nla_parse_nested_deprecated(tb, NFTA_DATA_MAX, nla,\n \t\t\t\t\t  nft_data_policy, NULL);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \tif (tb[NFTA_DATA_VALUE]) {\n \t\tif (desc->type != NFT_DATA_VALUE)\n@@ -9851,7 +10227,11 @@ int nft_data_init(const struct nft_ctx *ctx, struct nft_data *data,\n \t\terr = -EINVAL;\n \t}\n \n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n EXPORT_SYMBOL_GPL(nft_data_init);\n \n@@ -9900,7 +10280,11 @@ int nft_data_dump(struct sk_buff *skb, int attr, const struct nft_data *data,\n \t}\n \n \tnla_nest_end(skb, nest);\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n EXPORT_SYMBOL_GPL(nft_data_dump);\n \n@@ -10108,7 +10492,11 @@ static int __init nf_tables_module_init(void)\n \n \terr = register_pernet_subsys(&nf_tables_net_ops);\n \tif (err < 0)\n-\t\treturn err;\n+\t\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n \terr = nft_chain_filter_init();\n \tif (err < 0)\n@@ -10141,7 +10529,11 @@ static int __init nf_tables_module_init(void)\n \n \tnft_chain_route_init();\n \n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n \n err_nfnl_subsys:\n \tnetlink_unregister_notifier(&nft_nl_notifier);\n@@ -10157,7 +10549,11 @@ static int __init nf_tables_module_init(void)\n \tnft_chain_filter_fini();\n err_chain_filter:\n \tunregister_pernet_subsys(&nf_tables_net_ops);\n-\treturn err;\n+\tlist_for_each_entry_safe(hook, next, hook_list, list) {\n+list_del(&hook->list);\n+kfree(hook);\n+}\n+return err;\n }\n \n static void __exit nf_tables_module_exit(void)\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "4892aaa2ef26ab83c6b974f1db422f526f9aaec0": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/drivers/video/fbdev/core/sysfillrect.c b/drivers/video/fbdev/core/sysfillrect.c\nindex 33ee3d34f9d2..9b3c25643c5d 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_idx + n <= buffer_size) {\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_idx + n <= buffer_size) {\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..a2e049a73b73 100644\n--- a/drivers/video/fbdev/core/sysfillrect.c\n+++ b/drivers/video/fbdev/core/sysfillrect.c\n@@ -50,7 +50,9 @@ 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\t/* Ensure n does not exceed bounds */\n+        if ((dst_idx + n) / bits > MAX_MEM_SIZE) return;\n+        while (n >= 8) {\n \t\t\t*dst++ = pat;\n \t\t\t*dst++ = pat;\n \t\t\t*dst++ = pat;\n@@ -160,7 +162,9 @@ 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\t/* Ensure n does not exceed bounds */\n+        if ((dst_idx + n) / bits > MAX_MEM_SIZE) return;\n+        while (n >= 8) {\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..ec60a21f3042 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 - 8)) {\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 - 8)) {\n \t\t\t*dst++ ^= val;\n \t\t\t*dst++ ^= val;\n \t\t\t*dst++ ^= val;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "993d8b5e64393ed9e6a70f9ae4de0119c605a822": {
        "non_crash": [
            "diff --git a/drivers/vhost/vhost.c b/drivers/vhost/vhost.c\nindex 59edb5a1ffe2..df94e00ce92b 100644\n--- a/drivers/vhost/vhost.c\n+++ b/drivers/vhost/vhost.c\n@@ -322,7 +322,7 @@ static void vhost_vq_reset(struct vhost_dev *dev,\n \tvq->last_used_idx = 0;\n \tvq->signalled_used = 0;\n \tvq->signalled_used_valid = false;\n-\tvq->used_flags = 0;\n+\tvq->used_flags = VRING_USED_F_NO_NOTIFY;\n \tvq->log_used = false;\n \tvq->log_addr = -1ull;\n \tvq->private_data = NULL;\n",
            "diff --git a/drivers/vhost/vhost.c b/drivers/vhost/vhost.c\nindex 59edb5a1ffe2..864ed6e124d7 100644\n--- a/drivers/vhost/vhost.c\n+++ b/drivers/vhost/vhost.c\n@@ -136,6 +136,7 @@ static void vhost_init_is_le(struct vhost_virtqueue *vq)\n static void vhost_reset_is_le(struct vhost_virtqueue *vq)\n {\n \tvhost_init_is_le(vq);\n+    vq->used_flags |= VRING_USED_F_NO_NOTIFY;\n }\n \n struct vhost_flush_struct {\n@@ -2009,6 +2010,7 @@ int vhost_vq_init_access(struct vhost_virtqueue *vq)\n \t\treturn 0;\n \n \tvhost_init_is_le(vq);\n+    vq->used_flags |= VRING_USED_F_NO_NOTIFY;\n \n \tr = vhost_update_used_flags(vq);\n \tif (r)\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/vhost/vhost.c b/drivers/vhost/vhost.c\nindex 59edb5a1ffe2..157902d99619 100644\n--- a/drivers/vhost/vhost.c\n+++ b/drivers/vhost/vhost.c\n@@ -2332,7 +2332,9 @@ int vhost_get_vq_desc(struct vhost_virtqueue *vq,\n \n \t/* Assume notifications from guest are disabled at this point,\n \t * if they aren't we would need to update avail_event index. */\n-\tBUG_ON(!(vq->used_flags & VRING_USED_F_NO_NOTIFY));\n+\tif (!(vq->used_flags & VRING_USED_F_NO_NOTIFY)) {\n+        vq->used_flags |= VRING_USED_F_NO_NOTIFY;\n+    }\n \treturn head;\n }\n EXPORT_SYMBOL_GPL(vhost_get_vq_desc);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/vhost/vhost.c b/drivers/vhost/vhost.c\nindex 59edb5a1ffe2..a84dab11b96e 100644\n--- a/drivers/vhost/vhost.c\n+++ b/drivers/vhost/vhost.c\n@@ -2197,6 +2197,13 @@ static int get_indirect(struct vhost_virtqueue *vq,\n  * never a valid descriptor number) if none was found.  A negative code is\n  * returned on error. */\n int vhost_get_vq_desc(struct vhost_virtqueue *vq,\n+{\n+    /* Ensure notifications from guest are disabled */\n+    if (!(vq->used_flags & VRING_USED_F_NO_NOTIFY)) {\n+        vq_err(vq, \"Guest notifications are not disabled\");\n+        return -EINVAL;\n+    }\n+\n \t\t      struct iovec iov[], unsigned int iov_size,\n \t\t      unsigned int *out_num, unsigned int *in_num,\n \t\t      struct vhost_log *log, unsigned int *log_num)\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..86188b3a110e 100644\n--- a/net/netfilter/nfnetlink_cttimeout.c\n+++ b/net/netfilter/nfnetlink_cttimeout.c\n@@ -475,7 +475,7 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \t\ttimeouts = &nf_generic_pernet(net)->timeout;\n \t\tbreak;\n \tdefault:\n-\t\tWARN_ON_ONCE(1);\n+\t\treturn -EINVAL;\n \t\tbreak;\n \t}\n \n",
            "diff --git a/net/netfilter/nfnetlink_cttimeout.c b/net/netfilter/nfnetlink_cttimeout.c\nindex a518eb162344..0da11a50ca06 100644\n--- a/net/netfilter/nfnetlink_cttimeout.c\n+++ b/net/netfilter/nfnetlink_cttimeout.c\n@@ -475,7 +475,7 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \t\ttimeouts = &nf_generic_pernet(net)->timeout;\n \t\tbreak;\n \tdefault:\n-\t\tWARN_ON_ONCE(1);\n+\t\tWARN_ON_ONCE(l4proto->l4proto != l4num);\n \t\tbreak;\n \t}\n \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"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netfilter/nfnetlink_cttimeout.c b/net/netfilter/nfnetlink_cttimeout.c\nindex a518eb162344..ecdfa7bc348d 100644\n--- a/net/netfilter/nfnetlink_cttimeout.c\n+++ b/net/netfilter/nfnetlink_cttimeout.c\n@@ -448,7 +448,8 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \tif (l4proto->l4proto != l4num)\n \t\tgoto err;\n \n-\tswitch (l4proto->l4proto) {\n+\tif (l4proto->l4proto < 0 || l4proto->l4proto > 255) goto err;\n+switch (l4proto->l4proto) {\n \tcase IPPROTO_ICMP:\n \t\ttimeouts = &nf_icmp_pernet(net)->timeout;\n \t\tbreak;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/netfilter/nfnetlink_cttimeout.c b/net/netfilter/nfnetlink_cttimeout.c\nindex a518eb162344..daba3cbd7b2f 100644\n--- a/net/netfilter/nfnetlink_cttimeout.c\n+++ b/net/netfilter/nfnetlink_cttimeout.c\n@@ -125,7 +125,7 @@ static int cttimeout_new_timeout(struct net *net, struct sock *ctnl,\n \tl4proto = nf_ct_l4proto_find_get(l4num);\n \n \t/* This protocol is not supportted, skip. */\n-\tif (l4proto->l4proto != l4num) {\n+\tif (!nf_ct_l4proto_supported(l4num) || l4proto->l4proto != l4num) {\n \t\tret = -EOPNOTSUPP;\n \t\tgoto err_proto_put;\n \t}\n@@ -362,7 +362,7 @@ static int cttimeout_default_set(struct net *net, struct sock *ctnl,\n \tl4proto = nf_ct_l4proto_find_get(l4num);\n \n \t/* This protocol is not supported, skip. */\n-\tif (l4proto->l4proto != l4num) {\n+\tif (!nf_ct_l4proto_supported(l4num) || l4proto->l4proto != l4num) {\n \t\tret = -EOPNOTSUPP;\n \t\tgoto err;\n \t}\n@@ -445,7 +445,7 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \tl4proto = nf_ct_l4proto_find_get(l4num);\n \n \terr = -EOPNOTSUPP;\n-\tif (l4proto->l4proto != l4num)\n+\tif (!nf_ct_l4proto_supported(l4num) || l4proto->l4proto != l4num)\n \t\tgoto err;\n \n \tswitch (l4proto->l4proto) {\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..81bdb376af4a 100644\n--- a/fs/btrfs/extent-io-tree.c\n+++ b/fs/btrfs/extent-io-tree.c\n@@ -636,7 +636,9 @@ 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+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 +659,9 @@ 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+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 +1016,9 @@ 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+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 +1091,9 @@ 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+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 +1130,9 @@ 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+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 +1164,9 @@ 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+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",
            "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": [
            {
                "patch": "diff --git a/fs/btrfs/extent-io-tree.c b/fs/btrfs/extent-io-tree.c\nindex a630c771d25c..ac32ba30f487 100644\n--- a/fs/btrfs/extent-io-tree.c\n+++ b/fs/btrfs/extent-io-tree.c\n@@ -156,6 +156,13 @@ static struct extent_state *alloc_extent_state(gfp_t mask)\n }\n \n static struct extent_state *alloc_extent_state_atomic(struct extent_state *prealloc)\n+{\n+int retry = 3;\n+while (!prealloc && retry--) {\n+prealloc = alloc_extent_state(GFP_ATOMIC);\n+}\n+return prealloc;\n+}\n {\n \tif (!prealloc)\n \t\tprealloc = alloc_extent_state(GFP_ATOMIC);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "9d6af32008ffd651175d152c5bea92cf767ae38c": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "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"
        ],
        "error": [
            {
                "patch": "diff --git a/io_uring/io_uring.c b/io_uring/io_uring.c\nindex 2ac1cd8d23ea..4e0ba9047b0b 100644\n--- a/io_uring/io_uring.c\n+++ b/io_uring/io_uring.c\n@@ -2364,6 +2364,59 @@ static const struct io_uring_sqe *io_get_sqe(struct io_ring_ctx *ctx)\n }\n \n int io_submit_sqes(struct io_ring_ctx *ctx, unsigned int nr)\n+{\n+    unsigned int entries = io_sqring_entries(ctx);\n+    unsigned int left;\n+    int ret;\n+\n+    if (unlikely(!entries))\n+        return 0;\n+    /* make sure SQ entry isn't read before tail */\n+    ret = left = min3(nr, ctx->sq_entries, entries);\n+    io_get_task_refs(left);\n+    io_submit_state_start(&ctx->submit_state, left);\n+\n+    do {\n+        const struct io_uring_sqe *sqe;\n+        struct io_kiocb *req;\n+\n+        if (unlikely(!io_alloc_req_refill(ctx))) {\n+            io_free_req(req);\n+            break;\n+        }\n+        req = io_alloc_req(ctx);\n+        sqe = io_get_sqe(ctx);\n+        if (unlikely(!sqe)) {\n+            io_req_add_to_cache(req, ctx);\n+            break;\n+        }\n+\n+        /*\n+         * Continue submitting even for sqe failure if the\n+         * ring was setup with IORING_SETUP_SUBMIT_ALL\n+         */\n+        if (unlikely(io_submit_sqe(ctx, req, sqe)) &&\n+            !(ctx->flags & IORING_SETUP_SUBMIT_ALL)) {\n+            io_free_req(req);\n+            left--;\n+            break;\n+        }\n+    } while (--left);\n+\n+    if (unlikely(left)) {\n+        ret -= left;\n+        /* try again if it submitted nothing and can't allocate a req */\n+        if (!ret && io_req_cache_empty(ctx))\n+            ret = -EAGAIN;\n+        current->io_uring->cached_refs += left;\n+    }\n+\n+    io_submit_state_end(ctx);\n+     /* Commit SQ ring head once we've consumed and submitted all SQEs */\n+    io_commit_sqring(ctx);\n+    return ret;\n+}\n+\n \t__must_hold(&ctx->uring_lock)\n {\n \tunsigned int entries = io_sqring_entries(ctx);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/io_uring/io_uring.c b/io_uring/io_uring.c\nindex 2ac1cd8d23ea..04c40d0fd2c2 100644\n--- a/io_uring/io_uring.c\n+++ b/io_uring/io_uring.c\n@@ -1055,7 +1055,7 @@ __cold bool __io_alloc_req_refill(struct io_ring_ctx *ctx)\n \t\tstruct io_kiocb *req = reqs[i];\n \n \t\tio_preinit_req(req, ctx);\n-\t\tio_req_add_to_cache(req, ctx);\n+\t\tio_req_free(req);\n \t}\n \treturn true;\n }\n@@ -1435,7 +1435,7 @@ void io_free_batch_list(struct io_ring_ctx *ctx, struct io_wq_work_node *node)\n \t\t}\n \t\ttask_refs++;\n \t\tnode = req->comp_list.next;\n-\t\tio_req_add_to_cache(req, ctx);\n+\t\tio_req_free(req);\n \t} while (node);\n \n \tif (task)\n@@ -2386,7 +2386,7 @@ int io_submit_sqes(struct io_ring_ctx *ctx, unsigned int nr)\n \t\treq = io_alloc_req(ctx);\n \t\tsqe = io_get_sqe(ctx);\n \t\tif (unlikely(!sqe)) {\n-\t\t\tio_req_add_to_cache(req, ctx);\n+\t\t\tio_req_free(req);\n \t\t\tbreak;\n \t\t}\n \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..2f08574817b8 100644\n--- a/net/netfilter/nf_conntrack_proto_icmp.c\n+++ b/net/netfilter/nf_conntrack_proto_icmp.c\n@@ -289,6 +289,10 @@ 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+\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..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"
        ],
        "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..a4c986747a39 100644\n--- a/net/netfilter/nf_conntrack_proto_icmp.c\n+++ b/net/netfilter/nf_conntrack_proto_icmp.c\n@@ -286,6 +286,9 @@ 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+    if (!timeout) return -EINVAL;\n {\n \tconst unsigned int *timeout = data;\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "738a1a0b5b9b8ece2bbf714f2e244358be2523c3": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/pipe.c b/fs/pipe.c\nindex 2d88f73f585a..b8232049c185 100644\n--- a/fs/pipe.c\n+++ b/fs/pipe.c\n@@ -241,7 +241,8 @@ pipe_read(struct kiocb *iocb, struct iov_iter *to)\n \t\treturn 0;\n \n \tret = 0;\n-\t__pipe_lock(pipe);\n+\tpr_info(\"Acquiring pipe lock\\n\");\n+    __pipe_lock(pipe);\n \n \t/*\n \t * We only wake up writers if the pipe was full when we started\n@@ -348,6 +349,7 @@ pipe_read(struct kiocb *iocb, struct iov_iter *to)\n \t\t\tbreak;\n \t\t}\n \t\t__pipe_unlock(pipe);\n+    pr_info(\"Released pipe lock\\n\");\n \n \t\t/*\n \t\t * We only get here if we didn't actually read anything.\n@@ -379,13 +381,15 @@ pipe_read(struct kiocb *iocb, struct iov_iter *to)\n \t\tif (wait_event_interruptible_exclusive(pipe->rd_wait, pipe_readable(pipe)) < 0)\n \t\t\treturn -ERESTARTSYS;\n \n-\t\t__pipe_lock(pipe);\n+\t\tpr_info(\"Acquiring pipe lock\\n\");\n+    __pipe_lock(pipe);\n \t\twas_full = pipe_full(pipe->head, pipe->tail, pipe->max_usage);\n \t\twake_next_reader = true;\n \t}\n \tif (pipe_empty(pipe->head, pipe->tail))\n \t\twake_next_reader = false;\n \t__pipe_unlock(pipe);\n+    pr_info(\"Released pipe lock\\n\");\n \n \tif (was_full)\n \t\twake_up_interruptible_sync_poll(&pipe->wr_wait, EPOLLOUT | EPOLLWRNORM);\n@@ -429,7 +433,8 @@ pipe_write(struct kiocb *iocb, struct iov_iter *from)\n \tif (unlikely(total_len == 0))\n \t\treturn 0;\n \n-\t__pipe_lock(pipe);\n+\tpr_info(\"Acquiring pipe lock\\n\");\n+    __pipe_lock(pipe);\n \n \tif (!pipe->readers) {\n \t\tsend_sig(SIGPIPE, current, 0);\n@@ -567,11 +572,13 @@ pipe_write(struct kiocb *iocb, struct iov_iter *from)\n \t\t * become empty while we dropped the lock.\n \t\t */\n \t\t__pipe_unlock(pipe);\n+    pr_info(\"Released pipe lock\\n\");\n \t\tif (was_empty)\n \t\t\twake_up_interruptible_sync_poll(&pipe->rd_wait, EPOLLIN | EPOLLRDNORM);\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+\t\tpr_info(\"Acquiring pipe lock\\n\");\n+    __pipe_lock(pipe);\n \t\twas_empty = pipe_empty(pipe->head, pipe->tail);\n \t\twake_next_writer = true;\n \t}\n@@ -579,6 +586,7 @@ pipe_write(struct kiocb *iocb, struct iov_iter *from)\n \tif (pipe_full(pipe->head, pipe->tail, pipe->max_usage))\n \t\twake_next_writer = false;\n \t__pipe_unlock(pipe);\n+    pr_info(\"Released pipe lock\\n\");\n \n \t/*\n \t * If we do do a wakeup event, we do a 'sync' wakeup, because we\n@@ -613,7 +621,8 @@ static long pipe_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)\n \n \tswitch (cmd) {\n \tcase FIONREAD:\n-\t\t__pipe_lock(pipe);\n+\t\tpr_info(\"Acquiring pipe lock\\n\");\n+    __pipe_lock(pipe);\n \t\tcount = 0;\n \t\thead = pipe->head;\n \t\ttail = pipe->tail;\n@@ -624,15 +633,18 @@ static long pipe_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)\n \t\t\ttail++;\n \t\t}\n \t\t__pipe_unlock(pipe);\n+    pr_info(\"Released pipe lock\\n\");\n \n \t\treturn put_user(count, (int __user *)arg);\n \n #ifdef CONFIG_WATCH_QUEUE\n \tcase IOC_WATCH_QUEUE_SET_SIZE: {\n \t\tint ret;\n-\t\t__pipe_lock(pipe);\n+\t\tpr_info(\"Acquiring pipe lock\\n\");\n+    __pipe_lock(pipe);\n \t\tret = watch_queue_set_size(pipe, arg);\n \t\t__pipe_unlock(pipe);\n+    pr_info(\"Released pipe lock\\n\");\n \t\treturn ret;\n \t}\n \n@@ -718,7 +730,8 @@ pipe_release(struct inode *inode, struct file *file)\n {\n \tstruct pipe_inode_info *pipe = file->private_data;\n \n-\t__pipe_lock(pipe);\n+\tpr_info(\"Acquiring pipe lock\\n\");\n+    __pipe_lock(pipe);\n \tif (file->f_mode & FMODE_READ)\n \t\tpipe->readers--;\n \tif (file->f_mode & FMODE_WRITE)\n@@ -732,6 +745,7 @@ pipe_release(struct inode *inode, struct file *file)\n \t\tkill_fasync(&pipe->fasync_writers, SIGIO, POLL_OUT);\n \t}\n \t__pipe_unlock(pipe);\n+    pr_info(\"Released pipe lock\\n\");\n \n \tput_pipe_info(inode, pipe);\n \treturn 0;\n@@ -743,7 +757,8 @@ pipe_fasync(int fd, struct file *filp, int on)\n \tstruct pipe_inode_info *pipe = filp->private_data;\n \tint retval = 0;\n \n-\t__pipe_lock(pipe);\n+\tpr_info(\"Acquiring pipe lock\\n\");\n+    __pipe_lock(pipe);\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@@ -753,6 +768,7 @@ pipe_fasync(int fd, struct file *filp, int on)\n \t\t\tfasync_helper(-1, filp, 0, &pipe->fasync_readers);\n \t}\n \t__pipe_unlock(pipe);\n+    pr_info(\"Released pipe lock\\n\");\n \treturn retval;\n }\n \n@@ -1128,7 +1144,8 @@ static int fifo_open(struct inode *inode, struct file *filp)\n \tfilp->private_data = pipe;\n \t/* OK, we have a pipe and it's pinned down */\n \n-\t__pipe_lock(pipe);\n+\tpr_info(\"Acquiring pipe lock\\n\");\n+    __pipe_lock(pipe);\n \n \t/* We can only do regular read/write on fifos */\n \tstream_open(inode, filp);\n@@ -1199,6 +1216,7 @@ static int fifo_open(struct inode *inode, struct file *filp)\n \n \t/* Ok! */\n \t__pipe_unlock(pipe);\n+    pr_info(\"Released pipe lock\\n\");\n \treturn 0;\n \n err_rd:\n@@ -1215,6 +1233,7 @@ static int fifo_open(struct inode *inode, struct file *filp)\n \n err:\n \t__pipe_unlock(pipe);\n+    pr_info(\"Released pipe lock\\n\");\n \n \tput_pipe_info(inode, pipe);\n \treturn ret;\n@@ -1396,7 +1415,8 @@ long pipe_fcntl(struct file *file, unsigned int cmd, unsigned long arg)\n \tif (!pipe)\n \t\treturn -EBADF;\n \n-\t__pipe_lock(pipe);\n+\tpr_info(\"Acquiring pipe lock\\n\");\n+    __pipe_lock(pipe);\n \n \tswitch (cmd) {\n \tcase F_SETPIPE_SZ:\n@@ -1411,6 +1431,7 @@ long pipe_fcntl(struct file *file, unsigned int cmd, unsigned long arg)\n \t}\n \n \t__pipe_unlock(pipe);\n+    pr_info(\"Released pipe lock\\n\");\n \treturn ret;\n }\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/pipe.c b/fs/pipe.c\nindex 2d88f73f585a..cdc60445939f 100644\n--- a/fs/pipe.c\n+++ b/fs/pipe.c\n@@ -715,6 +715,27 @@ static void put_pipe_info(struct inode *inode, struct pipe_inode_info *pipe)\n \n static int\n pipe_release(struct inode *inode, struct file *file)\n+{\n+    printk(KERN_INFO \"Entering pipe_release\\n\");\n+    struct pipe_inode_info *pipe = file->private_data;\n+    __pipe_lock(pipe);\n+    printk(KERN_INFO \"Pipe locked\\n\");\n+    if (file->f_mode & FMODE_READ)\n+        pipe->readers--;\n+    if (file->f_mode & FMODE_WRITE)\n+        pipe->writers--;\n+    printk(KERN_INFO \"Readers: %d, Writers: %d\\n\", pipe->readers, pipe->writers);\n+    if (!pipe->readers != !pipe->writers) {\n+        wake_up_interruptible_all(&pipe->rd_wait);\n+        wake_up_interruptible_all(&pipe->wr_wait);\n+        kill_fasync(&pipe->fasync_readers, SIGIO, POLL_IN);\n+        kill_fasync(&pipe->fasync_writers, SIGIO, POLL_OUT);\n+    }\n+    __pipe_unlock(pipe);\n+    printk(KERN_INFO \"Pipe unlocked\\n\");\n+    put_pipe_info(inode, pipe);\n+    return 0;\n+}\n {\n \tstruct pipe_inode_info *pipe = file->private_data;\n \n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/pipe.c b/fs/pipe.c\nindex 2d88f73f585a..08d08e878a98 100644\n--- a/fs/pipe.c\n+++ b/fs/pipe.c\n@@ -242,6 +242,11 @@ pipe_read(struct kiocb *iocb, struct iov_iter *to)\n \n \tret = 0;\n \t__pipe_lock(pipe);\n+    if (pipe->readers == 0 && pipe->writers == 0) {\n+        __pipe_unlock(pipe);\n+        put_pipe_info(inode, pipe);\n+        return 0;\n+    }\n \n \t/*\n \t * We only wake up writers if the pipe was full when we started\n@@ -380,6 +385,11 @@ pipe_read(struct kiocb *iocb, struct iov_iter *to)\n \t\t\treturn -ERESTARTSYS;\n \n \t\t__pipe_lock(pipe);\n+    if (pipe->readers == 0 && pipe->writers == 0) {\n+        __pipe_unlock(pipe);\n+        put_pipe_info(inode, pipe);\n+        return 0;\n+    }\n \t\twas_full = pipe_full(pipe->head, pipe->tail, pipe->max_usage);\n \t\twake_next_reader = true;\n \t}\n@@ -430,6 +440,11 @@ pipe_write(struct kiocb *iocb, struct iov_iter *from)\n \t\treturn 0;\n \n \t__pipe_lock(pipe);\n+    if (pipe->readers == 0 && pipe->writers == 0) {\n+        __pipe_unlock(pipe);\n+        put_pipe_info(inode, pipe);\n+        return 0;\n+    }\n \n \tif (!pipe->readers) {\n \t\tsend_sig(SIGPIPE, current, 0);\n@@ -572,6 +587,11 @@ 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+    if (pipe->readers == 0 && pipe->writers == 0) {\n+        __pipe_unlock(pipe);\n+        put_pipe_info(inode, pipe);\n+        return 0;\n+    }\n \t\twas_empty = pipe_empty(pipe->head, pipe->tail);\n \t\twake_next_writer = true;\n \t}\n@@ -614,6 +634,11 @@ 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+    if (pipe->readers == 0 && pipe->writers == 0) {\n+        __pipe_unlock(pipe);\n+        put_pipe_info(inode, pipe);\n+        return 0;\n+    }\n \t\tcount = 0;\n \t\thead = pipe->head;\n \t\ttail = pipe->tail;\n@@ -631,6 +656,11 @@ 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+    if (pipe->readers == 0 && pipe->writers == 0) {\n+        __pipe_unlock(pipe);\n+        put_pipe_info(inode, pipe);\n+        return 0;\n+    }\n \t\tret = watch_queue_set_size(pipe, arg);\n \t\t__pipe_unlock(pipe);\n \t\treturn ret;\n@@ -719,6 +749,11 @@ pipe_release(struct inode *inode, struct file *file)\n \tstruct pipe_inode_info *pipe = file->private_data;\n \n \t__pipe_lock(pipe);\n+    if (pipe->readers == 0 && pipe->writers == 0) {\n+        __pipe_unlock(pipe);\n+        put_pipe_info(inode, pipe);\n+        return 0;\n+    }\n \tif (file->f_mode & FMODE_READ)\n \t\tpipe->readers--;\n \tif (file->f_mode & FMODE_WRITE)\n@@ -744,6 +779,11 @@ pipe_fasync(int fd, struct file *filp, int on)\n \tint retval = 0;\n \n \t__pipe_lock(pipe);\n+    if (pipe->readers == 0 && pipe->writers == 0) {\n+        __pipe_unlock(pipe);\n+        put_pipe_info(inode, pipe);\n+        return 0;\n+    }\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@@ -1129,6 +1169,11 @@ 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+    if (pipe->readers == 0 && pipe->writers == 0) {\n+        __pipe_unlock(pipe);\n+        put_pipe_info(inode, pipe);\n+        return 0;\n+    }\n \n \t/* We can only do regular read/write on fifos */\n \tstream_open(inode, filp);\n@@ -1397,6 +1442,11 @@ long pipe_fcntl(struct file *file, unsigned int cmd, unsigned long arg)\n \t\treturn -EBADF;\n \n \t__pipe_lock(pipe);\n+    if (pipe->readers == 0 && pipe->writers == 0) {\n+        __pipe_unlock(pipe);\n+        put_pipe_info(inode, pipe);\n+        return 0;\n+    }\n \n \tswitch (cmd) {\n \tcase F_SETPIPE_SZ:\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "9b857c714d3e890900acbe48172866a93ab8589a": {
        "non_crash": [
            "diff --git a/sound/core/oss/mulaw.c b/sound/core/oss/mulaw.c\nindex 3788906421a7..c9a2aac76ed5 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_err(\"Invalid format: expected linear format\\n\");\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..2e24d43b64d4 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",
            "diff --git a/sound/core/oss/mulaw.c b/sound/core/oss/mulaw.c\nindex 3788906421a7..02ae96f6ea19 100644\n--- a/sound/core/oss/mulaw.c\n+++ b/sound/core/oss/mulaw.c\n@@ -329,7 +329,12 @@ 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+        // Handle non-linear format case\n+        // Convert or adjust format as necessary\n+        // Log or report the issue if needed\n+        return -EINVAL;\n+    }\n \t\treturn -ENXIO;\n \n \terr = snd_pcm_plugin_build(plug, \"Mu-Law<->linear conversion\",\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/sound/core/oss/pcm_plugin.c b/sound/core/oss/pcm_plugin.c\nindex d5ca161d588c..05d760b88ec5 100644\n--- a/sound/core/oss/pcm_plugin.c\n+++ b/sound/core/oss/pcm_plugin.c\n@@ -419,7 +419,7 @@ int snd_pcm_plug_format_plugins(struct snd_pcm_substream *plug,\n \t/* Format change (linearization) */\n \tif (! rate_match(srcformat.rate, dstformat.rate) &&\n \t    ! snd_pcm_format_linear(srcformat.format)) {\n-\t\tif (srcformat.format != SNDRV_PCM_FORMAT_MU_LAW)\n+\t\tif (srcformat.format != SNDRV_PCM_FORMAT_MU_LAW && !snd_pcm_format_linear(srcformat.format))\n \t\t\treturn -EINVAL;\n \t\ttmpformat.format = SNDRV_PCM_FORMAT_S16;\n \t\terr = snd_pcm_plugin_build_mulaw(plug,\n",
            "diff --git a/sound/core/oss/pcm_plugin.c b/sound/core/oss/pcm_plugin.c\nindex d5ca161d588c..fa13f669ebd6 100644\n--- a/sound/core/oss/pcm_plugin.c\n+++ b/sound/core/oss/pcm_plugin.c\n@@ -419,7 +419,7 @@ int snd_pcm_plug_format_plugins(struct snd_pcm_substream *plug,\n \t/* Format change (linearization) */\n \tif (! rate_match(srcformat.rate, dstformat.rate) &&\n \t    ! snd_pcm_format_linear(srcformat.format)) {\n-\t\tif (srcformat.format != SNDRV_PCM_FORMAT_MU_LAW)\n+\t\tif (!snd_pcm_format_linear(srcformat.format) && srcformat.format != SNDRV_PCM_FORMAT_MU_LAW)\n \t\t\treturn -EINVAL;\n \t\ttmpformat.format = SNDRV_PCM_FORMAT_S16;\n \t\terr = snd_pcm_plugin_build_mulaw(plug,\n"
        ],
        "error": []
    },
    "d21cb12ee03822236d82ba4e83a1f8968e7832fb": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/filemap.c b/mm/filemap.c\nindex a34abfe8c654..9ce4cbcc90c6 100644\n--- a/mm/filemap.c\n+++ b/mm/filemap.c\n@@ -1279,7 +1279,7 @@ 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) folio_put(folio);\n \n \t/*\n \t * Note that until the \"finish_wait()\", or until\n@@ -1548,7 +1548,7 @@ 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) folio_put(folio);\n }\n EXPORT_SYMBOL(folio_end_private_2);\n \n@@ -1621,7 +1621,7 @@ 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) folio_put(folio);\n }\n EXPORT_SYMBOL(folio_end_writeback);\n \n@@ -1869,7 +1869,7 @@ 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) folio_put(folio);\n \t\tgoto repeat;\n \t}\n out:\n@@ -1924,7 +1924,7 @@ 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) folio_put(folio);\n \t\t\t\treturn ERR_PTR(-EAGAIN);\n \t\t\t}\n \t\t} else {\n@@ -1934,7 +1934,7 @@ 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) 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 +1975,7 @@ 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) folio_put(folio);\n \t\t\tfolio = NULL;\n \t\t\tif (err == -EEXIST)\n \t\t\t\tgoto repeat;\n@@ -2020,7 +2020,7 @@ 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) folio_put(folio);\n \t\tgoto reset;\n \t}\n \n@@ -2124,7 +2124,7 @@ 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) folio_put(folio);\n \t}\n \trcu_read_unlock();\n \n@@ -2260,7 +2260,7 @@ 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) folio_put(folio);\n \n retry:\n \t\txas_reset(&xas);\n@@ -2394,7 +2394,7 @@ 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) folio_put(folio);\n retry:\n \t\txas_reset(&xas);\n \t}\n@@ -2510,7 +2510,7 @@ 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) folio_put(folio);\n \treturn error;\n }\n \n@@ -2555,7 +2555,7 @@ 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) folio_put(folio);\n \treturn error;\n }\n \n@@ -2625,7 +2625,7 @@ 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) folio_put(folio);\n \tif (likely(--fbatch->nr))\n \t\treturn 0;\n \tif (err == AOP_TRUNCATED_PAGE)\n@@ -3057,14 +3057,14 @@ 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) 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) folio_put(folio);\n \tif (start > end)\n \t\treturn end;\n \treturn start;\n@@ -3303,7 +3303,7 @@ 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) folio_put(folio);\n \t\tgoto retry_find;\n \t}\n \tVM_BUG_ON_FOLIO(!folio_contains(folio, index), folio);\n@@ -3321,7 +3321,7 @@ 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) folio_put(folio);\n \t\t\tgoto retry_find;\n \t\t}\n \t\tgoto page_not_uptodate;\n@@ -3346,7 +3346,7 @@ 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) folio_put(folio);\n \t\treturn VM_FAULT_SIGBUS;\n \t}\n \n@@ -3364,7 +3364,7 @@ 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) folio_put(folio);\n \n \tif (!error || error == AOP_TRUNCATED_PAGE)\n \t\tgoto retry_find;\n@@ -3379,7 +3379,7 @@ 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) folio_put(folio);\n \tif (mapping_locked)\n \t\tfilemap_invalidate_unlock_shared(mapping);\n \tif (fpin)\n@@ -3396,7 +3396,7 @@ 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) folio_put(folio);\n \t\treturn true;\n \t}\n \n@@ -3416,7 +3416,7 @@ 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) folio_put(folio);\n \t\treturn true;\n \t}\n \n@@ -3458,7 +3458,7 @@ 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) folio_put(folio);\n \t} while ((folio = xas_next_entry(xas, end_pgoff)) != NULL);\n \n \treturn NULL;\n@@ -3547,7 +3547,7 @@ 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) 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 +3646,7 @@ 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) 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 +3666,7 @@ 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) folio_put(folio);\n \t\tgoto repeat;\n \t}\n \n@@ -3679,7 +3679,7 @@ 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) folio_put(folio);\n \t\tif (err == AOP_TRUNCATED_PAGE)\n \t\t\tgoto repeat;\n \t\treturn ERR_PTR(err);\n",
            "diff --git a/mm/filemap.c b/mm/filemap.c\nindex a34abfe8c654..8f547b171c48 100644\n--- a/mm/filemap.c\n+++ b/mm/filemap.c\n@@ -3297,7 +3297,7 @@ vm_fault_t filemap_fault(struct vm_fault *vmf)\n \t\t}\n \t}\n \n-\tif (!lock_folio_maybe_drop_mmap(vmf, folio, &fpin))\n+\tif (!folio || IS_ERR(folio) || !lock_folio_maybe_drop_mmap(vmf, folio, &fpin))\n \t\tgoto out_retry;\n \n \t/* Did it get truncated? */\n",
            "diff --git a/mm/filemap.c b/mm/filemap.c\nindex a34abfe8c654..b871154b0740 100644\n--- a/mm/filemap.c\n+++ b/mm/filemap.c\n@@ -1279,7 +1279,9 @@ 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 \n \t/*\n \t * Note that until the \"finish_wait()\", or until\n@@ -1548,7 +1550,9 @@ 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 }\n EXPORT_SYMBOL(folio_end_private_2);\n \n@@ -1621,7 +1625,9 @@ 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 }\n EXPORT_SYMBOL(folio_end_writeback);\n \n@@ -1869,7 +1875,9 @@ 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+}\n \t\tgoto repeat;\n \t}\n out:\n@@ -1924,7 +1932,9 @@ 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+}\n \t\t\t\treturn ERR_PTR(-EAGAIN);\n \t\t\t}\n \t\t} else {\n@@ -1934,7 +1944,9 @@ 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+}\n \t\t\tgoto repeat;\n \t\t}\n \t\tVM_BUG_ON_FOLIO(!folio_contains(folio, index), folio);\n@@ -1975,7 +1987,9 @@ 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+}\n \t\t\tfolio = NULL;\n \t\t\tif (err == -EEXIST)\n \t\t\t\tgoto repeat;\n@@ -2020,7 +2034,9 @@ 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+}\n \t\tgoto reset;\n \t}\n \n@@ -2124,7 +2140,9 @@ 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+}\n \t}\n \trcu_read_unlock();\n \n@@ -2260,7 +2278,9 @@ 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 \n retry:\n \t\txas_reset(&xas);\n@@ -2394,7 +2414,9 @@ 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+}\n retry:\n \t\txas_reset(&xas);\n \t}\n@@ -2510,7 +2532,9 @@ 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+}\n \treturn error;\n }\n \n@@ -2555,7 +2579,9 @@ 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+}\n \treturn error;\n }\n \n@@ -2625,7 +2651,9 @@ 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+}\n \tif (likely(--fbatch->nr))\n \t\treturn 0;\n \tif (err == AOP_TRUNCATED_PAGE)\n@@ -3057,14 +3085,18 @@ 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+}\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+}\n \tif (start > end)\n \t\treturn end;\n \treturn start;\n@@ -3303,7 +3335,9 @@ 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+}\n \t\tgoto retry_find;\n \t}\n \tVM_BUG_ON_FOLIO(!folio_contains(folio, index), folio);\n@@ -3321,7 +3355,9 @@ 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+}\n \t\t\tgoto retry_find;\n \t\t}\n \t\tgoto page_not_uptodate;\n@@ -3346,7 +3382,9 @@ 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+}\n \t\treturn VM_FAULT_SIGBUS;\n \t}\n \n@@ -3364,7 +3402,9 @@ 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 \n \tif (!error || error == AOP_TRUNCATED_PAGE)\n \t\tgoto retry_find;\n@@ -3379,7 +3419,9 @@ 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+}\n \tif (mapping_locked)\n \t\tfilemap_invalidate_unlock_shared(mapping);\n \tif (fpin)\n@@ -3396,7 +3438,9 @@ 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+}\n \t\treturn true;\n \t}\n \n@@ -3416,7 +3460,9 @@ 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+}\n \t\treturn true;\n \t}\n \n@@ -3458,7 +3504,9 @@ 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+}\n \t} while ((folio = xas_next_entry(xas, end_pgoff)) != NULL);\n \n \treturn NULL;\n@@ -3547,7 +3595,9 @@ 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+}\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 +3696,9 @@ 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+}\n \t\t\tif (err == -EEXIST)\n \t\t\t\tgoto repeat;\n \t\t\t/* Presumably ENOMEM for xarray node */\n@@ -3666,7 +3718,9 @@ 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+}\n \t\tgoto repeat;\n \t}\n \n@@ -3679,7 +3733,9 @@ 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+}\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..d9115f8b1dc5 100644\n--- a/mm/filemap.c\n+++ b/mm/filemap.c\n@@ -3260,6 +3260,7 @@ 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) return VM_FAULT_SIGBUS;\n \tif (likely(!IS_ERR(folio))) {\n \t\t/*\n \t\t * We found the page, so try async readahead before waiting for\n@@ -3640,6 +3641,7 @@ 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) return VM_FAULT_SIGBUS;\n \tif (IS_ERR(folio)) {\n \t\tfolio = filemap_alloc_folio(gfp, 0);\n \t\tif (!folio)\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "0084fd109a7a10011e183a357715c91cff2cacb0": {
        "non_crash": [
            "diff --git a/mm/mempolicy.c b/mm/mempolicy.c\nindex 69e278b469ef..cb86bbbeed0c 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+gfp &= ~__GFP_THISNODE;\n+}\n+preferred_nid = policy_node(gfp, pol, node);\n \tpage = __alloc_pages_nodemask(gfp, order, preferred_nid, nmask);\n \tmpol_cond_put(pol);\n out:\n",
            "diff --git a/mm/mempolicy.c b/mm/mempolicy.c\nindex 69e278b469ef..ad97e5e495ef 100644\n--- a/mm/mempolicy.c\n+++ b/mm/mempolicy.c\n@@ -1742,7 +1742,10 @@ static int policy_node(gfp_t gfp, struct mempolicy *policy,\n \t\t * because we might easily break the expectation to stay on the\n \t\t * requested node and not break the policy.\n \t\t */\n-\t\tWARN_ON_ONCE(policy->mode == MPOL_BIND && (gfp & __GFP_THISNODE));\n+\t\tif (policy->mode == MPOL_BIND && (gfp & __GFP_THISNODE)) {\n+        pr_warn(\"policy_node: BIND policy used with __GFP_THISNODE, ignoring __GFP_THISNODE\\n\");\n+        nd = first_node(policy->v.nodes);\n+    }\n \t}\n \n \treturn nd;\n",
            "diff --git a/mm/mempolicy.c b/mm/mempolicy.c\nindex 69e278b469ef..d1bedef21551 100644\n--- a/mm/mempolicy.c\n+++ b/mm/mempolicy.c\n@@ -1742,7 +1742,8 @@ static int policy_node(gfp_t gfp, struct mempolicy *policy,\n \t\t * because we might easily break the expectation to stay on the\n \t\t * requested node and not break the policy.\n \t\t */\n-\t\tWARN_ON_ONCE(policy->mode == MPOL_BIND && (gfp & __GFP_THISNODE));\n+\t\tgfp &= ~__GFP_THISNODE;\n+WARN_ON_ONCE(policy->mode == MPOL_BIND && (gfp & __GFP_THISNODE));\n \t}\n \n \treturn nd;\n",
            "diff --git a/mm/mempolicy.c b/mm/mempolicy.c\nindex 69e278b469ef..19f77e29e4f7 100644\n--- a/mm/mempolicy.c\n+++ b/mm/mempolicy.c\n@@ -2040,7 +2040,7 @@ 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 = policy_node(gfp & ~__GFP_THISNODE, pol, 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/mempolicy.c b/mm/mempolicy.c\nindex 69e278b469ef..1eea7f2ae4ff 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+    preferred_nid = 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"
            }
        ]
    },
    "0518799fc2250353125d212fc510c44adbde73c3": {
        "non_crash": [],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/netlink/af_netlink.c b/net/netlink/af_netlink.c\nindex 9ebdf3262015..4472f060cdc8 100644\n--- a/net/netlink/af_netlink.c\n+++ b/net/netlink/af_netlink.c\n@@ -1930,6 +1930,10 @@ static int netlink_sendmsg(struct socket *sock, struct msghdr *msg, size_t len)\n \t\tnetlink_broadcast(sk, skb, dst_portid, dst_group, GFP_KERNEL);\n \t}\n \terr = netlink_unicast(sk, skb, dst_portid, msg->msg_flags & MSG_DONTWAIT);\n+    \n+    if (err && refcount_dec_and_test(&skb->users)) {\n+        kfree_skb(skb);\n+    }\n \n out:\n \tscm_destroy(&scm);\n",
                "error_message": "Failed to set up instance"
            },
            {
                "patch": "diff --git a/drivers/net/wireless/ath/ath9k/hif_usb.c b/drivers/net/wireless/ath/ath9k/hif_usb.c\nindex 86ede591dafa..1381c39caf38 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,7 @@ static void hif_usb_regout_cb(struct urb *urb)\n \t\tkfree(cmd);\n \t}\n \n-\treturn;\n+\tgoto err;\n free:\n \tkfree_skb(cmd->skb);\n \tkfree(cmd);\n@@ -142,7 +142,7 @@ 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\tgoto err;\n \n \thif_dev = cmd->hif_dev;\n \n@@ -164,7 +164,7 @@ 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\tgoto err;\n \t\t}\n \t\tspin_unlock_irqrestore(&hif_dev->tx.tx_lock, flags);\n \n@@ -259,7 +259,7 @@ 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\tgoto err;\n \n \thif_dev = tx_buf->hif_dev;\n \n@@ -280,7 +280,7 @@ 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\tgoto err;\n \t\t}\n \t\tspin_unlock(&hif_dev->tx.tx_lock);\n \n@@ -586,14 +586,14 @@ 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\tgoto err;\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\tgoto err;\n \t\t}\n \n \t\tpad_len = 4 - (pkt_len & 0x3);\n@@ -664,7 +664,7 @@ static void ath9k_hif_usb_rx_cb(struct urb *urb)\n \tint ret;\n \n \tif (!skb)\n-\t\treturn;\n+\t\tgoto err;\n \n \tif (!hif_dev)\n \t\tgoto free;\n@@ -697,7 +697,7 @@ static void ath9k_hif_usb_rx_cb(struct urb *urb)\n \t\tgoto free;\n \t}\n \n-\treturn;\n+\tgoto err;\n free:\n \tkfree_skb(skb);\n \tkfree(rx_buf);\n@@ -711,7 +711,7 @@ static void ath9k_hif_usb_reg_in_cb(struct urb *urb)\n \tint ret;\n \n \tif (!skb)\n-\t\treturn;\n+\t\tgoto err;\n \n \tif (!hif_dev)\n \t\tgoto free_skb;\n@@ -766,7 +766,7 @@ static void ath9k_hif_usb_reg_in_cb(struct urb *urb)\n \t\tgoto free_skb;\n \t}\n \n-\treturn;\n+\tgoto err;\n free_skb:\n \tkfree_skb(skb);\n free_rx_buf:\n@@ -1218,7 +1218,7 @@ 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\tgoto err;\n \n \t\tdev_err(&hif_dev->udev->dev,\n \t\t\t\"ath9k_htc: Failed to get firmware %s\\n\",\n@@ -1254,7 +1254,7 @@ 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+\tgoto err;\n \n err_htc_hw_init:\n \tath9k_hif_usb_dev_deinit(hif_dev);\n@@ -1388,7 +1388,7 @@ 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\tgoto err;\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 +1405,7 @@ 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\tgoto err;\n \n \twait_for_completion(&hif_dev->fw_done);\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "47ff89a13ed39d393e043ec2715452a5b23ce8b2": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/kernel/exit.c b/kernel/exit.c\nindex f2afdb0add7c..192decde32e7 100644\n--- a/kernel/exit.c\n+++ b/kernel/exit.c\n@@ -536,7 +536,8 @@ 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+        return;\n \tmmgrab(mm);\n \tBUG_ON(mm != current->active_mm);\n \t/* more a memory barrier than a real lock */\n"
        ],
        "error": [
            {
                "patch": "diff --git a/kernel/fork.c b/kernel/fork.c\nindex f68954d05e89..f1410196df92 100644\n--- a/kernel/fork.c\n+++ b/kernel/fork.c\n@@ -589,7 +589,13 @@ static __latent_entropy int dup_mmap(struct mm_struct *mm,\n \tVMA_ITERATOR(vmi, mm, 0);\n \n \tuprobe_start_dup_mmap();\n-\tif (mmap_write_lock_killable(oldmm)) {\n+\tif (mmap_write_lock_killable(oldmm)\n+        /* Perform initial operations without holding the lock */\n+        flush_cache_dup_mm(oldmm)\n+        uprobe_dup_mmap(oldmm, mm)\n+        mmap_write_unlock(oldmm)\n+        /* Acquire lock again for critical section */\n+        mmap_write_lock_nested(mm, SINGLE_DEPTH_NESTING)) {\n \t\tretval = -EINTR;\n \t\tgoto fail_uprobe_end;\n \t}\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/kernel/fork.c b/kernel/fork.c\nindex f68954d05e89..ab248131bfca 100644\n--- a/kernel/fork.c\n+++ b/kernel/fork.c\n@@ -1309,7 +1309,7 @@ int replace_mm_exe_file(struct mm_struct *mm, struct file *new_exe_file)\n \told_exe_file = get_mm_exe_file(mm);\n \tif (old_exe_file) {\n \t\tVMA_ITERATOR(vmi, mm, 0);\n-\t\tmmap_read_lock(mm);\n+\t\tif (mmap_read_lock_killable(mm)) return;\n \t\tfor_each_vma(vmi, vma) {\n \t\t\tif (!vma->vm_file)\n \t\t\t\tcontinue;\n@@ -1337,7 +1337,7 @@ int replace_mm_exe_file(struct mm_struct *mm, struct file *new_exe_file)\n \t\t * Don't race with dup_mmap() getting the file and disallowing\n \t\t * write access while someone might open the file writable.\n \t\t */\n-\t\tmmap_read_lock(mm);\n+\t\tif (mmap_read_lock_killable(mm)) return;\n \t\tallow_write_access(old_exe_file);\n \t\tfput(old_exe_file);\n \t\tmmap_read_unlock(mm);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/kernel/sys.c b/kernel/sys.c\nindex 495cd87d9bf4..5ab2f0a1e59d 100644\n--- a/kernel/sys.c\n+++ b/kernel/sys.c\n@@ -2032,7 +2032,19 @@ static int prctl_set_mm_map(int opt, const void __user *addr, unsigned long data\n \t * arg_lock protects concurrent updates but we still need mmap_lock for\n \t * read to exclude races with sys_brk.\n \t */\n-\tmmap_read_lock(mm);\n+\t{\n+        int retries = 10;\n+        while (retries--) {\n+            if (mmap_read_trylock(mm)) {\n+                break;\n+            }\n+            msleep(100);\n+        }\n+        if (retries <= 0) {\n+            pr_err(\"Failed to acquire mmap_read_lock in exit_mm\\n\");\n+            return;\n+        }\n+    }\n \n \t/*\n \t * We don't validate if these members are pointing to\n@@ -2147,7 +2159,19 @@ static int prctl_set_mm(int opt, unsigned long addr,\n \t * mmap_lock for a) concurrent sys_brk, b) finding VMA for addr\n \t * validation.\n \t */\n-\tmmap_read_lock(mm);\n+\t{\n+        int retries = 10;\n+        while (retries--) {\n+            if (mmap_read_trylock(mm)) {\n+                break;\n+            }\n+            msleep(100);\n+        }\n+        if (retries <= 0) {\n+            pr_err(\"Failed to acquire mmap_read_lock in exit_mm\\n\");\n+            return;\n+        }\n+    }\n \tvma = find_vma(mm, addr);\n \n \tspin_lock(&mm->arg_lock);\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..ae5d25153f9f 100644\n--- a/drivers/infiniband/core/cma.c\n+++ b/drivers/infiniband/core/cma.c\n@@ -2590,7 +2590,8 @@ static int cma_listen_on_all(struct rdma_id_private *id_priv)\n \tint ret;\n \n \tmutex_lock(&lock);\n-\tlist_add_tail(&id_priv->listen_any_item, &listen_any_list);\n+\tcma_id_get(id_priv);\n+    list_add_tail(&id_priv->listen_any_item, &listen_any_list);\n \tlist_for_each_entry(cma_dev, &dev_list, list) {\n \t\tret = cma_listen_on_dev(id_priv, cma_dev, &to_destroy);\n \t\tif (ret) {\n",
            "diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c\nindex c447526288f4..3dc76cb63ba7 100644\n--- a/drivers/infiniband/core/cma.c\n+++ b/drivers/infiniband/core/cma.c\n@@ -2579,6 +2579,7 @@ static int cma_listen_on_dev(struct rdma_id_private *id_priv,\n err_listen:\n \t/* Caller must destroy this after releasing lock */\n \t*to_destroy = dev_id_priv;\n+list_del_init(&dev_id_priv->listen_item);\n \tdev_warn(&cma_dev->device->dev, \"RDMA CMA: %s, error %d\\n\", __func__, ret);\n \treturn ret;\n }\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c\nindex c447526288f4..fac162c14b5a 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\tif (to_destroy) {\n+list_del_init(&to_destroy->listen_item);\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+\tif (to_destroy) {\n+list_del_init(&to_destroy->listen_item);\n \t\trdma_destroy_id(&to_destroy->id);\n \treturn ret;\n }\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "625eef83808cdc8a4d6775801b04e985eb32fcf7": {
        "non_crash": [
            "diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c\nindex 19c707bc8801..583413ba04dd 100644\n--- a/fs/btrfs/inode.c\n+++ b/fs/btrfs/inode.c\n@@ -2619,7 +2619,11 @@ int btrfs_extract_ordered_extent(struct btrfs_bio *bbio,\n \t\treturn -EINVAL;\n \n \t/* No need to split if the ordered extent covers the entire bio. */\n-\tif (ordered->disk_num_bytes == len)\n+\tif (len >= ordered->num_bytes) {\n+        return -EINVAL;\n+    }\n+\n+    if (ordered->disk_num_bytes == len)\n \t\treturn 0;\n \n \tret = btrfs_split_ordered_extent(ordered, len);\n",
            "diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c\nindex 19c707bc8801..f36eda67185a 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",
            "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..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"
        ],
        "special_crash": [],
        "crash": [],
        "error": []
    },
    "4f6ce6f5223c2c8e75c92ce8cb619b227a8b0277": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/tipc/node.c b/net/tipc/node.c\nindex a4c2816c3746..52c653511639 100644\n--- a/net/tipc/node.c\n+++ b/net/tipc/node.c\n@@ -585,6 +585,7 @@ static void tipc_node_delete_from_list(struct tipc_node *node)\n \tlist_del_rcu(&node->list);\n \thlist_del_rcu(&node->hash);\n \ttipc_node_put(node);\n+return -EINVAL;\n }\n \n static void tipc_node_delete(struct tipc_node *node)\n@@ -594,6 +595,7 @@ static void tipc_node_delete(struct tipc_node *node)\n \n \tdel_timer_sync(&node->timer);\n \ttipc_node_put(node);\n+return -EINVAL;\n }\n \n void tipc_node_stop(struct net *net)\n@@ -671,6 +673,7 @@ int tipc_node_add_conn(struct net *net, u32 dnode, u32 port, u32 peer_port)\n \ttipc_node_write_unlock(node);\n exit:\n \ttipc_node_put(node);\n+return -EINVAL;\n \treturn err;\n }\n \n@@ -695,6 +698,7 @@ void tipc_node_remove_conn(struct net *net, u32 dnode, u32 port)\n \t}\n \ttipc_node_write_unlock(node);\n \ttipc_node_put(node);\n+return -EINVAL;\n }\n \n static void  tipc_node_clear_links(struct tipc_node *node)\n@@ -1539,6 +1543,7 @@ int tipc_node_get_linkname(struct net *net, u32 bearer_id, u32 addr,\n \ttipc_node_read_unlock(node);\n exit:\n \ttipc_node_put(node);\n+return -EINVAL;\n \treturn err;\n }\n \n@@ -2254,6 +2259,7 @@ int tipc_nl_node_dump(struct sk_buff *skb, struct netlink_callback *cb)\n \t\t\treturn -EPIPE;\n \t\t}\n \t\ttipc_node_put(node);\n+return -EINVAL;\n \t}\n \n \tlist_for_each_entry_rcu(node, &tn->node_list, list) {\n@@ -2619,6 +2625,7 @@ int tipc_nl_node_dump_link(struct sk_buff *skb, struct netlink_callback *cb)\n \t\t\tgoto out;\n \t\t}\n \t\ttipc_node_put(node);\n+return -EINVAL;\n \n \t\tlist_for_each_entry_continue_rcu(node, &tn->node_list,\n \t\t\t\t\t\t list) {\n",
            "diff --git a/net/tipc/node.c b/net/tipc/node.c\nindex a4c2816c3746..0baca19c4295 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); // Deferred to after iteration\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); // Deferred to after iteration\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); // Deferred to after iteration\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); // Deferred to after iteration\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); // Deferred to after iteration\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); // Deferred to after iteration\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); // Deferred to after iteration\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..517bda787947 100644\n--- a/net/tipc/node.c\n+++ b/net/tipc/node.c\n@@ -584,7 +584,17 @@ 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+\tlist_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 static void tipc_node_delete(struct tipc_node *node)\n@@ -593,7 +603,17 @@ 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+\tlist_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 void tipc_node_stop(struct net *net)\n@@ -670,7 +690,17 @@ 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+\tlist_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 \treturn err;\n }\n \n@@ -694,7 +724,17 @@ 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+\tlist_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 static void  tipc_node_clear_links(struct tipc_node *node)\n@@ -1538,7 +1578,17 @@ 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+\tlist_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 \treturn err;\n }\n \n@@ -2253,7 +2303,17 @@ 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\tlist_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 \t}\n \n \tlist_for_each_entry_rcu(node, &tn->node_list, list) {\n@@ -2618,7 +2678,17 @@ 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\tlist_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\tlist_for_each_entry_continue_rcu(node, &tn->node_list,\n \t\t\t\t\t\t list) {\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "ecd1f6c4b2442ea4c47c7331ed1c27c0cfdc627e": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c\nindex 2b5ef1b64249..d400e4f60563 100644\n--- a/fs/ext4/inode.c\n+++ b/fs/ext4/inode.c\n@@ -1676,6 +1676,7 @@ static int ext4_insert_delayed_block(struct inode *inode, ext4_lblk_t lblk)\n \t */\n \tif (sbi->s_cluster_ratio == 1) {\n \t\tret = ext4_da_reserve_space(inode);\n+    if (ret == 0) reserved = true;\n \t\tif (ret != 0)   /* ENOSPC */\n \t\t\tgoto errout;\n \t\treserved = true;\n@@ -1689,6 +1690,7 @@ static int ext4_insert_delayed_block(struct inode *inode, ext4_lblk_t lblk)\n \t\t\t\t\tgoto errout;\n \t\t\t\tif (ret == 0) {\n \t\t\t\t\tret = ext4_da_reserve_space(inode);\n+    if (ret == 0) reserved = true;\n \t\t\t\t\tif (ret != 0)   /* ENOSPC */\n \t\t\t\t\t\tgoto errout;\n \t\t\t\t\treserved = true;\n",
            "diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c\nindex 2b5ef1b64249..b123257925bc 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 (unlikely(ei->i_reserved_data_blocks < 0)) ei->i_reserved_data_blocks = 0;\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..1bcf3a08e631 100644\n--- a/fs/ext4/inode.c\n+++ b/fs/ext4/inode.c\n@@ -1515,6 +1515,7 @@ void ext4_da_release_space(struct inode *inode, int to_free)\n \n \ttrace_ext4_da_release_space(inode, to_free);\n \tif (unlikely(to_free > ei->i_reserved_data_blocks)) {\n+    ext4_warning(inode->i_sb, \"ext4_da_release_space: potential mismatch detected\");\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"
        ],
        "error": []
    },
    "731e35eeed762019e385baa96953d9ec8eb63c10": {
        "non_crash": [
            "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex d3dfc51a43c5..294f15f0c6f2 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -57,6 +57,7 @@ static int get_max_inline_xattr_value_size(struct inode *inode,\n \traw_inode = ext4_raw_inode(iloc);\n \theader = IHDR(inode, raw_inode);\n \tentry = IFIRST(header);\n+memset(entry, 0, sizeof(struct ext4_xattr_entry));\n \n \t/* Compute min_offs. */\n \tfor (; !IS_LAST_ENTRY(entry); entry = EXT4_XATTR_NEXT(entry)) {\n",
            "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex d3dfc51a43c5..50ed8d849f9c 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -59,7 +59,8 @@ 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+\tstruct ext4_xattr_entry *end = (struct ext4_xattr_entry *)((void *)header + EXT4_SB(inode->i_sb)->s_inode_size);\n+for (; entry < end && !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",
            "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex d3dfc51a43c5..aaa18dccea8d 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 *)EXT4_XATTR_NEXT(entry) <= (void *)raw_inode + inode->i_sb->s_blocksize); entry = EXT4_XATTR_NEXT(entry)) {\n \t\tif (!entry->e_value_inum && entry->e_value_size) {\n \t\t\tsize_t offs = le16_to_cpu(entry->e_value_offs);\n \t\t\tif (offs < min_offs)\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dfc2e223bd10..a89c9281fb1d 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -1670,6 +1670,8 @@ static int ext4_xattr_set_entry(struct ext4_xattr_info *i,\n \n \t/* Compute min_offs and last. */\n \tlast = s->first;\n+    if (s->end - (void *)last >= sizeof(struct ext4_xattr_entry))\n+        memset(last, 0, sizeof(struct ext4_xattr_entry));\n \tfor (; !IS_LAST_ENTRY(last); last = next) {\n \t\tnext = EXT4_XATTR_NEXT(last);\n \t\tif ((void *)next >= s->end) {\n@@ -1781,6 +1783,8 @@ static int ext4_xattr_set_entry(struct ext4_xattr_info *i,\n \n \t\t/* Adjust all value offsets. */\n \t\tlast = s->first;\n+    if (s->end - (void *)last >= sizeof(struct ext4_xattr_entry))\n+        memset(last, 0, sizeof(struct ext4_xattr_entry));\n \t\twhile (!IS_LAST_ENTRY(last)) {\n \t\t\tsize_t o = le16_to_cpu(last->e_value_offs);\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex d3dfc51a43c5..51b58eb3163e 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -59,7 +59,7 @@ static int get_max_inline_xattr_value_size(struct inode *inode,\n \tentry = IFIRST(header);\n \n \t/* Compute min_offs. */\n-\tfor (; !IS_LAST_ENTRY(entry); entry = EXT4_XATTR_NEXT(entry)) {\n+\tfor (; !IS_LAST_ENTRY(entry) && (void *)entry < (void *)raw_inode + iloc.bh->b_size; entry = EXT4_XATTR_NEXT(entry)) {\n \t\tif (!entry->e_value_inum && entry->e_value_size) {\n \t\t\tsize_t offs = le16_to_cpu(entry->e_value_offs);\n \t\t\tif (offs < min_offs)\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "b5d799a2cc619607ed6e322f97f78eaf534451e1": {
        "non_crash": [
            "diff --git a/fs/namei.c b/fs/namei.c\nindex 0cab6494978c..051919612ef2 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",
            "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"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/fs/namei.c b/fs/namei.c\nindex 0cab6494978c..c38a442d25c8 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -213,6 +213,10 @@ 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 {\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..ae3fe1e8f01b 100644\n--- a/fs/namei.c\n+++ b/fs/namei.c\n@@ -213,6 +213,8 @@ getname(const char __user * filename)\n \n struct filename *\n getname_kernel(const char * filename)\n+{\n+    if (!filename) 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..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"
            }
        ]
    },
    "37556d70764e226e660023fad17c9c0316cb6f1d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/fs-writeback.c b/fs/fs-writeback.c\nindex 443f83382b9b..89c9072acdb1 100644\n--- a/fs/fs-writeback.c\n+++ b/fs/fs-writeback.c\n@@ -1364,6 +1364,8 @@ static int move_expired_inodes(struct list_head *delaying_queue,\n \n \twhile (!list_empty(delaying_queue)) {\n \t\tinode = wb_inode(delaying_queue->prev);\n+        if (unlikely(inode == NULL || inode->i_state & I_FREEING))\n+            continue;\n \t\tif (inode_dirtied_after(inode, dirtied_before))\n \t\t\tbreak;\n \t\tspin_lock(&inode->i_lock);\n",
            "diff --git a/fs/fs-writeback.c b/fs/fs-writeback.c\nindex 443f83382b9b..d8997bfc6d37 100644\n--- a/fs/fs-writeback.c\n+++ b/fs/fs-writeback.c\n@@ -1332,7 +1332,7 @@ static void inode_sync_complete(struct inode *inode)\n \n static bool inode_dirtied_after(struct inode *inode, unsigned long t)\n {\n-\tbool ret = time_after(inode->dirtied_when, t);\n+\tbool ret = inode && time_after(inode->dirtied_when, t);\n #ifndef CONFIG_64BIT\n \t/*\n \t * For inodes being constantly redirtied, dirtied_when can get stuck.\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/fs-writeback.c b/fs/fs-writeback.c\nindex 443f83382b9b..0b4b01d7c25a 100644\n--- a/fs/fs-writeback.c\n+++ b/fs/fs-writeback.c\n@@ -313,6 +313,7 @@ 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+        iput(inode);\n \t\tspin_lock(&wb->list_lock);\n \n \t\t/* i_wb may have changed inbetween, can't use inode_to_wb() */\n@@ -457,6 +458,7 @@ static bool inode_do_switch_wbs(struct inode *inode,\n \n \txa_unlock_irq(&mapping->i_pages);\n \tspin_unlock(&inode->i_lock);\n+        iput(inode);\n \n \treturn switched;\n }\n@@ -538,11 +540,13 @@ static bool inode_prepare_wbs_switch(struct inode *inode,\n \t    inode->i_state & (I_WB_SWITCH | I_FREEING | I_WILL_FREE) ||\n \t    inode_to_wb(inode) == new_wb) {\n \t\tspin_unlock(&inode->i_lock);\n+        iput(inode);\n \t\treturn false;\n \t}\n \tinode->i_state |= I_WB_SWITCH;\n \t__iget(inode);\n \tspin_unlock(&inode->i_lock);\n+        iput(inode);\n \n \treturn true;\n }\n@@ -693,6 +697,7 @@ void wbc_attach_and_unlock_inode(struct writeback_control *wbc,\n {\n \tif (!inode_cgwb_enabled(inode)) {\n \t\tspin_unlock(&inode->i_lock);\n+        iput(inode);\n \t\treturn;\n \t}\n \n@@ -708,6 +713,7 @@ void wbc_attach_and_unlock_inode(struct writeback_control *wbc,\n \n \twb_get(wbc->wb);\n \tspin_unlock(&inode->i_lock);\n+        iput(inode);\n \n \t/*\n \t * A dying wb indicates that either the blkcg associated with the\n@@ -1143,6 +1149,7 @@ 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+        iput(inode);\n \tspin_lock(&wb->list_lock);\n \treturn wb;\n }\n@@ -1241,6 +1248,7 @@ void inode_io_list_del(struct inode *inode)\n \twb_io_lists_depopulated(wb);\n \n \tspin_unlock(&inode->i_lock);\n+        iput(inode);\n \tspin_unlock(&wb->list_lock);\n }\n EXPORT_SYMBOL(inode_io_list_del);\n@@ -1310,6 +1318,7 @@ static void redirty_tail(struct inode *inode, struct bdi_writeback *wb)\n \tspin_lock(&inode->i_lock);\n \tredirty_tail_locked(inode, wb);\n \tspin_unlock(&inode->i_lock);\n+        iput(inode);\n }\n \n /*\n@@ -1364,6 +1373,8 @@ static int move_expired_inodes(struct list_head *delaying_queue,\n \n \twhile (!list_empty(delaying_queue)) {\n \t\tinode = wb_inode(delaying_queue->prev);\n+        if (!igrab(inode))\n+            break;\n \t\tif (inode_dirtied_after(inode, dirtied_before))\n \t\t\tbreak;\n \t\tspin_lock(&inode->i_lock);\n@@ -1371,6 +1382,7 @@ static int move_expired_inodes(struct list_head *delaying_queue,\n \t\tmoved++;\n \t\tinode->i_state |= I_SYNC_QUEUED;\n \t\tspin_unlock(&inode->i_lock);\n+        iput(inode);\n \t\tif (sb_is_blkdev_sb(inode->i_sb))\n \t\t\tcontinue;\n \t\tif (sb && sb != inode->i_sb)\n@@ -1458,6 +1470,7 @@ static void __inode_wait_for_writeback(struct inode *inode)\n \twqh = bit_waitqueue(&inode->i_state, __I_SYNC);\n \twhile (inode->i_state & I_SYNC) {\n \t\tspin_unlock(&inode->i_lock);\n+        iput(inode);\n \t\t__wait_on_bit(wqh, &wq, bit_wait,\n \t\t\t      TASK_UNINTERRUPTIBLE);\n \t\tspin_lock(&inode->i_lock);\n@@ -1472,6 +1485,7 @@ void inode_wait_for_writeback(struct inode *inode)\n \tspin_lock(&inode->i_lock);\n \t__inode_wait_for_writeback(inode);\n \tspin_unlock(&inode->i_lock);\n+        iput(inode);\n }\n \n /*\n@@ -1489,6 +1503,7 @@ static void inode_sleep_on_writeback(struct inode *inode)\n \tprepare_to_wait(wqh, &wait, TASK_UNINTERRUPTIBLE);\n \tsleep = inode->i_state & I_SYNC;\n \tspin_unlock(&inode->i_lock);\n+        iput(inode);\n \tif (sleep)\n \t\tschedule();\n \tfinish_wait(wqh, &wait);\n@@ -1646,6 +1661,7 @@ __writeback_single_inode(struct inode *inode, struct writeback_control *wbc)\n \t}\n \n \tspin_unlock(&inode->i_lock);\n+        iput(inode);\n \n \t/* Don't write the inode if only I_DIRTY_PAGES was set */\n \tif (dirty & ~I_DIRTY_PAGES) {\n@@ -1731,6 +1747,7 @@ static int writeback_single_inode(struct inode *inode,\n \tinode_sync_complete(inode);\n out:\n \tspin_unlock(&inode->i_lock);\n+        iput(inode);\n \treturn ret;\n }\n \n@@ -1825,6 +1842,7 @@ static long writeback_sb_inodes(struct super_block *sb,\n \t\tif (inode->i_state & (I_NEW | I_FREEING | I_WILL_FREE)) {\n \t\t\tredirty_tail_locked(inode, wb);\n \t\t\tspin_unlock(&inode->i_lock);\n+        iput(inode);\n \t\t\tcontinue;\n \t\t}\n \t\tif ((inode->i_state & I_SYNC) && wbc.sync_mode != WB_SYNC_ALL) {\n@@ -1839,6 +1857,7 @@ static long writeback_sb_inodes(struct super_block *sb,\n \t\t\t */\n \t\t\trequeue_io(inode, wb);\n \t\t\tspin_unlock(&inode->i_lock);\n+        iput(inode);\n \t\t\ttrace_writeback_sb_inodes_requeue(inode);\n \t\t\tcontinue;\n \t\t}\n@@ -1899,6 +1918,7 @@ static long writeback_sb_inodes(struct super_block *sb,\n \t\trequeue_inode(inode, tmp_wb, &wbc);\n \t\tinode_sync_complete(inode);\n \t\tspin_unlock(&inode->i_lock);\n+        iput(inode);\n \n \t\tif (unlikely(tmp_wb != wb)) {\n \t\t\tspin_unlock(&tmp_wb->list_lock);\n@@ -2386,6 +2406,7 @@ void __mark_inode_dirty(struct inode *inode, int flags)\n \t\t\t\tflags |= I_DIRTY_TIME;\n \t\t\t}\n \t\t\tspin_unlock(&inode->i_lock);\n+        iput(inode);\n \t\t}\n \n \t\t/*\n@@ -2483,6 +2504,7 @@ void __mark_inode_dirty(struct inode *inode, int flags)\n \n \t\t\tspin_unlock(&wb->list_lock);\n \t\t\tspin_unlock(&inode->i_lock);\n+        iput(inode);\n \t\t\ttrace_writeback_dirty_inode_enqueue(inode);\n \n \t\t\t/*\n@@ -2501,6 +2523,7 @@ void __mark_inode_dirty(struct inode *inode, int flags)\n \tif (wb)\n \t\tspin_unlock(&wb->list_lock);\n \tspin_unlock(&inode->i_lock);\n+        iput(inode);\n }\n EXPORT_SYMBOL(__mark_inode_dirty);\n \n@@ -2571,12 +2594,14 @@ static void wait_sb_inodes(struct super_block *sb)\n \t\tspin_lock(&inode->i_lock);\n \t\tif (inode->i_state & (I_FREEING|I_WILL_FREE|I_NEW)) {\n \t\t\tspin_unlock(&inode->i_lock);\n+        iput(inode);\n \n \t\t\tspin_lock_irq(&sb->s_inode_wblist_lock);\n \t\t\tcontinue;\n \t\t}\n \t\t__iget(inode);\n \t\tspin_unlock(&inode->i_lock);\n+        iput(inode);\n \t\trcu_read_unlock();\n \n \t\t/*\n",
                "error_message": "Failed to set up instance"
            },
            {
                "patch": "diff --git a/fs/fs-writeback.c b/fs/fs-writeback.c\nindex 443f83382b9b..31d6e42fe344 100644\n--- a/fs/fs-writeback.c\n+++ b/fs/fs-writeback.c\n@@ -1364,6 +1364,7 @@ static int move_expired_inodes(struct list_head *delaying_queue,\n \n \twhile (!list_empty(delaying_queue)) {\n \t\tinode = wb_inode(delaying_queue->prev);\n+        igrab(inode);\n \t\tif (inode_dirtied_after(inode, dirtied_before))\n \t\t\tbreak;\n \t\tspin_lock(&inode->i_lock);\n@@ -1399,7 +1400,11 @@ static int move_expired_inodes(struct list_head *delaying_queue,\n \t\t}\n \t}\n out:\n-\treturn moved;\n+\tlist_for_each_prev_safe(pos, node, &tmp) {\n+        inode = wb_inode(pos);\n+        iput(inode);\n+    }\n+    return moved;\n }\n \n /*\n",
                "error_message": "Failed to set up instance"
            }
        ]
    },
    "e0623166295289b0b91d327386331328f3f2505d": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/hsr/hsr_slave.c b/net/hsr/hsr_slave.c\nindex 25b6ffba26cd..85d8ecadc7c3 100644\n--- a/net/hsr/hsr_slave.c\n+++ b/net/hsr/hsr_slave.c\n@@ -162,7 +162,8 @@ int hsr_add_port(struct hsr_priv *hsr, struct net_device *dev,\n \t}\n \n \tlist_add_tail_rcu(&port->port_list, &hsr->ports);\n-\tsynchronize_rcu();\n+\t// Ensure all resources are freed before syncing\n+synchronize_rcu();\n \n \tmaster = hsr_port_get_hsr(hsr, HSR_PT_MASTER);\n \tnetdev_update_features(master->dev);\n@@ -192,7 +193,8 @@ void hsr_del_port(struct hsr_port *port)\n \t\tnetdev_upper_dev_unlink(port->dev, master->dev);\n \t}\n \n-\tsynchronize_rcu();\n+\t// Ensure all resources are freed before syncing\n+synchronize_rcu();\n \n \tkfree(port);\n }\n",
            "diff --git a/net/hsr/hsr_device.c b/net/hsr/hsr_device.c\nindex 478852ef98ef..5f8230ae1578 100644\n--- a/net/hsr/hsr_device.c\n+++ b/net/hsr/hsr_device.c\n@@ -480,6 +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+    if (netif_running(hsr_dev))\n+        unregister_netdevice(hsr_dev);\n \tunregister_netdevice(hsr_dev);\n err_unregister:\n \thsr_del_ports(hsr);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/hsr/hsr_slave.c b/net/hsr/hsr_slave.c\nindex 25b6ffba26cd..00982a1e3bde 100644\n--- a/net/hsr/hsr_slave.c\n+++ b/net/hsr/hsr_slave.c\n@@ -176,6 +176,9 @@ int hsr_add_port(struct hsr_priv *hsr, struct net_device *dev,\n }\n \n void hsr_del_port(struct hsr_port *port)\n+{\n+    if (!port || !port->dev || !netdev_has_upper_dev(port->dev, port->hsr->dev))\n+        return;\n {\n \tstruct hsr_priv *hsr;\n \tstruct hsr_port *master;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/hsr/hsr_device.c b/net/hsr/hsr_device.c\nindex 478852ef98ef..77cd6693fd0a 100644\n--- a/net/hsr/hsr_device.c\n+++ b/net/hsr/hsr_device.c\n@@ -480,7 +480,10 @@ 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+\tif (netdev_has_any_upper_dev(hsr_dev) || netdev_has_any_lower_dev(hsr_dev)) {\n+pr_warn(\"HSR device has linked upper or lower devices before unregistering\\n\");\n+}\n+unregister_netdevice(hsr_dev);\n err_unregister:\n \thsr_del_ports(hsr);\n err_add_master:\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "e9f526f59d5b25decd3b91d4270b5da2aa23c8f6": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/media/common/videobuf2/videobuf2-vmalloc.c b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\nindex 6dfbd5b05907..138bc3c159ce 100644\n--- a/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n+++ b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n@@ -133,7 +133,7 @@ static void vb2_vmalloc_put_userptr(void *buf_priv)\n \tstruct page **pages;\n \tunsigned int n_pages;\n \n-\tif (!buf->vec->is_pfns) {\n+\tif (buf->vec && !buf->vec->is_pfns) {\n \t\tn_pages = frame_vector_count(buf->vec);\n \t\tpages = frame_vector_pages(buf->vec);\n \t\tif (vaddr)\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/media/common/videobuf2/videobuf2-vmalloc.c b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\nindex 6dfbd5b05907..5b385818c664 100644\n--- a/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n+++ b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n@@ -126,6 +126,21 @@ 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(\"Buffer is NULL in vb2_vmalloc_put_userptr\\n\");\n+        return;\n+    }\n+    struct vb2_vmalloc_buf *buf = buf_priv;\n+    if (!buf->vec) {\n+        pr_err(\"Frame vector is NULL in vb2_vmalloc_put_userptr\\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+    if (!buf->vec->is_pfns) {\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..b381f62ba538 100644\n--- a/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n+++ b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n@@ -126,6 +126,32 @@ 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->vaddr || !buf->vec) {\n+        pr_err(\"Invalid buffer or unallocated memory\\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+    if (!buf->vec->is_pfns) {\n+        n_pages = frame_vector_count(buf->vec);\n+        pages = frame_vector_pages(buf->vec);\n+        if (vaddr)\n+            vm_unmap_ram((void *)vaddr, n_pages);\n+        if (buf->dma_dir == DMA_FROM_DEVICE ||\n+            buf->dma_dir == DMA_BIDIRECTIONAL)\n+            for (i = 0; i < n_pages; i++)\n+                set_page_dirty_lock(pages[i]);\n+    } else {\n+        iounmap((__force void __iomem *)buf->vaddr);\n+    }\n+    vb2_destroy_framevec(buf->vec);\n+    kfree(buf);\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..893c84fa46cf 100644\n--- a/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n+++ b/drivers/media/common/videobuf2/videobuf2-vmalloc.c\n@@ -126,6 +126,33 @@ 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+    unsigned long vaddr = (unsigned long)buf->vaddr & PAGE_MASK;\n+    unsigned int i;\n+    struct page **pages;\n+    unsigned int n_pages;\n+\n+    if (!buf || !buf->vec || !buf->vaddr) {\n+        pr_err(\"Invalid buffer or vector or address\\n\");\n+        return;\n+    }\n+    \n+    if (!buf->vec->is_pfns) {\n+        n_pages = frame_vector_count(buf->vec);\n+        pages = frame_vector_pages(buf->vec);\n+        if (vaddr)\n+            vm_unmap_ram((void *)vaddr, n_pages);\n+        if (buf->dma_dir == DMA_FROM_DEVICE ||\n+            buf->dma_dir == DMA_BIDIRECTIONAL)\n+            for (i = 0; i < n_pages; i++)\n+                set_page_dirty_lock(pages[i]);\n+    } else {\n+        iounmap((__force void __iomem *)buf->vaddr);\n+    }\n+    vb2_destroy_framevec(buf->vec);\n+    kfree(buf);\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..f83ba4cef1bc 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(\"Buffer pointer is NULL\\n\");\n+        return;\n+    }\n+    struct vb2_vmalloc_buf *buf = buf_priv;\n+    if (!buf->vec) {\n+        pr_err(\"Frame vector is NULL\\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"
            }
        ]
    },
    "c7c63c2548579c7e4718d2f8bc079a6e152e4ac8": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 354cb472f386..1e55e05312c6 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -134,7 +134,7 @@ nf_hook_entries_grow(const struct nf_hook_entries *old,\n \ti = 0;\n \tnhooks = 0;\n \twhile (i < old_entries) {\n-\t\tif (orig_ops[i] == &dummy_ops) {\n+\t\tif (!orig_ops || orig_ops[i] == &dummy_ops) {\n \t\t\t++i;\n \t\t\tcontinue;\n \t\t}\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 354cb472f386..c92602cb06dc 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -102,6 +102,7 @@ static const struct nf_hook_ops dummy_ops = {\n \n static struct nf_hook_entries *\n nf_hook_entries_grow(const struct nf_hook_entries *old,\n+rcu_read_lock();\n \t\t     const struct nf_hook_ops *reg)\n {\n \tunsigned int i, alloc_entries, nhooks, old_entries;\n@@ -158,7 +159,8 @@ nf_hook_entries_grow(const struct nf_hook_entries *old,\n \t\tnew->hooks[nhooks].priv = reg->priv;\n \t}\n \n-\treturn new;\n+\trcu_read_unlock();\n+return new;\n }\n \n static void hooks_validate(const struct nf_hook_entries *hooks)\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 354cb472f386..bc19e7cda8c0 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -535,6 +535,11 @@ void nf_unregister_net_hook(struct net *net, const struct nf_hook_ops *reg)\n EXPORT_SYMBOL(nf_unregister_net_hook);\n \n void nf_hook_entries_delete_raw(struct nf_hook_entries __rcu **pp,\n+const struct nf_hook_ops *reg)\n+{\n+struct nf_hook_entries *p;\n+\n+mutex_lock(&nf_hook_mutex);\n \t\t\t\tconst struct nf_hook_ops *reg)\n {\n \tstruct nf_hook_entries *p;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/netfilter/core.c b/net/netfilter/core.c\nindex 354cb472f386..77ef7f42a6e8 100644\n--- a/net/netfilter/core.c\n+++ b/net/netfilter/core.c\n@@ -158,7 +158,9 @@ nf_hook_entries_grow(const struct nf_hook_entries *old,\n \t\tnew->hooks[nhooks].priv = reg->priv;\n \t}\n \n-\treturn new;\n+\trcu_read_lock();\n+    return new;\n+    rcu_read_unlock();\n }\n \n static void hooks_validate(const struct nf_hook_entries *hooks)\n",
                "error_message": "Failed to set up instance"
            }
        ]
    },
    "31a3f2ad09a571fb7a5212efc400ce6bfc82e04c": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/extents_status.c b/fs/ext4/extents_status.c\nindex 9a3a8996aacf..6868cc6675c6 100644\n--- a/fs/ext4/extents_status.c\n+++ b/fs/ext4/extents_status.c\n@@ -896,7 +896,9 @@ 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 (len <= 0) return;\n+\n+    BUG_ON(end < lblk);\n \n \twrite_lock(&EXT4_I(inode)->i_es_lock);\n \n",
            "diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c\nindex 474479ce76e0..9e3ebd69f19b 100644\n--- a/fs/ext4/extents.c\n+++ b/fs/ext4/extents.c\n@@ -509,7 +509,7 @@ static void ext4_cache_extents(struct inode *inode,\n \t\text4_lblk_t lblk = le32_to_cpu(ex->ee_block);\n \t\tint len = ext4_ext_get_actual_len(ex);\n \n-\t\tif (prev && (prev != lblk))\n+\t\tif (prev && (prev != lblk) && (lblk > prev))\n \t\t\text4_es_cache_extent(inode, prev, lblk - prev, ~0,\n \t\t\t\t\t     EXTENT_STATUS_HOLE);\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/extents_status.c b/fs/ext4/extents_status.c\nindex 9a3a8996aacf..a6cb5ad6fdd1 100644\n--- a/fs/ext4/extents_status.c\n+++ b/fs/ext4/extents_status.c\n@@ -878,6 +878,9 @@ int ext4_es_insert_extent(struct inode *inode, ext4_lblk_t lblk,\n  * question already.\n  */\n void ext4_es_cache_extent(struct inode *inode, ext4_lblk_t lblk,\n+{\n+    if (!len)\n+        return;\n \t\t\t  ext4_lblk_t len, ext4_fsblk_t pblk,\n \t\t\t  unsigned int status)\n {\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..ddd48f78bf2e 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1211,7 +1211,8 @@ int ebt_register_table(struct net *net, const struct ebt_table *input_table,\n \t\tgoto free_newinfo;\n \n \tmemcpy(p, repl->entries, repl->entries_size);\n-\tnewinfo->entries = p;\n+\tmemset(p, 0, repl->entries_size);\n+    newinfo->entries = p;\n \n \tnewinfo->entries_size = repl->entries_size;\n \tnewinfo->nentries = repl->nentries;\n",
            "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex ce5dfa3babd2..d6f54f709e20 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": [
            {
                "patch": "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex ce5dfa3babd2..6b9eda5a6175 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -474,7 +474,7 @@ static int ebt_verify_pointers(const struct ebt_replace *repl,\n \tfor (i = 0; i < NF_BR_NUMHOOKS; i++)\n \t\tnewinfo->hook_entry[i] = NULL;\n \n-\tnewinfo->entries_size = repl->entries_size;\n+\tnewinfo->entries_size = vmalloc_size(p); // Ensure entries_size matches allocated size\n \tnewinfo->nentries = repl->nentries;\n \n \twhile (offset < limit) {\n@@ -1213,7 +1213,7 @@ 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+\tnewinfo->entries_size = vmalloc_size(p); // Ensure entries_size matches allocated size\n \tnewinfo->nentries = repl->nentries;\n \n \tif (countersize)\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/include/uapi/linux/netfilter_bridge/ebtables.h b/include/uapi/linux/netfilter_bridge/ebtables.h\nindex a494cf43a755..5f23943e4e40 100644\n--- a/include/uapi/linux/netfilter_bridge/ebtables.h\n+++ b/include/uapi/linux/netfilter_bridge/ebtables.h\n@@ -265,7 +265,11 @@ ebt_get_target(struct ebt_entry *e)\n \tint __ret = 0;                                      \\\n \tstruct ebt_entry *__entry;                          \\\n \t                                                    \\\n-\tfor (__i = 0; __i < (size);) {                      \\\n+\tfor (__i = 0; __i < (size);) {\n+if (__i + __entry->next_offset > size) {\n+__ret = -EINVAL;\n+break;\n+}                      \\\n \t\t__entry = (void *)(entries) + __i;          \\\n \t\t__ret = fn(__entry , ## args);              \\\n \t\tif (__ret != 0)                             \\\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex ce5dfa3babd2..4b8c64754387 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1883,6 +1883,7 @@ static int compat_copy_everything_to_user(struct ebt_table *t,\n \t\treturn ret;\n \n \tif (*len != sizeof(tmp) + repl.entries_size +\n+    if (tinfo.entries_size != repl.entries_size) return -EINVAL;\n \t   (tmp.num_counters? tinfo.nentries * sizeof(struct ebt_counter): 0)) {\n \t\tpr_err(\"wrong size: *len %d, entries_size %u, replsz %d\\n\",\n \t\t\t\t*len, tinfo.entries_size, repl.entries_size);\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..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..5c6363a82459 100644\n--- a/net/ipv6/exthdrs.c\n+++ b/net/ipv6/exthdrs.c\n@@ -1353,7 +1353,9 @@ 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+            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..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..d274ce44bbc4 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..12672f54ea71 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)\n+        fl6->daddr = srh->segments[srh->segments_left];\n \t\tbreak;\n \t}\n \tdefault:\n"
        ],
        "error": []
    },
    "bf7780df648105d40e1fdbb0566defda3605ed93": {
        "non_crash": [
            "diff --git a/net/core/gro.c b/net/core/gro.c\nindex b4190eb08467..3eece615c515 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 (unlikely(!pskb_may_pull(skb, vlan_depth))) 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..7491ac68141a 100644\n--- a/net/core/gro.c\n+++ b/net/core/gro.c\n@@ -133,7 +133,9 @@ 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))\n+        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..29f64ba14319 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 (unlikely(skb->len < vlan_depth)) 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..b7c76105f819 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->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..cb25e6be2f31 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->len || !type) 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"
        ],
        "error": []
    },
    "64619c0d6d2ef98d85b7bb4ff271bfa9df74ce03": {
        "non_crash": [
            "diff --git a/fs/ext4/mballoc.c b/fs/ext4/mballoc.c\nindex 9dad93059945..20b615690f58 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+        mb_debug(ac->ac_sb, \"not enough free blocks in inode pa %p\\n\", pa);\n+        return;\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",
            "diff --git a/fs/ext4/mballoc.c b/fs/ext4/mballoc.c\nindex 9dad93059945..d1fdf0edda91 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+        mb_debug(ac->ac_sb, \"Not enough free blocks in inode pa %p\\n\", pa);\n+        return;\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..559557d723c0 100644\n--- a/fs/ext4/mballoc.c\n+++ b/fs/ext4/mballoc.c\n@@ -4291,7 +4291,12 @@ 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 free blocks */\n+        ac->ac_status = AC_STATUS_CONTINUE;\n+        return;\n+    }\n+    BUG_ON(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..63b1db545932 100644\n--- a/fs/ext4/mballoc.c\n+++ b/fs/ext4/mballoc.c\n@@ -4291,7 +4291,8 @@ 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: %u, len: %d\\n\", pa->pa_free, len);\n+    BUG_ON(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"
        ],
        "error": []
    },
    "49b6f675bead6969f913a3f7dcef4d28fdd13296": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/mmap.c b/mm/mmap.c\nindex 51e70fa98450..cf65f628a359 100644\n--- a/mm/mmap.c\n+++ b/mm/mmap.c\n@@ -2531,7 +2531,10 @@ do_vmi_align_munmap(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \t\t\tvma_test = mas_next(&test, end - 1);\n \t\t}\n \t\trcu_read_unlock();\n-\t\tBUG_ON(count != test_count);\n+\t\tif (count != test_count) {\n+    pr_err(\"VMA count mismatch: expected %d, found %d\\n\", test_count, count);\n+    return -EINVAL;\n+}\n \t}\n #endif\n \tvma_iter_set(vmi, start);\n",
            "diff --git a/mm/mmap.c b/mm/mmap.c\nindex 51e70fa98450..6b3722c39d32 100644\n--- a/mm/mmap.c\n+++ b/mm/mmap.c\n@@ -426,6 +426,7 @@ static int vma_link(struct mm_struct *mm, struct vm_area_struct *vma)\n \n \tmm->map_count++;\n \tvalidate_mm(mm);\n+    pr_warn(\"After adding VMA: map_count = %d\\n\", mm->map_count);\n \treturn 0;\n }\n \n@@ -580,6 +581,7 @@ static inline void vma_complete(struct vma_prepare *vp,\n \t\tif (vp->remove->anon_vma)\n \t\t\tanon_vma_merge(vp->vma, vp->remove);\n \t\tmm->map_count--;\n+    pr_warn(\"After removing VMA: map_count = %d\\n\", mm->map_count);\n \t\tmpol_put(vma_policy(vp->remove));\n \t\tif (!vp->remove2)\n \t\t\tWARN_ON_ONCE(vp->vma->vm_end < vp->remove->vm_end);\n@@ -892,6 +894,7 @@ struct vm_area_struct *vma_merge(struct vma_iterator *vmi, struct mm_struct *mm,\n \tlong adj_start = 0;\n \n \tvalidate_mm(mm);\n+    pr_warn(\"After adding VMA: map_count = %d\\n\", mm->map_count);\n \t/*\n \t * We later require that vma->vm_flags == vm_flags,\n \t * so this tests vma->vm_flags & VM_SPECIAL, too.\n@@ -1020,6 +1023,7 @@ struct vm_area_struct *vma_merge(struct vma_iterator *vmi, struct mm_struct *mm,\n \tvma_complete(&vp, vmi, mm);\n \tvma_iter_free(vmi);\n \tvalidate_mm(mm);\n+    pr_warn(\"After adding VMA: map_count = %d\\n\", mm->map_count);\n \tkhugepaged_enter_vma(res, vm_flags);\n \n \treturn res;\n@@ -1197,6 +1201,7 @@ unsigned long do_mmap(struct file *file, unsigned long addr,\n \tint pkey = 0;\n \n \tvalidate_mm(mm);\n+    pr_warn(\"After adding VMA: map_count = %d\\n\", mm->map_count);\n \t*populate = 0;\n \n \tif (!len)\n@@ -2289,6 +2294,7 @@ static inline void remove_mt(struct mm_struct *mm, struct ma_state *mas)\n \t}\n \tvm_unacct_memory(nr_accounted);\n \tvalidate_mm(mm);\n+    pr_warn(\"After adding VMA: map_count = %d\\n\", mm->map_count);\n }\n \n /*\n@@ -2559,6 +2565,7 @@ do_vmi_align_munmap(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \n \n \tvalidate_mm(mm);\n+    pr_warn(\"After adding VMA: map_count = %d\\n\", mm->map_count);\n \treturn 0;\n \n clear_tree_failed:\n@@ -2860,6 +2867,7 @@ unsigned long mmap_region(struct file *file, unsigned long addr,\n \tvma_set_page_prot(vma);\n \n \tvalidate_mm(mm);\n+    pr_warn(\"After adding VMA: map_count = %d\\n\", mm->map_count);\n \treturn addr;\n \n close_and_free_vma:\n@@ -2883,6 +2891,7 @@ unsigned long mmap_region(struct file *file, unsigned long addr,\n \tif (charged)\n \t\tvm_unacct_memory(charged);\n \tvalidate_mm(mm);\n+    pr_warn(\"After adding VMA: map_count = %d\\n\", mm->map_count);\n \treturn error;\n }\n \n@@ -3025,6 +3034,7 @@ int do_vma_munmap(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \tarch_unmap(mm, start, end);\n \tret = do_vmi_align_munmap(vmi, vma, mm, start, end, uf, unlock);\n \tvalidate_mm(mm);\n+    pr_warn(\"After adding VMA: map_count = %d\\n\", mm->map_count);\n \treturn ret;\n }\n \n@@ -3047,6 +3057,7 @@ static int do_brk_flags(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \tstruct vma_prepare vp;\n \n \tvalidate_mm(mm);\n+    pr_warn(\"After adding VMA: map_count = %d\\n\", mm->map_count);\n \t/*\n \t * Check against address space limits by the changed size\n \t * Note: This happens *after* clearing old mappings in some code paths.\n@@ -3107,6 +3118,7 @@ static int do_brk_flags(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \t\tmm->locked_vm += (len >> PAGE_SHIFT);\n \tvm_flags_set(vma, VM_SOFTDIRTY);\n \tvalidate_mm(mm);\n+    pr_warn(\"After adding VMA: map_count = %d\\n\", mm->map_count);\n \treturn 0;\n \n mas_store_fail:\n@@ -3288,6 +3300,7 @@ struct vm_area_struct *copy_vma(struct vm_area_struct **vmap,\n \tVMA_ITERATOR(vmi, mm, addr);\n \n \tvalidate_mm(mm);\n+    pr_warn(\"After adding VMA: map_count = %d\\n\", mm->map_count);\n \t/*\n \t * If anonymous vma has not yet been faulted, update new pgoff\n \t * to match new location, to increase its chance of merging.\n@@ -3347,6 +3360,7 @@ struct vm_area_struct *copy_vma(struct vm_area_struct **vmap,\n \t\t*need_rmap_locks = false;\n \t}\n \tvalidate_mm(mm);\n+    pr_warn(\"After adding VMA: map_count = %d\\n\", mm->map_count);\n \treturn new_vma;\n \n out_vma_link:\n@@ -3363,6 +3377,7 @@ struct vm_area_struct *copy_vma(struct vm_area_struct **vmap,\n \tvm_area_free(new_vma);\n out:\n \tvalidate_mm(mm);\n+    pr_warn(\"After adding VMA: map_count = %d\\n\", mm->map_count);\n \treturn NULL;\n }\n \n@@ -3500,6 +3515,7 @@ static struct vm_area_struct *__install_special_mapping(\n \tstruct vm_area_struct *vma;\n \n \tvalidate_mm(mm);\n+    pr_warn(\"After adding VMA: map_count = %d\\n\", mm->map_count);\n \tvma = vm_area_alloc(mm);\n \tif (unlikely(vma == NULL))\n \t\treturn ERR_PTR(-ENOMEM);\n@@ -3523,11 +3539,13 @@ static struct vm_area_struct *__install_special_mapping(\n \tperf_event_mmap(vma);\n \n \tvalidate_mm(mm);\n+    pr_warn(\"After adding VMA: map_count = %d\\n\", mm->map_count);\n \treturn vma;\n \n out:\n \tvm_area_free(vma);\n \tvalidate_mm(mm);\n+    pr_warn(\"After adding VMA: map_count = %d\\n\", mm->map_count);\n \treturn ERR_PTR(ret);\n }\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/mm/mmap.c b/mm/mmap.c\nindex 51e70fa98450..50a0b9200d98 100644\n--- a/mm/mmap.c\n+++ b/mm/mmap.c\n@@ -424,7 +424,8 @@ static int vma_link(struct mm_struct *mm, struct vm_area_struct *vma)\n \t\ti_mmap_unlock_write(mapping);\n \t}\n \n-\tmm->map_count++;\n+\tmm->map_count--;\n+    \n \tvalidate_mm(mm);\n \treturn 0;\n }\n@@ -551,7 +552,8 @@ static inline void vma_complete(struct vma_prepare *vp,\n \t\t * (it may either follow vma or precede it).\n \t\t */\n \t\tvma_iter_store(vmi, vp->insert);\n-\t\tmm->map_count++;\n+\t\tmm->map_count--;\n+    \n \t}\n \n \tif (vp->anon_vma) {\n@@ -2809,7 +2811,8 @@ unsigned long mmap_region(struct file *file, unsigned long addr,\n \t\ti_mmap_lock_write(vma->vm_file->f_mapping);\n \n \tvma_iter_store(&vmi, vma);\n-\tmm->map_count++;\n+\tmm->map_count--;\n+    \n \tif (vma->vm_file) {\n \t\tif (vma->vm_flags & VM_SHARED)\n \t\t\tmapping_allow_writable(vma->vm_file->f_mapping);\n@@ -3097,7 +3100,8 @@ static int do_brk_flags(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \tif (vma_iter_store_gfp(vmi, vma, GFP_KERNEL))\n \t\tgoto mas_store_fail;\n \n-\tmm->map_count++;\n+\tmm->map_count--;\n+    \n \tksm_add_vma(vma);\n out:\n \tperf_event_mmap(vma);\n",
                "error_message": "Failed to set up instance"
            }
        ]
    },
    "e58343393efd3e0657ca37cf4466fc38d1f4d4df": {
        "non_crash": [],
        "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",
            "diff --git a/drivers/dma-buf/udmabuf.c b/drivers/dma-buf/udmabuf.c\nindex 38e8767ec371..f01943a70f5d 100644\n--- a/drivers/dma-buf/udmabuf.c\n+++ b/drivers/dma-buf/udmabuf.c\n@@ -110,7 +110,11 @@ static void release_udmabuf(struct dma_buf *buf)\n \tstruct device *dev = ubuf->device->this_device;\n \tpgoff_t pg;\n \n-\tif (ubuf->sg)\n+\tif (ubuf->sg) {\n+        put_sg_table(dev, ubuf->sg, DMA_BIDIRECTIONAL);\n+    } else {\n+        pr_warn(\"release_udmabuf: sg table is null\\n\");\n+    }\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..2d7c92f6b008 100644\n--- a/drivers/dma-buf/udmabuf.c\n+++ b/drivers/dma-buf/udmabuf.c\n@@ -110,7 +110,7 @@ static void release_udmabuf(struct dma_buf *buf)\n \tstruct device *dev = ubuf->device->this_device;\n \tpgoff_t pg;\n \n-\tif (ubuf->sg)\n+\tif (ubuf->sg != NULL)\n \t\tput_sg_table(dev, ubuf->sg, DMA_BIDIRECTIONAL);\n \n \tfor (pg = 0; pg < ubuf->pagecount; pg++)\n",
            "diff --git a/drivers/dma-buf/udmabuf.c b/drivers/dma-buf/udmabuf.c\nindex 38e8767ec371..2a624b7ab3fb 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->device && ubuf->sg)\n \t\tput_sg_table(dev, ubuf->sg, DMA_BIDIRECTIONAL);\n \n \tfor (pg = 0; pg < ubuf->pagecount; pg++)\n"
        ],
        "error": []
    },
    "82136e2452d5e1ea212f5bf76fcd8db36512f981": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/erofs/inode.c b/fs/erofs/inode.c\nindex 95a403720e8c..95740a1023aa 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, 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..e453e3150478 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 -EINVAL;\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..707c42f43747 100644\n--- a/fs/erofs/inode.c\n+++ b/fs/erofs/inode.c\n@@ -220,6 +220,7 @@ 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) return -ENOMEM;\n \tif (!lnk)\n \t\treturn -ENOMEM;\n \n",
            "diff --git a/fs/erofs/inode.c b/fs/erofs/inode.c\nindex 95a403720e8c..e9218f782f9e 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, \"failed to allocate memory for symlink @ nid %llu\", vi->nid);\n+        return -ENOMEM;\n+    }\n \tif (!lnk)\n \t\treturn -ENOMEM;\n \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",
            "diff --git a/include/net/nexthop.h b/include/net/nexthop.h\nindex 3a4f9e3b91a5..07d0aec2f3ff 100644\n--- a/include/net/nexthop.h\n+++ b/include/net/nexthop.h\n@@ -238,7 +238,7 @@ 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+\treturn nhi ? nhi->reject_nh : false;\n }\n \n static inline void nexthop_path_fib_result(struct fib_result *res, int hash)\n",
            "diff --git a/include/net/nexthop.h b/include/net/nexthop.h\nindex 3a4f9e3b91a5..56803edd311d 100644\n--- a/include/net/nexthop.h\n+++ b/include/net/nexthop.h\n@@ -238,7 +238,8 @@ 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) 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..08165bebf250 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"
            },
            {
                "patch": "diff --git a/include/net/nexthop.h b/include/net/nexthop.h\nindex 3a4f9e3b91a5..08165bebf250 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"
            }
        ]
    },
    "cd95cb722bfa1234ac4c78345c8953ee2e7170d0": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c\nindex e79c767cc5e0..3d1a2cfa6606 100644\n--- a/fs/ext4/extents.c\n+++ b/fs/ext4/extents.c\n@@ -905,6 +905,7 @@ 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+            return ERR_PTR(-EFSCORRUPTED);\n \t\t\tkfree(path);\n \t\t\t*orig_path = path = NULL;\n \t\t}\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c\nindex e79c767cc5e0..ae0b1952a6a2 100644\n--- a/fs/ext4/extents.c\n+++ b/fs/ext4/extents.c\n@@ -656,6 +656,10 @@ int ext4_ext_precache(struct inode *inode)\n out:\n \tup_read(&ei->i_data_sem);\n \text4_free_ext_path(path);\n+if (orig_path) {\n+*orig_path = NULL;\n+}\n+path = NULL;\n \treturn ret;\n }\n \n@@ -961,6 +965,10 @@ ext4_find_extent(struct inode *inode, ext4_lblk_t block,\n \n err:\n \text4_free_ext_path(path);\n+if (orig_path) {\n+*orig_path = NULL;\n+}\n+path = NULL;\n \tif (orig_path)\n \t\t*orig_path = NULL;\n \treturn ERR_PTR(ret);\n@@ -3064,6 +3072,10 @@ int ext4_ext_remove_space(struct inode *inode, ext4_lblk_t start,\n \t}\n out:\n \text4_free_ext_path(path);\n+if (orig_path) {\n+*orig_path = NULL;\n+}\n+path = NULL;\n \tpath = NULL;\n \tif (err == -EAGAIN)\n \t\tgoto again;\n@@ -4377,6 +4389,10 @@ 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+if (orig_path) {\n+*orig_path = NULL;\n+}\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 +5277,10 @@ ext4_ext_shift_extents(struct inode *inode, handle_t *handle,\n \t}\n out:\n \text4_free_ext_path(path);\n+if (orig_path) {\n+*orig_path = NULL;\n+}\n+path = NULL;\n \treturn ret;\n }\n \n@@ -5539,12 +5559,20 @@ 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+if (orig_path) {\n+*orig_path = NULL;\n+}\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+if (orig_path) {\n+*orig_path = NULL;\n+}\n+path = NULL;\n \t}\n \n \tret = ext4_es_remove_extent(inode, offset_lblk,\n@@ -5852,6 +5880,10 @@ int ext4_clu_mapped(struct inode *inode, ext4_lblk_t lclu)\n \n out:\n \text4_free_ext_path(path);\n+if (orig_path) {\n+*orig_path = NULL;\n+}\n+path = NULL;\n \n \treturn err ? err : mapped;\n }\n@@ -5919,6 +5951,10 @@ 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+if (orig_path) {\n+*orig_path = NULL;\n+}\n+path = NULL;\n \text4_mark_inode_dirty(NULL, inode);\n \treturn ret;\n }\n@@ -5937,6 +5973,10 @@ 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+if (orig_path) {\n+*orig_path = NULL;\n+}\n+path = NULL;\n \t\t\text4_mark_inode_dirty(NULL, inode);\n \t\t\treturn;\n \t\t}\n@@ -5950,6 +5990,10 @@ 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+if (orig_path) {\n+*orig_path = NULL;\n+}\n+path = NULL;\n \t}\n }\n \n@@ -5989,10 +6033,18 @@ 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+if (orig_path) {\n+*orig_path = NULL;\n+}\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+if (orig_path) {\n+*orig_path = NULL;\n+}\n+path = NULL;\n \n \t/* Count the number of data blocks */\n \tcur = 0;\n@@ -6023,6 +6075,10 @@ 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+if (orig_path) {\n+*orig_path = NULL;\n+}\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 +6086,10 @@ 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+if (orig_path) {\n+*orig_path = NULL;\n+}\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 +6097,19 @@ 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+if (orig_path) {\n+*orig_path = NULL;\n+}\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+if (orig_path) {\n+*orig_path = NULL;\n+}\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 +6124,10 @@ 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+if (orig_path) {\n+*orig_path = NULL;\n+}\n+path = NULL;\n \t\text4_free_ext_path(path2);\n \t}\n \n@@ -6084,10 +6156,18 @@ 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+if (orig_path) {\n+*orig_path = NULL;\n+}\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+if (orig_path) {\n+*orig_path = NULL;\n+}\n+path = NULL;\n \n \tcur = 0;\n \twhile (cur < end) {\n@@ -6107,6 +6187,10 @@ 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+if (orig_path) {\n+*orig_path = NULL;\n+}\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_message": "Failed to build"
            }
        ]
    },
    "8dba39eccdf108d625bf6acb2bea1aa0c7e1fd61": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netfilter/xt_RATEEST.c b/net/netfilter/xt_RATEEST.c\nindex 37253d399c6b..5a36784a25b3 100644\n--- a/net/netfilter/xt_RATEEST.c\n+++ b/net/netfilter/xt_RATEEST.c\n@@ -77,7 +77,7 @@ void xt_rateest_put(struct net *net, struct xt_rateest *est)\n \tstruct xt_rateest_net *xn = net_generic(net, xt_rateest_id);\n \n \tmutex_lock(&xn->hash_lock);\n-\tif (--est->refcnt == 0) {\n+\tif (est && --est->refcnt == 0) {\n \t\thlist_del(&est->list);\n \t\tgen_kill_estimator(&est->rate_est);\n \t\t/*\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/netfilter/xt_RATEEST.c b/net/netfilter/xt_RATEEST.c\nindex 37253d399c6b..5d30b9b81a78 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)\n+        return;\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..1b887f57e249 100644\n--- a/net/netfilter/xt_RATEEST.c\n+++ b/net/netfilter/xt_RATEEST.c\n@@ -73,6 +73,8 @@ 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 {\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..368edeb7de4f 100644\n--- a/net/netfilter/xt_RATEEST.c\n+++ b/net/netfilter/xt_RATEEST.c\n@@ -72,7 +72,9 @@ struct xt_rateest *xt_rateest_lookup(struct net *net, const char *name)\n }\n EXPORT_SYMBOL_GPL(xt_rateest_lookup);\n \n-void xt_rateest_put(struct net *net, struct xt_rateest *est)\n+void xt_rateest_put(struct net *net, struct xt_rateest *est) {\n+    if (!est)\n+        return;\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..5d30b9b81a78 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)\n+        return;\n {\n \tstruct xt_rateest_net *xn = net_generic(net, xt_rateest_id);\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "ee9018bd8989530a2dbdd62436efd8b1c3ecd3e5": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/bluetooth/rfcomm/sock.c b/net/bluetooth/rfcomm/sock.c\nindex 21e24da4847f..8f04f35861fd 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_lock(d);\n+    lock_sock(sk);\n \n \tif (err)\n \t\tsk->sk_err = err;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/bluetooth/rfcomm/core.c b/net/bluetooth/rfcomm/core.c\nindex 8d6fce9005bd..c4ebb13e6a94 100644\n--- a/net/bluetooth/rfcomm/core.c\n+++ b/net/bluetooth/rfcomm/core.c\n@@ -484,7 +484,9 @@ static int __rfcomm_dlc_close(struct rfcomm_dlc *d, int err)\n \tdefault:\n \t\trfcomm_dlc_clear_timer(d);\n \n-\t\trfcomm_dlc_lock(d);\n+\t\trfcomm_dlc_unlock(d);\n+    d->state_change(d, err);\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@@ -1213,7 +1215,9 @@ static struct rfcomm_session *rfcomm_recv_ua(struct rfcomm_session *s, u8 dlci)\n \t\tcase BT_CONNECT:\n \t\t\trfcomm_dlc_clear_timer(d);\n \n-\t\t\trfcomm_dlc_lock(d);\n+\t\t\trfcomm_dlc_unlock(d);\n+    d->state_change(d, err);\n+    rfcomm_dlc_lock(d);\n \t\t\td->state = BT_CONNECTED;\n \t\t\td->state_change(d, 0);\n \t\t\trfcomm_dlc_unlock(d);\n@@ -1324,7 +1328,9 @@ void rfcomm_dlc_accept(struct rfcomm_dlc *d)\n \n \trfcomm_dlc_clear_timer(d);\n \n-\trfcomm_dlc_lock(d);\n+\trfcomm_dlc_unlock(d);\n+    d->state_change(d, err);\n+    rfcomm_dlc_lock(d);\n \td->state = BT_CONNECTED;\n \td->state_change(d, 0);\n \trfcomm_dlc_unlock(d);\n@@ -1342,7 +1348,9 @@ static void rfcomm_check_accept(struct rfcomm_dlc *d)\n \t\t\tset_bit(RFCOMM_DEFER_SETUP, &d->flags);\n \t\t\trfcomm_dlc_set_timer(d, RFCOMM_AUTH_TIMEOUT);\n \n-\t\t\trfcomm_dlc_lock(d);\n+\t\t\trfcomm_dlc_unlock(d);\n+    d->state_change(d, err);\n+    rfcomm_dlc_lock(d);\n \t\t\td->state = BT_CONNECT2;\n \t\t\td->state_change(d, 0);\n \t\t\trfcomm_dlc_unlock(d);\n@@ -1620,7 +1628,9 @@ static int rfcomm_recv_msc(struct rfcomm_session *s, int cr, struct sk_buff *skb\n \t\telse\n \t\t\tclear_bit(RFCOMM_TX_THROTTLED, &d->flags);\n \n-\t\trfcomm_dlc_lock(d);\n+\t\trfcomm_dlc_unlock(d);\n+    d->state_change(d, err);\n+    rfcomm_dlc_lock(d);\n \n \t\td->remote_v24_sig = msc->v24_sig;\n \n@@ -1719,7 +1729,9 @@ static int rfcomm_recv_data(struct rfcomm_session *s, u8 dlci, int pf, struct sk\n \t}\n \n \tif (skb->len && d->state == BT_CONNECTED) {\n-\t\trfcomm_dlc_lock(d);\n+\t\trfcomm_dlc_unlock(d);\n+    d->state_change(d, err);\n+    rfcomm_dlc_lock(d);\n \t\td->rx_credits--;\n \t\td->data_ready(d, skb);\n \t\trfcomm_dlc_unlock(d);\n@@ -1896,7 +1908,9 @@ static void rfcomm_process_dlcs(struct rfcomm_session *s)\n \t\t\t\t\tset_bit(RFCOMM_DEFER_SETUP, &d->flags);\n \t\t\t\t\trfcomm_dlc_set_timer(d, RFCOMM_AUTH_TIMEOUT);\n \n-\t\t\t\t\trfcomm_dlc_lock(d);\n+\t\t\t\t\trfcomm_dlc_unlock(d);\n+    d->state_change(d, err);\n+    rfcomm_dlc_lock(d);\n \t\t\t\t\td->state = BT_CONNECT2;\n \t\t\t\t\td->state_change(d, 0);\n \t\t\t\t\trfcomm_dlc_unlock(d);\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"
            },
            {
                "patch": "diff --git a/net/bluetooth/rfcomm/sock.c b/net/bluetooth/rfcomm/sock.c\nindex 21e24da4847f..d9297612899b 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_lock();\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_lock();\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_lock();\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_lock();\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_lock();\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_lock();\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_lock();\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_lock();\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_lock();\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_lock();\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_lock();\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_lock();\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_lock();\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_lock();\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"
            }
        ]
    },
    "0be4824a86385f022a4f6f5104bcb9246032fdd9": {
        "non_crash": [
            "diff --git a/sound/core/oss/pcm_plugin.c b/sound/core/oss/pcm_plugin.c\nindex 061ba06bc926..d96fb1e3d3b0 100644\n--- a/sound/core/oss/pcm_plugin.c\n+++ b/sound/core/oss/pcm_plugin.c\n@@ -66,6 +66,9 @@ 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+        if (size > KMALLOC_MAX_SIZE) {\n+            return -ENOMEM;\n+        }\n \tif (plugin->buf_frames < frames) {\n \t\tkvfree(plugin->buf);\n \t\tplugin->buf = kvzalloc(size, GFP_KERNEL);\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/sound/core/oss/pcm_plugin.c b/sound/core/oss/pcm_plugin.c\nindex 061ba06bc926..1ee41f57dec7 100644\n--- a/sound/core/oss/pcm_plugin.c\n+++ b/sound/core/oss/pcm_plugin.c\n@@ -62,7 +62,8 @@ static int snd_pcm_plugin_alloc(struct snd_pcm_plugin *plugin, snd_pcm_uframes_t\n \twidth = snd_pcm_format_physical_width(format->format);\n \tif (width < 0)\n \t\treturn width;\n-\tsize = frames * format->channels * width;\n+\tif (frames > ULONG_MAX / format->channels / width) return -ENOMEM;\n+    size = frames * format->channels * width;\n \tif (snd_BUG_ON(size % 8))\n \t\treturn -ENXIO;\n \tsize /= 8;\n",
            "diff --git a/sound/core/oss/pcm_plugin.c b/sound/core/oss/pcm_plugin.c\nindex 061ba06bc926..2f8ac759b494 100644\n--- a/sound/core/oss/pcm_plugin.c\n+++ b/sound/core/oss/pcm_plugin.c\n@@ -62,7 +62,8 @@ static int snd_pcm_plugin_alloc(struct snd_pcm_plugin *plugin, snd_pcm_uframes_t\n \twidth = snd_pcm_format_physical_width(format->format);\n \tif (width < 0)\n \t\treturn width;\n-\tsize = frames * format->channels * width;\n+\tif (frames <= 0) return -EINVAL;\n+    size = frames * format->channels * width;\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..113afbf19061 100644\n--- a/sound/core/oss/pcm_plugin.c\n+++ b/sound/core/oss/pcm_plugin.c\n@@ -62,7 +62,10 @@ static int snd_pcm_plugin_alloc(struct snd_pcm_plugin *plugin, snd_pcm_uframes_t\n \twidth = snd_pcm_format_physical_width(format->format);\n \tif (width < 0)\n \t\treturn width;\n-\tsize = frames * format->channels * width;\n+\t/* Validate size and frames before allocation */\n+if (frames == 0 || frames > MAX_FRAMES_LIMIT) return -EINVAL;\n+size = frames * format->channels * width;\n+if (size == 0 || size > MAX_SIZE_LIMIT) 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..1b8e87805a85 100644\n--- a/sound/core/oss/pcm_plugin.c\n+++ b/sound/core/oss/pcm_plugin.c\n@@ -88,7 +88,8 @@ static int snd_pcm_plugin_alloc(struct snd_pcm_plugin *plugin, snd_pcm_uframes_t\n \t} else if (plugin->access == SNDRV_PCM_ACCESS_RW_NONINTERLEAVED) {\n \t\tif (snd_BUG_ON(size % format->channels))\n \t\t\treturn -EINVAL;\n-\t\tsize /= format->channels;\n+\t\tif (size > MAX_ALLOWED_SIZE) return -EINVAL;\n+    size /= format->channels;\n \t\tfor (channel = 0; channel < format->channels; channel++, c++) {\n \t\t\tc->frames = frames;\n \t\t\tc->enabled = 1;\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "b0932be9507e30fc4cbd16bf05cd3bea03b325d7": {
        "non_crash": [
            "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": [
            "diff --git a/block/disk-events.c b/block/disk-events.c\nindex 8d5496e7592a..94f8c1da1499 100644\n--- a/block/disk-events.c\n+++ b/block/disk-events.c\n@@ -489,6 +489,7 @@ void disk_del_events(struct gendisk *disk)\n {\n \tif (disk->ev) {\n \t\tdisk_block_events(disk);\n+        disk->ev->block = 1;\n \n \t\tmutex_lock(&disk_events_mutex);\n \t\tlist_del_init(&disk->ev->node);\n"
        ],
        "error": []
    },
    "ad6e459b5804609befe3e5c24001b25185b073fc": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/net/wireguard/netlink.c b/drivers/net/wireguard/netlink.c\nindex 20a4f3c0a0a1..8e3460e4f43b 100644\n--- a/drivers/net/wireguard/netlink.c\n+++ b/drivers/net/wireguard/netlink.c\n@@ -66,7 +66,7 @@ static struct wg_device *lookup_interface(struct nlattr **attrs,\n \t\treturn ERR_PTR(-ENODEV);\n \tif (!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\tif (dev) dev_put(dev);\n \t\treturn ERR_PTR(-EOPNOTSUPP);\n \t}\n \treturn netdev_priv(dev);\n",
            "diff --git a/drivers/net/wireguard/netlink.c b/drivers/net/wireguard/netlink.c\nindex 20a4f3c0a0a1..8e3460e4f43b 100644\n--- a/drivers/net/wireguard/netlink.c\n+++ b/drivers/net/wireguard/netlink.c\n@@ -66,7 +66,7 @@ static struct wg_device *lookup_interface(struct nlattr **attrs,\n \t\treturn ERR_PTR(-ENODEV);\n \tif (!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\tif (dev) dev_put(dev);\n \t\treturn ERR_PTR(-EOPNOTSUPP);\n \t}\n \treturn netdev_priv(dev);\n"
        ],
        "error": []
    },
    "11acaa6d5c31d0b655997957f725da4a3cc05435": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex d1f1da6820fb..2240b5979869 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -1955,7 +1955,8 @@ 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+\tpr_warn(\"BTRFS warning: Aborting transaction due to error %d\\n\", err);\n+    btrfs_abort_transaction(trans, 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..9407b79e6807 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, \"Transaction aborted 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..ca9ba427d4fb 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -1953,7 +1953,11 @@ static void cleanup_transaction(struct btrfs_trans_handle *trans, int err)\n \tstruct btrfs_fs_info *fs_info = trans->fs_info;\n \tstruct btrfs_transaction *cur_trans = trans->transaction;\n \n-\tWARN_ON(refcount_read(&trans->use_count) > 1);\n+\tif (TRANS_ABORTED(cur_trans)) {\n+        pr_warn(\"BTRFS warning (device %s): Skipping commit of aborted transaction.\\n\", fs_info->sb->s_id);\n+    } else {\n+        WARN_ON(refcount_read(&trans->use_count) > 1);\n+    }\n \n \tbtrfs_abort_transaction(trans, err);\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c\nindex d1f1da6820fb..f1c480e80d93 100644\n--- a/fs/btrfs/transaction.c\n+++ b/fs/btrfs/transaction.c\n@@ -260,7 +260,8 @@ static noinline int join_transaction(struct btrfs_fs_info *fs_info,\n \n \tcur_trans = fs_info->running_transaction;\n \tif (cur_trans) {\n-\t\tif (TRANS_ABORTED(cur_trans)) {\n+\t\tif (TRANS_ABORTED(cur_trans)\n+    cleanup_transaction(trans, cur_trans->aborted)) {\n \t\t\tspin_unlock(&fs_info->trans_lock);\n \t\t\treturn cur_trans->aborted;\n \t\t}\n@@ -512,7 +513,8 @@ static void wait_current_trans(struct btrfs_fs_info *fs_info)\n \t\tbtrfs_might_wait_for_state(fs_info, BTRFS_LOCKDEP_TRANS_UNBLOCKED);\n \t\twait_event(fs_info->transaction_wait,\n \t\t\t   cur_trans->state >= TRANS_STATE_UNBLOCKED ||\n-\t\t\t   TRANS_ABORTED(cur_trans));\n+\t\t\t   TRANS_ABORTED(cur_trans)\n+    cleanup_transaction(trans, cur_trans->aborted));\n \t\tbtrfs_put_transaction(cur_trans);\n \t} else {\n \t\tspin_unlock(&fs_info->trans_lock);\n@@ -1944,7 +1946,8 @@ void btrfs_commit_transaction_async(struct btrfs_trans_handle *trans)\n \tbtrfs_might_wait_for_state(fs_info, BTRFS_LOCKDEP_TRANS_COMMIT_START);\n \twait_event(fs_info->transaction_blocked_wait,\n \t\t   cur_trans->state >= TRANS_STATE_COMMIT_START ||\n-\t\t   TRANS_ABORTED(cur_trans));\n+\t\t   TRANS_ABORTED(cur_trans)\n+    cleanup_transaction(trans, cur_trans->aborted));\n \tbtrfs_put_transaction(cur_trans);\n }\n \n@@ -2102,7 +2105,8 @@ int btrfs_commit_transaction(struct btrfs_trans_handle *trans)\n \tbtrfs_trans_state_lockdep_acquire(fs_info, BTRFS_LOCKDEP_TRANS_COMMIT_START);\n \n \t/* Stop the commit early if ->aborted is set */\n-\tif (TRANS_ABORTED(cur_trans)) {\n+\tif (TRANS_ABORTED(cur_trans)\n+    cleanup_transaction(trans, cur_trans->aborted)) {\n \t\tret = cur_trans->aborted;\n \t\tgoto lockdep_trans_commit_start_release;\n \t}\n@@ -2173,7 +2177,8 @@ int btrfs_commit_transaction(struct btrfs_trans_handle *trans)\n \t\tret = btrfs_end_transaction(trans);\n \t\twait_for_commit(cur_trans, want_state);\n \n-\t\tif (TRANS_ABORTED(cur_trans))\n+\t\tif (TRANS_ABORTED(cur_trans)\n+    cleanup_transaction(trans, cur_trans->aborted))\n \t\t\tret = cur_trans->aborted;\n \n \t\tbtrfs_put_transaction(cur_trans);\n@@ -2303,7 +2308,8 @@ int btrfs_commit_transaction(struct btrfs_trans_handle *trans)\n \t */\n \tclear_bit(BTRFS_FS_COMMIT_TRANS, &fs_info->flags);\n \n-\tif (TRANS_ABORTED(cur_trans)) {\n+\tif (TRANS_ABORTED(cur_trans)\n+    cleanup_transaction(trans, cur_trans->aborted)) {\n \t\tret = cur_trans->aborted;\n \t\tbtrfs_trans_state_lockdep_release(fs_info, BTRFS_LOCKDEP_TRANS_UNBLOCKED);\n \t\tgoto scrub_continue;\n@@ -2381,7 +2387,8 @@ int btrfs_commit_transaction(struct btrfs_trans_handle *trans)\n \t * The tasks which save the space cache and inode cache may also\n \t * update ->aborted, check it.\n \t */\n-\tif (TRANS_ABORTED(cur_trans)) {\n+\tif (TRANS_ABORTED(cur_trans)\n+    cleanup_transaction(trans, cur_trans->aborted)) {\n \t\tret = cur_trans->aborted;\n \t\tgoto unlock_reloc;\n \t}\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "a8afc55e6cd0cac79fd97a5c0d2272751dc558fc": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/media/platform/vim2m.c b/drivers/media/platform/vim2m.c\nindex 035c7b7c8d87..5a51d1ee6553 100644\n--- a/drivers/media/platform/vim2m.c\n+++ b/drivers/media/platform/vim2m.c\n@@ -807,7 +807,12 @@ static void vim2m_stop_streaming(struct vb2_queue *q)\n \tunsigned long flags;\n \n \tflush_scheduled_work();\n+    int timeout_counter = 1000; // Define a reasonable timeout threshold\n \tfor (;;) {\n+        if (--timeout_counter == 0) {\n+            pr_err(\"vim2m_stop_streaming: timeout while stopping streaming\\n\");\n+            break;\n+        }\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": [
            {
                "patch": "diff --git a/drivers/media/platform/vim2m.c b/drivers/media/platform/vim2m.c\nindex 035c7b7c8d87..2e822a452c0f 100644\n--- a/drivers/media/platform/vim2m.c\n+++ b/drivers/media/platform/vim2m.c\n@@ -419,7 +419,7 @@ static void device_work(struct work_struct *w)\n \tspin_unlock_irqrestore(&vim2m_dev->irqlock, flags);\n \n \tif (curr_ctx->num_processed == curr_ctx->translen\n-\t    || curr_ctx->aborting) {\n+\t    || curr_ctx->aborting || time_after(jiffies, curr_ctx->start_jiffies + curr_ctx->timeout_jiffies)) {\n \t\tdprintk(curr_ctx->dev, \"Finishing transaction\\n\");\n \t\tcurr_ctx->num_processed = 0;\n \t\tv4l2_m2m_job_finish(vim2m_dev->m2m_dev, curr_ctx->fh.m2m_ctx);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/media/platform/vim2m.c b/drivers/media/platform/vim2m.c\nindex 035c7b7c8d87..6f914e7e1f89 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+\tflush_scheduled_work_timeout(HUNG_TASK_TIMEOUT_SECS);\n \tfor (;;) {\n \t\tif (V4L2_TYPE_IS_OUTPUT(q->type))\n \t\t\tvbuf = v4l2_m2m_src_buf_remove(ctx->fh.m2m_ctx);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/media/platform/vim2m.c b/drivers/media/platform/vim2m.c\nindex 035c7b7c8d87..727b89126ded 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+\tflush_scheduled_work_timeout();\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@@ -1138,5 +1138,13 @@ static int __init vim2m_init(void)\n \treturn ret;\n }\n \n+\n+static void flush_scheduled_work_timeout(void)\n+{\n+    unsigned long timeout = msecs_to_jiffies(5000); // 5-second timeout\n+    if (!flush_work_timeout(&dev->work_run.work, timeout)) {\n+        pr_err(\"Timeout while flushing scheduled work\\n\");\n+    }\n+}\n module_init(vim2m_init);\n module_exit(vim2m_exit);\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..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..1868e9d5739f 100644\n--- a/drivers/usb/core/hcd.c\n+++ b/drivers/usb/core/hcd.c\n@@ -771,7 +771,7 @@ 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\tmemcpy(urb->transfer_buffer, buffer, min(length, sizeof(buffer)));\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..8eaab4108c18 100644\n--- a/drivers/usb/core/hcd.c\n+++ b/drivers/usb/core/hcd.c\n@@ -771,7 +771,13 @@ void usb_hcd_poll_rh_status(struct usb_hcd *hcd)\n \t\t\tclear_bit(HCD_FLAG_POLL_PENDING, &hcd->flags);\n \t\t\thcd->status_urb = NULL;\n \t\t\turb->actual_length = length;\n-\t\t\tmemcpy(urb->transfer_buffer, buffer, length);\n+\t\t\tif (urb->transfer_buffer_length >= length) {\n+                memcpy(urb->transfer_buffer, buffer, length);\n+            }\n+            else {\n+                dev_err(hcd->self.controller, \"transfer buffer too small for status data\\n\");\n+                length = 0;\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..e3006a35ab8c 100644\n--- a/drivers/usb/core/hcd.c\n+++ b/drivers/usb/core/hcd.c\n@@ -771,7 +771,11 @@ 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+                dev_err(hcd->self.controller, \"Buffer overflow detected in usb_hcd_poll_rh_status\\n\");\n+            }\n \n \t\t\tusb_hcd_unlink_urb_from_ep(hcd, urb);\n \t\t\tusb_hcd_giveback_urb(hcd, urb, 0);\n"
        ],
        "error": []
    },
    "1665a0a4a1d6d4d3f61624353f8a9e5dbfff67bd": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/l2tp/l2tp_core.c b/net/l2tp/l2tp_core.c\nindex 754fdda8a5f5..5133be0ccf11 100644\n--- a/net/l2tp/l2tp_core.c\n+++ b/net/l2tp/l2tp_core.c\n@@ -1474,7 +1474,7 @@ int l2tp_tunnel_register(struct l2tp_tunnel *tunnel, struct net *net,\n \t}\n \n \tsk = sock->sk;\n-\twrite_lock(&sk->sk_callback_lock);\n+\twrite_lock_bh(&sk->sk_callback_lock);\n \n \tret = l2tp_validate_socket(sk, net, tunnel->encap);\n \tif (ret < 0)\n",
            "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..a28598ebad46 100644\n--- a/net/l2tp/l2tp_core.c\n+++ b/net/l2tp/l2tp_core.c\n@@ -1475,6 +1475,7 @@ int l2tp_tunnel_register(struct l2tp_tunnel *tunnel, struct net *net,\n \n \tsk = sock->sk;\n \twrite_lock(&sk->sk_callback_lock);\n+write_unlock(&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..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..af1ec86aa2e6 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+\tlocal_irq_disable();\n+    write_lock(&sk->sk_callback_lock);\n \n \tret = l2tp_validate_socket(sk, net, tunnel->encap);\n \tif (ret < 0)\n"
        ],
        "error": []
    },
    "874c5bfa1234dcef000574388df68a8d08274ecd": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/hfsplus/bnode.c b/fs/hfsplus/bnode.c\nindex 87974d5e6791..5a95b81d1ce3 100644\n--- a/fs/hfsplus/bnode.c\n+++ b/fs/hfsplus/bnode.c\n@@ -630,7 +630,7 @@ void hfs_bnode_put(struct hfs_bnode *node)\n \t\t\tif (hfs_bnode_need_zeroout(tree))\n \t\t\t\thfs_bnode_clear(node, 0, tree->node_size);\n \t\t\thfs_bmap_free(node);\n-\t\t\thfs_bnode_free(node);\n+\t\t\thfs_bnode_put(node);\n \t\t\treturn;\n \t\t}\n \t\tspin_unlock(&tree->hash_lock);\n",
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..96719488e478 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -98,7 +98,7 @@ static bool hfsplus_release_folio(struct folio *folio, gfp_t mask)\n \t\t\t;\n \t\telse if (atomic_read(&node->refcnt))\n \t\t\tres = false;\n-\t\tif (res && node) {\n+\t\tif (node && res && atomic_read(&node->refcnt) == 0) {\n \t\t\thfs_bnode_unhash(node);\n \t\t\thfs_bnode_free(node);\n \t\t}\n",
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..5a88917e48cf 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -101,6 +101,8 @@ static bool hfsplus_release_folio(struct folio *folio, gfp_t mask)\n \t\tif (res && node) {\n \t\t\thfs_bnode_unhash(node);\n \t\t\thfs_bnode_free(node);\n+printk(KERN_INFO \"Node freed: %p\\n\", node);\n+BUG_ON(atomic_read(&node->refcnt));\n \t\t}\n \t\tspin_unlock(&tree->hash_lock);\n \t} else {\n@@ -118,6 +120,8 @@ 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+printk(KERN_INFO \"Node freed: %p\\n\", node);\n+BUG_ON(atomic_read(&node->refcnt));\n \t\t} while (--i && nidx < tree->node_count);\n \t\tspin_unlock(&tree->hash_lock);\n \t}\n"
        ],
        "error": []
    },
    "032c91d1b0189a2a36f47141f9c3331f8c09d7b1": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 816052089b33..2f5f18822155 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 (!rcu_access_pointer(chain->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 (!rcu_access_pointer(chain->stats))\n \t\tstatic_branch_inc(&nft_counters_enabled);\n }\n \n",
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 816052089b33..425af4e496c8 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -2329,6 +2329,8 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n \tnf_tables_unregister_hook(net, table, chain);\n err_destroy_chain:\n \tnf_tables_chain_destroy(ctx);\n+    if (stats)\n+        static_branch_dec(&nft_counters_enabled);\n \n \treturn err;\n }\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 816052089b33..70ddc36f43e9 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -1877,7 +1877,8 @@ void nf_tables_chain_destroy(struct nft_ctx *ctx)\n \t\t}\n \t\tmodule_put(basechain->type->owner);\n \t\tif (rcu_access_pointer(basechain->stats)) {\n-\t\t\tstatic_branch_dec(&nft_counters_enabled);\n+\t\t\tif (static_key_count(&nft_counters_enabled) > 0)\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",
                "error_message": "Failed to build"
            }
        ]
    },
    "b139c306850a825c7656508c3773dbea33eb56a1": {
        "non_crash": [
            "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..9bd77fd98713 100644\n--- a/fs/xfs/xfs_dquot.c\n+++ b/fs/xfs/xfs_dquot.c\n@@ -798,7 +798,9 @@ xfs_qm_dqget_cache_insert(\n \terror = radix_tree_insert(tree, id, dqp);\n \tif (unlikely(error)) {\n \t\t/* Duplicate found!  Caller must try again. */\n-\t\tWARN_ON(error != -EEXIST);\n+\t\tif (error != -EEXIST) {\n+            printk(KERN_WARNING \"Unexpected error in xfs_qm_dqget_cache_insert: %d\\n\", 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"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/xfs/xfs_dquot.c b/fs/xfs/xfs_dquot.c\nindex 8fb90da89787..6fa4f094bdc5 100644\n--- a/fs/xfs/xfs_dquot.c\n+++ b/fs/xfs/xfs_dquot.c\n@@ -796,6 +796,9 @@ xfs_qm_dqget_cache_insert(\n \n \tmutex_lock(&qi->qi_tree_lock);\n \terror = radix_tree_insert(tree, id, dqp);\n+if (error && error != -EEXIST) {\n+pr_err(\"radix_tree_insert failed with error %d for id %u\\n\", error, id);\n+}\n \tif (unlikely(error)) {\n \t\t/* Duplicate found!  Caller must try again. */\n \t\tWARN_ON(error != -EEXIST);\n"
        ],
        "error": []
    },
    "6e185619b66eae1ef09684c5f6e283d6cfb5ba84": {
        "non_crash": [
            "diff --git a/fs/btrfs/file.c b/fs/btrfs/file.c\nindex 448b143a5cb2..503e884923df 100644\n--- a/fs/btrfs/file.c\n+++ b/fs/btrfs/file.c\n@@ -467,7 +467,12 @@ 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 == -ENOMEM) {\n+    printk(KERN_ERR \"btrfs_drop_extents: Out of memory error while freeing extent\\n\");\n+    btrfs_abort_transaction(trans, ret);\n+    return ret;\n+}\n+\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..fde5c4441681 100644\n--- a/fs/btrfs/file.c\n+++ b/fs/btrfs/file.c\n@@ -380,7 +380,10 @@ int btrfs_drop_extents(struct btrfs_trans_handle *trans,\n \t\t\t\t\t\targs->start - extent_offset,\n \t\t\t\t\t\t0, false);\n \t\t\t\tret = btrfs_inc_extent_ref(trans, &ref);\n-\t\t\t\tBUG_ON(ret); /* -ENOMEM */\n+\t\t\t\tif (ret) {\n+    btrfs_abort_transaction(trans, ret);\n+    break;\n+}\n \t\t\t}\n \t\t\tkey.offset = args->start;\n \t\t}\n@@ -467,7 +470,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+}\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..401b043e61bf 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_err(fs_info, \"Failed to free extent\");\n+    goto out;\n+} /* -ENOMEM */\n \t\t\t\targs->bytes_found += extent_end - key.offset;\n \t\t\t}\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/btrfs/file.c b/fs/btrfs/file.c\nindex 448b143a5cb2..48f902fc5493 100644\n--- a/fs/btrfs/file.c\n+++ b/fs/btrfs/file.c\n@@ -262,7 +262,13 @@ int btrfs_drop_extents(struct btrfs_trans_handle *trans,\n next_slot:\n \t\tleaf = path->nodes[0];\n \t\tif (path->slots[0] >= btrfs_header_nritems(leaf)) {\n-\t\t\tBUG_ON(del_nr > 0);\n+\t\t\tif (del_nr > 0) {\n+                ret = btrfs_del_items(trans, root, path, del_slot, del_nr);\n+                if (ret)\n+                    btrfs_abort_transaction(trans, ret);\n+                del_nr = 0;\n+            }\n+            BUG_ON(del_nr > 0);\n \t\t\tret = btrfs_next_leaf(root, path);\n \t\t\tif (ret < 0)\n \t\t\t\tbreak;\n@@ -338,7 +344,13 @@ int btrfs_drop_extents(struct btrfs_trans_handle *trans,\n \t\t *  | -------- extent -------- |\n \t\t */\n \t\tif (args->start > key.offset && args->end < extent_end) {\n-\t\t\tBUG_ON(del_nr > 0);\n+\t\t\tif (del_nr > 0) {\n+                ret = btrfs_del_items(trans, root, path, del_slot, del_nr);\n+                if (ret)\n+                    btrfs_abort_transaction(trans, ret);\n+                del_nr = 0;\n+            }\n+            BUG_ON(del_nr > 0);\n \t\t\tif (extent_type == BTRFS_FILE_EXTENT_INLINE) {\n \t\t\t\tret = -EOPNOTSUPP;\n \t\t\t\tbreak;\n@@ -420,7 +432,13 @@ int btrfs_drop_extents(struct btrfs_trans_handle *trans,\n \t\t *  | -------- extent -------- |\n \t\t */\n \t\tif (args->start > key.offset && args->end >= extent_end) {\n-\t\t\tBUG_ON(del_nr > 0);\n+\t\t\tif (del_nr > 0) {\n+                ret = btrfs_del_items(trans, root, path, del_slot, del_nr);\n+                if (ret)\n+                    btrfs_abort_transaction(trans, ret);\n+                del_nr = 0;\n+            }\n+            BUG_ON(del_nr > 0);\n \t\t\tif (extent_type == BTRFS_FILE_EXTENT_INLINE) {\n \t\t\t\tret = -EOPNOTSUPP;\n \t\t\t\tbreak;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c\nindex 892d78c1853c..fd0fb6323cc3 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_warn(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_warn(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_warn(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_warn(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_warn(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"
            }
        ]
    },
    "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..82617006e50a 100644\n--- a/drivers/misc/vmw_vmci/vmci_queue_pair.c\n+++ b/drivers/misc/vmw_vmci/vmci_queue_pair.c\n@@ -629,7 +629,7 @@ static void qp_release_pages(struct page **pages,\n \tint i;\n \n \tfor (i = 0; i < num_pages; i++) {\n-\t\tif (dirty)\n+\t\tif (pages[i] && dirty)\n \t\t\tset_page_dirty(pages[i]);\n \n \t\tput_page(pages[i]);\n",
            "diff --git a/drivers/misc/vmw_vmci/vmci_queue_pair.c b/drivers/misc/vmw_vmci/vmci_queue_pair.c\nindex 8531ae781195..82617006e50a 100644\n--- a/drivers/misc/vmw_vmci/vmci_queue_pair.c\n+++ b/drivers/misc/vmw_vmci/vmci_queue_pair.c\n@@ -629,7 +629,7 @@ static void qp_release_pages(struct page **pages,\n \tint i;\n \n \tfor (i = 0; i < num_pages; i++) {\n-\t\tif (dirty)\n+\t\tif (pages[i] && dirty)\n \t\t\tset_page_dirty(pages[i]);\n \n \t\tput_page(pages[i]);\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": []
    },
    "1f07634f79ac1436ec38e2e71d73392404b17bbb": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/quota/quota.c b/fs/quota/quota.c\nindex 052f143e2e0e..8b6776fc0fdf 100644\n--- a/fs/quota/quota.c\n+++ b/fs/quota/quota.c\n@@ -987,7 +987,13 @@ SYSCALL_DEFINE4(quotactl_fd, unsigned int, fd, unsigned int, cmd,\n \t\tgoto out;\n \n \tif (quotactl_cmd_write(cmds)) {\n-\t\tret = mnt_want_write(f.file->f_path.mnt);\n+\t\tif (quotactl_cmd_onoff(cmds)) {\n+        down_write(&sb->s_umount);\n+    } else {\n+        down_read(&sb->s_umount);\n+    }\n+\n+    ret = mnt_want_write(f.file->f_path.mnt);\n \t\tif (ret)\n \t\t\tgoto out;\n \t}\n",
            "diff --git a/fs/quota/quota.c b/fs/quota/quota.c\nindex 052f143e2e0e..f0ae767eca19 100644\n--- a/fs/quota/quota.c\n+++ b/fs/quota/quota.c\n@@ -994,7 +994,7 @@ 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\tdown_read(&sb->s_umount);\n \telse\n \t\tdown_read(&sb->s_umount);\n \n",
            "diff --git a/fs/quota/quota.c b/fs/quota/quota.c\nindex 052f143e2e0e..23ea45fc84ea 100644\n--- a/fs/quota/quota.c\n+++ b/fs/quota/quota.c\n@@ -996,7 +996,10 @@ SYSCALL_DEFINE4(quotactl_fd, unsigned int, fd, unsigned int, cmd,\n \tif (quotactl_cmd_onoff(cmds))\n \t\tdown_write(&sb->s_umount);\n \telse\n-\t\tdown_read(&sb->s_umount);\n+\t\tret = mnt_want_write(f.file->f_path.mnt);\n+    if (ret)\n+        goto out;\n+    down_read(&sb->s_umount);\n \n \tret = do_quotactl(sb, type, cmds, id, addr, ERR_PTR(-EINVAL));\n \n"
        ],
        "error": []
    },
    "38efa4618c3379cf98642b9379d6e340b14d2702": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 91de361ea9ab..6d9499d0a908 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 || !kiocb->ki_filp->f_op) 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..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..65c3847a3302 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -2773,7 +2773,11 @@ static int io_do_iopoll(struct io_ring_ctx *ctx, bool force_nonspin)\n \t\tif (READ_ONCE(req->iopoll_completed))\n \t\t\tbreak;\n \n-\t\tret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\n+\t\tif (kiocb->ki_filp && kiocb->ki_filp->f_op && kiocb->ki_filp->f_op->iopoll) {\n+            ret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\n+        } else {\n+            return -EINVAL; // Return an error if pointers are NULL\n+        }\n \t\tif (unlikely(ret < 0))\n \t\t\treturn ret;\n \t\telse if (ret)\n"
        ],
        "error": []
    },
    "74c4de068e77c137156235cc06a904c9baea491f": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex 1310d2d5feb3..2b68f7820446 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1023,7 +1023,9 @@ 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) {\n+        get_bh(*pbh);\n+    }\n \tspin_unlock(&nilfs->ns_inode_lock);\n \treturn 0;\n }\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex 1310d2d5feb3..015c251a92de 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1001,6 +1001,12 @@ 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 nilfs_inode_info *ii = NILFS_I(inode);\n+    \n+    if (!ii->i_bh) {\n+        return -EINVAL; /* Invalid state, buffer head should not be NULL */\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"
            },
            {
                "patch": "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex 1310d2d5feb3..5b506ae59857 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1001,6 +1001,34 @@ 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+            get_bh(*pbh); // Ensure buffer head reference is increased\n+        } else {\n+            brelse(*pbh);\n+            *pbh = ii->i_bh;\n+        }\n+    } else {\n+        *pbh = ii->i_bh;\n+        get_bh(*pbh); // Ensure buffer head reference is increased\n+    }\n+\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"
            },
            {
                "patch": "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex 1310d2d5feb3..0b4605f18024 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1001,6 +1001,35 @@ 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+        if (!ii->i_bh) { return -EIO; }  // Check for use-after-free\n+        *pbh = ii->i_bh;\n+    }\n+\n+    get_bh(*pbh);\n+    spin_unlock(&nilfs->ns_inode_lock);\n+    return 0;\n+}\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"
            },
            {
                "patch": "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex 1310d2d5feb3..821fcb39e087 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1001,6 +1001,34 @@ 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 && *pbh)  // Ensure *pbh is valid before assigning\n+            ii->i_bh = *pbh;\n+        else if (ii->i_bh) {  // Check if ii->i_bh is still valid\n+            brelse(*pbh);\n+            *pbh = ii->i_bh;\n+        }\n+    } else\n+        *pbh = ii->i_bh;\n+\n+    if (*pbh) {  // Ensure *pbh is valid before getting buffer\n+        get_bh(*pbh);\n+    }\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"
            }
        ]
    },
    "d8e8c32d387c7b35680b035aab36efdefe253ab7": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/btrfs/block-group.c b/fs/btrfs/block-group.c\nindex 0cb1dee965a0..876df308a321 100644\n--- a/fs/btrfs/block-group.c\n+++ b/fs/btrfs/block-group.c\n@@ -4029,7 +4029,7 @@ int btrfs_chunk_alloc(struct btrfs_trans_handle *trans, u64 flags,\n \t\tif (force < space_info->force_alloc)\n \t\t\tforce = space_info->force_alloc;\n \t\tshould_alloc = should_alloc_chunk(fs_info, space_info, force);\n-\t\tif (space_info->full) {\n+\t\tif (space_info->full && !wait_for_alloc) {\n \t\t\t/* No more free physical space */\n \t\t\tif (should_alloc)\n \t\t\t\tret = -ENOSPC;\n",
            "diff --git a/fs/btrfs/block-group.c b/fs/btrfs/block-group.c\nindex 0cb1dee965a0..cecb4bed47f4 100644\n--- a/fs/btrfs/block-group.c\n+++ b/fs/btrfs/block-group.c\n@@ -3835,7 +3835,9 @@ 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+\t/* Enhance verification logic for space availability */\n+if (ret == -ENOSPC) {\n+btrfs_info(trans->fs_info, \"ENOSPC encountered, attempting to allocate system chunk\");\n \t\tconst u64 sys_flags = btrfs_system_alloc_profile(trans->fs_info);\n \t\tstruct btrfs_block_group *sys_bg;\n \n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/btrfs/block-group.c b/fs/btrfs/block-group.c\nindex 0cb1dee965a0..8ff02231c98e 100644\n--- a/fs/btrfs/block-group.c\n+++ b/fs/btrfs/block-group.c\n@@ -2897,7 +2897,7 @@ 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 && space_info->force_alloc != CHUNK_ALLOC_FORCE)\n \t\t\t\tret = 0;\n \t\t\tif (ret < 0)\n \t\t\t\tgoto out;\n@@ -3185,7 +3185,7 @@ 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 && space_info->force_alloc != CHUNK_ALLOC_FORCE)\n \t\tset_bit(BTRFS_TRANS_CACHE_ENOSPC, &trans->transaction->flags);\n \n out_put:\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->force_alloc != CHUNK_ALLOC_FORCE) {\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 +4102,7 @@ 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 && space_info->force_alloc != CHUNK_ALLOC_FORCE)\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..d1ec77f17840 100644\n--- a/fs/btrfs/block-group.c\n+++ b/fs/btrfs/block-group.c\n@@ -1348,7 +1348,8 @@ static int inc_block_group_ro(struct btrfs_block_group *cache, int force)\n {\n \tstruct btrfs_space_info *sinfo = cache->space_info;\n \tu64 num_bytes;\n-\tint ret = -ENOSPC;\n+\tint pr_warn(\"BTRFS: Transaction aborted due to ENOSPC. Space full: %d, should alloc: %d\\n\", space_info->full, should_alloc);\n+ret = -ENOSPC;\n \n \tspin_lock(&sinfo->lock);\n \tspin_lock(&cache->lock);\n@@ -3150,7 +3151,8 @@ static int cache_save_setup(struct btrfs_block_group *block_group,\n \t * skip doing the setup, we've already cleared the cache so we're safe.\n \t */\n \tif (test_bit(BTRFS_TRANS_CACHE_ENOSPC, &trans->transaction->flags)) {\n-\t\tret = -ENOSPC;\n+\t\tpr_warn(\"BTRFS: Transaction aborted due to ENOSPC. Space full: %d, should alloc: %d\\n\", space_info->full, should_alloc);\n+ret = -ENOSPC;\n \t\tgoto out_put;\n \t}\n \n@@ -4032,7 +4034,8 @@ int btrfs_chunk_alloc(struct btrfs_trans_handle *trans, u64 flags,\n \t\tif (space_info->full) {\n \t\t\t/* No more free physical space */\n \t\t\tif (should_alloc)\n-\t\t\t\tret = -ENOSPC;\n+\t\t\t\tpr_warn(\"BTRFS: Transaction aborted due to ENOSPC. Space full: %d, should alloc: %d\\n\", space_info->full, should_alloc);\n+ret = -ENOSPC;\n \t\t\telse\n \t\t\t\tret = 0;\n \t\t\tspin_unlock(&space_info->lock);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/btrfs/block-group.c b/fs/btrfs/block-group.c\nindex 0cb1dee965a0..671fbb367453 100644\n--- a/fs/btrfs/block-group.c\n+++ b/fs/btrfs/block-group.c\n@@ -1349,6 +1349,7 @@ static int inc_block_group_ro(struct btrfs_block_group *cache, int force)\n \tstruct btrfs_space_info *sinfo = cache->space_info;\n \tu64 num_bytes;\n \tint ret = -ENOSPC;\n+btrfs_debug(fs_info, \"Chunk allocation failed: no space left (should_alloc=%d, full=%d)\\n\", should_alloc, space_info->full);\n \n \tspin_lock(&sinfo->lock);\n \tspin_lock(&cache->lock);\n@@ -3151,6 +3152,7 @@ static int cache_save_setup(struct btrfs_block_group *block_group,\n \t */\n \tif (test_bit(BTRFS_TRANS_CACHE_ENOSPC, &trans->transaction->flags)) {\n \t\tret = -ENOSPC;\n+btrfs_debug(fs_info, \"Chunk allocation failed: no space left (should_alloc=%d, full=%d)\\n\", should_alloc, space_info->full);\n \t\tgoto out_put;\n \t}\n \n@@ -4033,6 +4035,7 @@ int btrfs_chunk_alloc(struct btrfs_trans_handle *trans, u64 flags,\n \t\t\t/* No more free physical space */\n \t\t\tif (should_alloc)\n \t\t\t\tret = -ENOSPC;\n+btrfs_debug(fs_info, \"Chunk allocation failed: no space left (should_alloc=%d, full=%d)\\n\", should_alloc, space_info->full);\n \t\t\telse\n \t\t\t\tret = 0;\n \t\t\tspin_unlock(&space_info->lock);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "1fbd9fd0ef463a9811d2c5b7d206f119cf259601": {
        "non_crash": [
            "diff --git a/net/smc/smc_sysctl.c b/net/smc/smc_sysctl.c\nindex bae19419e755..783b1104dd1d 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->ctl_table);\n }\n",
            "diff --git a/net/smc/smc_sysctl.c b/net/smc/smc_sysctl.c\nindex bae19419e755..783b1104dd1d 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->ctl_table);\n }\n"
        ],
        "special_crash": [],
        "crash": [
            "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",
            "diff --git a/net/smc/smc_sysctl.c b/net/smc/smc_sysctl.c\nindex bae19419e755..d1eb2f7344bd 100644\n--- a/net/smc/smc_sysctl.c\n+++ b/net/smc/smc_sysctl.c\n@@ -47,6 +47,8 @@ int __net_init smc_sysctl_net_init(struct net *net)\n \tnet->smc.smc_hdr = register_net_sysctl(net, \"net/smc\", table);\n \tif (!net->smc.smc_hdr)\n \t\tgoto err_reg;\n+if (!net_eq(net, &init_net))\n+kfree(table);\n \n \tnet->smc.sysctl_autocorking_size = SMC_AUTOCORKING_DEFAULT_SIZE;\n \n"
        ],
        "error": []
    },
    "75b0feac9a3f9e361fd60605e261f8a4ffef1c40": {
        "non_crash": [
            "diff --git a/mm/truncate.c b/mm/truncate.c\nindex ab50d0d59a2a..9d16d94e6934 100644\n--- a/mm/truncate.c\n+++ b/mm/truncate.c\n@@ -223,7 +223,9 @@ bool truncate_inode_partial_folio(struct folio *folio, loff_t start, loff_t end)\n \telse\n \t\tlength = end + 1 - pos - offset;\n \n-\tfolio_wait_writeback(folio);\n+\tif (!folio_trylock(folio))\n+        return false;\n+    folio_wait_writeback(folio);\n \tif (length == folio_size(folio)) {\n \t\ttruncate_inode_folio(folio->mapping, folio);\n \t\treturn true;\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/truncate.c b/mm/truncate.c\nindex ab50d0d59a2a..c93bf7b574ef 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_test_uptodate(folio)) {\n+        folio_zero_range(folio, offset, length);\n+    } else {\n+        // Handle error or fallback\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..fe02f0204889 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+    length = folio_size(folio) - offset;\n+folio_zero_range(folio, offset, length);\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..007dc01392e3 100644\n--- a/mm/truncate.c\n+++ b/mm/truncate.c\n@@ -234,7 +234,8 @@ 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)\n+    folio_zero_range(folio, offset, length);\n \n \tif (folio_has_private(folio))\n \t\tfolio_invalidate(folio, offset, length);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/include/linux/highmem.h b/include/linux/highmem.h\nindex 56d6a0196534..99dc70dde033 100644\n--- a/include/linux/highmem.h\n+++ b/include/linux/highmem.h\n@@ -417,12 +417,22 @@ static inline void folio_zero_segment(struct folio *folio,\n }\n \n /**\n- * folio_zero_range() - Zero a byte range in a folio.\n+ * folio_zero_range\n+{\n+    if (!PageUptodate(&folio->page) || PageDirty(&folio->page)) {\n+        return;\n+    }\n+() - Zero a byte range in a folio.\n  * @folio: The folio to write to.\n  * @start: The first byte to zero.\n  * @length: The number of bytes to zero.\n  */\n-static inline void folio_zero_range(struct folio *folio,\n+static inline void folio_zero_range\n+{\n+    if (!PageUptodate(&folio->page) || PageDirty(&folio->page)) {\n+        return;\n+    }\n+(struct folio *folio,\n \t\tsize_t start, size_t length)\n {\n \tzero_user_segments(&folio->page, start, start + length, 0, 0);\n",
                "error_message": "Failed to build"
            }
        ]
    }
}