{
    "c7c63c2548579c7e4718d2f8bc079a6e152e4ac8": {
        "non_crash": [
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 5fa16990da95..3081c4399f10 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -9636,10 +9636,13 @@ EXPORT_SYMBOL_GPL(__nft_release_basechain);\n \n static void __nft_release_hook(struct net *net, struct nft_table *table)\n {\n+\tstruct nft_flowtable *flowtable;\n \tstruct nft_chain *chain;\n \n \tlist_for_each_entry(chain, &table->chains, list)\n \t\tnf_tables_unregister_hook(net, table, chain);\n+\tlist_for_each_entry(flowtable, &table->flowtables, list)\n+\t\tnft_unregister_flowtable_net_hooks(net, &flowtable->hook_list);\n }\n \n static void __nft_release_hooks(struct net *net)\n"
        ]
    },
    "9e03d0567a2ff908a4bcf8bc378c03be4afdd75d": {
        "non_crash": [
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex d8fef540ca9b..863c15388848 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -422,6 +422,17 @@ static int ext4_xattr_inode_iget(struct inode *parent, unsigned long ea_ino,\n \tstruct inode *inode;\n \tint err;\n \n+\t/*\n+\t * We have to check for this corruption early as otherwise\n+\t * iget_locked() could wait indefinitely for the state of our\n+\t * parent inode.\n+\t */\n+\tif (parent->i_ino == ea_ino) {\n+\t\text4_error(parent->i_sb,\n+\t\t\t   \"Parent and EA inode have the same ino %lu\", ea_ino);\n+\t\treturn -EFSCORRUPTED;\n+\t}\n+\n \tinode = ext4_iget(parent->i_sb, ea_ino, EXT4_IGET_NORMAL);\n \tif (IS_ERR(inode)) {\n \t\terr = PTR_ERR(inode);\n"
        ]
    },
    "bf3e592d3ed61b8f86b8ffba072adcde5485a5f6": {
        "non_crash": [
            "diff --git a/io_uring/rw.c b/io_uring/rw.c\nindex 1ae1e52ab4cb..a25cd44cd415 100644\n--- a/io_uring/rw.c\n+++ b/io_uring/rw.c\n@@ -236,14 +236,6 @@ static void kiocb_end_write(struct io_kiocb *req)\n \n static bool __io_complete_rw_common(struct io_kiocb *req, long res)\n {\n-\tstruct io_rw *rw = io_kiocb_to_cmd(req, struct io_rw);\n-\n-\tif (rw->kiocb.ki_flags & IOCB_WRITE) {\n-\t\tkiocb_end_write(req);\n-\t\tfsnotify_modify(req->file);\n-\t} else {\n-\t\tfsnotify_access(req->file);\n-\t}\n \tif (unlikely(res != req->cqe.res)) {\n \t\tif ((res == -EAGAIN || res == -EOPNOTSUPP) &&\n \t\t    io_rw_should_reissue(req)) {\n@@ -270,6 +262,20 @@ static inline int io_fixup_rw_res(struct io_kiocb *req, long res)\n \treturn res;\n }\n \n+static void io_req_rw_complete(struct io_kiocb *req, bool *locked)\n+{\n+\tstruct io_rw *rw = io_kiocb_to_cmd(req, struct io_rw);\n+\n+\tif (rw->kiocb.ki_flags & IOCB_WRITE) {\n+\t\tkiocb_end_write(req);\n+\t\tfsnotify_modify(req->file);\n+\t} else {\n+\t\tfsnotify_access(req->file);\n+\t}\n+\n+\tio_req_task_complete(req, locked);\n+}\n+\n static void io_complete_rw(struct kiocb *kiocb, long res)\n {\n \tstruct io_rw *rw = container_of(kiocb, struct io_rw, kiocb);\n@@ -278,7 +284,7 @@ static void io_complete_rw(struct kiocb *kiocb, long res)\n \tif (__io_complete_rw_common(req, res))\n \t\treturn;\n \tio_req_set_res(req, io_fixup_rw_res(req, res), 0);\n-\treq->io_task_work.func = io_req_task_complete;\n+\treq->io_task_work.func = io_req_rw_complete;\n \tio_req_task_work_add(req);\n }\n \n"
        ]
    },
    "47ff89a13ed39d393e043ec2715452a5b23ce8b2": {
        "non_crash": [
            "diff --git a/mm/migrate.c b/mm/migrate.c\nindex 98f1c11197a8..f348e0a7b1df 100644\n--- a/mm/migrate.c\n+++ b/mm/migrate.c\n@@ -1112,7 +1112,7 @@ static void migrate_folio_done(struct folio *src,\n /* Obtain the lock on page, remove all ptes. */\n static int migrate_folio_unmap(new_page_t get_new_page, free_page_t put_new_page,\n \t\t\t       unsigned long private, struct folio *src,\n-\t\t\t       struct folio **dstp, int force, bool avoid_force_lock,\n+\t\t\t       struct folio **dstp, int force,\n \t\t\t       enum migrate_mode mode, enum migrate_reason reason,\n \t\t\t       struct list_head *ret)\n {\n@@ -1163,17 +1163,6 @@ static int migrate_folio_unmap(new_page_t get_new_page, free_page_t put_new_page\n \t\tif (current->flags & PF_MEMALLOC)\n \t\t\tgoto out;\n \n-\t\t/*\n-\t\t * We have locked some folios and are going to wait to lock\n-\t\t * this folio.  To avoid a potential deadlock, let's bail\n-\t\t * out and not do that. The locked folios will be moved and\n-\t\t * unlocked, then we can wait to lock this folio.\n-\t\t */\n-\t\tif (avoid_force_lock) {\n-\t\t\trc = -EDEADLOCK;\n-\t\t\tgoto out;\n-\t\t}\n-\n \t\tfolio_lock(src);\n \t}\n \tlocked = true;\n@@ -1253,7 +1242,7 @@ static int migrate_folio_unmap(new_page_t get_new_page, free_page_t put_new_page\n \t\t/* Establish migration ptes */\n \t\tVM_BUG_ON_FOLIO(folio_test_anon(src) &&\n \t\t\t       !folio_test_ksm(src) && !anon_vma, src);\n-\t\ttry_to_migrate(src, TTU_BATCH_FLUSH);\n+\t\ttry_to_migrate(src, mode == MIGRATE_ASYNC ? TTU_BATCH_FLUSH : 0);\n \t\tpage_was_mapped = 1;\n \t}\n \n@@ -1267,7 +1256,7 @@ static int migrate_folio_unmap(new_page_t get_new_page, free_page_t put_new_page\n \t * A folio that has not been unmapped will be restored to\n \t * right list unless we want to retry.\n \t */\n-\tif (rc == -EAGAIN || rc == -EDEADLOCK)\n+\tif (rc == -EAGAIN)\n \t\tret = NULL;\n \n \tmigrate_folio_undo_src(src, page_was_mapped, anon_vma, locked, ret);\n@@ -1618,6 +1607,11 @@ static int migrate_hugetlbs(struct list_head *from, new_page_t get_new_page,\n /*\n  * migrate_pages_batch() first unmaps folios in the from list as many as\n  * possible, then move the unmapped folios.\n+ *\n+ * We only batch migration if mode == MIGRATE_ASYNC to avoid to wait a\n+ * lock or bit when we have locked more than one folio.  Which may cause\n+ * deadlock (e.g., for loop device).  So, if mode != MIGRATE_ASYNC, the\n+ * length of the from list must be <= 1.\n  */\n static int migrate_pages_batch(struct list_head *from, new_page_t get_new_page,\n \t\tfree_page_t put_new_page, unsigned long private,\n@@ -1640,11 +1634,11 @@ static int migrate_pages_batch(struct list_head *from, new_page_t get_new_page,\n \tLIST_HEAD(dst_folios);\n \tbool nosplit = (reason == MR_NUMA_MISPLACED);\n \tbool no_split_folio_counting = false;\n-\tbool avoid_force_lock;\n \n+\tVM_WARN_ON_ONCE(mode != MIGRATE_ASYNC &&\n+\t\t\t!list_empty(from) && !list_is_singular(from));\n retry:\n \trc_saved = 0;\n-\tavoid_force_lock = false;\n \tretry = 1;\n \tfor (pass = 0;\n \t     pass < NR_MAX_MIGRATE_PAGES_RETRY && (retry || large_retry);\n@@ -1689,15 +1683,14 @@ static int migrate_pages_batch(struct list_head *from, new_page_t get_new_page,\n \t\t\t}\n \n \t\t\trc = migrate_folio_unmap(get_new_page, put_new_page, private,\n-\t\t\t\t\t\t folio, &dst, pass > 2, avoid_force_lock,\n-\t\t\t\t\t\t mode, reason, ret_folios);\n+\t\t\t\t\t\t folio, &dst, pass > 2, mode,\n+\t\t\t\t\t\t reason, ret_folios);\n \t\t\t/*\n \t\t\t * The rules are:\n \t\t\t *\tSuccess: folio will be freed\n \t\t\t *\tUnmap: folio will be put on unmap_folios list,\n \t\t\t *\t       dst folio put on dst_folios list\n \t\t\t *\t-EAGAIN: stay on the from list\n-\t\t\t *\t-EDEADLOCK: stay on the from list\n \t\t\t *\t-ENOMEM: stay on the from list\n \t\t\t *\tOther errno: put on ret_folios list\n \t\t\t */\n@@ -1749,14 +1742,6 @@ static int migrate_pages_batch(struct list_head *from, new_page_t get_new_page,\n \t\t\t\t\tgoto out;\n \t\t\t\telse\n \t\t\t\t\tgoto move;\n-\t\t\tcase -EDEADLOCK:\n-\t\t\t\t/*\n-\t\t\t\t * The folio cannot be locked for potential deadlock.\n-\t\t\t\t * Go move (and unlock) all locked folios.  Then we can\n-\t\t\t\t * try again.\n-\t\t\t\t */\n-\t\t\t\trc_saved = rc;\n-\t\t\t\tgoto move;\n \t\t\tcase -EAGAIN:\n \t\t\t\tif (is_large) {\n \t\t\t\t\tlarge_retry++;\n@@ -1771,11 +1756,6 @@ static int migrate_pages_batch(struct list_head *from, new_page_t get_new_page,\n \t\t\t\tstats->nr_thp_succeeded += is_thp;\n \t\t\t\tbreak;\n \t\t\tcase MIGRATEPAGE_UNMAP:\n-\t\t\t\t/*\n-\t\t\t\t * We have locked some folios, don't force lock\n-\t\t\t\t * to avoid deadlock.\n-\t\t\t\t */\n-\t\t\t\tavoid_force_lock = true;\n \t\t\t\tlist_move_tail(&folio->lru, &unmap_folios);\n \t\t\t\tlist_add_tail(&dst->lru, &dst_folios);\n \t\t\t\tbreak;\n@@ -1900,17 +1880,15 @@ static int migrate_pages_batch(struct list_head *from, new_page_t get_new_page,\n \t\t */\n \t\tlist_splice_init(from, ret_folios);\n \t\tlist_splice_init(&split_folios, from);\n+\t\t/*\n+\t\t * Force async mode to avoid to wait lock or bit when we have\n+\t\t * locked more than one folios.\n+\t\t */\n+\t\tmode = MIGRATE_ASYNC;\n \t\tno_split_folio_counting = true;\n \t\tgoto retry;\n \t}\n \n-\t/*\n-\t * We have unlocked all locked folios, so we can force lock now, let's\n-\t * try again.\n-\t */\n-\tif (rc == -EDEADLOCK)\n-\t\tgoto retry;\n-\n \treturn rc;\n }\n \n@@ -1945,7 +1923,7 @@ int migrate_pages(struct list_head *from, new_page_t get_new_page,\n \t\tenum migrate_mode mode, int reason, unsigned int *ret_succeeded)\n {\n \tint rc, rc_gather;\n-\tint nr_pages;\n+\tint nr_pages, batch;\n \tstruct folio *folio, *folio2;\n \tLIST_HEAD(folios);\n \tLIST_HEAD(ret_folios);\n@@ -1959,6 +1937,11 @@ int migrate_pages(struct list_head *from, new_page_t get_new_page,\n \t\t\t\t     mode, reason, &stats, &ret_folios);\n \tif (rc_gather < 0)\n \t\tgoto out;\n+\n+\tif (mode == MIGRATE_ASYNC)\n+\t\tbatch = NR_MAX_BATCHED_MIGRATION;\n+\telse\n+\t\tbatch = 1;\n again:\n \tnr_pages = 0;\n \tlist_for_each_entry_safe(folio, folio2, from, lru) {\n@@ -1969,11 +1952,11 @@ int migrate_pages(struct list_head *from, new_page_t get_new_page,\n \t\t}\n \n \t\tnr_pages += folio_nr_pages(folio);\n-\t\tif (nr_pages > NR_MAX_BATCHED_MIGRATION)\n+\t\tif (nr_pages >= batch)\n \t\t\tbreak;\n \t}\n-\tif (nr_pages > NR_MAX_BATCHED_MIGRATION)\n-\t\tlist_cut_before(&folios, from, &folio->lru);\n+\tif (nr_pages >= batch)\n+\t\tlist_cut_before(&folios, from, &folio2->lru);\n \telse\n \t\tlist_splice_init(from, &folios);\n \trc = migrate_pages_batch(&folios, get_new_page, put_new_page, private,\n"
        ]
    },
    "0987d64a09e1eb9642824a088eb331dbdb2db644": {
        "non_crash": [
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 0194a36d0b36..3dce3166855f 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -12629,10 +12629,12 @@ static int check_map_prog_compatibility(struct bpf_verifier_env *env,\n \t * For programs attached to PERF events this is mandatory as the\n \t * perf NMI can hit any arbitrary code sequence.\n \t *\n-\t * All other trace types using preallocated hash maps are unsafe as\n-\t * well because tracepoint or kprobes can be inside locked regions\n-\t * of the memory allocator or at a place where a recursion into the\n-\t * memory allocator would see inconsistent state.\n+\t * All other trace types using non-preallocated per-cpu hash maps are\n+\t * unsafe as well because tracepoint or kprobes can be inside locked\n+\t * regions of the per-cpu memory allocator or at a place where a\n+\t * recursion into the per-cpu memory allocator would see inconsistent\n+\t * state. Non per-cpu hash maps are using bpf_mem_alloc-tor which is\n+\t * safe to use from kprobe/fentry and in RT.\n \t *\n \t * On RT enabled kernels run-time allocation of all trace type\n \t * programs is strictly prohibited due to lock type constraints. On\n@@ -12642,15 +12644,26 @@ static int check_map_prog_compatibility(struct bpf_verifier_env *env,\n \t */\n \tif (is_tracing_prog_type(prog_type) && !is_preallocated_map(map)) {\n \t\tif (prog_type == BPF_PROG_TYPE_PERF_EVENT) {\n+\t\t\t/* perf_event bpf progs have to use preallocated hash maps\n+\t\t\t * because non-prealloc is still relying on call_rcu to free\n+\t\t\t * elements.\n+\t\t\t */\n \t\t\tverbose(env, \"perf_event programs can only use preallocated hash map\\n\");\n \t\t\treturn -EINVAL;\n \t\t}\n-\t\tif (IS_ENABLED(CONFIG_PREEMPT_RT)) {\n-\t\t\tverbose(env, \"trace type programs can only use preallocated hash map\\n\");\n-\t\t\treturn -EINVAL;\n+\t\tif (map->map_type == BPF_MAP_TYPE_PERCPU_HASH ||\n+\t\t    (map->inner_map_meta &&\n+\t\t     map->inner_map_meta->map_type == BPF_MAP_TYPE_PERCPU_HASH)) {\n+\t\t\tif (IS_ENABLED(CONFIG_PREEMPT_RT)) {\n+\t\t\t\tverbose(env,\n+\t\t\t\t\t\"trace type programs can only use preallocated per-cpu hash map\\n\");\n+\t\t\t\treturn -EINVAL;\n+\t\t\t}\n+\t\t\tWARN_ONCE(1, \"trace type BPF program uses run-time allocation\\n\");\n+\t\t\tverbose(env,\n+\t\t\t\t\"trace type programs with run-time allocated per-cpu hash maps are unsafe.\"\n+\t\t\t\t\" Switch to preallocated hash maps.\\n\");\n \t\t}\n-\t\tWARN_ONCE(1, \"trace type BPF program uses run-time allocation\\n\");\n-\t\tverbose(env, \"trace type programs with run-time allocated hash maps are unsafe. Switch to preallocated hash maps.\\n\");\n \t}\n \n \tif (map_value_has_spin_lock(map)) {\n"
        ]
    },
    "4894a6d412735394296e80976329c1a6848acc14": {
        "non_crash": [
            "diff --git a/fs/file_table.c b/fs/file_table.c\nindex e06c68e2d757..fc7d677ff5ad 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\tput_cred(f->f_cred);\n \t\treturn error;\n \t}\n \n@@ -208,8 +208,10 @@ struct file *alloc_empty_file(int flags, const struct cred *cred)\n \t\treturn ERR_PTR(-ENOMEM);\n \n \terror = init_file(f, flags, cred);\n-\tif (unlikely(error))\n+\tif (unlikely(error)) {\n+\t\tkmem_cache_free(filp_cachep, f);\n \t\treturn ERR_PTR(error);\n+\t}\n \n \tpercpu_counter_inc(&nr_files);\n \n@@ -240,8 +242,10 @@ struct file *alloc_empty_file_noaccount(int flags, const struct cred *cred)\n \t\treturn ERR_PTR(-ENOMEM);\n \n \terror = init_file(f, flags, cred);\n-\tif (unlikely(error))\n+\tif (unlikely(error)) {\n+\t\tkmem_cache_free(filp_cachep, f);\n \t\treturn ERR_PTR(error);\n+\t}\n \n \tf->f_mode |= FMODE_NOACCOUNT;\n \n@@ -265,8 +269,10 @@ struct file *alloc_empty_backing_file(int flags, const struct cred *cred)\n \t\treturn ERR_PTR(-ENOMEM);\n \n \terror = init_file(&ff->file, flags, cred);\n-\tif (unlikely(error))\n+\tif (unlikely(error)) {\n+\t\tkfree(ff);\n \t\treturn ERR_PTR(error);\n+\t}\n \n \tff->file.f_mode |= FMODE_BACKING | FMODE_NOACCOUNT;\n \treturn &ff->file;\n"
        ]
    },
    "19a04b43c75ed1092021010419b5e560a8172c4f": {
        "non_crash": [
            "diff --git a/drivers/hid/hidraw.c b/drivers/hid/hidraw.c\nindex 681614a8302a..197b1e7bf029 100644\n--- a/drivers/hid/hidraw.c\n+++ b/drivers/hid/hidraw.c\n@@ -350,6 +350,8 @@ static int hidraw_release(struct inode * inode, struct file * file)\n \tdown_write(&minors_rwsem);\n \n \tspin_lock_irqsave(&hidraw_table[minor]->list_lock, flags);\n+\tfor (int i = list->tail; i < list->head; i++)\n+\t\tkfree(list->buffer[i].value);\n \tlist_del(&list->node);\n \tspin_unlock_irqrestore(&hidraw_table[minor]->list_lock, flags);\n \tkfree(list);\n"
        ]
    },
    "deb061ff946b02c2f4821f91683d89a68b2f45f8": {
        "non_crash": [
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..b21660475ac1 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -511,7 +511,11 @@ int hfsplus_cat_read_inode(struct inode *inode, struct hfs_find_data *fd)\n \tif (type == HFSPLUS_FOLDER) {\n \t\tstruct hfsplus_cat_folder *folder = &entry.folder;\n \n-\t\tWARN_ON(fd->entrylength < sizeof(struct hfsplus_cat_folder));\n+\t\tif (fd->entrylength < sizeof(struct hfsplus_cat_folder)) {\n+\t\t\tpr_err(\"bad catalog folder entry\\n\");\n+\t\t\tres = -EIO;\n+\t\t\tgoto out;\n+\t\t}\n \t\thfs_bnode_read(fd->bnode, &entry, fd->entryoffset,\n \t\t\t\t\tsizeof(struct hfsplus_cat_folder));\n \t\thfsplus_get_perms(inode, &folder->permissions, 1);\n@@ -531,7 +535,11 @@ int hfsplus_cat_read_inode(struct inode *inode, struct hfs_find_data *fd)\n \t} else if (type == HFSPLUS_FILE) {\n \t\tstruct hfsplus_cat_file *file = &entry.file;\n \n-\t\tWARN_ON(fd->entrylength < sizeof(struct hfsplus_cat_file));\n+\t\tif (fd->entrylength < sizeof(struct hfsplus_cat_file)) {\n+\t\t\tpr_err(\"bad catalog file entry\\n\");\n+\t\t\tres = -EIO;\n+\t\t\tgoto out;\n+\t\t}\n \t\thfs_bnode_read(fd->bnode, &entry, fd->entryoffset,\n \t\t\t\t\tsizeof(struct hfsplus_cat_file));\n \n@@ -562,6 +570,7 @@ int hfsplus_cat_read_inode(struct inode *inode, struct hfs_find_data *fd)\n \t\tpr_err(\"bad catalog entry used to create inode\\n\");\n \t\tres = -EIO;\n \t}\n+out:\n \treturn res;\n }\n \n@@ -570,6 +579,7 @@ int hfsplus_cat_write_inode(struct inode *inode)\n \tstruct inode *main_inode = inode;\n \tstruct hfs_find_data fd;\n \thfsplus_cat_entry entry;\n+\tint res = 0;\n \n \tif (HFSPLUS_IS_RSRC(inode))\n \t\tmain_inode = HFSPLUS_I(inode)->rsrc_inode;\n@@ -588,7 +598,11 @@ int hfsplus_cat_write_inode(struct inode *inode)\n \tif (S_ISDIR(main_inode->i_mode)) {\n \t\tstruct hfsplus_cat_folder *folder = &entry.folder;\n \n-\t\tWARN_ON(fd.entrylength < sizeof(struct hfsplus_cat_folder));\n+\t\tif (fd.entrylength < sizeof(struct hfsplus_cat_folder)) {\n+\t\t\tpr_err(\"bad catalog folder entry\\n\");\n+\t\t\tres = -EIO;\n+\t\t\tgoto out;\n+\t\t}\n \t\thfs_bnode_read(fd.bnode, &entry, fd.entryoffset,\n \t\t\t\t\tsizeof(struct hfsplus_cat_folder));\n \t\t/* simple node checks? */\n@@ -613,7 +627,11 @@ int hfsplus_cat_write_inode(struct inode *inode)\n \t} else {\n \t\tstruct hfsplus_cat_file *file = &entry.file;\n \n-\t\tWARN_ON(fd.entrylength < sizeof(struct hfsplus_cat_file));\n+\t\tif (fd.entrylength < sizeof(struct hfsplus_cat_file)) {\n+\t\t\tpr_err(\"bad catalog file entry\\n\");\n+\t\t\tres = -EIO;\n+\t\t\tgoto out;\n+\t\t}\n \t\thfs_bnode_read(fd.bnode, &entry, fd.entryoffset,\n \t\t\t\t\tsizeof(struct hfsplus_cat_file));\n \t\thfsplus_inode_write_fork(inode, &file->data_fork);\n@@ -634,7 +652,7 @@ int hfsplus_cat_write_inode(struct inode *inode)\n \tset_bit(HFSPLUS_I_CAT_DIRTY, &HFSPLUS_I(inode)->flags);\n out:\n \thfs_find_exit(&fd);\n-\treturn 0;\n+\treturn res;\n }\n \n int hfsplus_fileattr_get(struct dentry *dentry, struct fileattr *fa)\n"
        ]
    },
    "0d0ea881c98701d8dcee7f48b634a84962689fa1": {
        "non_crash": [
            "diff --git a/drivers/net/wireless/virtual/mac80211_hwsim.c b/drivers/net/wireless/virtual/mac80211_hwsim.c\nindex 9a8faaf4c6b6..89c7a1420381 100644\n--- a/drivers/net/wireless/virtual/mac80211_hwsim.c\n+++ b/drivers/net/wireless/virtual/mac80211_hwsim.c\n@@ -5964,10 +5964,11 @@ static int hwsim_new_radio_nl(struct sk_buff *msg, struct genl_info *info)\n \t\t\tret = -ENOMEM;\n \t\t\tgoto out_free;\n \t\t}\n+\t\tparam.pmsr_capa = pmsr_capa;\n+\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\tparam.pmsr_capa = pmsr_capa;\n \t}\n \n \tret = mac80211_hwsim_new_radio(info, &param);\n"
        ]
    },
    "4f4531908efc47fa22cc64aacbb920d7afb4e222": {
        "non_crash": [
            "diff --git a/fs/ext4/namei.c b/fs/ext4/namei.c\nindex a789ea9b61a0..1c5518a4bdf9 100644\n--- a/fs/ext4/namei.c\n+++ b/fs/ext4/namei.c\n@@ -3796,6 +3796,9 @@ static int ext4_rename(struct user_namespace *mnt_userns, struct inode *old_dir,\n \t\treturn -EXDEV;\n \n \tretval = dquot_initialize(old.dir);\n+\tif (retval)\n+\t\treturn retval;\n+\tretval = dquot_initialize(old.inode);\n \tif (retval)\n \t\treturn retval;\n \tretval = dquot_initialize(new.dir);\n"
        ]
    },
    "37f68bc0a80819d1509e1b024c413389ae877175": {
        "non_crash": [
            "diff --git a/fs/xfs/xfs_bmap_util.c b/fs/xfs/xfs_bmap_util.c\nindex f032d3a4b727..fbb675563208 100644\n--- a/fs/xfs/xfs_bmap_util.c\n+++ b/fs/xfs/xfs_bmap_util.c\n@@ -558,7 +558,9 @@ xfs_getbmap(\n \t\tif (!xfs_iext_next_extent(ifp, &icur, &got)) {\n \t\t\txfs_fileoff_t\tend = XFS_B_TO_FSB(mp, XFS_ISIZE(ip));\n \n-\t\t\tout[bmv->bmv_entries - 1].bmv_oflags |= BMV_OF_LAST;\n+\t\t\tif (bmv->bmv_entries > 0)\n+\t\t\t\tout[bmv->bmv_entries - 1].bmv_oflags |=\n+\t\t\t\t\t\t\t\tBMV_OF_LAST;\n \n \t\t\tif (whichfork != XFS_ATTR_FORK && bno < end &&\n \t\t\t    !xfs_getbmap_full(bmv)) {\n"
        ]
    },
    "08bcc3eb4d1892c93490ce2924713568b1fed364": {
        "non_crash": [
            "diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h\nindex c602ff2403b6..c0b7417f1d87 100644\n--- a/fs/f2fs/f2fs.h\n+++ b/fs/f2fs/f2fs.h\n@@ -2122,15 +2122,6 @@ static inline int f2fs_down_read_trylock(struct f2fs_rwsem *sem)\n \treturn down_read_trylock(&sem->internal_rwsem);\n }\n \n-#ifdef CONFIG_DEBUG_LOCK_ALLOC\n-static inline void f2fs_down_read_nested(struct f2fs_rwsem *sem, int subclass)\n-{\n-\tdown_read_nested(&sem->internal_rwsem, subclass);\n-}\n-#else\n-#define f2fs_down_read_nested(sem, subclass) f2fs_down_read(sem)\n-#endif\n-\n static inline void f2fs_up_read(struct f2fs_rwsem *sem)\n {\n \tup_read(&sem->internal_rwsem);\n@@ -2141,6 +2132,21 @@ static inline void f2fs_down_write(struct f2fs_rwsem *sem)\n \tdown_write(&sem->internal_rwsem);\n }\n \n+#ifdef CONFIG_DEBUG_LOCK_ALLOC\n+static inline void f2fs_down_read_nested(struct f2fs_rwsem *sem, int subclass)\n+{\n+\tdown_read_nested(&sem->internal_rwsem, subclass);\n+}\n+\n+static inline void f2fs_down_write_nested(struct f2fs_rwsem *sem, int subclass)\n+{\n+\tdown_write_nested(&sem->internal_rwsem, subclass);\n+}\n+#else\n+#define f2fs_down_read_nested(sem, subclass) f2fs_down_read(sem)\n+#define f2fs_down_write_nested(sem, subclass) f2fs_down_write(sem)\n+#endif\n+\n static inline int f2fs_down_write_trylock(struct f2fs_rwsem *sem)\n {\n \treturn down_write_trylock(&sem->internal_rwsem);\ndiff --git a/fs/f2fs/inline.c b/fs/f2fs/inline.c\nindex 4638fee16a91..0d185ad5e469 100644\n--- a/fs/f2fs/inline.c\n+++ b/fs/f2fs/inline.c\n@@ -641,7 +641,8 @@ int f2fs_add_inline_entry(struct inode *dir, const struct f2fs_filename *fname,\n \t}\n \n \tif (inode) {\n-\t\tf2fs_down_write(&F2FS_I(inode)->i_sem);\n+\t\tf2fs_down_write_nested(&F2FS_I(inode)->i_sem,\n+\t\t\t\t\t\tSINGLE_DEPTH_NESTING);\n \t\tpage = f2fs_init_inode_metadata(inode, dir, fname, ipage);\n \t\tif (IS_ERR(page)) {\n \t\t\terr = PTR_ERR(page);\n"
        ]
    },
    "ca2299cf11b3e3d3d0f44ac479410a14eecbd326": {
        "non_crash": [
            "diff --git a/net/qrtr/qrtr.c b/net/qrtr/qrtr.c\nindex b4c0db0b7d31..90c558f89d46 100644\n--- a/net/qrtr/qrtr.c\n+++ b/net/qrtr/qrtr.c\n@@ -692,23 +692,25 @@ static void qrtr_port_remove(struct qrtr_sock *ipc)\n  */\n static int qrtr_port_assign(struct qrtr_sock *ipc, int *port)\n {\n+\tu32 min_port;\n \tint rc;\n \n \tmutex_lock(&qrtr_port_lock);\n \tif (!*port) {\n-\t\trc = idr_alloc(&qrtr_ports, ipc,\n-\t\t\t       QRTR_MIN_EPH_SOCKET, QRTR_MAX_EPH_SOCKET + 1,\n-\t\t\t       GFP_ATOMIC);\n-\t\tif (rc >= 0)\n-\t\t\t*port = rc;\n+\t\tmin_port = QRTR_MIN_EPH_SOCKET;\n+\t\trc = idr_alloc_u32(&qrtr_ports, ipc, &min_port, QRTR_MAX_EPH_SOCKET, GFP_ATOMIC);\n+\t\tif (!rc)\n+\t\t\t*port = min_port;\n \t} else if (*port < QRTR_MIN_EPH_SOCKET && !capable(CAP_NET_ADMIN)) {\n \t\trc = -EACCES;\n \t} else if (*port == QRTR_PORT_CTRL) {\n-\t\trc = idr_alloc(&qrtr_ports, ipc, 0, 1, GFP_ATOMIC);\n+\t\tmin_port = 0;\n+\t\trc = idr_alloc_u32(&qrtr_ports, ipc, &min_port, 0, GFP_ATOMIC);\n \t} else {\n-\t\trc = idr_alloc(&qrtr_ports, ipc, *port, *port + 1, GFP_ATOMIC);\n-\t\tif (rc >= 0)\n-\t\t\t*port = rc;\n+\t\tmin_port = *port;\n+\t\trc = idr_alloc_u32(&qrtr_ports, ipc, &min_port, *port, GFP_ATOMIC);\n+\t\tif (!rc)\n+\t\t\t*port = min_port;\n \t}\n \tmutex_unlock(&qrtr_port_lock);\n \n"
        ]
    },
    "0b6b2d6d6cefa8b462930e55be699efba635788f": {
        "non_crash": [
            "diff --git a/net/netfilter/nft_chain_filter.c b/net/netfilter/nft_chain_filter.c\nindex 5b02408a920b..3ced0eb6b7c3 100644\n--- a/net/netfilter/nft_chain_filter.c\n+++ b/net/netfilter/nft_chain_filter.c\n@@ -342,12 +342,6 @@ static void nft_netdev_event(unsigned long event, struct net_device *dev,\n \t\treturn;\n \t}\n \n-\t/* UNREGISTER events are also happening on netns exit.\n-\t *\n-\t * Although nf_tables core releases all tables/chains, only this event\n-\t * handler provides guarantee that hook->ops.dev is still accessible,\n-\t * so we cannot skip exiting net namespaces.\n-\t */\n \t__nft_release_basechain(ctx);\n }\n \n@@ -366,6 +360,9 @@ static int nf_tables_netdev_event(struct notifier_block *this,\n \t    event != NETDEV_CHANGENAME)\n \t\treturn NOTIFY_DONE;\n \n+\tif (!check_net(ctx.net))\n+\t\treturn NOTIFY_DONE;\n+\n \tnft_net = nft_pernet(ctx.net);\n \tmutex_lock(&nft_net->commit_mutex);\n \tlist_for_each_entry(table, &nft_net->tables, list) {\n"
        ]
    },
    "76c0afb6e24e6dc4093c36801d0b3a61b486ec4d": {
        "non_crash": [
            "diff --git a/fs/nilfs2/sufile.c b/fs/nilfs2/sufile.c\nindex dc359b56fdfa..2c6078a6b8ec 100644\n--- a/fs/nilfs2/sufile.c\n+++ b/fs/nilfs2/sufile.c\n@@ -779,6 +779,15 @@ int nilfs_sufile_resize(struct inode *sufile, __u64 newnsegs)\n \t\t\tgoto out_header;\n \n \t\tsui->ncleansegs -= nsegs - newnsegs;\n+\n+\t\t/*\n+\t\t * If the sufile is successfully truncated, immediately adjust\n+\t\t * the segment allocation space while locking the semaphore\n+\t\t * \"mi_sem\" so that nilfs_sufile_alloc() never allocates\n+\t\t * segments in the truncated space.\n+\t\t */\n+\t\tsui->allocmax = newnsegs - 1;\n+\t\tsui->allocmin = 0;\n \t}\n \n \tkaddr = kmap_atomic(header_bh->b_page);\n"
        ]
    },
    "6c4345574ac937d9ccc195fdadb44f7cc95a19f9": {
        "non_crash": [
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 2ee50e23c9b7..816052089b33 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -2166,8 +2166,10 @@ static int nft_basechain_init(struct nft_base_chain *basechain, u8 family,\n \tchain->flags |= NFT_CHAIN_BASE | flags;\n \tbasechain->policy = NF_ACCEPT;\n \tif (chain->flags & NFT_CHAIN_HW_OFFLOAD &&\n-\t    !nft_chain_offload_support(basechain))\n+\t    !nft_chain_offload_support(basechain)) {\n+\t\tlist_splice_init(&basechain->hook_list, &hook->list);\n \t\treturn -EOPNOTSUPP;\n+\t}\n \n \tflow_block_init(&basechain->flow_block);\n \n"
        ]
    },
    "f55849742bdcdf58f6eaae61e747ac00e5c061f4": {
        "non_crash": [
            "diff --git a/mm/hugetlb.c b/mm/hugetlb.c\nindex 41d3aa077837..9a910612336d 100644\n--- a/mm/hugetlb.c\n+++ b/mm/hugetlb.c\n@@ -5096,6 +5096,7 @@ static void __unmap_hugepage_range(struct mmu_gather *tlb, struct vm_area_struct\n \t\t * unmapped and its refcount is dropped, so just clear pte here.\n \t\t */\n \t\tif (unlikely(!pte_present(pte))) {\n+#ifdef CONFIG_PTE_MARKER_UFFD_WP\n \t\t\t/*\n \t\t\t * If the pte was wr-protected by uffd-wp in any of the\n \t\t\t * swap forms, meanwhile the caller does not want to\n@@ -5107,6 +5108,7 @@ static void __unmap_hugepage_range(struct mmu_gather *tlb, struct vm_area_struct\n \t\t\t\tset_huge_pte_at(mm, address, ptep,\n \t\t\t\t\t\tmake_pte_marker(PTE_MARKER_UFFD_WP));\n \t\t\telse\n+#endif\n \t\t\t\thuge_pte_clear(mm, address, ptep, sz);\n \t\t\tspin_unlock(ptl);\n \t\t\tcontinue;\n@@ -5135,11 +5137,13 @@ static void __unmap_hugepage_range(struct mmu_gather *tlb, struct vm_area_struct\n \t\ttlb_remove_huge_tlb_entry(h, tlb, ptep, address);\n \t\tif (huge_pte_dirty(pte))\n \t\t\tset_page_dirty(page);\n+#ifdef CONFIG_PTE_MARKER_UFFD_WP\n \t\t/* Leave a uffd-wp pte marker if needed */\n \t\tif (huge_pte_uffd_wp(pte) &&\n \t\t    !(zap_flags & ZAP_FLAG_DROP_MARKER))\n \t\t\tset_huge_pte_at(mm, address, ptep,\n \t\t\t\t\tmake_pte_marker(PTE_MARKER_UFFD_WP));\n+#endif\n \t\thugetlb_count_sub(pages_per_huge_page(h), mm);\n \t\tpage_remove_rmap(page, vma, true);\n \ndiff --git a/mm/memory.c b/mm/memory.c\nindex df678fa30cdb..2c7723ea4371 100644\n--- a/mm/memory.c\n+++ b/mm/memory.c\n@@ -1393,10 +1393,12 @@ zap_install_uffd_wp_if_needed(struct vm_area_struct *vma,\n \t\t\t      unsigned long addr, pte_t *pte,\n \t\t\t      struct zap_details *details, pte_t pteval)\n {\n+#ifdef CONFIG_PTE_MARKER_UFFD_WP\n \tif (zap_drop_file_uffd_wp(details))\n \t\treturn;\n \n \tpte_install_uffd_wp_if_needed(vma, addr, pte, pteval);\n+#endif\n }\n \n static unsigned long zap_pte_range(struct mmu_gather *tlb,\ndiff --git a/mm/mprotect.c b/mm/mprotect.c\nindex 461dcbd4f21a..668bfaa6ed2a 100644\n--- a/mm/mprotect.c\n+++ b/mm/mprotect.c\n@@ -267,6 +267,7 @@ 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+#ifdef CONFIG_PTE_MARKER_UFFD_WP\n \t\t\tif (unlikely(uffd_wp && !vma_is_anonymous(vma))) {\n \t\t\t\t/*\n \t\t\t\t * For file-backed mem, we need to be able to\n@@ -278,6 +279,7 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\t\t   make_pte_marker(PTE_MARKER_UFFD_WP));\n \t\t\t\tpages++;\n \t\t\t}\n+#endif\n \t\t}\n \t} while (pte++, addr += PAGE_SIZE, addr != end);\n \tarch_leave_lazy_mmu_mode();\n"
        ]
    },
    "80b047eb9aff0254f4adc620c6891c0ca3276309": {
        "non_crash": [
            "diff --git a/include/net/genetlink.h b/include/net/genetlink.h\nindex 74950663bb00..ad71ed4f55ff 100644\n--- a/include/net/genetlink.h\n+++ b/include/net/genetlink.h\n@@ -41,7 +41,6 @@ struct genl_info;\n  *\tNote that unbind() will not be called symmetrically if the\n  *\tgeneric netlink family is removed while there are still open\n  *\tsockets.\n- * @attrbuf: buffer to store parsed attributes (private)\n  * @mcgrps: multicast groups used by this family\n  * @n_mcgrps: number of multicast groups\n  * @mcgrp_offset: starting number of multicast group IDs in this family\n@@ -66,7 +65,6 @@ struct genl_family {\n \t\t\t\t\t     struct genl_info *info);\n \tint\t\t\t(*mcast_bind)(struct net *net, int group);\n \tvoid\t\t\t(*mcast_unbind)(struct net *net, int group);\n-\tstruct nlattr **\tattrbuf;\t/* private */\n \tconst struct genl_ops *\tops;\n \tconst struct genl_multicast_group *mcgrps;\n \tunsigned int\t\tn_ops;\ndiff --git a/net/netlink/genetlink.c b/net/netlink/genetlink.c\nindex 55ee680e9db1..a914b9365a46 100644\n--- a/net/netlink/genetlink.c\n+++ b/net/netlink/genetlink.c\n@@ -351,22 +351,11 @@ int genl_register_family(struct genl_family *family)\n \t\tstart = end = GENL_ID_VFS_DQUOT;\n \t}\n \n-\tif (family->maxattr && !family->parallel_ops) {\n-\t\tfamily->attrbuf = kmalloc_array(family->maxattr + 1,\n-\t\t\t\t\t\tsizeof(struct nlattr *),\n-\t\t\t\t\t\tGFP_KERNEL);\n-\t\tif (family->attrbuf == NULL) {\n-\t\t\terr = -ENOMEM;\n-\t\t\tgoto errout_locked;\n-\t\t}\n-\t} else\n-\t\tfamily->attrbuf = NULL;\n-\n \tfamily->id = idr_alloc_cyclic(&genl_fam_idr, family,\n \t\t\t\t      start, end + 1, GFP_KERNEL);\n \tif (family->id < 0) {\n \t\terr = family->id;\n-\t\tgoto errout_free;\n+\t\tgoto errout_locked;\n \t}\n \n \terr = genl_validate_assign_mc_groups(family);\n@@ -385,8 +374,6 @@ int genl_register_family(struct genl_family *family)\n \n errout_remove:\n \tidr_remove(&genl_fam_idr, family->id);\n-errout_free:\n-\tkfree(family->attrbuf);\n errout_locked:\n \tgenl_unlock_all();\n \treturn err;\n@@ -419,8 +406,6 @@ int genl_unregister_family(const struct genl_family *family)\n \t\t   atomic_read(&genl_sk_destructing_cnt) == 0);\n \tgenl_unlock();\n \n-\tkfree(family->attrbuf);\n-\n \tgenl_ctrl_event(CTRL_CMD_DELFAMILY, family, NULL, 0);\n \n \treturn 0;\n@@ -485,30 +470,23 @@ genl_family_rcv_msg_attrs_parse(const struct genl_family *family,\n \tif (!family->maxattr)\n \t\treturn NULL;\n \n-\tif (family->parallel_ops) {\n-\t\tattrbuf = kmalloc_array(family->maxattr + 1,\n-\t\t\t\t\tsizeof(struct nlattr *), GFP_KERNEL);\n-\t\tif (!attrbuf)\n-\t\t\treturn ERR_PTR(-ENOMEM);\n-\t} else {\n-\t\tattrbuf = family->attrbuf;\n-\t}\n+\tattrbuf = kmalloc_array(family->maxattr + 1,\n+\t\t\t\tsizeof(struct nlattr *), GFP_KERNEL);\n+\tif (!attrbuf)\n+\t\treturn ERR_PTR(-ENOMEM);\n \n \terr = __nlmsg_parse(nlh, hdrlen, attrbuf, family->maxattr,\n \t\t\t    family->policy, validate, extack);\n \tif (err) {\n-\t\tif (family->parallel_ops)\n-\t\t\tkfree(attrbuf);\n+\t\tkfree(attrbuf);\n \t\treturn ERR_PTR(err);\n \t}\n \treturn attrbuf;\n }\n \n-static void genl_family_rcv_msg_attrs_free(const struct genl_family *family,\n-\t\t\t\t\t   struct nlattr **attrbuf)\n+static void genl_family_rcv_msg_attrs_free(struct nlattr **attrbuf)\n {\n-\tif (family->parallel_ops)\n-\t\tkfree(attrbuf);\n+\tkfree(attrbuf);\n }\n \n struct genl_start_context {\n@@ -542,7 +520,7 @@ static int genl_start(struct netlink_callback *cb)\n no_attrs:\n \tinfo = genl_dumpit_info_alloc();\n \tif (!info) {\n-\t\tgenl_family_rcv_msg_attrs_free(ctx->family, attrs);\n+\t\tgenl_family_rcv_msg_attrs_free(attrs);\n \t\treturn -ENOMEM;\n \t}\n \tinfo->family = ctx->family;\n@@ -559,7 +537,7 @@ static int genl_start(struct netlink_callback *cb)\n \t}\n \n \tif (rc) {\n-\t\tgenl_family_rcv_msg_attrs_free(info->family, info->attrs);\n+\t\tgenl_family_rcv_msg_attrs_free(info->attrs);\n \t\tgenl_dumpit_info_free(info);\n \t\tcb->data = NULL;\n \t}\n@@ -588,7 +566,7 @@ static int genl_lock_done(struct netlink_callback *cb)\n \t\trc = ops->done(cb);\n \t\tgenl_unlock();\n \t}\n-\tgenl_family_rcv_msg_attrs_free(info->family, info->attrs);\n+\tgenl_family_rcv_msg_attrs_free(info->attrs);\n \tgenl_dumpit_info_free(info);\n \treturn rc;\n }\n@@ -601,7 +579,7 @@ static int genl_parallel_done(struct netlink_callback *cb)\n \n \tif (ops->done)\n \t\trc = ops->done(cb);\n-\tgenl_family_rcv_msg_attrs_free(info->family, info->attrs);\n+\tgenl_family_rcv_msg_attrs_free(info->attrs);\n \tgenl_dumpit_info_free(info);\n \treturn rc;\n }\n@@ -694,7 +672,7 @@ static int genl_family_rcv_msg_doit(const struct genl_family *family,\n \t\tfamily->post_doit(ops, skb, &info);\n \n out:\n-\tgenl_family_rcv_msg_attrs_free(family, attrbuf);\n+\tgenl_family_rcv_msg_attrs_free(attrbuf);\n \n \treturn err;\n }\n"
        ]
    },
    "89740d8d8416726adeba5953543037142b3b20be": {
        "non_crash": [
            "diff --git a/security/keys/keyctl_pkey.c b/security/keys/keyctl_pkey.c\nindex 70e65a2ff207..8bdea5abad11 100644\n--- a/security/keys/keyctl_pkey.c\n+++ b/security/keys/keyctl_pkey.c\n@@ -50,6 +50,8 @@ static int keyctl_pkey_params_parse(struct kernel_pkey_params *params)\n \t\tif (*p == '\\0' || *p == ' ' || *p == '\\t')\n \t\t\tcontinue;\n \t\ttoken = match_token(p, param_keys, args);\n+\t\tif (token == Opt_err)\n+\t\t\treturn -EINVAL;\n \t\tif (__test_and_set_bit(token, &token_mask))\n \t\t\treturn -EINVAL;\n \t\tq = args[0].from;\n"
        ]
    },
    "67d5dc5f84651b05fc3c2cb3d163037f414a10f4": {
        "non_crash": [
            "diff --git a/net/qrtr/tun.c b/net/qrtr/tun.c\nindex 15ce9b642b25..b238c40a9984 100644\n--- a/net/qrtr/tun.c\n+++ b/net/qrtr/tun.c\n@@ -80,6 +80,12 @@ static ssize_t qrtr_tun_write_iter(struct kiocb *iocb, struct iov_iter *from)\n \tssize_t ret;\n \tvoid *kbuf;\n \n+\tif (!len)\n+\t\treturn -EINVAL;\n+\n+\tif (len > KMALLOC_MAX_SIZE)\n+\t\treturn -ENOMEM;\n+\n \tkbuf = kzalloc(len, GFP_KERNEL);\n \tif (!kbuf)\n \t\treturn -ENOMEM;\n"
        ]
    },
    "4f6ce6f5223c2c8e75c92ce8cb619b227a8b0277": {
        "non_crash": [
            "diff --git a/include/net/genetlink.h b/include/net/genetlink.h\nindex 74950663bb00..ad71ed4f55ff 100644\n--- a/include/net/genetlink.h\n+++ b/include/net/genetlink.h\n@@ -41,7 +41,6 @@ struct genl_info;\n  *\tNote that unbind() will not be called symmetrically if the\n  *\tgeneric netlink family is removed while there are still open\n  *\tsockets.\n- * @attrbuf: buffer to store parsed attributes (private)\n  * @mcgrps: multicast groups used by this family\n  * @n_mcgrps: number of multicast groups\n  * @mcgrp_offset: starting number of multicast group IDs in this family\n@@ -66,7 +65,6 @@ struct genl_family {\n \t\t\t\t\t     struct genl_info *info);\n \tint\t\t\t(*mcast_bind)(struct net *net, int group);\n \tvoid\t\t\t(*mcast_unbind)(struct net *net, int group);\n-\tstruct nlattr **\tattrbuf;\t/* private */\n \tconst struct genl_ops *\tops;\n \tconst struct genl_multicast_group *mcgrps;\n \tunsigned int\t\tn_ops;\ndiff --git a/net/netlink/genetlink.c b/net/netlink/genetlink.c\nindex 55ee680e9db1..a914b9365a46 100644\n--- a/net/netlink/genetlink.c\n+++ b/net/netlink/genetlink.c\n@@ -351,22 +351,11 @@ int genl_register_family(struct genl_family *family)\n \t\tstart = end = GENL_ID_VFS_DQUOT;\n \t}\n \n-\tif (family->maxattr && !family->parallel_ops) {\n-\t\tfamily->attrbuf = kmalloc_array(family->maxattr + 1,\n-\t\t\t\t\t\tsizeof(struct nlattr *),\n-\t\t\t\t\t\tGFP_KERNEL);\n-\t\tif (family->attrbuf == NULL) {\n-\t\t\terr = -ENOMEM;\n-\t\t\tgoto errout_locked;\n-\t\t}\n-\t} else\n-\t\tfamily->attrbuf = NULL;\n-\n \tfamily->id = idr_alloc_cyclic(&genl_fam_idr, family,\n \t\t\t\t      start, end + 1, GFP_KERNEL);\n \tif (family->id < 0) {\n \t\terr = family->id;\n-\t\tgoto errout_free;\n+\t\tgoto errout_locked;\n \t}\n \n \terr = genl_validate_assign_mc_groups(family);\n@@ -385,8 +374,6 @@ int genl_register_family(struct genl_family *family)\n \n errout_remove:\n \tidr_remove(&genl_fam_idr, family->id);\n-errout_free:\n-\tkfree(family->attrbuf);\n errout_locked:\n \tgenl_unlock_all();\n \treturn err;\n@@ -419,8 +406,6 @@ int genl_unregister_family(const struct genl_family *family)\n \t\t   atomic_read(&genl_sk_destructing_cnt) == 0);\n \tgenl_unlock();\n \n-\tkfree(family->attrbuf);\n-\n \tgenl_ctrl_event(CTRL_CMD_DELFAMILY, family, NULL, 0);\n \n \treturn 0;\n@@ -485,30 +470,23 @@ genl_family_rcv_msg_attrs_parse(const struct genl_family *family,\n \tif (!family->maxattr)\n \t\treturn NULL;\n \n-\tif (family->parallel_ops) {\n-\t\tattrbuf = kmalloc_array(family->maxattr + 1,\n-\t\t\t\t\tsizeof(struct nlattr *), GFP_KERNEL);\n-\t\tif (!attrbuf)\n-\t\t\treturn ERR_PTR(-ENOMEM);\n-\t} else {\n-\t\tattrbuf = family->attrbuf;\n-\t}\n+\tattrbuf = kmalloc_array(family->maxattr + 1,\n+\t\t\t\tsizeof(struct nlattr *), GFP_KERNEL);\n+\tif (!attrbuf)\n+\t\treturn ERR_PTR(-ENOMEM);\n \n \terr = __nlmsg_parse(nlh, hdrlen, attrbuf, family->maxattr,\n \t\t\t    family->policy, validate, extack);\n \tif (err) {\n-\t\tif (family->parallel_ops)\n-\t\t\tkfree(attrbuf);\n+\t\tkfree(attrbuf);\n \t\treturn ERR_PTR(err);\n \t}\n \treturn attrbuf;\n }\n \n-static void genl_family_rcv_msg_attrs_free(const struct genl_family *family,\n-\t\t\t\t\t   struct nlattr **attrbuf)\n+static void genl_family_rcv_msg_attrs_free(struct nlattr **attrbuf)\n {\n-\tif (family->parallel_ops)\n-\t\tkfree(attrbuf);\n+\tkfree(attrbuf);\n }\n \n struct genl_start_context {\n@@ -542,7 +520,7 @@ static int genl_start(struct netlink_callback *cb)\n no_attrs:\n \tinfo = genl_dumpit_info_alloc();\n \tif (!info) {\n-\t\tgenl_family_rcv_msg_attrs_free(ctx->family, attrs);\n+\t\tgenl_family_rcv_msg_attrs_free(attrs);\n \t\treturn -ENOMEM;\n \t}\n \tinfo->family = ctx->family;\n@@ -559,7 +537,7 @@ static int genl_start(struct netlink_callback *cb)\n \t}\n \n \tif (rc) {\n-\t\tgenl_family_rcv_msg_attrs_free(info->family, info->attrs);\n+\t\tgenl_family_rcv_msg_attrs_free(info->attrs);\n \t\tgenl_dumpit_info_free(info);\n \t\tcb->data = NULL;\n \t}\n@@ -588,7 +566,7 @@ static int genl_lock_done(struct netlink_callback *cb)\n \t\trc = ops->done(cb);\n \t\tgenl_unlock();\n \t}\n-\tgenl_family_rcv_msg_attrs_free(info->family, info->attrs);\n+\tgenl_family_rcv_msg_attrs_free(info->attrs);\n \tgenl_dumpit_info_free(info);\n \treturn rc;\n }\n@@ -601,7 +579,7 @@ static int genl_parallel_done(struct netlink_callback *cb)\n \n \tif (ops->done)\n \t\trc = ops->done(cb);\n-\tgenl_family_rcv_msg_attrs_free(info->family, info->attrs);\n+\tgenl_family_rcv_msg_attrs_free(info->attrs);\n \tgenl_dumpit_info_free(info);\n \treturn rc;\n }\n@@ -694,7 +672,7 @@ static int genl_family_rcv_msg_doit(const struct genl_family *family,\n \t\tfamily->post_doit(ops, skb, &info);\n \n out:\n-\tgenl_family_rcv_msg_attrs_free(family, attrbuf);\n+\tgenl_family_rcv_msg_attrs_free(attrbuf);\n \n \treturn err;\n }\n"
        ]
    },
    "ee9018bd8989530a2dbdd62436efd8b1c3ecd3e5": {
        "non_crash": [
            "diff --git a/net/bluetooth/rfcomm/sock.c b/net/bluetooth/rfcomm/sock.c\nindex 21e24da4847f..4397e14ff560 100644\n--- a/net/bluetooth/rfcomm/sock.c\n+++ b/net/bluetooth/rfcomm/sock.c\n@@ -391,6 +391,7 @@ 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+\tsock_hold(sk);\n \tlock_sock(sk);\n \n \tif (sk->sk_state != BT_OPEN && sk->sk_state != BT_BOUND) {\n@@ -410,14 +411,18 @@ static int rfcomm_sock_connect(struct socket *sock, struct sockaddr *addr, int a\n \td->sec_level = rfcomm_pi(sk)->sec_level;\n \td->role_switch = rfcomm_pi(sk)->role_switch;\n \n+\t/* Drop sock lock to avoid potential deadlock with the RFCOMM lock */\n+\trelease_sock(sk);\n \terr = rfcomm_dlc_open(d, &rfcomm_pi(sk)->src, &sa->rc_bdaddr,\n \t\t\t      sa->rc_channel);\n-\tif (!err)\n+\tlock_sock(sk);\n+\tif (!err && !sock_flag(sk, SOCK_ZAPPED))\n \t\terr = bt_sock_wait_state(sk, BT_CONNECTED,\n \t\t\t\tsock_sndtimeo(sk, flags & O_NONBLOCK));\n \n done:\n \trelease_sock(sk);\n+\tsock_put(sk);\n \treturn err;\n }\n \n"
        ]
    },
    "8dc7a6aed7b8ead4c982ecdf2cd1ea5a4c3b57bb": {
        "non_crash": [
            "diff --git a/fs/fuse/file.c b/fs/fuse/file.c\nindex 71bfb663aac5..89f4741728ba 100644\n--- a/fs/fuse/file.c\n+++ b/fs/fuse/file.c\n@@ -2963,11 +2963,9 @@ static long fuse_file_fallocate(struct file *file, int mode, loff_t offset,\n \t\t.mode = mode\n \t};\n \tint err;\n-\tbool lock_inode = !(mode & FALLOC_FL_KEEP_SIZE) ||\n-\t\t\t   (mode & (FALLOC_FL_PUNCH_HOLE |\n-\t\t\t\t    FALLOC_FL_ZERO_RANGE));\n-\n-\tbool block_faults = FUSE_IS_DAX(inode) && lock_inode;\n+\tbool block_faults = FUSE_IS_DAX(inode) &&\n+\t\t(!(mode & FALLOC_FL_KEEP_SIZE) ||\n+\t\t (mode & (FALLOC_FL_PUNCH_HOLE | FALLOC_FL_ZERO_RANGE)));\n \n \tif (mode & ~(FALLOC_FL_KEEP_SIZE | FALLOC_FL_PUNCH_HOLE |\n \t\t     FALLOC_FL_ZERO_RANGE))\n@@ -2976,22 +2974,20 @@ static long fuse_file_fallocate(struct file *file, int mode, loff_t offset,\n \tif (fm->fc->no_fallocate)\n \t\treturn -EOPNOTSUPP;\n \n-\tif (lock_inode) {\n-\t\tinode_lock(inode);\n-\t\tif (block_faults) {\n-\t\t\tfilemap_invalidate_lock(inode->i_mapping);\n-\t\t\terr = fuse_dax_break_layouts(inode, 0, 0);\n-\t\t\tif (err)\n-\t\t\t\tgoto out;\n-\t\t}\n+\tinode_lock(inode);\n+\tif (block_faults) {\n+\t\tfilemap_invalidate_lock(inode->i_mapping);\n+\t\terr = fuse_dax_break_layouts(inode, 0, 0);\n+\t\tif (err)\n+\t\t\tgoto out;\n+\t}\n \n-\t\tif (mode & (FALLOC_FL_PUNCH_HOLE | FALLOC_FL_ZERO_RANGE)) {\n-\t\t\tloff_t endbyte = offset + length - 1;\n+\tif (mode & (FALLOC_FL_PUNCH_HOLE | FALLOC_FL_ZERO_RANGE)) {\n+\t\tloff_t endbyte = offset + length - 1;\n \n-\t\t\terr = fuse_writeback_range(inode, offset, endbyte);\n-\t\t\tif (err)\n-\t\t\t\tgoto out;\n-\t\t}\n+\t\terr = fuse_writeback_range(inode, offset, endbyte);\n+\t\tif (err)\n+\t\t\tgoto out;\n \t}\n \n \tif (!(mode & FALLOC_FL_KEEP_SIZE) &&\n@@ -3039,8 +3035,7 @@ static long fuse_file_fallocate(struct file *file, int mode, loff_t offset,\n \tif (block_faults)\n \t\tfilemap_invalidate_unlock(inode->i_mapping);\n \n-\tif (lock_inode)\n-\t\tinode_unlock(inode);\n+\tinode_unlock(inode);\n \n \tfuse_flush_time_update(inode);\n \n"
        ]
    },
    "392ce929bb0e269e6782a4d0586e5f187b9e4d92": {
        "non_crash": [
            "diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c\nindex d4b75a6cfeee..5471fbf38873 100644\n--- a/net/bluetooth/hci_event.c\n+++ b/net/bluetooth/hci_event.c\n@@ -5906,7 +5906,8 @@ 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    ev->data + ev->length <= 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@@ -5916,6 +5917,11 @@ static void hci_le_adv_report_evt(struct hci_dev *hdev, struct sk_buff *skb)\n \t\t}\n \n \t\tptr += sizeof(*ev) + ev->length + 1;\n+\n+\t\tif (ptr > (void *) skb_tail_pointer(skb) - sizeof(*ev)) {\n+\t\t\tbt_dev_err(hdev, \"Malicious advertising data. Stopping processing\");\n+\t\t\tbreak;\n+\t\t}\n \t}\n \n \thci_dev_unlock(hdev);\n"
        ]
    },
    "c861c927f694825cea94240c7acf698eccb2a8c2": {
        "non_crash": [
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 3b55e239705f..9930fa901039 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -111,6 +111,13 @@ static void nilfs_dat_commit_free(struct inode *dat,\n \tkunmap_atomic(kaddr);\n \n \tnilfs_dat_commit_entry(dat, req);\n+\n+\tif (unlikely(req->pr_desc_bh == NULL || req->pr_bitmap_bh == NULL)) {\n+\t\tnilfs_error(dat->i_sb,\n+\t\t\t    \"state inconsistency probably due to duplicate use of vblocknr = %llu\",\n+\t\t\t    (unsigned long long)req->pr_entry_nr);\n+\t\treturn;\n+\t}\n \tnilfs_palloc_commit_free_entry(dat, req);\n }\n \n"
        ]
    },
    "1bb51491ca5df96a5f724899d1dbb87afda61419": {
        "non_crash": [
            "diff --git a/include/net/bluetooth/hci_core.h b/include/net/bluetooth/hci_core.h\nindex a6c8aee2f256..8baf34639939 100644\n--- a/include/net/bluetooth/hci_core.h\n+++ b/include/net/bluetooth/hci_core.h\n@@ -1327,7 +1327,7 @@ int hci_le_create_cis(struct hci_conn *conn);\n \n struct hci_conn *hci_conn_add(struct hci_dev *hdev, int type, bdaddr_t *dst,\n \t\t\t      u8 role);\n-int hci_conn_del(struct hci_conn *conn);\n+void hci_conn_del(struct hci_conn *conn);\n void hci_conn_hash_flush(struct hci_dev *hdev);\n void hci_conn_check_pending(struct hci_dev *hdev);\n \ndiff --git a/net/bluetooth/hci_conn.c b/net/bluetooth/hci_conn.c\nindex 44d0643fc681..ce588359b290 100644\n--- a/net/bluetooth/hci_conn.c\n+++ b/net/bluetooth/hci_conn.c\n@@ -1088,6 +1088,14 @@ static void hci_conn_unlink(struct hci_conn *conn)\n \n \t\t\thci_conn_unlink(child);\n \n+\t\t\t/* If hdev is down it means\n+\t\t\t * hci_dev_close_sync/hci_conn_hash_flush is in progress\n+\t\t\t * and links don't need to be cleanup as all connections\n+\t\t\t * would be cleanup.\n+\t\t\t */\n+\t\t\tif (!test_bit(HCI_UP, &hdev->flags))\n+\t\t\t\tcontinue;\n+\n \t\t\t/* Due to race, SCO connection might be not established\n \t\t\t * yet at this point. Delete it now, otherwise it is\n \t\t\t * possible for it to be stuck and can't be deleted.\n@@ -1112,7 +1120,7 @@ static void hci_conn_unlink(struct hci_conn *conn)\n \tconn->link = NULL;\n }\n \n-int hci_conn_del(struct hci_conn *conn)\n+void hci_conn_del(struct hci_conn *conn)\n {\n \tstruct hci_dev *hdev = conn->hdev;\n \n@@ -1163,8 +1171,6 @@ int hci_conn_del(struct hci_conn *conn)\n \t * rest of hci_conn_del.\n \t */\n \thci_conn_cleanup(conn);\n-\n-\treturn 0;\n }\n \n struct hci_dev *hci_get_route(bdaddr_t *dst, bdaddr_t *src, uint8_t src_type)\n@@ -2465,22 +2471,27 @@ void hci_conn_enter_active_mode(struct hci_conn *conn, __u8 force_active)\n /* Drop all connection on the device */\n void hci_conn_hash_flush(struct hci_dev *hdev)\n {\n-\tstruct hci_conn_hash *h = &hdev->conn_hash;\n-\tstruct hci_conn *c, *n;\n+\tstruct list_head *head = &hdev->conn_hash.list;\n+\tstruct hci_conn *conn;\n \n \tBT_DBG(\"hdev %s\", hdev->name);\n \n-\tlist_for_each_entry_safe(c, n, &h->list, list) {\n-\t\tc->state = BT_CLOSED;\n-\n-\t\thci_disconn_cfm(c, HCI_ERROR_LOCAL_HOST_TERM);\n+\t/* We should not traverse the list here, because hci_conn_del\n+\t * can remove extra links, which may cause the list traversal\n+\t * to hit items that have already been released.\n+\t */\n+\twhile ((conn = list_first_entry_or_null(head,\n+\t\t\t\t\t\tstruct hci_conn,\n+\t\t\t\t\t\tlist)) != NULL) {\n+\t\tconn->state = BT_CLOSED;\n+\t\thci_disconn_cfm(conn, HCI_ERROR_LOCAL_HOST_TERM);\n \n \t\t/* Unlink before deleting otherwise it is possible that\n \t\t * hci_conn_del removes the link which may cause the list to\n \t\t * contain items already freed.\n \t\t */\n-\t\thci_conn_unlink(c);\n-\t\thci_conn_del(c);\n+\t\thci_conn_unlink(conn);\n+\t\thci_conn_del(conn);\n \t}\n }\n \n"
        ]
    },
    "2ebf4e2ffdaf022d2aac190c391ecb56689b6fc4": {
        "non_crash": [
            "diff --git a/fs/udf/namei.c b/fs/udf/namei.c\nindex fb4c30e05245..ae7bc13a5298 100644\n--- a/fs/udf/namei.c\n+++ b/fs/udf/namei.c\n@@ -240,7 +240,7 @@ static struct fileIdentDesc *udf_find_entry(struct inode *dir,\n \t\t\t\t\t\t      poffset - lfi);\n \t\t\telse {\n \t\t\t\tif (!copy_name) {\n-\t\t\t\t\tcopy_name = kmalloc(UDF_NAME_LEN,\n+\t\t\t\t\tcopy_name = kmalloc(UDF_NAME_LEN_CS0,\n \t\t\t\t\t\t\t    GFP_NOFS);\n \t\t\t\t\tif (!copy_name) {\n \t\t\t\t\t\tfi = ERR_PTR(-ENOMEM);\n"
        ]
    },
    "6408a8ba0fa0e3940c5c2dfa40e808cbf4228689": {
        "non_crash": [
            "diff --git a/fs/userfaultfd.c b/fs/userfaultfd.c\nindex ae0b8b5f69e6..ccbdbd62f0d8 100644\n--- a/fs/userfaultfd.c\n+++ b/fs/userfaultfd.c\n@@ -40,6 +40,16 @@ enum userfaultfd_state {\n /*\n  * Start with fault_pending_wqh and fault_wqh so they're more likely\n  * to be in the same cacheline.\n+ *\n+ * Locking order:\n+ *\tfd_wqh.lock\n+ *\t\tfault_pending_wqh.lock\n+ *\t\t\tfault_wqh.lock\n+ *\t\tevent_wqh.lock\n+ *\n+ * To avoid deadlocks, IRQs must be disabled when taking any of the above locks,\n+ * since fd_wqh.lock is taken by aio_poll() while it's holding a lock that's\n+ * also taken in IRQ context.\n  */\n struct userfaultfd_ctx {\n \t/* waitqueue head for the pending (i.e. not read) userfaults */\n@@ -458,7 +468,7 @@ vm_fault_t handle_userfault(struct vm_fault *vmf, unsigned long reason)\n \tblocking_state = return_to_userland ? TASK_INTERRUPTIBLE :\n \t\t\t TASK_KILLABLE;\n \n-\tspin_lock(&ctx->fault_pending_wqh.lock);\n+\tspin_lock_irq(&ctx->fault_pending_wqh.lock);\n \t/*\n \t * After the __add_wait_queue the uwq is visible to userland\n \t * through poll/read().\n@@ -470,7 +480,7 @@ vm_fault_t handle_userfault(struct vm_fault *vmf, unsigned long reason)\n \t * __add_wait_queue.\n \t */\n \tset_current_state(blocking_state);\n-\tspin_unlock(&ctx->fault_pending_wqh.lock);\n+\tspin_unlock_irq(&ctx->fault_pending_wqh.lock);\n \n \tif (!is_vm_hugetlb_page(vmf->vma))\n \t\tmust_wait = userfaultfd_must_wait(ctx, vmf->address, vmf->flags,\n@@ -552,13 +562,13 @@ vm_fault_t handle_userfault(struct vm_fault *vmf, unsigned long reason)\n \t * kernel stack can be released after the list_del_init.\n \t */\n \tif (!list_empty_careful(&uwq.wq.entry)) {\n-\t\tspin_lock(&ctx->fault_pending_wqh.lock);\n+\t\tspin_lock_irq(&ctx->fault_pending_wqh.lock);\n \t\t/*\n \t\t * No need of list_del_init(), the uwq on the stack\n \t\t * will be freed shortly anyway.\n \t\t */\n \t\tlist_del(&uwq.wq.entry);\n-\t\tspin_unlock(&ctx->fault_pending_wqh.lock);\n+\t\tspin_unlock_irq(&ctx->fault_pending_wqh.lock);\n \t}\n \n \t/*\n@@ -583,7 +593,7 @@ static void userfaultfd_event_wait_completion(struct userfaultfd_ctx *ctx,\n \tinit_waitqueue_entry(&ewq->wq, current);\n \trelease_new_ctx = NULL;\n \n-\tspin_lock(&ctx->event_wqh.lock);\n+\tspin_lock_irq(&ctx->event_wqh.lock);\n \t/*\n \t * After the __add_wait_queue the uwq is visible to userland\n \t * through poll/read().\n@@ -613,15 +623,15 @@ static void userfaultfd_event_wait_completion(struct userfaultfd_ctx *ctx,\n \t\t\tbreak;\n \t\t}\n \n-\t\tspin_unlock(&ctx->event_wqh.lock);\n+\t\tspin_unlock_irq(&ctx->event_wqh.lock);\n \n \t\twake_up_poll(&ctx->fd_wqh, EPOLLIN);\n \t\tschedule();\n \n-\t\tspin_lock(&ctx->event_wqh.lock);\n+\t\tspin_lock_irq(&ctx->event_wqh.lock);\n \t}\n \t__set_current_state(TASK_RUNNING);\n-\tspin_unlock(&ctx->event_wqh.lock);\n+\tspin_unlock_irq(&ctx->event_wqh.lock);\n \n \tif (release_new_ctx) {\n \t\tstruct vm_area_struct *vma;\n@@ -918,10 +928,10 @@ static int userfaultfd_release(struct inode *inode, struct file *file)\n \t * the last page faults that may have been already waiting on\n \t * the fault_*wqh.\n \t */\n-\tspin_lock(&ctx->fault_pending_wqh.lock);\n+\tspin_lock_irq(&ctx->fault_pending_wqh.lock);\n \t__wake_up_locked_key(&ctx->fault_pending_wqh, TASK_NORMAL, &range);\n \t__wake_up(&ctx->fault_wqh, TASK_NORMAL, 1, &range);\n-\tspin_unlock(&ctx->fault_pending_wqh.lock);\n+\tspin_unlock_irq(&ctx->fault_pending_wqh.lock);\n \n \t/* Flush pending events that may still wait on event_wqh */\n \twake_up_all(&ctx->event_wqh);\n@@ -1134,7 +1144,7 @@ static ssize_t userfaultfd_ctx_read(struct userfaultfd_ctx *ctx, int no_wait,\n \n \tif (!ret && msg->event == UFFD_EVENT_FORK) {\n \t\tret = resolve_userfault_fork(ctx, fork_nctx, msg);\n-\t\tspin_lock(&ctx->event_wqh.lock);\n+\t\tspin_lock_irq(&ctx->event_wqh.lock);\n \t\tif (!list_empty(&fork_event)) {\n \t\t\t/*\n \t\t\t * The fork thread didn't abort, so we can\n@@ -1180,7 +1190,7 @@ static ssize_t userfaultfd_ctx_read(struct userfaultfd_ctx *ctx, int no_wait,\n \t\t\tif (ret)\n \t\t\t\tuserfaultfd_ctx_put(fork_nctx);\n \t\t}\n-\t\tspin_unlock(&ctx->event_wqh.lock);\n+\t\tspin_unlock_irq(&ctx->event_wqh.lock);\n \t}\n \n \treturn ret;\n@@ -1219,14 +1229,14 @@ static ssize_t userfaultfd_read(struct file *file, char __user *buf,\n static void __wake_userfault(struct userfaultfd_ctx *ctx,\n \t\t\t     struct userfaultfd_wake_range *range)\n {\n-\tspin_lock(&ctx->fault_pending_wqh.lock);\n+\tspin_lock_irq(&ctx->fault_pending_wqh.lock);\n \t/* wake all in the range and autoremove */\n \tif (waitqueue_active(&ctx->fault_pending_wqh))\n \t\t__wake_up_locked_key(&ctx->fault_pending_wqh, TASK_NORMAL,\n \t\t\t\t     range);\n \tif (waitqueue_active(&ctx->fault_wqh))\n \t\t__wake_up(&ctx->fault_wqh, TASK_NORMAL, 1, range);\n-\tspin_unlock(&ctx->fault_pending_wqh.lock);\n+\tspin_unlock_irq(&ctx->fault_pending_wqh.lock);\n }\n \n static __always_inline void wake_userfault(struct userfaultfd_ctx *ctx,\n@@ -1881,7 +1891,7 @@ static void userfaultfd_show_fdinfo(struct seq_file *m, struct file *f)\n \twait_queue_entry_t *wq;\n \tunsigned long pending = 0, total = 0;\n \n-\tspin_lock(&ctx->fault_pending_wqh.lock);\n+\tspin_lock_irq(&ctx->fault_pending_wqh.lock);\n \tlist_for_each_entry(wq, &ctx->fault_pending_wqh.head, entry) {\n \t\tpending++;\n \t\ttotal++;\n@@ -1889,7 +1899,7 @@ static void userfaultfd_show_fdinfo(struct seq_file *m, struct file *f)\n \tlist_for_each_entry(wq, &ctx->fault_wqh.head, entry) {\n \t\ttotal++;\n \t}\n-\tspin_unlock(&ctx->fault_pending_wqh.lock);\n+\tspin_unlock_irq(&ctx->fault_pending_wqh.lock);\n \n \t/*\n \t * If more protocols will be added, there will be all shown\n"
        ]
    },
    "1fbd9fd0ef463a9811d2c5b7d206f119cf259601": {
        "non_crash": [
            "diff --git a/net/smc/smc_sysctl.c b/net/smc/smc_sysctl.c\nindex bae19419e755..cf3ab1334c00 100644\n--- a/net/smc/smc_sysctl.c\n+++ b/net/smc/smc_sysctl.c\n@@ -61,5 +61,10 @@ int __net_init smc_sysctl_net_init(struct net *net)\n \n void __net_exit smc_sysctl_net_exit(struct net *net)\n {\n+\tstruct ctl_table *table;\n+\n+\ttable = net->smc.smc_hdr->ctl_table_arg;\n \tunregister_net_sysctl_table(net->smc.smc_hdr);\n+\tif (!net_eq(net, &init_net))\n+\t\tkfree(table);\n }\n"
        ]
    },
    "e0623166295289b0b91d327386331328f3f2505d": {
        "non_crash": [
            "diff --git a/net/hsr/hsr_device.c b/net/hsr/hsr_device.c\nindex 478852ef98ef..a6f4e9f65b14 100644\n--- a/net/hsr/hsr_device.c\n+++ b/net/hsr/hsr_device.c\n@@ -415,6 +415,7 @@ int hsr_dev_finalize(struct net_device *hsr_dev, struct net_device *slave[2],\n \t\t     unsigned char multicast_spec, u8 protocol_version,\n \t\t     struct netlink_ext_ack *extack)\n {\n+\tbool unregister = false;\n \tstruct hsr_priv *hsr;\n \tint res;\n \n@@ -466,25 +467,27 @@ int hsr_dev_finalize(struct net_device *hsr_dev, struct net_device *slave[2],\n \tif (res)\n \t\tgoto err_unregister;\n \n+\tunregister = true;\n+\n \tres = hsr_add_port(hsr, slave[0], HSR_PT_SLAVE_A, extack);\n \tif (res)\n-\t\tgoto err_add_slaves;\n+\t\tgoto err_unregister;\n \n \tres = hsr_add_port(hsr, slave[1], HSR_PT_SLAVE_B, extack);\n \tif (res)\n-\t\tgoto err_add_slaves;\n+\t\tgoto err_unregister;\n \n \thsr_debugfs_init(hsr, hsr_dev);\n \tmod_timer(&hsr->prune_timer, jiffies + msecs_to_jiffies(PRUNE_PERIOD));\n \n \treturn 0;\n \n-err_add_slaves:\n-\tunregister_netdevice(hsr_dev);\n err_unregister:\n \thsr_del_ports(hsr);\n err_add_master:\n \thsr_del_self_node(hsr);\n \n+\tif (unregister)\n+\t\tunregister_netdevice(hsr_dev);\n \treturn res;\n }\n"
        ]
    },
    "11acaa6d5c31d0b655997957f725da4a3cc05435": {
        "non_crash": [
            "diff --git a/fs/btrfs/ctree.c b/fs/btrfs/ctree.c\nindex b39b339fbf96..a9543f01184c 100644\n--- a/fs/btrfs/ctree.c\n+++ b/fs/btrfs/ctree.c\n@@ -113,6 +113,22 @@ noinline void btrfs_release_path(struct btrfs_path *p)\n \t}\n }\n \n+/*\n+ * We want the transaction abort to print stack trace only for errors where the\n+ * cause could be a bug, eg. due to ENOSPC, and not for common errors that are\n+ * caused by external factors.\n+ */\n+bool __cold abort_should_print_stack(int errno)\n+{\n+\tswitch (errno) {\n+\tcase -EIO:\n+\tcase -EROFS:\n+\tcase -ENOMEM:\n+\t\treturn false;\n+\t}\n+\treturn true;\n+}\n+\n /*\n  * safely gets a reference on the root node of a tree.  A lock\n  * is not taken, so a concurrent writer may put a different node\ndiff --git a/fs/btrfs/ctree.h b/fs/btrfs/ctree.h\nindex f677b49df8ae..9e6d48ff4597 100644\n--- a/fs/btrfs/ctree.h\n+++ b/fs/btrfs/ctree.h\n@@ -3796,9 +3796,11 @@ void __btrfs_abort_transaction(struct btrfs_trans_handle *trans,\n \t\t\t       const char *function,\n \t\t\t       unsigned int line, int errno, bool first_hit);\n \n+bool __cold abort_should_print_stack(int errno);\n+\n /*\n  * Call btrfs_abort_transaction as early as possible when an error condition is\n- * detected, that way the exact line number is reported.\n+ * detected, that way the exact stack trace is reported for some errors.\n  */\n #define btrfs_abort_transaction(trans, errno)\t\t\\\n do {\t\t\t\t\t\t\t\t\\\n@@ -3807,10 +3809,11 @@ do {\t\t\t\t\t\t\t\t\\\n \tif (!test_and_set_bit(BTRFS_FS_STATE_TRANS_ABORTED,\t\\\n \t\t\t&((trans)->fs_info->fs_state))) {\t\\\n \t\tfirst = true;\t\t\t\t\t\\\n-\t\tif ((errno) != -EIO && (errno) != -EROFS) {\t\t\\\n-\t\t\tWARN(1, KERN_DEBUG\t\t\t\t\\\n+\t\tif (WARN(abort_should_print_stack(errno), \t\\\n+\t\t\tKERN_DEBUG\t\t\t\t\\\n \t\t\t\"BTRFS: Transaction aborted (error %d)\\n\",\t\\\n-\t\t\t(errno));\t\t\t\t\t\\\n+\t\t\t(errno))) {\t\t\t\t\t\\\n+\t\t\t/* Stack trace printed. */\t\t\t\\\n \t\t} else {\t\t\t\t\t\t\\\n \t\t\tbtrfs_debug((trans)->fs_info,\t\t\t\\\n \t\t\t\t    \"Transaction aborted (error %d)\", \\\n"
        ]
    },
    "e9d3ca982b76224e183481018baa693a26655ac4": {
        "non_crash": [
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 863c15388848..2a006e4db467 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2851,6 +2851,9 @@ int ext4_expand_extra_isize_ea(struct inode *inode, int new_extra_isize,\n \t\t\t(void *)header, total_ino);\n \tEXT4_I(inode)->i_extra_isize = new_extra_isize;\n \n+\tif (ext4_has_inline_data(inode))\n+\t\terror = ext4_find_inline_data_nolock(inode);\n+\n cleanup:\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"
        ]
    },
    "d92cc44e8c8ce5af6d2bea9f7a73cee791989fc8": {
        "non_crash": [
            "diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c\nindex 258f3cbed347..02de439bf1f0 100644\n--- a/fs/ext4/inode.c\n+++ b/fs/ext4/inode.c\n@@ -4647,6 +4647,9 @@ static const char *check_igot_inode(struct inode *inode, ext4_iget_flags flags)\n \tif (flags & EXT4_IGET_EA_INODE) {\n \t\tif (!(EXT4_I(inode)->i_flags & EXT4_EA_INODE_FL))\n \t\t\treturn \"missing EA_INODE flag\";\n+\t\tif (ext4_test_inode_state(inode, EXT4_STATE_XATTR) ||\n+\t\t    EXT4_I(inode)->i_file_acl)\n+\t\t\treturn \"ea_inode with extended attributes\";\n \t} else {\n \t\tif ((EXT4_I(inode)->i_flags & EXT4_EA_INODE_FL))\n \t\t\treturn \"unexpected EA_INODE flag\";\n"
        ]
    },
    "f080ff8eb73ae6a29960594307de8e732db389d3": {
        "non_crash": [
            "diff --git a/fs/f2fs/super.c b/fs/f2fs/super.c\nindex 8eb17cc73941..6e770f82d39f 100644\n--- a/fs/f2fs/super.c\n+++ b/fs/f2fs/super.c\n@@ -2086,9 +2086,22 @@ static int f2fs_show_options(struct seq_file *seq, struct dentry *root)\n \treturn 0;\n }\n \n-static void default_options(struct f2fs_sb_info *sbi)\n+static void default_options(struct f2fs_sb_info *sbi, bool remount)\n {\n \t/* init some FS parameters */\n+\tif (!remount) {\n+\t\tset_opt(sbi, READ_EXTENT_CACHE);\n+\t\tclear_opt(sbi, DISABLE_CHECKPOINT);\n+\n+\t\tif (f2fs_hw_support_discard(sbi) || f2fs_hw_should_discard(sbi))\n+\t\t\tset_opt(sbi, DISCARD);\n+\n+\t\tif (f2fs_sb_has_blkzoned(sbi))\n+\t\t\tF2FS_OPTION(sbi).discard_unit = DISCARD_UNIT_SECTION;\n+\t\telse\n+\t\t\tF2FS_OPTION(sbi).discard_unit = DISCARD_UNIT_BLOCK;\n+\t}\n+\n \tif (f2fs_sb_has_readonly(sbi))\n \t\tF2FS_OPTION(sbi).active_logs = NR_CURSEG_RO_TYPE;\n \telse\n@@ -2118,23 +2131,16 @@ static void default_options(struct f2fs_sb_info *sbi)\n \tset_opt(sbi, INLINE_XATTR);\n \tset_opt(sbi, INLINE_DATA);\n \tset_opt(sbi, INLINE_DENTRY);\n-\tset_opt(sbi, READ_EXTENT_CACHE);\n \tset_opt(sbi, NOHEAP);\n-\tclear_opt(sbi, DISABLE_CHECKPOINT);\n \tset_opt(sbi, MERGE_CHECKPOINT);\n \tF2FS_OPTION(sbi).unusable_cap = 0;\n \tsbi->sb->s_flags |= SB_LAZYTIME;\n \tif (!f2fs_is_readonly(sbi))\n \t\tset_opt(sbi, FLUSH_MERGE);\n-\tif (f2fs_hw_support_discard(sbi) || f2fs_hw_should_discard(sbi))\n-\t\tset_opt(sbi, DISCARD);\n-\tif (f2fs_sb_has_blkzoned(sbi)) {\n+\tif (f2fs_sb_has_blkzoned(sbi))\n \t\tF2FS_OPTION(sbi).fs_mode = FS_MODE_LFS;\n-\t\tF2FS_OPTION(sbi).discard_unit = DISCARD_UNIT_SECTION;\n-\t} else {\n+\telse\n \t\tF2FS_OPTION(sbi).fs_mode = FS_MODE_ADAPTIVE;\n-\t\tF2FS_OPTION(sbi).discard_unit = DISCARD_UNIT_BLOCK;\n-\t}\n \n #ifdef CONFIG_F2FS_FS_XATTR\n \tset_opt(sbi, XATTR_USER);\n@@ -2306,7 +2312,7 @@ static int f2fs_remount(struct super_block *sb, int *flags, char *data)\n \t\t\tclear_sbi_flag(sbi, SBI_NEED_SB_WRITE);\n \t}\n \n-\tdefault_options(sbi);\n+\tdefault_options(sbi, true);\n \n \t/* parse mount options */\n \terr = parse_options(sb, data, true);\n@@ -4346,7 +4352,7 @@ static int f2fs_fill_super(struct super_block *sb, void *data, int silent)\n \t\tsbi->s_chksum_seed = f2fs_chksum(sbi, ~0, raw_super->uuid,\n \t\t\t\t\t\tsizeof(raw_super->uuid));\n \n-\tdefault_options(sbi);\n+\tdefault_options(sbi, false);\n \t/* parse mount options */\n \toptions = kstrdup((const char *)data, GFP_KERNEL);\n \tif (data && !options) {\n"
        ]
    },
    "d1975758ab72f25acdc552246472398abe66c7fd": {
        "non_crash": [
            "diff --git a/mm/gup.c b/mm/gup.c\nindex ce14d4d28503..a8336b39d6b5 100644\n--- a/mm/gup.c\n+++ b/mm/gup.c\n@@ -3080,7 +3080,7 @@ static int internal_get_user_pages_fast(unsigned long start,\n \tstart = untagged_addr(start) & PAGE_MASK;\n \tlen = nr_pages << PAGE_SHIFT;\n \tif (check_add_overflow(start, len, &end))\n-\t\treturn 0;\n+\t\treturn -EOVERFLOW;\n \tif (end > TASK_SIZE_MAX)\n \t\treturn -EFAULT;\n \tif (unlikely(!access_ok((void __user *)start, len)))\n"
        ]
    },
    "a59816f87c8e514d1b5ed891ae85341fbef1e553": {
        "non_crash": [
            "diff --git a/block/fops.c b/block/fops.c\nindex e3643362c244..b9b83030e0df 100644\n--- a/block/fops.c\n+++ b/block/fops.c\n@@ -44,14 +44,6 @@ static unsigned int dio_bio_write_op(struct kiocb *iocb)\n \n #define DIO_INLINE_BIO_VECS 4\n \n-static void blkdev_bio_end_io_simple(struct bio *bio)\n-{\n-\tstruct task_struct *waiter = bio->bi_private;\n-\n-\tWRITE_ONCE(bio->bi_private, NULL);\n-\tblk_wake_io_task(waiter);\n-}\n-\n static ssize_t __blkdev_direct_IO_simple(struct kiocb *iocb,\n \t\tstruct iov_iter *iter, unsigned int nr_pages)\n {\n@@ -83,8 +75,6 @@ static ssize_t __blkdev_direct_IO_simple(struct kiocb *iocb,\n \t\tbio_init(&bio, bdev, vecs, nr_pages, dio_bio_write_op(iocb));\n \t}\n \tbio.bi_iter.bi_sector = pos >> SECTOR_SHIFT;\n-\tbio.bi_private = current;\n-\tbio.bi_end_io = blkdev_bio_end_io_simple;\n \tbio.bi_ioprio = iocb->ki_ioprio;\n \n \tret = bio_iov_iter_get_pages(&bio, iter);\n@@ -97,18 +87,8 @@ static ssize_t __blkdev_direct_IO_simple(struct kiocb *iocb,\n \n \tif (iocb->ki_flags & IOCB_NOWAIT)\n \t\tbio.bi_opf |= REQ_NOWAIT;\n-\tif (iocb->ki_flags & IOCB_HIPRI)\n-\t\tbio_set_polled(&bio, iocb);\n \n-\tsubmit_bio(&bio);\n-\tfor (;;) {\n-\t\tset_current_state(TASK_UNINTERRUPTIBLE);\n-\t\tif (!READ_ONCE(bio.bi_private))\n-\t\t\tbreak;\n-\t\tif (!(iocb->ki_flags & IOCB_HIPRI) || !bio_poll(&bio, NULL, 0))\n-\t\t\tblk_io_schedule();\n-\t}\n-\t__set_current_state(TASK_RUNNING);\n+\tsubmit_bio_wait(&bio);\n \n \tbio_release_pages(&bio, should_dirty);\n \tif (unlikely(bio.bi_status))\ndiff --git a/fs/iomap/direct-io.c b/fs/iomap/direct-io.c\nindex 62da020d02a1..80f9b047aa1b 100644\n--- a/fs/iomap/direct-io.c\n+++ b/fs/iomap/direct-io.c\n@@ -56,7 +56,8 @@ static void iomap_dio_submit_bio(const struct iomap_iter *iter,\n {\n \tatomic_inc(&dio->ref);\n \n-\tif (dio->iocb->ki_flags & IOCB_HIPRI) {\n+\t/* Sync dio can't be polled reliably */\n+\tif ((dio->iocb->ki_flags & IOCB_HIPRI) && !is_sync_kiocb(dio->iocb)) {\n \t\tbio_set_polled(bio, dio->iocb);\n \t\tdio->submit.poll_bio = bio;\n \t}\n@@ -653,9 +654,7 @@ __iomap_dio_rw(struct kiocb *iocb, struct iov_iter *iter,\n \t\t\tif (!READ_ONCE(dio->submit.waiter))\n \t\t\t\tbreak;\n \n-\t\t\tif (!dio->submit.poll_bio ||\n-\t\t\t    !bio_poll(dio->submit.poll_bio, NULL, 0))\n-\t\t\t\tblk_io_schedule();\n+\t\t\tblk_io_schedule();\n \t\t}\n \t\t__set_current_state(TASK_RUNNING);\n \t}\ndiff --git a/mm/page_io.c b/mm/page_io.c\nindex 89fbf3cae30f..3fbdab6a940e 100644\n--- a/mm/page_io.c\n+++ b/mm/page_io.c\n@@ -360,7 +360,6 @@ int swap_readpage(struct page *page, bool synchronous)\n \t * attempt to access it in the page fault retry time check.\n \t */\n \tif (synchronous) {\n-\t\tbio->bi_opf |= REQ_POLLED;\n \t\tget_task_struct(current);\n \t\tbio->bi_private = current;\n \t}\n@@ -372,8 +371,7 @@ int swap_readpage(struct page *page, bool synchronous)\n \t\tif (!READ_ONCE(bio->bi_private))\n \t\t\tbreak;\n \n-\t\tif (!bio_poll(bio, NULL, 0))\n-\t\t\tblk_io_schedule();\n+\t\tblk_io_schedule();\n \t}\n \t__set_current_state(TASK_RUNNING);\n \tbio_put(bio);\n"
        ]
    },
    "72c3096dbc86cdffde7afa178a39dc1a29dec67a": {
        "non_crash": [
            "diff --git a/fs/exfat/dir.c b/fs/exfat/dir.c\nindex bc48f3329921..598081d0d059 100644\n--- a/fs/exfat/dir.c\n+++ b/fs/exfat/dir.c\n@@ -218,7 +218,10 @@ static void exfat_free_namebuf(struct exfat_dentry_namebuf *nb)\n \texfat_init_namebuf(nb);\n }\n \n-/* skip iterating emit_dots when dir is empty */\n+/*\n+ * Before calling dir_emit*(), sbi->s_lock should be released\n+ * because page fault can occur in dir_emit*().\n+ */\n #define ITER_POS_FILLED_DOTS    (2)\n static int exfat_iterate(struct file *file, struct dir_context *ctx)\n {\n@@ -233,11 +236,10 @@ static int exfat_iterate(struct file *file, struct dir_context *ctx)\n \tint err = 0, fake_offset = 0;\n \n \texfat_init_namebuf(nb);\n-\tmutex_lock(&EXFAT_SB(sb)->s_lock);\n \n \tcpos = ctx->pos;\n \tif (!dir_emit_dots(file, ctx))\n-\t\tgoto unlock;\n+\t\tgoto out;\n \n \tif (ctx->pos == ITER_POS_FILLED_DOTS) {\n \t\tcpos = 0;\n@@ -249,16 +251,18 @@ static int exfat_iterate(struct file *file, struct dir_context *ctx)\n \t/* name buffer should be allocated before use */\n \terr = exfat_alloc_namebuf(nb);\n \tif (err)\n-\t\tgoto unlock;\n+\t\tgoto out;\n get_new:\n+\tmutex_lock(&EXFAT_SB(sb)->s_lock);\n+\n \tif (ei->flags == ALLOC_NO_FAT_CHAIN && cpos >= i_size_read(inode))\n \t\tgoto end_of_dir;\n \n \terr = exfat_readdir(inode, &cpos, &de);\n \tif (err) {\n \t\t/*\n-\t\t * At least we tried to read a sector.  Move cpos to next sector\n-\t\t * position (should be aligned).\n+\t\t * At least we tried to read a sector.\n+\t\t * Move cpos to next sector position (should be aligned).\n \t\t */\n \t\tif (err == -EIO) {\n \t\t\tcpos += 1 << (sb->s_blocksize_bits);\n@@ -281,16 +285,10 @@ static int exfat_iterate(struct file *file, struct dir_context *ctx)\n \t\tinum = iunique(sb, EXFAT_ROOT_INO);\n \t}\n \n-\t/*\n-\t * Before calling dir_emit(), sb_lock should be released.\n-\t * Because page fault can occur in dir_emit() when the size\n-\t * of buffer given from user is larger than one page size.\n-\t */\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-\tmutex_lock(&EXFAT_SB(sb)->s_lock);\n+\t\tgoto out;\n \tctx->pos = cpos;\n \tgoto get_new;\n \n@@ -298,9 +296,8 @@ static int exfat_iterate(struct file *file, struct dir_context *ctx)\n \tif (!cpos && fake_offset)\n \t\tcpos = ITER_POS_FILLED_DOTS;\n \tctx->pos = cpos;\n-unlock:\n \tmutex_unlock(&EXFAT_SB(sb)->s_lock);\n-out_unlocked:\n+out:\n \t/*\n \t * To improve performance, free namebuf after unlock sb_lock.\n \t * If namebuf is not allocated, this function do nothing\n"
        ]
    },
    "2db2545ff94291fabe4a5dd4ee182db44ef35d4b": {
        "non_crash": [
            "diff --git a/drivers/hid/uhid.c b/drivers/hid/uhid.c\nindex 3c5507313606..051639c09f72 100644\n--- a/drivers/hid/uhid.c\n+++ b/drivers/hid/uhid.c\n@@ -12,6 +12,7 @@\n \n #include <linux/atomic.h>\n #include <linux/compat.h>\n+#include <linux/cred.h>\n #include <linux/device.h>\n #include <linux/fs.h>\n #include <linux/hid.h>\n@@ -722,6 +723,17 @@ static ssize_t uhid_char_write(struct file *file, const char __user *buffer,\n \n \tswitch (uhid->input_buf.type) {\n \tcase UHID_CREATE:\n+\t\t/*\n+\t\t * 'struct uhid_create_req' contains a __user pointer which is\n+\t\t * copied from, so it's unsafe to allow this with elevated\n+\t\t * privileges (e.g. from a setuid binary) or via kernel_write().\n+\t\t */\n+\t\tif (file->f_cred != current_cred() || uaccess_kernel()) {\n+\t\t\tpr_err_once(\"UHID_CREATE from different security context by process %d (%s), this is not allowed.\\n\",\n+\t\t\t\t    task_tgid_vnr(current), current->comm);\n+\t\t\tret = -EACCES;\n+\t\t\tgoto unlock;\n+\t\t}\n \t\tret = uhid_dev_create(uhid, &uhid->input_buf);\n \t\tbreak;\n \tcase UHID_CREATE2:\n"
        ]
    },
    "feb49e622c3d0ca5ff931e55e2310f96a4d0231e": {
        "non_crash": [
            "diff --git a/drivers/gpu/drm/vkms/vkms_crtc.c b/drivers/gpu/drm/vkms/vkms_crtc.c\nindex 177bbcb38306..3c37d8c41d4a 100644\n--- a/drivers/gpu/drm/vkms/vkms_crtc.c\n+++ b/drivers/gpu/drm/vkms/vkms_crtc.c\n@@ -104,6 +104,7 @@ static void vkms_atomic_crtc_reset(struct drm_crtc *crtc)\n \tvkms_state = kzalloc(sizeof(*vkms_state), GFP_KERNEL);\n \tif (!vkms_state)\n \t\treturn;\n+\tINIT_WORK(&vkms_state->crc_work, vkms_crc_work_handle);\n \n \tcrtc->state = &vkms_state->base;\n \tcrtc->state->crtc = crtc;\n"
        ]
    },
    "b32fa08468c9e84e361296e1bc502283ea202ec6": {
        "non_crash": [
            "diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c\nindex 46943a18a10d..76c2dca7f0a5 100644\n--- a/net/packet/af_packet.c\n+++ b/net/packet/af_packet.c\n@@ -4492,9 +4492,10 @@ static int packet_set_ring(struct sock *sk, union tpacket_req_u *req_u,\n \t}\n \n out_free_pg_vec:\n-\tbitmap_free(rx_owner_map);\n-\tif (pg_vec)\n+\tif (pg_vec) {\n+\t\tbitmap_free(rx_owner_map);\n \t\tfree_pg_vec(pg_vec, order, req->tp_block_nr);\n+\t}\n out:\n \treturn err;\n }\n"
        ]
    },
    "e0083a52ae0eb23d3186173d403646079b45c715": {
        "non_crash": [
            "diff --git a/drivers/usb/core/hcd.c b/drivers/usb/core/hcd.c\nindex 9ffc63ae65ac..3e01dd6e509b 100644\n--- a/drivers/usb/core/hcd.c\n+++ b/drivers/usb/core/hcd.c\n@@ -753,6 +753,7 @@ void usb_hcd_poll_rh_status(struct usb_hcd *hcd)\n {\n \tstruct urb\t*urb;\n \tint\t\tlength;\n+\tint\t\tstatus;\n \tunsigned long\tflags;\n \tchar\t\tbuffer[6];\t/* Any root hubs with > 31 ports? */\n \n@@ -770,11 +771,17 @@ void usb_hcd_poll_rh_status(struct usb_hcd *hcd)\n \t\tif (urb) {\n \t\t\tclear_bit(HCD_FLAG_POLL_PENDING, &hcd->flags);\n \t\t\thcd->status_urb = NULL;\n+\t\t\tif (urb->transfer_buffer_length >= length) {\n+\t\t\t\tstatus = 0;\n+\t\t\t} else {\n+\t\t\t\tstatus = -EOVERFLOW;\n+\t\t\t\tlength = urb->transfer_buffer_length;\n+\t\t\t}\n \t\t\turb->actual_length = length;\n \t\t\tmemcpy(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+\t\t\tusb_hcd_giveback_urb(hcd, urb, status);\n \t\t} else {\n \t\t\tlength = 0;\n \t\t\tset_bit(HCD_FLAG_POLL_PENDING, &hcd->flags);\n"
        ]
    },
    "e2fdad19640cdf94dec600b3c67260b6095e5f7d": {
        "non_crash": [
            "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 4eae088046d0..2e04850a657b 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -94,7 +94,7 @@ static __cold void __io_uring_show_fdinfo(struct io_ring_ctx *ctx,\n \t\tsq_idx = READ_ONCE(ctx->sq_array[entry & sq_mask]);\n \t\tif (sq_idx > sq_mask)\n \t\t\tcontinue;\n-\t\tsqe = &ctx->sq_sqes[sq_idx << 1];\n+\t\tsqe = &ctx->sq_sqes[sq_idx << sq_shift];\n \t\tseq_printf(m, \"%5u: opcode:%s, fd:%d, flags:%x, off:%llu, \"\n \t\t\t      \"addr:0x%llx, rw_flags:0x%x, buf_index:%d \"\n \t\t\t      \"user_data:%llu\",\n"
        ]
    },
    "f07cf3e7df6d272b92ccdabfeef07ae06c014ca5": {
        "non_crash": [
            "diff --git a/fs/ext4/namei.c b/fs/ext4/namei.c\nindex e8f429330f3c..7cc3918e2f18 100644\n--- a/fs/ext4/namei.c\n+++ b/fs/ext4/namei.c\n@@ -3813,10 +3813,20 @@ static int ext4_rename(struct user_namespace *mnt_userns, struct inode *old_dir,\n \t\t\treturn retval;\n \t}\n \n+\t/*\n+\t * We need to protect against old.inode directory getting converted\n+\t * from inline directory format into a normal one.\n+\t */\n+\tif (S_ISDIR(old.inode->i_mode))\n+\t\tinode_lock_nested(old.inode, I_MUTEX_NONDIR2);\n+\n \told.bh = ext4_find_entry(old.dir, &old.dentry->d_name, &old.de,\n \t\t\t\t &old.inlined);\n-\tif (IS_ERR(old.bh))\n-\t\treturn PTR_ERR(old.bh);\n+\tif (IS_ERR(old.bh)) {\n+\t\tretval = PTR_ERR(old.bh);\n+\t\tgoto unlock_moved_dir;\n+\t}\n+\n \t/*\n \t *  Check for inode number is _not_ due to possible IO errors.\n \t *  We might rmdir the source, keep it as pwd of some process\n@@ -3873,11 +3883,6 @@ static int ext4_rename(struct user_namespace *mnt_userns, struct inode *old_dir,\n \t\t\tif (new.dir != old.dir && EXT4_DIR_LINK_MAX(new.dir))\n \t\t\t\tgoto end_rename;\n \t\t}\n-\t\t/*\n-\t\t * We need to protect against old.inode directory getting\n-\t\t * converted from inline directory format into a normal one.\n-\t\t */\n-\t\tinode_lock_nested(old.inode, I_MUTEX_NONDIR2);\n \t\tretval = ext4_rename_dir_prepare(handle, &old);\n \t\tif (retval) {\n \t\t\tinode_unlock(old.inode);\n@@ -4014,12 +4019,15 @@ static int ext4_rename(struct user_namespace *mnt_userns, struct inode *old_dir,\n \t} else {\n \t\text4_journal_stop(handle);\n \t}\n-\tif (old.dir_bh)\n-\t\tinode_unlock(old.inode);\n release_bh:\n \tbrelse(old.dir_bh);\n \tbrelse(old.bh);\n \tbrelse(new.bh);\n+\n+unlock_moved_dir:\n+\tif (S_ISDIR(old.inode->i_mode))\n+\t\tinode_unlock(old.inode);\n+\n \treturn retval;\n }\n \n"
        ]
    },
    "1665a0a4a1d6d4d3f61624353f8a9e5dbfff67bd": {
        "non_crash": [
            "diff --git a/net/l2tp/l2tp_core.c b/net/l2tp/l2tp_core.c\nindex 754fdda8a5f5..9a1415fe3fa7 100644\n--- a/net/l2tp/l2tp_core.c\n+++ b/net/l2tp/l2tp_core.c\n@@ -1474,11 +1474,12 @@ int l2tp_tunnel_register(struct l2tp_tunnel *tunnel, struct net *net,\n \t}\n \n \tsk = sock->sk;\n-\twrite_lock(&sk->sk_callback_lock);\n-\n+\twrite_lock_bh(&sk->sk_callback_lock);\n \tret = l2tp_validate_socket(sk, net, tunnel->encap);\n \tif (ret < 0)\n-\t\tgoto err_sock;\n+\t\tgoto err_inval_sock;\n+\trcu_assign_sk_user_data(sk, tunnel);\n+\twrite_unlock_bh(&sk->sk_callback_lock);\n \n \ttunnel->l2tp_net = net;\n \tpn = l2tp_pernet(net);\n@@ -1507,8 +1508,6 @@ int l2tp_tunnel_register(struct l2tp_tunnel *tunnel, struct net *net,\n \t\t};\n \n \t\tsetup_udp_tunnel_sock(net, sock, &udp_cfg);\n-\t} else {\n-\t\trcu_assign_sk_user_data(sk, tunnel);\n \t}\n \n \ttunnel->old_sk_destruct = sk->sk_destruct;\n@@ -1522,16 +1521,18 @@ int l2tp_tunnel_register(struct l2tp_tunnel *tunnel, struct net *net,\n \tif (tunnel->fd >= 0)\n \t\tsockfd_put(sock);\n \n-\twrite_unlock(&sk->sk_callback_lock);\n \treturn 0;\n \n err_sock:\n+\twrite_lock_bh(&sk->sk_callback_lock);\n+\trcu_assign_sk_user_data(sk, NULL);\n+err_inval_sock:\n+\twrite_unlock_bh(&sk->sk_callback_lock);\n+\n \tif (tunnel->fd < 0)\n \t\tsock_release(sock);\n \telse\n \t\tsockfd_put(sock);\n-\n-\twrite_unlock(&sk->sk_callback_lock);\n err:\n \treturn ret;\n }\n"
        ]
    },
    "ad6e459b5804609befe3e5c24001b25185b073fc": {
        "non_crash": [
            "diff --git a/include/net/genetlink.h b/include/net/genetlink.h\nindex 74950663bb00..ad71ed4f55ff 100644\n--- a/include/net/genetlink.h\n+++ b/include/net/genetlink.h\n@@ -41,7 +41,6 @@ struct genl_info;\n  *\tNote that unbind() will not be called symmetrically if the\n  *\tgeneric netlink family is removed while there are still open\n  *\tsockets.\n- * @attrbuf: buffer to store parsed attributes (private)\n  * @mcgrps: multicast groups used by this family\n  * @n_mcgrps: number of multicast groups\n  * @mcgrp_offset: starting number of multicast group IDs in this family\n@@ -66,7 +65,6 @@ struct genl_family {\n \t\t\t\t\t     struct genl_info *info);\n \tint\t\t\t(*mcast_bind)(struct net *net, int group);\n \tvoid\t\t\t(*mcast_unbind)(struct net *net, int group);\n-\tstruct nlattr **\tattrbuf;\t/* private */\n \tconst struct genl_ops *\tops;\n \tconst struct genl_multicast_group *mcgrps;\n \tunsigned int\t\tn_ops;\ndiff --git a/net/netlink/genetlink.c b/net/netlink/genetlink.c\nindex 55ee680e9db1..a914b9365a46 100644\n--- a/net/netlink/genetlink.c\n+++ b/net/netlink/genetlink.c\n@@ -351,22 +351,11 @@ int genl_register_family(struct genl_family *family)\n \t\tstart = end = GENL_ID_VFS_DQUOT;\n \t}\n \n-\tif (family->maxattr && !family->parallel_ops) {\n-\t\tfamily->attrbuf = kmalloc_array(family->maxattr + 1,\n-\t\t\t\t\t\tsizeof(struct nlattr *),\n-\t\t\t\t\t\tGFP_KERNEL);\n-\t\tif (family->attrbuf == NULL) {\n-\t\t\terr = -ENOMEM;\n-\t\t\tgoto errout_locked;\n-\t\t}\n-\t} else\n-\t\tfamily->attrbuf = NULL;\n-\n \tfamily->id = idr_alloc_cyclic(&genl_fam_idr, family,\n \t\t\t\t      start, end + 1, GFP_KERNEL);\n \tif (family->id < 0) {\n \t\terr = family->id;\n-\t\tgoto errout_free;\n+\t\tgoto errout_locked;\n \t}\n \n \terr = genl_validate_assign_mc_groups(family);\n@@ -385,8 +374,6 @@ int genl_register_family(struct genl_family *family)\n \n errout_remove:\n \tidr_remove(&genl_fam_idr, family->id);\n-errout_free:\n-\tkfree(family->attrbuf);\n errout_locked:\n \tgenl_unlock_all();\n \treturn err;\n@@ -419,8 +406,6 @@ int genl_unregister_family(const struct genl_family *family)\n \t\t   atomic_read(&genl_sk_destructing_cnt) == 0);\n \tgenl_unlock();\n \n-\tkfree(family->attrbuf);\n-\n \tgenl_ctrl_event(CTRL_CMD_DELFAMILY, family, NULL, 0);\n \n \treturn 0;\n@@ -485,30 +470,23 @@ genl_family_rcv_msg_attrs_parse(const struct genl_family *family,\n \tif (!family->maxattr)\n \t\treturn NULL;\n \n-\tif (family->parallel_ops) {\n-\t\tattrbuf = kmalloc_array(family->maxattr + 1,\n-\t\t\t\t\tsizeof(struct nlattr *), GFP_KERNEL);\n-\t\tif (!attrbuf)\n-\t\t\treturn ERR_PTR(-ENOMEM);\n-\t} else {\n-\t\tattrbuf = family->attrbuf;\n-\t}\n+\tattrbuf = kmalloc_array(family->maxattr + 1,\n+\t\t\t\tsizeof(struct nlattr *), GFP_KERNEL);\n+\tif (!attrbuf)\n+\t\treturn ERR_PTR(-ENOMEM);\n \n \terr = __nlmsg_parse(nlh, hdrlen, attrbuf, family->maxattr,\n \t\t\t    family->policy, validate, extack);\n \tif (err) {\n-\t\tif (family->parallel_ops)\n-\t\t\tkfree(attrbuf);\n+\t\tkfree(attrbuf);\n \t\treturn ERR_PTR(err);\n \t}\n \treturn attrbuf;\n }\n \n-static void genl_family_rcv_msg_attrs_free(const struct genl_family *family,\n-\t\t\t\t\t   struct nlattr **attrbuf)\n+static void genl_family_rcv_msg_attrs_free(struct nlattr **attrbuf)\n {\n-\tif (family->parallel_ops)\n-\t\tkfree(attrbuf);\n+\tkfree(attrbuf);\n }\n \n struct genl_start_context {\n@@ -542,7 +520,7 @@ static int genl_start(struct netlink_callback *cb)\n no_attrs:\n \tinfo = genl_dumpit_info_alloc();\n \tif (!info) {\n-\t\tgenl_family_rcv_msg_attrs_free(ctx->family, attrs);\n+\t\tgenl_family_rcv_msg_attrs_free(attrs);\n \t\treturn -ENOMEM;\n \t}\n \tinfo->family = ctx->family;\n@@ -559,7 +537,7 @@ static int genl_start(struct netlink_callback *cb)\n \t}\n \n \tif (rc) {\n-\t\tgenl_family_rcv_msg_attrs_free(info->family, info->attrs);\n+\t\tgenl_family_rcv_msg_attrs_free(info->attrs);\n \t\tgenl_dumpit_info_free(info);\n \t\tcb->data = NULL;\n \t}\n@@ -588,7 +566,7 @@ static int genl_lock_done(struct netlink_callback *cb)\n \t\trc = ops->done(cb);\n \t\tgenl_unlock();\n \t}\n-\tgenl_family_rcv_msg_attrs_free(info->family, info->attrs);\n+\tgenl_family_rcv_msg_attrs_free(info->attrs);\n \tgenl_dumpit_info_free(info);\n \treturn rc;\n }\n@@ -601,7 +579,7 @@ static int genl_parallel_done(struct netlink_callback *cb)\n \n \tif (ops->done)\n \t\trc = ops->done(cb);\n-\tgenl_family_rcv_msg_attrs_free(info->family, info->attrs);\n+\tgenl_family_rcv_msg_attrs_free(info->attrs);\n \tgenl_dumpit_info_free(info);\n \treturn rc;\n }\n@@ -694,7 +672,7 @@ static int genl_family_rcv_msg_doit(const struct genl_family *family,\n \t\tfamily->post_doit(ops, skb, &info);\n \n out:\n-\tgenl_family_rcv_msg_attrs_free(family, attrbuf);\n+\tgenl_family_rcv_msg_attrs_free(attrbuf);\n \n \treturn err;\n }\n"
        ]
    },
    "49b6f675bead6969f913a3f7dcef4d28fdd13296": {
        "non_crash": [
            "diff --git a/mm/mmap.c b/mm/mmap.c\nindex 51e70fa98450..547b40531791 100644\n--- a/mm/mmap.c\n+++ b/mm/mmap.c\n@@ -2554,11 +2554,10 @@ do_vmi_align_munmap(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \tmas_set(&mas_detach, start);\n \tremove_mt(mm, &mas_detach);\n \t__mt_destroy(&mt_detach);\n+\tvalidate_mm(mm);\n \tif (unlock)\n \t\tmmap_read_unlock(mm);\n \n-\n-\tvalidate_mm(mm);\n \treturn 0;\n \n clear_tree_failed:\n"
        ]
    },
    "7ba391f8e821454d748011f0dbd3ed0f862dfb78": {
        "non_crash": [
            "diff --git a/io_uring/cancel.c b/io_uring/cancel.c\nindex 2291a53cdabd..b4f5dfacc0c3 100644\n--- a/io_uring/cancel.c\n+++ b/io_uring/cancel.c\n@@ -288,24 +288,23 @@ int io_sync_cancel(struct io_ring_ctx *ctx, void __user *arg)\n \n \t\tret = __io_sync_cancel(current->io_uring, &cd, sc.fd);\n \n+\t\tmutex_unlock(&ctx->uring_lock);\n \t\tif (ret != -EALREADY)\n \t\t\tbreak;\n \n-\t\tmutex_unlock(&ctx->uring_lock);\n \t\tret = io_run_task_work_sig(ctx);\n-\t\tif (ret < 0) {\n-\t\t\tmutex_lock(&ctx->uring_lock);\n+\t\tif (ret < 0)\n \t\t\tbreak;\n-\t\t}\n \t\tret = schedule_hrtimeout(&timeout, HRTIMER_MODE_ABS);\n-\t\tmutex_lock(&ctx->uring_lock);\n \t\tif (!ret) {\n \t\t\tret = -ETIME;\n \t\t\tbreak;\n \t\t}\n+\t\tmutex_lock(&ctx->uring_lock);\n \t} while (1);\n \n \tfinish_wait(&ctx->cq_wait, &wait);\n+\tmutex_lock(&ctx->uring_lock);\n \n \tif (ret == -ENOENT || ret > 0)\n \t\tret = 0;\n"
        ]
    },
    "17ba20e86ace8566cff1a3ace9042a779bd8bb7c": {
        "non_crash": [
            "diff --git a/drivers/char/hw_random/virtio-rng.c b/drivers/char/hw_random/virtio-rng.c\nindex 208c547dcac1..173aeea835bb 100644\n--- a/drivers/char/hw_random/virtio-rng.c\n+++ b/drivers/char/hw_random/virtio-rng.c\n@@ -82,6 +82,11 @@ static int virtio_read(struct hwrng *rng, void *buf, size_t size, bool wait)\n \t\tret = wait_for_completion_killable(&vi->have_data);\n \t\tif (ret < 0)\n \t\t\treturn ret;\n+\t\t/* if vi->data_avail is 0, we have been interrupted\n+\t\t * by a cleanup, but buffer stays in the queue\n+\t\t */\n+\t\tif (vi->data_avail == 0)\n+\t\t\treturn read;\n \n \t\tchunk = min_t(unsigned int, size, vi->data_avail);\n \t\tmemcpy(buf + read, vi->data, chunk);\n@@ -105,7 +110,7 @@ static void virtio_cleanup(struct hwrng *rng)\n \tstruct virtrng_info *vi = (struct virtrng_info *)rng->priv;\n \n \tif (vi->busy)\n-\t\twait_for_completion(&vi->have_data);\n+\t\tcomplete(&vi->have_data);\n }\n \n static int probe_common(struct virtio_device *vdev)\n"
        ]
    },
    "4d37ad3f55c09b663fe33db0a19fc9684e805a81": {
        "non_crash": [
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 1e7f653c1df7..9cf6ba58f585 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -158,6 +158,7 @@ void nilfs_dat_commit_start(struct inode *dat, struct nilfs_palloc_req *req,\n int nilfs_dat_prepare_end(struct inode *dat, struct nilfs_palloc_req *req)\n {\n \tstruct nilfs_dat_entry *entry;\n+\t__u64 start;\n \tsector_t blocknr;\n \tvoid *kaddr;\n \tint ret;\n@@ -169,6 +170,7 @@ int nilfs_dat_prepare_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+\tstart = le64_to_cpu(entry->de_start);\n \tblocknr = le64_to_cpu(entry->de_blocknr);\n \tkunmap_atomic(kaddr);\n \n@@ -179,6 +181,15 @@ int nilfs_dat_prepare_end(struct inode *dat, struct nilfs_palloc_req *req)\n \t\t\treturn ret;\n \t\t}\n \t}\n+\tif (unlikely(start > nilfs_mdt_cno(dat))) {\n+\t\tnilfs_err(dat->i_sb,\n+\t\t\t  \"vblocknr = %llu has abnormal lifetime: start cno (= %llu) > current cno (= %llu)\",\n+\t\t\t  (unsigned long long)req->pr_entry_nr,\n+\t\t\t  (unsigned long long)start,\n+\t\t\t  (unsigned long long)nilfs_mdt_cno(dat));\n+\t\tnilfs_dat_abort_entry(dat, req);\n+\t\treturn -EINVAL;\n+\t}\n \n \treturn 0;\n }\n"
        ]
    },
    "d5cd7bc74de1e50a5139d45189395427cc5c3f63": {
        "non_crash": [
            "diff --git a/kernel/bpf/btf.c b/kernel/bpf/btf.c\nindex cad09858a5f2..546ebee39e2a 100644\n--- a/kernel/bpf/btf.c\n+++ b/kernel/bpf/btf.c\n@@ -1928,8 +1928,8 @@ 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-\tif (btf_type_is_resolve_source_only(index_type) ||\n-\t    btf_type_nosize_or_null(index_type)) {\n+\tif (btf_type_nosize_or_null(index_type) ||\n+\t    btf_type_is_resolve_source_only(index_type)) {\n \t\tbtf_verifier_log_type(env, v->t, \"Invalid index\");\n \t\treturn -EINVAL;\n \t}\n@@ -1948,8 +1948,8 @@ 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-\tif (btf_type_is_resolve_source_only(elem_type) ||\n-\t    btf_type_nosize_or_null(elem_type)) {\n+\tif (btf_type_nosize_or_null(elem_type) ||\n+\t    btf_type_is_resolve_source_only(elem_type)) {\n \t\tbtf_verifier_log_type(env, v->t,\n \t\t\t\t      \"Invalid elem\");\n \t\treturn -EINVAL;\n@@ -2170,8 +2170,8 @@ static int btf_struct_resolve(struct btf_verifier_env *env,\n \t\tconst struct btf_type *member_type = btf_type_by_id(env->btf,\n \t\t\t\t\t\t\t\tmember_type_id);\n \n-\t\tif (btf_type_is_resolve_source_only(member_type) ||\n-\t\t    btf_type_nosize_or_null(member_type)) {\n+\t\tif (btf_type_nosize_or_null(member_type) ||\n+\t\t    btf_type_is_resolve_source_only(member_type)) {\n \t\t\tbtf_verifier_log_member(env, v->t, member,\n \t\t\t\t\t\t\"Invalid member\");\n \t\t\treturn -EINVAL;\n"
        ]
    },
    "95277dbea9484baea60662d0243a93011a21ceb5": {
        "non_crash": [
            "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex ce5dfa3babd2..757ec46fc45a 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1090,7 +1090,7 @@ static int do_replace_finish(struct net *net, struct ebt_replace *repl,\n \n \taudit_log_nfcfg(repl->name, AF_BRIDGE, repl->nentries,\n \t\t\tAUDIT_XT_OP_REPLACE, GFP_KERNEL);\n-\treturn ret;\n+\treturn 0;\n \n free_unlock:\n \tmutex_unlock(&ebt_mutex);\ndiff --git a/net/ipv4/netfilter/ip_tables.c b/net/ipv4/netfilter/ip_tables.c\nindex 2ed7c58b471a..aae5fd51dfd7 100644\n--- a/net/ipv4/netfilter/ip_tables.c\n+++ b/net/ipv4/netfilter/ip_tables.c\n@@ -1045,7 +1045,6 @@ __do_replace(struct net *net, const char *name, unsigned int valid_hooks,\n \tstruct xt_counters *counters;\n \tstruct ipt_entry *iter;\n \n-\tret = 0;\n \tcounters = xt_counters_alloc(num_counters);\n \tif (!counters) {\n \t\tret = -ENOMEM;\n@@ -1091,7 +1090,7 @@ __do_replace(struct net *net, const char *name, unsigned int valid_hooks,\n \t\tnet_warn_ratelimited(\"iptables: counters copy to user failed while replacing table\\n\");\n \t}\n \tvfree(counters);\n-\treturn ret;\n+\treturn 0;\n \n  put_module:\n \tmodule_put(t->me);\ndiff --git a/net/ipv6/netfilter/ip6_tables.c b/net/ipv6/netfilter/ip6_tables.c\nindex 2d816277f2c5..ac902f7bca47 100644\n--- a/net/ipv6/netfilter/ip6_tables.c\n+++ b/net/ipv6/netfilter/ip6_tables.c\n@@ -1062,7 +1062,6 @@ __do_replace(struct net *net, const char *name, unsigned int valid_hooks,\n \tstruct xt_counters *counters;\n \tstruct ip6t_entry *iter;\n \n-\tret = 0;\n \tcounters = xt_counters_alloc(num_counters);\n \tif (!counters) {\n \t\tret = -ENOMEM;\n@@ -1108,7 +1107,7 @@ __do_replace(struct net *net, const char *name, unsigned int valid_hooks,\n \t\tnet_warn_ratelimited(\"ip6tables: counters copy to user failed while replacing table\\n\");\n \t}\n \tvfree(counters);\n-\treturn ret;\n+\treturn 0;\n \n  put_module:\n \tmodule_put(t->me);\n"
        ]
    },
    "6922c8c31f1fdd120d1cef3f58b319b6dd1d8c00": {
        "non_crash": [
            "diff --git a/drivers/misc/vmw_vmci/vmci_queue_pair.c b/drivers/misc/vmw_vmci/vmci_queue_pair.c\nindex 8531ae781195..c49065887e8f 100644\n--- a/drivers/misc/vmw_vmci/vmci_queue_pair.c\n+++ b/drivers/misc/vmw_vmci/vmci_queue_pair.c\n@@ -657,8 +657,9 @@ static int qp_host_get_user_memory(u64 produce_uva,\n \tif (retval < (int)produce_q->kernel_if->num_pages) {\n \t\tpr_debug(\"get_user_pages_fast(produce) failed (retval=%d)\",\n \t\t\tretval);\n-\t\tqp_release_pages(produce_q->kernel_if->u.h.header_page,\n-\t\t\t\t retval, false);\n+\t\tif (retval > 0)\n+\t\t\tqp_release_pages(produce_q->kernel_if->u.h.header_page,\n+\t\t\t\t\tretval, false);\n \t\terr = VMCI_ERROR_NO_MEM;\n \t\tgoto out;\n \t}\n@@ -670,8 +671,9 @@ static int qp_host_get_user_memory(u64 produce_uva,\n \tif (retval < (int)consume_q->kernel_if->num_pages) {\n \t\tpr_debug(\"get_user_pages_fast(consume) failed (retval=%d)\",\n \t\t\tretval);\n-\t\tqp_release_pages(consume_q->kernel_if->u.h.header_page,\n-\t\t\t\t retval, false);\n+\t\tif (retval > 0)\n+\t\t\tqp_release_pages(consume_q->kernel_if->u.h.header_page,\n+\t\t\t\t\tretval, false);\n \t\tqp_release_pages(produce_q->kernel_if->u.h.header_page,\n \t\t\t\t produce_q->kernel_if->num_pages, false);\n \t\terr = VMCI_ERROR_NO_MEM;\n"
        ]
    },
    "14f3125f37b7c76896b25c222159f6c205ff7e08": {
        "non_crash": [
            "diff --git a/net/wireless/core.h b/net/wireless/core.h\nindex e3e9686859d4..7df91f940212 100644\n--- a/net/wireless/core.h\n+++ b/net/wireless/core.h\n@@ -433,6 +433,8 @@ void cfg80211_sme_abandon_assoc(struct wireless_dev *wdev);\n \n /* internal helpers */\n bool cfg80211_supported_cipher_suite(struct wiphy *wiphy, u32 cipher);\n+bool cfg80211_valid_key_idx(struct cfg80211_registered_device *rdev,\n+\t\t\t    int key_idx, bool pairwise);\n int cfg80211_validate_key_settings(struct cfg80211_registered_device *rdev,\n \t\t\t\t   struct key_params *params, int key_idx,\n \t\t\t\t   bool pairwise, const u8 *mac_addr);\ndiff --git a/net/wireless/nl80211.c b/net/wireless/nl80211.c\nindex c8d31181a660..910872974f2d 100644\n--- a/net/wireless/nl80211.c\n+++ b/net/wireless/nl80211.c\n@@ -4239,9 +4239,6 @@ static int nl80211_del_key(struct sk_buff *skb, struct genl_info *info)\n \tif (err)\n \t\treturn err;\n \n-\tif (key.idx < 0)\n-\t\treturn -EINVAL;\n-\n \tif (info->attrs[NL80211_ATTR_MAC])\n \t\tmac_addr = nla_data(info->attrs[NL80211_ATTR_MAC]);\n \n@@ -4257,6 +4254,10 @@ static int nl80211_del_key(struct sk_buff *skb, struct genl_info *info)\n \t    key.type != NL80211_KEYTYPE_GROUP)\n \t\treturn -EINVAL;\n \n+\tif (!cfg80211_valid_key_idx(rdev, key.idx,\n+\t\t\t\t    key.type == NL80211_KEYTYPE_PAIRWISE))\n+\t\treturn -EINVAL;\n+\n \tif (!rdev->ops->del_key)\n \t\treturn -EOPNOTSUPP;\n \ndiff --git a/net/wireless/util.c b/net/wireless/util.c\nindex 79c5780e3033..b4acc805114b 100644\n--- a/net/wireless/util.c\n+++ b/net/wireless/util.c\n@@ -272,18 +272,53 @@ bool cfg80211_supported_cipher_suite(struct wiphy *wiphy, u32 cipher)\n \treturn false;\n }\n \n-int cfg80211_validate_key_settings(struct cfg80211_registered_device *rdev,\n-\t\t\t\t   struct key_params *params, int key_idx,\n-\t\t\t\t   bool pairwise, const u8 *mac_addr)\n+static bool\n+cfg80211_igtk_cipher_supported(struct cfg80211_registered_device *rdev)\n {\n-\tint max_key_idx = 5;\n+\tstruct wiphy *wiphy = &rdev->wiphy;\n+\tint i;\n+\n+\tfor (i = 0; i < wiphy->n_cipher_suites; i++) {\n+\t\tswitch (wiphy->cipher_suites[i]) {\n+\t\tcase WLAN_CIPHER_SUITE_AES_CMAC:\n+\t\tcase WLAN_CIPHER_SUITE_BIP_CMAC_256:\n+\t\tcase WLAN_CIPHER_SUITE_BIP_GMAC_128:\n+\t\tcase WLAN_CIPHER_SUITE_BIP_GMAC_256:\n+\t\t\treturn true;\n+\t\t}\n+\t}\n+\n+\treturn false;\n+}\n \n-\tif (wiphy_ext_feature_isset(&rdev->wiphy,\n-\t\t\t\t    NL80211_EXT_FEATURE_BEACON_PROTECTION) ||\n-\t    wiphy_ext_feature_isset(&rdev->wiphy,\n-\t\t\t\t    NL80211_EXT_FEATURE_BEACON_PROTECTION_CLIENT))\n+bool cfg80211_valid_key_idx(struct cfg80211_registered_device *rdev,\n+\t\t\t    int key_idx, bool pairwise)\n+{\n+\tint max_key_idx;\n+\n+\tif (pairwise)\n+\t\tmax_key_idx = 3;\n+\telse if (wiphy_ext_feature_isset(&rdev->wiphy,\n+\t\t\t\t\t NL80211_EXT_FEATURE_BEACON_PROTECTION) ||\n+\t\t wiphy_ext_feature_isset(&rdev->wiphy,\n+\t\t\t\t\t NL80211_EXT_FEATURE_BEACON_PROTECTION_CLIENT))\n \t\tmax_key_idx = 7;\n+\telse if (cfg80211_igtk_cipher_supported(rdev))\n+\t\tmax_key_idx = 5;\n+\telse\n+\t\tmax_key_idx = 3;\n+\n \tif (key_idx < 0 || key_idx > max_key_idx)\n+\t\treturn false;\n+\n+\treturn true;\n+}\n+\n+int cfg80211_validate_key_settings(struct cfg80211_registered_device *rdev,\n+\t\t\t\t   struct key_params *params, int key_idx,\n+\t\t\t\t   bool pairwise, const u8 *mac_addr)\n+{\n+\tif (!cfg80211_valid_key_idx(rdev, key_idx, pairwise))\n \t\treturn -EINVAL;\n \n \tif (!pairwise && mac_addr && !(rdev->wiphy.flags & WIPHY_FLAG_IBSS_RSN))\n"
        ]
    },
    "5e2e50e2c145ca06459e9e0900c20eefd1a0877e": {
        "non_crash": [
            "diff --git a/net/9p/trans_fd.c b/net/9p/trans_fd.c\nindex 56a186768750..bd28e63d7666 100644\n--- a/net/9p/trans_fd.c\n+++ b/net/9p/trans_fd.c\n@@ -202,9 +202,11 @@ static void p9_conn_cancel(struct p9_conn *m, int err)\n \n \tlist_for_each_entry_safe(req, rtmp, &m->req_list, req_list) {\n \t\tlist_move(&req->req_list, &cancel_list);\n+\t\treq->status = REQ_STATUS_ERROR;\n \t}\n \tlist_for_each_entry_safe(req, rtmp, &m->unsent_req_list, req_list) {\n \t\tlist_move(&req->req_list, &cancel_list);\n+\t\treq->status = REQ_STATUS_ERROR;\n \t}\n \n \tspin_unlock(&m->req_lock);\n"
        ]
    },
    "d905b9cf668a6fd23e8268008fff061b302d6fb5": {
        "non_crash": [
            "diff --git a/lib/percpu-refcount.c b/lib/percpu-refcount.c\nindex af9302141bcf..e5c5315da274 100644\n--- a/lib/percpu-refcount.c\n+++ b/lib/percpu-refcount.c\n@@ -76,6 +76,7 @@ int percpu_ref_init(struct percpu_ref *ref, percpu_ref_func_t *release,\n \tdata = kzalloc(sizeof(*ref->data), gfp);\n \tif (!data) {\n \t\tfree_percpu((void __percpu *)ref->percpu_count_ptr);\n+\t\tref->percpu_count_ptr = 0;\n \t\treturn -ENOMEM;\n \t}\n \n"
        ]
    },
    "37556d70764e226e660023fad17c9c0316cb6f1d": {
        "non_crash": [
            "diff --git a/fs/fs-writeback.c b/fs/fs-writeback.c\nindex 443f83382b9b..9958d4020771 100644\n--- a/fs/fs-writeback.c\n+++ b/fs/fs-writeback.c\n@@ -1712,18 +1712,26 @@ static int writeback_single_inode(struct inode *inode,\n \twb = inode_to_wb_and_lock_list(inode);\n \tspin_lock(&inode->i_lock);\n \t/*\n-\t * If the inode is now fully clean, then it can be safely removed from\n-\t * its writeback list (if any).  Otherwise the flusher threads are\n-\t * responsible for the writeback lists.\n+\t * If the inode is freeing, its i_io_list shoudn't be updated\n+\t * as it can be finally deleted at this moment.\n \t */\n-\tif (!(inode->i_state & I_DIRTY_ALL))\n-\t\tinode_cgwb_move_to_attached(inode, wb);\n-\telse if (!(inode->i_state & I_SYNC_QUEUED)) {\n-\t\tif ((inode->i_state & I_DIRTY))\n-\t\t\tredirty_tail_locked(inode, wb);\n-\t\telse if (inode->i_state & I_DIRTY_TIME) {\n-\t\t\tinode->dirtied_when = jiffies;\n-\t\t\tinode_io_list_move_locked(inode, wb, &wb->b_dirty_time);\n+\tif (!(inode->i_state & I_FREEING)) {\n+\t\t/*\n+\t\t * If the inode is now fully clean, then it can be safely\n+\t\t * removed from its writeback list (if any). Otherwise the\n+\t\t * flusher threads are responsible for the writeback lists.\n+\t\t */\n+\t\tif (!(inode->i_state & I_DIRTY_ALL))\n+\t\t\tinode_cgwb_move_to_attached(inode, wb);\n+\t\telse if (!(inode->i_state & I_SYNC_QUEUED)) {\n+\t\t\tif ((inode->i_state & I_DIRTY))\n+\t\t\t\tredirty_tail_locked(inode, wb);\n+\t\t\telse if (inode->i_state & I_DIRTY_TIME) {\n+\t\t\t\tinode->dirtied_when = jiffies;\n+\t\t\t\tinode_io_list_move_locked(inode,\n+\t\t\t\t\t\t\t  wb,\n+\t\t\t\t\t\t\t  &wb->b_dirty_time);\n+\t\t\t}\n \t\t}\n \t}\n \n"
        ]
    },
    "251bb5cec78ffc6f0f277696516aafb04b1e1bd9": {
        "non_crash": [
            "diff --git a/kernel/bpf/log.c b/kernel/bpf/log.c\nindex 046ddff37a76..850494423530 100644\n--- a/kernel/bpf/log.c\n+++ b/kernel/bpf/log.c\n@@ -62,9 +62,6 @@ void bpf_verifier_vlog(struct bpf_verifier_log *log, const char *fmt,\n \n \tn = vscnprintf(log->kbuf, BPF_VERIFIER_TMP_LOG_SIZE, fmt, args);\n \n-\tWARN_ONCE(n >= BPF_VERIFIER_TMP_LOG_SIZE - 1,\n-\t\t  \"verifier log line truncated - local buffer too short\\n\");\n-\n \tif (log->level == BPF_LOG_KERNEL) {\n \t\tbool newline = n > 0 && log->kbuf[n - 1] == '\\n';\n \n"
        ]
    },
    "ef9605001826ed9db7e9ae5b0c08ec9b347a5148": {
        "non_crash": [
            "diff --git a/io_uring/fdinfo.c b/io_uring/fdinfo.c\nindex 300455b4bc12..c53678875416 100644\n--- a/io_uring/fdinfo.c\n+++ b/io_uring/fdinfo.c\n@@ -93,6 +93,8 @@ __cold void io_uring_show_fdinfo(struct seq_file *m, struct file *f)\n \t\tstruct io_uring_sqe *sqe;\n \t\tunsigned int sq_idx;\n \n+\t\tif (ctx->flags & IORING_SETUP_NO_SQARRAY)\n+\t\t\tbreak;\n \t\tsq_idx = READ_ONCE(ctx->sq_array[entry & sq_mask]);\n \t\tif (sq_idx > sq_mask)\n \t\t\tcontinue;\n"
        ]
    },
    "b5d799a2cc619607ed6e322f97f78eaf534451e1": {
        "non_crash": [
            "diff --git a/fs/gfs2/ops_fstype.c b/fs/gfs2/ops_fstype.c\nindex c2469833b4fb..6b84ef6ccff3 100644\n--- a/fs/gfs2/ops_fstype.c\n+++ b/fs/gfs2/ops_fstype.c\n@@ -1333,6 +1333,9 @@ static struct dentry *gfs2_mount_meta(struct file_system_type *fs_type,\n \tstruct path path;\n \tint error;\n \n+\tif (!dev_name || !*dev_name)\n+\t\treturn ERR_PTR(-EINVAL);\n+\n \terror = kern_path(dev_name, LOOKUP_FOLLOW, &path);\n \tif (error) {\n \t\tpr_warn(\"path_lookup on %s returned error %d\\n\",\n"
        ]
    },
    "e675fbaf856bd1465eed8b8f51ae182b58b8d656": {
        "non_crash": [
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex bc0f15257b49..6836e937ee61 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -4183,9 +4183,9 @@ static int do_mount_setattr(struct path *path, struct mount_kattr *kattr)\n \tunlock_mount_hash();\n \n \tif (kattr->propagation) {\n-\t\tnamespace_unlock();\n \t\tif (err)\n \t\t\tcleanup_group_ids(mnt, NULL);\n+\t\tnamespace_unlock();\n \t}\n \n \treturn err;\n"
        ]
    },
    "daa1858cc0258eb026f89eecf342f6b3fdad7b05": {
        "non_crash": [
            "diff --git a/net/sched/ematch.c b/net/sched/ematch.c\nindex 4ce681361851..5c1235e6076a 100644\n--- a/net/sched/ematch.c\n+++ b/net/sched/ematch.c\n@@ -255,6 +255,8 @@ static int tcf_em_validate(struct tcf_proto *tp,\n \t\t\t * the value carried.\n \t\t\t */\n \t\t\tif (em_hdr->flags & TCF_EM_SIMPLE) {\n+\t\t\t\tif (em->ops->datalen > 0)\n+\t\t\t\t\tgoto errout;\n \t\t\t\tif (data_len < sizeof(u32))\n \t\t\t\t\tgoto errout;\n \t\t\t\tem->data = *(u32 *) data;\n"
        ]
    },
    "789df5b54ebd19aec0b5c3900c933d1910db8ec5": {
        "non_crash": [
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex 6bdd502527f8..b666d3bf8b38 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 = kvmalloc(value_size, GFP_NOFS);\n \tb_entry_name = kmalloc(entry->e_name_len + 1, GFP_NOFS);\n \tif (!is || !bs || !buffer || !b_entry_name) {\n \t\terror = -ENOMEM;\n@@ -2600,7 +2600,7 @@ static int ext4_xattr_move_to_block(handle_t *handle, struct inode *inode,\n \terror = 0;\n out:\n \tkfree(b_entry_name);\n-\tkfree(buffer);\n+\tkvfree(buffer);\n \tif (is)\n \t\tbrelse(is->iloc.bh);\n \tif (bs)\n"
        ]
    },
    "a8afc55e6cd0cac79fd97a5c0d2272751dc558fc": {
        "non_crash": [
            "diff --git a/drivers/media/platform/vim2m.c b/drivers/media/platform/vim2m.c\nindex 035c7b7c8d87..d01821a6906a 100644\n--- a/drivers/media/platform/vim2m.c\n+++ b/drivers/media/platform/vim2m.c\n@@ -803,10 +803,11 @@ static int vim2m_start_streaming(struct vb2_queue *q, unsigned count)\n static void vim2m_stop_streaming(struct vb2_queue *q)\n {\n \tstruct vim2m_ctx *ctx = vb2_get_drv_priv(q);\n+\tstruct vim2m_dev *dev = ctx->dev;\n \tstruct vb2_v4l2_buffer *vbuf;\n \tunsigned long flags;\n \n-\tflush_scheduled_work();\n+\tcancel_delayed_work_sync(&dev->work_run);\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"
        ]
    },
    "5d48b50ed679f22d7d4a4b578da8559d34b104ac": {
        "non_crash": [
            "diff --git a/kernel/cgroup/cgroup.c b/kernel/cgroup/cgroup.c\nindex 8afa8690d288..570b0c97392a 100644\n--- a/kernel/cgroup/cgroup.c\n+++ b/kernel/cgroup/cgroup.c\n@@ -6574,22 +6574,29 @@ int cgroup_parse_float(const char *input, unsigned dec_shift, s64 *v)\n \n void cgroup_sk_alloc(struct sock_cgroup_data *skcd)\n {\n-\t/* Don't associate the sock with unrelated interrupted task's cgroup. */\n-\tif (in_interrupt())\n-\t\treturn;\n+\tstruct cgroup *cgroup;\n \n \trcu_read_lock();\n+\t/* Don't associate the sock with unrelated interrupted task's cgroup. */\n+\tif (in_interrupt()) {\n+\t\tcgroup = &cgrp_dfl_root.cgrp;\n+\t\tcgroup_get(cgroup);\n+\t\tgoto out;\n+\t}\n+\n \twhile (true) {\n \t\tstruct css_set *cset;\n \n \t\tcset = task_css_set(current);\n \t\tif (likely(cgroup_tryget(cset->dfl_cgrp))) {\n-\t\t\tskcd->cgroup = cset->dfl_cgrp;\n-\t\t\tcgroup_bpf_get(cset->dfl_cgrp);\n+\t\t\tcgroup = cset->dfl_cgrp;\n \t\t\tbreak;\n \t\t}\n \t\tcpu_relax();\n \t}\n+out:\n+\tskcd->cgroup = cgroup;\n+\tcgroup_bpf_get(cgroup);\n \trcu_read_unlock();\n }\n \n"
        ]
    },
    "0ec05481e31f2772a2c6f16aecb38f48467da26e": {
        "non_crash": [
            "diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c\nindex 1971ca325fb4..6dd419550aba 100644\n--- a/kernel/bpf/verifier.c\n+++ b/kernel/bpf/verifier.c\n@@ -5650,7 +5650,7 @@ static void adjust_subprog_starts(struct bpf_verifier_env *env, u32 off, u32 len\n \t\treturn;\n \t/* NOTE: fake 'exit' subprog should be updated as well. */\n \tfor (i = 0; i <= env->subprog_cnt; i++) {\n-\t\tif (env->subprog_info[i].start < off)\n+\t\tif (env->subprog_info[i].start <= off)\n \t\t\tcontinue;\n \t\tenv->subprog_info[i].start += len - 1;\n \t}\ndiff --git a/tools/testing/selftests/bpf/test_verifier.c b/tools/testing/selftests/bpf/test_verifier.c\nindex 6f61df62f690..550b7e46bf4a 100644\n--- a/tools/testing/selftests/bpf/test_verifier.c\n+++ b/tools/testing/selftests/bpf/test_verifier.c\n@@ -13896,6 +13896,25 @@ static struct bpf_test tests[] = {\n \t\t.prog_type = BPF_PROG_TYPE_SCHED_CLS,\n \t\t.result = ACCEPT,\n \t},\n+\t{\n+\t\t\"calls: ctx read at start of subprog\",\n+\t\t.insns = {\n+\t\t\tBPF_MOV64_REG(BPF_REG_6, BPF_REG_1),\n+\t\t\tBPF_RAW_INSN(BPF_JMP | BPF_CALL, 0, 1, 0, 5),\n+\t\t\tBPF_JMP_REG(BPF_JSGT, BPF_REG_0, BPF_REG_0, 0),\n+\t\t\tBPF_MOV64_REG(BPF_REG_1, BPF_REG_6),\n+\t\t\tBPF_RAW_INSN(BPF_JMP | BPF_CALL, 0, 1, 0, 2),\n+\t\t\tBPF_MOV64_REG(BPF_REG_1, BPF_REG_0),\n+\t\t\tBPF_EXIT_INSN(),\n+\t\t\tBPF_LDX_MEM(BPF_B, BPF_REG_9, BPF_REG_1, 0),\n+\t\t\tBPF_MOV64_IMM(BPF_REG_0, 0),\n+\t\t\tBPF_EXIT_INSN(),\n+\t\t},\n+\t\t.prog_type = BPF_PROG_TYPE_SOCKET_FILTER,\n+\t\t.errstr_unpriv = \"function calls to other bpf functions are allowed for root only\",\n+\t\t.result_unpriv = REJECT,\n+\t\t.result = ACCEPT,\n+\t},\n };\n \n static int probe_filter_length(const struct bpf_insn *fp)\n"
        ]
    },
    "b5ecc684bb9e49db213e88f69d4ce80f7e20238d": {
        "non_crash": [
            "diff --git a/drivers/nfc/virtual_ncidev.c b/drivers/nfc/virtual_ncidev.c\nindex 85c06dbb2c44..bb76c7c7cc82 100644\n--- a/drivers/nfc/virtual_ncidev.c\n+++ b/drivers/nfc/virtual_ncidev.c\n@@ -13,12 +13,6 @@\n #include <linux/wait.h>\n #include <net/nfc/nci_core.h>\n \n-enum virtual_ncidev_mode {\n-\tvirtual_ncidev_enabled,\n-\tvirtual_ncidev_disabled,\n-\tvirtual_ncidev_disabling,\n-};\n-\n #define IOCTL_GET_NCIDEV_IDX    0\n #define VIRTUAL_NFC_PROTOCOLS\t(NFC_PROTO_JEWEL_MASK | \\\n \t\t\t\t NFC_PROTO_MIFARE_MASK | \\\n@@ -27,12 +21,12 @@ enum virtual_ncidev_mode {\n \t\t\t\t NFC_PROTO_ISO14443_B_MASK | \\\n \t\t\t\t NFC_PROTO_ISO15693_MASK)\n \n-static enum virtual_ncidev_mode state;\n-static DECLARE_WAIT_QUEUE_HEAD(wq);\n-static struct miscdevice miscdev;\n-static struct sk_buff *send_buff;\n-static struct nci_dev *ndev;\n-static DEFINE_MUTEX(nci_mutex);\n+struct virtual_nci_dev {\n+\tstruct nci_dev *ndev;\n+\tstruct mutex mtx;\n+\tstruct sk_buff *send_buff;\n+\tstruct wait_queue_head wq;\n+};\n \n static int virtual_nci_open(struct nci_dev *ndev)\n {\n@@ -41,31 +35,34 @@ static int virtual_nci_open(struct nci_dev *ndev)\n \n static int virtual_nci_close(struct nci_dev *ndev)\n {\n-\tmutex_lock(&nci_mutex);\n-\tkfree_skb(send_buff);\n-\tsend_buff = NULL;\n-\tmutex_unlock(&nci_mutex);\n+\tstruct virtual_nci_dev *vdev = nci_get_drvdata(ndev);\n+\n+\tmutex_lock(&vdev->mtx);\n+\tkfree_skb(vdev->send_buff);\n+\tvdev->send_buff = NULL;\n+\tmutex_unlock(&vdev->mtx);\n \n \treturn 0;\n }\n \n static int virtual_nci_send(struct nci_dev *ndev, struct sk_buff *skb)\n {\n-\tmutex_lock(&nci_mutex);\n-\tif (state != virtual_ncidev_enabled) {\n-\t\tmutex_unlock(&nci_mutex);\n+\tstruct virtual_nci_dev *vdev = nci_get_drvdata(ndev);\n+\n+\tmutex_lock(&vdev->mtx);\n+\tif (vdev->send_buff) {\n+\t\tmutex_unlock(&vdev->mtx);\n \t\tkfree_skb(skb);\n-\t\treturn 0;\n+\t\treturn -1;\n \t}\n-\n-\tif (send_buff) {\n-\t\tmutex_unlock(&nci_mutex);\n+\tvdev->send_buff = skb_copy(skb, GFP_KERNEL);\n+\tif (!vdev->send_buff) {\n+\t\tmutex_unlock(&vdev->mtx);\n \t\tkfree_skb(skb);\n \t\treturn -1;\n \t}\n-\tsend_buff = skb_copy(skb, GFP_KERNEL);\n-\tmutex_unlock(&nci_mutex);\n-\twake_up_interruptible(&wq);\n+\tmutex_unlock(&vdev->mtx);\n+\twake_up_interruptible(&vdev->wq);\n \tconsume_skb(skb);\n \n \treturn 0;\n@@ -80,29 +77,30 @@ static const struct nci_ops virtual_nci_ops = {\n static ssize_t virtual_ncidev_read(struct file *file, char __user *buf,\n \t\t\t\t   size_t count, loff_t *ppos)\n {\n+\tstruct virtual_nci_dev *vdev = file->private_data;\n \tsize_t actual_len;\n \n-\tmutex_lock(&nci_mutex);\n-\twhile (!send_buff) {\n-\t\tmutex_unlock(&nci_mutex);\n-\t\tif (wait_event_interruptible(wq, send_buff))\n+\tmutex_lock(&vdev->mtx);\n+\twhile (!vdev->send_buff) {\n+\t\tmutex_unlock(&vdev->mtx);\n+\t\tif (wait_event_interruptible(vdev->wq, vdev->send_buff))\n \t\t\treturn -EFAULT;\n-\t\tmutex_lock(&nci_mutex);\n+\t\tmutex_lock(&vdev->mtx);\n \t}\n \n-\tactual_len = min_t(size_t, count, send_buff->len);\n+\tactual_len = min_t(size_t, count, vdev->send_buff->len);\n \n-\tif (copy_to_user(buf, send_buff->data, actual_len)) {\n-\t\tmutex_unlock(&nci_mutex);\n+\tif (copy_to_user(buf, vdev->send_buff->data, actual_len)) {\n+\t\tmutex_unlock(&vdev->mtx);\n \t\treturn -EFAULT;\n \t}\n \n-\tskb_pull(send_buff, actual_len);\n-\tif (send_buff->len == 0) {\n-\t\tconsume_skb(send_buff);\n-\t\tsend_buff = NULL;\n+\tskb_pull(vdev->send_buff, actual_len);\n+\tif (vdev->send_buff->len == 0) {\n+\t\tconsume_skb(vdev->send_buff);\n+\t\tvdev->send_buff = NULL;\n \t}\n-\tmutex_unlock(&nci_mutex);\n+\tmutex_unlock(&vdev->mtx);\n \n \treturn actual_len;\n }\n@@ -111,6 +109,7 @@ static ssize_t virtual_ncidev_write(struct file *file,\n \t\t\t\t    const char __user *buf,\n \t\t\t\t    size_t count, loff_t *ppos)\n {\n+\tstruct virtual_nci_dev *vdev = file->private_data;\n \tstruct sk_buff *skb;\n \n \tskb = alloc_skb(count, GFP_KERNEL);\n@@ -122,63 +121,58 @@ static ssize_t virtual_ncidev_write(struct file *file,\n \t\treturn -EFAULT;\n \t}\n \n-\tnci_recv_frame(ndev, skb);\n+\tnci_recv_frame(vdev->ndev, skb);\n \treturn count;\n }\n \n static int virtual_ncidev_open(struct inode *inode, struct file *file)\n {\n \tint ret = 0;\n+\tstruct virtual_nci_dev *vdev;\n \n-\tmutex_lock(&nci_mutex);\n-\tif (state != virtual_ncidev_disabled) {\n-\t\tmutex_unlock(&nci_mutex);\n-\t\treturn -EBUSY;\n-\t}\n-\n-\tndev = nci_allocate_device(&virtual_nci_ops, VIRTUAL_NFC_PROTOCOLS,\n-\t\t\t\t   0, 0);\n-\tif (!ndev) {\n-\t\tmutex_unlock(&nci_mutex);\n+\tvdev = kzalloc(sizeof(*vdev), GFP_KERNEL);\n+\tif (!vdev)\n+\t\treturn -ENOMEM;\n+\tvdev->ndev = nci_allocate_device(&virtual_nci_ops,\n+\t\tVIRTUAL_NFC_PROTOCOLS, 0, 0);\n+\tif (!vdev->ndev) {\n+\t\tkfree(vdev);\n \t\treturn -ENOMEM;\n \t}\n \n-\tret = nci_register_device(ndev);\n+\tmutex_init(&vdev->mtx);\n+\tinit_waitqueue_head(&vdev->wq);\n+\tfile->private_data = vdev;\n+\tnci_set_drvdata(vdev->ndev, vdev);\n+\n+\tret = nci_register_device(vdev->ndev);\n \tif (ret < 0) {\n-\t\tnci_free_device(ndev);\n-\t\tmutex_unlock(&nci_mutex);\n+\t\tnci_free_device(vdev->ndev);\n+\t\tmutex_destroy(&vdev->mtx);\n+\t\tkfree(vdev);\n \t\treturn ret;\n \t}\n-\tstate = virtual_ncidev_enabled;\n-\tmutex_unlock(&nci_mutex);\n \n \treturn 0;\n }\n \n static int virtual_ncidev_close(struct inode *inode, struct file *file)\n {\n-\tmutex_lock(&nci_mutex);\n-\n-\tif (state == virtual_ncidev_enabled) {\n-\t\tstate = virtual_ncidev_disabling;\n-\t\tmutex_unlock(&nci_mutex);\n+\tstruct virtual_nci_dev *vdev = file->private_data;\n \n-\t\tnci_unregister_device(ndev);\n-\t\tnci_free_device(ndev);\n-\n-\t\tmutex_lock(&nci_mutex);\n-\t}\n-\n-\tstate = virtual_ncidev_disabled;\n-\tmutex_unlock(&nci_mutex);\n+\tnci_unregister_device(vdev->ndev);\n+\tnci_free_device(vdev->ndev);\n+\tmutex_destroy(&vdev->mtx);\n+\tkfree(vdev);\n \n \treturn 0;\n }\n \n-static long virtual_ncidev_ioctl(struct file *flip, unsigned int cmd,\n+static long virtual_ncidev_ioctl(struct file *file, unsigned int cmd,\n \t\t\t\t unsigned long arg)\n {\n-\tconst struct nfc_dev *nfc_dev = ndev->nfc_dev;\n+\tstruct virtual_nci_dev *vdev = file->private_data;\n+\tconst struct nfc_dev *nfc_dev = vdev->ndev->nfc_dev;\n \tvoid __user *p = (void __user *)arg;\n \n \tif (cmd != IOCTL_GET_NCIDEV_IDX)\n@@ -199,14 +193,15 @@ static const struct file_operations virtual_ncidev_fops = {\n \t.unlocked_ioctl = virtual_ncidev_ioctl\n };\n \n+static struct miscdevice miscdev = {\n+\t.minor = MISC_DYNAMIC_MINOR,\n+\t.name = \"virtual_nci\",\n+\t.fops = &virtual_ncidev_fops,\n+\t.mode = 0600,\n+};\n+\n static int __init virtual_ncidev_init(void)\n {\n-\tstate = virtual_ncidev_disabled;\n-\tmiscdev.minor = MISC_DYNAMIC_MINOR;\n-\tmiscdev.name = \"virtual_nci\";\n-\tmiscdev.fops = &virtual_ncidev_fops;\n-\tmiscdev.mode = 0600;\n-\n \treturn misc_register(&miscdev);\n }\n \n"
        ]
    },
    "75b0feac9a3f9e361fd60605e261f8a4ffef1c40": {
        "non_crash": [
            "diff --git a/mm/secretmem.c b/mm/secretmem.c\nindex 206ed6b40c1d..f06279d6190a 100644\n--- a/mm/secretmem.c\n+++ b/mm/secretmem.c\n@@ -55,22 +55,28 @@ static vm_fault_t secretmem_fault(struct vm_fault *vmf)\n \tgfp_t gfp = vmf->gfp_mask;\n \tunsigned long addr;\n \tstruct page *page;\n+\tvm_fault_t ret;\n \tint err;\n \n \tif (((loff_t)vmf->pgoff << PAGE_SHIFT) >= i_size_read(inode))\n \t\treturn vmf_error(-EINVAL);\n \n+\tfilemap_invalidate_lock_shared(mapping);\n+\n retry:\n \tpage = find_lock_page(mapping, offset);\n \tif (!page) {\n \t\tpage = alloc_page(gfp | __GFP_ZERO);\n-\t\tif (!page)\n-\t\t\treturn VM_FAULT_OOM;\n+\t\tif (!page) {\n+\t\t\tret = VM_FAULT_OOM;\n+\t\t\tgoto out;\n+\t\t}\n \n \t\terr = set_direct_map_invalid_noflush(page);\n \t\tif (err) {\n \t\t\tput_page(page);\n-\t\t\treturn vmf_error(err);\n+\t\t\tret = vmf_error(err);\n+\t\t\tgoto out;\n \t\t}\n \n \t\t__SetPageUptodate(page);\n@@ -86,7 +92,8 @@ static vm_fault_t secretmem_fault(struct vm_fault *vmf)\n \t\t\tif (err == -EEXIST)\n \t\t\t\tgoto retry;\n \n-\t\t\treturn vmf_error(err);\n+\t\t\tret = vmf_error(err);\n+\t\t\tgoto out;\n \t\t}\n \n \t\taddr = (unsigned long)page_address(page);\n@@ -94,7 +101,11 @@ static vm_fault_t secretmem_fault(struct vm_fault *vmf)\n \t}\n \n \tvmf->page = page;\n-\treturn VM_FAULT_LOCKED;\n+\tret = VM_FAULT_LOCKED;\n+\n+out:\n+\tfilemap_invalidate_unlock_shared(mapping);\n+\treturn ret;\n }\n \n static const struct vm_operations_struct secretmem_vm_ops = {\n@@ -162,12 +173,20 @@ static int secretmem_setattr(struct user_namespace *mnt_userns,\n \t\t\t     struct dentry *dentry, struct iattr *iattr)\n {\n \tstruct inode *inode = d_inode(dentry);\n+\tstruct address_space *mapping = inode->i_mapping;\n \tunsigned int ia_valid = iattr->ia_valid;\n+\tint ret;\n+\n+\tfilemap_invalidate_lock(mapping);\n \n \tif ((ia_valid & ATTR_SIZE) && inode->i_size)\n-\t\treturn -EINVAL;\n+\t\tret = -EINVAL;\n+\telse\n+\t\tret = simple_setattr(mnt_userns, dentry, iattr);\n \n-\treturn simple_setattr(mnt_userns, dentry, iattr);\n+\tfilemap_invalidate_unlock(mapping);\n+\n+\treturn ret;\n }\n \n static const struct inode_operations secretmem_iops = {\n"
        ]
    },
    "6bb7224cd01f8742533b486573005f65d512fdf6": {
        "non_crash": [
            "diff --git a/include/net/sctp/stream_sched.h b/include/net/sctp/stream_sched.h\nindex 01a70b27e026..65058faea4db 100644\n--- a/include/net/sctp/stream_sched.h\n+++ b/include/net/sctp/stream_sched.h\n@@ -26,6 +26,8 @@ struct sctp_sched_ops {\n \tint (*init)(struct sctp_stream *stream);\n \t/* Init a stream */\n \tint (*init_sid)(struct sctp_stream *stream, __u16 sid, gfp_t gfp);\n+\t/* free a stream */\n+\tvoid (*free_sid)(struct sctp_stream *stream, __u16 sid);\n \t/* Frees the entire thing */\n \tvoid (*free)(struct sctp_stream *stream);\n \ndiff --git a/net/sctp/stream.c b/net/sctp/stream.c\nindex ef9fceadef8d..ee6514af830f 100644\n--- a/net/sctp/stream.c\n+++ b/net/sctp/stream.c\n@@ -52,6 +52,19 @@ static void sctp_stream_shrink_out(struct sctp_stream *stream, __u16 outcnt)\n \t}\n }\n \n+static void sctp_stream_free_ext(struct sctp_stream *stream, __u16 sid)\n+{\n+\tstruct sctp_sched_ops *sched;\n+\n+\tif (!SCTP_SO(stream, sid)->ext)\n+\t\treturn;\n+\n+\tsched = sctp_sched_ops_from_stream(stream);\n+\tsched->free_sid(stream, sid);\n+\tkfree(SCTP_SO(stream, sid)->ext);\n+\tSCTP_SO(stream, sid)->ext = NULL;\n+}\n+\n /* Migrates chunks from stream queues to new stream queues if needed,\n  * but not across associations. Also, removes those chunks to streams\n  * higher than the new max.\n@@ -70,16 +83,14 @@ static void sctp_stream_outq_migrate(struct sctp_stream *stream,\n \t\t * sctp_stream_update will swap ->out pointers.\n \t\t */\n \t\tfor (i = 0; i < outcnt; i++) {\n-\t\t\tkfree(SCTP_SO(new, i)->ext);\n+\t\t\tsctp_stream_free_ext(new, i);\n \t\t\tSCTP_SO(new, i)->ext = SCTP_SO(stream, i)->ext;\n \t\t\tSCTP_SO(stream, i)->ext = NULL;\n \t\t}\n \t}\n \n-\tfor (i = outcnt; i < stream->outcnt; i++) {\n-\t\tkfree(SCTP_SO(stream, i)->ext);\n-\t\tSCTP_SO(stream, i)->ext = NULL;\n-\t}\n+\tfor (i = outcnt; i < stream->outcnt; i++)\n+\t\tsctp_stream_free_ext(stream, i);\n }\n \n static int sctp_stream_alloc_out(struct sctp_stream *stream, __u16 outcnt,\n@@ -174,9 +185,9 @@ void sctp_stream_free(struct sctp_stream *stream)\n \tstruct sctp_sched_ops *sched = sctp_sched_ops_from_stream(stream);\n \tint i;\n \n-\tsched->free(stream);\n+\tsched->unsched_all(stream);\n \tfor (i = 0; i < stream->outcnt; i++)\n-\t\tkfree(SCTP_SO(stream, i)->ext);\n+\t\tsctp_stream_free_ext(stream, i);\n \tgenradix_free(&stream->out);\n \tgenradix_free(&stream->in);\n }\ndiff --git a/net/sctp/stream_sched.c b/net/sctp/stream_sched.c\nindex 1ad565ed5627..7c8f9d89e16a 100644\n--- a/net/sctp/stream_sched.c\n+++ b/net/sctp/stream_sched.c\n@@ -46,6 +46,10 @@ static int sctp_sched_fcfs_init_sid(struct sctp_stream *stream, __u16 sid,\n \treturn 0;\n }\n \n+static void sctp_sched_fcfs_free_sid(struct sctp_stream *stream, __u16 sid)\n+{\n+}\n+\n static void sctp_sched_fcfs_free(struct sctp_stream *stream)\n {\n }\n@@ -96,6 +100,7 @@ static struct sctp_sched_ops sctp_sched_fcfs = {\n \t.get = sctp_sched_fcfs_get,\n \t.init = sctp_sched_fcfs_init,\n \t.init_sid = sctp_sched_fcfs_init_sid,\n+\t.free_sid = sctp_sched_fcfs_free_sid,\n \t.free = sctp_sched_fcfs_free,\n \t.enqueue = sctp_sched_fcfs_enqueue,\n \t.dequeue = sctp_sched_fcfs_dequeue,\ndiff --git a/net/sctp/stream_sched_prio.c b/net/sctp/stream_sched_prio.c\nindex 80b5a2c4cbc7..4fc9f2923ed1 100644\n--- a/net/sctp/stream_sched_prio.c\n+++ b/net/sctp/stream_sched_prio.c\n@@ -204,6 +204,24 @@ static int sctp_sched_prio_init_sid(struct sctp_stream *stream, __u16 sid,\n \treturn sctp_sched_prio_set(stream, sid, 0, gfp);\n }\n \n+static void sctp_sched_prio_free_sid(struct sctp_stream *stream, __u16 sid)\n+{\n+\tstruct sctp_stream_priorities *prio = SCTP_SO(stream, sid)->ext->prio_head;\n+\tint i;\n+\n+\tif (!prio)\n+\t\treturn;\n+\n+\tSCTP_SO(stream, sid)->ext->prio_head = NULL;\n+\tfor (i = 0; i < stream->outcnt; i++) {\n+\t\tif (SCTP_SO(stream, i)->ext &&\n+\t\t    SCTP_SO(stream, i)->ext->prio_head == prio)\n+\t\t\treturn;\n+\t}\n+\n+\tkfree(prio);\n+}\n+\n static void sctp_sched_prio_free(struct sctp_stream *stream)\n {\n \tstruct sctp_stream_priorities *prio, *n;\n@@ -323,6 +341,7 @@ static struct sctp_sched_ops sctp_sched_prio = {\n \t.get = sctp_sched_prio_get,\n \t.init = sctp_sched_prio_init,\n \t.init_sid = sctp_sched_prio_init_sid,\n+\t.free_sid = sctp_sched_prio_free_sid,\n \t.free = sctp_sched_prio_free,\n \t.enqueue = sctp_sched_prio_enqueue,\n \t.dequeue = sctp_sched_prio_dequeue,\ndiff --git a/net/sctp/stream_sched_rr.c b/net/sctp/stream_sched_rr.c\nindex ff425aed62c7..cc444fe0d67c 100644\n--- a/net/sctp/stream_sched_rr.c\n+++ b/net/sctp/stream_sched_rr.c\n@@ -90,6 +90,10 @@ static int sctp_sched_rr_init_sid(struct sctp_stream *stream, __u16 sid,\n \treturn 0;\n }\n \n+static void sctp_sched_rr_free_sid(struct sctp_stream *stream, __u16 sid)\n+{\n+}\n+\n static void sctp_sched_rr_free(struct sctp_stream *stream)\n {\n \tsctp_sched_rr_unsched_all(stream);\n@@ -177,6 +181,7 @@ static struct sctp_sched_ops sctp_sched_rr = {\n \t.get = sctp_sched_rr_get,\n \t.init = sctp_sched_rr_init,\n \t.init_sid = sctp_sched_rr_init_sid,\n+\t.free_sid = sctp_sched_rr_free_sid,\n \t.free = sctp_sched_rr_free,\n \t.enqueue = sctp_sched_rr_enqueue,\n \t.dequeue = sctp_sched_rr_dequeue,\n"
        ]
    },
    "641c688b5c5a0c80d5d5832c5cd9f361c1cbb0a9": {
        "non_crash": [
            "diff --git a/drivers/usb/gadget/legacy/raw_gadget.c b/drivers/usb/gadget/legacy/raw_gadget.c\nindex 2acece16b890..e549022642e5 100644\n--- a/drivers/usb/gadget/legacy/raw_gadget.c\n+++ b/drivers/usb/gadget/legacy/raw_gadget.c\n@@ -310,13 +310,15 @@ static int gadget_bind(struct usb_gadget *gadget,\n \tdev->eps_num = i;\n \tspin_unlock_irqrestore(&dev->lock, flags);\n \n-\t/* Matches kref_put() in gadget_unbind(). */\n-\tkref_get(&dev->count);\n-\n \tret = raw_queue_event(dev, USB_RAW_EVENT_CONNECT, 0, NULL);\n-\tif (ret < 0)\n+\tif (ret < 0) {\n \t\tdev_err(&gadget->dev, \"failed to queue event\\n\");\n+\t\tset_gadget_data(gadget, NULL);\n+\t\treturn ret;\n+\t}\n \n+\t/* Matches kref_put() in gadget_unbind(). */\n+\tkref_get(&dev->count);\n \treturn ret;\n }\n \n"
        ]
    },
    "02617ac69815ae324053c954118c2dc7ba0e59b2": {
        "non_crash": [
            "diff --git a/net/tls/tls_sw.c b/net/tls/tls_sw.c\nindex 0024a692f0f8..a8976ef95528 100644\n--- a/net/tls/tls_sw.c\n+++ b/net/tls/tls_sw.c\n@@ -1496,7 +1496,7 @@ static int decrypt_internal(struct sock *sk, struct sk_buff *skb,\n \tif (prot->version == TLS_1_3_VERSION ||\n \t    prot->cipher_type == TLS_CIPHER_CHACHA20_POLY1305)\n \t\tmemcpy(iv + iv_offset, tls_ctx->rx.iv,\n-\t\t       crypto_aead_ivsize(ctx->aead_recv));\n+\t\t       prot->iv_size + prot->salt_size);\n \telse\n \t\tmemcpy(iv + iv_offset, tls_ctx->rx.iv, prot->salt_size);\n \n"
        ]
    },
    "6fe3c93209dfd48301d1cad0ab1efd53c87462e1": {
        "non_crash": [
            "diff --git a/kernel/module/main.c b/kernel/module/main.c\nindex 834de86ebe35..59b1d067e528 100644\n--- a/kernel/module/main.c\n+++ b/kernel/module/main.c\n@@ -3092,7 +3092,7 @@ static bool idempotent(struct idempotent *u, const void *cookie)\n  * remove everybody - which includes ourselves - fill in the return\n  * value, and then complete the operation.\n  */\n-static void idempotent_complete(struct idempotent *u, int ret)\n+static int idempotent_complete(struct idempotent *u, int ret)\n {\n \tconst void *cookie = u->cookie;\n \tint hash = hash_ptr(cookie, IDEM_HASH_BITS);\n@@ -3109,27 +3109,18 @@ static void idempotent_complete(struct idempotent *u, int ret)\n \t\tcomplete(&pos->complete);\n \t}\n \tspin_unlock(&idem_lock);\n+\treturn ret;\n }\n \n static int init_module_from_file(struct file *f, const char __user * uargs, int flags)\n {\n-\tstruct idempotent idem;\n \tstruct load_info info = { };\n \tvoid *buf = NULL;\n-\tint len, ret;\n-\n-\tif (!f || !(f->f_mode & FMODE_READ))\n-\t\treturn -EBADF;\n-\n-\tif (idempotent(&idem, file_inode(f))) {\n-\t\twait_for_completion(&idem.complete);\n-\t\treturn idem.ret;\n-\t}\n+\tint len;\n \n \tlen = kernel_read_file(f, 0, &buf, INT_MAX, NULL, READING_MODULE);\n \tif (len < 0) {\n \t\tmod_stat_inc(&failed_kreads);\n-\t\tmod_stat_add_long(len, &invalid_kread_bytes);\n \t\treturn len;\n \t}\n \n@@ -3146,9 +3137,25 @@ static int init_module_from_file(struct file *f, const char __user * uargs, int\n \t\tinfo.len = len;\n \t}\n \n-\tret = load_module(&info, uargs, flags);\n-\tidempotent_complete(&idem, ret);\n-\treturn ret;\n+\treturn load_module(&info, uargs, flags);\n+}\n+\n+static int idempotent_init_module(struct file *f, const char __user * uargs, int flags)\n+{\n+\tstruct idempotent idem;\n+\n+\tif (!f || !(f->f_mode & FMODE_READ))\n+\t\treturn -EBADF;\n+\n+\t/* See if somebody else is doing the operation? */\n+\tif (idempotent(&idem, file_inode(f))) {\n+\t\twait_for_completion(&idem.complete);\n+\t\treturn idem.ret;\n+\t}\n+\n+\t/* Otherwise, we'll do it and complete others */\n+\treturn idempotent_complete(&idem,\n+\t\tinit_module_from_file(f, uargs, flags));\n }\n \n SYSCALL_DEFINE3(finit_module, int, fd, const char __user *, uargs, int, flags)\n@@ -3168,7 +3175,7 @@ SYSCALL_DEFINE3(finit_module, int, fd, const char __user *, uargs, int, flags)\n \t\treturn -EINVAL;\n \n \tf = fdget(fd);\n-\terr = init_module_from_file(f.file, uargs, flags);\n+\terr = idempotent_init_module(f.file, uargs, flags);\n \tfdput(f);\n \treturn err;\n }\n"
        ]
    },
    "b0932be9507e30fc4cbd16bf05cd3bea03b325d7": {
        "non_crash": [
            "diff --git a/block/genhd.c b/block/genhd.c\nindex 3c139a1b6f04..603db5d6f10c 100644\n--- a/block/genhd.c\n+++ b/block/genhd.c\n@@ -442,10 +442,6 @@ int __must_check device_add_disk(struct device *parent, struct gendisk *disk,\n \t\tdisk->first_minor = ret;\n \t}\n \n-\tret = disk_alloc_events(disk);\n-\tif (ret)\n-\t\tgoto out_free_ext_minor;\n-\n \t/* delay uevents, until we scanned partition table */\n \tdev_set_uevent_suppress(ddev, 1);\n \n@@ -456,7 +452,12 @@ int __must_check device_add_disk(struct device *parent, struct gendisk *disk,\n \t\tddev->devt = MKDEV(disk->major, disk->first_minor);\n \tret = device_add(ddev);\n \tif (ret)\n-\t\tgoto out_disk_release_events;\n+\t\tgoto out_free_ext_minor;\n+\n+\tret = disk_alloc_events(disk);\n+\tif (ret)\n+\t\tgoto out_device_del;\n+\n \tif (!sysfs_deprecated) {\n \t\tret = sysfs_create_link(block_depr, &ddev->kobj,\n \t\t\t\t\tkobject_name(&ddev->kobj));\n@@ -538,8 +539,6 @@ int __must_check device_add_disk(struct device *parent, struct gendisk *disk,\n \t\tsysfs_remove_link(block_depr, dev_name(ddev));\n out_device_del:\n \tdevice_del(ddev);\n-out_disk_release_events:\n-\tdisk_release_events(disk);\n out_free_ext_minor:\n \tif (disk->major == BLOCK_EXT_MAJOR)\n \t\tblk_free_ext_minor(disk->first_minor);\n"
        ]
    },
    "1bc76a5779300075e3466a0e2abcd753df212779": {
        "non_crash": [
            "diff --git a/drivers/bluetooth/hci_h5.c b/drivers/bluetooth/hci_h5.c\nindex 0c0dedece59c..eb0099a21288 100644\n--- a/drivers/bluetooth/hci_h5.c\n+++ b/drivers/bluetooth/hci_h5.c\n@@ -587,9 +587,11 @@ static int h5_recv(struct hci_uart *hu, const void *data, int count)\n \t\tcount -= processed;\n \t}\n \n-\tpm_runtime_get(&hu->serdev->dev);\n-\tpm_runtime_mark_last_busy(&hu->serdev->dev);\n-\tpm_runtime_put_autosuspend(&hu->serdev->dev);\n+\tif (hu->serdev) {\n+\t\tpm_runtime_get(&hu->serdev->dev);\n+\t\tpm_runtime_mark_last_busy(&hu->serdev->dev);\n+\t\tpm_runtime_put_autosuspend(&hu->serdev->dev);\n+\t}\n \n \treturn 0;\n }\n"
        ]
    },
    "17535f4bf5b322437f7c639b59161ce343fc55a9": {
        "non_crash": [
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex 2fcab61b8ff5..03954c13024c 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -812,6 +812,9 @@ int vb2_core_create_bufs(struct vb2_queue *q, enum vb2_memory memory,\n \t\tmemset(q->alloc_devs, 0, sizeof(q->alloc_devs));\n \t\tq->memory = memory;\n \t\tq->waiting_for_buffers = !q->is_output;\n+\t} else if (q->memory != memory) {\n+\t\tdprintk(1, \"memory model mismatch\\n\");\n+\t\treturn -EINVAL;\n \t}\n \n \tnum_buffers = min(*count, VB2_MAX_FRAME - q->num_buffers);\n"
        ]
    },
    "5c8b4f0ea10c23945625f4187bac8e6e471d732c": {
        "non_crash": [
            "diff --git a/fs/proc/task_mmu.c b/fs/proc/task_mmu.c\nindex 18f8c3acbb85..6e97ed775074 100644\n--- a/fs/proc/task_mmu.c\n+++ b/fs/proc/task_mmu.c\n@@ -440,7 +440,8 @@ static void smaps_page_accumulate(struct mem_size_stats *mss,\n }\n \n static void smaps_account(struct mem_size_stats *mss, struct page *page,\n-\t\tbool compound, bool young, bool dirty, bool locked)\n+\t\tbool compound, bool young, bool dirty, bool locked,\n+\t\tbool migration)\n {\n \tint i, nr = compound ? compound_nr(page) : 1;\n \tunsigned long size = nr * PAGE_SIZE;\n@@ -467,8 +468,15 @@ static void smaps_account(struct mem_size_stats *mss, struct page *page,\n \t * page_count(page) == 1 guarantees the page is mapped exactly once.\n \t * If any subpage of the compound page mapped with PTE it would elevate\n \t * page_count().\n+\t *\n+\t * The page_mapcount() is called to get a snapshot of the mapcount.\n+\t * Without holding the page lock this snapshot can be slightly wrong as\n+\t * we cannot always read the mapcount atomically.  It is not safe to\n+\t * call page_mapcount() even with PTL held if the page is not mapped,\n+\t * especially for migration entries.  Treat regular migration entries\n+\t * as mapcount == 1.\n \t */\n-\tif (page_count(page) == 1) {\n+\tif ((page_count(page) == 1) || migration) {\n \t\tsmaps_page_accumulate(mss, page, size, size << PSS_SHIFT, dirty,\n \t\t\tlocked, true);\n \t\treturn;\n@@ -517,6 +525,7 @@ static void smaps_pte_entry(pte_t *pte, unsigned long addr,\n \tstruct vm_area_struct *vma = walk->vma;\n \tbool locked = !!(vma->vm_flags & VM_LOCKED);\n \tstruct page *page = NULL;\n+\tbool migration = false;\n \n \tif (pte_present(*pte)) {\n \t\tpage = vm_normal_page(vma, addr, *pte);\n@@ -536,8 +545,11 @@ static void smaps_pte_entry(pte_t *pte, unsigned long addr,\n \t\t\t} else {\n \t\t\t\tmss->swap_pss += (u64)PAGE_SIZE << PSS_SHIFT;\n \t\t\t}\n-\t\t} else if (is_pfn_swap_entry(swpent))\n+\t\t} else if (is_pfn_swap_entry(swpent)) {\n+\t\t\tif (is_migration_entry(swpent))\n+\t\t\t\tmigration = true;\n \t\t\tpage = pfn_swap_entry_to_page(swpent);\n+\t\t}\n \t} else {\n \t\tsmaps_pte_hole_lookup(addr, walk);\n \t\treturn;\n@@ -546,7 +558,8 @@ static void smaps_pte_entry(pte_t *pte, unsigned long addr,\n \tif (!page)\n \t\treturn;\n \n-\tsmaps_account(mss, page, false, pte_young(*pte), pte_dirty(*pte), locked);\n+\tsmaps_account(mss, page, false, pte_young(*pte), pte_dirty(*pte),\n+\t\t      locked, migration);\n }\n \n #ifdef CONFIG_TRANSPARENT_HUGEPAGE\n@@ -557,6 +570,7 @@ static void smaps_pmd_entry(pmd_t *pmd, unsigned long addr,\n \tstruct vm_area_struct *vma = walk->vma;\n \tbool locked = !!(vma->vm_flags & VM_LOCKED);\n \tstruct page *page = NULL;\n+\tbool migration = false;\n \n \tif (pmd_present(*pmd)) {\n \t\t/* FOLL_DUMP will return -EFAULT on huge zero page */\n@@ -564,8 +578,10 @@ static void smaps_pmd_entry(pmd_t *pmd, unsigned long addr,\n \t} else if (unlikely(thp_migration_supported() && is_swap_pmd(*pmd))) {\n \t\tswp_entry_t entry = pmd_to_swp_entry(*pmd);\n \n-\t\tif (is_migration_entry(entry))\n+\t\tif (is_migration_entry(entry)) {\n+\t\t\tmigration = true;\n \t\t\tpage = pfn_swap_entry_to_page(entry);\n+\t\t}\n \t}\n \tif (IS_ERR_OR_NULL(page))\n \t\treturn;\n@@ -577,7 +593,9 @@ static void smaps_pmd_entry(pmd_t *pmd, unsigned long addr,\n \t\t/* pass */;\n \telse\n \t\tmss->file_thp += HPAGE_PMD_SIZE;\n-\tsmaps_account(mss, page, true, pmd_young(*pmd), pmd_dirty(*pmd), locked);\n+\n+\tsmaps_account(mss, page, true, pmd_young(*pmd), pmd_dirty(*pmd),\n+\t\t      locked, migration);\n }\n #else\n static void smaps_pmd_entry(pmd_t *pmd, unsigned long addr,\n@@ -1378,6 +1396,7 @@ static pagemap_entry_t pte_to_pagemap_entry(struct pagemapread *pm,\n {\n \tu64 frame = 0, flags = 0;\n \tstruct page *page = NULL;\n+\tbool migration = false;\n \n \tif (pte_present(pte)) {\n \t\tif (pm->show_pfn)\n@@ -1399,13 +1418,14 @@ static pagemap_entry_t pte_to_pagemap_entry(struct pagemapread *pm,\n \t\t\tframe = swp_type(entry) |\n \t\t\t\t(swp_offset(entry) << MAX_SWAPFILES_SHIFT);\n \t\tflags |= PM_SWAP;\n+\t\tmigration = is_migration_entry(entry);\n \t\tif (is_pfn_swap_entry(entry))\n \t\t\tpage = pfn_swap_entry_to_page(entry);\n \t}\n \n \tif (page && !PageAnon(page))\n \t\tflags |= PM_FILE;\n-\tif (page && page_mapcount(page) == 1)\n+\tif (page && !migration && page_mapcount(page) == 1)\n \t\tflags |= PM_MMAP_EXCLUSIVE;\n \tif (vma->vm_flags & VM_SOFTDIRTY)\n \t\tflags |= PM_SOFT_DIRTY;\n@@ -1421,8 +1441,9 @@ static int pagemap_pmd_range(pmd_t *pmdp, unsigned long addr, unsigned long end,\n \tspinlock_t *ptl;\n \tpte_t *pte, *orig_pte;\n \tint err = 0;\n-\n #ifdef CONFIG_TRANSPARENT_HUGEPAGE\n+\tbool migration = false;\n+\n \tptl = pmd_trans_huge_lock(pmdp, vma);\n \tif (ptl) {\n \t\tu64 flags = 0, frame = 0;\n@@ -1461,11 +1482,12 @@ static int pagemap_pmd_range(pmd_t *pmdp, unsigned long addr, unsigned long end,\n \t\t\tif (pmd_swp_uffd_wp(pmd))\n \t\t\t\tflags |= PM_UFFD_WP;\n \t\t\tVM_BUG_ON(!is_pmd_migration_entry(pmd));\n+\t\t\tmigration = is_migration_entry(entry);\n \t\t\tpage = pfn_swap_entry_to_page(entry);\n \t\t}\n #endif\n \n-\t\tif (page && page_mapcount(page) == 1)\n+\t\tif (page && !migration && page_mapcount(page) == 1)\n \t\t\tflags |= PM_MMAP_EXCLUSIVE;\n \n \t\tfor (; addr != end; addr += PAGE_SIZE) {\n"
        ]
    },
    "e8fc405587520f9442d64d47321fd53cef0f9bde": {
        "non_crash": [
            "diff --git a/block/blk-core.c b/block/blk-core.c\nindex 00c74330fa92..1da77e7d6289 100644\n--- a/block/blk-core.c\n+++ b/block/blk-core.c\n@@ -520,7 +520,7 @@ static inline int bio_check_eod(struct bio *bio)\n \tsector_t maxsector = bdev_nr_sectors(bio->bi_bdev);\n \tunsigned int nr_sectors = bio_sectors(bio);\n \n-\tif (nr_sectors && maxsector &&\n+\tif (nr_sectors &&\n \t    (nr_sectors > maxsector ||\n \t     bio->bi_iter.bi_sector > maxsector - nr_sectors)) {\n \t\tpr_info_ratelimited(\"%s: attempt to access beyond end of device\\n\"\n"
        ]
    },
    "738a1a0b5b9b8ece2bbf714f2e244358be2523c3": {
        "non_crash": [
            "diff --git a/net/ipv4/ip_output.c b/net/ipv4/ip_output.c\nindex 54d2d3a2d850..6ba1a0fafbaa 100644\n--- a/net/ipv4/ip_output.c\n+++ b/net/ipv4/ip_output.c\n@@ -1158,10 +1158,15 @@ static int __ip_append_data(struct sock *sk,\n \t\t\t}\n \n \t\t\tcopy = datalen - transhdrlen - fraggap - pagedlen;\n+\t\t\t/* [!] NOTE: copy will be negative if pagedlen>0\n+\t\t\t * because then the equation reduces to -fraggap.\n+\t\t\t */\n \t\t\tif (copy > 0 && getfrag(from, data + transhdrlen, offset, copy, fraggap, skb) < 0) {\n \t\t\t\terr = -EFAULT;\n \t\t\t\tkfree_skb(skb);\n \t\t\t\tgoto error;\n+\t\t\t} else if (flags & MSG_SPLICE_PAGES) {\n+\t\t\t\tcopy = 0;\n \t\t\t}\n \n \t\t\toffset += copy;\n@@ -1209,6 +1214,10 @@ static int __ip_append_data(struct sock *sk,\n \t\t} else if (flags & MSG_SPLICE_PAGES) {\n \t\t\tstruct msghdr *msg = from;\n \n+\t\t\terr = -EIO;\n+\t\t\tif (WARN_ON_ONCE(copy > msg->msg_iter.count))\n+\t\t\t\tgoto error;\n+\n \t\t\terr = skb_splice_from_iter(skb, &msg->msg_iter, copy,\n \t\t\t\t\t\t   sk->sk_allocation);\n \t\t\tif (err < 0)\n"
        ]
    },
    "91e171a9aa357b24b62b3ab188bc04996448c99b": {
        "non_crash": [
            "diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c\nindex 5864cbc30db6..49cc6587dd77 100644\n--- a/net/ipv6/addrconf.c\n+++ b/net/ipv6/addrconf.c\n@@ -5168,9 +5168,9 @@ static int in6_dump_addrs(struct inet6_dev *idev, struct sk_buff *skb,\n \t\tfillargs->event = RTM_GETMULTICAST;\n \n \t\t/* multicast address */\n-\t\tfor (ifmca = rcu_dereference(idev->mc_list);\n+\t\tfor (ifmca = rtnl_dereference(idev->mc_list);\n \t\t     ifmca;\n-\t\t     ifmca = rcu_dereference(ifmca->next), ip_idx++) {\n+\t\t     ifmca = rtnl_dereference(ifmca->next), ip_idx++) {\n \t\t\tif (ip_idx < s_ip_idx)\n \t\t\t\tcontinue;\n \t\t\terr = inet6_fill_ifmcaddr(skb, ifmca, fillargs);\n"
        ]
    },
    "4a547542bb29dc957c096f0c95ef9154e93d68d3": {
        "non_crash": [
            "diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c\nindex 955dd978dccf..d815502cc97c 100644\n--- a/fs/ext4/inode.c\n+++ b/fs/ext4/inode.c\n@@ -3952,7 +3952,8 @@ int ext4_punch_hole(struct file *file, loff_t offset, loff_t length)\n \tstruct super_block *sb = inode->i_sb;\n \text4_lblk_t first_block, stop_block;\n \tstruct address_space *mapping = inode->i_mapping;\n-\tloff_t first_block_offset, last_block_offset;\n+\tloff_t first_block_offset, last_block_offset, max_length;\n+\tstruct ext4_sb_info *sbi = EXT4_SB(inode->i_sb);\n \thandle_t *handle;\n \tunsigned int credits;\n \tint ret = 0, ret2 = 0;\n@@ -3995,6 +3996,14 @@ int ext4_punch_hole(struct file *file, loff_t offset, loff_t length)\n \t\t   offset;\n \t}\n \n+\t/*\n+\t * For punch hole the length + offset needs to be within one block\n+\t * before last range. Adjust the length if it goes beyond that limit.\n+\t */\n+\tmax_length = sbi->s_bitmap_maxbytes - inode->i_sb->s_blocksize;\n+\tif (offset + length > max_length)\n+\t\tlength = max_length - offset;\n+\n \tif (offset & (sb->s_blocksize - 1) ||\n \t    (offset + length) & (sb->s_blocksize - 1)) {\n \t\t/*\n"
        ]
    },
    "cd246a3e7f0fd69a115b910b3b2cf6fa96351278": {
        "non_crash": [
            "diff --git a/fs/nilfs2/btree.c b/fs/nilfs2/btree.c\nindex b9d15c3df3cc..40ce92a332fe 100644\n--- a/fs/nilfs2/btree.c\n+++ b/fs/nilfs2/btree.c\n@@ -480,9 +480,18 @@ static int __nilfs_btree_get_block(const struct nilfs_bmap *btree, __u64 ptr,\n \tret = nilfs_btnode_submit_block(btnc, ptr, 0, REQ_OP_READ, &bh,\n \t\t\t\t\t&submit_ptr);\n \tif (ret) {\n-\t\tif (ret != -EEXIST)\n-\t\t\treturn ret;\n-\t\tgoto out_check;\n+\t\tif (likely(ret == -EEXIST))\n+\t\t\tgoto out_check;\n+\t\tif (ret == -ENOENT) {\n+\t\t\t/*\n+\t\t\t * Block address translation failed due to invalid\n+\t\t\t * value of 'ptr'.  In this case, return internal code\n+\t\t\t * -EINVAL (broken bmap) to notify bmap layer of fatal\n+\t\t\t * metadata corruption.\n+\t\t\t */\n+\t\t\tret = -EINVAL;\n+\t\t}\n+\t\treturn ret;\n \t}\n \n \tif (ra) {\n"
        ]
    },
    "637351e3088fc2aed419d941674f2774f4162ea2": {
        "non_crash": [
            "diff --git a/drivers/tty/vt/vt.c b/drivers/tty/vt/vt.c\nindex 57a5c23b51d4..3c2ea9c098f7 100644\n--- a/drivers/tty/vt/vt.c\n+++ b/drivers/tty/vt/vt.c\n@@ -4545,6 +4545,9 @@ static int con_font_get(struct vc_data *vc, struct console_font_op *op)\n \tint c;\n \tunsigned int vpitch = op->op == KD_FONT_OP_GET_TALL ? op->height : 32;\n \n+\tif (vpitch > max_font_height)\n+\t\treturn -EINVAL;\n+\n \tif (op->data) {\n \t\tfont.data = kvmalloc(max_font_size, GFP_KERNEL);\n \t\tif (!font.data)\n"
        ]
    },
    "0cd33d8e114be941da0773f8980488e1ca71ed58": {
        "non_crash": [
            "diff --git a/net/rxrpc/recvmsg.c b/net/rxrpc/recvmsg.c\nindex eaf19ebaa964..3f7bb11f3290 100644\n--- a/net/rxrpc/recvmsg.c\n+++ b/net/rxrpc/recvmsg.c\n@@ -596,6 +596,7 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n \t}\n error_no_call:\n \trelease_sock(&rx->sk);\n+error_trace:\n \ttrace_rxrpc_recvmsg(call, rxrpc_recvmsg_return, 0, 0, 0, ret);\n \treturn ret;\n \n@@ -604,7 +605,7 @@ int rxrpc_recvmsg(struct socket *sock, struct msghdr *msg, size_t len,\n wait_error:\n \tfinish_wait(sk_sleep(&rx->sk), &wait);\n \tcall = NULL;\n-\tgoto error_no_call;\n+\tgoto error_trace;\n }\n \n /**\n"
        ]
    },
    "949ecf93b67ab1df8f890571d24ef9db50872c96": {
        "non_crash": [
            "diff --git a/fs/afs/main.c b/fs/afs/main.c\nindex accdd8970e7c..b2975256dadb 100644\n--- a/fs/afs/main.c\n+++ b/fs/afs/main.c\n@@ -193,7 +193,7 @@ static int __init afs_init(void)\n \t\tgoto error_cache;\n #endif\n \n-\tret = register_pernet_subsys(&afs_net_ops);\n+\tret = register_pernet_device(&afs_net_ops);\n \tif (ret < 0)\n \t\tgoto error_net;\n \n@@ -213,7 +213,7 @@ static int __init afs_init(void)\n error_proc:\n \tafs_fs_exit();\n error_fs:\n-\tunregister_pernet_subsys(&afs_net_ops);\n+\tunregister_pernet_device(&afs_net_ops);\n error_net:\n #ifdef CONFIG_AFS_FSCACHE\n \tfscache_unregister_netfs(&afs_cache_netfs);\n@@ -244,7 +244,7 @@ static void __exit afs_exit(void)\n \n \tproc_remove(afs_proc_symlink);\n \tafs_fs_exit();\n-\tunregister_pernet_subsys(&afs_net_ops);\n+\tunregister_pernet_device(&afs_net_ops);\n #ifdef CONFIG_AFS_FSCACHE\n \tfscache_unregister_netfs(&afs_cache_netfs);\n #endif\ndiff --git a/net/rxrpc/af_rxrpc.c b/net/rxrpc/af_rxrpc.c\nindex 0a2f4817ec6c..41671af6b33f 100644\n--- a/net/rxrpc/af_rxrpc.c\n+++ b/net/rxrpc/af_rxrpc.c\n@@ -990,7 +990,7 @@ static int __init af_rxrpc_init(void)\n \t\tgoto error_security;\n \t}\n \n-\tret = register_pernet_subsys(&rxrpc_net_ops);\n+\tret = register_pernet_device(&rxrpc_net_ops);\n \tif (ret)\n \t\tgoto error_pernet;\n \n@@ -1035,7 +1035,7 @@ static int __init af_rxrpc_init(void)\n error_sock:\n \tproto_unregister(&rxrpc_proto);\n error_proto:\n-\tunregister_pernet_subsys(&rxrpc_net_ops);\n+\tunregister_pernet_device(&rxrpc_net_ops);\n error_pernet:\n \trxrpc_exit_security();\n error_security:\n@@ -1057,7 +1057,7 @@ static void __exit af_rxrpc_exit(void)\n \tunregister_key_type(&key_type_rxrpc);\n \tsock_unregister(PF_RXRPC);\n \tproto_unregister(&rxrpc_proto);\n-\tunregister_pernet_subsys(&rxrpc_net_ops);\n+\tunregister_pernet_device(&rxrpc_net_ops);\n \tASSERTCMP(atomic_read(&rxrpc_n_tx_skbs), ==, 0);\n \tASSERTCMP(atomic_read(&rxrpc_n_rx_skbs), ==, 0);\n \n"
        ]
    },
    "35dd38010e383ee37d27b39f6b50eb25b4c92dd2": {
        "non_crash": [
            "diff --git a/drivers/media/usb/siano/smsusb.c b/drivers/media/usb/siano/smsusb.c\nindex 6f443c542c6d..640737d3b8ae 100644\n--- a/drivers/media/usb/siano/smsusb.c\n+++ b/drivers/media/usb/siano/smsusb.c\n@@ -179,7 +179,8 @@ static void smsusb_stop_streaming(struct smsusb_device_t *dev)\n \n \tfor (i = 0; i < MAX_URBS; i++) {\n \t\tusb_kill_urb(&dev->surbs[i].urb);\n-\t\tcancel_work_sync(&dev->surbs[i].wq);\n+\t\tif (dev->surbs[i].wq.func)\n+\t\t\tcancel_work_sync(&dev->surbs[i].wq);\n \n \t\tif (dev->surbs[i].cb) {\n \t\t\tsmscore_putbuffer(dev->coredev, dev->surbs[i].cb);\n"
        ]
    },
    "7b2aea1ce02f87c175f94492d21d04a34bc99b5e": {
        "non_crash": [
            "diff --git a/drivers/vhost/iotlb.c b/drivers/vhost/iotlb.c\nindex 670d56c879e5..40b098320b2a 100644\n--- a/drivers/vhost/iotlb.c\n+++ b/drivers/vhost/iotlb.c\n@@ -57,6 +57,17 @@ int vhost_iotlb_add_range_ctx(struct vhost_iotlb *iotlb,\n \tif (last < start)\n \t\treturn -EFAULT;\n \n+\t/* If the range being mapped is [0, ULONG_MAX], split it into two entries\n+\t * otherwise its size would overflow u64.\n+\t */\n+\tif (start == 0 && last == ULONG_MAX) {\n+\t\tu64 mid = last / 2;\n+\n+\t\tvhost_iotlb_add_range_ctx(iotlb, start, mid, addr, perm, opaque);\n+\t\taddr += mid + 1;\n+\t\tstart = mid + 1;\n+\t}\n+\n \tif (iotlb->limit &&\n \t    iotlb->nmaps == iotlb->limit &&\n \t    iotlb->flags & VHOST_IOTLB_FLAG_RETIRE) {\ndiff --git a/drivers/vhost/vhost.c b/drivers/vhost/vhost.c\nindex 59edb5a1ffe2..55475fd59fb7 100644\n--- a/drivers/vhost/vhost.c\n+++ b/drivers/vhost/vhost.c\n@@ -1170,6 +1170,11 @@ ssize_t vhost_chr_write_iter(struct vhost_dev *dev,\n \t\tgoto done;\n \t}\n \n+\tif (msg.size == 0) {\n+\t\tret = -EINVAL;\n+\t\tgoto done;\n+\t}\n+\n \tif (dev->msg_handler)\n \t\tret = dev->msg_handler(dev, &msg);\n \telse\n"
        ]
    },
    "07c9d71dc1a215b19c6a245c68f502bc57dbdb83": {
        "non_crash": [
            "diff --git a/net/qrtr/ns.c b/net/qrtr/ns.c\nindex d8252fdab851..934999b56d60 100644\n--- a/net/qrtr/ns.c\n+++ b/net/qrtr/ns.c\n@@ -193,12 +193,13 @@ static int announce_servers(struct sockaddr_qrtr *sq)\n \tstruct qrtr_server *srv;\n \tstruct qrtr_node *node;\n \tvoid __rcu **slot;\n-\tint ret;\n+\tint ret = 0;\n \n \tnode = node_get(qrtr_ns.local_node);\n \tif (!node)\n \t\treturn 0;\n \n+\trcu_read_lock();\n \t/* Announce the list of servers registered in this node */\n \tradix_tree_for_each_slot(slot, &node->servers, &iter, 0) {\n \t\tsrv = radix_tree_deref_slot(slot);\n@@ -206,11 +207,14 @@ static int announce_servers(struct sockaddr_qrtr *sq)\n \t\tret = service_announce_new(sq, srv);\n \t\tif (ret < 0) {\n \t\t\tpr_err(\"failed to announce new service\\n\");\n-\t\t\treturn ret;\n+\t\t\tgoto err_out;\n \t\t}\n \t}\n \n-\treturn 0;\n+err_out:\n+\trcu_read_unlock();\n+\n+\treturn ret;\n }\n \n static struct qrtr_server *server_add(unsigned int service,\n@@ -335,7 +339,7 @@ static int ctrl_cmd_bye(struct sockaddr_qrtr *from)\n \tstruct qrtr_node *node;\n \tvoid __rcu **slot;\n \tstruct kvec iv;\n-\tint ret;\n+\tint ret = 0;\n \n \tiv.iov_base = &pkt;\n \tiv.iov_len = sizeof(pkt);\n@@ -344,11 +348,13 @@ static int ctrl_cmd_bye(struct sockaddr_qrtr *from)\n \tif (!node)\n \t\treturn 0;\n \n+\trcu_read_lock();\n \t/* Advertise removal of this client to all servers of remote node */\n \tradix_tree_for_each_slot(slot, &node->servers, &iter, 0) {\n \t\tsrv = radix_tree_deref_slot(slot);\n \t\tserver_del(node, srv->port);\n \t}\n+\trcu_read_unlock();\n \n \t/* Advertise the removal of this client to all local servers */\n \tlocal_node = node_get(qrtr_ns.local_node);\n@@ -359,6 +365,7 @@ static int ctrl_cmd_bye(struct sockaddr_qrtr *from)\n \tpkt.cmd = cpu_to_le32(QRTR_TYPE_BYE);\n \tpkt.client.node = cpu_to_le32(from->sq_node);\n \n+\trcu_read_lock();\n \tradix_tree_for_each_slot(slot, &local_node->servers, &iter, 0) {\n \t\tsrv = radix_tree_deref_slot(slot);\n \n@@ -372,11 +379,14 @@ static int ctrl_cmd_bye(struct sockaddr_qrtr *from)\n \t\tret = kernel_sendmsg(qrtr_ns.sock, &msg, &iv, 1, sizeof(pkt));\n \t\tif (ret < 0) {\n \t\t\tpr_err(\"failed to send bye cmd\\n\");\n-\t\t\treturn ret;\n+\t\t\tgoto err_out;\n \t\t}\n \t}\n \n-\treturn 0;\n+err_out:\n+\trcu_read_unlock();\n+\n+\treturn ret;\n }\n \n static int ctrl_cmd_del_client(struct sockaddr_qrtr *from,\n@@ -394,7 +404,7 @@ static int ctrl_cmd_del_client(struct sockaddr_qrtr *from,\n \tstruct list_head *li;\n \tvoid __rcu **slot;\n \tstruct kvec iv;\n-\tint ret;\n+\tint ret = 0;\n \n \tiv.iov_base = &pkt;\n \tiv.iov_len = sizeof(pkt);\n@@ -434,6 +444,7 @@ static int ctrl_cmd_del_client(struct sockaddr_qrtr *from,\n \tpkt.client.node = cpu_to_le32(node_id);\n \tpkt.client.port = cpu_to_le32(port);\n \n+\trcu_read_lock();\n \tradix_tree_for_each_slot(slot, &local_node->servers, &iter, 0) {\n \t\tsrv = radix_tree_deref_slot(slot);\n \n@@ -447,11 +458,14 @@ static int ctrl_cmd_del_client(struct sockaddr_qrtr *from,\n \t\tret = kernel_sendmsg(qrtr_ns.sock, &msg, &iv, 1, sizeof(pkt));\n \t\tif (ret < 0) {\n \t\t\tpr_err(\"failed to send del client cmd\\n\");\n-\t\t\treturn ret;\n+\t\t\tgoto err_out;\n \t\t}\n \t}\n \n-\treturn 0;\n+err_out:\n+\trcu_read_unlock();\n+\n+\treturn ret;\n }\n \n static int ctrl_cmd_new_server(struct sockaddr_qrtr *from,\n@@ -554,6 +568,7 @@ static int ctrl_cmd_new_lookup(struct sockaddr_qrtr *from,\n \tfilter.service = service;\n \tfilter.instance = instance;\n \n+\trcu_read_lock();\n \tradix_tree_for_each_slot(node_slot, &nodes, &node_iter, 0) {\n \t\tnode = radix_tree_deref_slot(node_slot);\n \n@@ -568,6 +583,7 @@ static int ctrl_cmd_new_lookup(struct sockaddr_qrtr *from,\n \t\t\tlookup_notify(from, srv, true);\n \t\t}\n \t}\n+\trcu_read_unlock();\n \n \t/* Empty notification, to indicate end of listing */\n \tlookup_notify(from, NULL, true);\n"
        ]
    },
    "4157935be2e32fae6b62aa95bb0a08b07160b986": {
        "non_crash": [
            "diff --git a/fs/ntfs3/fsntfs.c b/fs/ntfs3/fsntfs.c\nindex 3de5700a9b83..891125ca6848 100644\n--- a/fs/ntfs3/fsntfs.c\n+++ b/fs/ntfs3/fsntfs.c\n@@ -831,10 +831,15 @@ int ntfs_update_mftmirr(struct ntfs_sb_info *sbi, int wait)\n {\n \tint err;\n \tstruct super_block *sb = sbi->sb;\n-\tu32 blocksize = sb->s_blocksize;\n+\tu32 blocksize;\n \tsector_t block1, block2;\n \tu32 bytes;\n \n+\tif (!sb)\n+\t\treturn -EINVAL;\n+\n+\tblocksize = sb->s_blocksize;\n+\n \tif (!(sbi->flags & NTFS_FLAGS_MFTMIRR))\n \t\treturn 0;\n \n"
        ]
    },
    "38efa4618c3379cf98642b9379d6e340b14d2702": {
        "non_crash": [
            "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 91de361ea9ab..e0823f58f795 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -4481,6 +4481,9 @@ static int io_msg_ring(struct io_kiocb *req, unsigned int issue_flags)\n \tif (ret < 0)\n \t\treq_set_fail(req);\n \t__io_req_complete(req, issue_flags, ret, 0);\n+\t/* put file to avoid an attempt to IOPOLL the req */\n+\tio_put_file(req->file);\n+\treq->file = NULL;\n \treturn 0;\n }\n \n"
        ]
    },
    "32577e96d88447ded2d3b76d71254fb855245837": {
        "non_crash": [
            "diff --git a/drivers/tty/vt/vt_ioctl.c b/drivers/tty/vt/vt_ioctl.c\nindex 2ea76a09e07f..0a33b8ababe3 100644\n--- a/drivers/tty/vt/vt_ioctl.c\n+++ b/drivers/tty/vt/vt_ioctl.c\n@@ -772,58 +772,21 @@ static int vt_resizex(struct vc_data *vc, struct vt_consize __user *cs)\n \tif (copy_from_user(&v, cs, sizeof(struct vt_consize)))\n \t\treturn -EFAULT;\n \n-\t/* FIXME: Should check the copies properly */\n-\tif (!v.v_vlin)\n-\t\tv.v_vlin = vc->vc_scan_lines;\n-\n-\tif (v.v_clin) {\n-\t\tint rows = v.v_vlin / v.v_clin;\n-\t\tif (v.v_rows != rows) {\n-\t\t\tif (v.v_rows) /* Parameters don't add up */\n-\t\t\t\treturn -EINVAL;\n-\t\t\tv.v_rows = rows;\n-\t\t}\n-\t}\n-\n-\tif (v.v_vcol && v.v_ccol) {\n-\t\tint cols = v.v_vcol / v.v_ccol;\n-\t\tif (v.v_cols != cols) {\n-\t\t\tif (v.v_cols)\n-\t\t\t\treturn -EINVAL;\n-\t\t\tv.v_cols = cols;\n-\t\t}\n-\t}\n-\n-\tif (v.v_clin > 32)\n-\t\treturn -EINVAL;\n+\tif (v.v_vlin)\n+\t\tpr_info_once(\"\\\"struct vt_consize\\\"->v_vlin is ignored. Please report if you need this.\\n\");\n+\tif (v.v_clin)\n+\t\tpr_info_once(\"\\\"struct vt_consize\\\"->v_clin is ignored. Please report if you need this.\\n\");\n \n+\tconsole_lock();\n \tfor (i = 0; i < MAX_NR_CONSOLES; i++) {\n-\t\tstruct vc_data *vcp;\n+\t\tvc = vc_cons[i].d;\n \n-\t\tif (!vc_cons[i].d)\n-\t\t\tcontinue;\n-\t\tconsole_lock();\n-\t\tvcp = vc_cons[i].d;\n-\t\tif (vcp) {\n-\t\t\tint ret;\n-\t\t\tint save_scan_lines = vcp->vc_scan_lines;\n-\t\t\tint save_font_height = vcp->vc_font.height;\n-\n-\t\t\tif (v.v_vlin)\n-\t\t\t\tvcp->vc_scan_lines = v.v_vlin;\n-\t\t\tif (v.v_clin)\n-\t\t\t\tvcp->vc_font.height = v.v_clin;\n-\t\t\tvcp->vc_resize_user = 1;\n-\t\t\tret = vc_resize(vcp, v.v_cols, v.v_rows);\n-\t\t\tif (ret) {\n-\t\t\t\tvcp->vc_scan_lines = save_scan_lines;\n-\t\t\t\tvcp->vc_font.height = save_font_height;\n-\t\t\t\tconsole_unlock();\n-\t\t\t\treturn ret;\n-\t\t\t}\n+\t\tif (vc) {\n+\t\t\tvc->vc_resize_user = 1;\n+\t\t\tvc_resize(vc, v.v_cols, v.v_rows);\n \t\t}\n-\t\tconsole_unlock();\n \t}\n+\tconsole_unlock();\n \n \treturn 0;\n }\n"
        ]
    },
    "3f5d1a7de17359e085f9a912eae7bf7e89dc7435": {
        "non_crash": [
            "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 2c351765c409..59ddb00d6944 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -454,6 +454,33 @@ void init_watch(struct watch *watch, struct watch_queue *wqueue)\n \trcu_assign_pointer(watch->queue, wqueue);\n }\n \n+static int add_one_watch(struct watch *watch, struct watch_list *wlist, struct watch_queue *wqueue)\n+{\n+\tconst struct cred *cred;\n+\tstruct watch *w;\n+\n+\thlist_for_each_entry(w, &wlist->watchers, list_node) {\n+\t\tstruct watch_queue *wq = rcu_access_pointer(w->queue);\n+\t\tif (wqueue == wq && watch->id == w->id)\n+\t\t\treturn -EBUSY;\n+\t}\n+\n+\tcred = current_cred();\n+\tif (atomic_inc_return(&cred->user->nr_watches) > task_rlimit(current, RLIMIT_NOFILE)) {\n+\t\tatomic_dec(&cred->user->nr_watches);\n+\t\treturn -EAGAIN;\n+\t}\n+\n+\twatch->cred = get_cred(cred);\n+\trcu_assign_pointer(watch->watch_list, wlist);\n+\n+\tkref_get(&wqueue->usage);\n+\tkref_get(&watch->usage);\n+\thlist_add_head(&watch->queue_node, &wqueue->watches);\n+\thlist_add_head_rcu(&watch->list_node, &wlist->watchers);\n+\treturn 0;\n+}\n+\n /**\n  * add_watch_to_object - Add a watch on an object to a watch list\n  * @watch: The watch to add\n@@ -468,34 +495,21 @@ void init_watch(struct watch *watch, struct watch_queue *wqueue)\n  */\n int add_watch_to_object(struct watch *watch, struct watch_list *wlist)\n {\n-\tstruct watch_queue *wqueue = rcu_access_pointer(watch->queue);\n-\tstruct watch *w;\n-\n-\thlist_for_each_entry(w, &wlist->watchers, list_node) {\n-\t\tstruct watch_queue *wq = rcu_access_pointer(w->queue);\n-\t\tif (wqueue == wq && watch->id == w->id)\n-\t\t\treturn -EBUSY;\n-\t}\n-\n-\twatch->cred = get_current_cred();\n-\trcu_assign_pointer(watch->watch_list, wlist);\n+\tstruct watch_queue *wqueue;\n+\tint ret = -ENOENT;\n \n-\tif (atomic_inc_return(&watch->cred->user->nr_watches) >\n-\t    task_rlimit(current, RLIMIT_NOFILE)) {\n-\t\tatomic_dec(&watch->cred->user->nr_watches);\n-\t\tput_cred(watch->cred);\n-\t\treturn -EAGAIN;\n-\t}\n+\trcu_read_lock();\n \n+\twqueue = rcu_access_pointer(watch->queue);\n \tif (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+\t\tspin_lock(&wlist->lock);\n+\t\tret = add_one_watch(watch, wlist, wqueue);\n+\t\tspin_unlock(&wlist->lock);\n \t\tunlock_wqueue(wqueue);\n \t}\n \n-\thlist_add_head_rcu(&watch->list_node, &wlist->watchers);\n-\treturn 0;\n+\trcu_read_unlock();\n+\treturn ret;\n }\n EXPORT_SYMBOL(add_watch_to_object);\n \n"
        ]
    },
    "f7c5a86e747f9b7ce333e7295875cd4ede2c7a0d": {
        "non_crash": [
            "diff --git a/mm/util.c b/mm/util.c\nindex 7e43369064c8..d3102081add0 100644\n--- a/mm/util.c\n+++ b/mm/util.c\n@@ -587,8 +587,10 @@ void *kvmalloc_node(size_t size, gfp_t flags, int node)\n \t\treturn ret;\n \n \t/* Don't even allow crazy sizes */\n-\tif (WARN_ON_ONCE(size > INT_MAX))\n+\tif (unlikely(size > INT_MAX)) {\n+\t\tWARN_ON_ONCE(!(flags & __GFP_NOWARN));\n \t\treturn NULL;\n+\t}\n \n \treturn __vmalloc_node(size, 1, flags, node,\n \t\t\t__builtin_return_address(0));\n"
        ]
    },
    "2e1943a94647f7732dd6fc60368642d6e8dc91b1": {
        "non_crash": [
            "diff --git a/include/net/bluetooth/hci_core.h b/include/net/bluetooth/hci_core.h\nindex ebdd4afe30d2..ca4ac6603b9a 100644\n--- a/include/net/bluetooth/hci_core.h\n+++ b/include/net/bluetooth/hci_core.h\n@@ -704,6 +704,7 @@ struct hci_chan {\n \tstruct sk_buff_head data_q;\n \tunsigned int\tsent;\n \t__u8\t\tstate;\n+\tbool\t\tamp;\n };\n \n struct hci_conn_params {\ndiff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c\nindex cf2f4a0abdbd..341c8ce93648 100644\n--- a/net/bluetooth/hci_event.c\n+++ b/net/bluetooth/hci_event.c\n@@ -5032,6 +5032,7 @@ static void hci_loglink_complete_evt(struct hci_dev *hdev, struct sk_buff *skb)\n \t\treturn;\n \n \thchan->handle = le16_to_cpu(ev->handle);\n+\thchan->amp = true;\n \n \tBT_DBG(\"hcon %p mgr %p hchan %p\", hcon, hcon->amp_mgr, hchan);\n \n@@ -5064,7 +5065,7 @@ static void hci_disconn_loglink_complete_evt(struct hci_dev *hdev,\n \thci_dev_lock(hdev);\n \n \thchan = hci_chan_lookup_handle(hdev, le16_to_cpu(ev->handle));\n-\tif (!hchan)\n+\tif (!hchan || !hchan->amp)\n \t\tgoto unlock;\n \n \tamp_destroy_logical_link(hchan, ev->reason);\n"
        ]
    },
    "a9412f636e2d733130f8def7975897d0b57f6e37": {
        "non_crash": [
            "diff --git a/fs/autofs/waitq.c b/fs/autofs/waitq.c\nindex 54c1f8b8b075..efdc76732fae 100644\n--- a/fs/autofs/waitq.c\n+++ b/fs/autofs/waitq.c\n@@ -32,8 +32,9 @@ void autofs_catatonic_mode(struct autofs_sb_info *sbi)\n \t\twq->status = -ENOENT; /* Magic is gone - report failure */\n \t\tkfree(wq->name.name - wq->offset);\n \t\twq->name.name = NULL;\n-\t\twq->wait_ctr--;\n \t\twake_up_interruptible(&wq->queue);\n+\t\tif (!--wq->wait_ctr)\n+\t\t\tkfree(wq);\n \t\twq = nwq;\n \t}\n \tfput(sbi->pipe);\t/* Close the pipe */\n"
        ]
    },
    "ac6fc97113de554dc57614c3ffa4c6a2c2668a97": {
        "non_crash": [
            "diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c\nindex 9c1d31f63f85..bd47628da6be 100644\n--- a/drivers/hid/hid-core.c\n+++ b/drivers/hid/hid-core.c\n@@ -1315,6 +1315,9 @@ static s32 snto32(__u32 value, unsigned n)\n \tif (!value || !n)\n \t\treturn 0;\n \n+\tif (n > 32)\n+\t\tn = 32;\n+\n \tswitch (n) {\n \tcase 8:  return ((__s8)value);\n \tcase 16: return ((__s16)value);\n"
        ]
    },
    "212130bd8af05df1d923b02f9a71db6e8208e40d": {
        "non_crash": [
            "diff --git a/drivers/block/loop.c b/drivers/block/loop.c\nindex 204558d7a81d..0c7f0367200c 100644\n--- a/drivers/block/loop.c\n+++ b/drivers/block/loop.c\n@@ -812,7 +812,6 @@ struct loop_worker {\n };\n \n static void loop_workfn(struct work_struct *work);\n-static void loop_rootcg_workfn(struct work_struct *work);\n \n #ifdef CONFIG_BLK_CGROUP\n static inline int queue_on_root_worker(struct cgroup_subsys_state *css)\n@@ -1050,20 +1049,19 @@ static int loop_configure(struct loop_device *lo, fmode_t mode,\n \t    !file->f_op->write_iter)\n \t\tlo->lo_flags |= LO_FLAGS_READ_ONLY;\n \n-\tlo->workqueue = alloc_workqueue(\"loop%d\",\n-\t\t\t\t\tWQ_UNBOUND | WQ_FREEZABLE,\n-\t\t\t\t\t0,\n-\t\t\t\t\tlo->lo_number);\n \tif (!lo->workqueue) {\n-\t\terror = -ENOMEM;\n-\t\tgoto out_unlock;\n+\t\tlo->workqueue = alloc_workqueue(\"loop%d\",\n+\t\t\t\t\t\tWQ_UNBOUND | WQ_FREEZABLE,\n+\t\t\t\t\t\t0, lo->lo_number);\n+\t\tif (!lo->workqueue) {\n+\t\t\terror = -ENOMEM;\n+\t\t\tgoto out_unlock;\n+\t\t}\n \t}\n \n \tdisk_force_media_change(lo->lo_disk, DISK_EVENT_MEDIA_CHANGE);\n \tset_disk_ro(lo->lo_disk, (lo->lo_flags & LO_FLAGS_READ_ONLY) != 0);\n \n-\tINIT_WORK(&lo->rootcg_work, loop_rootcg_workfn);\n-\tINIT_LIST_HEAD(&lo->rootcg_cmd_list);\n \tlo->use_dio = lo->lo_flags & LO_FLAGS_DIRECT_IO;\n \tlo->lo_device = bdev;\n \tlo->lo_backing_file = file;\n@@ -1143,10 +1141,6 @@ static void __loop_clr_fd(struct loop_device *lo, bool release)\n \tif (!release)\n \t\tblk_mq_freeze_queue(lo->lo_queue);\n \n-\tdestroy_workqueue(lo->workqueue);\n-\tloop_free_idle_workers(lo, true);\n-\tdel_timer_sync(&lo->timer);\n-\n \tspin_lock_irq(&lo->lo_lock);\n \tfilp = lo->lo_backing_file;\n \tlo->lo_backing_file = NULL;\n@@ -1750,6 +1744,10 @@ static void lo_free_disk(struct gendisk *disk)\n {\n \tstruct loop_device *lo = disk->private_data;\n \n+\tif (lo->workqueue)\n+\t\tdestroy_workqueue(lo->workqueue);\n+\tloop_free_idle_workers(lo, true);\n+\tdel_timer_sync(&lo->timer);\n \tmutex_destroy(&lo->lo_mutex);\n \tkfree(lo);\n }\n@@ -2013,6 +2011,8 @@ static int loop_add(int i)\n \tlo->lo_number\t\t= i;\n \tspin_lock_init(&lo->lo_lock);\n \tspin_lock_init(&lo->lo_work_lock);\n+\tINIT_WORK(&lo->rootcg_work, loop_rootcg_workfn);\n+\tINIT_LIST_HEAD(&lo->rootcg_cmd_list);\n \tdisk->major\t\t= LOOP_MAJOR;\n \tdisk->first_minor\t= i << part_shift;\n \tdisk->minors\t\t= 1 << part_shift;\n"
        ]
    },
    "31a3f2ad09a571fb7a5212efc400ce6bfc82e04c": {
        "non_crash": [
            "diff --git a/fs/ext4/super.c b/fs/ext4/super.c\nindex 7f6cd2473163..9cbb22045379 100644\n--- a/fs/ext4/super.c\n+++ b/fs/ext4/super.c\n@@ -4770,7 +4770,7 @@ static int __ext4_fill_super(struct fs_context *fc, struct super_block *sb)\n \t\t\t\t\tsbi->s_inodes_per_block;\n \tsbi->s_desc_per_block = blocksize / EXT4_DESC_SIZE(sb);\n \tsbi->s_sbh = bh;\n-\tsbi->s_mount_state = le16_to_cpu(es->s_state);\n+\tsbi->s_mount_state = le16_to_cpu(es->s_state) & ~EXT4_FC_REPLAY;\n \tsbi->s_addr_per_block_bits = ilog2(EXT4_ADDR_PER_BLOCK(sb));\n \tsbi->s_desc_per_block_bits = ilog2(EXT4_DESC_PER_BLOCK(sb));\n \n@@ -6333,7 +6333,8 @@ static int __ext4_remount(struct fs_context *fc, struct super_block *sb)\n \t\t\t\tif (err)\n \t\t\t\t\tgoto restore_opts;\n \t\t\t}\n-\t\t\tsbi->s_mount_state = le16_to_cpu(es->s_state);\n+\t\t\tsbi->s_mount_state = (le16_to_cpu(es->s_state) &\n+\t\t\t\t\t      ~EXT4_FC_REPLAY);\n \n \t\t\terr = ext4_setup_super(sb, es, 0);\n \t\t\tif (err)\n"
        ]
    },
    "bf7780df648105d40e1fdbb0566defda3605ed93": {
        "non_crash": [
            "diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c\nindex 677f9cfa9660..ca6e92a22923 100644\n--- a/net/packet/af_packet.c\n+++ b/net/packet/af_packet.c\n@@ -1935,8 +1935,10 @@ static void packet_parse_headers(struct sk_buff *skb, struct socket *sock)\n \t/* Move network header to the right position for VLAN tagged packets */\n \tif (likely(skb->dev->type == ARPHRD_ETHER) &&\n \t    eth_type_vlan(skb->protocol) &&\n-\t    __vlan_get_protocol(skb, skb->protocol, &depth) != 0)\n-\t\tskb_set_network_header(skb, depth);\n+\t    __vlan_get_protocol(skb, skb->protocol, &depth) != 0) {\n+\t\tif (pskb_may_pull(skb, depth))\n+\t\t\tskb_set_network_header(skb, depth);\n+\t}\n \n \tskb_probe_transport_header(skb);\n }\n"
        ]
    },
    "36a409539269df8733aaba8c3b36cf2fc7091cf7": {
        "non_crash": [
            "diff --git a/net/sched/cls_tcindex.c b/net/sched/cls_tcindex.c\nindex eb0e9458e722..ee2a050c887b 100644\n--- a/net/sched/cls_tcindex.c\n+++ b/net/sched/cls_tcindex.c\n@@ -333,7 +333,7 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\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 {\n-\tstruct tcindex_filter_result new_filter_result, *old_r = r;\n+\tstruct tcindex_filter_result new_filter_result;\n \tstruct tcindex_data *cp = NULL, *oldp;\n \tstruct tcindex_filter *f = NULL; /* make gcc behave */\n \tstruct tcf_result cr = {};\n@@ -402,7 +402,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-\tif (old_r)\n+\tif (r)\n \t\tcr = r->res;\n \n \terr = -EBUSY;\n@@ -479,14 +479,6 @@ tcindex_set_parms(struct net *net, struct tcf_proto *tp, unsigned long base,\n \t\ttcf_bind_filter(tp, &cr, base);\n \t}\n \n-\tif (old_r && old_r != r) {\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}\n-\t}\n-\n \toldp = p;\n \tr->res = cr;\n \ttcf_exts_change(&r->exts, &e);\n"
        ]
    },
    "92a742e993c8b9e769f8502a0497c88c0afa78af": {
        "non_crash": [
            "diff --git a/drivers/net/can/usb/gs_usb.c b/drivers/net/can/usb/gs_usb.c\nindex 67408e316062..b29ba9138866 100644\n--- a/drivers/net/can/usb/gs_usb.c\n+++ b/drivers/net/can/usb/gs_usb.c\n@@ -1092,6 +1092,8 @@ static struct gs_can *gs_make_candev(unsigned int channel,\n \t\tdev->data_bt_const.brp_inc = le32_to_cpu(bt_const_extended->dbrp_inc);\n \n \t\tdev->can.data_bittiming_const = &dev->data_bt_const;\n+\n+\t\tkfree(bt_const_extended);\n \t}\n \n \tSET_NETDEV_DEV(netdev, &intf->dev);\n"
        ]
    },
    "362b5b49fced29361c0ba3007a2b3e5cd13776b5": {
        "non_crash": [
            "diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c\nindex c447526288f4..50c53409ceb6 100644\n--- a/drivers/infiniband/core/cma.c\n+++ b/drivers/infiniband/core/cma.c\n@@ -3370,22 +3370,30 @@ static int cma_resolve_ib_addr(struct rdma_id_private *id_priv)\n static int cma_bind_addr(struct rdma_cm_id *id, struct sockaddr *src_addr,\n \t\t\t const struct sockaddr *dst_addr)\n {\n-\tif (!src_addr || !src_addr->sa_family) {\n-\t\tsrc_addr = (struct sockaddr *) &id->route.addr.src_addr;\n-\t\tsrc_addr->sa_family = dst_addr->sa_family;\n-\t\tif (IS_ENABLED(CONFIG_IPV6) &&\n-\t\t    dst_addr->sa_family == AF_INET6) {\n-\t\t\tstruct sockaddr_in6 *src_addr6 = (struct sockaddr_in6 *) src_addr;\n-\t\t\tstruct sockaddr_in6 *dst_addr6 = (struct sockaddr_in6 *) dst_addr;\n-\t\t\tsrc_addr6->sin6_scope_id = dst_addr6->sin6_scope_id;\n-\t\t\tif (ipv6_addr_type(&dst_addr6->sin6_addr) & IPV6_ADDR_LINKLOCAL)\n-\t\t\t\tid->route.addr.dev_addr.bound_dev_if = dst_addr6->sin6_scope_id;\n-\t\t} else if (dst_addr->sa_family == AF_IB) {\n-\t\t\t((struct sockaddr_ib *) src_addr)->sib_pkey =\n-\t\t\t\t((struct sockaddr_ib *) dst_addr)->sib_pkey;\n-\t\t}\n-\t}\n-\treturn rdma_bind_addr(id, src_addr);\n+\tstruct sockaddr_storage zero_sock = {};\n+\n+\tif (src_addr && src_addr->sa_family)\n+\t\treturn rdma_bind_addr(id, src_addr);\n+\n+\t/*\n+\t * When the src_addr is not specified, automatically supply an any addr\n+\t */\n+\tzero_sock.ss_family = dst_addr->sa_family;\n+\tif (IS_ENABLED(CONFIG_IPV6) && dst_addr->sa_family == AF_INET6) {\n+\t\tstruct sockaddr_in6 *src_addr6 =\n+\t\t\t(struct sockaddr_in6 *)&zero_sock;\n+\t\tstruct sockaddr_in6 *dst_addr6 =\n+\t\t\t(struct sockaddr_in6 *)dst_addr;\n+\n+\t\tsrc_addr6->sin6_scope_id = dst_addr6->sin6_scope_id;\n+\t\tif (ipv6_addr_type(&dst_addr6->sin6_addr) & IPV6_ADDR_LINKLOCAL)\n+\t\t\tid->route.addr.dev_addr.bound_dev_if =\n+\t\t\t\tdst_addr6->sin6_scope_id;\n+\t} else if (dst_addr->sa_family == AF_IB) {\n+\t\t((struct sockaddr_ib *)&zero_sock)->sib_pkey =\n+\t\t\t((struct sockaddr_ib *)dst_addr)->sib_pkey;\n+\t}\n+\treturn rdma_bind_addr(id, (struct sockaddr *)&zero_sock);\n }\n \n /*\n"
        ]
    },
    "874c5bfa1234dcef000574388df68a8d08274ecd": {
        "non_crash": [
            "diff --git a/fs/hfsplus/super.c b/fs/hfsplus/super.c\nindex 122ed89ebf9f..1986b4f18a90 100644\n--- a/fs/hfsplus/super.c\n+++ b/fs/hfsplus/super.c\n@@ -295,11 +295,11 @@ static void hfsplus_put_super(struct super_block *sb)\n \t\thfsplus_sync_fs(sb, 1);\n \t}\n \n+\tiput(sbi->alloc_file);\n+\tiput(sbi->hidden_dir);\n \thfs_btree_close(sbi->attr_tree);\n \thfs_btree_close(sbi->cat_tree);\n \thfs_btree_close(sbi->ext_tree);\n-\tiput(sbi->alloc_file);\n-\tiput(sbi->hidden_dir);\n \tkfree(sbi->s_vhdr_buf);\n \tkfree(sbi->s_backup_vhdr_buf);\n \tunload_nls(sbi->nls);\n"
        ]
    },
    "f0ec9a394925aafbdf13d0a7e6af4cff860f0ed6": {
        "non_crash": [
            "diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c\nindex bd306ba3ade5..1df95145f574 100644\n--- a/net/bluetooth/hci_event.c\n+++ b/net/bluetooth/hci_event.c\n@@ -2566,7 +2566,6 @@ static void hci_inquiry_result_evt(struct hci_dev *hdev, struct sk_buff *skb)\n static void hci_conn_complete_evt(struct hci_dev *hdev, struct sk_buff *skb)\n {\n \tstruct hci_ev_conn_complete *ev = (void *) skb->data;\n-\tstruct inquiry_entry *ie;\n \tstruct hci_conn *conn;\n \n \tBT_DBG(\"%s\", hdev->name);\n@@ -2575,13 +2574,19 @@ static void hci_conn_complete_evt(struct hci_dev *hdev, struct sk_buff *skb)\n \n \tconn = hci_conn_hash_lookup_ba(hdev, ev->link_type, &ev->bdaddr);\n \tif (!conn) {\n-\t\t/* Connection may not exist if auto-connected. Check the inquiry\n-\t\t * cache to see if we've already discovered this bdaddr before.\n-\t\t * If found and link is an ACL type, create a connection class\n+\t\t/* Connection may not exist if auto-connected. Check the bredr\n+\t\t * allowlist to see if this device is allowed to auto connect.\n+\t\t * If link is an ACL type, create a connection class\n \t\t * automatically.\n+\t\t *\n+\t\t * Auto-connect will only occur if the event filter is\n+\t\t * programmed with a given address. Right now, event filter is\n+\t\t * only used during suspend.\n \t\t */\n-\t\tie = hci_inquiry_cache_lookup(hdev, &ev->bdaddr);\n-\t\tif (ie && ev->link_type == ACL_LINK) {\n+\t\tif (ev->link_type == ACL_LINK &&\n+\t\t    hci_bdaddr_list_lookup_with_flags(&hdev->whitelist,\n+\t\t\t\t\t\t      &ev->bdaddr,\n+\t\t\t\t\t\t      BDADDR_BREDR)) {\n \t\t\tconn = hci_conn_add(hdev, ev->link_type, &ev->bdaddr,\n \t\t\t\t\t    HCI_ROLE_SLAVE);\n \t\t\tif (!conn) {\n"
        ]
    },
    "ecd1f6c4b2442ea4c47c7331ed1c27c0cfdc627e": {
        "non_crash": [
            "diff --git a/fs/ext4/migrate.c b/fs/ext4/migrate.c\nindex 0a220ec9862d..a19a9661646e 100644\n--- a/fs/ext4/migrate.c\n+++ b/fs/ext4/migrate.c\n@@ -424,7 +424,8 @@ int ext4_ext_migrate(struct inode *inode)\n \t * already is extent-based, error out.\n \t */\n \tif (!ext4_has_feature_extents(inode->i_sb) ||\n-\t    (ext4_test_inode_flag(inode, EXT4_INODE_EXTENTS)))\n+\t    ext4_test_inode_flag(inode, EXT4_INODE_EXTENTS) ||\n+\t    ext4_has_inline_data(inode))\n \t\treturn -EINVAL;\n \n \tif (S_ISLNK(inode->i_mode) && inode->i_blocks == 0)\n"
        ]
    },
    "0264f823322ea8600fbe3fb7e9e016569ca542d8": {
        "non_crash": [
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex b98ec6e1a222..7ebd58a1c431 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -672,6 +672,11 @@ int vb2_core_reqbufs(struct vb2_queue *q, enum vb2_memory memory,\n \t\treturn -EBUSY;\n \t}\n \n+\tif (q->waiting_in_dqbuf && *count) {\n+\t\tdprintk(1, \"another dup()ped fd is waiting for a buffer\\n\");\n+\t\treturn -EBUSY;\n+\t}\n+\n \tif (*count == 0 || q->num_buffers != 0 ||\n \t    (q->memory != VB2_MEMORY_UNKNOWN && q->memory != memory)) {\n \t\t/*\n@@ -807,6 +812,10 @@ int vb2_core_create_bufs(struct vb2_queue *q, enum vb2_memory memory,\n \t}\n \n \tif (!q->num_buffers) {\n+\t\tif (q->waiting_in_dqbuf && *count) {\n+\t\t\tdprintk(1, \"another dup()ped fd is waiting for a buffer\\n\");\n+\t\t\treturn -EBUSY;\n+\t\t}\n \t\tmemset(q->alloc_devs, 0, sizeof(q->alloc_devs));\n \t\tq->memory = memory;\n \t\tq->waiting_for_buffers = !q->is_output;\n@@ -1656,6 +1665,11 @@ static int __vb2_wait_for_done_vb(struct vb2_queue *q, int nonblocking)\n \tfor (;;) {\n \t\tint ret;\n \n+\t\tif (q->waiting_in_dqbuf) {\n+\t\t\tdprintk(1, \"another dup()ped fd is waiting for a buffer\\n\");\n+\t\t\treturn -EBUSY;\n+\t\t}\n+\n \t\tif (!q->streaming) {\n \t\t\tdprintk(1, \"streaming off, will not wait for buffers\\n\");\n \t\t\treturn -EINVAL;\n@@ -1683,6 +1697,7 @@ static int __vb2_wait_for_done_vb(struct vb2_queue *q, int nonblocking)\n \t\t\treturn -EAGAIN;\n \t\t}\n \n+\t\tq->waiting_in_dqbuf = 1;\n \t\t/*\n \t\t * We are streaming and blocking, wait for another buffer to\n \t\t * become ready or for streamoff. Driver's lock is released to\n@@ -1703,6 +1718,7 @@ static int __vb2_wait_for_done_vb(struct vb2_queue *q, int nonblocking)\n \t\t * the locks or return an error if one occurred.\n \t\t */\n \t\tcall_void_qop(q, wait_finish, q);\n+\t\tq->waiting_in_dqbuf = 0;\n \t\tif (ret) {\n \t\t\tdprintk(1, \"sleep was interrupted\\n\");\n \t\t\treturn ret;\n@@ -2585,6 +2601,12 @@ static size_t __vb2_perform_fileio(struct vb2_queue *q, char __user *data, size_\n \tif (!data)\n \t\treturn -EINVAL;\n \n+\tif (q->waiting_in_dqbuf) {\n+\t\tdprintk(3, \"another dup()ped fd is %s\\n\",\n+\t\t\tread ? \"reading\" : \"writing\");\n+\t\treturn -EBUSY;\n+\t}\n+\n \t/*\n \t * Initialize emulator on first call.\n \t */\ndiff --git a/include/media/videobuf2-core.h b/include/media/videobuf2-core.h\nindex fe010ad62b90..22f3ff76a8b5 100644\n--- a/include/media/videobuf2-core.h\n+++ b/include/media/videobuf2-core.h\n@@ -596,6 +596,7 @@ struct vb2_queue {\n \tunsigned int\t\t\tstart_streaming_called:1;\n \tunsigned int\t\t\terror:1;\n \tunsigned int\t\t\twaiting_for_buffers:1;\n+\tunsigned int\t\t\twaiting_in_dqbuf:1;\n \tunsigned int\t\t\tis_multiplanar:1;\n \tunsigned int\t\t\tis_output:1;\n \tunsigned int\t\t\tcopy_timestamp:1;\n"
        ]
    },
    "d8e8c32d387c7b35680b035aab36efdefe253ab7": {
        "non_crash": [
            "diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c\nindex 3c62a7eaf24b..ba22790f95f7 100644\n--- a/fs/btrfs/extent-tree.c\n+++ b/fs/btrfs/extent-tree.c\n@@ -3481,7 +3481,6 @@ btrfs_release_block_group(struct btrfs_block_group *cache,\n  * Helper function for find_free_extent().\n  *\n  * Return -ENOENT to inform caller that we need fallback to unclustered mode.\n- * Return -EAGAIN to inform caller that we need to re-search this block group\n  * Return >0 to inform caller that we find nothing\n  * Return 0 means we have found a location and set ffe_ctl->found_offset.\n  */\n@@ -3562,14 +3561,6 @@ static int find_free_extent_clustered(struct btrfs_block_group *bg,\n \t\t\ttrace_btrfs_reserve_extent_cluster(bg, ffe_ctl);\n \t\t\treturn 0;\n \t\t}\n-\t} else if (!ffe_ctl->cached && ffe_ctl->loop > LOOP_CACHING_NOWAIT &&\n-\t\t   !ffe_ctl->retry_clustered) {\n-\t\tspin_unlock(&last_ptr->refill_lock);\n-\n-\t\tffe_ctl->retry_clustered = true;\n-\t\tbtrfs_wait_block_group_cache_progress(bg, ffe_ctl->num_bytes +\n-\t\t\t\tffe_ctl->empty_cluster + ffe_ctl->empty_size);\n-\t\treturn -EAGAIN;\n \t}\n \t/*\n \t * At this point we either didn't find a cluster or we weren't able to\n@@ -3584,7 +3575,6 @@ static int find_free_extent_clustered(struct btrfs_block_group *bg,\n /*\n  * Return >0 to inform caller that we find nothing\n  * Return 0 when we found an free extent and set ffe_ctrl->found_offset\n- * Return -EAGAIN to inform caller that we need to re-search this block group\n  */\n static int find_free_extent_unclustered(struct btrfs_block_group *bg,\n \t\t\t\t\tstruct find_free_extent_ctl *ffe_ctl)\n@@ -3622,25 +3612,8 @@ static int find_free_extent_unclustered(struct btrfs_block_group *bg,\n \toffset = btrfs_find_space_for_alloc(bg, ffe_ctl->search_start,\n \t\t\tffe_ctl->num_bytes, ffe_ctl->empty_size,\n \t\t\t&ffe_ctl->max_extent_size);\n-\n-\t/*\n-\t * If we didn't find a chunk, and we haven't failed on this block group\n-\t * before, and this block group is in the middle of caching and we are\n-\t * ok with waiting, then go ahead and wait for progress to be made, and\n-\t * set @retry_unclustered to true.\n-\t *\n-\t * If @retry_unclustered is true then we've already waited on this\n-\t * block group once and should move on to the next block group.\n-\t */\n-\tif (!offset && !ffe_ctl->retry_unclustered && !ffe_ctl->cached &&\n-\t    ffe_ctl->loop > LOOP_CACHING_NOWAIT) {\n-\t\tbtrfs_wait_block_group_cache_progress(bg, ffe_ctl->num_bytes +\n-\t\t\t\t\t\t      ffe_ctl->empty_size);\n-\t\tffe_ctl->retry_unclustered = true;\n-\t\treturn -EAGAIN;\n-\t} else if (!offset) {\n+\tif (!offset)\n \t\treturn 1;\n-\t}\n \tffe_ctl->found_offset = offset;\n \treturn 0;\n }\n@@ -3654,7 +3627,7 @@ static int do_allocation_clustered(struct btrfs_block_group *block_group,\n \t/* We want to try and use the cluster allocator, so lets look there */\n \tif (ffe_ctl->last_ptr && ffe_ctl->use_cluster) {\n \t\tret = find_free_extent_clustered(block_group, ffe_ctl, bg_ret);\n-\t\tif (ret >= 0 || ret == -EAGAIN)\n+\t\tif (ret >= 0)\n \t\t\treturn ret;\n \t\t/* ret == -ENOENT case falls through */\n \t}\n@@ -3872,8 +3845,7 @@ static void release_block_group(struct btrfs_block_group *block_group,\n {\n \tswitch (ffe_ctl->policy) {\n \tcase BTRFS_EXTENT_ALLOC_CLUSTERED:\n-\t\tffe_ctl->retry_clustered = false;\n-\t\tffe_ctl->retry_unclustered = false;\n+\t\tffe_ctl->retry_uncached = false;\n \t\tbreak;\n \tcase BTRFS_EXTENT_ALLOC_ZONED:\n \t\t/* Nothing to do */\n@@ -4220,9 +4192,7 @@ static noinline int find_free_extent(struct btrfs_root *root,\n \tffe_ctl->orig_have_caching_bg = false;\n \tffe_ctl->index = btrfs_bg_flags_to_raid_index(ffe_ctl->flags);\n \tffe_ctl->loop = 0;\n-\t/* For clustered allocation */\n-\tffe_ctl->retry_clustered = false;\n-\tffe_ctl->retry_unclustered = false;\n+\tffe_ctl->retry_uncached = false;\n \tffe_ctl->cached = 0;\n \tffe_ctl->max_extent_size = 0;\n \tffe_ctl->total_free_space = 0;\n@@ -4373,16 +4343,12 @@ static noinline int find_free_extent(struct btrfs_root *root,\n \n \t\tbg_ret = NULL;\n \t\tret = do_allocation(block_group, ffe_ctl, &bg_ret);\n-\t\tif (ret == 0) {\n-\t\t\tif (bg_ret && bg_ret != block_group) {\n-\t\t\t\tbtrfs_release_block_group(block_group,\n-\t\t\t\t\t\t\t  ffe_ctl->delalloc);\n-\t\t\t\tblock_group = bg_ret;\n-\t\t\t}\n-\t\t} else if (ret == -EAGAIN) {\n-\t\t\tgoto have_block_group;\n-\t\t} else if (ret > 0) {\n+\t\tif (ret > 0)\n \t\t\tgoto loop;\n+\n+\t\tif (bg_ret && bg_ret != block_group) {\n+\t\t\tbtrfs_release_block_group(block_group, ffe_ctl->delalloc);\n+\t\t\tblock_group = bg_ret;\n \t\t}\n \n \t\t/* Checks */\n@@ -4423,6 +4389,15 @@ static noinline int find_free_extent(struct btrfs_root *root,\n \t\tbtrfs_release_block_group(block_group, ffe_ctl->delalloc);\n \t\tbreak;\n loop:\n+\t\tif (!ffe_ctl->cached && ffe_ctl->loop > LOOP_CACHING_NOWAIT &&\n+\t\t    !ffe_ctl->retry_uncached) {\n+\t\t\tffe_ctl->retry_uncached = true;\n+\t\t\tbtrfs_wait_block_group_cache_progress(block_group,\n+\t\t\t\t\t\tffe_ctl->num_bytes +\n+\t\t\t\t\t\tffe_ctl->empty_cluster +\n+\t\t\t\t\t\tffe_ctl->empty_size);\n+\t\t\tgoto have_block_group;\n+\t\t}\n \t\trelease_block_group(block_group, ffe_ctl, ffe_ctl->delalloc);\n \t\tcond_resched();\n \t}\ndiff --git a/fs/btrfs/extent-tree.h b/fs/btrfs/extent-tree.h\nindex b9e148adcd28..88c249c37516 100644\n--- a/fs/btrfs/extent-tree.h\n+++ b/fs/btrfs/extent-tree.h\n@@ -48,16 +48,11 @@ struct find_free_extent_ctl {\n \tint loop;\n \n \t/*\n-\t * Whether we're refilling a cluster, if true we need to re-search\n-\t * current block group but don't try to refill the cluster again.\n+\t * Set to true if we're retrying the allocation on this block group\n+\t * after waiting for caching progress, this is so that we retry only\n+\t * once before moving on to another block group.\n \t */\n-\tbool retry_clustered;\n-\n-\t/*\n-\t * Whether we're updating free space cache, if true we need to re-search\n-\t * current block group but don't try updating free space cache again.\n-\t */\n-\tbool retry_unclustered;\n+\tbool retry_uncached;\n \n \t/* If current block group is cached */\n \tint cached;\n"
        ]
    },
    "699e4f546c33df9781a67891d42766bbbe3ca30b": {
        "non_crash": [
            "diff --git a/fs/fuse/dir.c b/fs/fuse/dir.c\nindex 2798fbe8d001..80a2181b402b 100644\n--- a/fs/fuse/dir.c\n+++ b/fs/fuse/dir.c\n@@ -1079,7 +1079,7 @@ int fuse_reverse_inval_entry(struct fuse_conn *fc, u64 parent_nodeid,\n \tif (!parent)\n \t\treturn -ENOENT;\n \n-\tinode_lock(parent);\n+\tinode_lock_nested(parent, I_MUTEX_PARENT);\n \tif (!S_ISDIR(parent->i_mode))\n \t\tgoto unlock;\n \n"
        ]
    },
    "625eef83808cdc8a4d6775801b04e985eb32fcf7": {
        "non_crash": [
            "diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c\nindex 19c707bc8801..3f99f02dc1fe 100644\n--- a/fs/btrfs/inode.c\n+++ b/fs/btrfs/inode.c\n@@ -7264,7 +7264,7 @@ static struct extent_map *create_io_em(struct btrfs_inode *inode, u64 start,\n static int btrfs_get_blocks_direct_write(struct extent_map **map,\n \t\t\t\t\t struct inode *inode,\n \t\t\t\t\t struct btrfs_dio_data *dio_data,\n-\t\t\t\t\t u64 start, u64 len,\n+\t\t\t\t\t u64 start, u64 *lenp,\n \t\t\t\t\t unsigned int iomap_flags)\n {\n \tconst bool nowait = (iomap_flags & IOMAP_NOWAIT);\n@@ -7275,6 +7275,7 @@ static int btrfs_get_blocks_direct_write(struct extent_map **map,\n \tstruct btrfs_block_group *bg;\n \tbool can_nocow = false;\n \tbool space_reserved = false;\n+\tu64 len = *lenp;\n \tu64 prev_len;\n \tint ret = 0;\n \n@@ -7345,15 +7346,19 @@ static int btrfs_get_blocks_direct_write(struct extent_map **map,\n \t\tfree_extent_map(em);\n \t\t*map = NULL;\n \n-\t\tif (nowait)\n-\t\t\treturn -EAGAIN;\n+\t\tif (nowait) {\n+\t\t\tret = -EAGAIN;\n+\t\t\tgoto out;\n+\t\t}\n \n \t\t/*\n \t\t * If we could not allocate data space before locking the file\n \t\t * range and we can't do a NOCOW write, then we have to fail.\n \t\t */\n-\t\tif (!dio_data->data_space_reserved)\n-\t\t\treturn -ENOSPC;\n+\t\tif (!dio_data->data_space_reserved) {\n+\t\t\tret = -ENOSPC;\n+\t\t\tgoto out;\n+\t\t}\n \n \t\t/*\n \t\t * We have to COW and we have already reserved data space before,\n@@ -7394,6 +7399,7 @@ static int btrfs_get_blocks_direct_write(struct extent_map **map,\n \t\tbtrfs_delalloc_release_extents(BTRFS_I(inode), len);\n \t\tbtrfs_delalloc_release_metadata(BTRFS_I(inode), len, true);\n \t}\n+\t*lenp = len;\n \treturn ret;\n }\n \n@@ -7570,7 +7576,7 @@ static int btrfs_dio_iomap_begin(struct inode *inode, loff_t start,\n \n \tif (write) {\n \t\tret = btrfs_get_blocks_direct_write(&em, inode, dio_data,\n-\t\t\t\t\t\t    start, len, flags);\n+\t\t\t\t\t\t    start, &len, flags);\n \t\tif (ret < 0)\n \t\t\tgoto unlock_err;\n \t\tunlock_extents = true;\n"
        ]
    },
    "1f07634f79ac1436ec38e2e71d73392404b17bbb": {
        "non_crash": [
            "diff --git a/fs/ext4/mmp.c b/fs/ext4/mmp.c\nindex 4022bc713421..0aaf38ffcb6e 100644\n--- a/fs/ext4/mmp.c\n+++ b/fs/ext4/mmp.c\n@@ -39,28 +39,36 @@ static void ext4_mmp_csum_set(struct super_block *sb, struct mmp_struct *mmp)\n  * Write the MMP block using REQ_SYNC to try to get the block on-disk\n  * faster.\n  */\n-static int write_mmp_block(struct super_block *sb, struct buffer_head *bh)\n+static int write_mmp_block_thawed(struct super_block *sb,\n+\t\t\t\t  struct buffer_head *bh)\n {\n \tstruct mmp_struct *mmp = (struct mmp_struct *)(bh->b_data);\n \n-\t/*\n-\t * We protect against freezing so that we don't create dirty buffers\n-\t * on frozen filesystem.\n-\t */\n-\tsb_start_write(sb);\n \text4_mmp_csum_set(sb, mmp);\n \tlock_buffer(bh);\n \tbh->b_end_io = end_buffer_write_sync;\n \tget_bh(bh);\n \tsubmit_bh(REQ_OP_WRITE | REQ_SYNC | REQ_META | REQ_PRIO, bh);\n \twait_on_buffer(bh);\n-\tsb_end_write(sb);\n \tif (unlikely(!buffer_uptodate(bh)))\n \t\treturn -EIO;\n-\n \treturn 0;\n }\n \n+static int write_mmp_block(struct super_block *sb, struct buffer_head *bh)\n+{\n+\tint err;\n+\n+\t/*\n+\t * We protect against freezing so that we don't create dirty buffers\n+\t * on frozen filesystem.\n+\t */\n+\tsb_start_write(sb);\n+\terr = write_mmp_block_thawed(sb, bh);\n+\tsb_end_write(sb);\n+\treturn err;\n+}\n+\n /*\n  * Read the MMP block. It _must_ be read from disk and hence we clear the\n  * uptodate flag on the buffer.\n@@ -344,7 +352,11 @@ int ext4_multi_mount_protect(struct super_block *sb,\n \tseq = mmp_new_seq();\n \tmmp->mmp_seq = cpu_to_le32(seq);\n \n-\tretval = write_mmp_block(sb, bh);\n+\t/*\n+\t * On mount / remount we are protected against fs freezing (by s_umount\n+\t * semaphore) and grabbing freeze protection upsets lockdep\n+\t */\n+\tretval = write_mmp_block_thawed(sb, bh);\n \tif (retval)\n \t\tgoto failed;\n \n"
        ]
    },
    "848057f402cb7a9107901060c07f48cd2e00e0e9": {
        "non_crash": [
            "diff --git a/drivers/scsi/hosts.c b/drivers/scsi/hosts.c\nindex f7f62e56afca..9b6fbbe15d92 100644\n--- a/drivers/scsi/hosts.c\n+++ b/drivers/scsi/hosts.c\n@@ -341,9 +341,6 @@ static void scsi_host_dev_release(struct device *dev)\n \tstruct Scsi_Host *shost = dev_to_shost(dev);\n \tstruct device *parent = dev->parent;\n \n-\t/* In case scsi_remove_host() has not been called. */\n-\tscsi_proc_hostdir_rm(shost->hostt);\n-\n \t/* Wait for functions invoked through call_rcu(&scmd->rcu, ...) */\n \trcu_barrier();\n \n"
        ]
    },
    "82136e2452d5e1ea212f5bf76fcd8db36512f981": {
        "non_crash": [
            "diff --git a/fs/erofs/inode.c b/fs/erofs/inode.c\nindex 95a403720e8c..16cf9a283557 100644\n--- a/fs/erofs/inode.c\n+++ b/fs/erofs/inode.c\n@@ -214,7 +214,7 @@ static int erofs_fill_symlink(struct inode *inode, void *kaddr,\n \n \t/* if it cannot be handled with fast symlink scheme */\n \tif (vi->datalayout != EROFS_INODE_FLAT_INLINE ||\n-\t    inode->i_size >= EROFS_BLKSIZ) {\n+\t    inode->i_size >= EROFS_BLKSIZ || inode->i_size < 0) {\n \t\tinode->i_op = &erofs_symlink_iops;\n \t\treturn 0;\n \t}\n"
        ]
    },
    "bb3342477c4669ef082c7056b6e2be4f903e646e": {
        "non_crash": [
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex b074144f6f83..232dd7b6cca1 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -455,6 +455,8 @@ int nilfs_read_inode_common(struct inode *inode,\n \tinode->i_atime.tv_nsec = le32_to_cpu(raw_inode->i_mtime_nsec);\n \tinode->i_ctime.tv_nsec = le32_to_cpu(raw_inode->i_ctime_nsec);\n \tinode->i_mtime.tv_nsec = le32_to_cpu(raw_inode->i_mtime_nsec);\n+\tif (nilfs_is_metadata_file_inode(inode) && !S_ISREG(inode->i_mode))\n+\t\treturn -EIO; /* this inode is for metadata and corrupted */\n \tif (inode->i_nlink == 0)\n \t\treturn -ESTALE; /* this inode is deleted */\n \n"
        ]
    },
    "4892aaa2ef26ab83c6b974f1db422f526f9aaec0": {
        "non_crash": [
            "diff --git a/drivers/video/fbdev/core/bitblit.c b/drivers/video/fbdev/core/bitblit.c\nindex ca935c09a261..35ebeeccde4d 100644\n--- a/drivers/video/fbdev/core/bitblit.c\n+++ b/drivers/video/fbdev/core/bitblit.c\n@@ -216,7 +216,7 @@ static void bit_clear_margins(struct vc_data *vc, struct fb_info *info,\n \tregion.color = color;\n \tregion.rop = ROP_COPY;\n \n-\tif (rw && !bottom_only) {\n+\tif ((int) rw > 0 && !bottom_only) {\n \t\tregion.dx = info->var.xoffset + rs;\n \t\tregion.dy = 0;\n \t\tregion.width = rw;\n@@ -224,7 +224,7 @@ static void bit_clear_margins(struct vc_data *vc, struct fb_info *info,\n \t\tinfo->fbops->fb_fillrect(info, &region);\n \t}\n \n-\tif (bh) {\n+\tif ((int) bh > 0) {\n \t\tregion.dx = info->var.xoffset;\n \t\tregion.dy = info->var.yoffset + bs;\n \t\tregion.width = rs;\ndiff --git a/drivers/video/fbdev/core/fbcon_ccw.c b/drivers/video/fbdev/core/fbcon_ccw.c\nindex dfa9a8aa4509..78f3a5621478 100644\n--- a/drivers/video/fbdev/core/fbcon_ccw.c\n+++ b/drivers/video/fbdev/core/fbcon_ccw.c\n@@ -201,7 +201,7 @@ static void ccw_clear_margins(struct vc_data *vc, struct fb_info *info,\n \tregion.color = color;\n \tregion.rop = ROP_COPY;\n \n-\tif (rw && !bottom_only) {\n+\tif ((int) rw > 0 && !bottom_only) {\n \t\tregion.dx = 0;\n \t\tregion.dy = info->var.yoffset;\n \t\tregion.height = rw;\n@@ -209,7 +209,7 @@ static void ccw_clear_margins(struct vc_data *vc, struct fb_info *info,\n \t\tinfo->fbops->fb_fillrect(info, &region);\n \t}\n \n-\tif (bh) {\n+\tif ((int) bh > 0) {\n \t\tregion.dx = info->var.xoffset + bs;\n \t\tregion.dy = 0;\n                 region.height = info->var.yres_virtual;\ndiff --git a/drivers/video/fbdev/core/fbcon_cw.c b/drivers/video/fbdev/core/fbcon_cw.c\nindex ce08251bfd38..fd098ff17574 100644\n--- a/drivers/video/fbdev/core/fbcon_cw.c\n+++ b/drivers/video/fbdev/core/fbcon_cw.c\n@@ -184,7 +184,7 @@ static void cw_clear_margins(struct vc_data *vc, struct fb_info *info,\n \tregion.color = color;\n \tregion.rop = ROP_COPY;\n \n-\tif (rw && !bottom_only) {\n+\tif ((int) rw > 0 && !bottom_only) {\n \t\tregion.dx = 0;\n \t\tregion.dy = info->var.yoffset + rs;\n \t\tregion.height = rw;\n@@ -192,7 +192,7 @@ static void cw_clear_margins(struct vc_data *vc, struct fb_info *info,\n \t\tinfo->fbops->fb_fillrect(info, &region);\n \t}\n \n-\tif (bh) {\n+\tif ((int) bh > 0) {\n \t\tregion.dx = info->var.xoffset;\n \t\tregion.dy = info->var.yoffset;\n                 region.height = info->var.yres;\ndiff --git a/drivers/video/fbdev/core/fbcon_ud.c b/drivers/video/fbdev/core/fbcon_ud.c\nindex 1936afc78fec..e165a3fad29a 100644\n--- a/drivers/video/fbdev/core/fbcon_ud.c\n+++ b/drivers/video/fbdev/core/fbcon_ud.c\n@@ -231,7 +231,7 @@ static void ud_clear_margins(struct vc_data *vc, struct fb_info *info,\n \tregion.color = color;\n \tregion.rop = ROP_COPY;\n \n-\tif (rw && !bottom_only) {\n+\tif ((int) rw > 0 && !bottom_only) {\n \t\tregion.dy = 0;\n \t\tregion.dx = info->var.xoffset;\n \t\tregion.width  = rw;\n@@ -239,7 +239,7 @@ static void ud_clear_margins(struct vc_data *vc, struct fb_info *info,\n \t\tinfo->fbops->fb_fillrect(info, &region);\n \t}\n \n-\tif (bh) {\n+\tif ((int) bh > 0) {\n \t\tregion.dy = info->var.yoffset;\n \t\tregion.dx = info->var.xoffset;\n                 region.height  = bh;\n"
        ]
    },
    "e2907149c69cbccae0842eb502b8af4f6fac52a0": {
        "non_crash": [
            "diff --git a/fs/xfs/xfs_buf_item_recover.c b/fs/xfs/xfs_buf_item_recover.c\nindex ffa94102094d..43167f543afc 100644\n--- a/fs/xfs/xfs_buf_item_recover.c\n+++ b/fs/xfs/xfs_buf_item_recover.c\n@@ -943,6 +943,16 @@ xlog_recover_buf_commit_pass2(\n \tif (lsn && lsn != -1 && XFS_LSN_CMP(lsn, current_lsn) >= 0) {\n \t\ttrace_xfs_log_recover_buf_skip(log, buf_f);\n \t\txlog_recover_validate_buf_type(mp, bp, buf_f, NULLCOMMITLSN);\n+\n+\t\t/*\n+\t\t * We're skipping replay of this buffer log item due to the log\n+\t\t * item LSN being behind the ondisk buffer.  Verify the buffer\n+\t\t * contents since we aren't going to run the write verifier.\n+\t\t */\n+\t\tif (bp->b_ops) {\n+\t\t\tbp->b_ops->verify_read(bp);\n+\t\t\terror = bp->b_error;\n+\t\t}\n \t\tgoto out_release;\n \t}\n \n"
        ]
    },
    "74c4de068e77c137156235cc06a904c9baea491f": {
        "non_crash": [
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex 1310d2d5feb3..a8ce522ac747 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -917,6 +917,7 @@ void nilfs_evict_inode(struct inode *inode)\n \tstruct nilfs_transaction_info ti;\n \tstruct super_block *sb = inode->i_sb;\n \tstruct nilfs_inode_info *ii = NILFS_I(inode);\n+\tstruct the_nilfs *nilfs;\n \tint ret;\n \n \tif (inode->i_nlink || !ii->i_root || unlikely(is_bad_inode(inode))) {\n@@ -929,6 +930,23 @@ void nilfs_evict_inode(struct inode *inode)\n \n \ttruncate_inode_pages_final(&inode->i_data);\n \n+\tnilfs = sb->s_fs_info;\n+\tif (unlikely(sb_rdonly(sb) || !nilfs->ns_writer)) {\n+\t\t/*\n+\t\t * If this inode is about to be disposed after the file system\n+\t\t * has been degraded to read-only due to file system corruption\n+\t\t * or after the writer has been detached, do not make any\n+\t\t * changes that cause writes, just clear it.\n+\t\t * Do this check after read-locking ns_segctor_sem by\n+\t\t * nilfs_transaction_begin() in order to avoid a race with\n+\t\t * the writer detach operation.\n+\t\t */\n+\t\tclear_inode(inode);\n+\t\tnilfs_clear_inode(inode);\n+\t\tnilfs_transaction_abort(sb);\n+\t\treturn;\n+\t}\n+\n \t/* TODO: some of the following operations may fail.  */\n \tnilfs_truncate_bmap(ii, 0);\n \tnilfs_mark_inode_dirty(inode);\n"
        ]
    },
    "8dba39eccdf108d625bf6acb2bea1aa0c7e1fd61": {
        "non_crash": [
            "diff --git a/net/ipv4/netfilter/arp_tables.c b/net/ipv4/netfilter/arp_tables.c\nindex 069f72edb264..f1f78a742b36 100644\n--- a/net/ipv4/netfilter/arp_tables.c\n+++ b/net/ipv4/netfilter/arp_tables.c\n@@ -496,12 +496,13 @@ static inline int check_entry_size_and_hooks(struct arpt_entry *e,\n \treturn 0;\n }\n \n-static inline void cleanup_entry(struct arpt_entry *e)\n+static void cleanup_entry(struct arpt_entry *e, struct net *net)\n {\n \tstruct xt_tgdtor_param par;\n \tstruct xt_entry_target *t;\n \n \tt = arpt_get_target(e);\n+\tpar.net      = net;\n \tpar.target   = t->u.kernel.target;\n \tpar.targinfo = t->data;\n \tpar.family   = NFPROTO_ARP;\n@@ -584,7 +585,7 @@ static int translate_table(struct net *net,\n \t\txt_entry_foreach(iter, entry0, newinfo->size) {\n \t\t\tif (i-- == 0)\n \t\t\t\tbreak;\n-\t\t\tcleanup_entry(iter);\n+\t\t\tcleanup_entry(iter, net);\n \t\t}\n \t\treturn ret;\n \t}\n@@ -927,7 +928,7 @@ static int __do_replace(struct net *net, const char *name,\n \t/* Decrease module usage counts and free resource */\n \tloc_cpu_old_entry = oldinfo->entries;\n \txt_entry_foreach(iter, loc_cpu_old_entry, oldinfo->size)\n-\t\tcleanup_entry(iter);\n+\t\tcleanup_entry(iter, net);\n \n \txt_free_table_info(oldinfo);\n \tif (copy_to_user(counters_ptr, counters,\n@@ -990,7 +991,7 @@ static int do_replace(struct net *net, const void __user *user,\n \n  free_newinfo_untrans:\n \txt_entry_foreach(iter, loc_cpu_entry, newinfo->size)\n-\t\tcleanup_entry(iter);\n+\t\tcleanup_entry(iter, net);\n  free_newinfo:\n \txt_free_table_info(newinfo);\n \treturn ret;\n@@ -1287,7 +1288,7 @@ static int compat_do_replace(struct net *net, void __user *user,\n \n  free_newinfo_untrans:\n \txt_entry_foreach(iter, loc_cpu_entry, newinfo->size)\n-\t\tcleanup_entry(iter);\n+\t\tcleanup_entry(iter, net);\n  free_newinfo:\n \txt_free_table_info(newinfo);\n \treturn ret;\n@@ -1514,7 +1515,7 @@ static int do_arpt_get_ctl(struct sock *sk, int cmd, void __user *user, int *len\n \treturn ret;\n }\n \n-static void __arpt_unregister_table(struct xt_table *table)\n+static void __arpt_unregister_table(struct net *net, struct xt_table *table)\n {\n \tstruct xt_table_info *private;\n \tvoid *loc_cpu_entry;\n@@ -1526,7 +1527,7 @@ static void __arpt_unregister_table(struct xt_table *table)\n \t/* Decrease module usage counts and free resources */\n \tloc_cpu_entry = private->entries;\n \txt_entry_foreach(iter, loc_cpu_entry, private->size)\n-\t\tcleanup_entry(iter);\n+\t\tcleanup_entry(iter, net);\n \tif (private->number > private->initial_entries)\n \t\tmodule_put(table_owner);\n \txt_free_table_info(private);\n@@ -1566,7 +1567,7 @@ int arpt_register_table(struct net *net,\n \n \tret = nf_register_net_hooks(net, ops, hweight32(table->valid_hooks));\n \tif (ret != 0) {\n-\t\t__arpt_unregister_table(new_table);\n+\t\t__arpt_unregister_table(net, new_table);\n \t\t*res = NULL;\n \t}\n \n@@ -1581,7 +1582,7 @@ void arpt_unregister_table(struct net *net, struct xt_table *table,\n \t\t\t   const struct nf_hook_ops *ops)\n {\n \tnf_unregister_net_hooks(net, ops, hweight32(table->valid_hooks));\n-\t__arpt_unregister_table(table);\n+\t__arpt_unregister_table(net, table);\n }\n \n /* The built-in targets: standard (NULL) and error. */\n"
        ]
    },
    "9d6af32008ffd651175d152c5bea92cf767ae38c": {
        "non_crash": [
            "diff --git a/io_uring/poll.c b/io_uring/poll.c\nindex ee7da6150ec4..cf6a70bd54e0 100644\n--- a/io_uring/poll.c\n+++ b/io_uring/poll.c\n@@ -533,6 +533,14 @@ static bool io_poll_can_finish_inline(struct io_kiocb *req,\n \treturn pt->owning || io_poll_get_ownership(req);\n }\n \n+static void io_poll_add_hash(struct io_kiocb *req)\n+{\n+\tif (req->flags & REQ_F_HASH_LOCKED)\n+\t\tio_poll_req_insert_locked(req);\n+\telse\n+\t\tio_poll_req_insert(req);\n+}\n+\n /*\n  * Returns 0 when it's handed over for polling. The caller owns the requests if\n  * it returns non-zero, but otherwise should not touch it. Negative values\n@@ -591,18 +599,17 @@ static int __io_arm_poll_handler(struct io_kiocb *req,\n \n \tif (mask &&\n \t   ((poll->events & (EPOLLET|EPOLLONESHOT)) == (EPOLLET|EPOLLONESHOT))) {\n-\t\tif (!io_poll_can_finish_inline(req, ipt))\n+\t\tif (!io_poll_can_finish_inline(req, ipt)) {\n+\t\t\tio_poll_add_hash(req);\n \t\t\treturn 0;\n+\t\t}\n \t\tio_poll_remove_entries(req);\n \t\tipt->result_mask = mask;\n \t\t/* no one else has access to the req, forget about the ref */\n \t\treturn 1;\n \t}\n \n-\tif (req->flags & REQ_F_HASH_LOCKED)\n-\t\tio_poll_req_insert_locked(req);\n-\telse\n-\t\tio_poll_req_insert(req);\n+\tio_poll_add_hash(req);\n \n \tif (mask && (poll->events & EPOLLET) &&\n \t    io_poll_can_finish_inline(req, ipt)) {\n"
        ]
    },
    "0be4824a86385f022a4f6f5104bcb9246032fdd9": {
        "non_crash": [
            "diff --git a/sound/core/oss/pcm_oss.c b/sound/core/oss/pcm_oss.c\nindex 3ee9edf85815..f158f0abd25d 100644\n--- a/sound/core/oss/pcm_oss.c\n+++ b/sound/core/oss/pcm_oss.c\n@@ -774,6 +774,11 @@ static int snd_pcm_oss_period_size(struct snd_pcm_substream *substream,\n \n \tif (oss_period_size < 16)\n \t\treturn -EINVAL;\n+\n+\t/* don't allocate too large period; 1MB period must be enough */\n+\tif (oss_period_size > 1024 * 1024)\n+\t\treturn -ENOMEM;\n+\n \truntime->oss.period_bytes = oss_period_size;\n \truntime->oss.period_frames = 1;\n \truntime->oss.periods = oss_periods;\n@@ -1043,10 +1048,9 @@ static int snd_pcm_oss_change_params_locked(struct snd_pcm_substream *substream)\n \t\t\tgoto failure;\n \t}\n #endif\n-\toss_period_size *= oss_frame_size;\n-\n-\toss_buffer_size = oss_period_size * runtime->oss.periods;\n-\tif (oss_buffer_size < 0) {\n+\toss_period_size = array_size(oss_period_size, oss_frame_size);\n+\toss_buffer_size = array_size(oss_period_size, runtime->oss.periods);\n+\tif (oss_buffer_size <= 0) {\n \t\terr = -EINVAL;\n \t\tgoto failure;\n \t}\ndiff --git a/sound/core/oss/pcm_plugin.c b/sound/core/oss/pcm_plugin.c\nindex 061ba06bc926..82e180c776ae 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+\tsize = array3_size(frames, format->channels, width);\n+\t/* check for too large period size once again */\n+\tif (size > 1024 * 1024)\n+\t\treturn -ENOMEM;\n \tif (snd_BUG_ON(size % 8))\n \t\treturn -ENXIO;\n \tsize /= 8;\n"
        ]
    },
    "fe36c362e30b849dad0ab99e2d1f09b82fc72883": {
        "non_crash": [
            "diff --git a/net/sched/act_pedit.c b/net/sched/act_pedit.c\nindex fb93d4c1faca..fc945c7e4123 100644\n--- a/net/sched/act_pedit.c\n+++ b/net/sched/act_pedit.c\n@@ -258,7 +258,7 @@ static int tcf_pedit_init(struct net *net, struct nlattr *nla,\n \t\tif (!offmask && cur % 4) {\n \t\t\tNL_SET_ERR_MSG_MOD(extack, \"Offsets must be on 32bit boundaries\");\n \t\t\tret = -EINVAL;\n-\t\t\tgoto put_chain;\n+\t\t\tgoto out_free_keys;\n \t\t}\n \n \t\t/* sanitize the shift value for any later use */\n@@ -291,6 +291,8 @@ static int tcf_pedit_init(struct net *net, struct nlattr *nla,\n \n \treturn ret;\n \n+out_free_keys:\n+\tkfree(nparms->tcfp_keys);\n put_chain:\n \tif (goto_ch)\n \t\ttcf_chain_put_by_act(goto_ch);\n"
        ]
    },
    "093e7092e01bed192b564b04528826cc6f1dbf91": {
        "non_crash": [
            "diff --git a/drivers/media/platform/vivid/vivid-vid-cap.c b/drivers/media/platform/vivid/vivid-vid-cap.c\nindex 8213297ee9dc..a1ed5fdabc75 100644\n--- a/drivers/media/platform/vivid/vivid-vid-cap.c\n+++ b/drivers/media/platform/vivid/vivid-vid-cap.c\n@@ -451,6 +451,8 @@ void vivid_update_format_cap(struct vivid_dev *dev, bool keep_controls)\n \t\ttpg_s_rgb_range(&dev->tpg, v4l2_ctrl_g_ctrl(dev->rgb_range_cap));\n \t\tbreak;\n \t}\n+\tvfree(dev->bitmap_cap);\n+\tdev->bitmap_cap = NULL;\n \tvivid_update_quality(dev);\n \ttpg_reset_source(&dev->tpg, dev->src_rect.width, dev->src_rect.height, dev->field_cap);\n \tdev->crop_cap = dev->src_rect;\n"
        ]
    },
    "6cd217d3878763ebef28a8fd279c88e791c1c9ef": {
        "non_crash": [
            "diff --git a/net/unix/af_unix.c b/net/unix/af_unix.c\nindex 347122c3575e..0b0f18ecce44 100644\n--- a/net/unix/af_unix.c\n+++ b/net/unix/af_unix.c\n@@ -2105,7 +2105,8 @@ static int unix_dgram_sendmsg(struct socket *sock, struct msghdr *msg,\n #define UNIX_SKB_FRAGS_SZ (PAGE_SIZE << get_order(32768))\n \n #if IS_ENABLED(CONFIG_AF_UNIX_OOB)\n-static int queue_oob(struct socket *sock, struct msghdr *msg, struct sock *other)\n+static int queue_oob(struct socket *sock, struct msghdr *msg, struct sock *other,\n+\t\t     struct scm_cookie *scm, bool fds_sent)\n {\n \tstruct unix_sock *ousk = unix_sk(other);\n \tstruct sk_buff *skb;\n@@ -2116,6 +2117,11 @@ static int queue_oob(struct socket *sock, struct msghdr *msg, struct sock *other\n \tif (!skb)\n \t\treturn err;\n \n+\terr = unix_scm_to_skb(scm, skb, !fds_sent);\n+\tif (err < 0) {\n+\t\tkfree_skb(skb);\n+\t\treturn err;\n+\t}\n \tskb_put(skb, 1);\n \terr = skb_copy_datagram_from_iter(skb, 0, &msg->msg_iter, 1);\n \n@@ -2243,7 +2249,7 @@ static int unix_stream_sendmsg(struct socket *sock, struct msghdr *msg,\n \n #if IS_ENABLED(CONFIG_AF_UNIX_OOB)\n \tif (msg->msg_flags & MSG_OOB) {\n-\t\terr = queue_oob(sock, msg, other);\n+\t\terr = queue_oob(sock, msg, other, &scm, fds_sent);\n \t\tif (err)\n \t\t\tgoto out_err;\n \t\tsent++;\n"
        ]
    },
    "d2ad6548d6f4f8f52f8fa250310fb027f04cfd18": {
        "non_crash": [
            "diff --git a/net/ieee802154/nl802154.c b/net/ieee802154/nl802154.c\nindex 2215f576ee37..d8f4379d4fa6 100644\n--- a/net/ieee802154/nl802154.c\n+++ b/net/ieee802154/nl802154.c\n@@ -1412,7 +1412,7 @@ static int nl802154_trigger_scan(struct sk_buff *skb, struct genl_info *info)\n \t\treturn -EOPNOTSUPP;\n \t}\n \n-\tif (!nla_get_u8(info->attrs[NL802154_ATTR_SCAN_TYPE])) {\n+\tif (!info->attrs[NL802154_ATTR_SCAN_TYPE]) {\n \t\tNL_SET_ERR_MSG(info->extack, \"Malformed request, missing scan type\");\n \t\treturn -EINVAL;\n \t}\n"
        ]
    },
    "cdaf5ed409125df023889aefe50b4cc4a41c0973": {
        "non_crash": [
            "diff --git a/Documentation/filesystems/ntfs3.rst b/Documentation/filesystems/ntfs3.rst\nindex 5aa102bd72c2..f0cf05cad2ba 100644\n--- a/Documentation/filesystems/ntfs3.rst\n+++ b/Documentation/filesystems/ntfs3.rst\n@@ -61,17 +61,6 @@ this table marked with no it means default is without **no**.\n        directories, fmask applies only to files and dmask only to directories.\n    * - fmask=\n \n-   * - noacsrules\n-     - \"No access rules\" mount option sets access rights for files/folders to\n-       777 and owner/group to root. This mount option absorbs all other\n-       permissions.\n-\n-       - Permissions change for files/folders will be reported as successful,\n-\t but they will remain 777.\n-\n-       - Owner/group change will be reported as successful, butthey will stay\n-\t as root.\n-\n    * - nohidden\n      - Files with the Windows-specific HIDDEN (FILE_ATTRIBUTE_HIDDEN) attribute\n        will not be shown under Linux.\ndiff --git a/fs/ntfs3/file.c b/fs/ntfs3/file.c\nindex b3b72673fa5e..e4b54d6bcda5 100644\n--- a/fs/ntfs3/file.c\n+++ b/fs/ntfs3/file.c\n@@ -654,22 +654,12 @@ static long ntfs_fallocate(struct file *file, int mode, loff_t vbo, loff_t len)\n int ntfs3_setattr(struct mnt_idmap *idmap, struct dentry *dentry,\n \t\t  struct iattr *attr)\n {\n-\tstruct super_block *sb = dentry->d_sb;\n-\tstruct ntfs_sb_info *sbi = sb->s_fs_info;\n \tstruct inode *inode = d_inode(dentry);\n \tstruct ntfs_inode *ni = ntfs_i(inode);\n \tu32 ia_valid = attr->ia_valid;\n \tumode_t mode = inode->i_mode;\n \tint err;\n \n-\tif (sbi->options->noacsrules) {\n-\t\t/* \"No access rules\" - Force any changes of time etc. */\n-\t\tattr->ia_valid |= ATTR_FORCE;\n-\t\t/* and disable for editing some attributes. */\n-\t\tattr->ia_valid &= ~(ATTR_UID | ATTR_GID | ATTR_MODE);\n-\t\tia_valid = attr->ia_valid;\n-\t}\n-\n \terr = setattr_prepare(idmap, dentry, attr);\n \tif (err)\n \t\tgoto out;\n@@ -1153,7 +1143,6 @@ const struct inode_operations ntfs_file_inode_operations = {\n \t.getattr\t= ntfs_getattr,\n \t.setattr\t= ntfs3_setattr,\n \t.listxattr\t= ntfs_listxattr,\n-\t.permission\t= ntfs_permission,\n \t.get_inode_acl\t= ntfs_get_acl,\n \t.set_acl\t= ntfs_set_acl,\n \t.fiemap\t\t= ntfs_fiemap,\ndiff --git a/fs/ntfs3/inode.c b/fs/ntfs3/inode.c\nindex bb004e476563..31f7e97fa43e 100644\n--- a/fs/ntfs3/inode.c\n+++ b/fs/ntfs3/inode.c\n@@ -2070,7 +2070,6 @@ const struct inode_operations ntfs_link_inode_operations = {\n \t.get_link\t= ntfs_get_link,\n \t.setattr\t= ntfs3_setattr,\n \t.listxattr\t= ntfs_listxattr,\n-\t.permission\t= ntfs_permission,\n };\n \n const struct address_space_operations ntfs_aops = {\ndiff --git a/fs/ntfs3/namei.c b/fs/ntfs3/namei.c\nindex 92bbc8ee83ca..fdd11f2a1883 100644\n--- a/fs/ntfs3/namei.c\n+++ b/fs/ntfs3/namei.c\n@@ -607,7 +607,6 @@ const struct inode_operations ntfs_dir_inode_operations = {\n \t.rmdir\t\t= ntfs_rmdir,\n \t.mknod\t\t= ntfs_mknod,\n \t.rename\t\t= ntfs_rename,\n-\t.permission\t= ntfs_permission,\n \t.get_inode_acl\t= ntfs_get_acl,\n \t.set_acl\t= ntfs_set_acl,\n \t.setattr\t= ntfs3_setattr,\ndiff --git a/fs/ntfs3/ntfs_fs.h b/fs/ntfs3/ntfs_fs.h\nindex 15296f5690b5..85efb34d211c 100644\n--- a/fs/ntfs3/ntfs_fs.h\n+++ b/fs/ntfs3/ntfs_fs.h\n@@ -100,7 +100,6 @@ struct ntfs_mount_options {\n \tunsigned hide_dot_files : 1; /* Set hidden flag on dot files. */\n \tunsigned windows_names : 1; /* Disallow names forbidden by Windows. */\n \tunsigned force : 1; /* RW mount dirty volume. */\n-\tunsigned noacsrules : 1; /* Exclude acs rules. */\n \tunsigned prealloc : 1; /* Preallocate space when file is growing. */\n \tunsigned nocase : 1; /* case insensitive. */\n };\n@@ -870,8 +869,6 @@ int ntfs_init_acl(struct mnt_idmap *idmap, struct inode *inode,\n #endif\n \n int ntfs_acl_chmod(struct mnt_idmap *idmap, struct dentry *dentry);\n-int ntfs_permission(struct mnt_idmap *idmap, struct inode *inode,\n-\t\t    int mask);\n ssize_t ntfs_listxattr(struct dentry *dentry, char *buffer, size_t size);\n extern const struct xattr_handler *ntfs_xattr_handlers[];\n \ndiff --git a/fs/ntfs3/super.c b/fs/ntfs3/super.c\nindex 19d0889b131f..10c019ef7da3 100644\n--- a/fs/ntfs3/super.c\n+++ b/fs/ntfs3/super.c\n@@ -253,7 +253,6 @@ enum Opt {\n \tOpt_acl,\n \tOpt_iocharset,\n \tOpt_prealloc,\n-\tOpt_noacsrules,\n \tOpt_nocase,\n \tOpt_err,\n };\n@@ -274,7 +273,6 @@ static const struct fs_parameter_spec ntfs_fs_parameters[] = {\n \tfsparam_flag_no(\"acl\",\t\t\tOpt_acl),\n \tfsparam_flag_no(\"showmeta\",\t\tOpt_showmeta),\n \tfsparam_flag_no(\"prealloc\",\t\tOpt_prealloc),\n-\tfsparam_flag_no(\"acsrules\",\t\tOpt_noacsrules),\n \tfsparam_flag_no(\"nocase\",\t\tOpt_nocase),\n \tfsparam_string(\"iocharset\",\t\tOpt_iocharset),\n \t{}\n@@ -387,9 +385,6 @@ static int ntfs_fs_parse_param(struct fs_context *fc,\n \tcase Opt_prealloc:\n \t\topts->prealloc = result.negated ? 0 : 1;\n \t\tbreak;\n-\tcase Opt_noacsrules:\n-\t\topts->noacsrules = result.negated ? 1 : 0;\n-\t\tbreak;\n \tcase Opt_nocase:\n \t\topts->nocase = result.negated ? 1 : 0;\n \t\tbreak;\n@@ -572,8 +567,6 @@ static int ntfs_show_options(struct seq_file *m, struct dentry *root)\n \t\tseq_puts(m, \",hide_dot_files\");\n \tif (opts->force)\n \t\tseq_puts(m, \",force\");\n-\tif (opts->noacsrules)\n-\t\tseq_puts(m, \",noacsrules\");\n \tif (opts->prealloc)\n \t\tseq_puts(m, \",prealloc\");\n \tif (sb->s_flags & SB_POSIXACL)\n@@ -791,7 +784,7 @@ static int ntfs_init_from_boot(struct super_block *sb, u32 sector_size,\n \tif (boot_sector_size != sector_size) {\n \t\tntfs_warn(\n \t\t\tsb,\n-\t\t\t\"Different NTFS' sector size (%u) and media sector size (%u)\",\n+\t\t\t\"Different NTFS sector size (%u) and media sector size (%u)\",\n \t\t\tboot_sector_size, sector_size);\n \t\tdev_size += sector_size - 1;\n \t}\ndiff --git a/fs/ntfs3/xattr.c b/fs/ntfs3/xattr.c\nindex 4746959af964..4cab20d70c79 100644\n--- a/fs/ntfs3/xattr.c\n+++ b/fs/ntfs3/xattr.c\n@@ -711,20 +711,6 @@ int ntfs_acl_chmod(struct mnt_idmap *idmap, struct dentry *dentry)\n \treturn posix_acl_chmod(idmap, dentry, inode->i_mode);\n }\n \n-/*\n- * ntfs_permission - inode_operations::permission\n- */\n-int ntfs_permission(struct mnt_idmap *idmap, struct inode *inode,\n-\t\t    int mask)\n-{\n-\tif (ntfs_sb(inode->i_sb)->options->noacsrules) {\n-\t\t/* \"No access rules\" mode - Allow all changes. */\n-\t\treturn 0;\n-\t}\n-\n-\treturn generic_permission(idmap, inode, mask);\n-}\n-\n /*\n  * ntfs_listxattr - inode_operations::listxattr\n  */\n"
        ]
    },
    "e58343393efd3e0657ca37cf4466fc38d1f4d4df": {
        "non_crash": [
            "diff --git a/drivers/dma-buf/udmabuf.c b/drivers/dma-buf/udmabuf.c\nindex 38e8767ec371..bf11d32205f3 100644\n--- a/drivers/dma-buf/udmabuf.c\n+++ b/drivers/dma-buf/udmabuf.c\n@@ -124,17 +124,20 @@ static int begin_cpu_udmabuf(struct dma_buf *buf,\n {\n \tstruct udmabuf *ubuf = buf->priv;\n \tstruct device *dev = ubuf->device->this_device;\n+\tint ret = 0;\n \n \tif (!ubuf->sg) {\n \t\tubuf->sg = get_sg_table(dev, buf, direction);\n-\t\tif (IS_ERR(ubuf->sg))\n-\t\t\treturn PTR_ERR(ubuf->sg);\n+\t\tif (IS_ERR(ubuf->sg)) {\n+\t\t\tret = PTR_ERR(ubuf->sg);\n+\t\t\tubuf->sg = NULL;\n+\t\t}\n \t} else {\n \t\tdma_sync_sg_for_cpu(dev, ubuf->sg->sgl, ubuf->sg->nents,\n \t\t\t\t    direction);\n \t}\n \n-\treturn 0;\n+\treturn ret;\n }\n \n static int end_cpu_udmabuf(struct dma_buf *buf,\n"
        ]
    },
    "dad6a582c4d54162ae8d096210ca126b659fd8c0": {
        "non_crash": [
            "diff --git a/fs/hfs/trans.c b/fs/hfs/trans.c\nindex 39f5e343bf4d..fdb0edb8a607 100644\n--- a/fs/hfs/trans.c\n+++ b/fs/hfs/trans.c\n@@ -109,7 +109,7 @@ void hfs_asc2mac(struct super_block *sb, struct hfs_name *out, const struct qstr\n \tif (nls_io) {\n \t\twchar_t ch;\n \n-\t\twhile (srclen > 0) {\n+\t\twhile (srclen > 0 && dstlen > 0) {\n \t\t\tsize = nls_io->char2uni(src, srclen, &ch);\n \t\t\tif (size < 0) {\n \t\t\t\tch = '?';\n"
        ]
    },
    "64619c0d6d2ef98d85b7bb4ff271bfa9df74ce03": {
        "non_crash": [
            "diff --git a/fs/ext4/file.c b/fs/ext4/file.c\nindex 109d07629f81..847a2f806b8f 100644\n--- a/fs/ext4/file.c\n+++ b/fs/ext4/file.c\n@@ -528,6 +528,12 @@ static ssize_t ext4_dio_write_iter(struct kiocb *iocb, struct iov_iter *from)\n \t\tret = -EAGAIN;\n \t\tgoto out;\n \t}\n+\t/*\n+\t * Make sure inline data cannot be created anymore since we are going\n+\t * to allocate blocks for DIO. We know the inode does not have any\n+\t * inline data now because ext4_dio_supported() checked for that.\n+\t */\n+\text4_clear_inode_state(inode, EXT4_STATE_MAY_INLINE_DATA);\n \n \toffset = iocb->ki_pos;\n \tcount = ret;\n"
        ]
    },
    "0be1740a2972a1852f35a3ed7dc70577610edcbd": {
        "non_crash": [
            "diff --git a/sound/core/seq/seq_ports.c b/sound/core/seq/seq_ports.c\nindex 9b80f8275026..f3f14ff0f80f 100644\n--- a/sound/core/seq/seq_ports.c\n+++ b/sound/core/seq/seq_ports.c\n@@ -149,6 +149,7 @@ int snd_seq_create_port(struct snd_seq_client *client, int port,\n \twrite_lock_irq(&client->ports_lock);\n \tlist_for_each_entry(p, &client->ports_list_head, list) {\n \t\tif (p->addr.port == port) {\n+\t\t\tkfree(new_port);\n \t\t\tnum = -EBUSY;\n \t\t\tgoto unlock;\n \t\t}\n"
        ]
    },
    "64182208616de0ae5ebd9b1652cb213485d61fce": {
        "non_crash": [
            "diff --git a/drivers/nfc/st-nci/se.c b/drivers/nfc/st-nci/se.c\nindex ec87dd21e054..b2f1ced8e6dd 100644\n--- a/drivers/nfc/st-nci/se.c\n+++ b/drivers/nfc/st-nci/se.c\n@@ -672,6 +672,12 @@ int st_nci_se_io(struct nci_dev *ndev, u32 se_idx,\n \t\t\t\t\tST_NCI_EVT_TRANSMIT_DATA, apdu,\n \t\t\t\t\tapdu_length);\n \tdefault:\n+\t\t/* Need to free cb_context here as at the moment we can't\n+\t\t * clearly indicate to the caller if the callback function\n+\t\t * would be called (and free it) or not. In both cases a\n+\t\t * negative value may be returned to the caller.\n+\t\t */\n+\t\tkfree(cb_context);\n \t\treturn -ENODEV;\n \t}\n }\ndiff --git a/drivers/nfc/st21nfca/se.c b/drivers/nfc/st21nfca/se.c\nindex df8d27cf2956..dae288bebcb5 100644\n--- a/drivers/nfc/st21nfca/se.c\n+++ b/drivers/nfc/st21nfca/se.c\n@@ -236,6 +236,12 @@ int st21nfca_hci_se_io(struct nfc_hci_dev *hdev, u32 se_idx,\n \t\t\t\t\tST21NFCA_EVT_TRANSMIT_DATA,\n \t\t\t\t\tapdu, apdu_length);\n \tdefault:\n+\t\t/* Need to free cb_context here as at the moment we can't\n+\t\t * clearly indicate to the caller if the callback function\n+\t\t * would be called (and free it) or not. In both cases a\n+\t\t * negative value may be returned to the caller.\n+\t\t */\n+\t\tkfree(cb_context);\n \t\treturn -ENODEV;\n \t}\n }\ndiff --git a/net/nfc/netlink.c b/net/nfc/netlink.c\nindex 1fc339084d89..348bf561bc9f 100644\n--- a/net/nfc/netlink.c\n+++ b/net/nfc/netlink.c\n@@ -1442,7 +1442,11 @@ static int nfc_se_io(struct nfc_dev *dev, u32 se_idx,\n \trc = dev->ops->se_io(dev, se_idx, apdu,\n \t\t\tapdu_length, cb, cb_context);\n \n+\tdevice_unlock(&dev->dev);\n+\treturn rc;\n+\n error:\n+\tkfree(cb_context);\n \tdevice_unlock(&dev->dev);\n \treturn rc;\n }\n"
        ]
    },
    "19526c104e66c633a05949201c4c09a3ec8c5644": {
        "non_crash": [
            "diff --git a/block/ioctl.c b/block/ioctl.c\nindex bdb3bbb253d9..ae74d0409afa 100644\n--- a/block/ioctl.c\n+++ b/block/ioctl.c\n@@ -112,8 +112,7 @@ static int blk_ioctl_discard(struct block_device *bdev, fmode_t mode,\n \tuint64_t range[2];\n \tuint64_t start, len;\n \tstruct request_queue *q = bdev_get_queue(bdev);\n-\tstruct address_space *mapping = bdev->bd_inode->i_mapping;\n-\n+\tint err;\n \n \tif (!(mode & FMODE_WRITE))\n \t\treturn -EBADF;\n@@ -134,7 +133,11 @@ static int blk_ioctl_discard(struct block_device *bdev, fmode_t mode,\n \n \tif (start + len > i_size_read(bdev->bd_inode))\n \t\treturn -EINVAL;\n-\ttruncate_inode_pages_range(mapping, start, start + len - 1);\n+\n+\terr = truncate_bdev_range(bdev, mode, start, start + len - 1);\n+\tif (err)\n+\t\treturn err;\n+\n \treturn blkdev_issue_discard(bdev, start >> 9, len >> 9,\n \t\t\t\t    GFP_KERNEL, flags);\n }\n@@ -143,8 +146,8 @@ static int blk_ioctl_zeroout(struct block_device *bdev, fmode_t mode,\n \t\tunsigned long arg)\n {\n \tuint64_t range[2];\n-\tstruct address_space *mapping;\n \tuint64_t start, end, len;\n+\tint err;\n \n \tif (!(mode & FMODE_WRITE))\n \t\treturn -EBADF;\n@@ -166,8 +169,9 @@ static int blk_ioctl_zeroout(struct block_device *bdev, fmode_t mode,\n \t\treturn -EINVAL;\n \n \t/* Invalidate the page cache, including dirty pages */\n-\tmapping = bdev->bd_inode->i_mapping;\n-\ttruncate_inode_pages_range(mapping, start, end);\n+\terr = truncate_bdev_range(bdev, mode, start, end);\n+\tif (err)\n+\t\treturn err;\n \n \treturn blkdev_issue_zeroout(bdev, start >> 9, len >> 9, GFP_KERNEL,\n \t\t\tBLKDEV_ZERO_NOUNMAP);\ndiff --git a/fs/block_dev.c b/fs/block_dev.c\nindex 9cb205405f9d..c70c41ecba48 100644\n--- a/fs/block_dev.c\n+++ b/fs/block_dev.c\n@@ -103,6 +103,35 @@ void invalidate_bdev(struct block_device *bdev)\n }\n EXPORT_SYMBOL(invalidate_bdev);\n \n+/*\n+ * Drop all buffers & page cache for given bdev range. This function bails\n+ * with error if bdev has other exclusive owner (such as filesystem).\n+ */\n+int truncate_bdev_range(struct block_device *bdev, fmode_t mode,\n+\t\t\tloff_t lstart, loff_t lend)\n+{\n+\tstruct block_device *claimed_bdev = NULL;\n+\tint err;\n+\n+\t/*\n+\t * If we don't hold exclusive handle for the device, upgrade to it\n+\t * while we discard the buffer cache to avoid discarding buffers\n+\t * under live filesystem.\n+\t */\n+\tif (!(mode & FMODE_EXCL)) {\n+\t\tclaimed_bdev = bdev->bd_contains;\n+\t\terr = bd_prepare_to_claim(bdev, claimed_bdev,\n+\t\t\t\t\t  truncate_bdev_range);\n+\t\tif (err)\n+\t\t\treturn err;\n+\t}\n+\ttruncate_inode_pages_range(bdev->bd_inode->i_mapping, lstart, lend);\n+\tif (claimed_bdev)\n+\t\tbd_abort_claiming(bdev, claimed_bdev, truncate_bdev_range);\n+\treturn 0;\n+}\n+EXPORT_SYMBOL(truncate_bdev_range);\n+\n static void set_init_blocksize(struct block_device *bdev)\n {\n \tbdev->bd_inode->i_blkbits = blksize_bits(bdev_logical_block_size(bdev));\n@@ -1968,7 +1997,6 @@ static long blkdev_fallocate(struct file *file, int mode, loff_t start,\n \t\t\t     loff_t len)\n {\n \tstruct block_device *bdev = I_BDEV(bdev_file_inode(file));\n-\tstruct address_space *mapping;\n \tloff_t end = start + len - 1;\n \tloff_t isize;\n \tint error;\n@@ -1996,8 +2024,9 @@ static long blkdev_fallocate(struct file *file, int mode, loff_t start,\n \t\treturn -EINVAL;\n \n \t/* Invalidate the page cache, including dirty pages. */\n-\tmapping = bdev->bd_inode->i_mapping;\n-\ttruncate_inode_pages_range(mapping, start, end);\n+\terror = truncate_bdev_range(bdev, file->f_mode, start, end);\n+\tif (error)\n+\t\treturn error;\n \n \tswitch (mode) {\n \tcase FALLOC_FL_ZERO_RANGE:\n@@ -2024,7 +2053,7 @@ static long blkdev_fallocate(struct file *file, int mode, loff_t start,\n \t * the caller will be given -EBUSY.  The third argument is\n \t * inclusive, so the rounding here is safe.\n \t */\n-\treturn invalidate_inode_pages2_range(mapping,\n+\treturn invalidate_inode_pages2_range(bdev->bd_inode->i_mapping,\n \t\t\t\t\t     start >> PAGE_SHIFT,\n \t\t\t\t\t     end >> PAGE_SHIFT);\n }\ndiff --git a/include/linux/blkdev.h b/include/linux/blkdev.h\nindex 7d82959e7b86..37ec5a73d027 100644\n--- a/include/linux/blkdev.h\n+++ b/include/linux/blkdev.h\n@@ -1987,11 +1987,18 @@ void bdput(struct block_device *);\n \n #ifdef CONFIG_BLOCK\n void invalidate_bdev(struct block_device *bdev);\n+int truncate_bdev_range(struct block_device *bdev, fmode_t mode, loff_t lstart,\n+\t\t\tloff_t lend);\n int sync_blockdev(struct block_device *bdev);\n #else\n static inline void invalidate_bdev(struct block_device *bdev)\n {\n }\n+static inline int truncate_bdev_range(struct block_device *bdev, fmode_t mode,\n+\t\t\t\t      loff_t lstart, loff_t lend)\n+{\n+\treturn 0;\n+}\n static inline int sync_blockdev(struct block_device *bdev)\n {\n \treturn 0;\n"
        ]
    },
    "4d35dd2768109c21f717806fb4274293758d65cf": {
        "non_crash": [
            "diff --git a/mm/mmap.c b/mm/mmap.c\nindex 51e70fa98450..547b40531791 100644\n--- a/mm/mmap.c\n+++ b/mm/mmap.c\n@@ -2554,11 +2554,10 @@ do_vmi_align_munmap(struct vma_iterator *vmi, struct vm_area_struct *vma,\n \tmas_set(&mas_detach, start);\n \tremove_mt(mm, &mas_detach);\n \t__mt_destroy(&mt_detach);\n+\tvalidate_mm(mm);\n \tif (unlock)\n \t\tmmap_read_unlock(mm);\n \n-\n-\tvalidate_mm(mm);\n \treturn 0;\n \n clear_tree_failed:\n"
        ]
    },
    "0084fd109a7a10011e183a357715c91cff2cacb0": {
        "non_crash": [
            "diff --git a/include/linux/gfp.h b/include/linux/gfp.h\nindex 76f8db0b0e71..0705164f928c 100644\n--- a/include/linux/gfp.h\n+++ b/include/linux/gfp.h\n@@ -510,18 +510,22 @@ alloc_pages(gfp_t gfp_mask, unsigned int order)\n }\n extern struct page *alloc_pages_vma(gfp_t gfp_mask, int order,\n \t\t\tstruct vm_area_struct *vma, unsigned long addr,\n-\t\t\tint node);\n+\t\t\tint node, bool hugepage);\n+#define alloc_hugepage_vma(gfp_mask, vma, addr, order) \\\n+\talloc_pages_vma(gfp_mask, order, vma, addr, numa_node_id(), true)\n #else\n #define alloc_pages(gfp_mask, order) \\\n \t\talloc_pages_node(numa_node_id(), gfp_mask, order)\n-#define alloc_pages_vma(gfp_mask, order, vma, addr, node)\\\n+#define alloc_pages_vma(gfp_mask, order, vma, addr, node, false)\\\n+\talloc_pages(gfp_mask, order)\n+#define alloc_hugepage_vma(gfp_mask, vma, addr, order) \\\n \talloc_pages(gfp_mask, order)\n #endif\n #define alloc_page(gfp_mask) alloc_pages(gfp_mask, 0)\n #define alloc_page_vma(gfp_mask, vma, addr)\t\t\t\\\n-\talloc_pages_vma(gfp_mask, 0, vma, addr, numa_node_id())\n+\talloc_pages_vma(gfp_mask, 0, vma, addr, numa_node_id(), false)\n #define alloc_page_vma_node(gfp_mask, vma, addr, node)\t\t\\\n-\talloc_pages_vma(gfp_mask, 0, vma, addr, node)\n+\talloc_pages_vma(gfp_mask, 0, vma, addr, node, false)\n \n extern unsigned long __get_free_pages(gfp_t gfp_mask, unsigned int order);\n extern unsigned long get_zeroed_page(gfp_t gfp_mask);\ndiff --git a/mm/huge_memory.c b/mm/huge_memory.c\nindex f2d19e4fe854..5da55b38b1b7 100644\n--- a/mm/huge_memory.c\n+++ b/mm/huge_memory.c\n@@ -629,30 +629,30 @@ static vm_fault_t __do_huge_pmd_anonymous_page(struct vm_fault *vmf,\n  *\t    available\n  * never: never stall for any thp allocation\n  */\n-static inline gfp_t alloc_hugepage_direct_gfpmask(struct vm_area_struct *vma, unsigned long addr)\n+static inline gfp_t alloc_hugepage_direct_gfpmask(struct vm_area_struct *vma)\n {\n \tconst bool vma_madvised = !!(vma->vm_flags & VM_HUGEPAGE);\n-\tconst gfp_t gfp_mask = GFP_TRANSHUGE_LIGHT | __GFP_THISNODE;\n \n \t/* Always do synchronous compaction */\n \tif (test_bit(TRANSPARENT_HUGEPAGE_DEFRAG_DIRECT_FLAG, &transparent_hugepage_flags))\n-\t\treturn GFP_TRANSHUGE | __GFP_THISNODE |\n-\t\t       (vma_madvised ? 0 : __GFP_NORETRY);\n+\t\treturn GFP_TRANSHUGE | (vma_madvised ? 0 : __GFP_NORETRY);\n \n \t/* Kick kcompactd and fail quickly */\n \tif (test_bit(TRANSPARENT_HUGEPAGE_DEFRAG_KSWAPD_FLAG, &transparent_hugepage_flags))\n-\t\treturn gfp_mask | __GFP_KSWAPD_RECLAIM;\n+\t\treturn GFP_TRANSHUGE_LIGHT | __GFP_KSWAPD_RECLAIM;\n \n \t/* Synchronous compaction if madvised, otherwise kick kcompactd */\n \tif (test_bit(TRANSPARENT_HUGEPAGE_DEFRAG_KSWAPD_OR_MADV_FLAG, &transparent_hugepage_flags))\n-\t\treturn gfp_mask | (vma_madvised ? __GFP_DIRECT_RECLAIM :\n-\t\t\t\t\t\t  __GFP_KSWAPD_RECLAIM);\n+\t\treturn GFP_TRANSHUGE_LIGHT |\n+\t\t\t(vma_madvised ? __GFP_DIRECT_RECLAIM :\n+\t\t\t\t\t__GFP_KSWAPD_RECLAIM);\n \n \t/* Only do synchronous compaction if madvised */\n \tif (test_bit(TRANSPARENT_HUGEPAGE_DEFRAG_REQ_MADV_FLAG, &transparent_hugepage_flags))\n-\t\treturn gfp_mask | (vma_madvised ? __GFP_DIRECT_RECLAIM : 0);\n+\t\treturn GFP_TRANSHUGE_LIGHT |\n+\t\t       (vma_madvised ? __GFP_DIRECT_RECLAIM : 0);\n \n-\treturn gfp_mask;\n+\treturn GFP_TRANSHUGE_LIGHT;\n }\n \n /* Caller must hold page table lock. */\n@@ -724,8 +724,8 @@ vm_fault_t do_huge_pmd_anonymous_page(struct vm_fault *vmf)\n \t\t\tpte_free(vma->vm_mm, pgtable);\n \t\treturn ret;\n \t}\n-\tgfp = alloc_hugepage_direct_gfpmask(vma, haddr);\n-\tpage = alloc_pages_vma(gfp, HPAGE_PMD_ORDER, vma, haddr, numa_node_id());\n+\tgfp = alloc_hugepage_direct_gfpmask(vma);\n+\tpage = alloc_hugepage_vma(gfp, vma, haddr, HPAGE_PMD_ORDER);\n \tif (unlikely(!page)) {\n \t\tcount_vm_event(THP_FAULT_FALLBACK);\n \t\treturn VM_FAULT_FALLBACK;\n@@ -1295,9 +1295,8 @@ vm_fault_t do_huge_pmd_wp_page(struct vm_fault *vmf, pmd_t orig_pmd)\n alloc:\n \tif (transparent_hugepage_enabled(vma) &&\n \t    !transparent_hugepage_debug_cow()) {\n-\t\thuge_gfp = alloc_hugepage_direct_gfpmask(vma, haddr);\n-\t\tnew_page = alloc_pages_vma(huge_gfp, HPAGE_PMD_ORDER, vma,\n-\t\t\t\thaddr, numa_node_id());\n+\t\thuge_gfp = alloc_hugepage_direct_gfpmask(vma);\n+\t\tnew_page = alloc_hugepage_vma(huge_gfp, vma, haddr, HPAGE_PMD_ORDER);\n \t} else\n \t\tnew_page = NULL;\n \ndiff --git a/mm/mempolicy.c b/mm/mempolicy.c\nindex 69e278b469ef..d4496d9d34f5 100644\n--- a/mm/mempolicy.c\n+++ b/mm/mempolicy.c\n@@ -1116,8 +1116,8 @@ static struct page *new_page(struct page *page, unsigned long start)\n \t} else if (PageTransHuge(page)) {\n \t\tstruct page *thp;\n \n-\t\tthp = alloc_pages_vma(GFP_TRANSHUGE, HPAGE_PMD_ORDER, vma,\n-\t\t\t\taddress, numa_node_id());\n+\t\tthp = alloc_hugepage_vma(GFP_TRANSHUGE, vma, address,\n+\t\t\t\t\t HPAGE_PMD_ORDER);\n \t\tif (!thp)\n \t\t\treturn NULL;\n \t\tprep_transhuge_page(thp);\n@@ -2011,6 +2011,7 @@ static struct page *alloc_page_interleave(gfp_t gfp, unsigned order,\n  * \t@vma:  Pointer to VMA or NULL if not available.\n  *\t@addr: Virtual Address of the allocation. Must be inside the VMA.\n  *\t@node: Which node to prefer for allocation (modulo policy).\n+ *\t@hugepage: for hugepages try only the preferred node if possible\n  *\n  * \tThis function allocates a page from the kernel page pool and applies\n  *\ta NUMA policy associated with the VMA or the current process.\n@@ -2021,7 +2022,7 @@ static struct page *alloc_page_interleave(gfp_t gfp, unsigned order,\n  */\n struct page *\n alloc_pages_vma(gfp_t gfp, int order, struct vm_area_struct *vma,\n-\t\tunsigned long addr, int node)\n+\t\tunsigned long addr, int node, bool hugepage)\n {\n \tstruct mempolicy *pol;\n \tstruct page *page;\n@@ -2039,6 +2040,31 @@ alloc_pages_vma(gfp_t gfp, int order, struct vm_area_struct *vma,\n \t\tgoto out;\n \t}\n \n+\tif (unlikely(IS_ENABLED(CONFIG_TRANSPARENT_HUGEPAGE) && hugepage)) {\n+\t\tint hpage_node = node;\n+\n+\t\t/*\n+\t\t * For hugepage allocation and non-interleave policy which\n+\t\t * allows the current node (or other explicitly preferred\n+\t\t * node) we only try to allocate from the current/preferred\n+\t\t * node and don't fall back to other nodes, as the cost of\n+\t\t * remote accesses would likely offset THP benefits.\n+\t\t *\n+\t\t * If the policy is interleave, or does not allow the current\n+\t\t * node in its nodemask, we allocate the standard way.\n+\t\t */\n+\t\tif (pol->mode == MPOL_PREFERRED && !(pol->flags & MPOL_F_LOCAL))\n+\t\t\thpage_node = pol->v.preferred_node;\n+\n+\t\tnmask = policy_nodemask(gfp, pol);\n+\t\tif (!nmask || node_isset(hpage_node, *nmask)) {\n+\t\t\tmpol_cond_put(pol);\n+\t\t\tpage = __alloc_pages_node(hpage_node,\n+\t\t\t\t\t\tgfp | __GFP_THISNODE, order);\n+\t\t\tgoto out;\n+\t\t}\n+\t}\n+\n \tnmask = policy_nodemask(gfp, pol);\n \tpreferred_nid = policy_node(gfp, pol, node);\n \tpage = __alloc_pages_nodemask(gfp, order, preferred_nid, nmask);\ndiff --git a/mm/shmem.c b/mm/shmem.c\nindex cddc72ac44d8..921f80488bb3 100644\n--- a/mm/shmem.c\n+++ b/mm/shmem.c\n@@ -1439,7 +1439,7 @@ static struct page *shmem_alloc_hugepage(gfp_t gfp,\n \n \tshmem_pseudo_vma_init(&pvma, info, hindex);\n \tpage = alloc_pages_vma(gfp | __GFP_COMP | __GFP_NORETRY | __GFP_NOWARN,\n-\t\t\tHPAGE_PMD_ORDER, &pvma, 0, numa_node_id());\n+\t\t\tHPAGE_PMD_ORDER, &pvma, 0, numa_node_id(), true);\n \tshmem_pseudo_vma_destroy(&pvma);\n \tif (page)\n \t\tprep_transhuge_page(page);\n"
        ]
    },
    "75a2a727e4636c7a34dbd49197b15c3de92a8f7f": {
        "non_crash": [
            "diff --git a/mm/gup.c b/mm/gup.c\nindex 39c84a200f06..90ae44f24870 100644\n--- a/mm/gup.c\n+++ b/mm/gup.c\n@@ -1009,6 +1009,9 @@ static int check_vma_flags(struct vm_area_struct *vma, unsigned long gup_flags)\n \t\tif (!(vm_flags & VM_WRITE)) {\n \t\t\tif (!(gup_flags & FOLL_FORCE))\n \t\t\t\treturn -EFAULT;\n+\t\t\t/* hugetlb does not support FOLL_FORCE|FOLL_WRITE. */\n+\t\t\tif (is_vm_hugetlb_page(vma))\n+\t\t\t\treturn -EFAULT;\n \t\t\t/*\n \t\t\t * We used to let the write,force case do COW in a\n \t\t\t * VM_MAYWRITE VM_SHARED !VM_WRITE vma, so ptrace could\n"
        ]
    },
    "802aba2422de4218ad0c01b46c9525cc9d4e4aa3": {
        "non_crash": [
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 76bd4d03dbda..e7152d599d73 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -10090,7 +10090,8 @@ static void __net_exit nf_tables_exit_net(struct net *net)\n \tstruct nftables_pernet *nft_net = nft_pernet(net);\n \n \tmutex_lock(&nft_net->commit_mutex);\n-\tif (!list_empty(&nft_net->commit_list))\n+\tif (!list_empty(&nft_net->commit_list) ||\n+\t    !list_empty(&nft_net->module_list))\n \t\t__nf_tables_abort(net, NFNL_ABORT_NONE);\n \t__nft_release_tables(net);\n \tmutex_unlock(&nft_net->commit_mutex);\n"
        ]
    },
    "41a6b5d4917c0412eb3b3c3c604965bed7d7420b": {
        "non_crash": [
            "diff --git a/fs/ext4/xattr.c b/fs/ext4/xattr.c\nindex dadad29bd81b..dfc2e223bd10 100644\n--- a/fs/ext4/xattr.c\n+++ b/fs/ext4/xattr.c\n@@ -2614,6 +2614,7 @@ static int ext4_xattr_move_to_block(handle_t *handle, struct inode *inode,\n \t\t.in_inode = !!entry->e_value_inum,\n \t};\n \tstruct ext4_xattr_ibody_header *header = IHDR(inode, raw_inode);\n+\tint needs_kvfree = 0;\n \tint error;\n \n \tis = kzalloc(sizeof(struct ext4_xattr_ibody_find), GFP_NOFS);\n@@ -2636,7 +2637,7 @@ static int ext4_xattr_move_to_block(handle_t *handle, struct inode *inode,\n \t\t\terror = -ENOMEM;\n \t\t\tgoto out;\n \t\t}\n-\n+\t\tneeds_kvfree = 1;\n \t\terror = ext4_xattr_inode_get(inode, entry, buffer, value_size);\n \t\tif (error)\n \t\t\tgoto out;\n@@ -2675,7 +2676,7 @@ static int ext4_xattr_move_to_block(handle_t *handle, struct inode *inode,\n \n out:\n \tkfree(b_entry_name);\n-\tif (entry->e_value_inum && buffer)\n+\tif (needs_kvfree && buffer)\n \t\tkvfree(buffer);\n \tif (is)\n \t\tbrelse(is->iloc.bh);\n"
        ]
    },
    "accafa9281766c4630ea5aeaad0d83decd70406d": {
        "non_crash": [
            "diff --git a/fs/nilfs2/inode.c b/fs/nilfs2/inode.c\nindex a8ce522ac747..35bc79305318 100644\n--- a/fs/nilfs2/inode.c\n+++ b/fs/nilfs2/inode.c\n@@ -1101,9 +1101,17 @@ int nilfs_set_file_dirty(struct inode *inode, unsigned int nr_dirty)\n \n int __nilfs_mark_inode_dirty(struct inode *inode, int flags)\n {\n+\tstruct the_nilfs *nilfs = inode->i_sb->s_fs_info;\n \tstruct buffer_head *ibh;\n \tint err;\n \n+\t/*\n+\t * Do not dirty inodes after the log writer has been detached\n+\t * and its nilfs_root struct has been freed.\n+\t */\n+\tif (unlikely(nilfs_purging(nilfs)))\n+\t\treturn 0;\n+\n \terr = nilfs_load_inode_block(inode, &ibh);\n \tif (unlikely(err)) {\n \t\tnilfs_warn(inode->i_sb,\ndiff --git a/fs/nilfs2/segment.c b/fs/nilfs2/segment.c\nindex c2553024bd25..581691e4be49 100644\n--- a/fs/nilfs2/segment.c\n+++ b/fs/nilfs2/segment.c\n@@ -2845,6 +2845,7 @@ void nilfs_detach_log_writer(struct super_block *sb)\n \t\tnilfs_segctor_destroy(nilfs->ns_writer);\n \t\tnilfs->ns_writer = NULL;\n \t}\n+\tset_nilfs_purging(nilfs);\n \n \t/* Force to free the list of dirty files */\n \tspin_lock(&nilfs->ns_inode_lock);\n@@ -2857,4 +2858,5 @@ void nilfs_detach_log_writer(struct super_block *sb)\n \tup_write(&nilfs->ns_segctor_sem);\n \n \tnilfs_dispose_list(nilfs, &garbage_list, 1);\n+\tclear_nilfs_purging(nilfs);\n }\ndiff --git a/fs/nilfs2/the_nilfs.h b/fs/nilfs2/the_nilfs.h\nindex 47c7dfbb7ea5..cd4ae1b8ae16 100644\n--- a/fs/nilfs2/the_nilfs.h\n+++ b/fs/nilfs2/the_nilfs.h\n@@ -29,6 +29,7 @@ enum {\n \tTHE_NILFS_DISCONTINUED,\t/* 'next' pointer chain has broken */\n \tTHE_NILFS_GC_RUNNING,\t/* gc process is running */\n \tTHE_NILFS_SB_DIRTY,\t/* super block is dirty */\n+\tTHE_NILFS_PURGING,\t/* disposing dirty files for cleanup */\n };\n \n /**\n@@ -208,6 +209,7 @@ THE_NILFS_FNS(INIT, init)\n THE_NILFS_FNS(DISCONTINUED, discontinued)\n THE_NILFS_FNS(GC_RUNNING, gc_running)\n THE_NILFS_FNS(SB_DIRTY, sb_dirty)\n+THE_NILFS_FNS(PURGING, purging)\n \n /*\n  * Mount option operations\n"
        ]
    },
    "c434e401d70d584f408424099090ddebe2076705": {
        "non_crash": [
            "diff --git a/fs/ntfs3/super.c b/fs/ntfs3/super.c\nindex 278dcf502410..b2b54c4553f9 100644\n--- a/fs/ntfs3/super.c\n+++ b/fs/ntfs3/super.c\n@@ -668,9 +668,11 @@ static u32 format_size_gb(const u64 bytes, u32 *mb)\n \n static u32 true_sectors_per_clst(const struct NTFS_BOOT *boot)\n {\n-\treturn boot->sectors_per_clusters <= 0x80\n-\t\t       ? boot->sectors_per_clusters\n-\t\t       : (1u << (0 - boot->sectors_per_clusters));\n+\tif (boot->sectors_per_clusters <= 0x80)\n+\t\treturn boot->sectors_per_clusters;\n+\tif (boot->sectors_per_clusters >= 0xf4) /* limit shift to 2MB max */\n+\t\treturn 1U << (0 - boot->sectors_per_clusters);\n+\treturn -EINVAL;\n }\n \n /*\n@@ -713,6 +715,8 @@ static int ntfs_init_from_boot(struct super_block *sb, u32 sector_size,\n \n \t/* cluster size: 512, 1K, 2K, 4K, ... 2M */\n \tsct_per_clst = true_sectors_per_clst(boot);\n+\tif ((int)sct_per_clst < 0)\n+\t\tgoto out;\n \tif (!is_power_of_2(sct_per_clst))\n \t\tgoto out;\n \n"
        ]
    },
    "993d8b5e64393ed9e6a70f9ae4de0119c605a822": {
        "non_crash": [
            "diff --git a/drivers/vhost/vsock.c b/drivers/vhost/vsock.c\nindex d6ca1c7ad513..37f0b4274113 100644\n--- a/drivers/vhost/vsock.c\n+++ b/drivers/vhost/vsock.c\n@@ -629,16 +629,18 @@ static int vhost_vsock_start(struct vhost_vsock *vsock)\n \treturn ret;\n }\n \n-static int vhost_vsock_stop(struct vhost_vsock *vsock)\n+static int vhost_vsock_stop(struct vhost_vsock *vsock, bool check_owner)\n {\n \tsize_t i;\n-\tint ret;\n+\tint ret = 0;\n \n \tmutex_lock(&vsock->dev.mutex);\n \n-\tret = vhost_dev_check_owner(&vsock->dev);\n-\tif (ret)\n-\t\tgoto err;\n+\tif (check_owner) {\n+\t\tret = vhost_dev_check_owner(&vsock->dev);\n+\t\tif (ret)\n+\t\t\tgoto err;\n+\t}\n \n \tfor (i = 0; i < ARRAY_SIZE(vsock->vqs); i++) {\n \t\tstruct vhost_virtqueue *vq = &vsock->vqs[i];\n@@ -753,7 +755,12 @@ static int vhost_vsock_dev_release(struct inode *inode, struct file *file)\n \t * inefficient.  Room for improvement here. */\n \tvsock_for_each_connected_socket(vhost_vsock_reset_orphans);\n \n-\tvhost_vsock_stop(vsock);\n+\t/* Don't check the owner, because we are in the release path, so we\n+\t * need to stop the vsock device in any case.\n+\t * vhost_vsock_stop() can not fail in this case, so we don't need to\n+\t * check the return code.\n+\t */\n+\tvhost_vsock_stop(vsock, false);\n \tvhost_vsock_flush(vsock);\n \tvhost_dev_stop(&vsock->dev);\n \n@@ -868,7 +875,7 @@ static long vhost_vsock_dev_ioctl(struct file *f, unsigned int ioctl,\n \t\tif (start)\n \t\t\treturn vhost_vsock_start(vsock);\n \t\telse\n-\t\t\treturn vhost_vsock_stop(vsock);\n+\t\t\treturn vhost_vsock_stop(vsock, true);\n \tcase VHOST_GET_FEATURES:\n \t\tfeatures = VHOST_VSOCK_FEATURES;\n \t\tif (copy_to_user(argp, &features, sizeof(features)))\n"
        ]
    },
    "6e185619b66eae1ef09684c5f6e283d6cfb5ba84": {
        "non_crash": [
            "diff --git a/fs/btrfs/file.c b/fs/btrfs/file.c\nindex 448b143a5cb2..91b00eb2440e 100644\n--- a/fs/btrfs/file.c\n+++ b/fs/btrfs/file.c\n@@ -380,7 +380,10 @@ int btrfs_drop_extents(struct btrfs_trans_handle *trans,\n \t\t\t\t\t\targs->start - extent_offset,\n \t\t\t\t\t\t0, false);\n \t\t\t\tret = btrfs_inc_extent_ref(trans, &ref);\n-\t\t\t\tBUG_ON(ret); /* -ENOMEM */\n+\t\t\t\tif (ret) {\n+\t\t\t\t\tbtrfs_abort_transaction(trans, ret);\n+\t\t\t\t\tbreak;\n+\t\t\t\t}\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+\t\t\t\t\tbtrfs_abort_transaction(trans, ret);\n+\t\t\t\t\tbreak;\n+\t\t\t\t}\n \t\t\t\targs->bytes_found += extent_end - key.offset;\n \t\t\t}\n \n"
        ]
    },
    "e1c3525a4f4e2e4b6c1f73611ceaf61ef462700c": {
        "non_crash": [
            "diff --git a/drivers/hid/hid-thrustmaster.c b/drivers/hid/hid-thrustmaster.c\nindex a4e20f9e598b..c3e6d69fdfbd 100644\n--- a/drivers/hid/hid-thrustmaster.c\n+++ b/drivers/hid/hid-thrustmaster.c\n@@ -160,6 +160,12 @@ static void thrustmaster_interrupts(struct hid_device *hdev)\n \t\treturn;\n \t}\n \n+\tif (usbif->cur_altsetting->desc.bNumEndpoints < 2) {\n+\t\tkfree(send_buf);\n+\t\thid_err(hdev, \"Wrong number of endpoints?\\n\");\n+\t\treturn;\n+\t}\n+\n \tep = &usbif->cur_altsetting->endpoint[1];\n \tb_ep = ep->desc.bEndpointAddress;\n \n"
        ]
    },
    "f7649aa07ffca82dc93dc5cebc00c665849f5138": {
        "non_crash": [
            "diff --git a/security/keys/keyring.c b/security/keys/keyring.c\nindex eadebb92986a..f81372f53dd7 100644\n--- a/security/keys/keyring.c\n+++ b/security/keys/keyring.c\n@@ -661,9 +661,6 @@ static bool search_nested_keyrings(struct key *keyring,\n \tBUG_ON((ctx->flags & STATE_CHECKS) == 0 ||\n \t       (ctx->flags & STATE_CHECKS) == STATE_CHECKS);\n \n-\tif (ctx->index_key.description)\n-\t\tctx->index_key.desc_len = strlen(ctx->index_key.description);\n-\n \t/* Check to see if this top-level keyring is what we are looking for\n \t * and whether it is valid or not.\n \t */\n@@ -914,6 +911,7 @@ key_ref_t keyring_search(key_ref_t keyring,\n \tstruct keyring_search_context ctx = {\n \t\t.index_key.type\t\t= type,\n \t\t.index_key.description\t= description,\n+\t\t.index_key.desc_len\t= strlen(description),\n \t\t.cred\t\t\t= current_cred(),\n \t\t.match_data.cmp\t\t= key_default_cmp,\n \t\t.match_data.raw_data\t= description,\ndiff --git a/security/keys/proc.c b/security/keys/proc.c\nindex d2b802072693..78ac305d715e 100644\n--- a/security/keys/proc.c\n+++ b/security/keys/proc.c\n@@ -165,8 +165,7 @@ static int proc_keys_show(struct seq_file *m, void *v)\n \tint rc;\n \n \tstruct keyring_search_context ctx = {\n-\t\t.index_key.type\t\t= key->type,\n-\t\t.index_key.description\t= key->description,\n+\t\t.index_key\t\t= key->index_key,\n \t\t.cred\t\t\t= m->file->f_cred,\n \t\t.match_data.cmp\t\t= lookup_user_key_possessed,\n \t\t.match_data.raw_data\t= key,\ndiff --git a/security/keys/request_key.c b/security/keys/request_key.c\nindex 3f56a312dd35..7a0c6b666ff0 100644\n--- a/security/keys/request_key.c\n+++ b/security/keys/request_key.c\n@@ -531,6 +531,7 @@ struct key *request_key_and_link(struct key_type *type,\n \tstruct keyring_search_context ctx = {\n \t\t.index_key.type\t\t= type,\n \t\t.index_key.description\t= description,\n+\t\t.index_key.desc_len\t= strlen(description),\n \t\t.cred\t\t\t= current_cred(),\n \t\t.match_data.cmp\t\t= key_default_cmp,\n \t\t.match_data.raw_data\t= description,\ndiff --git a/security/keys/request_key_auth.c b/security/keys/request_key_auth.c\nindex afc304e8b61e..bda6201c6c45 100644\n--- a/security/keys/request_key_auth.c\n+++ b/security/keys/request_key_auth.c\n@@ -247,7 +247,7 @@ struct key *key_get_instantiation_authkey(key_serial_t target_id)\n \tstruct key *authkey;\n \tkey_ref_t authkey_ref;\n \n-\tsprintf(description, \"%x\", target_id);\n+\tctx.index_key.desc_len = sprintf(description, \"%x\", target_id);\n \n \tauthkey_ref = search_process_keyrings(&ctx);\n \n"
        ]
    },
    "4b5b6bdc090752dbcdd7e220a4703fed752cdfe7": {
        "non_crash": [
            "diff --git a/fs/nilfs2/page.c b/fs/nilfs2/page.c\nindex 5cf30827f244..b4e54d079b7d 100644\n--- a/fs/nilfs2/page.c\n+++ b/fs/nilfs2/page.c\n@@ -370,7 +370,15 @@ void nilfs_clear_dirty_pages(struct address_space *mapping, bool silent)\n \t\t\tstruct folio *folio = fbatch.folios[i];\n \n \t\t\tfolio_lock(folio);\n-\t\t\tnilfs_clear_dirty_page(&folio->page, silent);\n+\n+\t\t\t/*\n+\t\t\t * This folio may have been removed from the address\n+\t\t\t * space by truncation or invalidation when the lock\n+\t\t\t * was acquired.  Skip processing in that case.\n+\t\t\t */\n+\t\t\tif (likely(folio->mapping == mapping))\n+\t\t\t\tnilfs_clear_dirty_page(&folio->page, silent);\n+\n \t\t\tfolio_unlock(folio);\n \t\t}\n \t\tfolio_batch_release(&fbatch);\n"
        ]
    },
    "766aad2609c9a3742436a3e25518eba8f5c6ddc8": {
        "non_crash": [
            "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 73f419adce61..4bb6d304eb4b 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -1919,6 +1919,7 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \tstruct usbtmc_ctrlrequest request;\n \tu8 *buffer = NULL;\n \tint rv;\n+\tunsigned int is_in, pipe;\n \tunsigned long res;\n \n \tres = copy_from_user(&request, arg, sizeof(struct usbtmc_ctrlrequest));\n@@ -1928,12 +1929,14 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \tif (request.req.wLength > USBTMC_BUFSIZE)\n \t\treturn -EMSGSIZE;\n \n+\tis_in = request.req.bRequestType & USB_DIR_IN;\n+\n \tif (request.req.wLength) {\n \t\tbuffer = kmalloc(request.req.wLength, GFP_KERNEL);\n \t\tif (!buffer)\n \t\t\treturn -ENOMEM;\n \n-\t\tif ((request.req.bRequestType & USB_DIR_IN) == 0) {\n+\t\tif (!is_in) {\n \t\t\t/* Send control data to device */\n \t\t\tres = copy_from_user(buffer, request.data,\n \t\t\t\t\t     request.req.wLength);\n@@ -1944,8 +1947,12 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \t\t}\n \t}\n \n+\tif (is_in)\n+\t\tpipe = usb_rcvctrlpipe(data->usb_dev, 0);\n+\telse\n+\t\tpipe = usb_sndctrlpipe(data->usb_dev, 0);\n \trv = usb_control_msg(data->usb_dev,\n-\t\t\tusb_rcvctrlpipe(data->usb_dev, 0),\n+\t\t\tpipe,\n \t\t\trequest.req.bRequest,\n \t\t\trequest.req.bRequestType,\n \t\t\trequest.req.wValue,\n@@ -1957,7 +1964,7 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \t\tgoto exit;\n \t}\n \n-\tif (rv && (request.req.bRequestType & USB_DIR_IN)) {\n+\tif (rv && is_in) {\n \t\t/* Read control data from device */\n \t\tres = copy_to_user(request.data, buffer, rv);\n \t\tif (res)\n"
        ]
    },
    "46dd655664a8b38dbf7234683b294171a4e0142b": {
        "non_crash": [
            "diff --git a/drivers/base/class.c b/drivers/base/class.c\nindex ac1808d1a2e8..05d9df90f621 100644\n--- a/drivers/base/class.c\n+++ b/drivers/base/class.c\n@@ -320,6 +320,7 @@ void class_dev_iter_init(struct class_dev_iter *iter, const struct class *class,\n \t\tstart_knode = &start->p->knode_class;\n \tklist_iter_init_node(&sp->klist_devices, &iter->ki, start_knode);\n \titer->type = type;\n+\titer->sp = sp;\n }\n EXPORT_SYMBOL_GPL(class_dev_iter_init);\n \n@@ -361,6 +362,7 @@ EXPORT_SYMBOL_GPL(class_dev_iter_next);\n void class_dev_iter_exit(struct class_dev_iter *iter)\n {\n \tklist_iter_exit(&iter->ki);\n+\tsubsys_put(iter->sp);\n }\n EXPORT_SYMBOL_GPL(class_dev_iter_exit);\n \ndiff --git a/include/linux/device/class.h b/include/linux/device/class.h\nindex 9deeaeb457bb..abf3d3bfb6fe 100644\n--- a/include/linux/device/class.h\n+++ b/include/linux/device/class.h\n@@ -74,6 +74,7 @@ struct class {\n struct class_dev_iter {\n \tstruct klist_iter\t\tki;\n \tconst struct device_type\t*type;\n+\tstruct subsys_private\t\t*sp;\n };\n \n int __must_check class_register(const struct class *class);\n"
        ]
    },
    "032c91d1b0189a2a36f47141f9c3331f8c09d7b1": {
        "non_crash": [
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 816052089b33..e062754dc6cc 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -2197,7 +2197,6 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n \t\t\t      struct netlink_ext_ack *extack)\n {\n \tconst struct nlattr * const *nla = ctx->nla;\n-\tstruct nft_stats __percpu *stats = NULL;\n \tstruct nft_table *table = ctx->table;\n \tstruct nft_base_chain *basechain;\n \tstruct net *net = ctx->net;\n@@ -2212,6 +2211,7 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n \t\treturn -EOVERFLOW;\n \n \tif (nla[NFTA_CHAIN_HOOK]) {\n+\t\tstruct nft_stats __percpu *stats = NULL;\n \t\tstruct nft_chain_hook hook;\n \n \t\tif (flags & NFT_CHAIN_BINDING)\n@@ -2245,6 +2245,8 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n \t\t\tkfree(basechain);\n \t\t\treturn err;\n \t\t}\n+\t\tif (stats)\n+\t\t\tstatic_branch_inc(&nft_counters_enabled);\n \t} else {\n \t\tif (flags & NFT_CHAIN_BASE)\n \t\t\treturn -EINVAL;\n@@ -2319,9 +2321,6 @@ static int nf_tables_addchain(struct nft_ctx *ctx, u8 family, u8 genmask,\n \t\tgoto err_unregister_hook;\n \t}\n \n-\tif (stats)\n-\t\tstatic_branch_inc(&nft_counters_enabled);\n-\n \ttable->use++;\n \n \treturn 0;\n"
        ]
    },
    "cdc284a3166b0aa5c8797071e971fd0606769e61": {
        "non_crash": [
            "diff --git a/net/nfc/nci/data.c b/net/nfc/nci/data.c\nindex aa5e712adf07..3d36ea5701f0 100644\n--- a/net/nfc/nci/data.c\n+++ b/net/nfc/nci/data.c\n@@ -279,8 +279,10 @@ void nci_rx_data_packet(struct nci_dev *ndev, struct sk_buff *skb)\n \t\t nci_plen(skb->data));\n \n \tconn_info = nci_get_conn_info_by_conn_id(ndev, nci_conn_id(skb->data));\n-\tif (!conn_info)\n+\tif (!conn_info) {\n+\t\tkfree_skb(skb);\n \t\treturn;\n+\t}\n \n \t/* strip the nci data header */\n \tskb_pull(skb, NCI_DATA_HDR_SIZE);\n"
        ]
    },
    "1a201ce4f0f4ab2f165b93d0ce5c15ebe1a5b321": {
        "non_crash": [
            "diff --git a/include/linux/mm_inline.h b/include/linux/mm_inline.h\nindex e8ed225d8f7c..ff3f3f23f649 100644\n--- a/include/linux/mm_inline.h\n+++ b/include/linux/mm_inline.h\n@@ -413,8 +413,7 @@ static inline void free_anon_vma_name(struct vm_area_struct *vma)\n \t * Not using anon_vma_name because it generates a warning if mmap_lock\n \t * is not held, which might be the case here.\n \t */\n-\tif (!vma->vm_file)\n-\t\tanon_vma_name_put(vma->anon_name);\n+\tanon_vma_name_put(vma->anon_name);\n }\n \n static inline bool anon_vma_name_eq(struct anon_vma_name *anon_name1,\n"
        ]
    },
    "3443d3a1fa6d964dd7310a0cb1696d165a3e07c4": {
        "non_crash": [
            "diff --git a/drivers/video/fbdev/core/fbcon.c b/drivers/video/fbdev/core/fbcon.c\nindex 4a032fcf0d14..098b62f7b701 100644\n--- a/drivers/video/fbdev/core/fbcon.c\n+++ b/drivers/video/fbdev/core/fbcon.c\n@@ -2401,15 +2401,21 @@ static int fbcon_do_set_font(struct vc_data *vc, int w, int h, int charcount,\n \tstruct fb_info *info = fbcon_info_from_console(vc->vc_num);\n \tstruct fbcon_ops *ops = info->fbcon_par;\n \tstruct fbcon_display *p = &fb_display[vc->vc_num];\n-\tint resize;\n+\tint resize, ret, old_userfont, old_width, old_height, old_charcount;\n \tchar *old_data = NULL;\n \n \tresize = (w != vc->vc_font.width) || (h != vc->vc_font.height);\n \tif (p->userfont)\n \t\told_data = vc->vc_font.data;\n \tvc->vc_font.data = (void *)(p->fontdata = data);\n+\told_userfont = p->userfont;\n \tif ((p->userfont = userfont))\n \t\tREFCOUNT(data)++;\n+\n+\told_width = vc->vc_font.width;\n+\told_height = vc->vc_font.height;\n+\told_charcount = vc->vc_font.charcount;\n+\n \tvc->vc_font.width = w;\n \tvc->vc_font.height = h;\n \tvc->vc_font.charcount = charcount;\n@@ -2425,7 +2431,9 @@ static int fbcon_do_set_font(struct vc_data *vc, int w, int h, int charcount,\n \t\trows = FBCON_SWAP(ops->rotate, info->var.yres, info->var.xres);\n \t\tcols /= w;\n \t\trows /= h;\n-\t\tvc_resize(vc, cols, rows);\n+\t\tret = vc_resize(vc, cols, rows);\n+\t\tif (ret)\n+\t\t\tgoto err_out;\n \t} else if (con_is_visible(vc)\n \t\t   && vc->vc_mode == KD_TEXT) {\n \t\tfbcon_clear_margins(vc, 0);\n@@ -2435,6 +2443,21 @@ static int fbcon_do_set_font(struct vc_data *vc, int w, int h, int charcount,\n \tif (old_data && (--REFCOUNT(old_data) == 0))\n \t\tkfree(old_data - FONT_EXTRA_WORDS * sizeof(int));\n \treturn 0;\n+\n+err_out:\n+\tp->fontdata = old_data;\n+\tvc->vc_font.data = (void *)old_data;\n+\n+\tif (userfont) {\n+\t\tp->userfont = old_userfont;\n+\t\tREFCOUNT(data)--;\n+\t}\n+\n+\tvc->vc_font.width = old_width;\n+\tvc->vc_font.height = old_height;\n+\tvc->vc_font.charcount = old_charcount;\n+\n+\treturn ret;\n }\n \n /*\n"
        ]
    },
    "cfec079d55325bc20e929c60cc2dca149448f9b1": {
        "non_crash": [
            "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 3990e4df3d7b..230038d4f908 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -370,6 +370,7 @@ static void __put_watch_queue(struct kref *kref)\n \n \tfor (i = 0; i < wqueue->nr_pages; i++)\n \t\t__free_page(wqueue->notes[i]);\n+\tkfree(wqueue->notes);\n \tbitmap_free(wqueue->notes_bitmap);\n \n \twfilter = rcu_access_pointer(wqueue->filter);\n"
        ]
    },
    "4649ea695ca98903ae82280a3b7aa97dbeb7fd07": {
        "non_crash": [
            "diff --git a/net/ipv4/nexthop.c b/net/ipv4/nexthop.c\nindex cc8049b100b2..134e92382275 100644\n--- a/net/ipv4/nexthop.c\n+++ b/net/ipv4/nexthop.c\n@@ -446,7 +446,7 @@ static int nh_check_attr_group(struct net *net, struct nlattr *tb[],\n \tunsigned int i, j;\n \tu8 nhg_fdb = 0;\n \n-\tif (len & (sizeof(struct nexthop_grp) - 1)) {\n+\tif (!len || len & (sizeof(struct nexthop_grp) - 1)) {\n \t\tNL_SET_ERR_MSG(extack,\n \t\t\t       \"Invalid length for nexthop group attribute\");\n \t\treturn -EINVAL;\n@@ -1187,6 +1187,9 @@ static struct nexthop *nexthop_create_group(struct net *net,\n \tstruct nexthop *nh;\n \tint i;\n \n+\tif (WARN_ON(!num_nh))\n+\t\treturn ERR_PTR(-EINVAL);\n+\n \tnh = nexthop_alloc();\n \tif (!nh)\n \t\treturn ERR_PTR(-ENOMEM);\n"
        ]
    },
    "e9f526f59d5b25decd3b91d4270b5da2aa23c8f6": {
        "non_crash": [
            "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex 2fcab61b8ff5..03954c13024c 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -812,6 +812,9 @@ int vb2_core_create_bufs(struct vb2_queue *q, enum vb2_memory memory,\n \t\tmemset(q->alloc_devs, 0, sizeof(q->alloc_devs));\n \t\tq->memory = memory;\n \t\tq->waiting_for_buffers = !q->is_output;\n+\t} else if (q->memory != memory) {\n+\t\tdprintk(1, \"memory model mismatch\\n\");\n+\t\treturn -EINVAL;\n \t}\n \n \tnum_buffers = min(*count, VB2_MAX_FRAME - q->num_buffers);\n"
        ]
    },
    "30f3a18df370dd15cce6f725620ac001e57dbee1": {
        "non_crash": [
            "diff --git a/fs/hfs/bnode.c b/fs/hfs/bnode.c\nindex 2015e42e752a..6add6ebfef89 100644\n--- a/fs/hfs/bnode.c\n+++ b/fs/hfs/bnode.c\n@@ -274,6 +274,7 @@ static struct hfs_bnode *__hfs_bnode_create(struct hfs_btree *tree, u32 cnid)\n \t\ttree->node_hash[hash] = node;\n \t\ttree->node_hash_cnt++;\n \t} else {\n+\t\thfs_bnode_get(node2);\n \t\tspin_unlock(&tree->hash_lock);\n \t\tkfree(node);\n \t\twait_event(node2->lock_wq, !test_bit(HFS_BNODE_NEW, &node2->flags));\n"
        ]
    },
    "223c64b1a2c03f0d67d64fdf69606ee2d5e26672": {
        "non_crash": [
            "diff --git a/net/batman-adv/bridge_loop_avoidance.c b/net/batman-adv/bridge_loop_avoidance.c\nindex 1669744304c5..17687848daec 100644\n--- a/net/batman-adv/bridge_loop_avoidance.c\n+++ b/net/batman-adv/bridge_loop_avoidance.c\n@@ -1560,10 +1560,14 @@ int batadv_bla_init(struct batadv_priv *bat_priv)\n \t\treturn 0;\n \n \tbat_priv->bla.claim_hash = batadv_hash_new(128);\n-\tbat_priv->bla.backbone_hash = batadv_hash_new(32);\n+\tif (!bat_priv->bla.claim_hash)\n+\t\treturn -ENOMEM;\n \n-\tif (!bat_priv->bla.claim_hash || !bat_priv->bla.backbone_hash)\n+\tbat_priv->bla.backbone_hash = batadv_hash_new(32);\n+\tif (!bat_priv->bla.backbone_hash) {\n+\t\tbatadv_hash_destroy(bat_priv->bla.claim_hash);\n \t\treturn -ENOMEM;\n+\t}\n \n \tbatadv_hash_set_lock_class(bat_priv->bla.claim_hash,\n \t\t\t\t   &batadv_claim_hash_lock_class_key);\ndiff --git a/net/batman-adv/main.c b/net/batman-adv/main.c\nindex 3ddd66e4c29e..5207cd8d6ad8 100644\n--- a/net/batman-adv/main.c\n+++ b/net/batman-adv/main.c\n@@ -190,29 +190,41 @@ int batadv_mesh_init(struct net_device *soft_iface)\n \n \tbat_priv->gw.generation = 0;\n \n-\tret = batadv_v_mesh_init(bat_priv);\n-\tif (ret < 0)\n-\t\tgoto err;\n-\n \tret = batadv_originator_init(bat_priv);\n-\tif (ret < 0)\n-\t\tgoto err;\n+\tif (ret < 0) {\n+\t\tatomic_set(&bat_priv->mesh_state, BATADV_MESH_DEACTIVATING);\n+\t\tgoto err_orig;\n+\t}\n \n \tret = batadv_tt_init(bat_priv);\n-\tif (ret < 0)\n-\t\tgoto err;\n+\tif (ret < 0) {\n+\t\tatomic_set(&bat_priv->mesh_state, BATADV_MESH_DEACTIVATING);\n+\t\tgoto err_tt;\n+\t}\n+\n+\tret = batadv_v_mesh_init(bat_priv);\n+\tif (ret < 0) {\n+\t\tatomic_set(&bat_priv->mesh_state, BATADV_MESH_DEACTIVATING);\n+\t\tgoto err_v;\n+\t}\n \n \tret = batadv_bla_init(bat_priv);\n-\tif (ret < 0)\n-\t\tgoto err;\n+\tif (ret < 0) {\n+\t\tatomic_set(&bat_priv->mesh_state, BATADV_MESH_DEACTIVATING);\n+\t\tgoto err_bla;\n+\t}\n \n \tret = batadv_dat_init(bat_priv);\n-\tif (ret < 0)\n-\t\tgoto err;\n+\tif (ret < 0) {\n+\t\tatomic_set(&bat_priv->mesh_state, BATADV_MESH_DEACTIVATING);\n+\t\tgoto err_dat;\n+\t}\n \n \tret = batadv_nc_mesh_init(bat_priv);\n-\tif (ret < 0)\n-\t\tgoto err;\n+\tif (ret < 0) {\n+\t\tatomic_set(&bat_priv->mesh_state, BATADV_MESH_DEACTIVATING);\n+\t\tgoto err_nc;\n+\t}\n \n \tbatadv_gw_init(bat_priv);\n \tbatadv_mcast_init(bat_priv);\n@@ -222,8 +234,20 @@ int batadv_mesh_init(struct net_device *soft_iface)\n \n \treturn 0;\n \n-err:\n-\tbatadv_mesh_free(soft_iface);\n+err_nc:\n+\tbatadv_dat_free(bat_priv);\n+err_dat:\n+\tbatadv_bla_free(bat_priv);\n+err_bla:\n+\tbatadv_v_mesh_free(bat_priv);\n+err_v:\n+\tbatadv_tt_free(bat_priv);\n+err_tt:\n+\tbatadv_originator_free(bat_priv);\n+err_orig:\n+\tbatadv_purge_outstanding_packets(bat_priv, NULL);\n+\tatomic_set(&bat_priv->mesh_state, BATADV_MESH_INACTIVE);\n+\n \treturn ret;\n }\n \ndiff --git a/net/batman-adv/network-coding.c b/net/batman-adv/network-coding.c\nindex 9f06132e007d..0a7f1d36a6a8 100644\n--- a/net/batman-adv/network-coding.c\n+++ b/net/batman-adv/network-coding.c\n@@ -152,8 +152,10 @@ int batadv_nc_mesh_init(struct batadv_priv *bat_priv)\n \t\t\t\t   &batadv_nc_coding_hash_lock_class_key);\n \n \tbat_priv->nc.decoding_hash = batadv_hash_new(128);\n-\tif (!bat_priv->nc.decoding_hash)\n+\tif (!bat_priv->nc.decoding_hash) {\n+\t\tbatadv_hash_destroy(bat_priv->nc.coding_hash);\n \t\tgoto err;\n+\t}\n \n \tbatadv_hash_set_lock_class(bat_priv->nc.decoding_hash,\n \t\t\t\t   &batadv_nc_decoding_hash_lock_class_key);\ndiff --git a/net/batman-adv/translation-table.c b/net/batman-adv/translation-table.c\nindex e0b3dace2020..4b7ad6684bc4 100644\n--- a/net/batman-adv/translation-table.c\n+++ b/net/batman-adv/translation-table.c\n@@ -4162,8 +4162,10 @@ int batadv_tt_init(struct batadv_priv *bat_priv)\n \t\treturn ret;\n \n \tret = batadv_tt_global_init(bat_priv);\n-\tif (ret < 0)\n+\tif (ret < 0) {\n+\t\tbatadv_tt_local_table_free(bat_priv);\n \t\treturn ret;\n+\t}\n \n \tbatadv_tvlv_handler_register(bat_priv, batadv_tt_tvlv_ogm_handler_v1,\n \t\t\t\t     batadv_tt_tvlv_unicast_handler_v1,\n"
        ]
    },
    "a49f5785c682daf283714b6695f902e5371b83d7": {
        "non_crash": [
            "diff --git a/fs/erofs/zmap.c b/fs/erofs/zmap.c\nindex cbd3f72c83e9..7ca108c3834c 100644\n--- a/fs/erofs/zmap.c\n+++ b/fs/erofs/zmap.c\n@@ -85,6 +85,10 @@ static int legacy_load_cluster_from_disk(struct z_erofs_maprecorder *m,\n \t\tif (advise & Z_EROFS_LI_PARTIAL_REF)\n \t\t\tm->partialref = true;\n \t\tm->clusterofs = le16_to_cpu(di->di_clusterofs);\n+\t\tif (m->clusterofs >= 1 << vi->z_logical_clusterbits) {\n+\t\t\tDBG_BUGON(1);\n+\t\t\treturn -EFSCORRUPTED;\n+\t\t}\n \t\tm->pblk = le32_to_cpu(di->di_u.blkaddr);\n \t\tbreak;\n \tdefault:\n"
        ]
    },
    "5eb8a5d29d77f8a364cf3270bf9625eb4d4ffc52": {
        "non_crash": [
            "diff --git a/fs/jfs/jfs_dmap.c b/fs/jfs/jfs_dmap.c\nindex 765838578a72..a3eb1e826947 100644\n--- a/fs/jfs/jfs_dmap.c\n+++ b/fs/jfs/jfs_dmap.c\n@@ -193,7 +193,8 @@ int dbMount(struct inode *ipbmap)\n \tbmp->db_agwidth = le32_to_cpu(dbmp_le->dn_agwidth);\n \tbmp->db_agstart = le32_to_cpu(dbmp_le->dn_agstart);\n \tbmp->db_agl2size = le32_to_cpu(dbmp_le->dn_agl2size);\n-\tif (bmp->db_agl2size > L2MAXL2SIZE - L2MAXAG) {\n+\tif (bmp->db_agl2size > L2MAXL2SIZE - L2MAXAG ||\n+\t    bmp->db_agl2size < 0) {\n \t\terr = -EINVAL;\n \t\tgoto err_release_metapage;\n \t}\n"
        ]
    },
    "cd95cb722bfa1234ac4c78345c8953ee2e7170d0": {
        "non_crash": [
            "diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c\nindex e79c767cc5e0..35703dce23a3 100644\n--- a/fs/ext4/extents.c\n+++ b/fs/ext4/extents.c\n@@ -5795,7 +5795,8 @@ int ext4_clu_mapped(struct inode *inode, ext4_lblk_t lclu)\n \t * mapped - no physical clusters have been allocated, and the\n \t * file has no extents\n \t */\n-\tif (ext4_test_inode_state(inode, EXT4_STATE_MAY_INLINE_DATA))\n+\tif (ext4_test_inode_state(inode, EXT4_STATE_MAY_INLINE_DATA) ||\n+\t    ext4_has_inline_data(inode))\n \t\treturn 0;\n \n \t/* search for the extent closest to the first block in the cluster */\n"
        ]
    },
    "39b560f8c5d46a5c107b83c6a1e8ae4051826de0": {
        "non_crash": [
            "diff --git a/net/ethtool/pse-pd.c b/net/ethtool/pse-pd.c\nindex 5a471e115b66..e8683e485dc9 100644\n--- a/net/ethtool/pse-pd.c\n+++ b/net/ethtool/pse-pd.c\n@@ -64,7 +64,7 @@ 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+\tret = pse_get_pse_attributes(dev, info ? info->extack : NULL, data);\n \n \tethnl_ops_complete(dev);\n \n"
        ]
    },
    "507c1be447a4c69f108a0b8cd281fcab44eaf774": {
        "non_crash": [
            "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 928446fe1319..4715980e9015 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -7926,7 +7926,15 @@ static __cold int io_rsrc_ref_quiesce(struct io_rsrc_data *data,\n \t\tret = wait_for_completion_interruptible(&data->done);\n \t\tif (!ret) {\n \t\t\tmutex_lock(&ctx->uring_lock);\n-\t\t\tbreak;\n+\t\t\tif (atomic_read(&data->refs) > 0) {\n+\t\t\t\t/*\n+\t\t\t\t * it has been revived by another thread while\n+\t\t\t\t * we were unlocked\n+\t\t\t\t */\n+\t\t\t\tmutex_unlock(&ctx->uring_lock);\n+\t\t\t} else {\n+\t\t\t\tbreak;\n+\t\t\t}\n \t\t}\n \n \t\tatomic_inc(&data->refs);\n"
        ]
    },
    "2e1c26930cc57edee80734ae71bf020493b32306": {
        "non_crash": [
            "diff --git a/include/net/seg6.h b/include/net/seg6.h\nindex 640724b35273..9d19c15e8545 100644\n--- a/include/net/seg6.h\n+++ b/include/net/seg6.h\n@@ -57,7 +57,7 @@ extern void seg6_iptunnel_exit(void);\n extern int seg6_local_init(void);\n extern void seg6_local_exit(void);\n \n-extern bool seg6_validate_srh(struct ipv6_sr_hdr *srh, int len);\n+extern bool seg6_validate_srh(struct ipv6_sr_hdr *srh, int len, bool reduced);\n extern int seg6_do_srh_encap(struct sk_buff *skb, struct ipv6_sr_hdr *osrh,\n \t\t\t     int proto);\n extern int seg6_do_srh_inline(struct sk_buff *skb, struct ipv6_sr_hdr *osrh);\ndiff --git a/net/core/filter.c b/net/core/filter.c\nindex d01a244b5087..209482a4eaa2 100644\n--- a/net/core/filter.c\n+++ b/net/core/filter.c\n@@ -5050,7 +5050,7 @@ static int bpf_push_seg6_encap(struct sk_buff *skb, u32 type, void *hdr, u32 len\n \tint err;\n \tstruct ipv6_sr_hdr *srh = (struct ipv6_sr_hdr *)hdr;\n \n-\tif (!seg6_validate_srh(srh, len))\n+\tif (!seg6_validate_srh(srh, len, false))\n \t\treturn -EINVAL;\n \n \tswitch (type) {\ndiff --git a/net/ipv6/ipv6_sockglue.c b/net/ipv6/ipv6_sockglue.c\nindex 2c843ff5e3a9..20576e87a5f7 100644\n--- a/net/ipv6/ipv6_sockglue.c\n+++ b/net/ipv6/ipv6_sockglue.c\n@@ -493,7 +493,7 @@ static int do_ipv6_setsockopt(struct sock *sk, int level, int optname,\n \t\t\t\tstruct ipv6_sr_hdr *srh = (struct ipv6_sr_hdr *)\n \t\t\t\t\t\t\t  opt->srcrt;\n \n-\t\t\t\tif (!seg6_validate_srh(srh, optlen))\n+\t\t\t\tif (!seg6_validate_srh(srh, optlen, false))\n \t\t\t\t\tgoto sticky_done;\n \t\t\t\tbreak;\n \t\t\t}\ndiff --git a/net/ipv6/seg6.c b/net/ipv6/seg6.c\nindex 37b434293bda..d2f8138e5a73 100644\n--- a/net/ipv6/seg6.c\n+++ b/net/ipv6/seg6.c\n@@ -25,7 +25,7 @@\n #include <net/seg6_hmac.h>\n #endif\n \n-bool seg6_validate_srh(struct ipv6_sr_hdr *srh, int len)\n+bool seg6_validate_srh(struct ipv6_sr_hdr *srh, int len, bool reduced)\n {\n \tunsigned int tlv_offset;\n \tint max_last_entry;\n@@ -37,13 +37,17 @@ bool seg6_validate_srh(struct ipv6_sr_hdr *srh, int len)\n \tif (((srh->hdrlen + 1) << 3) != len)\n \t\treturn false;\n \n-\tmax_last_entry = (srh->hdrlen / 2) - 1;\n-\n-\tif (srh->first_segment > max_last_entry)\n+\tif (!reduced && srh->segments_left > srh->first_segment) {\n \t\treturn false;\n+\t} else {\n+\t\tmax_last_entry = (srh->hdrlen / 2) - 1;\n \n-\tif (srh->segments_left > srh->first_segment + 1)\n-\t\treturn false;\n+\t\tif (srh->first_segment > max_last_entry)\n+\t\t\treturn false;\n+\n+\t\tif (srh->segments_left > srh->first_segment + 1)\n+\t\t\treturn false;\n+\t}\n \n \ttlv_offset = sizeof(*srh) + ((srh->first_segment + 1) << 4);\n \ndiff --git a/net/ipv6/seg6_iptunnel.c b/net/ipv6/seg6_iptunnel.c\nindex c7cbfeae94f5..e0e9f48ab14f 100644\n--- a/net/ipv6/seg6_iptunnel.c\n+++ b/net/ipv6/seg6_iptunnel.c\n@@ -426,7 +426,7 @@ static int seg6_build_state(struct net *net, struct nlattr *nla,\n \t}\n \n \t/* verify that SRH is consistent */\n-\tif (!seg6_validate_srh(tuninfo->srh, tuninfo_len - sizeof(*tuninfo)))\n+\tif (!seg6_validate_srh(tuninfo->srh, tuninfo_len - sizeof(*tuninfo), false))\n \t\treturn -EINVAL;\n \n \tnewts = lwtunnel_state_alloc(tuninfo_len + sizeof(*slwt));\ndiff --git a/net/ipv6/seg6_local.c b/net/ipv6/seg6_local.c\nindex 52493423f329..eba23279912d 100644\n--- a/net/ipv6/seg6_local.c\n+++ b/net/ipv6/seg6_local.c\n@@ -87,7 +87,7 @@ static struct ipv6_sr_hdr *get_srh(struct sk_buff *skb)\n \t */\n \tsrh = (struct ipv6_sr_hdr *)(skb->data + srhoff);\n \n-\tif (!seg6_validate_srh(srh, len))\n+\tif (!seg6_validate_srh(srh, len, true))\n \t\treturn NULL;\n \n \treturn srh;\n@@ -495,7 +495,7 @@ bool seg6_bpf_has_valid_srh(struct sk_buff *skb)\n \t\t\treturn false;\n \n \t\tsrh->hdrlen = (u8)(srh_state->hdrlen >> 3);\n-\t\tif (!seg6_validate_srh(srh, (srh->hdrlen + 1) << 3))\n+\t\tif (!seg6_validate_srh(srh, (srh->hdrlen + 1) << 3, true))\n \t\t\treturn false;\n \n \t\tsrh_state->valid = true;\n@@ -670,7 +670,7 @@ static int parse_nla_srh(struct nlattr **attrs, struct seg6_local_lwt *slwt)\n \tif (len < sizeof(*srh) + sizeof(struct in6_addr))\n \t\treturn -EINVAL;\n \n-\tif (!seg6_validate_srh(srh, len))\n+\tif (!seg6_validate_srh(srh, len, false))\n \t\treturn -EINVAL;\n \n \tslwt->srh = kmemdup(srh, len, GFP_KERNEL);\n"
        ]
    },
    "96e0ffd75bd9a59edf367decb7583c8994e48cd6": {
        "non_crash": [
            "diff --git a/fs/ntfs3/bitmap.c b/fs/ntfs3/bitmap.c\nindex 629c1ee97268..badaaaf302dd 100644\n--- a/fs/ntfs3/bitmap.c\n+++ b/fs/ntfs3/bitmap.c\n@@ -661,7 +661,7 @@ 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+\twnd->free_bits = kcalloc(wnd->nwnd, sizeof(u16), GFP_NOFS | __GFP_NOWARN);\n \tif (!wnd->free_bits)\n \t\treturn -ENOMEM;\n \n"
        ]
    },
    "8137f770127ad3ae80cc615fbb3b3bdf71c5e17e": {
        "non_crash": [
            "diff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c\nindex 59a5c1341c26..a0f99baafd35 100644\n--- a/net/bluetooth/hci_core.c\n+++ b/net/bluetooth/hci_core.c\n@@ -571,6 +571,7 @@ int hci_dev_close(__u16 dev)\n \t\tgoto done;\n \t}\n \n+\tcancel_work_sync(&hdev->power_on);\n \tif (hci_dev_test_and_clear_flag(hdev, HCI_AUTO_OFF))\n \t\tcancel_delayed_work(&hdev->power_off);\n \n@@ -2675,6 +2676,8 @@ void hci_unregister_dev(struct hci_dev *hdev)\n \tlist_del(&hdev->list);\n \twrite_unlock(&hci_dev_list_lock);\n \n+\tcancel_work_sync(&hdev->power_on);\n+\n \thci_cmd_sync_clear(hdev);\n \n \tif (!test_bit(HCI_QUIRK_NO_SUSPEND_NOTIFIER, &hdev->quirks))\ndiff --git a/net/bluetooth/hci_sync.c b/net/bluetooth/hci_sync.c\nindex 286d6767f017..1739e8cb3291 100644\n--- a/net/bluetooth/hci_sync.c\n+++ b/net/bluetooth/hci_sync.c\n@@ -4088,7 +4088,6 @@ int hci_dev_close_sync(struct hci_dev *hdev)\n \n \tbt_dev_dbg(hdev, \"\");\n \n-\tcancel_work_sync(&hdev->power_on);\n \tcancel_delayed_work(&hdev->power_off);\n \tcancel_delayed_work(&hdev->ncmd_timer);\n \n"
        ]
    },
    "5b79a616feb996279758323aba4031c57f80a8bc": {
        "non_crash": [
            "diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c\nindex 9a0ae59cdc50..4f385d52a1c4 100644\n--- a/net/bridge/netfilter/ebtables.c\n+++ b/net/bridge/netfilter/ebtables.c\n@@ -1040,8 +1040,10 @@ static int do_replace_finish(struct net *net, struct ebt_replace *repl,\n \t\tgoto free_iterate;\n \t}\n \n-\tif (repl->valid_hooks != t->valid_hooks)\n+\tif (repl->valid_hooks != t->valid_hooks) {\n+\t\tret = -EINVAL;\n \t\tgoto free_unlock;\n+\t}\n \n \tif (repl->num_counters && repl->num_counters != t->private->nentries) {\n \t\tret = -EINVAL;\n"
        ]
    },
    "ec324fb855382395411b32d87a6eafd5da721ecc": {
        "non_crash": [
            "diff --git a/net/sctp/socket.c b/net/sctp/socket.c\nindex fc0386e8ff23..739f3e50120d 100644\n--- a/net/sctp/socket.c\n+++ b/net/sctp/socket.c\n@@ -7083,14 +7083,15 @@ static int sctp_getsockopt_pr_assocstatus(struct sock *sk, int len,\n \t}\n \n \tpolicy = params.sprstat_policy;\n-\tif (!policy || (policy & ~(SCTP_PR_SCTP_MASK | SCTP_PR_SCTP_ALL)))\n+\tif (!policy || (policy & ~(SCTP_PR_SCTP_MASK | SCTP_PR_SCTP_ALL)) ||\n+\t    ((policy & SCTP_PR_SCTP_ALL) && (policy & SCTP_PR_SCTP_MASK)))\n \t\tgoto out;\n \n \tasoc = sctp_id2assoc(sk, params.sprstat_assoc_id);\n \tif (!asoc)\n \t\tgoto out;\n \n-\tif (policy & SCTP_PR_SCTP_ALL) {\n+\tif (policy == SCTP_PR_SCTP_ALL) {\n \t\tparams.sprstat_abandoned_unsent = 0;\n \t\tparams.sprstat_abandoned_sent = 0;\n \t\tfor (policy = 0; policy <= SCTP_PR_INDEX(MAX); policy++) {\n@@ -7142,7 +7143,8 @@ static int sctp_getsockopt_pr_streamstatus(struct sock *sk, int len,\n \t}\n \n \tpolicy = params.sprstat_policy;\n-\tif (!policy || (policy & ~(SCTP_PR_SCTP_MASK | SCTP_PR_SCTP_ALL)))\n+\tif (!policy || (policy & ~(SCTP_PR_SCTP_MASK | SCTP_PR_SCTP_ALL)) ||\n+\t    ((policy & SCTP_PR_SCTP_ALL) && (policy & SCTP_PR_SCTP_MASK)))\n \t\tgoto out;\n \n \tasoc = sctp_id2assoc(sk, params.sprstat_assoc_id);\n"
        ]
    },
    "943853d124b5c70143eb385e993d35cb42a883c7": {
        "non_crash": [
            "diff --git a/net/qrtr/af_qrtr.c b/net/qrtr/af_qrtr.c\nindex 5c2fb992803b..3a70255c8d02 100644\n--- a/net/qrtr/af_qrtr.c\n+++ b/net/qrtr/af_qrtr.c\n@@ -393,10 +393,12 @@ static struct qrtr_node *qrtr_node_lookup(unsigned int nid)\n \tstruct qrtr_node *node;\n \tunsigned long flags;\n \n+\tmutex_lock(&qrtr_node_lock);\n \tspin_lock_irqsave(&qrtr_nodes_lock, flags);\n \tnode = radix_tree_lookup(&qrtr_nodes, nid);\n \tnode = qrtr_node_acquire(node);\n \tspin_unlock_irqrestore(&qrtr_nodes_lock, flags);\n+\tmutex_unlock(&qrtr_node_lock);\n \n \treturn node;\n }\n"
        ]
    },
    "731e35eeed762019e385baa96953d9ec8eb63c10": {
        "non_crash": [
            "diff --git a/fs/ext4/inline.c b/fs/ext4/inline.c\nindex d3dfc51a43c5..f47adb284e90 100644\n--- a/fs/ext4/inline.c\n+++ b/fs/ext4/inline.c\n@@ -34,6 +34,7 @@ static int get_max_inline_xattr_value_size(struct inode *inode,\n \tstruct ext4_xattr_ibody_header *header;\n \tstruct ext4_xattr_entry *entry;\n \tstruct ext4_inode *raw_inode;\n+\tvoid *end;\n \tint free, min_offs;\n \n \tif (!EXT4_INODE_HAS_XATTR_SPACE(inode))\n@@ -57,14 +58,23 @@ 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+\tend = (void *)raw_inode + EXT4_SB(inode->i_sb)->s_inode_size;\n \n \t/* Compute min_offs. */\n-\tfor (; !IS_LAST_ENTRY(entry); entry = EXT4_XATTR_NEXT(entry)) {\n+\twhile (!IS_LAST_ENTRY(entry)) {\n+\t\tvoid *next = EXT4_XATTR_NEXT(entry);\n+\n+\t\tif (next >= end) {\n+\t\t\tEXT4_ERROR_INODE(inode,\n+\t\t\t\t\t \"corrupt xattr in inline inode\");\n+\t\t\treturn 0;\n+\t\t}\n \t\tif (!entry->e_value_inum && entry->e_value_size) {\n \t\t\tsize_t offs = le16_to_cpu(entry->e_value_offs);\n \t\t\tif (offs < min_offs)\n \t\t\t\tmin_offs = offs;\n \t\t}\n+\t\tentry = next;\n \t}\n \tfree = min_offs -\n \t\t((void *)entry - (void *)IFIRST(header)) - sizeof(__u32);\n"
        ]
    },
    "0784eb04ffd5b9955880826669badef2ffb32285": {
        "non_crash": [
            "diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c\nindex 1f58debb9a04..49cef61f6a39 100644\n--- a/fs/btrfs/inode.c\n+++ b/fs/btrfs/inode.c\n@@ -7873,8 +7873,11 @@ static void btrfs_dio_submit_io(const struct iomap_iter *iter, struct bio *bio,\n \n \t\tret = btrfs_extract_ordered_extent(bbio, dio_data->ordered);\n \t\tif (ret) {\n-\t\t\tbbio->bio.bi_status = errno_to_blk_status(ret);\n-\t\t\tbtrfs_dio_end_io(bbio);\n+\t\t\tbtrfs_finish_ordered_extent(dio_data->ordered, NULL,\n+\t\t\t\t\t\t    file_offset, dip->bytes,\n+\t\t\t\t\t\t    !ret);\n+\t\t\tbio->bi_status = errno_to_blk_status(ret);\n+\t\t\tiomap_dio_bio_end_io(bio);\n \t\t\treturn;\n \t\t}\n \t}\n"
        ]
    },
    "e90732b9b16086b7f6207149157d36c0faea59f1": {
        "non_crash": [
            "diff --git a/fs/crypto/keyring.c b/fs/crypto/keyring.c\nindex 1cca09aa43f8..2a24b1f0ae68 100644\n--- a/fs/crypto/keyring.c\n+++ b/fs/crypto/keyring.c\n@@ -205,14 +205,19 @@ static int allocate_filesystem_keyring(struct super_block *sb)\n }\n \n /*\n- * This is called at unmount time to release all encryption keys that have been\n- * added to the filesystem, along with the keyring that contains them.\n+ * Release all encryption keys that have been added to the filesystem, along\n+ * with the keyring that contains them.\n  *\n- * Note that besides clearing and freeing memory, this might need to evict keys\n- * from the keyslots of an inline crypto engine.  Therefore, this must be called\n- * while the filesystem's underlying block device(s) are still available.\n+ * This is called at unmount time.  The filesystem's underlying block device(s)\n+ * are still available at this time; this is important because after user file\n+ * accesses have been allowed, this function may need to evict keys from the\n+ * keyslots of an inline crypto engine, which requires the block device(s).\n+ *\n+ * This is also called when the super_block is being freed.  This is needed to\n+ * avoid a memory leak if mounting fails after the \"test_dummy_encryption\"\n+ * option was processed, as in that case the unmount-time call isn't made.\n  */\n-void fscrypt_sb_delete(struct super_block *sb)\n+void fscrypt_destroy_keyring(struct super_block *sb)\n {\n \tstruct fscrypt_keyring *keyring = sb->s_master_keys;\n \tsize_t i;\ndiff --git a/fs/super.c b/fs/super.c\nindex 6a82660e1adb..8d39e4f11cfa 100644\n--- a/fs/super.c\n+++ b/fs/super.c\n@@ -291,6 +291,7 @@ static void __put_super(struct super_block *s)\n \t\tWARN_ON(s->s_inode_lru.node);\n \t\tWARN_ON(!list_empty(&s->s_mounts));\n \t\tsecurity_sb_free(s);\n+\t\tfscrypt_destroy_keyring(s);\n \t\tput_user_ns(s->s_user_ns);\n \t\tkfree(s->s_subtype);\n \t\tcall_rcu(&s->rcu, destroy_super_rcu);\n@@ -479,7 +480,7 @@ void generic_shutdown_super(struct super_block *sb)\n \t\tevict_inodes(sb);\n \t\t/* only nonzero refcount inodes can have marks */\n \t\tfsnotify_sb_delete(sb);\n-\t\tfscrypt_sb_delete(sb);\n+\t\tfscrypt_destroy_keyring(sb);\n \t\tsecurity_sb_delete(sb);\n \n \t\tif (sb->s_dio_done_wq) {\ndiff --git a/include/linux/fscrypt.h b/include/linux/fscrypt.h\nindex cad78b569c7e..4f5f8a651213 100644\n--- a/include/linux/fscrypt.h\n+++ b/include/linux/fscrypt.h\n@@ -307,7 +307,7 @@ fscrypt_free_dummy_policy(struct fscrypt_dummy_policy *dummy_policy)\n }\n \n /* keyring.c */\n-void fscrypt_sb_delete(struct super_block *sb);\n+void fscrypt_destroy_keyring(struct super_block *sb);\n int fscrypt_ioctl_add_key(struct file *filp, void __user *arg);\n int fscrypt_add_test_dummy_key(struct super_block *sb,\n \t\t\t       const struct fscrypt_dummy_policy *dummy_policy);\n@@ -521,7 +521,7 @@ fscrypt_free_dummy_policy(struct fscrypt_dummy_policy *dummy_policy)\n }\n \n /* keyring.c */\n-static inline void fscrypt_sb_delete(struct super_block *sb)\n+static inline void fscrypt_destroy_keyring(struct super_block *sb)\n {\n }\n \n"
        ]
    },
    "9a58b47cdbbb40f7679a00991cac436716c70192": {
        "non_crash": [
            "diff --git a/fs/udf/inode.c b/fs/udf/inode.c\nindex e077183e2ee3..5498365669eb 100644\n--- a/fs/udf/inode.c\n+++ b/fs/udf/inode.c\n@@ -997,23 +997,8 @@ static void udf_merge_extents(struct inode *inode, struct kernel_long_ad *laarr,\n \t\t\tblocksize - 1) >> blocksize_bits)))) {\n \n \t\t\tif (((li->extLength & UDF_EXTENT_LENGTH_MASK) +\n-\t\t\t\t(lip1->extLength & UDF_EXTENT_LENGTH_MASK) +\n-\t\t\t\tblocksize - 1) & ~UDF_EXTENT_LENGTH_MASK) {\n-\t\t\t\tlip1->extLength = (lip1->extLength -\n-\t\t\t\t\t\t  (li->extLength &\n-\t\t\t\t\t\t   UDF_EXTENT_LENGTH_MASK) +\n-\t\t\t\t\t\t   UDF_EXTENT_LENGTH_MASK) &\n-\t\t\t\t\t\t\t~(blocksize - 1);\n-\t\t\t\tli->extLength = (li->extLength &\n-\t\t\t\t\t\t UDF_EXTENT_FLAG_MASK) +\n-\t\t\t\t\t\t(UDF_EXTENT_LENGTH_MASK + 1) -\n-\t\t\t\t\t\tblocksize;\n-\t\t\t\tlip1->extLocation.logicalBlockNum =\n-\t\t\t\t\tli->extLocation.logicalBlockNum +\n-\t\t\t\t\t((li->extLength &\n-\t\t\t\t\t\tUDF_EXTENT_LENGTH_MASK) >>\n-\t\t\t\t\t\tblocksize_bits);\n-\t\t\t} else {\n+\t\t\t     (lip1->extLength & UDF_EXTENT_LENGTH_MASK) +\n+\t\t\t     blocksize - 1) <= UDF_EXTENT_LENGTH_MASK) {\n \t\t\t\tli->extLength = lip1->extLength +\n \t\t\t\t\t(((li->extLength &\n \t\t\t\t\t\tUDF_EXTENT_LENGTH_MASK) +\n"
        ]
    },
    "d58fe2a53afa4ffbfaf3df368acb70d137e46c9f": {
        "non_crash": [
            "diff --git a/fs/f2fs/inode.c b/fs/f2fs/inode.c\nindex 09e986b050c6..e81725c922cd 100644\n--- a/fs/f2fs/inode.c\n+++ b/fs/f2fs/inode.c\n@@ -475,6 +475,12 @@ static int do_read_inode(struct inode *inode)\n \t\tfi->i_inline_xattr_size = 0;\n \t}\n \n+\tif (!sanity_check_inode(inode, node_page)) {\n+\t\tf2fs_put_page(node_page, 1);\n+\t\tf2fs_handle_error(sbi, ERROR_CORRUPTED_INODE);\n+\t\treturn -EFSCORRUPTED;\n+\t}\n+\n \t/* check data exist */\n \tif (f2fs_has_inline_data(inode) && !f2fs_exist_data(inode))\n \t\t__recover_inline_status(inode, node_page);\n@@ -544,12 +550,6 @@ static int do_read_inode(struct inode *inode)\n \tf2fs_init_read_extent_tree(inode, node_page);\n \tf2fs_init_age_extent_tree(inode);\n \n-\tif (!sanity_check_inode(inode, node_page)) {\n-\t\tf2fs_put_page(node_page, 1);\n-\t\tf2fs_handle_error(sbi, ERROR_CORRUPTED_INODE);\n-\t\treturn -EFSCORRUPTED;\n-\t}\n-\n \tif (!sanity_check_extent_cache(inode)) {\n \t\tf2fs_put_page(node_page, 1);\n \t\tf2fs_handle_error(sbi, ERROR_CORRUPTED_INODE);\n"
        ]
    },
    "9b857c714d3e890900acbe48172866a93ab8589a": {
        "non_crash": [
            "diff --git a/sound/core/oss/mulaw.c b/sound/core/oss/mulaw.c\nindex 3788906421a7..fe27034f2846 100644\n--- a/sound/core/oss/mulaw.c\n+++ b/sound/core/oss/mulaw.c\n@@ -329,8 +329,8 @@ 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-\t\treturn -ENXIO;\n+\tif (!snd_pcm_format_linear(format->format))\n+\t\treturn -EINVAL;\n \n \terr = snd_pcm_plugin_build(plug, \"Mu-Law<->linear conversion\",\n \t\t\t\t   src_format, dst_format,\n"
        ]
    },
    "e0640a911365faa499433155c3d5d5b674b36a83": {
        "non_crash": [
            "diff --git a/include/linux/netfilter/nf_conntrack_proto_gre.h b/include/linux/netfilter/nf_conntrack_proto_gre.h\nindex b8d95564bd53..14edb795ab43 100644\n--- a/include/linux/netfilter/nf_conntrack_proto_gre.h\n+++ b/include/linux/netfilter/nf_conntrack_proto_gre.h\n@@ -21,6 +21,19 @@ struct nf_ct_gre_keymap {\n \tstruct nf_conntrack_tuple tuple;\n };\n \n+enum grep_conntrack {\n+\tGRE_CT_UNREPLIED,\n+\tGRE_CT_REPLIED,\n+\tGRE_CT_MAX\n+};\n+\n+struct netns_proto_gre {\n+\tstruct nf_proto_net\tnf;\n+\trwlock_t\t\tkeymap_lock;\n+\tstruct list_head\tkeymap_list;\n+\tunsigned int\t\tgre_timeouts[GRE_CT_MAX];\n+};\n+\n /* add new tuple->key_reply pair to keymap */\n int nf_ct_gre_keymap_add(struct nf_conn *ct, enum ip_conntrack_dir dir,\n \t\t\t struct nf_conntrack_tuple *t);\ndiff --git a/net/netfilter/nf_conntrack_proto_gre.c b/net/netfilter/nf_conntrack_proto_gre.c\nindex 9b48dc8b4b88..2a5e56c6d8d9 100644\n--- a/net/netfilter/nf_conntrack_proto_gre.c\n+++ b/net/netfilter/nf_conntrack_proto_gre.c\n@@ -43,24 +43,12 @@\n #include <linux/netfilter/nf_conntrack_proto_gre.h>\n #include <linux/netfilter/nf_conntrack_pptp.h>\n \n-enum grep_conntrack {\n-\tGRE_CT_UNREPLIED,\n-\tGRE_CT_REPLIED,\n-\tGRE_CT_MAX\n-};\n-\n static const unsigned int gre_timeouts[GRE_CT_MAX] = {\n \t[GRE_CT_UNREPLIED]\t= 30*HZ,\n \t[GRE_CT_REPLIED]\t= 180*HZ,\n };\n \n static unsigned int proto_gre_net_id __read_mostly;\n-struct netns_proto_gre {\n-\tstruct nf_proto_net\tnf;\n-\trwlock_t\t\tkeymap_lock;\n-\tstruct list_head\tkeymap_list;\n-\tunsigned int\t\tgre_timeouts[GRE_CT_MAX];\n-};\n \n static inline struct netns_proto_gre *gre_pernet(struct net *net)\n {\n@@ -402,6 +390,8 @@ static int __init nf_ct_proto_gre_init(void)\n {\n \tint ret;\n \n+\tBUILD_BUG_ON(offsetof(struct netns_proto_gre, nf) != 0);\n+\n \tret = register_pernet_subsys(&proto_gre_net_ops);\n \tif (ret < 0)\n \t\tgoto out_pernet;\ndiff --git a/net/netfilter/nfnetlink_cttimeout.c b/net/netfilter/nfnetlink_cttimeout.c\nindex a518eb162344..109b0d27345a 100644\n--- a/net/netfilter/nfnetlink_cttimeout.c\n+++ b/net/netfilter/nfnetlink_cttimeout.c\n@@ -455,7 +455,8 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \tcase IPPROTO_TCP:\n \t\ttimeouts = nf_tcp_pernet(net)->timeouts;\n \t\tbreak;\n-\tcase IPPROTO_UDP:\n+\tcase IPPROTO_UDP: /* fallthrough */\n+\tcase IPPROTO_UDPLITE:\n \t\ttimeouts = nf_udp_pernet(net)->timeouts;\n \t\tbreak;\n \tcase IPPROTO_DCCP:\n@@ -469,13 +470,23 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \tcase IPPROTO_SCTP:\n #ifdef CONFIG_NF_CT_PROTO_SCTP\n \t\ttimeouts = nf_sctp_pernet(net)->timeouts;\n+#endif\n+\t\tbreak;\n+\tcase IPPROTO_GRE:\n+#ifdef CONFIG_NF_CT_PROTO_GRE\n+\t\tif (l4proto->net_id) {\n+\t\t\tstruct netns_proto_gre *net_gre;\n+\n+\t\t\tnet_gre = net_generic(net, *l4proto->net_id);\n+\t\t\ttimeouts = net_gre->gre_timeouts;\n+\t\t}\n #endif\n \t\tbreak;\n \tcase 255:\n \t\ttimeouts = &nf_generic_pernet(net)->timeout;\n \t\tbreak;\n \tdefault:\n-\t\tWARN_ON_ONCE(1);\n+\t\tWARN_ONCE(1, \"Missing timeouts for proto %d\", l4proto->l4proto);\n \t\tbreak;\n \t}\n \n"
        ]
    },
    "01383b29d139cf9c9f9d9bd6e9947474ffe657a6": {
        "non_crash": [
            "diff --git a/mm/gup.c b/mm/gup.c\nindex ef29641671c7..76d222ccc3ff 100644\n--- a/mm/gup.c\n+++ b/mm/gup.c\n@@ -1091,6 +1091,45 @@ static int check_vma_flags(struct vm_area_struct *vma, unsigned long gup_flags)\n \treturn 0;\n }\n \n+/*\n+ * This is \"vma_lookup()\", but with a warning if we would have\n+ * historically expanded the stack in the GUP code.\n+ */\n+static struct vm_area_struct *gup_vma_lookup(struct mm_struct *mm,\n+\t unsigned long addr)\n+{\n+#ifdef CONFIG_STACK_GROWSUP\n+\treturn vma_lookup(mm, addr);\n+#else\n+\tstatic volatile unsigned long next_warn;\n+\tstruct vm_area_struct *vma;\n+\tunsigned long now, next;\n+\n+\tvma = find_vma(mm, addr);\n+\tif (!vma || (addr >= vma->vm_start))\n+\t\treturn vma;\n+\n+\t/* Only warn for half-way relevant accesses */\n+\tif (!(vma->vm_flags & VM_GROWSDOWN))\n+\t\treturn NULL;\n+\tif (vma->vm_start - addr > 65536)\n+\t\treturn NULL;\n+\n+\t/* Let's not warn more than once an hour.. */\n+\tnow = jiffies; next = next_warn;\n+\tif (next && time_before(now, next))\n+\t\treturn NULL;\n+\tnext_warn = now + 60*60*HZ;\n+\n+\t/* Let people know things may have changed. */\n+\tpr_warn(\"GUP no longer grows the stack in %s (%d): %lx-%lx (%lx)\\n\",\n+\t\tcurrent->comm, task_pid_nr(current),\n+\t\tvma->vm_start, vma->vm_end, addr);\n+\tdump_stack();\n+\treturn NULL;\n+#endif\n+}\n+\n /**\n  * __get_user_pages() - pin user pages in memory\n  * @mm:\t\tmm_struct of target mm\n@@ -1168,11 +1207,7 @@ static long __get_user_pages(struct mm_struct *mm,\n \n \t\t/* first iteration or cross vma bound */\n \t\tif (!vma || start >= vma->vm_end) {\n-\t\t\tvma = find_vma(mm, start);\n-\t\t\tif (vma && (start < vma->vm_start)) {\n-\t\t\t\tWARN_ON_ONCE(vma->vm_flags & VM_GROWSDOWN);\n-\t\t\t\tvma = NULL;\n-\t\t\t}\n+\t\t\tvma = gup_vma_lookup(mm, start);\n \t\t\tif (!vma && in_gate_area(mm, start)) {\n \t\t\t\tret = get_gate_page(mm, start & PAGE_MASK,\n \t\t\t\t\t\tgup_flags, &vma,\n@@ -1337,13 +1372,9 @@ int fixup_user_fault(struct mm_struct *mm,\n \t\tfault_flags |= FAULT_FLAG_ALLOW_RETRY | FAULT_FLAG_KILLABLE;\n \n retry:\n-\tvma = find_vma(mm, address);\n+\tvma = gup_vma_lookup(mm, address);\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\treturn -EFAULT;\n-\t}\n \n \tif (!vma_permits_fault(vma, fault_flags))\n \t\treturn -EFAULT;\n"
        ]
    },
    "fea1767458f80cd02b783a4a317e76c229ffddab": {
        "non_crash": [
            "diff --git a/net/netfilter/nfnetlink_cttimeout.c b/net/netfilter/nfnetlink_cttimeout.c\nindex e7a50af1b3d6..a518eb162344 100644\n--- a/net/netfilter/nfnetlink_cttimeout.c\n+++ b/net/netfilter/nfnetlink_cttimeout.c\n@@ -382,7 +382,8 @@ static int cttimeout_default_set(struct net *net, struct sock *ctnl,\n static int\n cttimeout_default_fill_info(struct net *net, struct sk_buff *skb, u32 portid,\n \t\t\t    u32 seq, u32 type, int event, u16 l3num,\n-\t\t\t    const struct nf_conntrack_l4proto *l4proto)\n+\t\t\t    const struct nf_conntrack_l4proto *l4proto,\n+\t\t\t    const unsigned int *timeouts)\n {\n \tstruct nlmsghdr *nlh;\n \tstruct nfgenmsg *nfmsg;\n@@ -408,7 +409,7 @@ cttimeout_default_fill_info(struct net *net, struct sk_buff *skb, u32 portid,\n \tif (!nest_parms)\n \t\tgoto nla_put_failure;\n \n-\tret = l4proto->ctnl_timeout.obj_to_nlattr(skb, NULL);\n+\tret = l4proto->ctnl_timeout.obj_to_nlattr(skb, timeouts);\n \tif (ret < 0)\n \t\tgoto nla_put_failure;\n \n@@ -430,6 +431,7 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \t\t\t\t struct netlink_ext_ack *extack)\n {\n \tconst struct nf_conntrack_l4proto *l4proto;\n+\tunsigned int *timeouts = NULL;\n \tstruct sk_buff *skb2;\n \tint ret, err;\n \t__u16 l3num;\n@@ -442,12 +444,44 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \tl4num = nla_get_u8(cda[CTA_TIMEOUT_L4PROTO]);\n \tl4proto = nf_ct_l4proto_find_get(l4num);\n \n-\t/* This protocol is not supported, skip. */\n-\tif (l4proto->l4proto != l4num) {\n-\t\terr = -EOPNOTSUPP;\n+\terr = -EOPNOTSUPP;\n+\tif (l4proto->l4proto != l4num)\n \t\tgoto err;\n+\n+\tswitch (l4proto->l4proto) {\n+\tcase IPPROTO_ICMP:\n+\t\ttimeouts = &nf_icmp_pernet(net)->timeout;\n+\t\tbreak;\n+\tcase IPPROTO_TCP:\n+\t\ttimeouts = nf_tcp_pernet(net)->timeouts;\n+\t\tbreak;\n+\tcase IPPROTO_UDP:\n+\t\ttimeouts = nf_udp_pernet(net)->timeouts;\n+\t\tbreak;\n+\tcase IPPROTO_DCCP:\n+#ifdef CONFIG_NF_CT_PROTO_DCCP\n+\t\ttimeouts = nf_dccp_pernet(net)->dccp_timeout;\n+#endif\n+\t\tbreak;\n+\tcase IPPROTO_ICMPV6:\n+\t\ttimeouts = &nf_icmpv6_pernet(net)->timeout;\n+\t\tbreak;\n+\tcase IPPROTO_SCTP:\n+#ifdef CONFIG_NF_CT_PROTO_SCTP\n+\t\ttimeouts = nf_sctp_pernet(net)->timeouts;\n+#endif\n+\t\tbreak;\n+\tcase 255:\n+\t\ttimeouts = &nf_generic_pernet(net)->timeout;\n+\t\tbreak;\n+\tdefault:\n+\t\tWARN_ON_ONCE(1);\n+\t\tbreak;\n \t}\n \n+\tif (!timeouts)\n+\t\tgoto err;\n+\n \tskb2 = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);\n \tif (skb2 == NULL) {\n \t\terr = -ENOMEM;\n@@ -458,8 +492,7 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \t\t\t\t\t  nlh->nlmsg_seq,\n \t\t\t\t\t  NFNL_MSG_TYPE(nlh->nlmsg_type),\n \t\t\t\t\t  IPCTNL_MSG_TIMEOUT_DEFAULT_SET,\n-\t\t\t\t\t  l3num,\n-\t\t\t\t\t  l4proto);\n+\t\t\t\t\t  l3num, l4proto, timeouts);\n \tif (ret <= 0) {\n \t\tkfree_skb(skb2);\n \t\terr = -ENOMEM;\n"
        ]
    },
    "bb281e89381b9ed55728c274447a575e69a96c35": {
        "non_crash": [
            "diff --git a/fs/overlayfs/super.c b/fs/overlayfs/super.c\nindex a29a8afe9b26..3d14a3f1465d 100644\n--- a/fs/overlayfs/super.c\n+++ b/fs/overlayfs/super.c\n@@ -139,11 +139,16 @@ static int ovl_dentry_revalidate_common(struct dentry *dentry,\n \t\t\t\t\tunsigned int flags, bool weak)\n {\n \tstruct ovl_entry *oe = dentry->d_fsdata;\n+\tstruct inode *inode = d_inode_rcu(dentry);\n \tstruct dentry *upper;\n \tunsigned int i;\n \tint ret = 1;\n \n-\tupper = ovl_dentry_upper(dentry);\n+\t/* Careful in RCU mode */\n+\tif (!inode)\n+\t\treturn -ECHILD;\n+\n+\tupper = ovl_i_dentry_upper(inode);\n \tif (upper)\n \t\tret = ovl_revalidate_real(upper, flags, weak);\n \n"
        ]
    },
    "8db097bf9d28642881b6dee785166885150fbd86": {
        "non_crash": [
            "diff --git a/fs/nilfs2/dat.c b/fs/nilfs2/dat.c\nindex 9930fa901039..1e7f653c1df7 100644\n--- a/fs/nilfs2/dat.c\n+++ b/fs/nilfs2/dat.c\n@@ -40,8 +40,21 @@ static inline struct nilfs_dat_info *NILFS_DAT_I(struct inode *dat)\n static int nilfs_dat_prepare_entry(struct inode *dat,\n \t\t\t\t   struct nilfs_palloc_req *req, int create)\n {\n-\treturn nilfs_palloc_get_entry_block(dat, req->pr_entry_nr,\n-\t\t\t\t\t    create, &req->pr_entry_bh);\n+\tint ret;\n+\n+\tret = nilfs_palloc_get_entry_block(dat, req->pr_entry_nr,\n+\t\t\t\t\t   create, &req->pr_entry_bh);\n+\tif (unlikely(ret == -ENOENT)) {\n+\t\tnilfs_err(dat->i_sb,\n+\t\t\t  \"DAT doesn't have a block to manage vblocknr = %llu\",\n+\t\t\t  (unsigned long long)req->pr_entry_nr);\n+\t\t/*\n+\t\t * Return internal code -EINVAL to notify bmap layer of\n+\t\t * metadata corruption.\n+\t\t */\n+\t\tret = -EINVAL;\n+\t}\n+\treturn ret;\n }\n \n static void nilfs_dat_commit_entry(struct inode *dat,\n@@ -123,11 +136,7 @@ static void nilfs_dat_commit_free(struct inode *dat,\n \n int nilfs_dat_prepare_start(struct inode *dat, struct nilfs_palloc_req *req)\n {\n-\tint ret;\n-\n-\tret = nilfs_dat_prepare_entry(dat, req, 0);\n-\tWARN_ON(ret == -ENOENT);\n-\treturn ret;\n+\treturn nilfs_dat_prepare_entry(dat, req, 0);\n }\n \n void nilfs_dat_commit_start(struct inode *dat, struct nilfs_palloc_req *req,\n@@ -154,10 +163,8 @@ int nilfs_dat_prepare_end(struct inode *dat, struct nilfs_palloc_req *req)\n \tint ret;\n \n \tret = nilfs_dat_prepare_entry(dat, req, 0);\n-\tif (ret < 0) {\n-\t\tWARN_ON(ret == -ENOENT);\n+\tif (ret < 0)\n \t\treturn ret;\n-\t}\n \n \tkaddr = kmap_atomic(req->pr_entry_bh->b_page);\n \tentry = nilfs_palloc_block_get_entry(dat, req->pr_entry_nr,\n"
        ]
    },
    "1bb19c23cbf08cedbc6bbe5d4b7e07f6403fa35e": {
        "non_crash": [
            "diff --git a/mm/ksm.c b/mm/ksm.c\nindex ad591b779d53..2b8d30068cbb 100644\n--- a/mm/ksm.c\n+++ b/mm/ksm.c\n@@ -988,9 +988,15 @@ static int unmerge_and_remove_all_rmap_items(void)\n \n \t\tmm = mm_slot->slot.mm;\n \t\tmmap_read_lock(mm);\n+\n+\t\t/*\n+\t\t * Exit right away if mm is exiting to avoid lockdep issue in\n+\t\t * the maple tree\n+\t\t */\n+\t\tif (ksm_test_exit(mm))\n+\t\t\tgoto mm_exiting;\n+\n \t\tfor_each_vma(vmi, vma) {\n-\t\t\tif (ksm_test_exit(mm))\n-\t\t\t\tbreak;\n \t\t\tif (!(vma->vm_flags & VM_MERGEABLE) || !vma->anon_vma)\n \t\t\t\tcontinue;\n \t\t\terr = unmerge_ksm_pages(vma,\n@@ -999,6 +1005,7 @@ static int unmerge_and_remove_all_rmap_items(void)\n \t\t\t\tgoto error;\n \t\t}\n \n+mm_exiting:\n \t\tremove_trailing_rmap_items(&mm_slot->rmap_list);\n \t\tmmap_read_unlock(mm);\n \n"
        ]
    },
    "8e9ea22655c782ac9af556ba3d4d822530a59390": {
        "non_crash": [
            "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 4bb6d304eb4b..311007b1d904 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -1928,6 +1928,8 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \n \tif (request.req.wLength > USBTMC_BUFSIZE)\n \t\treturn -EMSGSIZE;\n+\tif (request.req.wLength == 0)\t/* Length-0 requests are never IN */\n+\t\trequest.req.bRequestType &= ~USB_DIR_IN;\n \n \tis_in = request.req.bRequestType & USB_DIR_IN;\n \n"
        ]
    },
    "f1d54f488af5e3967ea8e664e514cb1c2820db45": {
        "non_crash": [
            "diff --git a/fs/btrfs/extent-io-tree.c b/fs/btrfs/extent-io-tree.c\nindex a630c771d25c..599db7b15574 100644\n--- a/fs/btrfs/extent-io-tree.c\n+++ b/fs/btrfs/extent-io-tree.c\n@@ -572,7 +572,7 @@ int __clear_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \tif (bits & (EXTENT_LOCKED | EXTENT_BOUNDARY))\n \t\tclear = 1;\n again:\n-\tif (!prealloc && gfpflags_allow_blocking(mask)) {\n+\tif (!prealloc) {\n \t\t/*\n \t\t * Don't care for allocation failure here because we might end\n \t\t * up not needing the pre-allocated extent state at all, which\n@@ -636,7 +636,8 @@ int __clear_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \n \tif (state->start < start) {\n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc)\n+\t\t\tgoto search_again;\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 +658,8 @@ int __clear_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \t */\n \tif (state->start <= end && state->end > end) {\n \t\tprealloc = alloc_extent_state_atomic(prealloc);\n-\t\tBUG_ON(!prealloc);\n+\t\tif (!prealloc)\n+\t\t\tgoto search_again;\n \t\terr = split_state(tree, state, prealloc, end + 1);\n \t\tif (err)\n \t\t\textent_io_tree_panic(tree, err);\n@@ -987,7 +989,7 @@ static int __set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end,\n \telse\n \t\tASSERT(failed_start == NULL && failed_state == NULL);\n again:\n-\tif (!prealloc && gfpflags_allow_blocking(mask)) {\n+\tif (!prealloc) {\n \t\t/*\n \t\t * Don't care for allocation failure here because we might end\n \t\t * up not needing the pre-allocated extent state at all, which\n@@ -1012,7 +1014,8 @@ 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+\t\t\tgoto search_again;\n \t\tprealloc->start = start;\n \t\tprealloc->end = end;\n \t\tinsert_state_fast(tree, prealloc, p, parent, bits, changeset);\n@@ -1085,7 +1088,8 @@ 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+\t\t\tgoto search_again;\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 +1126,8 @@ 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+\t\t\tgoto search_again;\n \n \t\t/*\n \t\t * Avoid to free 'prealloc' if it can be merged with the later\n@@ -1154,7 +1159,8 @@ 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+\t\t\tgoto search_again;\n \t\terr = split_state(tree, state, prealloc, end + 1);\n \t\tif (err)\n \t\t\textent_io_tree_panic(tree, err);\n"
        ]
    },
    "12be9aa373be9d8727cdd172f190de39528a413a": {
        "non_crash": [
            "diff --git a/net/mptcp/protocol.c b/net/mptcp/protocol.c\nindex 32ea8d35489a..c8675d2eb5b9 100644\n--- a/net/mptcp/protocol.c\n+++ b/net/mptcp/protocol.c\n@@ -954,7 +954,8 @@ static int mptcp_recvmsg(struct sock *sk, struct msghdr *msg, size_t len,\n \n \t\tpr_debug(\"block timeout %ld\", timeo);\n \t\tmptcp_wait_data(sk, &timeo);\n-\t\tif (unlikely(__mptcp_tcp_fallback(msk)))\n+\t\tssock = __mptcp_tcp_fallback(msk);\n+\t\tif (unlikely(ssock))\n \t\t\tgoto fallback;\n \t}\n \n"
        ]
    },
    "0518799fc2250353125d212fc510c44adbde73c3": {
        "non_crash": [
            "diff --git a/drivers/net/wireless/ath/ath9k/htc_hst.c b/drivers/net/wireless/ath/ath9k/htc_hst.c\nindex ca05b07a45e6..fe62ff668f75 100644\n--- a/drivers/net/wireless/ath/ath9k/htc_hst.c\n+++ b/drivers/net/wireless/ath/ath9k/htc_hst.c\n@@ -391,7 +391,7 @@ static void ath9k_htc_fw_panic_report(struct htc_target *htc_handle,\n  * HTC Messages are handled directly here and the obtained SKB\n  * is freed.\n  *\n- * Service messages (Data, WMI) passed to the corresponding\n+ * Service messages (Data, WMI) are passed to the corresponding\n  * endpoint RX handlers, which have to free the SKB.\n  */\n void ath9k_htc_rx_msg(struct htc_target *htc_handle,\n@@ -478,6 +478,8 @@ void ath9k_htc_rx_msg(struct htc_target *htc_handle,\n \t\tif (endpoint->ep_callbacks.rx)\n \t\t\tendpoint->ep_callbacks.rx(endpoint->ep_callbacks.priv,\n \t\t\t\t\t\t  skb, epid);\n+\t\telse\n+\t\t\tgoto invalid;\n \t}\n }\n \n"
        ]
    },
    "d21cb12ee03822236d82ba4e83a1f8968e7832fb": {
        "non_crash": [
            "diff --git a/mm/filemap.c b/mm/filemap.c\nindex a34abfe8c654..b4c9bd368b7e 100644\n--- a/mm/filemap.c\n+++ b/mm/filemap.c\n@@ -3378,7 +3378,7 @@ vm_fault_t filemap_fault(struct vm_fault *vmf)\n \t * re-find the vma and come back and find our hopefully still populated\n \t * page.\n \t */\n-\tif (folio)\n+\tif (!IS_ERR(folio))\n \t\tfolio_put(folio);\n \tif (mapping_locked)\n \t\tfilemap_invalidate_unlock_shared(mapping);\n"
        ]
    },
    "1bd2e7a7bb0310b1b0974022c78ee23975119187": {
        "non_crash": [
            "diff --git a/net/rxrpc/call_object.c b/net/rxrpc/call_object.c\nindex dbdbc4f18b5e..c9f34b0a11df 100644\n--- a/net/rxrpc/call_object.c\n+++ b/net/rxrpc/call_object.c\n@@ -562,11 +562,11 @@ void rxrpc_put_call(struct rxrpc_call *call, enum rxrpc_call_trace op)\n }\n \n /*\n- * Final call destruction under RCU.\n+ * Final call destruction - but must be done in process context.\n  */\n-static void rxrpc_rcu_destroy_call(struct rcu_head *rcu)\n+static void rxrpc_destroy_call(struct work_struct *work)\n {\n-\tstruct rxrpc_call *call = container_of(rcu, struct rxrpc_call, rcu);\n+\tstruct rxrpc_call *call = container_of(work, struct rxrpc_call, processor);\n \tstruct rxrpc_net *rxnet = call->rxnet;\n \n \trxrpc_put_connection(call->conn);\n@@ -578,6 +578,22 @@ static void rxrpc_rcu_destroy_call(struct rcu_head *rcu)\n \t\twake_up_var(&rxnet->nr_calls);\n }\n \n+/*\n+ * Final call destruction under RCU.\n+ */\n+static void rxrpc_rcu_destroy_call(struct rcu_head *rcu)\n+{\n+\tstruct rxrpc_call *call = container_of(rcu, struct rxrpc_call, rcu);\n+\n+\tif (in_softirq()) {\n+\t\tINIT_WORK(&call->processor, rxrpc_destroy_call);\n+\t\tif (!rxrpc_queue_work(&call->processor))\n+\t\t\tBUG();\n+\t} else {\n+\t\trxrpc_destroy_call(&call->processor);\n+\t}\n+}\n+\n /*\n  * clean up a call\n  */\n"
        ]
    },
    "67d3719a7490d99812faae7f9c2c26e9f386c1a6": {
        "non_crash": [
            "diff --git a/fs/hfs/trans.c b/fs/hfs/trans.c\nindex 39f5e343bf4d..fdb0edb8a607 100644\n--- a/fs/hfs/trans.c\n+++ b/fs/hfs/trans.c\n@@ -109,7 +109,7 @@ void hfs_asc2mac(struct super_block *sb, struct hfs_name *out, const struct qstr\n \tif (nls_io) {\n \t\twchar_t ch;\n \n-\t\twhile (srclen > 0) {\n+\t\twhile (srclen > 0 && dstlen > 0) {\n \t\t\tsize = nls_io->char2uni(src, srclen, &ch);\n \t\t\tif (size < 0) {\n \t\t\t\tch = '?';\n"
        ]
    },
    "7d3c28ba3d4bf4b26e89ed1f1ca146e0223a2d36": {
        "non_crash": [
            "diff --git a/kernel/watch_queue.c b/kernel/watch_queue.c\nindex 5848d4795816..3990e4df3d7b 100644\n--- a/kernel/watch_queue.c\n+++ b/kernel/watch_queue.c\n@@ -395,6 +395,7 @@ static void free_watch(struct rcu_head *rcu)\n \tput_watch_queue(rcu_access_pointer(watch->queue));\n \tatomic_dec(&watch->cred->user->nr_watches);\n \tput_cred(watch->cred);\n+\tkfree(watch);\n }\n \n static void __put_watch(struct kref *kref)\n"
        ]
    },
    "64bdab02654a9c43c1009be0bd3d7e992ba2eab2": {
        "non_crash": [
            "diff --git a/include/net/genetlink.h b/include/net/genetlink.h\nindex 74950663bb00..ad71ed4f55ff 100644\n--- a/include/net/genetlink.h\n+++ b/include/net/genetlink.h\n@@ -41,7 +41,6 @@ struct genl_info;\n  *\tNote that unbind() will not be called symmetrically if the\n  *\tgeneric netlink family is removed while there are still open\n  *\tsockets.\n- * @attrbuf: buffer to store parsed attributes (private)\n  * @mcgrps: multicast groups used by this family\n  * @n_mcgrps: number of multicast groups\n  * @mcgrp_offset: starting number of multicast group IDs in this family\n@@ -66,7 +65,6 @@ struct genl_family {\n \t\t\t\t\t     struct genl_info *info);\n \tint\t\t\t(*mcast_bind)(struct net *net, int group);\n \tvoid\t\t\t(*mcast_unbind)(struct net *net, int group);\n-\tstruct nlattr **\tattrbuf;\t/* private */\n \tconst struct genl_ops *\tops;\n \tconst struct genl_multicast_group *mcgrps;\n \tunsigned int\t\tn_ops;\ndiff --git a/net/netlink/genetlink.c b/net/netlink/genetlink.c\nindex 55ee680e9db1..a914b9365a46 100644\n--- a/net/netlink/genetlink.c\n+++ b/net/netlink/genetlink.c\n@@ -351,22 +351,11 @@ int genl_register_family(struct genl_family *family)\n \t\tstart = end = GENL_ID_VFS_DQUOT;\n \t}\n \n-\tif (family->maxattr && !family->parallel_ops) {\n-\t\tfamily->attrbuf = kmalloc_array(family->maxattr + 1,\n-\t\t\t\t\t\tsizeof(struct nlattr *),\n-\t\t\t\t\t\tGFP_KERNEL);\n-\t\tif (family->attrbuf == NULL) {\n-\t\t\terr = -ENOMEM;\n-\t\t\tgoto errout_locked;\n-\t\t}\n-\t} else\n-\t\tfamily->attrbuf = NULL;\n-\n \tfamily->id = idr_alloc_cyclic(&genl_fam_idr, family,\n \t\t\t\t      start, end + 1, GFP_KERNEL);\n \tif (family->id < 0) {\n \t\terr = family->id;\n-\t\tgoto errout_free;\n+\t\tgoto errout_locked;\n \t}\n \n \terr = genl_validate_assign_mc_groups(family);\n@@ -385,8 +374,6 @@ int genl_register_family(struct genl_family *family)\n \n errout_remove:\n \tidr_remove(&genl_fam_idr, family->id);\n-errout_free:\n-\tkfree(family->attrbuf);\n errout_locked:\n \tgenl_unlock_all();\n \treturn err;\n@@ -419,8 +406,6 @@ int genl_unregister_family(const struct genl_family *family)\n \t\t   atomic_read(&genl_sk_destructing_cnt) == 0);\n \tgenl_unlock();\n \n-\tkfree(family->attrbuf);\n-\n \tgenl_ctrl_event(CTRL_CMD_DELFAMILY, family, NULL, 0);\n \n \treturn 0;\n@@ -485,30 +470,23 @@ genl_family_rcv_msg_attrs_parse(const struct genl_family *family,\n \tif (!family->maxattr)\n \t\treturn NULL;\n \n-\tif (family->parallel_ops) {\n-\t\tattrbuf = kmalloc_array(family->maxattr + 1,\n-\t\t\t\t\tsizeof(struct nlattr *), GFP_KERNEL);\n-\t\tif (!attrbuf)\n-\t\t\treturn ERR_PTR(-ENOMEM);\n-\t} else {\n-\t\tattrbuf = family->attrbuf;\n-\t}\n+\tattrbuf = kmalloc_array(family->maxattr + 1,\n+\t\t\t\tsizeof(struct nlattr *), GFP_KERNEL);\n+\tif (!attrbuf)\n+\t\treturn ERR_PTR(-ENOMEM);\n \n \terr = __nlmsg_parse(nlh, hdrlen, attrbuf, family->maxattr,\n \t\t\t    family->policy, validate, extack);\n \tif (err) {\n-\t\tif (family->parallel_ops)\n-\t\t\tkfree(attrbuf);\n+\t\tkfree(attrbuf);\n \t\treturn ERR_PTR(err);\n \t}\n \treturn attrbuf;\n }\n \n-static void genl_family_rcv_msg_attrs_free(const struct genl_family *family,\n-\t\t\t\t\t   struct nlattr **attrbuf)\n+static void genl_family_rcv_msg_attrs_free(struct nlattr **attrbuf)\n {\n-\tif (family->parallel_ops)\n-\t\tkfree(attrbuf);\n+\tkfree(attrbuf);\n }\n \n struct genl_start_context {\n@@ -542,7 +520,7 @@ static int genl_start(struct netlink_callback *cb)\n no_attrs:\n \tinfo = genl_dumpit_info_alloc();\n \tif (!info) {\n-\t\tgenl_family_rcv_msg_attrs_free(ctx->family, attrs);\n+\t\tgenl_family_rcv_msg_attrs_free(attrs);\n \t\treturn -ENOMEM;\n \t}\n \tinfo->family = ctx->family;\n@@ -559,7 +537,7 @@ static int genl_start(struct netlink_callback *cb)\n \t}\n \n \tif (rc) {\n-\t\tgenl_family_rcv_msg_attrs_free(info->family, info->attrs);\n+\t\tgenl_family_rcv_msg_attrs_free(info->attrs);\n \t\tgenl_dumpit_info_free(info);\n \t\tcb->data = NULL;\n \t}\n@@ -588,7 +566,7 @@ static int genl_lock_done(struct netlink_callback *cb)\n \t\trc = ops->done(cb);\n \t\tgenl_unlock();\n \t}\n-\tgenl_family_rcv_msg_attrs_free(info->family, info->attrs);\n+\tgenl_family_rcv_msg_attrs_free(info->attrs);\n \tgenl_dumpit_info_free(info);\n \treturn rc;\n }\n@@ -601,7 +579,7 @@ static int genl_parallel_done(struct netlink_callback *cb)\n \n \tif (ops->done)\n \t\trc = ops->done(cb);\n-\tgenl_family_rcv_msg_attrs_free(info->family, info->attrs);\n+\tgenl_family_rcv_msg_attrs_free(info->attrs);\n \tgenl_dumpit_info_free(info);\n \treturn rc;\n }\n@@ -694,7 +672,7 @@ static int genl_family_rcv_msg_doit(const struct genl_family *family,\n \t\tfamily->post_doit(ops, skb, &info);\n \n out:\n-\tgenl_family_rcv_msg_attrs_free(family, attrbuf);\n+\tgenl_family_rcv_msg_attrs_free(attrbuf);\n \n \treturn err;\n }\n"
        ]
    },
    "1860a98f3556d97065ad773d095aa1d7eb5fbafa": {
        "non_crash": [
            "diff --git a/net/smc/af_smc.c b/net/smc/af_smc.c\nindex 14ddc40149e8..fc7b6eb22143 100644\n--- a/net/smc/af_smc.c\n+++ b/net/smc/af_smc.c\n@@ -2674,8 +2674,10 @@ static int smc_shutdown(struct socket *sock, int how)\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\tif (sk->sk_shutdown == SHUTDOWN_MASK) {\n \t\t\tsk->sk_state = SMC_CLOSED;\n+\t\t\tsock_put(sk);\n+\t\t}\n \t\tgoto out;\n \t}\n \tswitch (how) {\n"
        ]
    },
    "b929091c762f0a3060a9941dcacfed0c3b4a903d": {
        "non_crash": [
            "diff --git a/net/can/j1939/transport.c b/net/can/j1939/transport.c\nindex fce9b9ebf13f..fb92c3609e17 100644\n--- a/net/can/j1939/transport.c\n+++ b/net/can/j1939/transport.c\n@@ -1124,8 +1124,6 @@ static void __j1939_session_cancel(struct j1939_session *session,\n \n \tif (session->sk)\n \t\tj1939_sk_send_loop_abort(session->sk, session->err);\n-\telse\n-\t\tj1939_sk_errqueue(session, J1939_ERRQUEUE_RX_ABORT);\n }\n \n static void j1939_session_cancel(struct j1939_session *session,\n@@ -1140,6 +1138,9 @@ static void j1939_session_cancel(struct j1939_session *session,\n \t}\n \n \tj1939_session_list_unlock(session->priv);\n+\n+\tif (!session->sk)\n+\t\tj1939_sk_errqueue(session, J1939_ERRQUEUE_RX_ABORT);\n }\n \n static enum hrtimer_restart j1939_tp_txtimer(struct hrtimer *hrtimer)\n@@ -1253,6 +1254,9 @@ static enum hrtimer_restart j1939_tp_rxtimer(struct hrtimer *hrtimer)\n \t\t\t__j1939_session_cancel(session, J1939_XTP_ABORT_TIMEOUT);\n \t\t}\n \t\tj1939_session_list_unlock(session->priv);\n+\n+\t\tif (!session->sk)\n+\t\t\tj1939_sk_errqueue(session, J1939_ERRQUEUE_RX_ABORT);\n \t}\n \n \tj1939_session_put(session);\n"
        ]
    },
    "33e08264ba252fcf3ed89b69fd088ac976363535": {
        "non_crash": [
            "diff --git a/fs/udf/file.c b/fs/udf/file.c\nindex 5c659e23e578..8be51161f3e5 100644\n--- a/fs/udf/file.c\n+++ b/fs/udf/file.c\n@@ -149,26 +149,24 @@ static ssize_t udf_file_write_iter(struct kiocb *iocb, struct iov_iter *from)\n \t\tgoto out;\n \n \tdown_write(&iinfo->i_data_sem);\n-\tif (iinfo->i_alloc_type == ICBTAG_FLAG_AD_IN_ICB) {\n-\t\tloff_t end = iocb->ki_pos + iov_iter_count(from);\n-\n-\t\tif (inode->i_sb->s_blocksize <\n-\t\t\t\t(udf_file_entry_alloc_offset(inode) + end)) {\n-\t\t\terr = udf_expand_file_adinicb(inode);\n-\t\t\tif (err) {\n-\t\t\t\tinode_unlock(inode);\n-\t\t\t\tudf_debug(\"udf_expand_adinicb: err=%d\\n\", err);\n-\t\t\t\treturn err;\n-\t\t\t}\n-\t\t} else {\n-\t\t\tiinfo->i_lenAlloc = max(end, inode->i_size);\n-\t\t\tup_write(&iinfo->i_data_sem);\n+\tif (iinfo->i_alloc_type == ICBTAG_FLAG_AD_IN_ICB &&\n+\t    inode->i_sb->s_blocksize < (udf_file_entry_alloc_offset(inode) +\n+\t\t\t\t iocb->ki_pos + iov_iter_count(from))) {\n+\t\terr = udf_expand_file_adinicb(inode);\n+\t\tif (err) {\n+\t\t\tinode_unlock(inode);\n+\t\t\tudf_debug(\"udf_expand_adinicb: err=%d\\n\", err);\n+\t\t\treturn err;\n \t\t}\n \t} else\n \t\tup_write(&iinfo->i_data_sem);\n \n \tretval = __generic_file_write_iter(iocb, from);\n out:\n+\tdown_write(&iinfo->i_data_sem);\n+\tif (iinfo->i_alloc_type == ICBTAG_FLAG_AD_IN_ICB && retval > 0)\n+\t\tiinfo->i_lenAlloc = inode->i_size;\n+\tup_write(&iinfo->i_data_sem);\n \tinode_unlock(inode);\n \n \tif (retval > 0) {\n"
        ]
    },
    "5091eca677b6821339a9491de5b4151c5be85ae7": {
        "non_crash": [
            "diff --git a/drivers/net/usb/usbnet.c b/drivers/net/usb/usbnet.c\nindex aaa89b4cfd50..e368b0780753 100644\n--- a/drivers/net/usb/usbnet.c\n+++ b/drivers/net/usb/usbnet.c\n@@ -1598,6 +1598,7 @@ void usbnet_disconnect (struct usb_interface *intf)\n \tstruct usbnet\t\t*dev;\n \tstruct usb_device\t*xdev;\n \tstruct net_device\t*net;\n+\tstruct urb\t\t*urb;\n \n \tdev = usb_get_intfdata(intf);\n \tusb_set_intfdata(intf, NULL);\n@@ -1614,7 +1615,11 @@ void usbnet_disconnect (struct usb_interface *intf)\n \tnet = dev->net;\n \tunregister_netdev (net);\n \n-\tusb_scuttle_anchored_urbs(&dev->deferred);\n+\twhile ((urb = usb_get_from_anchor(&dev->deferred))) {\n+\t\tdev_kfree_skb(urb->context);\n+\t\tkfree(urb->sg);\n+\t\tusb_free_urb(urb);\n+\t}\n \n \tif (dev->driver_info->unbind)\n \t\tdev->driver_info->unbind(dev, intf);\n"
        ]
    },
    "b139c306850a825c7656508c3773dbea33eb56a1": {
        "non_crash": [
            "diff --git a/fs/xfs/xfs_dquot.c b/fs/xfs/xfs_dquot.c\nindex 8fb90da89787..7f071757f278 100644\n--- a/fs/xfs/xfs_dquot.c\n+++ b/fs/xfs/xfs_dquot.c\n@@ -798,7 +798,6 @@ 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\tmutex_unlock(&qi->qi_tree_lock);\n \t\ttrace_xfs_dqget_dup(dqp);\n \t\treturn error;\n"
        ]
    },
    "59174b68c3c9d5d3ecc323e0b0a0c5466b0e7d18": {
        "non_crash": [
            "diff --git a/fs/nilfs2/ioctl.c b/fs/nilfs2/ioctl.c\nindex 87e1004b606d..b4041d0566a9 100644\n--- a/fs/nilfs2/ioctl.c\n+++ b/fs/nilfs2/ioctl.c\n@@ -1114,7 +1114,14 @@ static int nilfs_ioctl_set_alloc_range(struct inode *inode, void __user *argp)\n \n \tminseg = range[0] + segbytes - 1;\n \tdo_div(minseg, segbytes);\n+\n+\tif (range[1] < 4096)\n+\t\tgoto out;\n+\n \tmaxseg = NILFS_SB2_OFFSET_BYTES(range[1]);\n+\tif (maxseg < segbytes)\n+\t\tgoto out;\n+\n \tdo_div(maxseg, segbytes);\n \tmaxseg--;\n \ndiff --git a/fs/nilfs2/super.c b/fs/nilfs2/super.c\nindex 6edb6e0dd61f..1422b8ba24ed 100644\n--- a/fs/nilfs2/super.c\n+++ b/fs/nilfs2/super.c\n@@ -408,6 +408,15 @@ int nilfs_resize_fs(struct super_block *sb, __u64 newsize)\n \tif (newsize > devsize)\n \t\tgoto out;\n \n+\t/*\n+\t * Prevent underflow in second superblock position calculation.\n+\t * The exact minimum size check is done in nilfs_sufile_resize().\n+\t */\n+\tif (newsize < 4096) {\n+\t\tret = -ENOSPC;\n+\t\tgoto out;\n+\t}\n+\n \t/*\n \t * Write lock is required to protect some functions depending\n \t * on the number of segments, the number of reserved segments,\ndiff --git a/fs/nilfs2/the_nilfs.c b/fs/nilfs2/the_nilfs.c\nindex 2064e6473d30..3a4c9c150cbf 100644\n--- a/fs/nilfs2/the_nilfs.c\n+++ b/fs/nilfs2/the_nilfs.c\n@@ -544,9 +544,15 @@ static int nilfs_load_super_block(struct the_nilfs *nilfs,\n {\n \tstruct nilfs_super_block **sbp = nilfs->ns_sbp;\n \tstruct buffer_head **sbh = nilfs->ns_sbh;\n-\tu64 sb2off = NILFS_SB2_OFFSET_BYTES(bdev_nr_bytes(nilfs->ns_bdev));\n+\tu64 sb2off, devsize = bdev_nr_bytes(nilfs->ns_bdev);\n \tint valid[2], swp = 0;\n \n+\tif (devsize < NILFS_SEG_MIN_BLOCKS * NILFS_MIN_BLOCK_SIZE + 4096) {\n+\t\tnilfs_err(sb, \"device size too small\");\n+\t\treturn -EINVAL;\n+\t}\n+\tsb2off = NILFS_SB2_OFFSET_BYTES(devsize);\n+\n \tsbp[0] = nilfs_read_super_block(sb, NILFS_SB_OFFSET_BYTES, blocksize,\n \t\t\t\t\t&sbh[0]);\n \tsbp[1] = nilfs_read_super_block(sb, sb2off, blocksize, &sbh[1]);\n"
        ]
    },
    "6513f6cb5cd6b5fc9f37e3bb70d273b94be9c34c": {
        "non_crash": [
            "diff --git a/fs/ext4/super.c b/fs/ext4/super.c\nindex 425b95a7a0ab..c7bc4a2709cc 100644\n--- a/fs/ext4/super.c\n+++ b/fs/ext4/super.c\n@@ -6387,6 +6387,7 @@ static int __ext4_remount(struct fs_context *fc, struct super_block *sb)\n \tstruct ext4_mount_options old_opts;\n \text4_group_t g;\n \tint err = 0;\n+\tint enable_rw = 0;\n #ifdef CONFIG_QUOTA\n \tint enable_quota = 0;\n \tint i, j;\n@@ -6573,7 +6574,7 @@ static int __ext4_remount(struct fs_context *fc, struct super_block *sb)\n \t\t\tif (err)\n \t\t\t\tgoto restore_opts;\n \n-\t\t\tsb->s_flags &= ~SB_RDONLY;\n+\t\t\tenable_rw = 1;\n \t\t\tif (ext4_has_feature_mmp(sb)) {\n \t\t\t\terr = ext4_multi_mount_protect(sb,\n \t\t\t\t\t\tle64_to_cpu(es->s_mmp_block));\n@@ -6632,6 +6633,9 @@ static int __ext4_remount(struct fs_context *fc, struct super_block *sb)\n \tif (!test_opt(sb, BLOCK_VALIDITY) && sbi->s_system_blks)\n \t\text4_release_system_zone(sb);\n \n+\tif (enable_rw)\n+\t\tsb->s_flags &= ~SB_RDONLY;\n+\n \tif (!ext4_has_feature_mmp(sb) || sb_rdonly(sb))\n \t\text4_stop_mmpd(sbi);\n \n"
        ]
    },
    "7a56fd91f3db3a79c974b34e1aac3879898d6f29": {
        "non_crash": [
            "diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c\nindex 7647ecfa0d40..88325b264737 100644\n--- a/net/netfilter/nf_tables_api.c\n+++ b/net/netfilter/nf_tables_api.c\n@@ -188,24 +188,6 @@ static void nft_netdev_unregister_hooks(struct net *net,\n \t\tnf_unregister_net_hook(net, &hook->ops);\n }\n \n-static int nft_register_basechain_hooks(struct net *net, int family,\n-\t\t\t\t\tstruct nft_base_chain *basechain)\n-{\n-\tif (family == NFPROTO_NETDEV)\n-\t\treturn nft_netdev_register_hooks(net, &basechain->hook_list);\n-\n-\treturn nf_register_net_hook(net, &basechain->ops);\n-}\n-\n-static void nft_unregister_basechain_hooks(struct net *net, int family,\n-\t\t\t\t\t   struct nft_base_chain *basechain)\n-{\n-\tif (family == NFPROTO_NETDEV)\n-\t\tnft_netdev_unregister_hooks(net, &basechain->hook_list);\n-\telse\n-\t\tnf_unregister_net_hook(net, &basechain->ops);\n-}\n-\n static int nf_tables_register_hook(struct net *net,\n \t\t\t\t   const struct nft_table *table,\n \t\t\t\t   struct nft_chain *chain)\n@@ -223,7 +205,10 @@ static int nf_tables_register_hook(struct net *net,\n \tif (basechain->type->ops_register)\n \t\treturn basechain->type->ops_register(net, ops);\n \n-\treturn nft_register_basechain_hooks(net, table->family, basechain);\n+\tif (table->family == NFPROTO_NETDEV)\n+\t\treturn nft_netdev_register_hooks(net, &basechain->hook_list);\n+\n+\treturn nf_register_net_hook(net, &basechain->ops);\n }\n \n static void nf_tables_unregister_hook(struct net *net,\n@@ -242,7 +227,10 @@ static void nf_tables_unregister_hook(struct net *net,\n \tif (basechain->type->ops_unregister)\n \t\treturn basechain->type->ops_unregister(net, ops);\n \n-\tnft_unregister_basechain_hooks(net, table->family, basechain);\n+\tif (table->family == NFPROTO_NETDEV)\n+\t\tnft_netdev_unregister_hooks(net, &basechain->hook_list);\n+\telse\n+\t\tnf_unregister_net_hook(net, &basechain->ops);\n }\n \n static int nft_trans_table_add(struct nft_ctx *ctx, int msg_type)\n@@ -832,8 +820,7 @@ static void nft_table_disable(struct net *net, struct nft_table *table, u32 cnt)\n \t\tif (cnt && i++ == cnt)\n \t\t\tbreak;\n \n-\t\tnft_unregister_basechain_hooks(net, table->family,\n-\t\t\t\t\t       nft_base_chain(chain));\n+\t\tnf_tables_unregister_hook(net, table, chain);\n \t}\n }\n \n@@ -848,8 +835,7 @@ static int nf_tables_table_enable(struct net *net, struct nft_table *table)\n \t\tif (!nft_is_base_chain(chain))\n \t\t\tcontinue;\n \n-\t\terr = nft_register_basechain_hooks(net, table->family,\n-\t\t\t\t\t\t   nft_base_chain(chain));\n+\t\terr = nf_tables_register_hook(net, table, chain);\n \t\tif (err < 0)\n \t\t\tgoto err_register_hooks;\n \n@@ -894,11 +880,12 @@ static int nf_tables_updtable(struct nft_ctx *ctx)\n \t\tnft_trans_table_enable(trans) = false;\n \t} else if (!(flags & NFT_TABLE_F_DORMANT) &&\n \t\t   ctx->table->flags & NFT_TABLE_F_DORMANT) {\n+\t\tctx->table->flags &= ~NFT_TABLE_F_DORMANT;\n \t\tret = nf_tables_table_enable(ctx->net, ctx->table);\n-\t\tif (ret >= 0) {\n-\t\t\tctx->table->flags &= ~NFT_TABLE_F_DORMANT;\n+\t\tif (ret >= 0)\n \t\t\tnft_trans_table_enable(trans) = true;\n-\t\t}\n+\t\telse\n+\t\t\tctx->table->flags |= NFT_TABLE_F_DORMANT;\n \t}\n \tif (ret < 0)\n \t\tgoto err;\n"
        ]
    },
    "384b9a05e5d4c3e74e31427e43a08f40f71db54a": {
        "non_crash": [
            "diff --git a/fs/super.c b/fs/super.c\nindex 779247eb219c..ad7ac3a24d38 100644\n--- a/fs/super.c\n+++ b/fs/super.c\n@@ -434,6 +434,33 @@ void put_super(struct super_block *sb)\n \tspin_unlock(&sb_lock);\n }\n \n+static void kill_super_notify(struct super_block *sb)\n+{\n+\tlockdep_assert_not_held(&sb->s_umount);\n+\n+\t/* already notified earlier */\n+\tif (sb->s_flags & SB_DEAD)\n+\t\treturn;\n+\n+\t/*\n+\t * Remove it from @fs_supers so it isn't found by new\n+\t * sget{_fc}() walkers anymore. Any concurrent mounter still\n+\t * managing to grab a temporary reference is guaranteed to\n+\t * already see SB_DYING and will wait until we notify them about\n+\t * SB_DEAD.\n+\t */\n+\tspin_lock(&sb_lock);\n+\thlist_del_init(&sb->s_instances);\n+\tspin_unlock(&sb_lock);\n+\n+\t/*\n+\t * Let concurrent mounts know that this thing is really dead.\n+\t * We don't need @sb->s_umount here as every concurrent caller\n+\t * will see SB_DYING and either discard the superblock or wait\n+\t * for SB_DEAD.\n+\t */\n+\tsuper_wake(sb, SB_DEAD);\n+}\n \n /**\n  *\tdeactivate_locked_super\t-\tdrop an active reference to superblock\n@@ -453,6 +480,8 @@ void deactivate_locked_super(struct super_block *s)\n \t\tunregister_shrinker(&s->s_shrink);\n \t\tfs->kill_sb(s);\n \n+\t\tkill_super_notify(s);\n+\n \t\t/*\n \t\t * Since list_lru_destroy() may sleep, we cannot call it from\n \t\t * put_super(), where we hold the sb_lock. Therefore we destroy\n@@ -461,25 +490,6 @@ void deactivate_locked_super(struct super_block *s)\n \t\tlist_lru_destroy(&s->s_dentry_lru);\n \t\tlist_lru_destroy(&s->s_inode_lru);\n \n-\t\t/*\n-\t\t * Remove it from @fs_supers so it isn't found by new\n-\t\t * sget{_fc}() walkers anymore. Any concurrent mounter still\n-\t\t * managing to grab a temporary reference is guaranteed to\n-\t\t * already see SB_DYING and will wait until we notify them about\n-\t\t * SB_DEAD.\n-\t\t */\n-\t\tspin_lock(&sb_lock);\n-\t\thlist_del_init(&s->s_instances);\n-\t\tspin_unlock(&sb_lock);\n-\n-\t\t/*\n-\t\t * Let concurrent mounts know that this thing is really dead.\n-\t\t * We don't need @sb->s_umount here as every concurrent caller\n-\t\t * will see SB_DYING and either discard the superblock or wait\n-\t\t * for SB_DEAD.\n-\t\t */\n-\t\tsuper_wake(s, SB_DEAD);\n-\n \t\tput_filesystem(fs);\n \t\tput_super(s);\n \t} else {\n@@ -1260,6 +1270,7 @@ void kill_anon_super(struct super_block *sb)\n {\n \tdev_t dev = sb->s_dev;\n \tgeneric_shutdown_super(sb);\n+\tkill_super_notify(sb);\n \tfree_anon_bdev(dev);\n }\n EXPORT_SYMBOL(kill_anon_super);\n"
        ]
    },
    "ffb9228cab75ad9d812af93d19e9637873d18439": {
        "non_crash": [
            "diff --git a/net/ipv4/ip_gre.c b/net/ipv4/ip_gre.c\nindex 7e474a85deaf..3b9cd487075a 100644\n--- a/net/ipv4/ip_gre.c\n+++ b/net/ipv4/ip_gre.c\n@@ -629,21 +629,20 @@ static netdev_tx_t ipgre_xmit(struct sk_buff *skb,\n \t}\n \n \tif (dev->header_ops) {\n-\t\tconst int pull_len = tunnel->hlen + sizeof(struct iphdr);\n-\n \t\tif (skb_cow_head(skb, 0))\n \t\t\tgoto free_skb;\n \n \t\ttnl_params = (const struct iphdr *)skb->data;\n \n-\t\tif (pull_len > skb_transport_offset(skb))\n-\t\t\tgoto free_skb;\n-\n \t\t/* Pull skb since ip_tunnel_xmit() needs skb->data pointing\n \t\t * to gre header.\n \t\t */\n-\t\tskb_pull(skb, pull_len);\n+\t\tskb_pull(skb, tunnel->hlen + sizeof(struct iphdr));\n \t\tskb_reset_mac_header(skb);\n+\n+\t\tif (skb->ip_summed == CHECKSUM_PARTIAL &&\n+\t\t    skb_checksum_start(skb) < skb->data)\n+\t\t\tgoto free_skb;\n \t} else {\n \t\tif (skb_cow_head(skb, dev->needed_headroom))\n \t\t\tgoto free_skb;\n"
        ]
    },
    "6e96f5bd56bfecdaa0bfeaf2695a25cc80bfbd9a": {
        "non_crash": [
            "diff --git a/net/netfilter/ipset/ip_set_hash_gen.h b/net/netfilter/ipset/ip_set_hash_gen.h\nindex 71e93eac0831..e52d7b7597a0 100644\n--- a/net/netfilter/ipset/ip_set_hash_gen.h\n+++ b/net/netfilter/ipset/ip_set_hash_gen.h\n@@ -931,6 +931,8 @@ mtype_add(struct ip_set *set, void *value, const struct ip_set_ext *ext,\n \t\t}\n \t}\n \tif (reuse || forceadd) {\n+\t\tif (j == -1)\n+\t\t\tj = 0;\n \t\tdata = ahash_data(n, j, set->dsize);\n \t\tif (!deleted) {\n #ifdef IP_SET_HASH_WITH_NETS\n"
        ]
    },
    "724cf869d3bb512081588651530d8071a4b61ceb": {
        "non_crash": [
            "diff --git a/fs/btrfs/qgroup.c b/fs/btrfs/qgroup.c\nindex 00851c86aa8a..af97413abcf4 100644\n--- a/fs/btrfs/qgroup.c\n+++ b/fs/btrfs/qgroup.c\n@@ -3367,6 +3367,7 @@ static void btrfs_qgroup_rescan_worker(struct btrfs_work *work)\n \tint err = -ENOMEM;\n \tint ret = 0;\n \tbool stopped = false;\n+\tbool did_leaf_rescans = false;\n \n \tpath = btrfs_alloc_path();\n \tif (!path)\n@@ -3387,6 +3388,7 @@ static void btrfs_qgroup_rescan_worker(struct btrfs_work *work)\n \t\t}\n \n \t\terr = qgroup_rescan_leaf(trans, path);\n+\t\tdid_leaf_rescans = true;\n \n \t\tif (err > 0)\n \t\t\tbtrfs_commit_transaction(trans);\n@@ -3407,16 +3409,23 @@ static void btrfs_qgroup_rescan_worker(struct btrfs_work *work)\n \tmutex_unlock(&fs_info->qgroup_rescan_lock);\n \n \t/*\n-\t * only update status, since the previous part has already updated the\n-\t * qgroup info.\n+\t * Only update status, since the previous part has already updated the\n+\t * qgroup info, and only if we did any actual work. This also prevents\n+\t * race with a concurrent quota disable, which has already set\n+\t * fs_info->quota_root to NULL and cleared BTRFS_FS_QUOTA_ENABLED at\n+\t * btrfs_quota_disable().\n \t */\n-\ttrans = btrfs_start_transaction(fs_info->quota_root, 1);\n-\tif (IS_ERR(trans)) {\n-\t\terr = PTR_ERR(trans);\n+\tif (did_leaf_rescans) {\n+\t\ttrans = btrfs_start_transaction(fs_info->quota_root, 1);\n+\t\tif (IS_ERR(trans)) {\n+\t\t\terr = PTR_ERR(trans);\n+\t\t\ttrans = NULL;\n+\t\t\tbtrfs_err(fs_info,\n+\t\t\t\t  \"fail to start transaction for status update: %d\",\n+\t\t\t\t  err);\n+\t\t}\n+\t} else {\n \t\ttrans = NULL;\n-\t\tbtrfs_err(fs_info,\n-\t\t\t  \"fail to start transaction for status update: %d\",\n-\t\t\t  err);\n \t}\n \n \tmutex_lock(&fs_info->qgroup_rescan_lock);\n"
        ]
    },
    "cfaa72b0f8cf807081aad90d4fe7c2442f0bf12b": {
        "non_crash": [
            "diff --git a/net/vmw_vsock/vsock_loopback.c b/net/vmw_vsock/vsock_loopback.c\nindex 671e03240fc5..89905c092645 100644\n--- a/net/vmw_vsock/vsock_loopback.c\n+++ b/net/vmw_vsock/vsock_loopback.c\n@@ -15,7 +15,6 @@\n struct vsock_loopback {\n \tstruct workqueue_struct *workqueue;\n \n-\tspinlock_t pkt_list_lock; /* protects pkt_list */\n \tstruct sk_buff_head pkt_queue;\n \tstruct work_struct pkt_work;\n };\n@@ -32,9 +31,7 @@ static int vsock_loopback_send_pkt(struct sk_buff *skb)\n \tstruct vsock_loopback *vsock = &the_vsock_loopback;\n \tint len = skb->len;\n \n-\tspin_lock_bh(&vsock->pkt_list_lock);\n \tskb_queue_tail(&vsock->pkt_queue, skb);\n-\tspin_unlock_bh(&vsock->pkt_list_lock);\n \n \tqueue_work(vsock->workqueue, &vsock->pkt_work);\n \n@@ -113,9 +110,9 @@ static void vsock_loopback_work(struct work_struct *work)\n \n \tskb_queue_head_init(&pkts);\n \n-\tspin_lock_bh(&vsock->pkt_list_lock);\n+\tspin_lock_bh(&vsock->pkt_queue.lock);\n \tskb_queue_splice_init(&vsock->pkt_queue, &pkts);\n-\tspin_unlock_bh(&vsock->pkt_list_lock);\n+\tspin_unlock_bh(&vsock->pkt_queue.lock);\n \n \twhile ((skb = __skb_dequeue(&pkts))) {\n \t\tvirtio_transport_deliver_tap_pkt(skb);\n@@ -132,7 +129,6 @@ static int __init vsock_loopback_init(void)\n \tif (!vsock->workqueue)\n \t\treturn -ENOMEM;\n \n-\tspin_lock_init(&vsock->pkt_list_lock);\n \tskb_queue_head_init(&vsock->pkt_queue);\n \tINIT_WORK(&vsock->pkt_work, vsock_loopback_work);\n \n@@ -156,9 +152,7 @@ static void __exit vsock_loopback_exit(void)\n \n \tflush_work(&vsock->pkt_work);\n \n-\tspin_lock_bh(&vsock->pkt_list_lock);\n \tvirtio_vsock_skb_queue_purge(&vsock->pkt_queue);\n-\tspin_unlock_bh(&vsock->pkt_list_lock);\n \n \tdestroy_workqueue(vsock->workqueue);\n }\n"
        ]
    },
    "f9cfa5c5564ffc453258d835293bf6e9881c5b1c": {
        "non_crash": [
            "diff --git a/net/sctp/stream.c b/net/sctp/stream.c\nindex 2936ed17bf9e..3b47457862cc 100644\n--- a/net/sctp/stream.c\n+++ b/net/sctp/stream.c\n@@ -230,8 +230,6 @@ int sctp_stream_init(struct sctp_stream *stream, __u16 outcnt, __u16 incnt,\n \tfor (i = 0; i < stream->outcnt; i++)\n \t\tSCTP_SO(stream, i)->state = SCTP_STREAM_OPEN;\n \n-\tsched->init(stream);\n-\n in:\n \tsctp_stream_interleave_init(stream);\n \tif (!incnt)\n"
        ]
    },
    "1a351beaed9d438481f1fc96aa336a25f71a2ae1": {
        "non_crash": [
            "diff --git a/fs/userfaultfd.c b/fs/userfaultfd.c\nindex 07c81ab3fd4d..98ac37e34e3d 100644\n--- a/fs/userfaultfd.c\n+++ b/fs/userfaultfd.c\n@@ -1630,17 +1630,20 @@ static int userfaultfd_unregister(struct userfaultfd_ctx *ctx,\n \t\t\t\t NULL_VM_UFFD_CTX, anon_vma_name(vma));\n \t\tif (prev) {\n \t\t\tvma = prev;\n+\t\t\tmas_pause(&mas);\n \t\t\tgoto next;\n \t\t}\n \t\tif (vma->vm_start < start) {\n \t\t\tret = split_vma(mm, vma, start, 1);\n \t\t\tif (ret)\n \t\t\t\tbreak;\n+\t\t\tmas_pause(&mas);\n \t\t}\n \t\tif (vma->vm_end > end) {\n \t\t\tret = split_vma(mm, vma, end, 0);\n \t\t\tif (ret)\n \t\t\t\tbreak;\n+\t\t\tmas_pause(&mas);\n \t\t}\n \tnext:\n \t\t/*\n"
        ]
    },
    "e1306831b0c04a2ee7705d93be9747c870cadfd5": {
        "non_crash": [
            "diff --git a/fs/namespace.c b/fs/namespace.c\nindex a0a36bfa3aa0..afe2b64b14f1 100644\n--- a/fs/namespace.c\n+++ b/fs/namespace.c\n@@ -4058,10 +4058,22 @@ static int mount_setattr_prepare(struct mount_kattr *kattr, struct mount *mnt)\n \tif (err) {\n \t\tstruct mount *p;\n \n-\t\tfor (p = mnt; p != m; p = next_mnt(p, mnt)) {\n+\t\t/*\n+\t\t * If we had to call mnt_hold_writers() MNT_WRITE_HOLD will\n+\t\t * be set in @mnt_flags. The loop unsets MNT_WRITE_HOLD for all\n+\t\t * mounts and needs to take care to include the first mount.\n+\t\t */\n+\t\tfor (p = mnt; p; p = next_mnt(p, mnt)) {\n \t\t\t/* If we had to hold writers unblock them. */\n \t\t\tif (p->mnt.mnt_flags & MNT_WRITE_HOLD)\n \t\t\t\tmnt_unhold_writers(p);\n+\n+\t\t\t/*\n+\t\t\t * We're done once the first mount we changed got\n+\t\t\t * MNT_WRITE_HOLD unset.\n+\t\t\t */\n+\t\t\tif (p == m)\n+\t\t\t\tbreak;\n \t\t}\n \t}\n \treturn err;\n"
        ]
    },
    "544afab64e441605326c54f7c2d4aa9bab2419ff": {
        "non_crash": [
            "diff --git a/net/netrom/af_netrom.c b/net/netrom/af_netrom.c\nindex 6f7f4392cffb..5a4cb796150f 100644\n--- a/net/netrom/af_netrom.c\n+++ b/net/netrom/af_netrom.c\n@@ -400,6 +400,11 @@ static int nr_listen(struct socket *sock, int backlog)\n \tstruct sock *sk = sock->sk;\n \n \tlock_sock(sk);\n+\tif (sock->state != SS_UNCONNECTED) {\n+\t\trelease_sock(sk);\n+\t\treturn -EINVAL;\n+\t}\n+\n \tif (sk->sk_state != TCP_LISTEN) {\n \t\tmemset(&nr_sk(sk)->user_addr, 0, AX25_ADDR_LEN);\n \t\tsk->sk_max_ack_backlog = backlog;\n"
        ]
    }
}