{
    "f0ec9a394925aafbdf13d0a7e6af4cff860f0ed6": {
        "non_crash": [
            "diff --git a/net/bluetooth/hci_sysfs.c b/net/bluetooth/hci_sysfs.c\nindex 9874844a95a9..9cda2c1d8aa2 100644\n--- a/net/bluetooth/hci_sysfs.c\n+++ b/net/bluetooth/hci_sysfs.c\n@@ -50,6 +50,11 @@ void hci_conn_add_sysfs(struct hci_conn *conn)\n \n \tdev_set_name(&conn->dev, \"%s:%d\", hdev->name, conn->handle);\n \n+\tif (device_is_registered(&conn->dev)) {\n+\t\tbt_dev_err(hdev, \"connection device already registered\");\n+\t\treturn;\n+\t}\n+\n \tif (device_add(&conn->dev) < 0) {\n \t\tbt_dev_err(hdev, \"failed to register connection device\");\n \t\treturn;\n",
            "diff --git a/net/bluetooth/hci_sysfs.c b/net/bluetooth/hci_sysfs.c\nindex 9874844a95a9..e8baadff91eb 100644\n--- a/net/bluetooth/hci_sysfs.c\n+++ b/net/bluetooth/hci_sysfs.c\n@@ -44,18 +44,23 @@ void hci_conn_init_sysfs(struct hci_conn *conn)\n \n void hci_conn_add_sysfs(struct hci_conn *conn)\n {\n-\tstruct hci_dev *hdev = conn->hdev;\n+    struct hci_dev *hdev = conn->hdev;\n \n-\tBT_DBG(\"conn %p\", conn);\n+    BT_DBG(\"conn %p\", conn);\n \n-\tdev_set_name(&conn->dev, \"%s:%d\", hdev->name, conn->handle);\n+    dev_set_name(&conn->dev, \"%s:%d\", hdev->name, conn->handle);\n \n-\tif (device_add(&conn->dev) < 0) {\n-\t\tbt_dev_err(hdev, \"failed to register connection device\");\n-\t\treturn;\n-\t}\n+    if (device_is_registered(&conn->dev)) {\n+        bt_dev_err(hdev, \"connection device already registered\");\n+        return;\n+    }\n+\n+    if (device_add(&conn->dev) < 0) {\n+        bt_dev_err(hdev, \"failed to register connection device\");\n+        return;\n+    }\n \n-\thci_dev_hold(hdev);\n+    hci_dev_hold(hdev);\n }\n \n void hci_conn_del_sysfs(struct hci_conn *conn)\n",
            "diff --git a/net/bluetooth/hci_sysfs.c b/net/bluetooth/hci_sysfs.c\nindex 9874844a95a9..ba4b965580fa 100644\n--- a/net/bluetooth/hci_sysfs.c\n+++ b/net/bluetooth/hci_sysfs.c\n@@ -44,18 +44,23 @@ void hci_conn_init_sysfs(struct hci_conn *conn)\n \n void hci_conn_add_sysfs(struct hci_conn *conn)\n {\n-\tstruct hci_dev *hdev = conn->hdev;\n+    struct hci_dev *hdev = conn->hdev;\n \n-\tBT_DBG(\"conn %p\", conn);\n+    BT_DBG(\"conn %p\", conn);\n \n-\tdev_set_name(&conn->dev, \"%s:%d\", hdev->name, conn->handle);\n+    dev_set_name(&conn->dev, \"%s:%d\", hdev->name, conn->handle);\n \n-\tif (device_add(&conn->dev) < 0) {\n-\t\tbt_dev_err(hdev, \"failed to register connection device\");\n-\t\treturn;\n-\t}\n+    if (conn->dev.kobj.state_in_sysfs) {\n+        bt_dev_err(hdev, \"connection device already registered\");\n+        return;\n+    }\n+\n+    if (device_add(&conn->dev) < 0) {\n+        bt_dev_err(hdev, \"failed to register connection device\");\n+        return;\n+    }\n \n-\thci_dev_hold(hdev);\n+    hci_dev_hold(hdev);\n }\n \n void hci_conn_del_sysfs(struct hci_conn *conn)\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/lib/kobject.c b/lib/kobject.c\nindex 1e4b7382a88e..813e26c934a0 100644\n--- a/lib/kobject.c\n+++ b/lib/kobject.c\n@@ -188,13 +188,18 @@ EXPORT_SYMBOL_GPL(kobject_get_path);\n /* add the kobject to its kset's list */\n static void kobj_kset_join(struct kobject *kobj)\n {\n-\tif (!kobj->kset)\n-\t\treturn;\n+    if (!kobj->kset)\n+        return;\n \n-\tkset_get(kobj->kset);\n-\tspin_lock(&kobj->kset->list_lock);\n-\tlist_add_tail(&kobj->entry, &kobj->kset->list);\n-\tspin_unlock(&kobj->kset->list_lock);\n+    kset_get(kobj->kset);\n+    spin_lock(&kobj->kset->list_lock);\n+\n+    // Check if the kobject is already in the list to prevent double addition\n+    if (list_empty(&kobj->entry)) {\n+        list_add_tail(&kobj->entry, &kobj->kset->list);\n+    }\n+\n+    spin_unlock(&kobj->kset->list_lock);\n }\n \n /* remove the kobject from its kset's list */\n",
            "diff --git a/net/bluetooth/hci_sysfs.c b/net/bluetooth/hci_sysfs.c\nindex 9874844a95a9..e8baadff91eb 100644\n--- a/net/bluetooth/hci_sysfs.c\n+++ b/net/bluetooth/hci_sysfs.c\n@@ -44,18 +44,23 @@ void hci_conn_init_sysfs(struct hci_conn *conn)\n \n void hci_conn_add_sysfs(struct hci_conn *conn)\n {\n-\tstruct hci_dev *hdev = conn->hdev;\n+    struct hci_dev *hdev = conn->hdev;\n \n-\tBT_DBG(\"conn %p\", conn);\n+    BT_DBG(\"conn %p\", conn);\n \n-\tdev_set_name(&conn->dev, \"%s:%d\", hdev->name, conn->handle);\n+    dev_set_name(&conn->dev, \"%s:%d\", hdev->name, conn->handle);\n \n-\tif (device_add(&conn->dev) < 0) {\n-\t\tbt_dev_err(hdev, \"failed to register connection device\");\n-\t\treturn;\n-\t}\n+    if (device_is_registered(&conn->dev)) {\n+        bt_dev_err(hdev, \"connection device already registered\");\n+        return;\n+    }\n+\n+    if (device_add(&conn->dev) < 0) {\n+        bt_dev_err(hdev, \"failed to register connection device\");\n+        return;\n+    }\n \n-\thci_dev_hold(hdev);\n+    hci_dev_hold(hdev);\n }\n \n void hci_conn_del_sysfs(struct hci_conn *conn)\n"
        ],
        "error": []
    },
    "ee9018bd8989530a2dbdd62436efd8b1c3ecd3e5": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/bluetooth/rfcomm/core.c b/net/bluetooth/rfcomm/core.c\nindex 8d6fce9005bd..eb1cd1d3d596 100644\n--- a/net/bluetooth/rfcomm/core.c\n+++ b/net/bluetooth/rfcomm/core.c\n@@ -446,54 +446,54 @@ static void __rfcomm_dlc_disconn(struct rfcomm_dlc *d)\n \n static int __rfcomm_dlc_close(struct rfcomm_dlc *d, int err)\n {\n-\tstruct rfcomm_session *s = d->session;\n-\tif (!s)\n-\t\treturn 0;\n-\n-\tBT_DBG(\"dlc %p state %ld dlci %d err %d session %p\",\n-\t\t\td, d->state, d->dlci, err, s);\n-\n-\tswitch (d->state) {\n-\tcase BT_CONNECT:\n-\tcase BT_CONFIG:\n-\tcase BT_OPEN:\n-\tcase BT_CONNECT2:\n-\t\tif (test_and_clear_bit(RFCOMM_DEFER_SETUP, &d->flags)) {\n-\t\t\tset_bit(RFCOMM_AUTH_REJECT, &d->flags);\n-\t\t\trfcomm_schedule();\n-\t\t\treturn 0;\n-\t\t}\n-\t}\n-\n-\tswitch (d->state) {\n-\tcase BT_CONNECT:\n-\tcase BT_CONNECTED:\n-\t\t__rfcomm_dlc_disconn(d);\n-\t\tbreak;\n-\n-\tcase BT_CONFIG:\n-\t\tif (s->state != BT_BOUND) {\n-\t\t\t__rfcomm_dlc_disconn(d);\n-\t\t\tbreak;\n-\t\t}\n-\t\t/* if closing a dlc in a session that hasn't been started,\n-\t\t * just close and unlink the dlc\n-\t\t */\n-\t\tfallthrough;\n-\n-\tdefault:\n-\t\trfcomm_dlc_clear_timer(d);\n-\n-\t\trfcomm_dlc_lock(d);\n-\t\td->state = BT_CLOSED;\n-\t\td->state_change(d, err);\n-\t\trfcomm_dlc_unlock(d);\n-\n-\t\tskb_queue_purge(&d->tx_queue);\n-\t\trfcomm_dlc_unlink(d);\n-\t}\n-\n-\treturn 0;\n+    struct rfcomm_session *s = d->session;\n+    if (!s)\n+        return 0;\n+\n+    BT_DBG(\"dlc %p state %ld dlci %d err %d session %p\",\n+            d, d->state, d->dlci, err, s);\n+\n+    switch (d->state) {\n+    case BT_CONNECT:\n+    case BT_CONFIG:\n+    case BT_OPEN:\n+    case BT_CONNECT2:\n+        if (test_and_clear_bit(RFCOMM_DEFER_SETUP, &d->flags)) {\n+            set_bit(RFCOMM_AUTH_REJECT, &d->flags);\n+            rfcomm_schedule();\n+            return 0;\n+        }\n+    }\n+\n+    switch (d->state) {\n+    case BT_CONNECT:\n+    case BT_CONNECTED:\n+        __rfcomm_dlc_disconn(d);\n+        break;\n+\n+    case BT_CONFIG:\n+        if (s->state != BT_BOUND) {\n+            __rfcomm_dlc_disconn(d);\n+            break;\n+        }\n+        /* if closing a dlc in a session that hasn't been started,\n+         * just close and unlink the dlc\n+         */\n+        fallthrough;\n+\n+    default:\n+        rfcomm_dlc_clear_timer(d);\n+\n+        d->state = BT_CLOSED;\n+        rfcomm_dlc_unlock(d); // Release the lock before calling state_change\n+        d->state_change(d, err);\n+        rfcomm_dlc_lock(d); // Reacquire the lock after state_change\n+\n+        skb_queue_purge(&d->tx_queue);\n+        rfcomm_dlc_unlink(d);\n+    }\n+\n+    return 0;\n }\n \n int rfcomm_dlc_close(struct rfcomm_dlc *d, int err)\n",
            "diff --git a/net/bluetooth/rfcomm/core.c b/net/bluetooth/rfcomm/core.c\nindex 8d6fce9005bd..e82457d3ae08 100644\n--- a/net/bluetooth/rfcomm/core.c\n+++ b/net/bluetooth/rfcomm/core.c\n@@ -446,54 +446,54 @@ static void __rfcomm_dlc_disconn(struct rfcomm_dlc *d)\n \n static int __rfcomm_dlc_close(struct rfcomm_dlc *d, int err)\n {\n-\tstruct rfcomm_session *s = d->session;\n-\tif (!s)\n-\t\treturn 0;\n-\n-\tBT_DBG(\"dlc %p state %ld dlci %d err %d session %p\",\n-\t\t\td, d->state, d->dlci, err, s);\n-\n-\tswitch (d->state) {\n-\tcase BT_CONNECT:\n-\tcase BT_CONFIG:\n-\tcase BT_OPEN:\n-\tcase BT_CONNECT2:\n-\t\tif (test_and_clear_bit(RFCOMM_DEFER_SETUP, &d->flags)) {\n-\t\t\tset_bit(RFCOMM_AUTH_REJECT, &d->flags);\n-\t\t\trfcomm_schedule();\n-\t\t\treturn 0;\n-\t\t}\n-\t}\n-\n-\tswitch (d->state) {\n-\tcase BT_CONNECT:\n-\tcase BT_CONNECTED:\n-\t\t__rfcomm_dlc_disconn(d);\n-\t\tbreak;\n-\n-\tcase BT_CONFIG:\n-\t\tif (s->state != BT_BOUND) {\n-\t\t\t__rfcomm_dlc_disconn(d);\n-\t\t\tbreak;\n-\t\t}\n-\t\t/* if closing a dlc in a session that hasn't been started,\n-\t\t * just close and unlink the dlc\n-\t\t */\n-\t\tfallthrough;\n-\n-\tdefault:\n-\t\trfcomm_dlc_clear_timer(d);\n-\n-\t\trfcomm_dlc_lock(d);\n-\t\td->state = BT_CLOSED;\n-\t\td->state_change(d, err);\n-\t\trfcomm_dlc_unlock(d);\n-\n-\t\tskb_queue_purge(&d->tx_queue);\n-\t\trfcomm_dlc_unlink(d);\n-\t}\n-\n-\treturn 0;\n+    struct rfcomm_session *s = d->session;\n+    if (!s)\n+        return 0;\n+\n+    BT_DBG(\"dlc %p state %ld dlci %d err %d session %p\",\n+            d, d->state, d->dlci, err, s);\n+\n+    switch (d->state) {\n+    case BT_CONNECT:\n+    case BT_CONFIG:\n+    case BT_OPEN:\n+    case BT_CONNECT2:\n+        if (test_and_clear_bit(RFCOMM_DEFER_SETUP, &d->flags)) {\n+            set_bit(RFCOMM_AUTH_REJECT, &d->flags);\n+            rfcomm_schedule();\n+            return 0;\n+        }\n+    }\n+\n+    switch (d->state) {\n+    case BT_CONNECT:\n+    case BT_CONNECTED:\n+        __rfcomm_dlc_disconn(d);\n+        break;\n+\n+    case BT_CONFIG:\n+        if (s->state != BT_BOUND) {\n+            __rfcomm_dlc_disconn(d);\n+            break;\n+        }\n+        /* if closing a dlc in a session that hasn't been started,\n+         * just close and unlink the dlc\n+         */\n+        fallthrough;\n+\n+    default:\n+        rfcomm_dlc_clear_timer(d);\n+\n+        rfcomm_dlc_unlock(d); // Release the lock before state change\n+        d->state = BT_CLOSED;\n+        d->state_change(d, err); // Call state change without holding the lock\n+        rfcomm_dlc_lock(d); // Reacquire the lock if necessary\n+\n+        skb_queue_purge(&d->tx_queue);\n+        rfcomm_dlc_unlink(d);\n+    }\n+\n+    return 0;\n }\n \n int rfcomm_dlc_close(struct rfcomm_dlc *d, int err)\n",
            "diff --git a/net/bluetooth/rfcomm/core.c b/net/bluetooth/rfcomm/core.c\nindex 8d6fce9005bd..584f5a8086a6 100644\n--- a/net/bluetooth/rfcomm/core.c\n+++ b/net/bluetooth/rfcomm/core.c\n@@ -484,10 +484,11 @@ static int __rfcomm_dlc_close(struct rfcomm_dlc *d, int err)\n \tdefault:\n \t\trfcomm_dlc_clear_timer(d);\n \n-\t\trfcomm_dlc_lock(d);\n+\t\t/* Release DLC lock before calling state_change to avoid deadlock */\n+\t\trfcomm_dlc_unlock(d);\n \t\td->state = BT_CLOSED;\n \t\td->state_change(d, err);\n-\t\trfcomm_dlc_unlock(d);\n+\t\trfcomm_dlc_lock(d);\n \n \t\tskb_queue_purge(&d->tx_queue);\n \t\trfcomm_dlc_unlink(d);\ndiff --git a/net/bluetooth/rfcomm/sock.c b/net/bluetooth/rfcomm/sock.c\nindex 21e24da4847f..8677ab6e0e03 100644\n--- a/net/bluetooth/rfcomm/sock.c\n+++ b/net/bluetooth/rfcomm/sock.c\n@@ -70,6 +70,8 @@ static void rfcomm_sk_state_change(struct rfcomm_dlc *d, int err)\n \n \tBT_DBG(\"dlc %p state %ld err %d\", d, d->state, err);\n \n+\t/* Release DLC lock before acquiring sock lock to avoid deadlock */\n+\trfcomm_dlc_unlock(d);\n \tlock_sock(sk);\n \n \tif (err)\n@@ -96,7 +98,6 @@ static void rfcomm_sk_state_change(struct rfcomm_dlc *d, int err)\n \tif (parent && sock_flag(sk, SOCK_ZAPPED)) {\n \t\t/* We have to drop DLC lock here, otherwise\n \t\t * rfcomm_sock_destruct() will dead lock. */\n-\t\trfcomm_dlc_unlock(d);\n \t\trfcomm_sock_kill(sk);\n \t\trfcomm_dlc_lock(d);\n \t}\n",
            "diff --git a/net/bluetooth/rfcomm/sock.c b/net/bluetooth/rfcomm/sock.c\nindex 21e24da4847f..0b6262169fa9 100644\n--- a/net/bluetooth/rfcomm/sock.c\n+++ b/net/bluetooth/rfcomm/sock.c\n@@ -70,6 +70,9 @@ static void rfcomm_sk_state_change(struct rfcomm_dlc *d, int err)\n \n \tBT_DBG(\"dlc %p state %ld err %d\", d, d->state, err);\n \n+\t/* Release DLC lock before acquiring socket lock to prevent deadlock */\n+\trfcomm_dlc_unlock(d);\n+\n \tlock_sock(sk);\n \n \tif (err)\n@@ -93,6 +96,9 @@ static void rfcomm_sk_state_change(struct rfcomm_dlc *d, int err)\n \n \trelease_sock(sk);\n \n+\t/* Reacquire DLC lock after releasing socket lock */\n+\trfcomm_dlc_lock(d);\n+\n \tif (parent && sock_flag(sk, SOCK_ZAPPED)) {\n \t\t/* We have to drop DLC lock here, otherwise\n \t\t * rfcomm_sock_destruct() will dead lock. */\n",
            "diff --git a/net/bluetooth/rfcomm/core.c b/net/bluetooth/rfcomm/core.c\nindex 8d6fce9005bd..4a47a53f5c86 100644\n--- a/net/bluetooth/rfcomm/core.c\n+++ b/net/bluetooth/rfcomm/core.c\n@@ -498,36 +498,38 @@ static int __rfcomm_dlc_close(struct rfcomm_dlc *d, int err)\n \n int rfcomm_dlc_close(struct rfcomm_dlc *d, int err)\n {\n-\tint r = 0;\n-\tstruct rfcomm_dlc *d_list;\n-\tstruct rfcomm_session *s, *s_list;\n-\n-\tBT_DBG(\"dlc %p state %ld dlci %d err %d\", d, d->state, d->dlci, err);\n-\n-\trfcomm_lock();\n-\n-\ts = d->session;\n-\tif (!s)\n-\t\tgoto no_session;\n-\n-\t/* after waiting on the mutex check the session still exists\n-\t * then check the dlc still exists\n-\t */\n-\tlist_for_each_entry(s_list, &session_list, list) {\n-\t\tif (s_list == s) {\n-\t\t\tlist_for_each_entry(d_list, &s->dlcs, list) {\n-\t\t\t\tif (d_list == d) {\n-\t\t\t\t\tr = __rfcomm_dlc_close(d, err);\n-\t\t\t\t\tbreak;\n-\t\t\t\t}\n-\t\t\t}\n-\t\t\tbreak;\n-\t\t}\n-\t}\n+    int r = 0;\n+    struct rfcomm_dlc *d_list;\n+    struct rfcomm_session *s, *s_list;\n+\n+    BT_DBG(\"dlc %p state %ld dlci %d err %d\", d, d->state, d->dlci, err);\n+\n+    rfcomm_lock();\n+\n+    s = d->session;\n+    if (!s)\n+        goto no_session;\n+\n+    /* after waiting on the mutex check the session still exists\n+     * then check the dlc still exists\n+     */\n+    list_for_each_entry(s_list, &session_list, list) {\n+        if (s_list == s) {\n+            list_for_each_entry(d_list, &s->dlcs, list) {\n+                if (d_list == d) {\n+                    rfcomm_dlc_unlock(d); // Release &d->lock before calling __rfcomm_dlc_close\n+                    r = __rfcomm_dlc_close(d, err);\n+                    rfcomm_dlc_lock(d); // Re-acquire &d->lock after __rfcomm_dlc_close\n+                    break;\n+                }\n+            }\n+            break;\n+        }\n+    }\n \n no_session:\n-\trfcomm_unlock();\n-\treturn r;\n+    rfcomm_unlock();\n+    return r;\n }\n \n struct rfcomm_dlc *rfcomm_dlc_exists(bdaddr_t *src, bdaddr_t *dst, u8 channel)\n"
        ],
        "error": []
    },
    "deb061ff946b02c2f4821f91683d89a68b2f45f8": {
        "non_crash": [
            "diff --git a/fs/hfsplus/catalog.c b/fs/hfsplus/catalog.c\nindex 35472cba750e..2d77488d1235 100644\n--- a/fs/hfsplus/catalog.c\n+++ b/fs/hfsplus/catalog.c\n@@ -191,33 +191,38 @@ static int hfsplus_fill_cat_thread(struct super_block *sb,\n }\n \n /* Try to get a catalog entry for given catalog id */\n-int hfsplus_find_cat(struct super_block *sb, u32 cnid,\n-\t\t     struct hfs_find_data *fd)\n+int hfsplus_find_cat(struct super_block *sb, u32 cnid, struct hfs_find_data *fd)\n {\n-\thfsplus_cat_entry tmp;\n-\tint err;\n-\tu16 type;\n-\n-\thfsplus_cat_build_key_with_cnid(sb, fd->search_key, cnid);\n-\terr = hfs_brec_read(fd, &tmp, sizeof(hfsplus_cat_entry));\n-\tif (err)\n-\t\treturn err;\n-\n-\ttype = be16_to_cpu(tmp.type);\n-\tif (type != HFSPLUS_FOLDER_THREAD && type != HFSPLUS_FILE_THREAD) {\n-\t\tpr_err(\"found bad thread record in catalog\\n\");\n-\t\treturn -EIO;\n-\t}\n-\n-\tif (be16_to_cpu(tmp.thread.nodeName.length) > 255) {\n-\t\tpr_err(\"catalog name length corrupted\\n\");\n-\t\treturn -EIO;\n-\t}\n-\n-\thfsplus_cat_build_key_uni(fd->search_key,\n-\t\tbe32_to_cpu(tmp.thread.parentID),\n-\t\t&tmp.thread.nodeName);\n-\treturn hfs_brec_find(fd, hfs_find_rec_by_key);\n+    hfsplus_cat_entry tmp;\n+    int err;\n+    u16 type;\n+\n+    hfsplus_cat_build_key_with_cnid(sb, fd->search_key, cnid);\n+    err = hfs_brec_read(fd, &tmp, sizeof(hfsplus_cat_entry));\n+    if (err)\n+        return err;\n+\n+    type = be16_to_cpu(tmp.type);\n+    if (type != HFSPLUS_FOLDER_THREAD && type != HFSPLUS_FILE_THREAD) {\n+        pr_err(\"found bad thread record in catalog\\n\");\n+        return -EIO;\n+    }\n+\n+    if (be16_to_cpu(tmp.thread.nodeName.length) > 255) {\n+        pr_err(\"catalog name length corrupted\\n\");\n+        return -EIO;\n+    }\n+\n+    // Validate entry length before proceeding\n+    if (fd->entrylength < sizeof(struct hfsplus_cat_file)) {\n+        pr_err(\"entry length too small for hfsplus_cat_file\\n\");\n+        return -EIO;\n+    }\n+\n+    hfsplus_cat_build_key_uni(fd->search_key,\n+        be32_to_cpu(tmp.thread.parentID),\n+        &tmp.thread.nodeName);\n+    return hfs_brec_find(fd, hfs_find_rec_by_key);\n }\n \n static void hfsplus_subfolders_inc(struct inode *dir)\n",
            "diff --git a/fs/hfsplus/inode.c b/fs/hfsplus/inode.c\nindex abb91f5fae92..eb716aa4798f 100644\n--- a/fs/hfsplus/inode.c\n+++ b/fs/hfsplus/inode.c\n@@ -567,74 +567,77 @@ int hfsplus_cat_read_inode(struct inode *inode, struct hfs_find_data *fd)\n \n int hfsplus_cat_write_inode(struct inode *inode)\n {\n-\tstruct inode *main_inode = inode;\n-\tstruct hfs_find_data fd;\n-\thfsplus_cat_entry entry;\n-\n-\tif (HFSPLUS_IS_RSRC(inode))\n-\t\tmain_inode = HFSPLUS_I(inode)->rsrc_inode;\n-\n-\tif (!main_inode->i_nlink)\n-\t\treturn 0;\n-\n-\tif (hfs_find_init(HFSPLUS_SB(main_inode->i_sb)->cat_tree, &fd))\n-\t\t/* panic? */\n-\t\treturn -EIO;\n-\n-\tif (hfsplus_find_cat(main_inode->i_sb, main_inode->i_ino, &fd))\n-\t\t/* panic? */\n-\t\tgoto out;\n-\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\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-\t\thfsplus_cat_set_perms(inode, &folder->permissions);\n-\t\tfolder->access_date = hfsp_ut2mt(inode->i_atime);\n-\t\tfolder->content_mod_date = hfsp_ut2mt(inode->i_mtime);\n-\t\tfolder->attribute_mod_date = hfsp_ut2mt(inode->i_ctime);\n-\t\tfolder->valence = cpu_to_be32(inode->i_size - 2);\n-\t\tif (folder->flags & cpu_to_be16(HFSPLUS_HAS_FOLDER_COUNT)) {\n-\t\t\tfolder->subfolders =\n-\t\t\t\tcpu_to_be32(HFSPLUS_I(inode)->subfolders);\n-\t\t}\n-\t\thfs_bnode_write(fd.bnode, &entry, fd.entryoffset,\n-\t\t\t\t\t sizeof(struct hfsplus_cat_folder));\n-\t} else if (HFSPLUS_IS_RSRC(inode)) {\n-\t\tstruct hfsplus_cat_file *file = &entry.file;\n-\t\thfs_bnode_read(fd.bnode, &entry, fd.entryoffset,\n-\t\t\t       sizeof(struct hfsplus_cat_file));\n-\t\thfsplus_inode_write_fork(inode, &file->rsrc_fork);\n-\t\thfs_bnode_write(fd.bnode, &entry, fd.entryoffset,\n-\t\t\t\tsizeof(struct hfsplus_cat_file));\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\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-\t\thfsplus_cat_set_perms(inode, &file->permissions);\n-\t\tif (HFSPLUS_FLG_IMMUTABLE &\n-\t\t\t\t(file->permissions.rootflags |\n-\t\t\t\t\tfile->permissions.userflags))\n-\t\t\tfile->flags |= cpu_to_be16(HFSPLUS_FILE_LOCKED);\n-\t\telse\n-\t\t\tfile->flags &= cpu_to_be16(~HFSPLUS_FILE_LOCKED);\n-\t\tfile->access_date = hfsp_ut2mt(inode->i_atime);\n-\t\tfile->content_mod_date = hfsp_ut2mt(inode->i_mtime);\n-\t\tfile->attribute_mod_date = hfsp_ut2mt(inode->i_ctime);\n-\t\thfs_bnode_write(fd.bnode, &entry, fd.entryoffset,\n-\t\t\t\t\t sizeof(struct hfsplus_cat_file));\n-\t}\n-\n-\tset_bit(HFSPLUS_I_CAT_DIRTY, &HFSPLUS_I(inode)->flags);\n+    struct inode *main_inode = inode;\n+    struct hfs_find_data fd;\n+    hfsplus_cat_entry entry;\n+\n+    if (HFSPLUS_IS_RSRC(inode))\n+        main_inode = HFSPLUS_I(inode)->rsrc_inode;\n+\n+    if (!main_inode->i_nlink)\n+        return 0;\n+\n+    if (hfs_find_init(HFSPLUS_SB(main_inode->i_sb)->cat_tree, &fd))\n+        return -EIO;\n+\n+    if (hfsplus_find_cat(main_inode->i_sb, main_inode->i_ino, &fd))\n+        goto out;\n+\n+    if (S_ISDIR(main_inode->i_mode)) {\n+        struct hfsplus_cat_folder *folder = &entry.folder;\n+\n+        if (fd.entrylength < sizeof(struct hfsplus_cat_folder)) {\n+            hfs_find_exit(&fd);\n+            return -EIO;\n+        }\n+        hfs_bnode_read(fd.bnode, &entry, fd.entryoffset,\n+                       sizeof(struct hfsplus_cat_folder));\n+        hfsplus_cat_set_perms(inode, &folder->permissions);\n+        folder->access_date = hfsp_ut2mt(inode->i_atime);\n+        folder->content_mod_date = hfsp_ut2mt(inode->i_mtime);\n+        folder->attribute_mod_date = hfsp_ut2mt(inode->i_ctime);\n+        folder->valence = cpu_to_be32(inode->i_size - 2);\n+        if (folder->flags & cpu_to_be16(HFSPLUS_HAS_FOLDER_COUNT)) {\n+            folder->subfolders =\n+                cpu_to_be32(HFSPLUS_I(inode)->subfolders);\n+        }\n+        hfs_bnode_write(fd.bnode, &entry, fd.entryoffset,\n+                        sizeof(struct hfsplus_cat_folder));\n+    } else if (HFSPLUS_IS_RSRC(inode)) {\n+        struct hfsplus_cat_file *file = &entry.file;\n+        hfs_bnode_read(fd.bnode, &entry, fd.entryoffset,\n+                       sizeof(struct hfsplus_cat_file));\n+        hfsplus_inode_write_fork(inode, &file->rsrc_fork);\n+        hfs_bnode_write(fd.bnode, &entry, fd.entryoffset,\n+                        sizeof(struct hfsplus_cat_file));\n+    } else {\n+        struct hfsplus_cat_file *file = &entry.file;\n+\n+        if (fd.entrylength < sizeof(struct hfsplus_cat_file)) {\n+            hfs_find_exit(&fd);\n+            return -EIO;\n+        }\n+        hfs_bnode_read(fd.bnode, &entry, fd.entryoffset,\n+                       sizeof(struct hfsplus_cat_file));\n+        hfsplus_inode_write_fork(inode, &file->data_fork);\n+        hfsplus_cat_set_perms(inode, &file->permissions);\n+        if (HFSPLUS_FLG_IMMUTABLE &\n+                (file->permissions.rootflags |\n+                 file->permissions.userflags))\n+            file->flags |= cpu_to_be16(HFSPLUS_FILE_LOCKED);\n+        else\n+            file->flags &= cpu_to_be16(~HFSPLUS_FILE_LOCKED);\n+        file->access_date = hfsp_ut2mt(inode->i_atime);\n+        file->content_mod_date = hfsp_ut2mt(inode->i_mtime);\n+        file->attribute_mod_date = hfsp_ut2mt(inode->i_ctime);\n+        hfs_bnode_write(fd.bnode, &entry, fd.entryoffset,\n+                        sizeof(struct hfsplus_cat_file));\n+    }\n+\n+    set_bit(HFSPLUS_I_CAT_DIRTY, &HFSPLUS_I(inode)->flags);\n out:\n-\thfs_find_exit(&fd);\n-\treturn 0;\n+    hfs_find_exit(&fd);\n+    return 0;\n }\n \n int hfsplus_fileattr_get(struct dentry *dentry, struct fileattr *fa)\n",
            "diff --git a/fs/hfsplus/bfind.c b/fs/hfsplus/bfind.c\nindex ca2ba8c9f82e..959a6e5793b9 100644\n--- a/fs/hfsplus/bfind.c\n+++ b/fs/hfsplus/bfind.c\n@@ -217,15 +217,15 @@ int hfs_brec_find(struct hfs_find_data *fd, search_strategy_t do_key_compare)\n \n int hfs_brec_read(struct hfs_find_data *fd, void *rec, int rec_len)\n {\n-\tint res;\n+    int res;\n \n-\tres = hfs_brec_find(fd, hfs_find_rec_by_key);\n-\tif (res)\n-\t\treturn res;\n-\tif (fd->entrylength > rec_len)\n-\t\treturn -EINVAL;\n-\thfs_bnode_read(fd->bnode, rec, fd->entryoffset, fd->entrylength);\n-\treturn 0;\n+    res = hfs_brec_find(fd, hfs_find_rec_by_key);\n+    if (res)\n+        return res;\n+    if (fd->entrylength > rec_len || fd->entrylength < sizeof(struct hfsplus_cat_file))\n+        return -EINVAL;\n+    hfs_bnode_read(fd->bnode, rec, fd->entryoffset, fd->entrylength);\n+    return 0;\n }\n \n int hfs_brec_goto(struct hfs_find_data *fd, int cnt)\n",
            "diff --git a/fs/hfsplus/catalog.c b/fs/hfsplus/catalog.c\nindex 35472cba750e..f0b851bc7a18 100644\n--- a/fs/hfsplus/catalog.c\n+++ b/fs/hfsplus/catalog.c\n@@ -214,6 +214,12 @@ int hfsplus_find_cat(struct super_block *sb, u32 cnid,\n \t\treturn -EIO;\n \t}\n \n+\t// Check if the entry length is sufficient for a file or folder\n+\tif (fd->entrylength < sizeof(struct hfsplus_cat_file)) {\n+\t\tpr_err(\"entry length too small for catalog entry\\n\");\n+\t\treturn -EIO;\n+\t}\n+\n \thfsplus_cat_build_key_uni(fd->search_key,\n \t\tbe32_to_cpu(tmp.thread.parentID),\n \t\t&tmp.thread.nodeName);\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/hfsplus/bfind.c b/fs/hfsplus/bfind.c\nindex ca2ba8c9f82e..c47ba0608a7b 100644\n--- a/fs/hfsplus/bfind.c\n+++ b/fs/hfsplus/bfind.c\n@@ -155,6 +155,12 @@ int __hfs_brec_find(struct hfs_bnode *bnode, struct hfs_find_data *fd,\n \tfd->entryoffset = off + keylen;\n \tfd->entrylength = len - keylen;\n \n+\t// Additional check to ensure entrylength is valid\n+\tif (fd->entrylength < 0) {\n+\t\tpr_err(\"Invalid entry length calculated: %d\\n\", fd->entrylength);\n+\t\tres = -EINVAL;\n+\t}\n+\n fail:\n \treturn res;\n }\n"
        ],
        "error": []
    },
    "384b9a05e5d4c3e74e31427e43a08f40f71db54a": {
        "non_crash": [
            "diff --git a/fs/afs/super.c b/fs/afs/super.c\nindex 95d713074dc8..2d9b135ce252 100644\n--- a/fs/afs/super.c\n+++ b/fs/afs/super.c\n@@ -429,10 +429,13 @@ static int afs_test_super(struct super_block *sb, struct fs_context *fc)\n \n static int afs_dynroot_test_super(struct super_block *sb, struct fs_context *fc)\n {\n-\tstruct afs_super_info *as = AFS_FS_S(sb);\n+    struct afs_super_info *as = AFS_FS_S(sb);\n \n-\treturn (as->net_ns == fc->net_ns &&\n-\t\tas->dyn_root);\n+    /* Ensure the superblock is active before accessing its resources */\n+    if (!(sb->s_flags & SB_ACTIVE))\n+        return 0;\n+\n+    return (as->net_ns == fc->net_ns && as->dyn_root);\n }\n \n static int afs_set_super(struct super_block *sb, struct fs_context *fc)\n",
            "diff --git a/fs/afs/super.c b/fs/afs/super.c\nindex 95d713074dc8..38b78ccb1937 100644\n--- a/fs/afs/super.c\n+++ b/fs/afs/super.c\n@@ -429,10 +429,15 @@ static int afs_test_super(struct super_block *sb, struct fs_context *fc)\n \n static int afs_dynroot_test_super(struct super_block *sb, struct fs_context *fc)\n {\n-\tstruct afs_super_info *as = AFS_FS_S(sb);\n+    struct afs_super_info *as;\n \n-\treturn (as->net_ns == fc->net_ns &&\n-\t\tas->dyn_root);\n+    if (sb->s_flags & (SB_DYING | SB_DEAD))\n+        return false;\n+\n+    as = AFS_FS_S(sb);\n+\n+    return (as->net_ns == fc->net_ns &&\n+            as->dyn_root);\n }\n \n static int afs_set_super(struct super_block *sb, struct fs_context *fc)\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/afs/super.c b/fs/afs/super.c\nindex 95d713074dc8..660e7d5ca792 100644\n--- a/fs/afs/super.c\n+++ b/fs/afs/super.c\n@@ -429,10 +429,13 @@ static int afs_test_super(struct super_block *sb, struct fs_context *fc)\n \n static int afs_dynroot_test_super(struct super_block *sb, struct fs_context *fc)\n {\n-\tstruct afs_super_info *as = AFS_FS_S(sb);\n+    struct afs_super_info *as = AFS_FS_S(sb);\n \n-\treturn (as->net_ns == fc->net_ns &&\n-\t\tas->dyn_root);\n+    /* Check if the superblock is marked as dead */\n+    if (sb->s_flags & SB_DEAD)\n+        return false;\n+\n+    return (as->net_ns == fc->net_ns && as->dyn_root);\n }\n \n static int afs_set_super(struct super_block *sb, struct fs_context *fc)\n@@ -534,20 +537,23 @@ static void afs_destroy_sbi(struct afs_super_info *as)\n \n static void afs_kill_super(struct super_block *sb)\n {\n-\tstruct afs_super_info *as = AFS_FS_S(sb);\n-\n-\tif (as->dyn_root)\n-\t\tafs_dynroot_depopulate(sb);\n-\n-\t/* Clear the callback interests (which will do ilookup5) before\n-\t * deactivating the superblock.\n-\t */\n-\tif (as->volume)\n-\t\trcu_assign_pointer(as->volume->sb, NULL);\n-\tkill_anon_super(sb);\n-\tif (as->volume)\n-\t\tafs_deactivate_volume(as->volume);\n-\tafs_destroy_sbi(as);\n+    struct afs_super_info *as = AFS_FS_S(sb);\n+\n+    if (as->dyn_root)\n+        afs_dynroot_depopulate(sb);\n+\n+    /* Clear the callback interests (which will do ilookup5) before\n+     * deactivating the superblock.\n+     */\n+    if (as->volume)\n+        rcu_assign_pointer(as->volume->sb, NULL);\n+    kill_anon_super(sb);\n+    if (as->volume)\n+        afs_deactivate_volume(as->volume);\n+    afs_destroy_sbi(as);\n+\n+    /* Mark the superblock as dead to prevent reuse */\n+    sb->s_flags |= SB_DEAD;\n }\n \n /*\n",
            "diff --git a/fs/afs/super.c b/fs/afs/super.c\nindex 95d713074dc8..7b76cea1e61a 100644\n--- a/fs/afs/super.c\n+++ b/fs/afs/super.c\n@@ -429,10 +429,12 @@ static int afs_test_super(struct super_block *sb, struct fs_context *fc)\n \n static int afs_dynroot_test_super(struct super_block *sb, struct fs_context *fc)\n {\n-\tstruct afs_super_info *as = AFS_FS_S(sb);\n+    struct afs_super_info *as = AFS_FS_S(sb);\n \n-\treturn (as->net_ns == fc->net_ns &&\n-\t\tas->dyn_root);\n+    if (!as || !as->net_ns || !as->dyn_root)\n+        return false;\n+\n+    return (as->net_ns == fc->net_ns && as->dyn_root);\n }\n \n static int afs_set_super(struct super_block *sb, struct fs_context *fc)\n@@ -534,20 +536,20 @@ static void afs_destroy_sbi(struct afs_super_info *as)\n \n static void afs_kill_super(struct super_block *sb)\n {\n-\tstruct afs_super_info *as = AFS_FS_S(sb);\n-\n-\tif (as->dyn_root)\n-\t\tafs_dynroot_depopulate(sb);\n-\n-\t/* Clear the callback interests (which will do ilookup5) before\n-\t * deactivating the superblock.\n-\t */\n-\tif (as->volume)\n-\t\trcu_assign_pointer(as->volume->sb, NULL);\n-\tkill_anon_super(sb);\n-\tif (as->volume)\n-\t\tafs_deactivate_volume(as->volume);\n-\tafs_destroy_sbi(as);\n+    struct afs_super_info *as = AFS_FS_S(sb);\n+\n+    if (as->dyn_root && sb->s_root)\n+        afs_dynroot_depopulate(sb);\n+\n+    /* Clear the callback interests (which will do ilookup5) before\n+     * deactivating the superblock.\n+     */\n+    if (as->volume)\n+        rcu_assign_pointer(as->volume->sb, NULL);\n+    kill_anon_super(sb);\n+    if (as->volume)\n+        afs_deactivate_volume(as->volume);\n+    afs_destroy_sbi(as);\n }\n \n /*\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/afs/super.c b/fs/afs/super.c\nindex 95d713074dc8..97e21007a982 100644\n--- a/fs/afs/super.c\n+++ b/fs/afs/super.c\n@@ -429,10 +429,13 @@ static int afs_test_super(struct super_block *sb, struct fs_context *fc)\n \n static int afs_dynroot_test_super(struct super_block *sb, struct fs_context *fc)\n {\n-\tstruct afs_super_info *as = AFS_FS_S(sb);\n+    struct afs_super_info *as = AFS_FS_S(sb);\n \n-\treturn (as->net_ns == fc->net_ns &&\n-\t\tas->dyn_root);\n+    if (!as || !as->net_ns)\n+        return 0;\n+\n+    return (as->net_ns == fc->net_ns &&\n+            as->dyn_root);\n }\n \n static int afs_set_super(struct super_block *sb, struct fs_context *fc)\n@@ -503,33 +506,34 @@ static int afs_fill_super(struct super_block *sb, struct afs_fs_context *ctx)\n \n static struct afs_super_info *afs_alloc_sbi(struct fs_context *fc)\n {\n-\tstruct afs_fs_context *ctx = fc->fs_private;\n-\tstruct afs_super_info *as;\n-\n-\tas = kzalloc(sizeof(struct afs_super_info), GFP_KERNEL);\n-\tif (as) {\n-\t\tas->net_ns = get_net(fc->net_ns);\n-\t\tas->flock_mode = ctx->flock_mode;\n-\t\tif (ctx->dyn_root) {\n-\t\t\tas->dyn_root = true;\n-\t\t} else {\n-\t\t\tas->cell = afs_use_cell(ctx->cell, afs_cell_trace_use_sbi);\n-\t\t\tas->volume = afs_get_volume(ctx->volume,\n-\t\t\t\t\t\t    afs_volume_trace_get_alloc_sbi);\n-\t\t}\n-\t}\n-\treturn as;\n+    struct afs_fs_context *ctx = fc->fs_private;\n+    struct afs_super_info *as;\n+\n+    as = kzalloc(sizeof(struct afs_super_info), GFP_KERNEL);\n+    if (as) {\n+        refcount_set(&as->refcount, 1);\n+        as->net_ns = get_net(fc->net_ns);\n+        as->flock_mode = ctx->flock_mode;\n+        if (ctx->dyn_root) {\n+            as->dyn_root = true;\n+        } else {\n+            as->cell = afs_use_cell(ctx->cell, afs_cell_trace_use_sbi);\n+            as->volume = afs_get_volume(ctx->volume,\n+                                        afs_volume_trace_get_alloc_sbi);\n+        }\n+    }\n+    return as;\n }\n \n static void afs_destroy_sbi(struct afs_super_info *as)\n {\n-\tif (as) {\n-\t\tstruct afs_net *net = afs_net(as->net_ns);\n-\t\tafs_put_volume(net, as->volume, afs_volume_trace_put_destroy_sbi);\n-\t\tafs_unuse_cell(net, as->cell, afs_cell_trace_unuse_sbi);\n-\t\tput_net(as->net_ns);\n-\t\tkfree(as);\n-\t}\n+    if (as && refcount_dec_and_test(&as->refcount)) {\n+        struct afs_net *net = afs_net(as->net_ns);\n+        afs_put_volume(net, as->volume, afs_volume_trace_put_destroy_sbi);\n+        afs_unuse_cell(net, as->cell, afs_cell_trace_unuse_sbi);\n+        put_net(as->net_ns);\n+        kfree(as);\n+    }\n }\n \n static void afs_kill_super(struct super_block *sb)\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "bb3342477c4669ef082c7056b6e2be4f903e646e": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/nilfs2/bmap.c b/fs/nilfs2/bmap.c\nindex 798a2c1b38c6..a416d111f95e 100644\n--- a/fs/nilfs2/bmap.c\n+++ b/fs/nilfs2/bmap.c\n@@ -551,14 +551,17 @@ void nilfs_bmap_write(struct nilfs_bmap *bmap, struct nilfs_inode *raw_inode)\n \n void nilfs_bmap_init_gc(struct nilfs_bmap *bmap)\n {\n-\tmemset(&bmap->b_u, 0, NILFS_BMAP_SIZE);\n-\tinit_rwsem(&bmap->b_sem);\n-\tbmap->b_inode = &NILFS_BMAP_I(bmap)->vfs_inode;\n-\tbmap->b_ptr_type = NILFS_BMAP_PTR_U;\n-\tbmap->b_last_allocated_key = 0;\n-\tbmap->b_last_allocated_ptr = NILFS_BMAP_INVALID_PTR;\n-\tbmap->b_state = 0;\n-\tnilfs_btree_init_gc(bmap);\n+    static struct lock_class_key nilfs_bmap_sem_lock_key;\n+\n+    memset(&bmap->b_u, 0, NILFS_BMAP_SIZE);\n+    init_rwsem(&bmap->b_sem);\n+    lockdep_set_class(&bmap->b_sem, &nilfs_bmap_sem_lock_key);\n+    bmap->b_inode = &NILFS_BMAP_I(bmap)->vfs_inode;\n+    bmap->b_ptr_type = NILFS_BMAP_PTR_U;\n+    bmap->b_last_allocated_key = 0;\n+    bmap->b_last_allocated_ptr = NILFS_BMAP_INVALID_PTR;\n+    bmap->b_state = 0;\n+    nilfs_btree_init_gc(bmap);\n }\n \n void nilfs_bmap_save(const struct nilfs_bmap *bmap,\n",
            "diff --git a/fs/nilfs2/bmap.c b/fs/nilfs2/bmap.c\nindex 798a2c1b38c6..98eb318c8996 100644\n--- a/fs/nilfs2/bmap.c\n+++ b/fs/nilfs2/bmap.c\n@@ -495,40 +495,37 @@ static struct lock_class_key nilfs_bmap_mdt_lock_key;\n  */\n int nilfs_bmap_read(struct nilfs_bmap *bmap, struct nilfs_inode *raw_inode)\n {\n-\tif (raw_inode == NULL)\n-\t\tmemset(bmap->b_u.u_data, 0, NILFS_BMAP_SIZE);\n-\telse\n-\t\tmemcpy(bmap->b_u.u_data, raw_inode->i_bmap, NILFS_BMAP_SIZE);\n-\n-\tinit_rwsem(&bmap->b_sem);\n-\tbmap->b_state = 0;\n-\tbmap->b_inode = &NILFS_BMAP_I(bmap)->vfs_inode;\n-\tswitch (bmap->b_inode->i_ino) {\n-\tcase NILFS_DAT_INO:\n-\t\tbmap->b_ptr_type = NILFS_BMAP_PTR_P;\n-\t\tbmap->b_last_allocated_key = 0;\n-\t\tbmap->b_last_allocated_ptr = NILFS_BMAP_NEW_PTR_INIT;\n-\t\tlockdep_set_class(&bmap->b_sem, &nilfs_bmap_dat_lock_key);\n-\t\tbreak;\n-\tcase NILFS_CPFILE_INO:\n-\tcase NILFS_SUFILE_INO:\n-\t\tbmap->b_ptr_type = NILFS_BMAP_PTR_VS;\n-\t\tbmap->b_last_allocated_key = 0;\n-\t\tbmap->b_last_allocated_ptr = NILFS_BMAP_INVALID_PTR;\n-\t\tlockdep_set_class(&bmap->b_sem, &nilfs_bmap_mdt_lock_key);\n-\t\tbreak;\n-\tcase NILFS_IFILE_INO:\n-\t\tlockdep_set_class(&bmap->b_sem, &nilfs_bmap_mdt_lock_key);\n-\t\tfallthrough;\n-\tdefault:\n-\t\tbmap->b_ptr_type = NILFS_BMAP_PTR_VM;\n-\t\tbmap->b_last_allocated_key = 0;\n-\t\tbmap->b_last_allocated_ptr = NILFS_BMAP_INVALID_PTR;\n-\t\tbreak;\n-\t}\n-\n-\treturn (bmap->b_u.u_flags & NILFS_BMAP_LARGE) ?\n-\t\tnilfs_btree_init(bmap) : nilfs_direct_init(bmap);\n+    memcpy(bmap->b_u.u_data, raw_inode->i_bmap, NILFS_BMAP_SIZE);\n+    init_rwsem(&bmap->b_sem);\n+    bmap->b_state = 0;\n+    bmap->b_inode = &NILFS_BMAP_I(bmap)->vfs_inode;\n+\n+    switch (bmap->b_inode->i_ino) {\n+    case NILFS_DAT_INO:\n+        bmap->b_ptr_type = NILFS_BMAP_PTR_P;\n+        bmap->b_last_allocated_key = 0;\n+        bmap->b_last_allocated_ptr = NILFS_BMAP_NEW_PTR_INIT;\n+        lockdep_set_class(&bmap->b_sem, &nilfs_bmap_dat_lock_key);\n+        break;\n+    case NILFS_CPFILE_INO:\n+    case NILFS_SUFILE_INO:\n+        bmap->b_ptr_type = NILFS_BMAP_PTR_VS;\n+        bmap->b_last_allocated_key = 0;\n+        bmap->b_last_allocated_ptr = NILFS_BMAP_INVALID_PTR;\n+        lockdep_set_class(&bmap->b_sem, &nilfs_bmap_mdt_lock_key);\n+        break;\n+    case NILFS_IFILE_INO:\n+        lockdep_set_class(&bmap->b_sem, &nilfs_bmap_mdt_lock_key);\n+        /* Fall through */\n+    default:\n+        bmap->b_ptr_type = NILFS_BMAP_PTR_VM;\n+        bmap->b_last_allocated_key = 0;\n+        bmap->b_last_allocated_ptr = NILFS_BMAP_INVALID_PTR;\n+        lockdep_set_class(&bmap->b_sem, &nilfs_bmap_mdt_lock_key);\n+        break;\n+    }\n+\n+    return 0;\n }\n \n /**\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/nilfs2/bmap.c b/fs/nilfs2/bmap.c\nindex 798a2c1b38c6..5d6ed348612d 100644\n--- a/fs/nilfs2/bmap.c\n+++ b/fs/nilfs2/bmap.c\n@@ -496,39 +496,18 @@ static struct lock_class_key nilfs_bmap_mdt_lock_key;\n int nilfs_bmap_read(struct nilfs_bmap *bmap, struct nilfs_inode *raw_inode)\n {\n \tif (raw_inode == NULL)\n-\t\tmemset(bmap->b_u.u_data, 0, NILFS_BMAP_SIZE);\n-\telse\n-\t\tmemcpy(bmap->b_u.u_data, raw_inode->i_bmap, NILFS_BMAP_SIZE);\n+\t\treturn -EINVAL;\n \n-\tinit_rwsem(&bmap->b_sem);\n-\tbmap->b_state = 0;\n-\tbmap->b_inode = &NILFS_BMAP_I(bmap)->vfs_inode;\n-\tswitch (bmap->b_inode->i_ino) {\n-\tcase NILFS_DAT_INO:\n-\t\tbmap->b_ptr_type = NILFS_BMAP_PTR_P;\n-\t\tbmap->b_last_allocated_key = 0;\n-\t\tbmap->b_last_allocated_ptr = NILFS_BMAP_NEW_PTR_INIT;\n-\t\tlockdep_set_class(&bmap->b_sem, &nilfs_bmap_dat_lock_key);\n-\t\tbreak;\n-\tcase NILFS_CPFILE_INO:\n-\tcase NILFS_SUFILE_INO:\n-\t\tbmap->b_ptr_type = NILFS_BMAP_PTR_VS;\n-\t\tbmap->b_last_allocated_key = 0;\n-\t\tbmap->b_last_allocated_ptr = NILFS_BMAP_INVALID_PTR;\n-\t\tlockdep_set_class(&bmap->b_sem, &nilfs_bmap_mdt_lock_key);\n-\t\tbreak;\n-\tcase NILFS_IFILE_INO:\n-\t\tlockdep_set_class(&bmap->b_sem, &nilfs_bmap_mdt_lock_key);\n-\t\tfallthrough;\n-\tdefault:\n-\t\tbmap->b_ptr_type = NILFS_BMAP_PTR_VM;\n-\t\tbmap->b_last_allocated_key = 0;\n-\t\tbmap->b_last_allocated_ptr = NILFS_BMAP_INVALID_PTR;\n-\t\tbreak;\n-\t}\n+\tbmap->b_inode = &NILFS_I(raw_inode)->vfs_inode;\n+\tbmap->b_ops = &nilfs_bmap_ops;\n+\tbmap->b_ptr_type = NILFS_BMAP_PTR_VM;\n+\tbmap->b_last_allocated_key = 0;\n+\tbmap->b_last_allocated_ptr = NILFS_BMAP_INVALID_PTR;\n \n-\treturn (bmap->b_u.u_flags & NILFS_BMAP_LARGE) ?\n-\t\tnilfs_btree_init(bmap) : nilfs_direct_init(bmap);\n+\t/* Set lock class for bmap->b_sem */\n+\tlockdep_set_class(&bmap->b_sem, &nilfs_bmap_dat_lock_key);\n+\n+\treturn 0;\n }\n \n /**\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/nilfs2/bmap.c b/fs/nilfs2/bmap.c\nindex 798a2c1b38c6..1088b2f92f0b 100644\n--- a/fs/nilfs2/bmap.c\n+++ b/fs/nilfs2/bmap.c\n@@ -495,40 +495,33 @@ static struct lock_class_key nilfs_bmap_mdt_lock_key;\n  */\n int nilfs_bmap_read(struct nilfs_bmap *bmap, struct nilfs_inode *raw_inode)\n {\n-\tif (raw_inode == NULL)\n-\t\tmemset(bmap->b_u.u_data, 0, NILFS_BMAP_SIZE);\n-\telse\n-\t\tmemcpy(bmap->b_u.u_data, raw_inode->i_bmap, NILFS_BMAP_SIZE);\n-\n-\tinit_rwsem(&bmap->b_sem);\n-\tbmap->b_state = 0;\n-\tbmap->b_inode = &NILFS_BMAP_I(bmap)->vfs_inode;\n-\tswitch (bmap->b_inode->i_ino) {\n-\tcase NILFS_DAT_INO:\n-\t\tbmap->b_ptr_type = NILFS_BMAP_PTR_P;\n-\t\tbmap->b_last_allocated_key = 0;\n-\t\tbmap->b_last_allocated_ptr = NILFS_BMAP_NEW_PTR_INIT;\n-\t\tlockdep_set_class(&bmap->b_sem, &nilfs_bmap_dat_lock_key);\n-\t\tbreak;\n-\tcase NILFS_CPFILE_INO:\n-\tcase NILFS_SUFILE_INO:\n-\t\tbmap->b_ptr_type = NILFS_BMAP_PTR_VS;\n-\t\tbmap->b_last_allocated_key = 0;\n-\t\tbmap->b_last_allocated_ptr = NILFS_BMAP_INVALID_PTR;\n-\t\tlockdep_set_class(&bmap->b_sem, &nilfs_bmap_mdt_lock_key);\n-\t\tbreak;\n-\tcase NILFS_IFILE_INO:\n-\t\tlockdep_set_class(&bmap->b_sem, &nilfs_bmap_mdt_lock_key);\n-\t\tfallthrough;\n-\tdefault:\n-\t\tbmap->b_ptr_type = NILFS_BMAP_PTR_VM;\n-\t\tbmap->b_last_allocated_key = 0;\n-\t\tbmap->b_last_allocated_ptr = NILFS_BMAP_INVALID_PTR;\n-\t\tbreak;\n-\t}\n-\n-\treturn (bmap->b_u.u_flags & NILFS_BMAP_LARGE) ?\n-\t\tnilfs_btree_init(bmap) : nilfs_direct_init(bmap);\n+    bmap->b_inode = &raw_inode->vfs_inode;\n+    bmap->b_ptr_type = NILFS_BMAP_PTR_VS;\n+    bmap->b_last_allocated_key = 0;\n+    bmap->b_last_allocated_ptr = NILFS_BMAP_INVALID_PTR;\n+\n+    switch (bmap->b_inode->i_ino) {\n+    case NILFS_DAT_INO:\n+        bmap->b_pops = &nilfs_bmap_ptr_ops_dat;\n+        lockdep_set_class(&bmap->b_sem, &nilfs_bmap_dat_lock_key);\n+        break;\n+    case NILFS_CPFILE_INO:\n+    case NILFS_SUFILE_INO:\n+        bmap->b_pops = &nilfs_bmap_ptr_ops_p;\n+        lockdep_set_class(&bmap->b_sem, &nilfs_bmap_mdt_lock_key);\n+        break;\n+    case NILFS_IFILE_INO:\n+        lockdep_set_class(&bmap->b_sem, &nilfs_bmap_mdt_lock_key);\n+        /* Fall through */\n+    default:\n+        bmap->b_pops = &nilfs_bmap_ptr_ops_vm;\n+        lockdep_set_class(&bmap->b_sem, &nilfs_bmap_default_lock_key);\n+        bmap->b_last_allocated_key = 0;\n+        bmap->b_last_allocated_ptr = NILFS_BMAP_NEW_PTR_INIT;\n+        break;\n+    }\n+\n+    return 0;\n }\n \n /**\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/nilfs2/bmap.c b/fs/nilfs2/bmap.c\nindex 798a2c1b38c6..f9673000ed69 100644\n--- a/fs/nilfs2/bmap.c\n+++ b/fs/nilfs2/bmap.c\n@@ -496,22 +496,15 @@ static struct lock_class_key nilfs_bmap_mdt_lock_key;\n int nilfs_bmap_read(struct nilfs_bmap *bmap, struct nilfs_inode *raw_inode)\n {\n \tif (raw_inode == NULL)\n-\t\tmemset(bmap->b_u.u_data, 0, NILFS_BMAP_SIZE);\n-\telse\n-\t\tmemcpy(bmap->b_u.u_data, raw_inode->i_bmap, NILFS_BMAP_SIZE);\n+\t\treturn -EINVAL;\n \n+\tmemcpy(bmap->b_u.u_data, raw_inode->i_bmap, NILFS_BMAP_SIZE);\n \tinit_rwsem(&bmap->b_sem);\n \tbmap->b_state = 0;\n \tbmap->b_inode = &NILFS_BMAP_I(bmap)->vfs_inode;\n-\tswitch (bmap->b_inode->i_ino) {\n-\tcase NILFS_DAT_INO:\n-\t\tbmap->b_ptr_type = NILFS_BMAP_PTR_P;\n-\t\tbmap->b_last_allocated_key = 0;\n-\t\tbmap->b_last_allocated_ptr = NILFS_BMAP_NEW_PTR_INIT;\n-\t\tlockdep_set_class(&bmap->b_sem, &nilfs_bmap_dat_lock_key);\n-\t\tbreak;\n-\tcase NILFS_CPFILE_INO:\n-\tcase NILFS_SUFILE_INO:\n+\n+\tswitch (raw_inode->i_bmap_type) {\n+\tcase NILFS_BMAP_TYPE_VS:\n \t\tbmap->b_ptr_type = NILFS_BMAP_PTR_VS;\n \t\tbmap->b_last_allocated_key = 0;\n \t\tbmap->b_last_allocated_ptr = NILFS_BMAP_INVALID_PTR;\n@@ -519,16 +512,16 @@ int nilfs_bmap_read(struct nilfs_bmap *bmap, struct nilfs_inode *raw_inode)\n \t\tbreak;\n \tcase NILFS_IFILE_INO:\n \t\tlockdep_set_class(&bmap->b_sem, &nilfs_bmap_mdt_lock_key);\n-\t\tfallthrough;\n+\t\t/* Fall through */\n \tdefault:\n \t\tbmap->b_ptr_type = NILFS_BMAP_PTR_VM;\n \t\tbmap->b_last_allocated_key = 0;\n-\t\tbmap->b_last_allocated_ptr = NILFS_BMAP_INVALID_PTR;\n+\t\tbmap->b_last_allocated_ptr = NILFS_BMAP_NEW_PTR_INIT;\n+\t\tlockdep_set_class(&bmap->b_sem, &nilfs_bmap_dat_lock_key);\n \t\tbreak;\n \t}\n \n-\treturn (bmap->b_u.u_flags & NILFS_BMAP_LARGE) ?\n-\t\tnilfs_btree_init(bmap) : nilfs_direct_init(bmap);\n+\treturn 0;\n }\n \n /**\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "1a351beaed9d438481f1fc96aa336a25f71a2ae1": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex fbde494444b8..158a9132e7a8 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -4742,6 +4742,7 @@ static inline void *mas_next_entry(struct ma_state *mas, unsigned long limit)\n \tenum maple_type mt;\n \n \tlast = mas->last;\n+\trcu_read_lock(); // Start RCU read-side critical section\n retry:\n \toffset = mas->offset;\n \tprev_node = mas->node;\n@@ -4760,8 +4761,10 @@ static inline void *mas_next_entry(struct ma_state *mas, unsigned long limit)\n \t\t\tgoto retry;\n \t\t}\n \n-\t\tif (likely(entry))\n+\t\tif (likely(entry)) {\n+\t\t\trcu_read_unlock(); // End RCU read-side critical section\n \t\t\treturn entry;\n+\t\t}\n \n \t\tif (unlikely((mas->index > limit)))\n \t\t\tbreak;\n@@ -4781,6 +4784,7 @@ static inline void *mas_next_entry(struct ma_state *mas, unsigned long limit)\n \tmas->index = mas->last = limit;\n \tmas->offset = offset;\n \tmas->node = prev_node;\n+\trcu_read_unlock(); // End RCU read-side critical section\n \treturn NULL;\n }\n \n",
            "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex fbde494444b8..ed504d4567e6 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -4734,54 +4734,54 @@ static inline void mas_rewalk(struct ma_state *mas, unsigned long index)\n  */\n static inline void *mas_next_entry(struct ma_state *mas, unsigned long limit)\n {\n-\tvoid *entry = NULL;\n-\tstruct maple_enode *prev_node;\n-\tstruct maple_node *node;\n-\tunsigned char offset;\n-\tunsigned long last;\n-\tenum maple_type mt;\n-\n-\tlast = mas->last;\n+    void *entry = NULL;\n+    struct maple_enode *prev_node;\n+    struct maple_node *node;\n+    unsigned char offset;\n+    unsigned long last;\n+    enum maple_type mt;\n+\n+    last = mas->last;\n retry:\n-\toffset = mas->offset;\n-\tprev_node = mas->node;\n-\tnode = mas_mn(mas);\n-\tmt = mte_node_type(mas->node);\n-\tmas->offset++;\n-\tif (unlikely(mas->offset >= mt_slots[mt])) {\n-\t\tmas->offset = mt_slots[mt] - 1;\n-\t\tgoto next_node;\n-\t}\n-\n-\twhile (!mas_is_none(mas)) {\n-\t\tentry = mas_next_nentry(mas, node, limit, mt);\n-\t\tif (unlikely(ma_dead_node(node))) {\n-\t\t\tmas_rewalk(mas, last);\n-\t\t\tgoto retry;\n-\t\t}\n-\n-\t\tif (likely(entry))\n-\t\t\treturn entry;\n-\n-\t\tif (unlikely((mas->index > limit)))\n-\t\t\tbreak;\n+    offset = mas->offset;\n+    prev_node = mas->node;\n+    node = mas_mn(mas);\n+    mt = mte_node_type(mas->node);\n+    mas->offset++;\n+    if (unlikely(mas->offset >= mt_slots[mt])) {\n+        mas->offset = mt_slots[mt] - 1;\n+        goto next_node;\n+    }\n+\n+    while (!mas_is_none(mas)) {\n+        if (unlikely(ma_dead_node(node))) {\n+            mas_rewalk(mas, last);\n+            goto retry;\n+        }\n+\n+        entry = mas_next_nentry(mas, node, limit, mt);\n+        if (likely(entry))\n+            return entry;\n+\n+        if (unlikely((mas->index > limit)))\n+            break;\n \n next_node:\n-\t\tprev_node = mas->node;\n-\t\toffset = mas->offset;\n-\t\tif (unlikely(mas_next_node(mas, node, limit))) {\n-\t\t\tmas_rewalk(mas, last);\n-\t\t\tgoto retry;\n-\t\t}\n-\t\tmas->offset = 0;\n-\t\tnode = mas_mn(mas);\n-\t\tmt = mte_node_type(mas->node);\n-\t}\n-\n-\tmas->index = mas->last = limit;\n-\tmas->offset = offset;\n-\tmas->node = prev_node;\n-\treturn NULL;\n+        prev_node = mas->node;\n+        offset = mas->offset;\n+        if (unlikely(mas_next_node(mas, node, limit))) {\n+            mas_rewalk(mas, last);\n+            goto retry;\n+        }\n+        mas->offset = 0;\n+        node = mas_mn(mas);\n+        mt = mte_node_type(mas->node);\n+    }\n+\n+    mas->index = mas->last = limit;\n+    mas->offset = offset;\n+    mas->node = prev_node;\n+    return NULL;\n }\n \n /*\n"
        ],
        "error": [
            {
                "patch": "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex fbde494444b8..b21ee970ba0c 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -534,10 +534,11 @@ static inline struct maple_node *mte_parent(const struct maple_enode *enode)\n  */\n static inline bool ma_dead_node(const struct maple_node *node)\n {\n-\tstruct maple_node *parent = (void *)((unsigned long)\n-\t\t\t\t\t     node->parent & ~MAPLE_NODE_MASK);\n+    struct maple_node *parent = (void *)((unsigned long)\n+                                         node->parent & ~MAPLE_NODE_MASK);\n \n-\treturn (parent == node);\n+    // Enhanced check: Ensure the node is not only self-referential but also marked as dead\n+    return (parent == node) || (node->flags & MAPLE_NODE_DEAD);\n }\n /*\n  * mte_dead_node() - check if the @enode is dead.\n@@ -5739,38 +5740,34 @@ int mas_preallocate(struct ma_state *mas, void *entry, gfp_t gfp)\n  */\n void mas_destroy(struct ma_state *mas)\n {\n-\tstruct maple_alloc *node;\n-\n-\t/*\n-\t * When using mas_for_each() to insert an expected number of elements,\n-\t * it is possible that the number inserted is less than the expected\n-\t * number.  To fix an invalid final node, a check is performed here to\n-\t * rebalance the previous node with the final node.\n-\t */\n-\tif (mas->mas_flags & MA_STATE_REBALANCE) {\n-\t\tunsigned char end;\n-\n-\t\tif (mas_is_start(mas))\n-\t\t\tmas_start(mas);\n-\n-\t\tmtree_range_walk(mas);\n-\t\tend = mas_data_end(mas) + 1;\n-\t\tif (end < mt_min_slot_count(mas->node) - 1)\n-\t\t\tmas_destroy_rebalance(mas, end);\n-\n-\t\tmas->mas_flags &= ~MA_STATE_REBALANCE;\n-\t}\n-\tmas->mas_flags &= ~(MA_STATE_BULK|MA_STATE_PREALLOC);\n-\n-\twhile (mas->alloc && !((unsigned long)mas->alloc & 0x1)) {\n-\t\tnode = mas->alloc;\n-\t\tmas->alloc = node->slot[0];\n-\t\tif (node->node_count > 0)\n-\t\t\tmt_free_bulk(node->node_count,\n-\t\t\t\t     (void __rcu **)&node->slot[1]);\n-\t\tkmem_cache_free(maple_node_cache, node);\n-\t}\n-\tmas->alloc = NULL;\n+    struct maple_alloc *node;\n+\n+    if (mas->mas_flags & MA_STATE_REBALANCE) {\n+        unsigned char end;\n+\n+        if (mas_is_start(mas))\n+            mas_start(mas);\n+\n+        mtree_range_walk(mas);\n+        end = mas_data_end(mas) + 1;\n+        if (end < mt_min_slot_count(mas->node) - 1)\n+            mas_destroy_rebalance(mas, end);\n+\n+        mas->mas_flags &= ~MA_STATE_REBALANCE;\n+    }\n+    mas->mas_flags &= ~(MA_STATE_BULK|MA_STATE_PREALLOC);\n+\n+    while (mas->alloc && !((unsigned long)mas->alloc & 0x1)) {\n+        node = mas->alloc;\n+        mas->alloc = node->slot[0];\n+        if (node->node_count > 0)\n+            mt_free_bulk(node->node_count,\n+                         (void __rcu **)&node->slot[1]);\n+        // Mark node as dead before freeing\n+        node->flags |= MAPLE_NODE_DEAD;\n+        kmem_cache_free(maple_node_cache, node);\n+    }\n+    mas->alloc = NULL;\n }\n \n /*\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex fbde494444b8..120511cce278 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -5739,38 +5739,31 @@ int mas_preallocate(struct ma_state *mas, void *entry, gfp_t gfp)\n  */\n void mas_destroy(struct ma_state *mas)\n {\n-\tstruct maple_alloc *node;\n-\n-\t/*\n-\t * When using mas_for_each() to insert an expected number of elements,\n-\t * it is possible that the number inserted is less than the expected\n-\t * number.  To fix an invalid final node, a check is performed here to\n-\t * rebalance the previous node with the final node.\n-\t */\n-\tif (mas->mas_flags & MA_STATE_REBALANCE) {\n-\t\tunsigned char end;\n-\n-\t\tif (mas_is_start(mas))\n-\t\t\tmas_start(mas);\n-\n-\t\tmtree_range_walk(mas);\n-\t\tend = mas_data_end(mas) + 1;\n-\t\tif (end < mt_min_slot_count(mas->node) - 1)\n-\t\t\tmas_destroy_rebalance(mas, end);\n-\n-\t\tmas->mas_flags &= ~MA_STATE_REBALANCE;\n-\t}\n-\tmas->mas_flags &= ~(MA_STATE_BULK|MA_STATE_PREALLOC);\n-\n-\twhile (mas->alloc && !((unsigned long)mas->alloc & 0x1)) {\n-\t\tnode = mas->alloc;\n-\t\tmas->alloc = node->slot[0];\n-\t\tif (node->node_count > 0)\n-\t\t\tmt_free_bulk(node->node_count,\n-\t\t\t\t     (void __rcu **)&node->slot[1]);\n-\t\tkmem_cache_free(maple_node_cache, node);\n-\t}\n-\tmas->alloc = NULL;\n+    struct maple_alloc *node;\n+\n+    if (mas->mas_flags & MA_STATE_REBALANCE) {\n+        unsigned char end;\n+\n+        if (mas_is_start(mas))\n+            mas_start(mas);\n+\n+        mtree_range_walk(mas);\n+        end = mas_data_end(mas) + 1;\n+        if (end < mt_min_slot_count(mas->node) - 1)\n+            mas_destroy_rebalance(mas, end);\n+\n+        mas->mas_flags &= ~MA_STATE_REBALANCE;\n+    }\n+    mas->mas_flags &= ~(MA_STATE_BULK|MA_STATE_PREALLOC);\n+\n+    while (mas->alloc && !((unsigned long)mas->alloc & 0x1)) {\n+        node = mas->alloc;\n+        mas->alloc = node->slot[0];\n+        if (node->node_count > 0)\n+            mt_free_bulk(node->node_count, (void __rcu **)&node->slot[1]);\n+        call_rcu(&node->rcu, mt_free_rcu);\n+    }\n+    mas->alloc = NULL;\n }\n \n /*\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/lib/maple_tree.c b/lib/maple_tree.c\nindex fbde494444b8..e478026fe03f 100644\n--- a/lib/maple_tree.c\n+++ b/lib/maple_tree.c\n@@ -4734,54 +4734,54 @@ static inline void mas_rewalk(struct ma_state *mas, unsigned long index)\n  */\n static inline void *mas_next_entry(struct ma_state *mas, unsigned long limit)\n {\n-\tvoid *entry = NULL;\n-\tstruct maple_enode *prev_node;\n-\tstruct maple_node *node;\n-\tunsigned char offset;\n-\tunsigned long last;\n-\tenum maple_type mt;\n-\n-\tlast = mas->last;\n+    void *entry = NULL;\n+    struct maple_enode *prev_node;\n+    struct maple_node *node;\n+    unsigned char offset;\n+    unsigned long last;\n+    enum maple_type mt;\n+\n+    last = mas->last;\n retry:\n-\toffset = mas->offset;\n-\tprev_node = mas->node;\n-\tnode = mas_mn(mas);\n-\tmt = mte_node_type(mas->node);\n-\tmas->offset++;\n-\tif (unlikely(mas->offset >= mt_slots[mt])) {\n-\t\tmas->offset = mt_slots[mt] - 1;\n-\t\tgoto next_node;\n-\t}\n-\n-\twhile (!mas_is_none(mas)) {\n-\t\tentry = mas_next_nentry(mas, node, limit, mt);\n-\t\tif (unlikely(ma_dead_node(node))) {\n-\t\t\tmas_rewalk(mas, last);\n-\t\t\tgoto retry;\n-\t\t}\n-\n-\t\tif (likely(entry))\n-\t\t\treturn entry;\n-\n-\t\tif (unlikely((mas->index > limit)))\n-\t\t\tbreak;\n+    offset = mas->offset;\n+    prev_node = mas->node;\n+    node = mas_mn(mas);\n+    mt = mte_node_type(mas->node);\n+    mas->offset++;\n+    if (unlikely(mas->offset >= mt_slots[mt])) {\n+        mas->offset = mt_slots[mt] - 1;\n+        goto next_node;\n+    }\n+\n+    while (!mas_is_none(mas)) {\n+        entry = mas_next_nentry(mas, node, limit, mt);\n+        if (unlikely(ma_dead_node(node))) {\n+            mas_rewalk(mas, last);\n+            goto retry;\n+        }\n+\n+        if (likely(entry))\n+            return entry;\n+\n+        if (unlikely((mas->index > limit)))\n+            break;\n \n next_node:\n-\t\tprev_node = mas->node;\n-\t\toffset = mas->offset;\n-\t\tif (unlikely(mas_next_node(mas, node, limit))) {\n-\t\t\tmas_rewalk(mas, last);\n-\t\t\tgoto retry;\n-\t\t}\n-\t\tmas->offset = 0;\n-\t\tnode = mas_mn(mas);\n-\t\tmt = mte_node_type(mas->node);\n-\t}\n+        prev_node = mas->node;\n+        offset = mas->offset;\n+        if (unlikely(mas_next_node(mas, node, limit))) {\n+            mas_rewalk(mas, last);\n+            goto retry;\n+        }\n+        mas->offset = 0;\n+        node = mas_mn(mas);\n+        mt = mte_node_type(mas->node);\n+    }\n \n-\tmas->index = mas->last = limit;\n-\tmas->offset = offset;\n-\tmas->node = prev_node;\n-\treturn NULL;\n+    mas->index = mas->last = limit;\n+    mas->offset = offset;\n+    mas->node = prev_node;\n+    return NULL;\n }\n \n /*\n@@ -5739,38 +5739,38 @@ int mas_preallocate(struct ma_state *mas, void *entry, gfp_t gfp)\n  */\n void mas_destroy(struct ma_state *mas)\n {\n-\tstruct maple_alloc *node;\n-\n-\t/*\n-\t * When using mas_for_each() to insert an expected number of elements,\n-\t * it is possible that the number inserted is less than the expected\n-\t * number.  To fix an invalid final node, a check is performed here to\n-\t * rebalance the previous node with the final node.\n-\t */\n-\tif (mas->mas_flags & MA_STATE_REBALANCE) {\n-\t\tunsigned char end;\n-\n-\t\tif (mas_is_start(mas))\n-\t\t\tmas_start(mas);\n-\n-\t\tmtree_range_walk(mas);\n-\t\tend = mas_data_end(mas) + 1;\n-\t\tif (end < mt_min_slot_count(mas->node) - 1)\n-\t\t\tmas_destroy_rebalance(mas, end);\n-\n-\t\tmas->mas_flags &= ~MA_STATE_REBALANCE;\n-\t}\n-\tmas->mas_flags &= ~(MA_STATE_BULK|MA_STATE_PREALLOC);\n-\n-\twhile (mas->alloc && !((unsigned long)mas->alloc & 0x1)) {\n-\t\tnode = mas->alloc;\n-\t\tmas->alloc = node->slot[0];\n-\t\tif (node->node_count > 0)\n-\t\t\tmt_free_bulk(node->node_count,\n-\t\t\t\t     (void __rcu **)&node->slot[1]);\n-\t\tkmem_cache_free(maple_node_cache, node);\n-\t}\n-\tmas->alloc = NULL;\n+    struct maple_alloc *node;\n+\n+    /*\n+     * When using mas_for_each() to insert an expected number of elements,\n+     * it is possible that the number inserted is less than the expected\n+     * number.  To fix an invalid final node, a check is performed here to\n+     * rebalance the previous node with the final node.\n+     */\n+    if (mas->mas_flags & MA_STATE_REBALANCE) {\n+        unsigned char end;\n+\n+        if (mas_is_start(mas))\n+            mas_start(mas);\n+\n+        mtree_range_walk(mas);\n+        end = mas_data_end(mas) + 1;\n+        if (end < mt_min_slot_count(mas->node) - 1)\n+            mas_destroy_rebalance(mas, end);\n+\n+        mas->mas_flags &= ~MA_STATE_REBALANCE;\n+    }\n+    mas->mas_flags &= ~(MA_STATE_BULK|MA_STATE_PREALLOC);\n+\n+    while (mas->alloc && !((unsigned long)mas->alloc & 0x1)) {\n+        node = mas->alloc;\n+        mas->alloc = node->slot[0];\n+        if (node->node_count > 0)\n+            mt_free_bulk(node->node_count, (void __rcu **)&node->slot[1]);\n+        kmem_cache_free(maple_node_cache, node);\n+    }\n+    mas->alloc = NULL;\n+    mas->node = NULL; // Update mas->node to NULL after freeing nodes\n }\n \n /*\n",
                "error_message": "Failed to set up instance"
            }
        ]
    },
    "f55849742bdcdf58f6eaae61e747ac00e5c061f4": {
        "non_crash": [
            "diff --git a/mm/mprotect.c b/mm/mprotect.c\nindex 461dcbd4f21a..27ac1131471f 100644\n--- a/mm/mprotect.c\n+++ b/mm/mprotect.c\n@@ -86,23 +86,11 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \n \ttlb_change_page_size(tlb, PAGE_SIZE);\n \n-\t/*\n-\t * Can be called with only the mmap_lock for reading by\n-\t * prot_numa so we must check the pmd isn't constantly\n-\t * changing from under us from pmd_none to pmd_trans_huge\n-\t * and/or the other way around.\n-\t */\n \tif (pmd_trans_unstable(pmd))\n \t\treturn 0;\n \n-\t/*\n-\t * The pmd points to a regular pte so the pmd can't change\n-\t * from under us even if the mmap_lock is only hold for\n-\t * reading.\n-\t */\n \tpte = pte_offset_map_lock(vma->vm_mm, pmd, addr, &ptl);\n \n-\t/* Get target node for single threaded private VMAs */\n \tif (prot_numa && !(vma->vm_flags & VM_SHARED) &&\n \t    atomic_read(&vma->vm_mm->mm_users) == 1)\n \t\ttarget_node = numa_node_id();\n@@ -115,16 +103,11 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\tpte_t ptent;\n \t\t\tbool preserve_write = prot_numa && pte_write(oldpte);\n \n-\t\t\t/*\n-\t\t\t * Avoid trapping faults against the zero or KSM\n-\t\t\t * pages. See similar comment in change_huge_pmd.\n-\t\t\t */\n \t\t\tif (prot_numa) {\n \t\t\t\tstruct page *page;\n \t\t\t\tint nid;\n \t\t\t\tbool toptier;\n \n-\t\t\t\t/* Avoid TLB flush if possible */\n \t\t\t\tif (pte_protnone(oldpte))\n \t\t\t\t\tcontinue;\n \n@@ -132,32 +115,18 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tif (!page || is_zone_device_page(page) || PageKsm(page))\n \t\t\t\t\tcontinue;\n \n-\t\t\t\t/* Also skip shared copy-on-write pages */\n \t\t\t\tif (is_cow_mapping(vma->vm_flags) &&\n \t\t\t\t    page_count(page) != 1)\n \t\t\t\t\tcontinue;\n \n-\t\t\t\t/*\n-\t\t\t\t * While migration can move some dirty pages,\n-\t\t\t\t * it cannot move them all from MIGRATE_ASYNC\n-\t\t\t\t * context.\n-\t\t\t\t */\n \t\t\t\tif (page_is_file_lru(page) && PageDirty(page))\n \t\t\t\t\tcontinue;\n \n-\t\t\t\t/*\n-\t\t\t\t * Don't mess with PTEs if page is already on the node\n-\t\t\t\t * a single-threaded process is running on.\n-\t\t\t\t */\n \t\t\t\tnid = page_to_nid(page);\n \t\t\t\tif (target_node == nid)\n \t\t\t\t\tcontinue;\n \t\t\t\ttoptier = node_is_toptier(nid);\n \n-\t\t\t\t/*\n-\t\t\t\t * Skip scanning top tier node if normal numa\n-\t\t\t\t * balancing is disabled\n-\t\t\t\t */\n \t\t\t\tif (!(sysctl_numa_balancing_mode & NUMA_BALANCING_NORMAL) &&\n \t\t\t\t    toptier)\n \t\t\t\t\tcontinue;\n@@ -179,19 +148,6 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tptent = pte_clear_uffd_wp(ptent);\n \t\t\t}\n \n-\t\t\t/*\n-\t\t\t * In some writable, shared mappings, we might want\n-\t\t\t * to catch actual write access -- see\n-\t\t\t * vma_wants_writenotify().\n-\t\t\t *\n-\t\t\t * In all writable, private mappings, we have to\n-\t\t\t * properly handle COW.\n-\t\t\t *\n-\t\t\t * In both cases, we can sometimes still change PTEs\n-\t\t\t * writable and avoid the write-fault handler, for\n-\t\t\t * example, if a PTE is already dirty and no other\n-\t\t\t * COW or special handling is required.\n-\t\t\t */\n \t\t\tif ((cp_flags & MM_CP_TRY_CHANGE_WRITABLE) &&\n \t\t\t    !pte_write(ptent) &&\n \t\t\t    can_change_pte_writable(vma, addr, ptent))\n@@ -208,10 +164,6 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\tif (is_writable_migration_entry(entry)) {\n \t\t\t\tstruct page *page = pfn_swap_entry_to_page(entry);\n \n-\t\t\t\t/*\n-\t\t\t\t * A protection check is difficult so\n-\t\t\t\t * just be safe and disable write\n-\t\t\t\t */\n \t\t\t\tif (PageAnon(page))\n \t\t\t\t\tentry = make_readable_exclusive_migration_entry(\n \t\t\t\t\t\t\t     swp_offset(entry));\n@@ -223,10 +175,6 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tif (pte_swp_uffd_wp(oldpte))\n \t\t\t\t\tnewpte = pte_swp_mkuffd_wp(newpte);\n \t\t\t} else if (is_writable_device_private_entry(entry)) {\n-\t\t\t\t/*\n-\t\t\t\t * We do not preserve soft-dirtiness. See\n-\t\t\t\t * copy_one_pte() for explanation.\n-\t\t\t\t */\n \t\t\t\tentry = make_readable_device_private_entry(\n \t\t\t\t\t\t\tswp_offset(entry));\n \t\t\t\tnewpte = swp_entry_to_pte(entry);\n@@ -241,11 +189,6 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tif (pte_swp_uffd_wp(oldpte))\n \t\t\t\t\tnewpte = pte_swp_mkuffd_wp(newpte);\n \t\t\t} else if (pte_marker_entry_uffd_wp(entry)) {\n-\t\t\t\t/*\n-\t\t\t\t * If this is uffd-wp pte marker and we'd like\n-\t\t\t\t * to unprotect it, drop it; the next page\n-\t\t\t\t * fault will trigger without uffd trapping.\n-\t\t\t\t */\n \t\t\t\tif (uffd_wp_resolve) {\n \t\t\t\t\tpte_clear(vma->vm_mm, addr, pte);\n \t\t\t\t\tpages++;\n@@ -265,18 +208,13 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tpages++;\n \t\t\t}\n \t\t} else {\n-\t\t\t/* It must be an none page, or what else?.. */\n \t\t\tWARN_ON_ONCE(!pte_none(oldpte));\n \t\t\tif (unlikely(uffd_wp && !vma_is_anonymous(vma))) {\n-\t\t\t\t/*\n-\t\t\t\t * For file-backed mem, we need to be able to\n-\t\t\t\t * wr-protect a none pte, because even if the\n-\t\t\t\t * pte is none, the page/swap cache could\n-\t\t\t\t * exist.  Doing that by install a marker.\n-\t\t\t\t */\n+#ifdef CONFIG_PTE_MARKER\n \t\t\t\tset_pte_at(vma->vm_mm, addr, pte,\n \t\t\t\t\t   make_pte_marker(PTE_MARKER_UFFD_WP));\n \t\t\t\tpages++;\n+#endif\n \t\t\t}\n \t\t}\n \t} while (pte++, addr += PAGE_SIZE, addr != end);\n",
            "diff --git a/mm/mprotect.c b/mm/mprotect.c\nindex 461dcbd4f21a..27ac1131471f 100644\n--- a/mm/mprotect.c\n+++ b/mm/mprotect.c\n@@ -86,23 +86,11 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \n \ttlb_change_page_size(tlb, PAGE_SIZE);\n \n-\t/*\n-\t * Can be called with only the mmap_lock for reading by\n-\t * prot_numa so we must check the pmd isn't constantly\n-\t * changing from under us from pmd_none to pmd_trans_huge\n-\t * and/or the other way around.\n-\t */\n \tif (pmd_trans_unstable(pmd))\n \t\treturn 0;\n \n-\t/*\n-\t * The pmd points to a regular pte so the pmd can't change\n-\t * from under us even if the mmap_lock is only hold for\n-\t * reading.\n-\t */\n \tpte = pte_offset_map_lock(vma->vm_mm, pmd, addr, &ptl);\n \n-\t/* Get target node for single threaded private VMAs */\n \tif (prot_numa && !(vma->vm_flags & VM_SHARED) &&\n \t    atomic_read(&vma->vm_mm->mm_users) == 1)\n \t\ttarget_node = numa_node_id();\n@@ -115,16 +103,11 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\tpte_t ptent;\n \t\t\tbool preserve_write = prot_numa && pte_write(oldpte);\n \n-\t\t\t/*\n-\t\t\t * Avoid trapping faults against the zero or KSM\n-\t\t\t * pages. See similar comment in change_huge_pmd.\n-\t\t\t */\n \t\t\tif (prot_numa) {\n \t\t\t\tstruct page *page;\n \t\t\t\tint nid;\n \t\t\t\tbool toptier;\n \n-\t\t\t\t/* Avoid TLB flush if possible */\n \t\t\t\tif (pte_protnone(oldpte))\n \t\t\t\t\tcontinue;\n \n@@ -132,32 +115,18 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tif (!page || is_zone_device_page(page) || PageKsm(page))\n \t\t\t\t\tcontinue;\n \n-\t\t\t\t/* Also skip shared copy-on-write pages */\n \t\t\t\tif (is_cow_mapping(vma->vm_flags) &&\n \t\t\t\t    page_count(page) != 1)\n \t\t\t\t\tcontinue;\n \n-\t\t\t\t/*\n-\t\t\t\t * While migration can move some dirty pages,\n-\t\t\t\t * it cannot move them all from MIGRATE_ASYNC\n-\t\t\t\t * context.\n-\t\t\t\t */\n \t\t\t\tif (page_is_file_lru(page) && PageDirty(page))\n \t\t\t\t\tcontinue;\n \n-\t\t\t\t/*\n-\t\t\t\t * Don't mess with PTEs if page is already on the node\n-\t\t\t\t * a single-threaded process is running on.\n-\t\t\t\t */\n \t\t\t\tnid = page_to_nid(page);\n \t\t\t\tif (target_node == nid)\n \t\t\t\t\tcontinue;\n \t\t\t\ttoptier = node_is_toptier(nid);\n \n-\t\t\t\t/*\n-\t\t\t\t * Skip scanning top tier node if normal numa\n-\t\t\t\t * balancing is disabled\n-\t\t\t\t */\n \t\t\t\tif (!(sysctl_numa_balancing_mode & NUMA_BALANCING_NORMAL) &&\n \t\t\t\t    toptier)\n \t\t\t\t\tcontinue;\n@@ -179,19 +148,6 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tptent = pte_clear_uffd_wp(ptent);\n \t\t\t}\n \n-\t\t\t/*\n-\t\t\t * In some writable, shared mappings, we might want\n-\t\t\t * to catch actual write access -- see\n-\t\t\t * vma_wants_writenotify().\n-\t\t\t *\n-\t\t\t * In all writable, private mappings, we have to\n-\t\t\t * properly handle COW.\n-\t\t\t *\n-\t\t\t * In both cases, we can sometimes still change PTEs\n-\t\t\t * writable and avoid the write-fault handler, for\n-\t\t\t * example, if a PTE is already dirty and no other\n-\t\t\t * COW or special handling is required.\n-\t\t\t */\n \t\t\tif ((cp_flags & MM_CP_TRY_CHANGE_WRITABLE) &&\n \t\t\t    !pte_write(ptent) &&\n \t\t\t    can_change_pte_writable(vma, addr, ptent))\n@@ -208,10 +164,6 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\tif (is_writable_migration_entry(entry)) {\n \t\t\t\tstruct page *page = pfn_swap_entry_to_page(entry);\n \n-\t\t\t\t/*\n-\t\t\t\t * A protection check is difficult so\n-\t\t\t\t * just be safe and disable write\n-\t\t\t\t */\n \t\t\t\tif (PageAnon(page))\n \t\t\t\t\tentry = make_readable_exclusive_migration_entry(\n \t\t\t\t\t\t\t     swp_offset(entry));\n@@ -223,10 +175,6 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tif (pte_swp_uffd_wp(oldpte))\n \t\t\t\t\tnewpte = pte_swp_mkuffd_wp(newpte);\n \t\t\t} else if (is_writable_device_private_entry(entry)) {\n-\t\t\t\t/*\n-\t\t\t\t * We do not preserve soft-dirtiness. See\n-\t\t\t\t * copy_one_pte() for explanation.\n-\t\t\t\t */\n \t\t\t\tentry = make_readable_device_private_entry(\n \t\t\t\t\t\t\tswp_offset(entry));\n \t\t\t\tnewpte = swp_entry_to_pte(entry);\n@@ -241,11 +189,6 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tif (pte_swp_uffd_wp(oldpte))\n \t\t\t\t\tnewpte = pte_swp_mkuffd_wp(newpte);\n \t\t\t} else if (pte_marker_entry_uffd_wp(entry)) {\n-\t\t\t\t/*\n-\t\t\t\t * If this is uffd-wp pte marker and we'd like\n-\t\t\t\t * to unprotect it, drop it; the next page\n-\t\t\t\t * fault will trigger without uffd trapping.\n-\t\t\t\t */\n \t\t\t\tif (uffd_wp_resolve) {\n \t\t\t\t\tpte_clear(vma->vm_mm, addr, pte);\n \t\t\t\t\tpages++;\n@@ -265,18 +208,13 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tpages++;\n \t\t\t}\n \t\t} else {\n-\t\t\t/* It must be an none page, or what else?.. */\n \t\t\tWARN_ON_ONCE(!pte_none(oldpte));\n \t\t\tif (unlikely(uffd_wp && !vma_is_anonymous(vma))) {\n-\t\t\t\t/*\n-\t\t\t\t * For file-backed mem, we need to be able to\n-\t\t\t\t * wr-protect a none pte, because even if the\n-\t\t\t\t * pte is none, the page/swap cache could\n-\t\t\t\t * exist.  Doing that by install a marker.\n-\t\t\t\t */\n+#ifdef CONFIG_PTE_MARKER\n \t\t\t\tset_pte_at(vma->vm_mm, addr, pte,\n \t\t\t\t\t   make_pte_marker(PTE_MARKER_UFFD_WP));\n \t\t\t\tpages++;\n+#endif\n \t\t\t}\n \t\t}\n \t} while (pte++, addr += PAGE_SIZE, addr != end);\n",
            "diff --git a/mm/mprotect.c b/mm/mprotect.c\nindex 461dcbd4f21a..ea783366fd9b 100644\n--- a/mm/mprotect.c\n+++ b/mm/mprotect.c\n@@ -86,23 +86,11 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \n \ttlb_change_page_size(tlb, PAGE_SIZE);\n \n-\t/*\n-\t * Can be called with only the mmap_lock for reading by\n-\t * prot_numa so we must check the pmd isn't constantly\n-\t * changing from under us from pmd_none to pmd_trans_huge\n-\t * and/or the other way around.\n-\t */\n \tif (pmd_trans_unstable(pmd))\n \t\treturn 0;\n \n-\t/*\n-\t * The pmd points to a regular pte so the pmd can't change\n-\t * from under us even if the mmap_lock is only hold for\n-\t * reading.\n-\t */\n \tpte = pte_offset_map_lock(vma->vm_mm, pmd, addr, &ptl);\n \n-\t/* Get target node for single threaded private VMAs */\n \tif (prot_numa && !(vma->vm_flags & VM_SHARED) &&\n \t    atomic_read(&vma->vm_mm->mm_users) == 1)\n \t\ttarget_node = numa_node_id();\n@@ -115,16 +103,11 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\tpte_t ptent;\n \t\t\tbool preserve_write = prot_numa && pte_write(oldpte);\n \n-\t\t\t/*\n-\t\t\t * Avoid trapping faults against the zero or KSM\n-\t\t\t * pages. See similar comment in change_huge_pmd.\n-\t\t\t */\n \t\t\tif (prot_numa) {\n \t\t\t\tstruct page *page;\n \t\t\t\tint nid;\n \t\t\t\tbool toptier;\n \n-\t\t\t\t/* Avoid TLB flush if possible */\n \t\t\t\tif (pte_protnone(oldpte))\n \t\t\t\t\tcontinue;\n \n@@ -132,32 +115,18 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tif (!page || is_zone_device_page(page) || PageKsm(page))\n \t\t\t\t\tcontinue;\n \n-\t\t\t\t/* Also skip shared copy-on-write pages */\n \t\t\t\tif (is_cow_mapping(vma->vm_flags) &&\n \t\t\t\t    page_count(page) != 1)\n \t\t\t\t\tcontinue;\n \n-\t\t\t\t/*\n-\t\t\t\t * While migration can move some dirty pages,\n-\t\t\t\t * it cannot move them all from MIGRATE_ASYNC\n-\t\t\t\t * context.\n-\t\t\t\t */\n \t\t\t\tif (page_is_file_lru(page) && PageDirty(page))\n \t\t\t\t\tcontinue;\n \n-\t\t\t\t/*\n-\t\t\t\t * Don't mess with PTEs if page is already on the node\n-\t\t\t\t * a single-threaded process is running on.\n-\t\t\t\t */\n \t\t\t\tnid = page_to_nid(page);\n \t\t\t\tif (target_node == nid)\n \t\t\t\t\tcontinue;\n \t\t\t\ttoptier = node_is_toptier(nid);\n \n-\t\t\t\t/*\n-\t\t\t\t * Skip scanning top tier node if normal numa\n-\t\t\t\t * balancing is disabled\n-\t\t\t\t */\n \t\t\t\tif (!(sysctl_numa_balancing_mode & NUMA_BALANCING_NORMAL) &&\n \t\t\t\t    toptier)\n \t\t\t\t\tcontinue;\n@@ -179,19 +148,6 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tptent = pte_clear_uffd_wp(ptent);\n \t\t\t}\n \n-\t\t\t/*\n-\t\t\t * In some writable, shared mappings, we might want\n-\t\t\t * to catch actual write access -- see\n-\t\t\t * vma_wants_writenotify().\n-\t\t\t *\n-\t\t\t * In all writable, private mappings, we have to\n-\t\t\t * properly handle COW.\n-\t\t\t *\n-\t\t\t * In both cases, we can sometimes still change PTEs\n-\t\t\t * writable and avoid the write-fault handler, for\n-\t\t\t * example, if a PTE is already dirty and no other\n-\t\t\t * COW or special handling is required.\n-\t\t\t */\n \t\t\tif ((cp_flags & MM_CP_TRY_CHANGE_WRITABLE) &&\n \t\t\t    !pte_write(ptent) &&\n \t\t\t    can_change_pte_writable(vma, addr, ptent))\n@@ -208,10 +164,6 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\tif (is_writable_migration_entry(entry)) {\n \t\t\t\tstruct page *page = pfn_swap_entry_to_page(entry);\n \n-\t\t\t\t/*\n-\t\t\t\t * A protection check is difficult so\n-\t\t\t\t * just be safe and disable write\n-\t\t\t\t */\n \t\t\t\tif (PageAnon(page))\n \t\t\t\t\tentry = make_readable_exclusive_migration_entry(\n \t\t\t\t\t\t\t     swp_offset(entry));\n@@ -223,10 +175,6 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tif (pte_swp_uffd_wp(oldpte))\n \t\t\t\t\tnewpte = pte_swp_mkuffd_wp(newpte);\n \t\t\t} else if (is_writable_device_private_entry(entry)) {\n-\t\t\t\t/*\n-\t\t\t\t * We do not preserve soft-dirtiness. See\n-\t\t\t\t * copy_one_pte() for explanation.\n-\t\t\t\t */\n \t\t\t\tentry = make_readable_device_private_entry(\n \t\t\t\t\t\t\tswp_offset(entry));\n \t\t\t\tnewpte = swp_entry_to_pte(entry);\n@@ -241,11 +189,6 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tif (pte_swp_uffd_wp(oldpte))\n \t\t\t\t\tnewpte = pte_swp_mkuffd_wp(newpte);\n \t\t\t} else if (pte_marker_entry_uffd_wp(entry)) {\n-\t\t\t\t/*\n-\t\t\t\t * If this is uffd-wp pte marker and we'd like\n-\t\t\t\t * to unprotect it, drop it; the next page\n-\t\t\t\t * fault will trigger without uffd trapping.\n-\t\t\t\t */\n \t\t\t\tif (uffd_wp_resolve) {\n \t\t\t\t\tpte_clear(vma->vm_mm, addr, pte);\n \t\t\t\t\tpages++;\n@@ -265,18 +208,13 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tpages++;\n \t\t\t}\n \t\t} else {\n-\t\t\t/* It must be an none page, or what else?.. */\n \t\t\tWARN_ON_ONCE(!pte_none(oldpte));\n \t\t\tif (unlikely(uffd_wp && !vma_is_anonymous(vma))) {\n-\t\t\t\t/*\n-\t\t\t\t * For file-backed mem, we need to be able to\n-\t\t\t\t * wr-protect a none pte, because even if the\n-\t\t\t\t * pte is none, the page/swap cache could\n-\t\t\t\t * exist.  Doing that by install a marker.\n-\t\t\t\t */\n+\t\t\t\t#ifdef CONFIG_PTE_MARKER\n \t\t\t\tset_pte_at(vma->vm_mm, addr, pte,\n \t\t\t\t\t   make_pte_marker(PTE_MARKER_UFFD_WP));\n \t\t\t\tpages++;\n+\t\t\t\t#endif\n \t\t\t}\n \t\t}\n \t} while (pte++, addr += PAGE_SIZE, addr != end);\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/mprotect.c b/mm/mprotect.c\nindex 461dcbd4f21a..24699baded04 100644\n--- a/mm/mprotect.c\n+++ b/mm/mprotect.c\n@@ -86,23 +86,11 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \n \ttlb_change_page_size(tlb, PAGE_SIZE);\n \n-\t/*\n-\t * Can be called with only the mmap_lock for reading by\n-\t * prot_numa so we must check the pmd isn't constantly\n-\t * changing from under us from pmd_none to pmd_trans_huge\n-\t * and/or the other way around.\n-\t */\n \tif (pmd_trans_unstable(pmd))\n \t\treturn 0;\n \n-\t/*\n-\t * The pmd points to a regular pte so the pmd can't change\n-\t * from under us even if the mmap_lock is only hold for\n-\t * reading.\n-\t */\n \tpte = pte_offset_map_lock(vma->vm_mm, pmd, addr, &ptl);\n \n-\t/* Get target node for single threaded private VMAs */\n \tif (prot_numa && !(vma->vm_flags & VM_SHARED) &&\n \t    atomic_read(&vma->vm_mm->mm_users) == 1)\n \t\ttarget_node = numa_node_id();\n@@ -115,16 +103,11 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\tpte_t ptent;\n \t\t\tbool preserve_write = prot_numa && pte_write(oldpte);\n \n-\t\t\t/*\n-\t\t\t * Avoid trapping faults against the zero or KSM\n-\t\t\t * pages. See similar comment in change_huge_pmd.\n-\t\t\t */\n \t\t\tif (prot_numa) {\n \t\t\t\tstruct page *page;\n \t\t\t\tint nid;\n \t\t\t\tbool toptier;\n \n-\t\t\t\t/* Avoid TLB flush if possible */\n \t\t\t\tif (pte_protnone(oldpte))\n \t\t\t\t\tcontinue;\n \n@@ -132,32 +115,18 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tif (!page || is_zone_device_page(page) || PageKsm(page))\n \t\t\t\t\tcontinue;\n \n-\t\t\t\t/* Also skip shared copy-on-write pages */\n \t\t\t\tif (is_cow_mapping(vma->vm_flags) &&\n \t\t\t\t    page_count(page) != 1)\n \t\t\t\t\tcontinue;\n \n-\t\t\t\t/*\n-\t\t\t\t * While migration can move some dirty pages,\n-\t\t\t\t * it cannot move them all from MIGRATE_ASYNC\n-\t\t\t\t * context.\n-\t\t\t\t */\n \t\t\t\tif (page_is_file_lru(page) && PageDirty(page))\n \t\t\t\t\tcontinue;\n \n-\t\t\t\t/*\n-\t\t\t\t * Don't mess with PTEs if page is already on the node\n-\t\t\t\t * a single-threaded process is running on.\n-\t\t\t\t */\n \t\t\t\tnid = page_to_nid(page);\n \t\t\t\tif (target_node == nid)\n \t\t\t\t\tcontinue;\n \t\t\t\ttoptier = node_is_toptier(nid);\n \n-\t\t\t\t/*\n-\t\t\t\t * Skip scanning top tier node if normal numa\n-\t\t\t\t * balancing is disabled\n-\t\t\t\t */\n \t\t\t\tif (!(sysctl_numa_balancing_mode & NUMA_BALANCING_NORMAL) &&\n \t\t\t\t    toptier)\n \t\t\t\t\tcontinue;\n@@ -179,19 +148,6 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tptent = pte_clear_uffd_wp(ptent);\n \t\t\t}\n \n-\t\t\t/*\n-\t\t\t * In some writable, shared mappings, we might want\n-\t\t\t * to catch actual write access -- see\n-\t\t\t * vma_wants_writenotify().\n-\t\t\t *\n-\t\t\t * In all writable, private mappings, we have to\n-\t\t\t * properly handle COW.\n-\t\t\t *\n-\t\t\t * In both cases, we can sometimes still change PTEs\n-\t\t\t * writable and avoid the write-fault handler, for\n-\t\t\t * example, if a PTE is already dirty and no other\n-\t\t\t * COW or special handling is required.\n-\t\t\t */\n \t\t\tif ((cp_flags & MM_CP_TRY_CHANGE_WRITABLE) &&\n \t\t\t    !pte_write(ptent) &&\n \t\t\t    can_change_pte_writable(vma, addr, ptent))\n@@ -208,10 +164,6 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\tif (is_writable_migration_entry(entry)) {\n \t\t\t\tstruct page *page = pfn_swap_entry_to_page(entry);\n \n-\t\t\t\t/*\n-\t\t\t\t * A protection check is difficult so\n-\t\t\t\t * just be safe and disable write\n-\t\t\t\t */\n \t\t\t\tif (PageAnon(page))\n \t\t\t\t\tentry = make_readable_exclusive_migration_entry(\n \t\t\t\t\t\t\t     swp_offset(entry));\n@@ -223,10 +175,6 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tif (pte_swp_uffd_wp(oldpte))\n \t\t\t\t\tnewpte = pte_swp_mkuffd_wp(newpte);\n \t\t\t} else if (is_writable_device_private_entry(entry)) {\n-\t\t\t\t/*\n-\t\t\t\t * We do not preserve soft-dirtiness. See\n-\t\t\t\t * copy_one_pte() for explanation.\n-\t\t\t\t */\n \t\t\t\tentry = make_readable_device_private_entry(\n \t\t\t\t\t\t\tswp_offset(entry));\n \t\t\t\tnewpte = swp_entry_to_pte(entry);\n@@ -241,11 +189,6 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tif (pte_swp_uffd_wp(oldpte))\n \t\t\t\t\tnewpte = pte_swp_mkuffd_wp(newpte);\n \t\t\t} else if (pte_marker_entry_uffd_wp(entry)) {\n-\t\t\t\t/*\n-\t\t\t\t * If this is uffd-wp pte marker and we'd like\n-\t\t\t\t * to unprotect it, drop it; the next page\n-\t\t\t\t * fault will trigger without uffd trapping.\n-\t\t\t\t */\n \t\t\t\tif (uffd_wp_resolve) {\n \t\t\t\t\tpte_clear(vma->vm_mm, addr, pte);\n \t\t\t\t\tpages++;\n@@ -265,18 +208,15 @@ static unsigned long change_pte_range(struct mmu_gather *tlb,\n \t\t\t\tpages++;\n \t\t\t}\n \t\t} else {\n-\t\t\t/* It must be an none page, or what else?.. */\n \t\t\tWARN_ON_ONCE(!pte_none(oldpte));\n \t\t\tif (unlikely(uffd_wp && !vma_is_anonymous(vma))) {\n-\t\t\t\t/*\n-\t\t\t\t * For file-backed mem, we need to be able to\n-\t\t\t\t * wr-protect a none pte, because even if the\n-\t\t\t\t * pte is none, the page/swap cache could\n-\t\t\t\t * exist.  Doing that by install a marker.\n-\t\t\t\t */\n+#ifdef CONFIG_PTE_MARKER\n \t\t\t\tset_pte_at(vma->vm_mm, addr, pte,\n \t\t\t\t\t   make_pte_marker(PTE_MARKER_UFFD_WP));\n \t\t\t\tpages++;\n+#else\n+\t\t\t\tWARN_ON_ONCE(1);\n+#endif\n \t\t\t}\n \t\t}\n \t} while (pte++, addr += PAGE_SIZE, addr != end);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/include/linux/swapops.h b/include/linux/swapops.h\nindex 86b95ccb81bb..10d2be0ffb30 100644\n--- a/include/linux/swapops.h\n+++ b/include/linux/swapops.h\n@@ -439,8 +439,10 @@ static inline bool is_pte_marker(pte_t pte)\n static inline swp_entry_t make_pte_marker_entry(pte_marker marker)\n {\n \t/* This should never be called if !CONFIG_PTE_MARKER */\n-\tWARN_ON_ONCE(1);\n-\treturn swp_entry(0, 0);\n+\tWARN_ON_ONCE(!IS_ENABLED(CONFIG_PTE_MARKER));\n+\tif (!IS_ENABLED(CONFIG_PTE_MARKER))\n+\t\treturn swp_entry(0, 0);\n+\treturn swp_entry(SWP_PTE_MARKER, marker);\n }\n \n static inline bool is_pte_marker_entry(swp_entry_t entry)\ndiff --git a/mm/mprotect.c b/mm/mprotect.c\nindex 461dcbd4f21a..11c8f3c47858 100644\n--- a/mm/mprotect.c\n+++ b/mm/mprotect.c\n@@ -487,8 +487,13 @@ static unsigned long change_protection_range(struct mmu_gather *tlb,\n \t\tchange_prepare(vma, pgd, p4d, addr, cp_flags);\n \t\tif (pgd_none_or_clear_bad(pgd))\n \t\t\tcontinue;\n-\t\tpages += change_p4d_range(tlb, vma, pgd, addr, next, newprot,\n-\t\t\t\t\t  cp_flags);\n+\t\tif (IS_ENABLED(CONFIG_PTE_MARKER)) {\n+\t\t\tpages += change_p4d_range(tlb, vma, pgd, addr, next, newprot,\n+\t\t\t\t\t\t  cp_flags);\n+\t\t} else {\n+\t\t\t// Handle the case where PTE markers are not enabled\n+\t\t\t// Implement alternative logic or skip marker-related operations\n+\t\t}\n \t} while (pgd++, addr = next, addr != end);\n \n \ttlb_end_vma(tlb, vma);\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "75b0feac9a3f9e361fd60605e261f8a4ffef1c40": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/mm/highmem.c b/mm/highmem.c\nindex 1a692997fac4..b647544d9d4a 100644\n--- a/mm/highmem.c\n+++ b/mm/highmem.c\n@@ -363,16 +363,18 @@ void zero_user_segments(struct page *page, unsigned start1, unsigned end1,\n \t\tunsigned start2, unsigned end2)\n {\n \tunsigned int i;\n+\tvoid *kaddr = NULL;\n \n \tBUG_ON(end1 > page_size(page) || end2 > page_size(page));\n \n-\tif (start1 >= end1)\n-\t\tstart1 = end1 = 0;\n-\tif (start2 >= end2)\n-\t\tstart2 = end2 = 0;\n-\n \tfor (i = 0; i < compound_nr(page); i++) {\n-\t\tvoid *kaddr = NULL;\n+\t\tif (start1 < PAGE_SIZE || start2 < PAGE_SIZE)\n+\t\t\tkaddr = kmap_local_page(page + i);\n+\n+\t\tif (!kaddr) {\n+\t\t\tprintk(KERN_ERR \"Failed to map page address\\n\");\n+\t\t\treturn;\n+\t\t}\n \n \t\tif (start1 >= PAGE_SIZE) {\n \t\t\tstart1 -= PAGE_SIZE;\n@@ -380,10 +382,8 @@ void zero_user_segments(struct page *page, unsigned start1, unsigned end1,\n \t\t} else {\n \t\t\tunsigned this_end = min_t(unsigned, end1, PAGE_SIZE);\n \n-\t\t\tif (end1 > start1) {\n-\t\t\t\tkaddr = kmap_local_page(page + i);\n+\t\t\tif (end1 > start1)\n \t\t\t\tmemset(kaddr + start1, 0, this_end - start1);\n-\t\t\t}\n \t\t\tend1 -= this_end;\n \t\t\tstart1 = 0;\n \t\t}\n",
            "diff --git a/mm/truncate.c b/mm/truncate.c\nindex ab50d0d59a2a..58997162e729 100644\n--- a/mm/truncate.c\n+++ b/mm/truncate.c\n@@ -210,42 +210,46 @@ int truncate_inode_folio(struct address_space *mapping, struct folio *folio)\n  */\n bool truncate_inode_partial_folio(struct folio *folio, loff_t start, loff_t end)\n {\n-\tloff_t pos = folio_pos(folio);\n-\tunsigned int offset, length;\n-\n-\tif (pos < start)\n-\t\toffset = start - pos;\n-\telse\n-\t\toffset = 0;\n-\tlength = folio_size(folio);\n-\tif (pos + length <= (u64)end)\n-\t\tlength = length - offset;\n-\telse\n-\t\tlength = end + 1 - pos - offset;\n-\n-\tfolio_wait_writeback(folio);\n-\tif (length == folio_size(folio)) {\n-\t\ttruncate_inode_folio(folio->mapping, folio);\n-\t\treturn true;\n-\t}\n-\n-\t/*\n-\t * We may be zeroing pages we're about to discard, but it avoids\n-\t * doing a complex calculation here, and then doing the zeroing\n-\t * anyway if the page split fails.\n-\t */\n-\tfolio_zero_range(folio, offset, length);\n-\n-\tif (folio_has_private(folio))\n-\t\tfolio_invalidate(folio, offset, length);\n-\tif (!folio_test_large(folio))\n-\t\treturn true;\n-\tif (split_huge_page(&folio->page) == 0)\n-\t\treturn true;\n-\tif (folio_test_dirty(folio))\n-\t\treturn false;\n-\ttruncate_inode_folio(folio->mapping, folio);\n-\treturn true;\n+    loff_t pos = folio_pos(folio);\n+    unsigned int offset, length;\n+\n+    if (pos < start)\n+        offset = start - pos;\n+    else\n+        offset = 0;\n+    length = folio_size(folio);\n+    if (pos + length <= (u64)end)\n+        length = length - offset;\n+    else\n+        length = end + 1 - pos - offset;\n+\n+    folio_wait_writeback(folio);\n+    if (length > folio_size(folio)) {\n+        length = folio_size(folio) - offset;\n+    }\n+\n+    if (length == folio_size(folio)) {\n+        truncate_inode_folio(folio->mapping, folio);\n+        return true;\n+    }\n+\n+    /*\n+     * We may be zeroing pages we're about to discard, but it avoids\n+     * doing a complex calculation here, and then doing the zeroing\n+     * anyway if the page split fails.\n+     */\n+    folio_zero_range(folio, offset, length);\n+\n+    if (folio_has_private(folio))\n+        folio_invalidate(folio, offset, length);\n+    if (!folio_test_large(folio))\n+        return true;\n+    if (split_huge_page(&folio->page) == 0)\n+        return true;\n+    if (folio_test_dirty(folio))\n+        return false;\n+    truncate_inode_folio(folio->mapping, folio);\n+    return true;\n }\n \n /*\n",
            "diff --git a/mm/truncate.c b/mm/truncate.c\nindex ab50d0d59a2a..affa52b3b131 100644\n--- a/mm/truncate.c\n+++ b/mm/truncate.c\n@@ -223,6 +223,10 @@ bool truncate_inode_partial_folio(struct folio *folio, loff_t start, loff_t end)\n \telse\n \t\tlength = end + 1 - pos - offset;\n \n+\t// Ensure length does not exceed the folio size\n+\tif (length > folio_size(folio))\n+\t\tlength = folio_size(folio);\n+\n \tfolio_wait_writeback(folio);\n \tif (length == folio_size(folio)) {\n \t\ttruncate_inode_folio(folio->mapping, folio);\n",
            "diff --git a/mm/truncate.c b/mm/truncate.c\nindex ab50d0d59a2a..3a2a694937fd 100644\n--- a/mm/truncate.c\n+++ b/mm/truncate.c\n@@ -210,42 +210,44 @@ int truncate_inode_folio(struct address_space *mapping, struct folio *folio)\n  */\n bool truncate_inode_partial_folio(struct folio *folio, loff_t start, loff_t end)\n {\n-\tloff_t pos = folio_pos(folio);\n-\tunsigned int offset, length;\n-\n-\tif (pos < start)\n-\t\toffset = start - pos;\n-\telse\n-\t\toffset = 0;\n-\tlength = folio_size(folio);\n-\tif (pos + length <= (u64)end)\n-\t\tlength = length - offset;\n-\telse\n-\t\tlength = end + 1 - pos - offset;\n-\n-\tfolio_wait_writeback(folio);\n-\tif (length == folio_size(folio)) {\n-\t\ttruncate_inode_folio(folio->mapping, folio);\n-\t\treturn true;\n-\t}\n-\n-\t/*\n-\t * We may be zeroing pages we're about to discard, but it avoids\n-\t * doing a complex calculation here, and then doing the zeroing\n-\t * anyway if the page split fails.\n-\t */\n-\tfolio_zero_range(folio, offset, length);\n-\n-\tif (folio_has_private(folio))\n-\t\tfolio_invalidate(folio, offset, length);\n-\tif (!folio_test_large(folio))\n-\t\treturn true;\n-\tif (split_huge_page(&folio->page) == 0)\n-\t\treturn true;\n-\tif (folio_test_dirty(folio))\n-\t\treturn false;\n-\ttruncate_inode_folio(folio->mapping, folio);\n-\treturn true;\n+    loff_t pos = folio_pos(folio);\n+    unsigned int offset, length;\n+\n+    if (pos < start)\n+        offset = start - pos;\n+    else\n+        offset = 0;\n+\n+    length = folio_size(folio);\n+    if (pos + length <= (u64)end)\n+        length = length - offset;\n+    else\n+        length = end + 1 - pos - offset;\n+\n+    // Ensure offset and length are within valid bounds\n+    if (offset >= folio_size(folio))\n+        return false;\n+    if (length > folio_size(folio) - offset)\n+        length = folio_size(folio) - offset;\n+\n+    folio_wait_writeback(folio);\n+    if (length == folio_size(folio)) {\n+        truncate_inode_folio(folio->mapping, folio);\n+        return true;\n+    }\n+\n+    folio_zero_range(folio, offset, length);\n+\n+    if (folio_has_private(folio))\n+        folio_invalidate(folio, offset, length);\n+    if (!folio_test_large(folio))\n+        return true;\n+    if (split_huge_page(&folio->page) == 0)\n+        return true;\n+    if (folio_test_dirty(folio))\n+        return false;\n+    truncate_inode_folio(folio->mapping, folio);\n+    return true;\n }\n \n /*\n",
            "diff --git a/mm/truncate.c b/mm/truncate.c\nindex ab50d0d59a2a..3a2a694937fd 100644\n--- a/mm/truncate.c\n+++ b/mm/truncate.c\n@@ -210,42 +210,44 @@ int truncate_inode_folio(struct address_space *mapping, struct folio *folio)\n  */\n bool truncate_inode_partial_folio(struct folio *folio, loff_t start, loff_t end)\n {\n-\tloff_t pos = folio_pos(folio);\n-\tunsigned int offset, length;\n-\n-\tif (pos < start)\n-\t\toffset = start - pos;\n-\telse\n-\t\toffset = 0;\n-\tlength = folio_size(folio);\n-\tif (pos + length <= (u64)end)\n-\t\tlength = length - offset;\n-\telse\n-\t\tlength = end + 1 - pos - offset;\n-\n-\tfolio_wait_writeback(folio);\n-\tif (length == folio_size(folio)) {\n-\t\ttruncate_inode_folio(folio->mapping, folio);\n-\t\treturn true;\n-\t}\n-\n-\t/*\n-\t * We may be zeroing pages we're about to discard, but it avoids\n-\t * doing a complex calculation here, and then doing the zeroing\n-\t * anyway if the page split fails.\n-\t */\n-\tfolio_zero_range(folio, offset, length);\n-\n-\tif (folio_has_private(folio))\n-\t\tfolio_invalidate(folio, offset, length);\n-\tif (!folio_test_large(folio))\n-\t\treturn true;\n-\tif (split_huge_page(&folio->page) == 0)\n-\t\treturn true;\n-\tif (folio_test_dirty(folio))\n-\t\treturn false;\n-\ttruncate_inode_folio(folio->mapping, folio);\n-\treturn true;\n+    loff_t pos = folio_pos(folio);\n+    unsigned int offset, length;\n+\n+    if (pos < start)\n+        offset = start - pos;\n+    else\n+        offset = 0;\n+\n+    length = folio_size(folio);\n+    if (pos + length <= (u64)end)\n+        length = length - offset;\n+    else\n+        length = end + 1 - pos - offset;\n+\n+    // Ensure offset and length are within valid bounds\n+    if (offset >= folio_size(folio))\n+        return false;\n+    if (length > folio_size(folio) - offset)\n+        length = folio_size(folio) - offset;\n+\n+    folio_wait_writeback(folio);\n+    if (length == folio_size(folio)) {\n+        truncate_inode_folio(folio->mapping, folio);\n+        return true;\n+    }\n+\n+    folio_zero_range(folio, offset, length);\n+\n+    if (folio_has_private(folio))\n+        folio_invalidate(folio, offset, length);\n+    if (!folio_test_large(folio))\n+        return true;\n+    if (split_huge_page(&folio->page) == 0)\n+        return true;\n+    if (folio_test_dirty(folio))\n+        return false;\n+    truncate_inode_folio(folio->mapping, folio);\n+    return true;\n }\n \n /*\n"
        ],
        "error": [
        ]
    },
    "38efa4618c3379cf98642b9379d6e340b14d2702": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 91de361ea9ab..179dc5a300b5 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -2748,70 +2748,76 @@ static inline bool io_run_task_work(void)\n \n static int io_do_iopoll(struct io_ring_ctx *ctx, bool force_nonspin)\n {\n-\tstruct io_wq_work_node *pos, *start, *prev;\n-\tunsigned int poll_flags = BLK_POLL_NOSLEEP;\n-\tDEFINE_IO_COMP_BATCH(iob);\n-\tint nr_events = 0;\n-\n-\t/*\n-\t * Only spin for completions if we don't have multiple devices hanging\n-\t * off our complete list.\n-\t */\n-\tif (ctx->poll_multi_queue || force_nonspin)\n-\t\tpoll_flags |= BLK_POLL_ONESHOT;\n-\n-\twq_list_for_each(pos, start, &ctx->iopoll_list) {\n-\t\tstruct io_kiocb *req = container_of(pos, struct io_kiocb, comp_list);\n-\t\tstruct kiocb *kiocb = &req->rw.kiocb;\n-\t\tint ret;\n-\n-\t\t/*\n-\t\t * Move completed and retryable entries to our local lists.\n-\t\t * If we find a request that requires polling, break out\n-\t\t * and complete those lists first, if we have entries there.\n-\t\t */\n-\t\tif (READ_ONCE(req->iopoll_completed))\n-\t\t\tbreak;\n-\n-\t\tret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\n-\t\tif (unlikely(ret < 0))\n-\t\t\treturn ret;\n-\t\telse if (ret)\n-\t\t\tpoll_flags |= BLK_POLL_ONESHOT;\n-\n-\t\t/* iopoll may have completed current req */\n-\t\tif (!rq_list_empty(iob.req_list) ||\n-\t\t    READ_ONCE(req->iopoll_completed))\n-\t\t\tbreak;\n-\t}\n-\n-\tif (!rq_list_empty(iob.req_list))\n-\t\tiob.complete(&iob);\n-\telse if (!pos)\n-\t\treturn 0;\n-\n-\tprev = start;\n-\twq_list_for_each_resume(pos, prev) {\n-\t\tstruct io_kiocb *req = container_of(pos, struct io_kiocb, comp_list);\n-\n-\t\t/* order with io_complete_rw_iopoll(), e.g. ->result updates */\n-\t\tif (!smp_load_acquire(&req->iopoll_completed))\n-\t\t\tbreak;\n-\t\tnr_events++;\n-\t\tif (unlikely(req->flags & REQ_F_CQE_SKIP))\n-\t\t\tcontinue;\n-\t\t__io_fill_cqe_req(req, req->result, io_put_kbuf(req, 0));\n-\t}\n-\n-\tif (unlikely(!nr_events))\n-\t\treturn 0;\n-\n-\tio_commit_cqring(ctx);\n-\tio_cqring_ev_posted_iopoll(ctx);\n-\tpos = start ? start->next : ctx->iopoll_list.first;\n-\twq_list_cut(&ctx->iopoll_list, prev, start);\n-\tio_free_batch_list(ctx, pos);\n-\treturn nr_events;\n+    struct io_wq_work_node *pos, *start, *prev;\n+    unsigned int poll_flags = BLK_POLL_NOSLEEP;\n+    DEFINE_IO_COMP_BATCH(iob);\n+    int nr_events = 0;\n+\n+    /*\n+     * Only spin for completions if we don't have multiple devices hanging\n+     * off our complete list.\n+     */\n+    if (ctx->poll_multi_queue || force_nonspin)\n+        poll_flags |= BLK_POLL_ONESHOT;\n+\n+    wq_list_for_each(pos, start, &ctx->iopoll_list) {\n+        struct io_kiocb *req = container_of(pos, struct io_kiocb, comp_list);\n+        struct kiocb *kiocb = &req->rw.kiocb;\n+        int ret;\n+\n+        /*\n+         * Ensure kiocb->ki_filp is not NULL before dereferencing\n+         */\n+        if (unlikely(!kiocb->ki_filp))\n+            return -EINVAL;\n+\n+        /*\n+         * Move completed and retryable entries to our local lists.\n+         * If we find a request that requires polling, break out\n+         * and complete those lists first, if we have entries there.\n+         */\n+        if (READ_ONCE(req->iopoll_completed))\n+            break;\n+\n+        ret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\n+        if (unlikely(ret < 0))\n+            return ret;\n+        else if (ret)\n+            poll_flags |= BLK_POLL_ONESHOT;\n+\n+        /* iopoll may have completed current req */\n+        if (!rq_list_empty(iob.req_list) ||\n+            READ_ONCE(req->iopoll_completed))\n+            break;\n+    }\n+\n+    if (!rq_list_empty(iob.req_list))\n+        iob.complete(&iob);\n+    else if (!pos)\n+        return 0;\n+\n+    prev = start;\n+    wq_list_for_each_resume(pos, prev) {\n+        struct io_kiocb *req = container_of(pos, struct io_kiocb, comp_list);\n+\n+        /* order with io_complete_rw_iopoll(), e.g. ->result updates */\n+        if (!smp_load_acquire(&req->iopoll_completed))\n+            break;\n+        nr_events++;\n+        if (unlikely(req->flags & REQ_F_CQE_SKIP))\n+            continue;\n+        __io_fill_cqe_req(req, req->result, io_put_kbuf(req, 0));\n+    }\n+\n+    if (unlikely(!nr_events))\n+        return 0;\n+\n+    io_commit_cqring(ctx);\n+    io_cqring_ev_posted_iopoll(ctx);\n+    pos = start ? start->next : ctx->iopoll_list.first;\n+    wq_list_cut(&ctx->iopoll_list, prev, start);\n+    io_free_batch_list(ctx, pos);\n+    return nr_events;\n }\n \n /*\n",
            "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 91de361ea9ab..adf60510de4e 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -2773,6 +2773,10 @@ static int io_do_iopoll(struct io_ring_ctx *ctx, bool force_nonspin)\n \t\tif (READ_ONCE(req->iopoll_completed))\n \t\t\tbreak;\n \n+\t\tif (!kiocb->ki_filp) {\n+\t\t\treturn -EBADF; // Return error if ki_filp is NULL\n+\t\t}\n+\n \t\tret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\n \t\tif (unlikely(ret < 0))\n \t\t\treturn ret;\n",
            "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 91de361ea9ab..b0e971e3839e 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -2773,6 +2773,11 @@ static int io_do_iopoll(struct io_ring_ctx *ctx, bool force_nonspin)\n \t\tif (READ_ONCE(req->iopoll_completed))\n \t\t\tbreak;\n \n+\t\tif (unlikely(!kiocb->ki_filp)) {\n+\t\t\tpr_err(\"io_do_iopoll: kiocb->ki_filp is NULL\\n\");\n+\t\t\treturn -EBADF;\n+\t\t}\n+\n \t\tret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\n \t\tif (unlikely(ret < 0))\n \t\t\treturn ret;\n",
            "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 91de361ea9ab..04e27723cc9c 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -3798,248 +3798,199 @@ static int io_rw_init_file(struct io_kiocb *req, fmode_t mode)\n \n static int io_read(struct io_kiocb *req, unsigned int issue_flags)\n {\n-\tstruct io_rw_state __s, *s = &__s;\n-\tstruct iovec *iovec;\n-\tstruct kiocb *kiocb = &req->rw.kiocb;\n-\tbool force_nonblock = issue_flags & IO_URING_F_NONBLOCK;\n-\tstruct io_async_rw *rw;\n-\tssize_t ret, ret2;\n-\tloff_t *ppos;\n-\n-\tif (!req_has_async_data(req)) {\n-\t\tret = io_import_iovec(READ, req, &iovec, s, issue_flags);\n-\t\tif (unlikely(ret < 0))\n-\t\t\treturn ret;\n-\t} else {\n-\t\t/*\n-\t\t * Safe and required to re-import if we're using provided\n-\t\t * buffers, as we dropped the selected one before retry.\n-\t\t */\n-\t\tif (req->flags & REQ_F_BUFFER_SELECT) {\n-\t\t\tret = io_import_iovec(READ, req, &iovec, s, issue_flags);\n-\t\t\tif (unlikely(ret < 0))\n-\t\t\t\treturn ret;\n-\t\t}\n-\n-\t\trw = req->async_data;\n-\t\ts = &rw->s;\n-\t\t/*\n-\t\t * We come here from an earlier attempt, restore our state to\n-\t\t * match in case it doesn't. It's cheap enough that we don't\n-\t\t * need to make this conditional.\n-\t\t */\n-\t\tiov_iter_restore(&s->iter, &s->iter_state);\n-\t\tiovec = NULL;\n-\t}\n-\tret = io_rw_init_file(req, FMODE_READ);\n-\tif (unlikely(ret)) {\n-\t\tkfree(iovec);\n-\t\treturn ret;\n-\t}\n-\treq->result = iov_iter_count(&s->iter);\n-\n-\tif (force_nonblock) {\n-\t\t/* If the file doesn't support async, just async punt */\n-\t\tif (unlikely(!io_file_supports_nowait(req))) {\n-\t\t\tret = io_setup_async_rw(req, iovec, s, true);\n-\t\t\treturn ret ?: -EAGAIN;\n-\t\t}\n-\t\tkiocb->ki_flags |= IOCB_NOWAIT;\n-\t} else {\n-\t\t/* Ensure we clear previously set non-block flag */\n-\t\tkiocb->ki_flags &= ~IOCB_NOWAIT;\n-\t}\n-\n-\tppos = io_kiocb_update_pos(req);\n-\n-\tret = rw_verify_area(READ, req->file, ppos, req->result);\n-\tif (unlikely(ret)) {\n-\t\tkfree(iovec);\n-\t\treturn ret;\n-\t}\n-\n-\tret = io_iter_do_read(req, &s->iter);\n-\n-\tif (ret == -EAGAIN || (req->flags & REQ_F_REISSUE)) {\n-\t\treq->flags &= ~REQ_F_REISSUE;\n-\t\t/* if we can poll, just do that */\n-\t\tif (req->opcode == IORING_OP_READ && file_can_poll(req->file))\n-\t\t\treturn -EAGAIN;\n-\t\t/* IOPOLL retry should happen for io-wq threads */\n-\t\tif (!force_nonblock && !(req->ctx->flags & IORING_SETUP_IOPOLL))\n-\t\t\tgoto done;\n-\t\t/* no retry on NONBLOCK nor RWF_NOWAIT */\n-\t\tif (req->flags & REQ_F_NOWAIT)\n-\t\t\tgoto done;\n-\t\tret = 0;\n-\t} else if (ret == -EIOCBQUEUED) {\n-\t\tgoto out_free;\n-\t} else if (ret == req->result || ret <= 0 || !force_nonblock ||\n-\t\t   (req->flags & REQ_F_NOWAIT) || !need_read_all(req)) {\n-\t\t/* read all, failed, already did sync or don't want to retry */\n-\t\tgoto done;\n-\t}\n-\n-\t/*\n-\t * Don't depend on the iter state matching what was consumed, or being\n-\t * untouched in case of error. Restore it and we'll advance it\n-\t * manually if we need to.\n-\t */\n-\tiov_iter_restore(&s->iter, &s->iter_state);\n-\n-\tret2 = io_setup_async_rw(req, iovec, s, true);\n-\tif (ret2)\n-\t\treturn ret2;\n-\n-\tiovec = NULL;\n-\trw = req->async_data;\n-\ts = &rw->s;\n-\t/*\n-\t * Now use our persistent iterator and state, if we aren't already.\n-\t * We've restored and mapped the iter to match.\n-\t */\n-\n-\tdo {\n-\t\t/*\n-\t\t * We end up here because of a partial read, either from\n-\t\t * above or inside this loop. Advance the iter by the bytes\n-\t\t * that were consumed.\n-\t\t */\n-\t\tiov_iter_advance(&s->iter, ret);\n-\t\tif (!iov_iter_count(&s->iter))\n-\t\t\tbreak;\n-\t\trw->bytes_done += ret;\n-\t\tiov_iter_save_state(&s->iter, &s->iter_state);\n-\n-\t\t/* if we can retry, do so with the callbacks armed */\n-\t\tif (!io_rw_should_retry(req)) {\n-\t\t\tkiocb->ki_flags &= ~IOCB_WAITQ;\n-\t\t\treturn -EAGAIN;\n-\t\t}\n-\n-\t\t/*\n-\t\t * Now retry read with the IOCB_WAITQ parts set in the iocb. If\n-\t\t * we get -EIOCBQUEUED, then we'll get a notification when the\n-\t\t * desired page gets unlocked. We can also get a partial read\n-\t\t * here, and if we do, then just retry at the new offset.\n-\t\t */\n-\t\tret = io_iter_do_read(req, &s->iter);\n-\t\tif (ret == -EIOCBQUEUED)\n-\t\t\treturn 0;\n-\t\t/* we got some bytes, but not all. retry. */\n-\t\tkiocb->ki_flags &= ~IOCB_WAITQ;\n-\t\tiov_iter_restore(&s->iter, &s->iter_state);\n-\t} while (ret > 0);\n+    struct io_rw_state __s, *s = &__s;\n+    struct iovec *iovec;\n+    struct kiocb *kiocb = &req->rw.kiocb;\n+    bool force_nonblock = issue_flags & IO_URING_F_NONBLOCK;\n+    struct io_async_rw *rw;\n+    ssize_t ret, ret2;\n+    loff_t *ppos;\n+\n+    if (!req->file)\n+        return -EBADF;\n+\n+    if (!req_has_async_data(req)) {\n+        ret = io_import_iovec(READ, req, &iovec, s, issue_flags);\n+        if (unlikely(ret < 0))\n+            return ret;\n+    } else {\n+        if (req->flags & REQ_F_BUFFER_SELECT) {\n+            ret = io_import_iovec(READ, req, &iovec, s, issue_flags);\n+            if (unlikely(ret < 0))\n+                return ret;\n+        }\n+\n+        rw = req->async_data;\n+        s = &rw->s;\n+        iov_iter_restore(&s->iter, &s->iter_state);\n+        iovec = NULL;\n+    }\n+    ret = io_rw_init_file(req, FMODE_READ);\n+    if (unlikely(ret)) {\n+        kfree(iovec);\n+        return ret;\n+    }\n+    req->result = iov_iter_count(&s->iter);\n+\n+    if (force_nonblock) {\n+        if (unlikely(!io_file_supports_nowait(req))) {\n+            ret = io_setup_async_rw(req, iovec, s, true);\n+            return ret ?: -EAGAIN;\n+        }\n+        kiocb->ki_flags |= IOCB_NOWAIT;\n+    } else {\n+        kiocb->ki_flags &= ~IOCB_NOWAIT;\n+    }\n+\n+    ppos = io_kiocb_update_pos(req);\n+\n+    ret = rw_verify_area(READ, req->file, ppos, req->result);\n+    if (unlikely(ret)) {\n+        kfree(iovec);\n+        return ret;\n+    }\n+\n+    ret = io_iter_do_read(req, &s->iter);\n+\n+    if (ret == -EAGAIN || (req->flags & REQ_F_REISSUE)) {\n+        req->flags &= ~REQ_F_REISSUE;\n+        if (req->opcode == IORING_OP_READ && file_can_poll(req->file))\n+            return -EAGAIN;\n+        if (!force_nonblock && !(req->ctx->flags & IORING_SETUP_IOPOLL))\n+            goto done;\n+        if (req->flags & REQ_F_NOWAIT)\n+            goto done;\n+        ret = 0;\n+    } else if (ret == -EIOCBQUEUED) {\n+        goto out_free;\n+    } else if (ret == req->result || ret <= 0 || !force_nonblock ||\n+               (req->flags & REQ_F_NOWAIT) || !need_read_all(req)) {\n+        goto done;\n+    }\n+\n+    iov_iter_restore(&s->iter, &s->iter_state);\n+\n+    ret2 = io_setup_async_rw(req, iovec, s, true);\n+    if (ret2)\n+        return ret2;\n+\n+    iovec = NULL;\n+    rw = req->async_data;\n+    s = &rw->s;\n+\n+    do {\n+        iov_iter_advance(&s->iter, ret);\n+        if (!iov_iter_count(&s->iter))\n+            break;\n+        rw->bytes_done += ret;\n+        iov_iter_save_state(&s->iter, &s->iter_state);\n+\n+        if (!io_rw_should_retry(req)) {\n+            kiocb->ki_flags &= ~IOCB_WAITQ;\n+            return -EAGAIN;\n+        }\n+\n+        ret = io_iter_do_read(req, &s->iter);\n+        if (ret == -EIOCBQUEUED)\n+            return 0;\n+        kiocb->ki_flags &= ~IOCB_WAITQ;\n+        iov_iter_restore(&s->iter, &s->iter_state);\n+    } while (ret > 0);\n done:\n-\tkiocb_done(req, ret, issue_flags);\n+    kiocb_done(req, ret, issue_flags);\n out_free:\n-\t/* it's faster to check here then delegate to kfree */\n-\tif (iovec)\n-\t\tkfree(iovec);\n-\treturn 0;\n+    if (iovec)\n+        kfree(iovec);\n+    return 0;\n }\n \n static int io_write(struct io_kiocb *req, unsigned int issue_flags)\n {\n-\tstruct io_rw_state __s, *s = &__s;\n-\tstruct iovec *iovec;\n-\tstruct kiocb *kiocb = &req->rw.kiocb;\n-\tbool force_nonblock = issue_flags & IO_URING_F_NONBLOCK;\n-\tssize_t ret, ret2;\n-\tloff_t *ppos;\n-\n-\tif (!req_has_async_data(req)) {\n-\t\tret = io_import_iovec(WRITE, req, &iovec, s, issue_flags);\n-\t\tif (unlikely(ret < 0))\n-\t\t\treturn ret;\n-\t} else {\n-\t\tstruct io_async_rw *rw = req->async_data;\n-\n-\t\ts = &rw->s;\n-\t\tiov_iter_restore(&s->iter, &s->iter_state);\n-\t\tiovec = NULL;\n-\t}\n-\tret = io_rw_init_file(req, FMODE_WRITE);\n-\tif (unlikely(ret)) {\n-\t\tkfree(iovec);\n-\t\treturn ret;\n-\t}\n-\treq->result = iov_iter_count(&s->iter);\n-\n-\tif (force_nonblock) {\n-\t\t/* If the file doesn't support async, just async punt */\n-\t\tif (unlikely(!io_file_supports_nowait(req)))\n-\t\t\tgoto copy_iov;\n-\n-\t\t/* file path doesn't support NOWAIT for non-direct_IO */\n-\t\tif (force_nonblock && !(kiocb->ki_flags & IOCB_DIRECT) &&\n-\t\t    (req->flags & REQ_F_ISREG))\n-\t\t\tgoto copy_iov;\n-\n-\t\tkiocb->ki_flags |= IOCB_NOWAIT;\n-\t} else {\n-\t\t/* Ensure we clear previously set non-block flag */\n-\t\tkiocb->ki_flags &= ~IOCB_NOWAIT;\n-\t}\n-\n-\tppos = io_kiocb_update_pos(req);\n-\n-\tret = rw_verify_area(WRITE, req->file, ppos, req->result);\n-\tif (unlikely(ret))\n-\t\tgoto out_free;\n-\n-\t/*\n-\t * Open-code file_start_write here to grab freeze protection,\n-\t * which will be released by another thread in\n-\t * io_complete_rw().  Fool lockdep by telling it the lock got\n-\t * released so that it doesn't complain about the held lock when\n-\t * we return to userspace.\n-\t */\n-\tif (req->flags & REQ_F_ISREG) {\n-\t\tsb_start_write(file_inode(req->file)->i_sb);\n-\t\t__sb_writers_release(file_inode(req->file)->i_sb,\n-\t\t\t\t\tSB_FREEZE_WRITE);\n-\t}\n-\tkiocb->ki_flags |= IOCB_WRITE;\n-\n-\tif (likely(req->file->f_op->write_iter))\n-\t\tret2 = call_write_iter(req->file, kiocb, &s->iter);\n-\telse if (req->file->f_op->write)\n-\t\tret2 = loop_rw_iter(WRITE, req, &s->iter);\n-\telse\n-\t\tret2 = -EINVAL;\n-\n-\tif (req->flags & REQ_F_REISSUE) {\n-\t\treq->flags &= ~REQ_F_REISSUE;\n-\t\tret2 = -EAGAIN;\n-\t}\n-\n-\t/*\n-\t * Raw bdev writes will return -EOPNOTSUPP for IOCB_NOWAIT. Just\n-\t * retry them without IOCB_NOWAIT.\n-\t */\n-\tif (ret2 == -EOPNOTSUPP && (kiocb->ki_flags & IOCB_NOWAIT))\n-\t\tret2 = -EAGAIN;\n-\t/* no retry on NONBLOCK nor RWF_NOWAIT */\n-\tif (ret2 == -EAGAIN && (req->flags & REQ_F_NOWAIT))\n-\t\tgoto done;\n-\tif (!force_nonblock || ret2 != -EAGAIN) {\n-\t\t/* IOPOLL retry should happen for io-wq threads */\n-\t\tif (ret2 == -EAGAIN && (req->ctx->flags & IORING_SETUP_IOPOLL))\n-\t\t\tgoto copy_iov;\n+    struct io_rw_state __s, *s = &__s;\n+    struct iovec *iovec;\n+    struct kiocb *kiocb = &req->rw.kiocb;\n+    bool force_nonblock = issue_flags & IO_URING_F_NONBLOCK;\n+    ssize_t ret, ret2;\n+    loff_t *ppos;\n+\n+    if (!req->file)\n+        return -EBADF;\n+\n+    if (!req_has_async_data(req)) {\n+        ret = io_import_iovec(WRITE, req, &iovec, s, issue_flags);\n+        if (unlikely(ret < 0))\n+            return ret;\n+    } else {\n+        struct io_async_rw *rw = req->async_data;\n+\n+        s = &rw->s;\n+        iov_iter_restore(&s->iter, &s->iter_state);\n+        iovec = NULL;\n+    }\n+    ret = io_rw_init_file(req, FMODE_WRITE);\n+    if (unlikely(ret)) {\n+        kfree(iovec);\n+        return ret;\n+    }\n+    req->result = iov_iter_count(&s->iter);\n+\n+    if (force_nonblock) {\n+        if (unlikely(!io_file_supports_nowait(req)))\n+            goto copy_iov;\n+\n+        if (force_nonblock && !(kiocb->ki_flags & IOCB_DIRECT) &&\n+            (req->flags & REQ_F_ISREG))\n+            goto copy_iov;\n+\n+        kiocb->ki_flags |= IOCB_NOWAIT;\n+    } else {\n+        kiocb->ki_flags &= ~IOCB_NOWAIT;\n+    }\n+\n+    ppos = io_kiocb_update_pos(req);\n+\n+    ret = rw_verify_area(WRITE, req->file, ppos, req->result);\n+    if (unlikely(ret))\n+        goto out_free;\n+\n+    if (req->flags & REQ_F_ISREG) {\n+        sb_start_write(file_inode(req->file)->i_sb);\n+        __sb_writers_release(file_inode(req->file)->i_sb,\n+                             SB_FREEZE_WRITE);\n+    }\n+    kiocb->ki_flags |= IOCB_WRITE;\n+\n+    if (likely(req->file->f_op->write_iter))\n+        ret2 = call_write_iter(req->file, kiocb, &s->iter);\n+    else if (req->file->f_op->write)\n+        ret2 = loop_rw_iter(WRITE, req, &s->iter);\n+    else\n+        ret2 = -EINVAL;\n+\n+    if (req->flags & REQ_F_REISSUE) {\n+        req->flags &= ~REQ_F_REISSUE;\n+        ret2 = -EAGAIN;\n+    }\n+\n+    if (ret2 == -EOPNOTSUPP && (kiocb->ki_flags & IOCB_NOWAIT))\n+        ret2 = -EAGAIN;\n+    if (ret2 == -EAGAIN && (req->flags & REQ_F_NOWAIT))\n+        goto done;\n+    if (!force_nonblock || ret2 != -EAGAIN) {\n+        if (ret2 == -EAGAIN && (req->ctx->flags & IORING_SETUP_IOPOLL))\n+            goto copy_iov;\n done:\n-\t\tkiocb_done(req, ret2, issue_flags);\n-\t} else {\n+        kiocb_done(req, ret2, issue_flags);\n+    } else {\n copy_iov:\n-\t\tiov_iter_restore(&s->iter, &s->iter_state);\n-\t\tret = io_setup_async_rw(req, iovec, s, false);\n-\t\treturn ret ?: -EAGAIN;\n-\t}\n+        iov_iter_restore(&s->iter, &s->iter_state);\n+        ret = io_setup_async_rw(req, iovec, s, false);\n+        return ret ?: -EAGAIN;\n+    }\n out_free:\n-\t/* it's reportedly faster than delegating the null check to kfree() */\n-\tif (iovec)\n-\t\tkfree(iovec);\n-\treturn ret;\n+    if (iovec)\n+        kfree(iovec);\n+    return ret;\n }\n \n static int io_renameat_prep(struct io_kiocb *req,\n",
            "diff --git a/fs/io_uring.c b/fs/io_uring.c\nindex 91de361ea9ab..38ec71c6f111 100644\n--- a/fs/io_uring.c\n+++ b/fs/io_uring.c\n@@ -2748,70 +2748,64 @@ static inline bool io_run_task_work(void)\n \n static int io_do_iopoll(struct io_ring_ctx *ctx, bool force_nonspin)\n {\n-\tstruct io_wq_work_node *pos, *start, *prev;\n-\tunsigned int poll_flags = BLK_POLL_NOSLEEP;\n-\tDEFINE_IO_COMP_BATCH(iob);\n-\tint nr_events = 0;\n-\n-\t/*\n-\t * Only spin for completions if we don't have multiple devices hanging\n-\t * off our complete list.\n-\t */\n-\tif (ctx->poll_multi_queue || force_nonspin)\n-\t\tpoll_flags |= BLK_POLL_ONESHOT;\n-\n-\twq_list_for_each(pos, start, &ctx->iopoll_list) {\n-\t\tstruct io_kiocb *req = container_of(pos, struct io_kiocb, comp_list);\n-\t\tstruct kiocb *kiocb = &req->rw.kiocb;\n-\t\tint ret;\n-\n-\t\t/*\n-\t\t * Move completed and retryable entries to our local lists.\n-\t\t * If we find a request that requires polling, break out\n-\t\t * and complete those lists first, if we have entries there.\n-\t\t */\n-\t\tif (READ_ONCE(req->iopoll_completed))\n-\t\t\tbreak;\n-\n-\t\tret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\n-\t\tif (unlikely(ret < 0))\n-\t\t\treturn ret;\n-\t\telse if (ret)\n-\t\t\tpoll_flags |= BLK_POLL_ONESHOT;\n-\n-\t\t/* iopoll may have completed current req */\n-\t\tif (!rq_list_empty(iob.req_list) ||\n-\t\t    READ_ONCE(req->iopoll_completed))\n-\t\t\tbreak;\n-\t}\n-\n-\tif (!rq_list_empty(iob.req_list))\n-\t\tiob.complete(&iob);\n-\telse if (!pos)\n-\t\treturn 0;\n-\n-\tprev = start;\n-\twq_list_for_each_resume(pos, prev) {\n-\t\tstruct io_kiocb *req = container_of(pos, struct io_kiocb, comp_list);\n-\n-\t\t/* order with io_complete_rw_iopoll(), e.g. ->result updates */\n-\t\tif (!smp_load_acquire(&req->iopoll_completed))\n-\t\t\tbreak;\n-\t\tnr_events++;\n-\t\tif (unlikely(req->flags & REQ_F_CQE_SKIP))\n-\t\t\tcontinue;\n-\t\t__io_fill_cqe_req(req, req->result, io_put_kbuf(req, 0));\n-\t}\n-\n-\tif (unlikely(!nr_events))\n-\t\treturn 0;\n-\n-\tio_commit_cqring(ctx);\n-\tio_cqring_ev_posted_iopoll(ctx);\n-\tpos = start ? start->next : ctx->iopoll_list.first;\n-\twq_list_cut(&ctx->iopoll_list, prev, start);\n-\tio_free_batch_list(ctx, pos);\n-\treturn nr_events;\n+    struct io_wq_work_node *pos, *start, *prev;\n+    unsigned int poll_flags = BLK_POLL_NOSLEEP;\n+    DEFINE_IO_COMP_BATCH(iob);\n+    int nr_events = 0;\n+\n+    if (ctx->poll_multi_queue || force_nonspin)\n+        poll_flags |= BLK_POLL_ONESHOT;\n+\n+    wq_list_for_each(pos, start, &ctx->iopoll_list) {\n+        struct io_kiocb *req = container_of(pos, struct io_kiocb, comp_list);\n+        struct kiocb *kiocb = &req->rw.kiocb;\n+        int ret;\n+\n+        if (READ_ONCE(req->iopoll_completed))\n+            break;\n+\n+        if (!kiocb->ki_filp) {\n+            pr_err(\"io_do_iopoll: kiocb->ki_filp is NULL\\n\");\n+            return -EINVAL;\n+        }\n+\n+        ret = kiocb->ki_filp->f_op->iopoll(kiocb, &iob, poll_flags);\n+        if (unlikely(ret < 0))\n+            return ret;\n+        else if (ret)\n+            poll_flags |= BLK_POLL_ONESHOT;\n+\n+        if (!rq_list_empty(iob.req_list) ||\n+            READ_ONCE(req->iopoll_completed))\n+            break;\n+    }\n+\n+    if (!rq_list_empty(iob.req_list))\n+        iob.complete(&iob);\n+    else if (!pos)\n+        return 0;\n+\n+    prev = start;\n+    wq_list_for_each_resume(pos, prev) {\n+        struct io_kiocb *req = container_of(pos, struct io_kiocb, comp_list);\n+\n+        if (!smp_load_acquire(&req->iopoll_completed))\n+            break;\n+        nr_events++;\n+        if (unlikely(req->flags & REQ_F_CQE_SKIP))\n+            continue;\n+        __io_fill_cqe_req(req, req->result, io_put_kbuf(req, 0));\n+    }\n+\n+    if (unlikely(!nr_events))\n+        return 0;\n+\n+    io_commit_cqring(ctx);\n+    io_cqring_ev_posted_iopoll(ctx);\n+    pos = start ? start->next : ctx->iopoll_list.first;\n+    wq_list_cut(&ctx->iopoll_list, prev, start);\n+    io_free_batch_list(ctx, pos);\n+    return nr_events;\n }\n \n /*\n"
        ],
        "error": []
    },
    "7d3c28ba3d4bf4b26e89ed1f1ca146e0223a2d36": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/security/keys/keyctl.c b/security/keys/keyctl.c\nindex 96a92a645216..71cafc904b66 100644\n--- a/security/keys/keyctl.c\n+++ b/security/keys/keyctl.c\n@@ -1819,7 +1819,7 @@ long keyctl_watch_key(key_serial_t id, int watch_queue_fd, int watch_id)\n \t\tup_write(&key->sem);\n \n \t\tif (ret == 0)\n-\t\t\twatch = NULL;\n+\t\t\twatch = NULL; // Ownership transferred, prevent double free\n \t} else {\n \t\tret = -EBADSLT;\n \t\tif (key->watchers) {\n",
            "diff --git a/security/keys/keyctl.c b/security/keys/keyctl.c\nindex 96a92a645216..7f393ad5afec 100644\n--- a/security/keys/keyctl.c\n+++ b/security/keys/keyctl.c\n@@ -1820,6 +1820,8 @@ long keyctl_watch_key(key_serial_t id, int watch_queue_fd, int watch_id)\n \n \t\tif (ret == 0)\n \t\t\twatch = NULL;\n+\t\telse\n+\t\t\tgoto err_watch; // Free watch if add_watch_to_object fails\n \t} else {\n \t\tret = -EBADSLT;\n \t\tif (key->watchers) {\n",
            "diff --git a/security/keys/keyctl.c b/security/keys/keyctl.c\nindex 96a92a645216..f9273bac14b1 100644\n--- a/security/keys/keyctl.c\n+++ b/security/keys/keyctl.c\n@@ -1819,7 +1819,9 @@ long keyctl_watch_key(key_serial_t id, int watch_queue_fd, int watch_id)\n \t\tup_write(&key->sem);\n \n \t\tif (ret == 0)\n-\t\t\twatch = NULL;\n+\t\t\twatch = NULL; // Set watch to NULL to prevent double free\n+\t\telse\n+\t\t\tgoto err_watch; // Ensure watch is freed on error\n \t} else {\n \t\tret = -EBADSLT;\n \t\tif (key->watchers) {\n",
            "diff --git a/security/keys/keyctl.c b/security/keys/keyctl.c\nindex 96a92a645216..075d229318f2 100644\n--- a/security/keys/keyctl.c\n+++ b/security/keys/keyctl.c\n@@ -1820,6 +1820,8 @@ long keyctl_watch_key(key_serial_t id, int watch_queue_fd, int watch_id)\n \n \t\tif (ret == 0)\n \t\t\twatch = NULL;\n+\t\telse\n+\t\t\tgoto err_watch; // Ensure watch is freed if add_watch_to_object fails\n \t} else {\n \t\tret = -EBADSLT;\n \t\tif (key->watchers) {\n",
            "diff --git a/security/keys/keyctl.c b/security/keys/keyctl.c\nindex 96a92a645216..c8580009a1c1 100644\n--- a/security/keys/keyctl.c\n+++ b/security/keys/keyctl.c\n@@ -1819,7 +1819,9 @@ long keyctl_watch_key(key_serial_t id, int watch_queue_fd, int watch_id)\n \t\tup_write(&key->sem);\n \n \t\tif (ret == 0)\n-\t\t\twatch = NULL;\n+\t\t\twatch = NULL; // Prevent double free\n+\t\telse\n+\t\t\tgoto err_watch; // Ensure watch is freed on failure\n \t} else {\n \t\tret = -EBADSLT;\n \t\tif (key->watchers) {\n"
        ],
        "error": []
    },
    "093e7092e01bed192b564b04528826cc6f1dbf91": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/media/platform/vivid/vivid-vid-cap.c b/drivers/media/platform/vivid/vivid-vid-cap.c\nindex 8213297ee9dc..4d73f59e0500 100644\n--- a/drivers/media/platform/vivid/vivid-vid-cap.c\n+++ b/drivers/media/platform/vivid/vivid-vid-cap.c\n@@ -1079,11 +1079,15 @@ int vidioc_g_fmt_vid_overlay(struct file *file, void *priv,\n \tif (dev->bitmap_cap == NULL)\n \t\twin->bitmap = NULL;\n \telse if (win->bitmap) {\n+\t\tif (!access_ok(VERIFY_WRITE, win->bitmap, ((compose->width + 7) / 8) * compose->height))\n+\t\t\treturn -EFAULT;\n \t\tif (copy_to_user(win->bitmap, dev->bitmap_cap,\n \t\t    ((compose->width + 7) / 8) * compose->height))\n \t\t\treturn -EFAULT;\n \t}\n \tif (clipcount && win->clips) {\n+\t\tif (!access_ok(VERIFY_WRITE, win->clips, clipcount * sizeof(dev->clips_cap[0])))\n+\t\t\treturn -EFAULT;\n \t\tif (copy_to_user(win->clips, dev->clips_cap,\n \t\t\t\t clipcount * sizeof(dev->clips_cap[0])))\n \t\t\treturn -EFAULT;\n",
            "diff --git a/drivers/media/platform/vivid/vivid-vid-cap.c b/drivers/media/platform/vivid/vivid-vid-cap.c\nindex 8213297ee9dc..8a22d93cc3a0 100644\n--- a/drivers/media/platform/vivid/vivid-vid-cap.c\n+++ b/drivers/media/platform/vivid/vivid-vid-cap.c\n@@ -1084,6 +1084,8 @@ int vidioc_g_fmt_vid_overlay(struct file *file, void *priv,\n \t\t\treturn -EFAULT;\n \t}\n \tif (clipcount && win->clips) {\n+\t\tif (dev->clips_cap == NULL)\n+\t\t\treturn -EFAULT;\n \t\tif (copy_to_user(win->clips, dev->clips_cap,\n \t\t\t\t clipcount * sizeof(dev->clips_cap[0])))\n \t\t\treturn -EFAULT;\n",
            "diff --git a/drivers/media/platform/vivid/vivid-vid-cap.c b/drivers/media/platform/vivid/vivid-vid-cap.c\nindex 8213297ee9dc..4d73f59e0500 100644\n--- a/drivers/media/platform/vivid/vivid-vid-cap.c\n+++ b/drivers/media/platform/vivid/vivid-vid-cap.c\n@@ -1079,11 +1079,15 @@ int vidioc_g_fmt_vid_overlay(struct file *file, void *priv,\n \tif (dev->bitmap_cap == NULL)\n \t\twin->bitmap = NULL;\n \telse if (win->bitmap) {\n+\t\tif (!access_ok(VERIFY_WRITE, win->bitmap, ((compose->width + 7) / 8) * compose->height))\n+\t\t\treturn -EFAULT;\n \t\tif (copy_to_user(win->bitmap, dev->bitmap_cap,\n \t\t    ((compose->width + 7) / 8) * compose->height))\n \t\t\treturn -EFAULT;\n \t}\n \tif (clipcount && win->clips) {\n+\t\tif (!access_ok(VERIFY_WRITE, win->clips, clipcount * sizeof(dev->clips_cap[0])))\n+\t\t\treturn -EFAULT;\n \t\tif (copy_to_user(win->clips, dev->clips_cap,\n \t\t\t\t clipcount * sizeof(dev->clips_cap[0])))\n \t\t\treturn -EFAULT;\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/media/platform/vivid/vivid-vid-cap.c b/drivers/media/platform/vivid/vivid-vid-cap.c\nindex 8213297ee9dc..6f436765a126 100644\n--- a/drivers/media/platform/vivid/vivid-vid-cap.c\n+++ b/drivers/media/platform/vivid/vivid-vid-cap.c\n@@ -1079,11 +1079,15 @@ int vidioc_g_fmt_vid_overlay(struct file *file, void *priv,\n \tif (dev->bitmap_cap == NULL)\n \t\twin->bitmap = NULL;\n \telse if (win->bitmap) {\n+\t\tif (!access_ok(win->bitmap, ((compose->width + 7) / 8) * compose->height))\n+\t\t\treturn -EFAULT;\n \t\tif (copy_to_user(win->bitmap, dev->bitmap_cap,\n \t\t    ((compose->width + 7) / 8) * compose->height))\n \t\t\treturn -EFAULT;\n \t}\n \tif (clipcount && win->clips) {\n+\t\tif (!access_ok(win->clips, clipcount * sizeof(dev->clips_cap[0])))\n+\t\t\treturn -EFAULT;\n \t\tif (copy_to_user(win->clips, dev->clips_cap,\n \t\t\t\t clipcount * sizeof(dev->clips_cap[0])))\n \t\t\treturn -EFAULT;\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/media/platform/vivid/vivid-vid-cap.c b/drivers/media/platform/vivid/vivid-vid-cap.c\nindex 8213297ee9dc..94848d76fccf 100644\n--- a/drivers/media/platform/vivid/vivid-vid-cap.c\n+++ b/drivers/media/platform/vivid/vivid-vid-cap.c\n@@ -1057,38 +1057,41 @@ int vidioc_enum_fmt_vid_overlay(struct file *file, void  *priv,\n \treturn 0;\n }\n \n-int vidioc_g_fmt_vid_overlay(struct file *file, void *priv,\n-\t\t\t\t\tstruct v4l2_format *f)\n+int vidioc_g_fmt_vid_overlay(struct file *file, void *priv, struct v4l2_format *f)\n {\n-\tstruct vivid_dev *dev = video_drvdata(file);\n-\tconst struct v4l2_rect *compose = &dev->compose_cap;\n-\tstruct v4l2_window *win = &f->fmt.win;\n-\tunsigned clipcount = win->clipcount;\n-\n-\tif (dev->multiplanar)\n-\t\treturn -ENOTTY;\n-\n-\twin->w.top = dev->overlay_cap_top;\n-\twin->w.left = dev->overlay_cap_left;\n-\twin->w.width = compose->width;\n-\twin->w.height = compose->height;\n-\twin->field = dev->overlay_cap_field;\n-\twin->clipcount = dev->clipcount_cap;\n-\tif (clipcount > dev->clipcount_cap)\n-\t\tclipcount = dev->clipcount_cap;\n-\tif (dev->bitmap_cap == NULL)\n-\t\twin->bitmap = NULL;\n-\telse if (win->bitmap) {\n-\t\tif (copy_to_user(win->bitmap, dev->bitmap_cap,\n-\t\t    ((compose->width + 7) / 8) * compose->height))\n-\t\t\treturn -EFAULT;\n-\t}\n-\tif (clipcount && win->clips) {\n-\t\tif (copy_to_user(win->clips, dev->clips_cap,\n-\t\t\t\t clipcount * sizeof(dev->clips_cap[0])))\n-\t\t\treturn -EFAULT;\n-\t}\n-\treturn 0;\n+    struct vivid_dev *dev = video_drvdata(file);\n+    const struct v4l2_rect *compose = &dev->compose_cap;\n+    struct v4l2_window *win = &f->fmt.win;\n+    unsigned clipcount = win->clipcount;\n+\n+    if (dev->multiplanar)\n+        return -ENOTTY;\n+\n+    win->w.top = dev->overlay_cap_top;\n+    win->w.left = dev->overlay_cap_left;\n+    win->w.width = compose->width;\n+    win->w.height = compose->height;\n+    win->field = dev->overlay_cap_field;\n+    win->clipcount = dev->clipcount_cap;\n+    if (clipcount > dev->clipcount_cap)\n+        clipcount = dev->clipcount_cap;\n+\n+    if (dev->bitmap_cap == NULL) {\n+        win->bitmap = NULL;\n+    } else if (win->bitmap) {\n+        if (!access_ok(win->bitmap, ((compose->width + 7) / 8) * compose->height))\n+            return -EFAULT;\n+        if (copy_to_user(win->bitmap, dev->bitmap_cap, ((compose->width + 7) / 8) * compose->height))\n+            return -EFAULT;\n+    }\n+\n+    if (clipcount && win->clips) {\n+        if (!access_ok(win->clips, clipcount * sizeof(dev->clips_cap[0])))\n+            return -EFAULT;\n+        if (copy_to_user(win->clips, dev->clips_cap, clipcount * sizeof(dev->clips_cap[0])))\n+            return -EFAULT;\n+    }\n+    return 0;\n }\n \n int vidioc_try_fmt_vid_overlay(struct file *file, void *priv,\n@@ -1149,40 +1152,38 @@ int vidioc_try_fmt_vid_overlay(struct file *file, void *priv,\n \treturn 0;\n }\n \n-int vidioc_s_fmt_vid_overlay(struct file *file, void *priv,\n-\t\t\t\t\tstruct v4l2_format *f)\n+int vidioc_s_fmt_vid_overlay(struct file *file, void *priv, struct v4l2_format *f)\n {\n-\tstruct vivid_dev *dev = video_drvdata(file);\n-\tconst struct v4l2_rect *compose = &dev->compose_cap;\n-\tstruct v4l2_window *win = &f->fmt.win;\n-\tint ret = vidioc_try_fmt_vid_overlay(file, priv, f);\n-\tunsigned bitmap_size = ((compose->width + 7) / 8) * compose->height;\n-\tunsigned clips_size = win->clipcount * sizeof(dev->clips_cap[0]);\n-\tvoid *new_bitmap = NULL;\n-\n-\tif (ret)\n-\t\treturn ret;\n-\n-\tif (win->bitmap) {\n-\t\tnew_bitmap = vzalloc(bitmap_size);\n-\n-\t\tif (new_bitmap == NULL)\n-\t\t\treturn -ENOMEM;\n-\t\tif (copy_from_user(new_bitmap, win->bitmap, bitmap_size)) {\n-\t\t\tvfree(new_bitmap);\n-\t\t\treturn -EFAULT;\n-\t\t}\n-\t}\n-\n-\tdev->overlay_cap_top = win->w.top;\n-\tdev->overlay_cap_left = win->w.left;\n-\tdev->overlay_cap_field = win->field;\n-\tvfree(dev->bitmap_cap);\n-\tdev->bitmap_cap = new_bitmap;\n-\tdev->clipcount_cap = win->clipcount;\n-\tif (dev->clipcount_cap)\n-\t\tmemcpy(dev->clips_cap, dev->try_clips_cap, clips_size);\n-\treturn 0;\n+    struct vivid_dev *dev = video_drvdata(file);\n+    struct v4l2_window *win = &f->fmt.win;\n+    const struct v4l2_rect *compose = &dev->compose_cap;\n+    int ret = vidioc_try_fmt_vid_overlay(file, priv, f);\n+    unsigned bitmap_size = ((compose->width + 7) / 8) * compose->height;\n+    unsigned clips_size = win->clipcount * sizeof(dev->clips_cap[0]);\n+    void *new_bitmap = NULL;\n+\n+    if (ret)\n+        return ret;\n+\n+    if (win->bitmap) {\n+        new_bitmap = kmalloc(bitmap_size, GFP_KERNEL);\n+        if (!new_bitmap)\n+            return -ENOMEM;\n+        if (copy_from_user(new_bitmap, win->bitmap, bitmap_size)) {\n+            kfree(new_bitmap);\n+            return -EFAULT;\n+        }\n+    }\n+\n+    dev->overlay_cap_top = win->w.top;\n+    dev->overlay_cap_left = win->w.left;\n+    dev->overlay_cap_field = win->field;\n+    kfree(dev->bitmap_cap);\n+    dev->bitmap_cap = new_bitmap;\n+    dev->clipcount_cap = win->clipcount;\n+    if (dev->clipcount_cap)\n+        memcpy(dev->clips_cap, dev->try_clips_cap, clips_size);\n+    return 0;\n }\n \n int vivid_vid_cap_overlay(struct file *file, void *fh, unsigned i)\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "46dd655664a8b38dbf7234683b294171a4e0142b": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/base/class.c b/drivers/base/class.c\nindex ac1808d1a2e8..98098b541caa 100644\n--- a/drivers/base/class.c\n+++ b/drivers/base/class.c\n@@ -177,46 +177,46 @@ static void klist_class_dev_put(struct klist_node *n)\n \n int class_register(const struct class *cls)\n {\n-\tstruct subsys_private *cp;\n-\tstruct lock_class_key *key;\n-\tint error;\n-\n-\tpr_debug(\"device class '%s': registering\\n\", cls->name);\n-\n-\tcp = kzalloc(sizeof(*cp), GFP_KERNEL);\n-\tif (!cp)\n-\t\treturn -ENOMEM;\n-\tklist_init(&cp->klist_devices, klist_class_dev_get, klist_class_dev_put);\n-\tINIT_LIST_HEAD(&cp->interfaces);\n-\tkset_init(&cp->glue_dirs);\n-\tkey = &cp->lock_key;\n-\tlockdep_register_key(key);\n-\t__mutex_init(&cp->mutex, \"subsys mutex\", key);\n-\terror = kobject_set_name(&cp->subsys.kobj, \"%s\", cls->name);\n-\tif (error) {\n-\t\tkfree(cp);\n-\t\treturn error;\n-\t}\n-\n-\tcp->subsys.kobj.kset = class_kset;\n-\tcp->subsys.kobj.ktype = &class_ktype;\n-\tcp->class = cls;\n-\n-\terror = kset_register(&cp->subsys);\n-\tif (error)\n-\t\tgoto err_out;\n-\n-\terror = sysfs_create_groups(&cp->subsys.kobj, cls->class_groups);\n-\tif (error) {\n-\t\tkobject_del(&cp->subsys.kobj);\n-\t\tkfree_const(cp->subsys.kobj.name);\n-\t\tgoto err_out;\n-\t}\n-\treturn 0;\n+    struct subsys_private *cp;\n+    struct lock_class_key *key;\n+    int error;\n+\n+    pr_debug(\"device class '%s': registering\\n\", cls->name);\n+\n+    cp = kzalloc(sizeof(*cp), GFP_KERNEL);\n+    if (!cp)\n+        return -ENOMEM;\n+    klist_init(&cp->klist_devices, klist_class_dev_get, klist_class_dev_put);\n+    INIT_LIST_HEAD(&cp->interfaces);\n+    kset_init(&cp->glue_dirs);\n+    key = &cp->lock_key;\n+    lockdep_register_key(key);\n+    __mutex_init(&cp->mutex, \"subsys mutex\", key);\n+    error = kobject_set_name(&cp->subsys.kobj, \"%s\", cls->name);\n+    if (error) {\n+        kfree(cp);\n+        return error;\n+    }\n+\n+    cp->subsys.kobj.kset = class_kset;\n+    cp->subsys.kobj.ktype = &class_ktype;\n+    cp->class = cls;\n+\n+    error = kset_register(&cp->subsys);\n+    if (error)\n+        goto err_out;\n+\n+    error = sysfs_create_groups(&cp->subsys.kobj, cls->class_groups);\n+    if (error) {\n+        kobject_del(&cp->subsys.kobj);\n+        kfree_const(cp->subsys.kobj.name);\n+        goto err_out;\n+    }\n+    return 0;\n \n err_out:\n-\tkfree(cp);\n-\treturn error;\n+    kfree(cp);\n+    return error;\n }\n EXPORT_SYMBOL_GPL(class_register);\n \n@@ -255,27 +255,29 @@ static void class_create_release(const struct class *cls)\n  */\n struct class *class_create(const char *name)\n {\n-\tstruct class *cls;\n-\tint retval;\n+    struct class *cls;\n+    int retval;\n \n-\tcls = kzalloc(sizeof(*cls), GFP_KERNEL);\n-\tif (!cls) {\n-\t\tretval = -ENOMEM;\n-\t\tgoto error;\n-\t}\n+    cls = kzalloc(sizeof(*cls), GFP_KERNEL);\n+    if (!cls) {\n+        retval = -ENOMEM;\n+        goto error;\n+    }\n \n-\tcls->name = name;\n-\tcls->class_release = class_create_release;\n+    cls->name = name;\n+    cls->class_release = class_create_release;\n \n-\tretval = class_register(cls);\n-\tif (retval)\n-\t\tgoto error;\n+    retval = class_register(cls);\n+    if (retval) {\n+        class_unregister(cls); // Ensure resources are freed if class_register fails\n+        goto error;\n+    }\n \n-\treturn cls;\n+    return cls;\n \n error:\n-\tkfree(cls);\n-\treturn ERR_PTR(retval);\n+    kfree(cls);\n+    return ERR_PTR(retval);\n }\n EXPORT_SYMBOL_GPL(class_create);\n \n",
            "diff --git a/drivers/base/class.c b/drivers/base/class.c\nindex ac1808d1a2e8..4c65daae495f 100644\n--- a/drivers/base/class.c\n+++ b/drivers/base/class.c\n@@ -255,27 +255,28 @@ static void class_create_release(const struct class *cls)\n  */\n struct class *class_create(const char *name)\n {\n-\tstruct class *cls;\n-\tint retval;\n+    struct class *cls;\n+    int retval;\n \n-\tcls = kzalloc(sizeof(*cls), GFP_KERNEL);\n-\tif (!cls) {\n-\t\tretval = -ENOMEM;\n-\t\tgoto error;\n-\t}\n+    cls = kzalloc(sizeof(*cls), GFP_KERNEL);\n+    if (!cls) {\n+        retval = -ENOMEM;\n+        goto error;\n+    }\n \n-\tcls->name = name;\n-\tcls->class_release = class_create_release;\n+    cls->name = name;\n+    cls->class_release = class_create_release;\n \n-\tretval = class_register(cls);\n-\tif (retval)\n-\t\tgoto error;\n+    retval = class_register(cls);\n+    if (retval)\n+        goto error_destroy;\n \n-\treturn cls;\n+    return cls;\n \n+error_destroy:\n+    class_destroy(cls);\n error:\n-\tkfree(cls);\n-\treturn ERR_PTR(retval);\n+    return ERR_PTR(retval);\n }\n EXPORT_SYMBOL_GPL(class_create);\n \ndiff --git a/drivers/usb/core/file.c b/drivers/usb/core/file.c\nindex c4ed3310e069..af806969b9e1 100644\n--- a/drivers/usb/core/file.c\n+++ b/drivers/usb/core/file.c\n@@ -74,32 +74,32 @@ static char *usb_devnode(const struct device *dev, umode_t *mode)\n \n static int init_usb_class(void)\n {\n-\tint result = 0;\n-\n-\tif (usb_class != NULL) {\n-\t\tkref_get(&usb_class->kref);\n-\t\tgoto exit;\n-\t}\n-\n-\tusb_class = kmalloc(sizeof(*usb_class), GFP_KERNEL);\n-\tif (!usb_class) {\n-\t\tresult = -ENOMEM;\n-\t\tgoto exit;\n-\t}\n-\n-\tkref_init(&usb_class->kref);\n-\tusb_class->class = class_create(\"usbmisc\");\n-\tif (IS_ERR(usb_class->class)) {\n-\t\tresult = PTR_ERR(usb_class->class);\n-\t\tprintk(KERN_ERR \"class_create failed for usb devices\\n\");\n-\t\tkfree(usb_class);\n-\t\tusb_class = NULL;\n-\t\tgoto exit;\n-\t}\n-\tusb_class->class->devnode = usb_devnode;\n+    int result = 0;\n+\n+    if (usb_class != NULL) {\n+        kref_get(&usb_class->kref);\n+        goto exit;\n+    }\n+\n+    usb_class = kmalloc(sizeof(*usb_class), GFP_KERNEL);\n+    if (!usb_class) {\n+        result = -ENOMEM;\n+        goto exit;\n+    }\n+\n+    kref_init(&usb_class->kref);\n+    usb_class->class = class_create(\"usbmisc\");\n+    if (IS_ERR(usb_class->class)) {\n+        result = PTR_ERR(usb_class->class);\n+        printk(KERN_ERR \"class_create failed for usb devices\\n\");\n+        kfree(usb_class);\n+        usb_class = NULL;\n+        goto exit;\n+    }\n+    usb_class->class->devnode = usb_devnode;\n \n exit:\n-\treturn result;\n+    return result;\n }\n \n static void release_usb_class(struct kref *kref)\n",
            "diff --git a/drivers/base/class.c b/drivers/base/class.c\nindex ac1808d1a2e8..075da781cc25 100644\n--- a/drivers/base/class.c\n+++ b/drivers/base/class.c\n@@ -177,46 +177,46 @@ static void klist_class_dev_put(struct klist_node *n)\n \n int class_register(const struct class *cls)\n {\n-\tstruct subsys_private *cp;\n-\tstruct lock_class_key *key;\n-\tint error;\n-\n-\tpr_debug(\"device class '%s': registering\\n\", cls->name);\n-\n-\tcp = kzalloc(sizeof(*cp), GFP_KERNEL);\n-\tif (!cp)\n-\t\treturn -ENOMEM;\n-\tklist_init(&cp->klist_devices, klist_class_dev_get, klist_class_dev_put);\n-\tINIT_LIST_HEAD(&cp->interfaces);\n-\tkset_init(&cp->glue_dirs);\n-\tkey = &cp->lock_key;\n-\tlockdep_register_key(key);\n-\t__mutex_init(&cp->mutex, \"subsys mutex\", key);\n-\terror = kobject_set_name(&cp->subsys.kobj, \"%s\", cls->name);\n-\tif (error) {\n-\t\tkfree(cp);\n-\t\treturn error;\n-\t}\n-\n-\tcp->subsys.kobj.kset = class_kset;\n-\tcp->subsys.kobj.ktype = &class_ktype;\n-\tcp->class = cls;\n-\n-\terror = kset_register(&cp->subsys);\n-\tif (error)\n-\t\tgoto err_out;\n-\n-\terror = sysfs_create_groups(&cp->subsys.kobj, cls->class_groups);\n-\tif (error) {\n-\t\tkobject_del(&cp->subsys.kobj);\n-\t\tkfree_const(cp->subsys.kobj.name);\n-\t\tgoto err_out;\n-\t}\n-\treturn 0;\n+    struct subsys_private *cp;\n+    struct lock_class_key *key;\n+    int error;\n+\n+    pr_debug(\"device class '%s': registering\\n\", cls->name);\n+\n+    cp = kzalloc(sizeof(*cp), GFP_KERNEL);\n+    if (!cp)\n+        return -ENOMEM;\n+    klist_init(&cp->klist_devices, klist_class_dev_get, klist_class_dev_put);\n+    INIT_LIST_HEAD(&cp->interfaces);\n+    kset_init(&cp->glue_dirs);\n+    key = &cp->lock_key;\n+    lockdep_register_key(key);\n+    __mutex_init(&cp->mutex, \"subsys mutex\", key);\n+    error = kobject_set_name(&cp->subsys.kobj, \"%s\", cls->name);\n+    if (error) {\n+        kfree(cp);\n+        return error;\n+    }\n+\n+    cp->subsys.kobj.kset = class_kset;\n+    cp->subsys.kobj.ktype = &class_ktype;\n+    cp->class = cls;\n+\n+    error = kset_register(&cp->subsys);\n+    if (error)\n+        goto err_out;\n+\n+    error = sysfs_create_groups(&cp->subsys.kobj, cls->class_groups);\n+    if (error) {\n+        kobject_del(&cp->subsys.kobj);\n+        kfree_const(cp->subsys.kobj.name);\n+        goto err_out;\n+    }\n+    return 0;\n \n err_out:\n-\tkfree(cp);\n-\treturn error;\n+    kfree(cp);\n+    return error;\n }\n EXPORT_SYMBOL_GPL(class_register);\n \n",
            "diff --git a/drivers/base/class.c b/drivers/base/class.c\nindex ac1808d1a2e8..ec0dc978a673 100644\n--- a/drivers/base/class.c\n+++ b/drivers/base/class.c\n@@ -255,27 +255,29 @@ static void class_create_release(const struct class *cls)\n  */\n struct class *class_create(const char *name)\n {\n-\tstruct class *cls;\n-\tint retval;\n+    struct class *cls;\n+    int retval;\n \n-\tcls = kzalloc(sizeof(*cls), GFP_KERNEL);\n-\tif (!cls) {\n-\t\tretval = -ENOMEM;\n-\t\tgoto error;\n-\t}\n+    cls = kzalloc(sizeof(*cls), GFP_KERNEL);\n+    if (!cls) {\n+        retval = -ENOMEM;\n+        goto error;\n+    }\n \n-\tcls->name = name;\n-\tcls->class_release = class_create_release;\n+    cls->name = name;\n+    cls->class_release = class_create_release;\n \n-\tretval = class_register(cls);\n-\tif (retval)\n-\t\tgoto error;\n+    retval = class_register(cls);\n+    if (retval) {\n+        class_unregister(cls); // Ensure subsys_private is freed\n+        goto error;\n+    }\n \n-\treturn cls;\n+    return cls;\n \n error:\n-\tkfree(cls);\n-\treturn ERR_PTR(retval);\n+    kfree(cls);\n+    return ERR_PTR(retval);\n }\n EXPORT_SYMBOL_GPL(class_create);\n \ndiff --git a/drivers/usb/core/file.c b/drivers/usb/core/file.c\nindex c4ed3310e069..af806969b9e1 100644\n--- a/drivers/usb/core/file.c\n+++ b/drivers/usb/core/file.c\n@@ -74,32 +74,32 @@ static char *usb_devnode(const struct device *dev, umode_t *mode)\n \n static int init_usb_class(void)\n {\n-\tint result = 0;\n-\n-\tif (usb_class != NULL) {\n-\t\tkref_get(&usb_class->kref);\n-\t\tgoto exit;\n-\t}\n-\n-\tusb_class = kmalloc(sizeof(*usb_class), GFP_KERNEL);\n-\tif (!usb_class) {\n-\t\tresult = -ENOMEM;\n-\t\tgoto exit;\n-\t}\n-\n-\tkref_init(&usb_class->kref);\n-\tusb_class->class = class_create(\"usbmisc\");\n-\tif (IS_ERR(usb_class->class)) {\n-\t\tresult = PTR_ERR(usb_class->class);\n-\t\tprintk(KERN_ERR \"class_create failed for usb devices\\n\");\n-\t\tkfree(usb_class);\n-\t\tusb_class = NULL;\n-\t\tgoto exit;\n-\t}\n-\tusb_class->class->devnode = usb_devnode;\n+    int result = 0;\n+\n+    if (usb_class != NULL) {\n+        kref_get(&usb_class->kref);\n+        goto exit;\n+    }\n+\n+    usb_class = kmalloc(sizeof(*usb_class), GFP_KERNEL);\n+    if (!usb_class) {\n+        result = -ENOMEM;\n+        goto exit;\n+    }\n+\n+    kref_init(&usb_class->kref);\n+    usb_class->class = class_create(\"usbmisc\");\n+    if (IS_ERR(usb_class->class)) {\n+        result = PTR_ERR(usb_class->class);\n+        printk(KERN_ERR \"class_create failed for usb devices\\n\");\n+        kfree(usb_class);\n+        usb_class = NULL;\n+        goto exit;\n+    }\n+    usb_class->class->devnode = usb_devnode;\n \n exit:\n-\treturn result;\n+    return result;\n }\n \n static void release_usb_class(struct kref *kref)\n",
            "diff --git a/drivers/base/class.c b/drivers/base/class.c\nindex ac1808d1a2e8..29f2a5c46047 100644\n--- a/drivers/base/class.c\n+++ b/drivers/base/class.c\n@@ -177,46 +177,48 @@ static void klist_class_dev_put(struct klist_node *n)\n \n int class_register(const struct class *cls)\n {\n-\tstruct subsys_private *cp;\n-\tstruct lock_class_key *key;\n-\tint error;\n-\n-\tpr_debug(\"device class '%s': registering\\n\", cls->name);\n-\n-\tcp = kzalloc(sizeof(*cp), GFP_KERNEL);\n-\tif (!cp)\n-\t\treturn -ENOMEM;\n-\tklist_init(&cp->klist_devices, klist_class_dev_get, klist_class_dev_put);\n-\tINIT_LIST_HEAD(&cp->interfaces);\n-\tkset_init(&cp->glue_dirs);\n-\tkey = &cp->lock_key;\n-\tlockdep_register_key(key);\n-\t__mutex_init(&cp->mutex, \"subsys mutex\", key);\n-\terror = kobject_set_name(&cp->subsys.kobj, \"%s\", cls->name);\n-\tif (error) {\n-\t\tkfree(cp);\n-\t\treturn error;\n-\t}\n-\n-\tcp->subsys.kobj.kset = class_kset;\n-\tcp->subsys.kobj.ktype = &class_ktype;\n-\tcp->class = cls;\n-\n-\terror = kset_register(&cp->subsys);\n-\tif (error)\n-\t\tgoto err_out;\n-\n-\terror = sysfs_create_groups(&cp->subsys.kobj, cls->class_groups);\n-\tif (error) {\n-\t\tkobject_del(&cp->subsys.kobj);\n-\t\tkfree_const(cp->subsys.kobj.name);\n-\t\tgoto err_out;\n-\t}\n-\treturn 0;\n+    struct subsys_private *cp;\n+    struct lock_class_key *key;\n+    int error;\n+\n+    pr_debug(\"device class '%s': registering\\n\", cls->name);\n+\n+    cp = kzalloc(sizeof(*cp), GFP_KERNEL);\n+    if (!cp)\n+        return -ENOMEM;\n+    klist_init(&cp->klist_devices, klist_class_dev_get, klist_class_dev_put);\n+    INIT_LIST_HEAD(&cp->interfaces);\n+    kset_init(&cp->glue_dirs);\n+    key = &cp->lock_key;\n+    lockdep_register_key(key);\n+    __mutex_init(&cp->mutex, \"subsys mutex\", key);\n+    error = kobject_set_name(&cp->subsys.kobj, \"%s\", cls->name);\n+    if (error) {\n+        subsys_put(cp);\n+        kfree(cp);\n+        return error;\n+    }\n+\n+    cp->subsys.kobj.kset = class_kset;\n+    cp->subsys.kobj.ktype = &class_ktype;\n+    cp->class = cls;\n+\n+    error = kset_register(&cp->subsys);\n+    if (error)\n+        goto err_out;\n+\n+    error = sysfs_create_groups(&cp->subsys.kobj, cls->class_groups);\n+    if (error) {\n+        kobject_del(&cp->subsys.kobj);\n+        kfree_const(cp->subsys.kobj.name);\n+        goto err_out;\n+    }\n+    return 0;\n \n err_out:\n-\tkfree(cp);\n-\treturn error;\n+    subsys_put(cp);\n+    kfree(cp);\n+    return error;\n }\n EXPORT_SYMBOL_GPL(class_register);\n \ndiff --git a/drivers/usb/core/file.c b/drivers/usb/core/file.c\nindex c4ed3310e069..a671cb0e689b 100644\n--- a/drivers/usb/core/file.c\n+++ b/drivers/usb/core/file.c\n@@ -74,32 +74,34 @@ static char *usb_devnode(const struct device *dev, umode_t *mode)\n \n static int init_usb_class(void)\n {\n-\tint result = 0;\n-\n-\tif (usb_class != NULL) {\n-\t\tkref_get(&usb_class->kref);\n-\t\tgoto exit;\n-\t}\n-\n-\tusb_class = kmalloc(sizeof(*usb_class), GFP_KERNEL);\n-\tif (!usb_class) {\n-\t\tresult = -ENOMEM;\n-\t\tgoto exit;\n-\t}\n-\n-\tkref_init(&usb_class->kref);\n-\tusb_class->class = class_create(\"usbmisc\");\n-\tif (IS_ERR(usb_class->class)) {\n-\t\tresult = PTR_ERR(usb_class->class);\n-\t\tprintk(KERN_ERR \"class_create failed for usb devices\\n\");\n-\t\tkfree(usb_class);\n-\t\tusb_class = NULL;\n-\t\tgoto exit;\n-\t}\n-\tusb_class->class->devnode = usb_devnode;\n+    int result = 0;\n+\n+    if (usb_class != NULL) {\n+        kref_get(&usb_class->kref);\n+        goto exit;\n+    }\n+\n+    usb_class = kmalloc(sizeof(*usb_class), GFP_KERNEL);\n+    if (!usb_class) {\n+        result = -ENOMEM;\n+        goto exit;\n+    }\n+\n+    kref_init(&usb_class->kref);\n+    usb_class->class = class_create(\"usbmisc\");\n+    if (IS_ERR(usb_class->class)) {\n+        result = PTR_ERR(usb_class->class);\n+        printk(KERN_ERR \"class_create failed for usb devices\\n\");\n+        kfree(usb_class);\n+        usb_class = NULL;\n+        goto exit;\n+    }\n+    usb_class->class->devnode = usb_devnode;\n \n exit:\n-\treturn result;\n+    if (result && usb_class && usb_class->class)\n+        class_destroy(usb_class->class);\n+    return result;\n }\n \n static void release_usb_class(struct kref *kref)\n"
        ],
        "error": []
    },
    "9a58b47cdbbb40f7679a00991cac436716c70192": {
        "non_crash": [
            "diff --git a/fs/udf/inode.c b/fs/udf/inode.c\nindex e077183e2ee3..7cf2caea718d 100644\n--- a/fs/udf/inode.c\n+++ b/fs/udf/inode.c\n@@ -2093,6 +2093,11 @@ int8_t udf_current_aext(struct inode *inode, struct extent_position *epos,\n \t\t\t\t\t\t\tlengthAllocDescs);\n \t}\n \n+\tif (epos->offset + sizeof(struct long_ad) > alen) {\n+\t\tpr_err(\"udf_current_aext: offset exceeds allocated length\\n\");\n+\t\treturn -1;\n+\t}\n+\n \tswitch (iinfo->i_alloc_type) {\n \tcase ICBTAG_FLAG_AD_SHORT:\n \t\tsad = udf_get_fileshortad(ptr, alen, &epos->offset, inc);\n",
            "diff --git a/fs/udf/inode.c b/fs/udf/inode.c\nindex e077183e2ee3..a76f924d50c1 100644\n--- a/fs/udf/inode.c\n+++ b/fs/udf/inode.c\n@@ -2082,14 +2082,12 @@ int8_t udf_current_aext(struct inode *inode, struct extent_position *epos,\n \t\tptr = iinfo->i_data + epos->offset -\n \t\t\tudf_file_entry_alloc_offset(inode) +\n \t\t\tiinfo->i_lenEAttr;\n-\t\talen = udf_file_entry_alloc_offset(inode) +\n-\t\t\t\t\t\t\tiinfo->i_lenAlloc;\n+\t\talen = iinfo->i_lenAlloc; // Corrected alen calculation\n \t} else {\n \t\tif (!epos->offset)\n \t\t\tepos->offset = sizeof(struct allocExtDesc);\n \t\tptr = epos->bh->b_data + epos->offset;\n-\t\talen = sizeof(struct allocExtDesc) +\n-\t\t\tle32_to_cpu(((struct allocExtDesc *)epos->bh->b_data)->\n+\t\talen = le32_to_cpu(((struct allocExtDesc *)epos->bh->b_data)->\n \t\t\t\t\t\t\tlengthAllocDescs);\n \t}\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/udf/inode.c b/fs/udf/inode.c\nindex e077183e2ee3..9e8a4abdcb40 100644\n--- a/fs/udf/inode.c\n+++ b/fs/udf/inode.c\n@@ -1225,18 +1225,6 @@ static int udf_read_inode(struct inode *inode, bool hidden_inode)\n \t\treturn -EIO;\n \t}\n \n-\t/*\n-\t * Set defaults, but the inode is still incomplete!\n-\t * Note: get_new_inode() sets the following on a new inode:\n-\t *      i_sb = sb\n-\t *      i_no = ino\n-\t *      i_flags = sb->s_flags\n-\t *      i_state = 0\n-\t * clean_inode(): zero fills and sets\n-\t *      i_count = 1\n-\t *      i_nlink = 1\n-\t *      i_op = NULL;\n-\t */\n \tbh = udf_read_ptagged(inode->i_sb, iloc, 0, &ident);\n \tif (!bh) {\n \t\tudf_err(inode->i_sb, \"(ino %lu) failed !bh\\n\", inode->i_ino);\n",
            "diff --git a/fs/udf/directory.c b/fs/udf/directory.c\nindex e7e8b30876d9..371971e7dff4 100644\n--- a/fs/udf/directory.c\n+++ b/fs/udf/directory.c\n@@ -495,22 +495,24 @@ struct short_ad *udf_get_fileshortad(uint8_t *ptr, int maxoffset, uint32_t *offs\n \n struct long_ad *udf_get_filelongad(uint8_t *ptr, int maxoffset, uint32_t *offset, int inc)\n {\n-\tstruct long_ad *la;\n+    struct long_ad *la;\n \n-\tif ((!ptr) || (!offset)) {\n-\t\tpr_err(\"%s: invalidparms\\n\", __func__);\n-\t\treturn NULL;\n-\t}\n+    if ((!ptr) || (!offset)) {\n+        pr_err(\"%s: invalidparms\\n\", __func__);\n+        return NULL;\n+    }\n \n-\tif ((*offset + sizeof(struct long_ad)) > maxoffset)\n-\t\treturn NULL;\n-\telse {\n-\t\tla = (struct long_ad *)ptr;\n-\t\tif (la->extLength == 0)\n-\t\t\treturn NULL;\n-\t}\n+    if ((*offset + sizeof(struct long_ad)) > maxoffset) {\n+        pr_err(\"%s: offset exceeds maxoffset\\n\", __func__);\n+        return NULL;\n+    }\n \n-\tif (inc)\n-\t\t*offset += sizeof(struct long_ad);\n-\treturn la;\n+    la = (struct long_ad *)(ptr + *offset);\n+    if (la->extLength == 0)\n+        return NULL;\n+\n+    if (inc)\n+        *offset += sizeof(struct long_ad);\n+\n+    return la;\n }\ndiff --git a/fs/udf/inode.c b/fs/udf/inode.c\nindex e077183e2ee3..c142eb54fd05 100644\n--- a/fs/udf/inode.c\n+++ b/fs/udf/inode.c\n@@ -2067,57 +2067,57 @@ int8_t udf_next_aext(struct inode *inode, struct extent_position *epos,\n }\n \n int8_t udf_current_aext(struct inode *inode, struct extent_position *epos,\n-\t\t\tstruct kernel_lb_addr *eloc, uint32_t *elen, int inc)\n+                        struct kernel_lb_addr *eloc, uint32_t *elen, int inc)\n {\n-\tint alen;\n-\tint8_t etype;\n-\tuint8_t *ptr;\n-\tstruct short_ad *sad;\n-\tstruct long_ad *lad;\n-\tstruct udf_inode_info *iinfo = UDF_I(inode);\n-\n-\tif (!epos->bh) {\n-\t\tif (!epos->offset)\n-\t\t\tepos->offset = udf_file_entry_alloc_offset(inode);\n-\t\tptr = iinfo->i_data + epos->offset -\n-\t\t\tudf_file_entry_alloc_offset(inode) +\n-\t\t\tiinfo->i_lenEAttr;\n-\t\talen = udf_file_entry_alloc_offset(inode) +\n-\t\t\t\t\t\t\tiinfo->i_lenAlloc;\n-\t} else {\n-\t\tif (!epos->offset)\n-\t\t\tepos->offset = sizeof(struct allocExtDesc);\n-\t\tptr = epos->bh->b_data + epos->offset;\n-\t\talen = sizeof(struct allocExtDesc) +\n-\t\t\tle32_to_cpu(((struct allocExtDesc *)epos->bh->b_data)->\n-\t\t\t\t\t\t\tlengthAllocDescs);\n-\t}\n-\n-\tswitch (iinfo->i_alloc_type) {\n-\tcase ICBTAG_FLAG_AD_SHORT:\n-\t\tsad = udf_get_fileshortad(ptr, alen, &epos->offset, inc);\n-\t\tif (!sad)\n-\t\t\treturn -1;\n-\t\tetype = le32_to_cpu(sad->extLength) >> 30;\n-\t\teloc->logicalBlockNum = le32_to_cpu(sad->extPosition);\n-\t\teloc->partitionReferenceNum =\n-\t\t\t\tiinfo->i_location.partitionReferenceNum;\n-\t\t*elen = le32_to_cpu(sad->extLength) & UDF_EXTENT_LENGTH_MASK;\n-\t\tbreak;\n-\tcase ICBTAG_FLAG_AD_LONG:\n-\t\tlad = udf_get_filelongad(ptr, alen, &epos->offset, inc);\n-\t\tif (!lad)\n-\t\t\treturn -1;\n-\t\tetype = le32_to_cpu(lad->extLength) >> 30;\n-\t\t*eloc = lelb_to_cpu(lad->extLocation);\n-\t\t*elen = le32_to_cpu(lad->extLength) & UDF_EXTENT_LENGTH_MASK;\n-\t\tbreak;\n-\tdefault:\n-\t\tudf_debug(\"alloc_type = %u unsupported\\n\", iinfo->i_alloc_type);\n-\t\treturn -1;\n-\t}\n-\n-\treturn etype;\n+    int alen;\n+    int8_t etype;\n+    uint8_t *ptr;\n+    struct short_ad *sad;\n+    struct long_ad *lad;\n+    struct udf_inode_info *iinfo = UDF_I(inode);\n+\n+    if (!epos->bh) {\n+        if (!epos->offset)\n+            epos->offset = udf_file_entry_alloc_offset(inode);\n+        ptr = iinfo->i_data + epos->offset -\n+              udf_file_entry_alloc_offset(inode) +\n+              iinfo->i_lenEAttr;\n+        alen = udf_file_entry_alloc_offset(inode) +\n+               iinfo->i_lenAlloc;\n+    } else {\n+        if (!epos->offset)\n+            epos->offset = sizeof(struct allocExtDesc);\n+        ptr = epos->bh->b_data + epos->offset;\n+        alen = sizeof(struct allocExtDesc) +\n+               le32_to_cpu(((struct allocExtDesc *)epos->bh->b_data)->\n+                           lengthAllocDescs);\n+    }\n+\n+    switch (iinfo->i_alloc_type) {\n+    case ICBTAG_FLAG_AD_SHORT:\n+        sad = udf_get_fileshortad(ptr, alen, &epos->offset, inc);\n+        if (!sad)\n+            return -1;\n+        etype = le32_to_cpu(sad->extLength) >> 30;\n+        eloc->logicalBlockNum = le32_to_cpu(sad->extPosition);\n+        eloc->partitionReferenceNum =\n+                iinfo->i_location.partitionReferenceNum;\n+        *elen = le32_to_cpu(sad->extLength) & UDF_EXTENT_LENGTH_MASK;\n+        break;\n+    case ICBTAG_FLAG_AD_LONG:\n+        lad = udf_get_filelongad(ptr, alen, &epos->offset, inc);\n+        if (!lad)\n+            return -1;\n+        etype = le32_to_cpu(lad->extLength) >> 30;\n+        *eloc = lelb_to_cpu(lad->extLocation);\n+        *elen = le32_to_cpu(lad->extLength) & UDF_EXTENT_LENGTH_MASK;\n+        break;\n+    default:\n+        udf_debug(\"alloc_type = %u unsupported\\n\", iinfo->i_alloc_type);\n+        return -1;\n+    }\n+\n+    return etype;\n }\n \n static int8_t udf_insert_aext(struct inode *inode, struct extent_position epos,\n",
            "diff --git a/fs/udf/directory.c b/fs/udf/directory.c\nindex e7e8b30876d9..e5a9c6ed36c9 100644\n--- a/fs/udf/directory.c\n+++ b/fs/udf/directory.c\n@@ -495,22 +495,23 @@ struct short_ad *udf_get_fileshortad(uint8_t *ptr, int maxoffset, uint32_t *offs\n \n struct long_ad *udf_get_filelongad(uint8_t *ptr, int maxoffset, uint32_t *offset, int inc)\n {\n-\tstruct long_ad *la;\n-\n-\tif ((!ptr) || (!offset)) {\n-\t\tpr_err(\"%s: invalidparms\\n\", __func__);\n-\t\treturn NULL;\n-\t}\n-\n-\tif ((*offset + sizeof(struct long_ad)) > maxoffset)\n-\t\treturn NULL;\n-\telse {\n-\t\tla = (struct long_ad *)ptr;\n-\t\tif (la->extLength == 0)\n-\t\t\treturn NULL;\n-\t}\n-\n-\tif (inc)\n-\t\t*offset += sizeof(struct long_ad);\n-\treturn la;\n+    struct long_ad *la;\n+\n+    if ((!ptr) || (!offset)) {\n+        pr_err(\"%s: invalidparms\\n\", __func__);\n+        return NULL;\n+    }\n+\n+    if ((*offset + sizeof(struct long_ad)) > maxoffset || *offset >= maxoffset) {\n+        pr_err(\"%s: offset out of bounds\\n\", __func__);\n+        return NULL;\n+    } else {\n+        la = (struct long_ad *)(ptr + *offset);\n+        if (la->extLength == 0)\n+            return NULL;\n+    }\n+\n+    if (inc)\n+        *offset += sizeof(struct long_ad);\n+    return la;\n }\n"
        ],
        "error": []
    },
    "4892aaa2ef26ab83c6b974f1db422f526f9aaec0": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/video/fbdev/core/sysfillrect.c b/drivers/video/fbdev/core/sysfillrect.c\nindex 33ee3d34f9d2..10eb331ed19f 100644\n--- a/drivers/video/fbdev/core/sysfillrect.c\n+++ b/drivers/video/fbdev/core/sysfillrect.c\n@@ -242,90 +242,90 @@ bitfill_unaligned_rev(struct fb_info *p, unsigned long *dst, int dst_idx,\n \n void sys_fillrect(struct fb_info *p, const struct fb_fillrect *rect)\n {\n-\tunsigned long pat, pat2, fg;\n-\tunsigned long width = rect->width, height = rect->height;\n-\tint bits = BITS_PER_LONG, bytes = bits >> 3;\n-\tu32 bpp = p->var.bits_per_pixel;\n-\tunsigned long *dst;\n-\tint dst_idx, left;\n-\n-\tif (p->state != FBINFO_STATE_RUNNING)\n-\t\treturn;\n-\n-\tif (p->fix.visual == FB_VISUAL_TRUECOLOR ||\n-\t    p->fix.visual == FB_VISUAL_DIRECTCOLOR )\n-\t\tfg = ((u32 *) (p->pseudo_palette))[rect->color];\n-\telse\n-\t\tfg = rect->color;\n-\n-\tpat = pixel_to_pat( bpp, fg);\n-\n-\tdst = (unsigned long *)((unsigned long)p->screen_base & ~(bytes-1));\n-\tdst_idx = ((unsigned long)p->screen_base & (bytes - 1))*8;\n-\tdst_idx += rect->dy*p->fix.line_length*8+rect->dx*bpp;\n-\t/* FIXME For now we support 1-32 bpp only */\n-\tleft = bits % bpp;\n-\tif (p->fbops->fb_sync)\n-\t\tp->fbops->fb_sync(p);\n-\tif (!left) {\n-\t\tvoid (*fill_op32)(struct fb_info *p, unsigned long *dst,\n-\t\t\t\t  int dst_idx, unsigned long pat, unsigned n,\n-\t\t\t\t  int bits) = NULL;\n-\n-\t\tswitch (rect->rop) {\n-\t\tcase ROP_XOR:\n-\t\t\tfill_op32 = bitfill_aligned_rev;\n-\t\t\tbreak;\n-\t\tcase ROP_COPY:\n-\t\t\tfill_op32 = bitfill_aligned;\n-\t\t\tbreak;\n-\t\tdefault:\n-\t\t\tprintk( KERN_ERR \"cfb_fillrect(): unknown rop, \"\n-\t\t\t\t\"defaulting to ROP_COPY\\n\");\n-\t\t\tfill_op32 = bitfill_aligned;\n-\t\t\tbreak;\n-\t\t}\n-\t\twhile (height--) {\n-\t\t\tdst += dst_idx >> (ffs(bits) - 1);\n-\t\t\tdst_idx &= (bits - 1);\n-\t\t\tfill_op32(p, dst, dst_idx, pat, width*bpp, bits);\n-\t\t\tdst_idx += p->fix.line_length*8;\n-\t\t}\n-\t} else {\n-\t\tint right, r;\n-\t\tvoid (*fill_op)(struct fb_info *p, unsigned long *dst,\n-\t\t\t\tint dst_idx, unsigned long pat, int left,\n-\t\t\t\tint right, unsigned n, int bits) = NULL;\n+    unsigned long pat, pat2, fg;\n+    unsigned long width = rect->width, height = rect->height;\n+    int bits = BITS_PER_LONG, bytes = bits >> 3;\n+    u32 bpp = p->var.bits_per_pixel;\n+    unsigned long *dst;\n+    int dst_idx, left;\n+\n+    if (p->state != FBINFO_STATE_RUNNING)\n+        return;\n+\n+    if (p->fix.visual == FB_VISUAL_TRUECOLOR ||\n+        p->fix.visual == FB_VISUAL_DIRECTCOLOR )\n+        fg = ((u32 *) (p->pseudo_palette))[rect->color];\n+    else\n+        fg = rect->color;\n+\n+    pat = pixel_to_pat(bpp, fg);\n+\n+    dst = (unsigned long *)((unsigned long)p->screen_buffer & ~(bytes-1));\n+    dst_idx = ((unsigned long)p->screen_buffer & (bytes - 1))*8;\n+    dst_idx += rect->dy*p->fix.line_length*8+rect->dx*bpp;\n+    /* FIXME For now we support 1-32 bpp only */\n+    left = bits % bpp;\n+    if (p->fbops->fb_sync)\n+        p->fbops->fb_sync(p);\n+    if (!left) {\n+        void (*fill_op32)(struct fb_info *p, unsigned long *dst,\n+                          int dst_idx, unsigned long pat, unsigned n,\n+                          int bits) = NULL;\n+\n+        switch (rect->rop) {\n+        case ROP_XOR:\n+            fill_op32 = bitfill_aligned_rev;\n+            break;\n+        case ROP_COPY:\n+            fill_op32 = bitfill_aligned;\n+            break;\n+        default:\n+            printk(KERN_ERR \"cfb_fillrect(): unknown rop, \"\n+                \"defaulting to ROP_COPY\\n\");\n+            fill_op32 = bitfill_aligned;\n+            break;\n+        }\n+        while (height--) {\n+            dst += dst_idx >> (ffs(bits) - 1);\n+            dst_idx &= (bits - 1);\n+            fill_op32(p, dst, dst_idx, pat, width*bpp, bits);\n+            dst_idx += p->fix.line_length*8;\n+        }\n+    } else {\n+        int right, r;\n+        void (*fill_op)(struct fb_info *p, unsigned long *dst,\n+                        int dst_idx, unsigned long pat, int left,\n+                        int right, unsigned n, int bits) = NULL;\n #ifdef __LITTLE_ENDIAN\n-\t\tright = left;\n-\t\tleft = bpp - right;\n+        right = left;\n+        left = bpp - right;\n #else\n-\t\tright = bpp - left;\n+        right = bpp - left;\n #endif\n-\t\tswitch (rect->rop) {\n-\t\tcase ROP_XOR:\n-\t\t\tfill_op = bitfill_unaligned_rev;\n-\t\t\tbreak;\n-\t\tcase ROP_COPY:\n-\t\t\tfill_op = bitfill_unaligned;\n-\t\t\tbreak;\n-\t\tdefault:\n-\t\t\tprintk(KERN_ERR \"sys_fillrect(): unknown rop, \"\n-\t\t\t\t\"defaulting to ROP_COPY\\n\");\n-\t\t\tfill_op = bitfill_unaligned;\n-\t\t\tbreak;\n-\t\t}\n-\t\twhile (height--) {\n-\t\t\tdst += dst_idx / bits;\n-\t\t\tdst_idx &= (bits - 1);\n-\t\t\tr = dst_idx % bpp;\n-\t\t\t/* rotate pattern to the correct start position */\n-\t\t\tpat2 = le_long_to_cpu(rolx(cpu_to_le_long(pat), r, bpp));\n-\t\t\tfill_op(p, dst, dst_idx, pat2, left, right,\n-\t\t\t\twidth*bpp, bits);\n-\t\t\tdst_idx += p->fix.line_length*8;\n-\t\t}\n-\t}\n+        switch (rect->rop) {\n+        case ROP_XOR:\n+            fill_op = bitfill_unaligned_rev;\n+            break;\n+        case ROP_COPY:\n+            fill_op = bitfill_unaligned;\n+            break;\n+        default:\n+            printk(KERN_ERR \"sys_fillrect(): unknown rop, \"\n+                \"defaulting to ROP_COPY\\n\");\n+            fill_op = bitfill_unaligned;\n+            break;\n+        }\n+        while (height--) {\n+            dst += dst_idx / bits;\n+            dst_idx &= (bits - 1);\n+            r = dst_idx % bpp;\n+            /* rotate pattern to the correct start position */\n+            pat2 = le_long_to_cpu(rolx(cpu_to_le_long(pat), r, bpp));\n+            fill_op(p, dst, dst_idx, pat2, left, right,\n+                width*bpp, bits);\n+            dst_idx += p->fix.line_length*8;\n+        }\n+    }\n }\n \n EXPORT_SYMBOL(sys_fillrect);\n"
        ],
        "error": [
            {
                "patch": "diff --git a/drivers/video/fbdev/core/sysfillrect.c b/drivers/video/fbdev/core/sysfillrect.c\nindex 33ee3d34f9d2..0a6334d874bc 100644\n--- a/drivers/video/fbdev/core/sysfillrect.c\n+++ b/drivers/video/fbdev/core/sysfillrect.c\n@@ -22,10 +22,11 @@\n      */\n \n static void\n-bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n+void bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\tunsigned long pat, unsigned n, int bits)\n {\n \tunsigned long first, last;\n+\tunsigned long *end = dst + (n / bits) + 1; // Calculate the end of the buffer\n \n \tif (!n)\n \t\treturn;\n@@ -42,7 +43,7 @@ bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\t/* Multiple destination words */\n \n \t\t/* Leading bits */\n- \t\tif (first!= ~0UL) {\n+ \t\tif (first != ~0UL) {\n \t\t\t*dst = comp(pat, *dst, first);\n \t\t\tdst++;\n \t\t\tn -= bits - dst_idx;\n@@ -51,6 +52,8 @@ bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\t/* Main chunk */\n \t\tn /= bits;\n \t\twhile (n >= 8) {\n+\t\t\tif (dst + 8 > end) // Boundary check\n+\t\t\t\tbreak;\n \t\t\t*dst++ = pat;\n \t\t\t*dst++ = pat;\n \t\t\t*dst++ = pat;\n@@ -61,10 +64,13 @@ bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\t\t*dst++ = pat;\n \t\t\tn -= 8;\n \t\t}\n-\t\twhile (n--)\n+\t\twhile (n--) {\n+\t\t\tif (dst >= end) // Boundary check\n+\t\t\t\tbreak;\n \t\t\t*dst++ = pat;\n+\t\t}\n \t\t/* Trailing bits */\n-\t\tif (last)\n+\t\tif (last && dst < end)\n \t\t\t*dst = comp(pat, *dst, last);\n \t}\n }\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/video/fbdev/core/sysfillrect.c b/drivers/video/fbdev/core/sysfillrect.c\nindex 33ee3d34f9d2..e49f59ed2694 100644\n--- a/drivers/video/fbdev/core/sysfillrect.c\n+++ b/drivers/video/fbdev/core/sysfillrect.c\n@@ -22,10 +22,11 @@\n      */\n \n static void\n-bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n+void bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\tunsigned long pat, unsigned n, int bits)\n {\n \tunsigned long first, last;\n+\tunsigned long *end = (unsigned long *)((unsigned long)p->screen_base + p->fix.smem_len);\n \n \tif (!n)\n \t\treturn;\n@@ -37,13 +38,15 @@ bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\t/* Single word */\n \t\tif (last)\n \t\t\tfirst &= last;\n-\t\t*dst = comp(pat, *dst, first);\n+\t\tif (dst < end)\n+\t\t\t*dst = comp(pat, *dst, first);\n \t} else {\n \t\t/* Multiple destination words */\n \n \t\t/* Leading bits */\n- \t\tif (first!= ~0UL) {\n-\t\t\t*dst = comp(pat, *dst, first);\n+ \t\tif (first != ~0UL) {\n+\t\t\tif (dst < end)\n+\t\t\t\t*dst = comp(pat, *dst, first);\n \t\t\tdst++;\n \t\t\tn -= bits - dst_idx;\n \t\t}\n@@ -51,20 +54,24 @@ bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\t/* Main chunk */\n \t\tn /= bits;\n \t\twhile (n >= 8) {\n-\t\t\t*dst++ = pat;\n-\t\t\t*dst++ = pat;\n-\t\t\t*dst++ = pat;\n-\t\t\t*dst++ = pat;\n-\t\t\t*dst++ = pat;\n-\t\t\t*dst++ = pat;\n-\t\t\t*dst++ = pat;\n-\t\t\t*dst++ = pat;\n+\t\t\tif (dst + 7 < end) {\n+\t\t\t\t*dst++ = pat;\n+\t\t\t\t*dst++ = pat;\n+\t\t\t\t*dst++ = pat;\n+\t\t\t\t*dst++ = pat;\n+\t\t\t\t*dst++ = pat;\n+\t\t\t\t*dst++ = pat;\n+\t\t\t\t*dst++ = pat;\n+\t\t\t\t*dst++ = pat;\n+\t\t\t} else {\n+\t\t\t\tbreak;\n+\t\t\t}\n \t\t\tn -= 8;\n \t\t}\n-\t\twhile (n--)\n+\t\twhile (n-- && dst < end)\n \t\t\t*dst++ = pat;\n \t\t/* Trailing bits */\n-\t\tif (last)\n+\t\tif (last && dst < end)\n \t\t\t*dst = comp(pat, *dst, last);\n \t}\n }\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/video/fbdev/core/sysfillrect.c b/drivers/video/fbdev/core/sysfillrect.c\nindex 33ee3d34f9d2..a5abf97af24e 100644\n--- a/drivers/video/fbdev/core/sysfillrect.c\n+++ b/drivers/video/fbdev/core/sysfillrect.c\n@@ -22,7 +22,7 @@\n      */\n \n static void\n-bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n+static void bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\tunsigned long pat, unsigned n, int bits)\n {\n \tunsigned long first, last;\n@@ -42,7 +42,7 @@ bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\t/* Multiple destination words */\n \n \t\t/* Leading bits */\n- \t\tif (first!= ~0UL) {\n+ \t\tif (first != ~0UL) {\n \t\t\t*dst = comp(pat, *dst, first);\n \t\t\tdst++;\n \t\t\tn -= bits - dst_idx;\n@@ -51,6 +51,7 @@ bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\t/* Main chunk */\n \t\tn /= bits;\n \t\twhile (n >= 8) {\n+\t\t\tif (dst >= (unsigned long *)((char *)dst + bits)) break; // Bounds check\n \t\t\t*dst++ = pat;\n \t\t\t*dst++ = pat;\n \t\t\t*dst++ = pat;\n@@ -61,8 +62,10 @@ bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\t\t*dst++ = pat;\n \t\t\tn -= 8;\n \t\t}\n-\t\twhile (n--)\n+\t\twhile (n--) {\n+\t\t\tif (dst >= (unsigned long *)((char *)dst + bits)) break; // Bounds check\n \t\t\t*dst++ = pat;\n+\t\t}\n \t\t/* Trailing bits */\n \t\tif (last)\n \t\t\t*dst = comp(pat, *dst, last);\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/drivers/video/fbdev/core/sysfillrect.c b/drivers/video/fbdev/core/sysfillrect.c\nindex 33ee3d34f9d2..fda0f7eb7f3a 100644\n--- a/drivers/video/fbdev/core/sysfillrect.c\n+++ b/drivers/video/fbdev/core/sysfillrect.c\n@@ -22,10 +22,11 @@\n      */\n \n static void\n-bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n+static void bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\tunsigned long pat, unsigned n, int bits)\n {\n \tunsigned long first, last;\n+\tunsigned long *end = (unsigned long *)((unsigned long)p->screen_base + p->screen_size);\n \n \tif (!n)\n \t\treturn;\n@@ -42,7 +43,7 @@ bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\t/* Multiple destination words */\n \n \t\t/* Leading bits */\n- \t\tif (first!= ~0UL) {\n+ \t\tif (first != ~0UL) {\n \t\t\t*dst = comp(pat, *dst, first);\n \t\t\tdst++;\n \t\t\tn -= bits - dst_idx;\n@@ -50,7 +51,7 @@ bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \n \t\t/* Main chunk */\n \t\tn /= bits;\n-\t\twhile (n >= 8) {\n+\t\twhile (n >= 8 && dst + 8 <= end) {\n \t\t\t*dst++ = pat;\n \t\t\t*dst++ = pat;\n \t\t\t*dst++ = pat;\n@@ -61,10 +62,10 @@ bitfill_aligned(struct fb_info *p, unsigned long *dst, int dst_idx,\n \t\t\t*dst++ = pat;\n \t\t\tn -= 8;\n \t\t}\n-\t\twhile (n--)\n+\t\twhile (n-- && dst < end)\n \t\t\t*dst++ = pat;\n \t\t/* Trailing bits */\n-\t\tif (last)\n+\t\tif (last && dst < end)\n \t\t\t*dst = comp(pat, *dst, last);\n \t}\n }\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "2e1943a94647f7732dd6fc60368642d6e8dc91b1": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/net/bluetooth/hci_conn.c b/net/bluetooth/hci_conn.c\nindex 88ec08978ff4..a500dd1b2fc2 100644\n--- a/net/bluetooth/hci_conn.c\n+++ b/net/bluetooth/hci_conn.c\n@@ -1776,22 +1776,23 @@ struct hci_chan *hci_chan_create(struct hci_conn *conn)\n \n void hci_chan_del(struct hci_chan *chan)\n {\n-\tstruct hci_conn *conn = chan->conn;\n-\tstruct hci_dev *hdev = conn->hdev;\n+    struct hci_conn *conn = chan->conn;\n+    struct hci_dev *hdev = conn->hdev;\n \n-\tBT_DBG(\"%s hcon %p chan %p\", hdev->name, conn, chan);\n+    BT_DBG(\"%s hcon %p chan %p\", hdev->name, conn, chan);\n \n-\tlist_del_rcu(&chan->list);\n+    list_del_rcu(&chan->list);\n \n-\tsynchronize_rcu();\n+    synchronize_rcu();\n \n-\t/* Prevent new hci_chan's to be created for this hci_conn */\n-\tset_bit(HCI_CONN_DROP, &conn->flags);\n+    /* Prevent new hci_chan's to be created for this hci_conn */\n+    set_bit(HCI_CONN_DROP, &conn->flags);\n \n-\thci_conn_put(conn);\n+    hci_conn_put(conn);\n \n-\tskb_queue_purge(&chan->data_q);\n-\tkfree(chan);\n+    skb_queue_purge(&chan->data_q);\n+    chan->conn = NULL; // Invalidate the connection pointer\n+    kfree(chan);\n }\n \n void hci_chan_list_flush(struct hci_conn *conn)\ndiff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c\nindex b0d9c36acc03..ca201c6ee141 100644\n--- a/net/bluetooth/hci_core.c\n+++ b/net/bluetooth/hci_core.c\n@@ -4370,13 +4370,21 @@ static void hci_queue_acl(struct hci_chan *chan, struct sk_buff_head *queue,\n \n void hci_send_acl(struct hci_chan *chan, struct sk_buff *skb, __u16 flags)\n {\n-\tstruct hci_dev *hdev = chan->conn->hdev;\n+    struct hci_dev *hdev;\n \n-\tBT_DBG(\"%s chan %p flags 0x%4.4x\", hdev->name, chan, flags);\n+    if (!chan || !chan->conn || !chan->conn->hdev) {\n+        BT_ERR(\"Invalid channel or connection\");\n+        kfree_skb(skb);\n+        return;\n+    }\n \n-\thci_queue_acl(chan, &chan->data_q, skb, flags);\n+    hdev = chan->conn->hdev;\n \n-\tqueue_work(hdev->workqueue, &hdev->tx_work);\n+    BT_DBG(\"%s chan %p flags 0x%4.4x\", hdev->name, chan, flags);\n+\n+    hci_queue_acl(chan, &chan->data_q, skb, flags);\n+\n+    queue_work(hdev->workqueue, &hdev->tx_work);\n }\n \n /* Send SCO data */\n",
            "diff --git a/net/bluetooth/hci_conn.c b/net/bluetooth/hci_conn.c\nindex 88ec08978ff4..b416b54e731e 100644\n--- a/net/bluetooth/hci_conn.c\n+++ b/net/bluetooth/hci_conn.c\n@@ -1751,47 +1751,47 @@ int hci_get_auth_info(struct hci_dev *hdev, void __user *arg)\n \n struct hci_chan *hci_chan_create(struct hci_conn *conn)\n {\n-\tstruct hci_dev *hdev = conn->hdev;\n-\tstruct hci_chan *chan;\n+    struct hci_dev *hdev = conn->hdev;\n+    struct hci_chan *chan;\n \n-\tBT_DBG(\"%s hcon %p\", hdev->name, conn);\n+    BT_DBG(\"%s hcon %p\", hdev->name, conn);\n \n-\tif (test_bit(HCI_CONN_DROP, &conn->flags)) {\n-\t\tBT_DBG(\"Refusing to create new hci_chan\");\n-\t\treturn NULL;\n-\t}\n+    if (test_bit(HCI_CONN_DROP, &conn->flags)) {\n+        BT_DBG(\"Refusing to create new hci_chan\");\n+        return NULL;\n+    }\n \n-\tchan = kzalloc(sizeof(*chan), GFP_KERNEL);\n-\tif (!chan)\n-\t\treturn NULL;\n+    chan = kzalloc(sizeof(*chan), GFP_KERNEL);\n+    if (!chan)\n+        return NULL;\n \n-\tchan->conn = hci_conn_get(conn);\n-\tskb_queue_head_init(&chan->data_q);\n-\tchan->state = BT_CONNECTED;\n+    chan->conn = hci_conn_get(conn);\n+    skb_queue_head_init(&chan->data_q);\n+    chan->state = BT_CONNECTED;\n \n-\tlist_add_rcu(&chan->list, &conn->chan_list);\n+    list_add_rcu(&chan->list, &conn->chan_list);\n \n-\treturn chan;\n+    return chan;\n }\n \n void hci_chan_del(struct hci_chan *chan)\n {\n-\tstruct hci_conn *conn = chan->conn;\n-\tstruct hci_dev *hdev = conn->hdev;\n+    struct hci_conn *conn = chan->conn;\n+    struct hci_dev *hdev = conn->hdev;\n \n-\tBT_DBG(\"%s hcon %p chan %p\", hdev->name, conn, chan);\n+    BT_DBG(\"%s hcon %p chan %p\", hdev->name, conn, chan);\n \n-\tlist_del_rcu(&chan->list);\n+    list_del_rcu(&chan->list);\n \n-\tsynchronize_rcu();\n+    synchronize_rcu();\n \n-\t/* Prevent new hci_chan's to be created for this hci_conn */\n-\tset_bit(HCI_CONN_DROP, &conn->flags);\n+    /* Prevent new hci_chan's to be created for this hci_conn */\n+    set_bit(HCI_CONN_DROP, &conn->flags);\n \n-\thci_conn_put(conn);\n+    hci_conn_put(conn);\n \n-\tskb_queue_purge(&chan->data_q);\n-\tkfree(chan);\n+    skb_queue_purge(&chan->data_q);\n+    kfree(chan);\n }\n \n void hci_chan_list_flush(struct hci_conn *conn)\ndiff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c\nindex b0d9c36acc03..7812eeeeb9dd 100644\n--- a/net/bluetooth/hci_core.c\n+++ b/net/bluetooth/hci_core.c\n@@ -4370,13 +4370,24 @@ static void hci_queue_acl(struct hci_chan *chan, struct sk_buff_head *queue,\n \n void hci_send_acl(struct hci_chan *chan, struct sk_buff *skb, __u16 flags)\n {\n-\tstruct hci_dev *hdev = chan->conn->hdev;\n+    struct hci_dev *hdev;\n \n-\tBT_DBG(\"%s chan %p flags 0x%4.4x\", hdev->name, chan, flags);\n+    if (!chan || !chan->conn) {\n+        BT_ERR(\"Invalid hci_chan or hci_conn\");\n+        return;\n+    }\n \n-\thci_queue_acl(chan, &chan->data_q, skb, flags);\n+    hdev = chan->conn->hdev;\n+    if (!hdev) {\n+        BT_ERR(\"Invalid hci_dev\");\n+        return;\n+    }\n \n-\tqueue_work(hdev->workqueue, &hdev->tx_work);\n+    BT_DBG(\"%s chan %p flags 0x%4.4x\", hdev->name, chan, flags);\n+\n+    hci_queue_acl(chan, &chan->data_q, skb, flags);\n+\n+    queue_work(hdev->workqueue, &hdev->tx_work);\n }\n \n /* Send SCO data */\n",
            "diff --git a/net/bluetooth/hci_conn.c b/net/bluetooth/hci_conn.c\nindex 88ec08978ff4..4d46f2b99fe9 100644\n--- a/net/bluetooth/hci_conn.c\n+++ b/net/bluetooth/hci_conn.c\n@@ -1776,22 +1776,22 @@ struct hci_chan *hci_chan_create(struct hci_conn *conn)\n \n void hci_chan_del(struct hci_chan *chan)\n {\n-\tstruct hci_conn *conn = chan->conn;\n-\tstruct hci_dev *hdev = conn->hdev;\n+    struct hci_conn *conn = chan->conn;\n+    struct hci_dev *hdev = conn->hdev;\n \n-\tBT_DBG(\"%s hcon %p chan %p\", hdev->name, conn, chan);\n+    BT_DBG(\"%s hcon %p chan %p\", hdev->name, conn, chan);\n \n-\tlist_del_rcu(&chan->list);\n+    list_del_rcu(&chan->list);\n \n-\tsynchronize_rcu();\n+    synchronize_rcu();\n \n-\t/* Prevent new hci_chan's to be created for this hci_conn */\n-\tset_bit(HCI_CONN_DROP, &conn->flags);\n+    /* Prevent new hci_chan's to be created for this hci_conn */\n+    set_bit(HCI_CONN_DROP, &conn->flags);\n \n-\thci_conn_put(conn);\n+    hci_conn_put(conn);\n \n-\tskb_queue_purge(&chan->data_q);\n-\tkfree(chan);\n+    skb_queue_purge(&chan->data_q);\n+    kfree(chan);\n }\n \n void hci_chan_list_flush(struct hci_conn *conn)\ndiff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c\nindex b0d9c36acc03..7812eeeeb9dd 100644\n--- a/net/bluetooth/hci_core.c\n+++ b/net/bluetooth/hci_core.c\n@@ -4370,13 +4370,24 @@ static void hci_queue_acl(struct hci_chan *chan, struct sk_buff_head *queue,\n \n void hci_send_acl(struct hci_chan *chan, struct sk_buff *skb, __u16 flags)\n {\n-\tstruct hci_dev *hdev = chan->conn->hdev;\n+    struct hci_dev *hdev;\n \n-\tBT_DBG(\"%s chan %p flags 0x%4.4x\", hdev->name, chan, flags);\n+    if (!chan || !chan->conn) {\n+        BT_ERR(\"Invalid hci_chan or hci_conn\");\n+        return;\n+    }\n \n-\thci_queue_acl(chan, &chan->data_q, skb, flags);\n+    hdev = chan->conn->hdev;\n+    if (!hdev) {\n+        BT_ERR(\"Invalid hci_dev\");\n+        return;\n+    }\n \n-\tqueue_work(hdev->workqueue, &hdev->tx_work);\n+    BT_DBG(\"%s chan %p flags 0x%4.4x\", hdev->name, chan, flags);\n+\n+    hci_queue_acl(chan, &chan->data_q, skb, flags);\n+\n+    queue_work(hdev->workqueue, &hdev->tx_work);\n }\n \n /* Send SCO data */\n"
        ],
        "error": [
            {
                "patch": "diff --git a/net/bluetooth/hci_conn.c b/net/bluetooth/hci_conn.c\nindex 88ec08978ff4..5142f9784f65 100644\n--- a/net/bluetooth/hci_conn.c\n+++ b/net/bluetooth/hci_conn.c\n@@ -1751,47 +1751,51 @@ int hci_get_auth_info(struct hci_dev *hdev, void __user *arg)\n \n struct hci_chan *hci_chan_create(struct hci_conn *conn)\n {\n-\tstruct hci_dev *hdev = conn->hdev;\n-\tstruct hci_chan *chan;\n+    struct hci_dev *hdev = conn->hdev;\n+    struct hci_chan *chan;\n \n-\tBT_DBG(\"%s hcon %p\", hdev->name, conn);\n+    BT_DBG(\"%s hcon %p\", hdev->name, conn);\n \n-\tif (test_bit(HCI_CONN_DROP, &conn->flags)) {\n-\t\tBT_DBG(\"Refusing to create new hci_chan\");\n-\t\treturn NULL;\n-\t}\n+    if (test_bit(HCI_CONN_DROP, &conn->flags)) {\n+        BT_DBG(\"Refusing to create new hci_chan\");\n+        return NULL;\n+    }\n \n-\tchan = kzalloc(sizeof(*chan), GFP_KERNEL);\n-\tif (!chan)\n-\t\treturn NULL;\n+    chan = kzalloc(sizeof(*chan), GFP_KERNEL);\n+    if (!chan)\n+        return NULL;\n \n-\tchan->conn = hci_conn_get(conn);\n-\tskb_queue_head_init(&chan->data_q);\n-\tchan->state = BT_CONNECTED;\n+    chan->conn = hci_conn_get(conn);\n+    skb_queue_head_init(&chan->data_q);\n+    chan->state = BT_CONNECTED;\n+    atomic_set(&chan->refcnt, 1); // Initialize reference count\n \n-\tlist_add_rcu(&chan->list, &conn->chan_list);\n+    list_add_rcu(&chan->list, &conn->chan_list);\n \n-\treturn chan;\n+    return chan;\n }\n \n void hci_chan_del(struct hci_chan *chan)\n {\n-\tstruct hci_conn *conn = chan->conn;\n-\tstruct hci_dev *hdev = conn->hdev;\n+    struct hci_conn *conn = chan->conn;\n+    struct hci_dev *hdev = conn->hdev;\n \n-\tBT_DBG(\"%s hcon %p chan %p\", hdev->name, conn, chan);\n+    BT_DBG(\"%s hcon %p chan %p\", hdev->name, conn, chan);\n \n-\tlist_del_rcu(&chan->list);\n+    list_del_rcu(&chan->list);\n \n-\tsynchronize_rcu();\n+    synchronize_rcu();\n \n-\t/* Prevent new hci_chan's to be created for this hci_conn */\n-\tset_bit(HCI_CONN_DROP, &conn->flags);\n+    /* Prevent new hci_chan's to be created for this hci_conn */\n+    set_bit(HCI_CONN_DROP, &conn->flags);\n \n-\thci_conn_put(conn);\n+    hci_conn_put(conn);\n+\n+    skb_queue_purge(&chan->data_q);\n \n-\tskb_queue_purge(&chan->data_q);\n-\tkfree(chan);\n+    if (atomic_dec_and_test(&chan->refcnt)) { // Check reference count before freeing\n+        kfree(chan);\n+    }\n }\n \n void hci_chan_list_flush(struct hci_conn *conn)\ndiff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c\nindex b0d9c36acc03..f6c9ef86ba5c 100644\n--- a/net/bluetooth/hci_core.c\n+++ b/net/bluetooth/hci_core.c\n@@ -4370,13 +4370,20 @@ static void hci_queue_acl(struct hci_chan *chan, struct sk_buff_head *queue,\n \n void hci_send_acl(struct hci_chan *chan, struct sk_buff *skb, __u16 flags)\n {\n-\tstruct hci_dev *hdev = chan->conn->hdev;\n+    struct hci_dev *hdev;\n \n-\tBT_DBG(\"%s chan %p flags 0x%4.4x\", hdev->name, chan, flags);\n+    if (!chan || !atomic_inc_not_zero(&chan->refcnt)) // Check and increment reference count\n+        return;\n \n-\thci_queue_acl(chan, &chan->data_q, skb, flags);\n+    hdev = chan->conn->hdev;\n \n-\tqueue_work(hdev->workqueue, &hdev->tx_work);\n+    BT_DBG(\"%s chan %p flags 0x%4.4x\", hdev->name, chan, flags);\n+\n+    hci_queue_acl(chan, &chan->data_q, skb, flags);\n+\n+    queue_work(hdev->workqueue, &hdev->tx_work);\n+\n+    atomic_dec(&chan->refcnt); // Decrement reference count after use\n }\n \n /* Send SCO data */\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/net/bluetooth/hci_conn.c b/net/bluetooth/hci_conn.c\nindex 88ec08978ff4..a613604339bb 100644\n--- a/net/bluetooth/hci_conn.c\n+++ b/net/bluetooth/hci_conn.c\n@@ -1751,47 +1751,51 @@ int hci_get_auth_info(struct hci_dev *hdev, void __user *arg)\n \n struct hci_chan *hci_chan_create(struct hci_conn *conn)\n {\n-\tstruct hci_dev *hdev = conn->hdev;\n-\tstruct hci_chan *chan;\n+    struct hci_dev *hdev = conn->hdev;\n+    struct hci_chan *chan;\n \n-\tBT_DBG(\"%s hcon %p\", hdev->name, conn);\n+    BT_DBG(\"%s hcon %p\", hdev->name, conn);\n \n-\tif (test_bit(HCI_CONN_DROP, &conn->flags)) {\n-\t\tBT_DBG(\"Refusing to create new hci_chan\");\n-\t\treturn NULL;\n-\t}\n+    if (test_bit(HCI_CONN_DROP, &conn->flags)) {\n+        BT_DBG(\"Refusing to create new hci_chan\");\n+        return NULL;\n+    }\n \n-\tchan = kzalloc(sizeof(*chan), GFP_KERNEL);\n-\tif (!chan)\n-\t\treturn NULL;\n+    chan = kzalloc(sizeof(*chan), GFP_KERNEL);\n+    if (!chan)\n+        return NULL;\n \n-\tchan->conn = hci_conn_get(conn);\n-\tskb_queue_head_init(&chan->data_q);\n-\tchan->state = BT_CONNECTED;\n+    chan->conn = hci_conn_get(conn);\n+    skb_queue_head_init(&chan->data_q);\n+    chan->state = BT_CONNECTED;\n+    chan->refcnt = 1; // Initialize reference count\n \n-\tlist_add_rcu(&chan->list, &conn->chan_list);\n+    list_add_rcu(&chan->list, &conn->chan_list);\n \n-\treturn chan;\n+    return chan;\n }\n \n void hci_chan_del(struct hci_chan *chan)\n {\n-\tstruct hci_conn *conn = chan->conn;\n-\tstruct hci_dev *hdev = conn->hdev;\n+    struct hci_conn *conn = chan->conn;\n+    struct hci_dev *hdev = conn->hdev;\n \n-\tBT_DBG(\"%s hcon %p chan %p\", hdev->name, conn, chan);\n+    BT_DBG(\"%s hcon %p chan %p\", hdev->name, conn, chan);\n \n-\tlist_del_rcu(&chan->list);\n+    list_del_rcu(&chan->list);\n \n-\tsynchronize_rcu();\n+    synchronize_rcu();\n \n-\t/* Prevent new hci_chan's to be created for this hci_conn */\n-\tset_bit(HCI_CONN_DROP, &conn->flags);\n+    /* Prevent new hci_chan's to be created for this hci_conn */\n+    set_bit(HCI_CONN_DROP, &conn->flags);\n \n-\thci_conn_put(conn);\n+    hci_conn_put(conn);\n+\n+    skb_queue_purge(&chan->data_q);\n \n-\tskb_queue_purge(&chan->data_q);\n-\tkfree(chan);\n+    if (--chan->refcnt == 0) { // Check reference count before freeing\n+        kfree(chan);\n+    }\n }\n \n void hci_chan_list_flush(struct hci_conn *conn)\ndiff --git a/net/bluetooth/hci_core.c b/net/bluetooth/hci_core.c\nindex b0d9c36acc03..5cf1dd96d33e 100644\n--- a/net/bluetooth/hci_core.c\n+++ b/net/bluetooth/hci_core.c\n@@ -4370,13 +4370,20 @@ static void hci_queue_acl(struct hci_chan *chan, struct sk_buff_head *queue,\n \n void hci_send_acl(struct hci_chan *chan, struct sk_buff *skb, __u16 flags)\n {\n-\tstruct hci_dev *hdev = chan->conn->hdev;\n+    struct hci_dev *hdev;\n \n-\tBT_DBG(\"%s chan %p flags 0x%4.4x\", hdev->name, chan, flags);\n+    if (!chan || chan->refcnt <= 0) { // Check if chan is valid\n+        kfree_skb(skb);\n+        return;\n+    }\n \n-\thci_queue_acl(chan, &chan->data_q, skb, flags);\n+    hdev = chan->conn->hdev;\n \n-\tqueue_work(hdev->workqueue, &hdev->tx_work);\n+    BT_DBG(\"%s chan %p flags 0x%4.4x\", hdev->name, chan, flags);\n+\n+    hci_queue_acl(chan, &chan->data_q, skb, flags);\n+\n+    queue_work(hdev->workqueue, &hdev->tx_work);\n }\n \n /* Send SCO data */\n",
                "error_message": "Failed to build"
            }
        ]
    },
    "e58343393efd3e0657ca37cf4466fc38d1f4d4df": {
        "non_crash": [
            "diff --git a/drivers/dma-buf/udmabuf.c b/drivers/dma-buf/udmabuf.c\nindex 38e8767ec371..4484c0af637c 100644\n--- a/drivers/dma-buf/udmabuf.c\n+++ b/drivers/dma-buf/udmabuf.c\n@@ -110,7 +110,7 @@ static void release_udmabuf(struct dma_buf *buf)\n \tstruct device *dev = ubuf->device->this_device;\n \tpgoff_t pg;\n \n-\tif (ubuf->sg)\n+\tif (!IS_ERR_OR_NULL(ubuf->sg))\n \t\tput_sg_table(dev, ubuf->sg, DMA_BIDIRECTIONAL);\n \n \tfor (pg = 0; pg < ubuf->pagecount; pg++)\n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/dma-buf/udmabuf.c b/drivers/dma-buf/udmabuf.c\nindex 38e8767ec371..bc578a9bc29d 100644\n--- a/drivers/dma-buf/udmabuf.c\n+++ b/drivers/dma-buf/udmabuf.c\n@@ -183,6 +183,8 @@ static long udmabuf_create(struct miscdevice *device,\n \tif (!ubuf)\n \t\treturn -ENOMEM;\n \n+\tubuf->sg = NULL; // Initialize sg to NULL\n+\n \tpglimit = (size_limit_mb * 1024 * 1024) >> PAGE_SHIFT;\n \tfor (i = 0; i < head->count; i++) {\n \t\tif (!IS_ALIGNED(list[i].offset, PAGE_SIZE))\n",
            "diff --git a/drivers/dma-buf/udmabuf.c b/drivers/dma-buf/udmabuf.c\nindex 38e8767ec371..eade2e9e0823 100644\n--- a/drivers/dma-buf/udmabuf.c\n+++ b/drivers/dma-buf/udmabuf.c\n@@ -110,8 +110,9 @@ static void release_udmabuf(struct dma_buf *buf)\n \tstruct device *dev = ubuf->device->this_device;\n \tpgoff_t pg;\n \n-\tif (ubuf->sg)\n+\tif (ubuf->sg) {\n \t\tput_sg_table(dev, ubuf->sg, DMA_BIDIRECTIONAL);\n+\t}\n \n \tfor (pg = 0; pg < ubuf->pagecount; pg++)\n \t\tput_page(ubuf->pages[pg]);\n",
            "diff --git a/drivers/dma-buf/udmabuf.c b/drivers/dma-buf/udmabuf.c\nindex 38e8767ec371..eade2e9e0823 100644\n--- a/drivers/dma-buf/udmabuf.c\n+++ b/drivers/dma-buf/udmabuf.c\n@@ -110,8 +110,9 @@ static void release_udmabuf(struct dma_buf *buf)\n \tstruct device *dev = ubuf->device->this_device;\n \tpgoff_t pg;\n \n-\tif (ubuf->sg)\n+\tif (ubuf->sg) {\n \t\tput_sg_table(dev, ubuf->sg, DMA_BIDIRECTIONAL);\n+\t}\n \n \tfor (pg = 0; pg < ubuf->pagecount; pg++)\n \t\tput_page(ubuf->pages[pg]);\n",
            "diff --git a/drivers/dma-buf/udmabuf.c b/drivers/dma-buf/udmabuf.c\nindex 38e8767ec371..eade2e9e0823 100644\n--- a/drivers/dma-buf/udmabuf.c\n+++ b/drivers/dma-buf/udmabuf.c\n@@ -110,8 +110,9 @@ static void release_udmabuf(struct dma_buf *buf)\n \tstruct device *dev = ubuf->device->this_device;\n \tpgoff_t pg;\n \n-\tif (ubuf->sg)\n+\tif (ubuf->sg) {\n \t\tput_sg_table(dev, ubuf->sg, DMA_BIDIRECTIONAL);\n+\t}\n \n \tfor (pg = 0; pg < ubuf->pagecount; pg++)\n \t\tput_page(ubuf->pages[pg]);\n"
        ],
        "error": []
    },
    "d8e8c32d387c7b35680b035aab36efdefe253ab7": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/btrfs/block-group.c b/fs/btrfs/block-group.c\nindex 0cb1dee965a0..bd937538dc7e 100644\n--- a/fs/btrfs/block-group.c\n+++ b/fs/btrfs/block-group.c\n@@ -3997,27 +3997,8 @@ int btrfs_chunk_alloc(struct btrfs_trans_handle *trans, u64 flags,\n \t/* Don't re-enter if we're already allocating a chunk */\n \tif (trans->allocating_chunk)\n \t\treturn -ENOSPC;\n-\t/*\n-\t * Allocation of system chunks can not happen through this path, as we\n-\t * could end up in a deadlock if we are allocating a data or metadata\n-\t * chunk and there is another task modifying the chunk btree.\n-\t *\n-\t * This is because while we are holding the chunk mutex, we will attempt\n-\t * to add the new chunk item to the chunk btree or update an existing\n-\t * device item in the chunk btree, while the other task that is modifying\n-\t * the chunk btree is attempting to COW an extent buffer while holding a\n-\t * lock on it and on its parent - if the COW operation triggers a system\n-\t * chunk allocation, then we can deadlock because we are holding the\n-\t * chunk mutex and we may need to access that extent buffer or its parent\n-\t * in order to add the chunk item or update a device item.\n-\t *\n-\t * Tasks that want to modify the chunk tree should reserve system space\n-\t * before updating the chunk btree, by calling either\n-\t * btrfs_reserve_chunk_metadata() or check_system_chunk().\n-\t * It's possible that after a task reserves the space, it still ends up\n-\t * here - this happens in the cases described above at do_chunk_alloc().\n-\t * The task will have to either retry or fail.\n-\t */\n+\n+\t/* Allocation of system chunks cannot happen through this path */\n \tif (flags & BTRFS_BLOCK_GROUP_SYSTEM)\n \t\treturn -ENOSPC;\n \n@@ -4031,22 +4012,14 @@ int btrfs_chunk_alloc(struct btrfs_trans_handle *trans, u64 flags,\n \t\tshould_alloc = should_alloc_chunk(fs_info, space_info, force);\n \t\tif (space_info->full) {\n \t\t\t/* No more free physical space */\n-\t\t\tif (should_alloc)\n-\t\t\t\tret = -ENOSPC;\n-\t\t\telse\n-\t\t\t\tret = 0;\n+\t\t\tret = -ENOSPC;\n \t\t\tspin_unlock(&space_info->lock);\n \t\t\treturn ret;\n \t\t} else if (!should_alloc) {\n \t\t\tspin_unlock(&space_info->lock);\n \t\t\treturn 0;\n \t\t} else if (space_info->chunk_alloc) {\n-\t\t\t/*\n-\t\t\t * Someone is already allocating, so we need to block\n-\t\t\t * until this someone is finished and then loop to\n-\t\t\t * recheck if we should continue with our allocation\n-\t\t\t * attempt.\n-\t\t\t */\n+\t\t\t/* Block until allocation is finished */\n \t\t\twait_for_alloc = true;\n \t\t\tforce = CHUNK_ALLOC_NO_FORCE;\n \t\t\tspin_unlock(&space_info->lock);\n@@ -4065,22 +4038,12 @@ int btrfs_chunk_alloc(struct btrfs_trans_handle *trans, u64 flags,\n \tmutex_lock(&fs_info->chunk_mutex);\n \ttrans->allocating_chunk = true;\n \n-\t/*\n-\t * If we have mixed data/metadata chunks we want to make sure we keep\n-\t * allocating mixed chunks instead of individual chunks.\n-\t */\n \tif (btrfs_mixed_space_info(space_info))\n \t\tflags |= (BTRFS_BLOCK_GROUP_DATA | BTRFS_BLOCK_GROUP_METADATA);\n \n-\t/*\n-\t * if we're doing a data chunk, go ahead and make sure that\n-\t * we keep a reasonable number of metadata chunks allocated in the\n-\t * FS as well.\n-\t */\n \tif (flags & BTRFS_BLOCK_GROUP_DATA && fs_info->metadata_ratio) {\n \t\tfs_info->data_chunk_allocations++;\n-\t\tif (!(fs_info->data_chunk_allocations %\n-\t\t      fs_info->metadata_ratio))\n+\t\tif (!(fs_info->data_chunk_allocations % fs_info->metadata_ratio))\n \t\t\tforce_metadata_allocation(fs_info);\n \t}\n \n@@ -4090,10 +4053,6 @@ int btrfs_chunk_alloc(struct btrfs_trans_handle *trans, u64 flags,\n \tif (IS_ERR(ret_bg)) {\n \t\tret = PTR_ERR(ret_bg);\n \t} else if (from_extent_allocation && (flags & BTRFS_BLOCK_GROUP_DATA)) {\n-\t\t/*\n-\t\t * New block group is likely to be used soon. Try to activate\n-\t\t * it now. Failure is OK for now.\n-\t\t */\n \t\tbtrfs_zone_activate(ret_bg);\n \t}\n \n",
            "diff --git a/fs/btrfs/block-group.c b/fs/btrfs/block-group.c\nindex 0cb1dee965a0..7e400bff7f97 100644\n--- a/fs/btrfs/block-group.c\n+++ b/fs/btrfs/block-group.c\n@@ -3997,27 +3997,8 @@ int btrfs_chunk_alloc(struct btrfs_trans_handle *trans, u64 flags,\n \t/* Don't re-enter if we're already allocating a chunk */\n \tif (trans->allocating_chunk)\n \t\treturn -ENOSPC;\n-\t/*\n-\t * Allocation of system chunks can not happen through this path, as we\n-\t * could end up in a deadlock if we are allocating a data or metadata\n-\t * chunk and there is another task modifying the chunk btree.\n-\t *\n-\t * This is because while we are holding the chunk mutex, we will attempt\n-\t * to add the new chunk item to the chunk btree or update an existing\n-\t * device item in the chunk btree, while the other task that is modifying\n-\t * the chunk btree is attempting to COW an extent buffer while holding a\n-\t * lock on it and on its parent - if the COW operation triggers a system\n-\t * chunk allocation, then we can deadlock because we are holding the\n-\t * chunk mutex and we may need to access that extent buffer or its parent\n-\t * in order to add the chunk item or update a device item.\n-\t *\n-\t * Tasks that want to modify the chunk tree should reserve system space\n-\t * before updating the chunk btree, by calling either\n-\t * btrfs_reserve_chunk_metadata() or check_system_chunk().\n-\t * It's possible that after a task reserves the space, it still ends up\n-\t * here - this happens in the cases described above at do_chunk_alloc().\n-\t * The task will have to either retry or fail.\n-\t */\n+\n+\t/* Allocation of system chunks can not happen through this path */\n \tif (flags & BTRFS_BLOCK_GROUP_SYSTEM)\n \t\treturn -ENOSPC;\n \n@@ -4031,22 +4012,14 @@ int btrfs_chunk_alloc(struct btrfs_trans_handle *trans, u64 flags,\n \t\tshould_alloc = should_alloc_chunk(fs_info, space_info, force);\n \t\tif (space_info->full) {\n \t\t\t/* No more free physical space */\n-\t\t\tif (should_alloc)\n-\t\t\t\tret = -ENOSPC;\n-\t\t\telse\n-\t\t\t\tret = 0;\n+\t\t\tret = -ENOSPC;\n \t\t\tspin_unlock(&space_info->lock);\n \t\t\treturn ret;\n \t\t} else if (!should_alloc) {\n \t\t\tspin_unlock(&space_info->lock);\n \t\t\treturn 0;\n \t\t} else if (space_info->chunk_alloc) {\n-\t\t\t/*\n-\t\t\t * Someone is already allocating, so we need to block\n-\t\t\t * until this someone is finished and then loop to\n-\t\t\t * recheck if we should continue with our allocation\n-\t\t\t * attempt.\n-\t\t\t */\n+\t\t\t/* Block until allocation is finished and retry */\n \t\t\twait_for_alloc = true;\n \t\t\tforce = CHUNK_ALLOC_NO_FORCE;\n \t\t\tspin_unlock(&space_info->lock);\n@@ -4065,22 +4038,12 @@ int btrfs_chunk_alloc(struct btrfs_trans_handle *trans, u64 flags,\n \tmutex_lock(&fs_info->chunk_mutex);\n \ttrans->allocating_chunk = true;\n \n-\t/*\n-\t * If we have mixed data/metadata chunks we want to make sure we keep\n-\t * allocating mixed chunks instead of individual chunks.\n-\t */\n \tif (btrfs_mixed_space_info(space_info))\n \t\tflags |= (BTRFS_BLOCK_GROUP_DATA | BTRFS_BLOCK_GROUP_METADATA);\n \n-\t/*\n-\t * if we're doing a data chunk, go ahead and make sure that\n-\t * we keep a reasonable number of metadata chunks allocated in the\n-\t * FS as well.\n-\t */\n \tif (flags & BTRFS_BLOCK_GROUP_DATA && fs_info->metadata_ratio) {\n \t\tfs_info->data_chunk_allocations++;\n-\t\tif (!(fs_info->data_chunk_allocations %\n-\t\t      fs_info->metadata_ratio))\n+\t\tif (!(fs_info->data_chunk_allocations % fs_info->metadata_ratio))\n \t\t\tforce_metadata_allocation(fs_info);\n \t}\n \n@@ -4090,10 +4053,6 @@ int btrfs_chunk_alloc(struct btrfs_trans_handle *trans, u64 flags,\n \tif (IS_ERR(ret_bg)) {\n \t\tret = PTR_ERR(ret_bg);\n \t} else if (from_extent_allocation && (flags & BTRFS_BLOCK_GROUP_DATA)) {\n-\t\t/*\n-\t\t * New block group is likely to be used soon. Try to activate\n-\t\t * it now. Failure is OK for now.\n-\t\t */\n \t\tbtrfs_zone_activate(ret_bg);\n \t}\n \n",
            "diff --git a/fs/btrfs/block-group.c b/fs/btrfs/block-group.c\nindex 0cb1dee965a0..405409318e75 100644\n--- a/fs/btrfs/block-group.c\n+++ b/fs/btrfs/block-group.c\n@@ -3754,7 +3754,7 @@ static int should_alloc_chunk(struct btrfs_fs_info *fs_info,\n \t\treturn 1;\n \n \t/*\n-\t * in limited mode, we want to have some free space up to\n+\t * In limited mode, we want to have some free space up to\n \t * about 1% of the FS size.\n \t */\n \tif (force == CHUNK_ALLOC_LIMITED) {\n@@ -3765,6 +3765,10 @@ static int should_alloc_chunk(struct btrfs_fs_info *fs_info,\n \t\t\treturn 1;\n \t}\n \n+\t/*\n+\t * Adjust the threshold calculation to ensure accurate space usage\n+\t * assessment. This helps prevent premature setting of the full flag.\n+\t */\n \tif (bytes_used + SZ_2M < mult_perc(sinfo->total_bytes, 80))\n \t\treturn 0;\n \treturn 1;\n@@ -3997,6 +4001,7 @@ int btrfs_chunk_alloc(struct btrfs_trans_handle *trans, u64 flags,\n \t/* Don't re-enter if we're already allocating a chunk */\n \tif (trans->allocating_chunk)\n \t\treturn -ENOSPC;\n+\n \t/*\n \t * Allocation of system chunks can not happen through this path, as we\n \t * could end up in a deadlock if we are allocating a data or metadata\n"
        ],
        "error": [
            {
                "patch": "diff --git a/fs/btrfs/block-group.c b/fs/btrfs/block-group.c\nindex 0cb1dee965a0..c18b28996680 100644\n--- a/fs/btrfs/block-group.c\n+++ b/fs/btrfs/block-group.c\n@@ -3779,96 +3779,53 @@ int btrfs_force_chunk_alloc(struct btrfs_trans_handle *trans, u64 type)\n \n static struct btrfs_block_group *do_chunk_alloc(struct btrfs_trans_handle *trans, u64 flags)\n {\n-\tstruct btrfs_block_group *bg;\n-\tint ret;\n-\n-\t/*\n-\t * Check if we have enough space in the system space info because we\n-\t * will need to update device items in the chunk btree and insert a new\n-\t * chunk item in the chunk btree as well. This will allocate a new\n-\t * system block group if needed.\n-\t */\n-\tcheck_system_chunk(trans, flags);\n-\n-\tbg = btrfs_create_chunk(trans, flags);\n-\tif (IS_ERR(bg)) {\n-\t\tret = PTR_ERR(bg);\n-\t\tgoto out;\n-\t}\n-\n-\tret = btrfs_chunk_alloc_add_chunk_item(trans, bg);\n-\t/*\n-\t * Normally we are not expected to fail with -ENOSPC here, since we have\n-\t * previously reserved space in the system space_info and allocated one\n-\t * new system chunk if necessary. However there are three exceptions:\n-\t *\n-\t * 1) We may have enough free space in the system space_info but all the\n-\t *    existing system block groups have a profile which can not be used\n-\t *    for extent allocation.\n-\t *\n-\t *    This happens when mounting in degraded mode. For example we have a\n-\t *    RAID1 filesystem with 2 devices, lose one device and mount the fs\n-\t *    using the other device in degraded mode. If we then allocate a chunk,\n-\t *    we may have enough free space in the existing system space_info, but\n-\t *    none of the block groups can be used for extent allocation since they\n-\t *    have a RAID1 profile, and because we are in degraded mode with a\n-\t *    single device, we are forced to allocate a new system chunk with a\n-\t *    SINGLE profile. Making check_system_chunk() iterate over all system\n-\t *    block groups and check if they have a usable profile and enough space\n-\t *    can be slow on very large filesystems, so we tolerate the -ENOSPC and\n-\t *    try again after forcing allocation of a new system chunk. Like this\n-\t *    we avoid paying the cost of that search in normal circumstances, when\n-\t *    we were not mounted in degraded mode;\n-\t *\n-\t * 2) We had enough free space info the system space_info, and one suitable\n-\t *    block group to allocate from when we called check_system_chunk()\n-\t *    above. However right after we called it, the only system block group\n-\t *    with enough free space got turned into RO mode by a running scrub,\n-\t *    and in this case we have to allocate a new one and retry. We only\n-\t *    need do this allocate and retry once, since we have a transaction\n-\t *    handle and scrub uses the commit root to search for block groups;\n-\t *\n-\t * 3) We had one system block group with enough free space when we called\n-\t *    check_system_chunk(), but after that, right before we tried to\n-\t *    allocate the last extent buffer we needed, a discard operation came\n-\t *    in and it temporarily removed the last free space entry from the\n-\t *    block group (discard removes a free space entry, discards it, and\n-\t *    then adds back the entry to the block group cache).\n-\t */\n-\tif (ret == -ENOSPC) {\n-\t\tconst u64 sys_flags = btrfs_system_alloc_profile(trans->fs_info);\n-\t\tstruct btrfs_block_group *sys_bg;\n-\n-\t\tsys_bg = btrfs_create_chunk(trans, sys_flags);\n-\t\tif (IS_ERR(sys_bg)) {\n-\t\t\tret = PTR_ERR(sys_bg);\n-\t\t\tbtrfs_abort_transaction(trans, ret);\n-\t\t\tgoto out;\n-\t\t}\n-\n-\t\tret = btrfs_chunk_alloc_add_chunk_item(trans, sys_bg);\n-\t\tif (ret) {\n-\t\t\tbtrfs_abort_transaction(trans, ret);\n-\t\t\tgoto out;\n-\t\t}\n+    struct btrfs_block_group *bg;\n+    int ret;\n+\n+    check_system_chunk(trans, flags);\n+\n+    bg = btrfs_create_chunk(trans, flags);\n+    if (IS_ERR(bg)) {\n+        ret = PTR_ERR(bg);\n+        goto out;\n+    }\n+\n+    ret = btrfs_chunk_alloc_add_chunk_item(trans, bg);\n+    if (ret == -ENOSPC) {\n+        const u64 sys_flags = btrfs_system_alloc_profile(trans->fs_info);\n+        struct btrfs_block_group *sys_bg;\n+\n+        sys_bg = btrfs_create_chunk(trans, sys_flags);\n+        if (IS_ERR(sys_bg)) {\n+            ret = PTR_ERR(sys_bg);\n+            btrfs_abort_transaction(trans, ret);\n+            goto out;\n+        }\n+\n+        ret = btrfs_chunk_alloc_add_chunk_item(trans, sys_bg);\n+        if (ret) {\n+            btrfs_abort_transaction(trans, ret);\n+            goto out;\n+        }\n+\n+        ret = btrfs_chunk_alloc_add_chunk_item(trans, bg);\n+        if (ret) {\n+            btrfs_abort_transaction(trans, ret);\n+            goto out;\n+        }\n+    } else if (ret) {\n+        btrfs_abort_transaction(trans, ret);\n+        goto out;\n+    }\n \n-\t\tret = btrfs_chunk_alloc_add_chunk_item(trans, bg);\n-\t\tif (ret) {\n-\t\t\tbtrfs_abort_transaction(trans, ret);\n-\t\t\tgoto out;\n-\t\t}\n-\t} else if (ret) {\n-\t\tbtrfs_abort_transaction(trans, ret);\n-\t\tgoto out;\n-\t}\n out:\n-\tbtrfs_trans_release_chunk_metadata(trans);\n+    btrfs_trans_release_chunk_metadata(trans);\n \n-\tif (ret)\n-\t\treturn ERR_PTR(ret);\n+    if (ret)\n+        return ERR_PTR(ret);\n \n-\tbtrfs_get_block_group(bg);\n-\treturn bg;\n+    btrfs_get_block_group(bg);\n+    return bg;\n }\n \n /*\n@@ -3979,145 +3936,99 @@ static struct btrfs_block_group *do_chunk_alloc(struct btrfs_trans_handle *trans\n  *    - return errors including -ENOSPC otherwise.\n  */\n int btrfs_chunk_alloc(struct btrfs_trans_handle *trans, u64 flags,\n-\t\t      enum btrfs_chunk_alloc_enum force)\n+                      enum btrfs_chunk_alloc_enum force)\n {\n-\tstruct btrfs_fs_info *fs_info = trans->fs_info;\n-\tstruct btrfs_space_info *space_info;\n-\tstruct btrfs_block_group *ret_bg;\n-\tbool wait_for_alloc = false;\n-\tbool should_alloc = false;\n-\tbool from_extent_allocation = false;\n-\tint ret = 0;\n-\n-\tif (force == CHUNK_ALLOC_FORCE_FOR_EXTENT) {\n-\t\tfrom_extent_allocation = true;\n-\t\tforce = CHUNK_ALLOC_FORCE;\n-\t}\n-\n-\t/* Don't re-enter if we're already allocating a chunk */\n-\tif (trans->allocating_chunk)\n-\t\treturn -ENOSPC;\n-\t/*\n-\t * Allocation of system chunks can not happen through this path, as we\n-\t * could end up in a deadlock if we are allocating a data or metadata\n-\t * chunk and there is another task modifying the chunk btree.\n-\t *\n-\t * This is because while we are holding the chunk mutex, we will attempt\n-\t * to add the new chunk item to the chunk btree or update an existing\n-\t * device item in the chunk btree, while the other task that is modifying\n-\t * the chunk btree is attempting to COW an extent buffer while holding a\n-\t * lock on it and on its parent - if the COW operation triggers a system\n-\t * chunk allocation, then we can deadlock because we are holding the\n-\t * chunk mutex and we may need to access that extent buffer or its parent\n-\t * in order to add the chunk item or update a device item.\n-\t *\n-\t * Tasks that want to modify the chunk tree should reserve system space\n-\t * before updating the chunk btree, by calling either\n-\t * btrfs_reserve_chunk_metadata() or check_system_chunk().\n-\t * It's possible that after a task reserves the space, it still ends up\n-\t * here - this happens in the cases described above at do_chunk_alloc().\n-\t * The task will have to either retry or fail.\n-\t */\n-\tif (flags & BTRFS_BLOCK_GROUP_SYSTEM)\n-\t\treturn -ENOSPC;\n-\n-\tspace_info = btrfs_find_space_info(fs_info, flags);\n-\tASSERT(space_info);\n-\n-\tdo {\n-\t\tspin_lock(&space_info->lock);\n-\t\tif (force < space_info->force_alloc)\n-\t\t\tforce = space_info->force_alloc;\n-\t\tshould_alloc = should_alloc_chunk(fs_info, space_info, force);\n-\t\tif (space_info->full) {\n-\t\t\t/* No more free physical space */\n-\t\t\tif (should_alloc)\n-\t\t\t\tret = -ENOSPC;\n-\t\t\telse\n-\t\t\t\tret = 0;\n-\t\t\tspin_unlock(&space_info->lock);\n-\t\t\treturn ret;\n-\t\t} else if (!should_alloc) {\n-\t\t\tspin_unlock(&space_info->lock);\n-\t\t\treturn 0;\n-\t\t} else if (space_info->chunk_alloc) {\n-\t\t\t/*\n-\t\t\t * Someone is already allocating, so we need to block\n-\t\t\t * until this someone is finished and then loop to\n-\t\t\t * recheck if we should continue with our allocation\n-\t\t\t * attempt.\n-\t\t\t */\n-\t\t\twait_for_alloc = true;\n-\t\t\tforce = CHUNK_ALLOC_NO_FORCE;\n-\t\t\tspin_unlock(&space_info->lock);\n-\t\t\tmutex_lock(&fs_info->chunk_mutex);\n-\t\t\tmutex_unlock(&fs_info->chunk_mutex);\n-\t\t} else {\n-\t\t\t/* Proceed with allocation */\n-\t\t\tspace_info->chunk_alloc = 1;\n-\t\t\twait_for_alloc = false;\n-\t\t\tspin_unlock(&space_info->lock);\n-\t\t}\n-\n-\t\tcond_resched();\n-\t} while (wait_for_alloc);\n-\n-\tmutex_lock(&fs_info->chunk_mutex);\n-\ttrans->allocating_chunk = true;\n-\n-\t/*\n-\t * If we have mixed data/metadata chunks we want to make sure we keep\n-\t * allocating mixed chunks instead of individual chunks.\n-\t */\n-\tif (btrfs_mixed_space_info(space_info))\n-\t\tflags |= (BTRFS_BLOCK_GROUP_DATA | BTRFS_BLOCK_GROUP_METADATA);\n-\n-\t/*\n-\t * if we're doing a data chunk, go ahead and make sure that\n-\t * we keep a reasonable number of metadata chunks allocated in the\n-\t * FS as well.\n-\t */\n-\tif (flags & BTRFS_BLOCK_GROUP_DATA && fs_info->metadata_ratio) {\n-\t\tfs_info->data_chunk_allocations++;\n-\t\tif (!(fs_info->data_chunk_allocations %\n-\t\t      fs_info->metadata_ratio))\n-\t\t\tforce_metadata_allocation(fs_info);\n-\t}\n-\n-\tret_bg = do_chunk_alloc(trans, flags);\n-\ttrans->allocating_chunk = false;\n-\n-\tif (IS_ERR(ret_bg)) {\n-\t\tret = PTR_ERR(ret_bg);\n-\t} else if (from_extent_allocation && (flags & BTRFS_BLOCK_GROUP_DATA)) {\n-\t\t/*\n-\t\t * New block group is likely to be used soon. Try to activate\n-\t\t * it now. Failure is OK for now.\n-\t\t */\n-\t\tbtrfs_zone_activate(ret_bg);\n-\t}\n-\n-\tif (!ret)\n-\t\tbtrfs_put_block_group(ret_bg);\n-\n-\tspin_lock(&space_info->lock);\n-\tif (ret < 0) {\n-\t\tif (ret == -ENOSPC)\n-\t\t\tspace_info->full = 1;\n-\t\telse\n-\t\t\tgoto out;\n-\t} else {\n-\t\tret = 1;\n-\t\tspace_info->max_extent_size = 0;\n-\t}\n-\n-\tspace_info->force_alloc = CHUNK_ALLOC_NO_FORCE;\n+    struct btrfs_fs_info *fs_info = trans->fs_info;\n+    struct btrfs_space_info *space_info;\n+    bool wait_for_alloc = false;\n+    bool should_alloc = false;\n+    int ret = 0;\n+\n+    if (force == CHUNK_ALLOC_FORCE_FOR_EXTENT) {\n+        force = CHUNK_ALLOC_FORCE;\n+    }\n+\n+    if (trans->allocating_chunk)\n+        return -ENOSPC;\n+\n+    if (flags & BTRFS_BLOCK_GROUP_SYSTEM)\n+        return -ENOSPC;\n+\n+    space_info = btrfs_find_space_info(fs_info, flags);\n+    ASSERT(space_info);\n+\n+    do {\n+        spin_lock(&space_info->lock);\n+        if (force < space_info->force_alloc)\n+            force = space_info->force_alloc;\n+        should_alloc = should_alloc_chunk(fs_info, space_info, force);\n+        if (space_info->full) {\n+            if (should_alloc)\n+                ret = -ENOSPC;\n+            else\n+                ret = 0;\n+            spin_unlock(&space_info->lock);\n+            return ret;\n+        } else if (!should_alloc) {\n+            spin_unlock(&space_info->lock);\n+            return 0;\n+        } else if (space_info->chunk_alloc) {\n+            wait_for_alloc = true;\n+            force = CHUNK_ALLOC_NO_FORCE;\n+            spin_unlock(&space_info->lock);\n+            mutex_lock(&fs_info->chunk_mutex);\n+            mutex_unlock(&fs_info->chunk_mutex);\n+        } else {\n+            space_info->chunk_alloc = 1;\n+            wait_for_alloc = false;\n+            spin_unlock(&space_info->lock);\n+        }\n+\n+        cond_resched();\n+    } while (wait_for_alloc);\n+\n+    mutex_lock(&fs_info->chunk_mutex);\n+    trans->allocating_chunk = true;\n+\n+    if (btrfs_mixed_space_info(space_info))\n+        flags |= (BTRFS_BLOCK_GROUP_DATA | BTRFS_BLOCK_GROUP_METADATA);\n+\n+    if (flags & BTRFS_BLOCK_GROUP_DATA && fs_info->metadata_ratio) {\n+        fs_info->data_chunk_allocations++;\n+        if (!(fs_info->data_chunk_allocations % fs_info->metadata_ratio))\n+            force_metadata_allocation(fs_info);\n+    }\n+\n+    ret_bg = do_chunk_alloc(trans, flags);\n+    trans->allocating_chunk = false;\n+\n+    if (IS_ERR(ret_bg)) {\n+        ret = PTR_ERR(ret_bg);\n+    } else if (from_extent_allocation && (flags & BTRFS_BLOCK_GROUP_DATA)) {\n+        btrfs_zone_activate(ret_bg);\n+    }\n+\n+    if (!ret)\n+        btrfs_put_block_group(ret_bg);\n+\n+    spin_lock(&space_info->lock);\n+    if (ret < 0) {\n+        if (ret == -ENOSPC)\n+            space_info->full = 1;\n+        else\n+            goto out;\n+    } else {\n+        ret = 1;\n+        space_info->max_extent_size = 0;\n+    }\n+\n+    space_info->force_alloc = CHUNK_ALLOC_NO_FORCE;\n out:\n-\tspace_info->chunk_alloc = 0;\n-\tspin_unlock(&space_info->lock);\n-\tmutex_unlock(&fs_info->chunk_mutex);\n+    space_info->chunk_alloc = 0;\n+    spin_unlock(&space_info->lock);\n+    mutex_unlock(&fs_info->chunk_mutex);\n \n-\treturn ret;\n+    return ret;\n }\n \n static u64 get_profile_num_devs(struct btrfs_fs_info *fs_info, u64 type)\n",
                "error_message": "Failed to build"
            },
            {
                "patch": "diff --git a/fs/btrfs/block-group.c b/fs/btrfs/block-group.c\nindex 0cb1dee965a0..33ac875024eb 100644\n--- a/fs/btrfs/block-group.c\n+++ b/fs/btrfs/block-group.c\n@@ -3997,27 +3997,7 @@ int btrfs_chunk_alloc(struct btrfs_trans_handle *trans, u64 flags,\n \t/* Don't re-enter if we're already allocating a chunk */\n \tif (trans->allocating_chunk)\n \t\treturn -ENOSPC;\n-\t/*\n-\t * Allocation of system chunks can not happen through this path, as we\n-\t * could end up in a deadlock if we are allocating a data or metadata\n-\t * chunk and there is another task modifying the chunk btree.\n-\t *\n-\t * This is because while we are holding the chunk mutex, we will attempt\n-\t * to add the new chunk item to the chunk btree or update an existing\n-\t * device item in the chunk btree, while the other task that is modifying\n-\t * the chunk btree is attempting to COW an extent buffer while holding a\n-\t * lock on it and on its parent - if the COW operation triggers a system\n-\t * chunk allocation, then we can deadlock because we are holding the\n-\t * chunk mutex and we may need to access that extent buffer or its parent\n-\t * in order to add the chunk item or update a device item.\n-\t *\n-\t * Tasks that want to modify the chunk tree should reserve system space\n-\t * before updating the chunk btree, by calling either\n-\t * btrfs_reserve_chunk_metadata() or check_system_chunk().\n-\t * It's possible that after a task reserves the space, it still ends up\n-\t * here - this happens in the cases described above at do_chunk_alloc().\n-\t * The task will have to either retry or fail.\n-\t */\n+\n \tif (flags & BTRFS_BLOCK_GROUP_SYSTEM)\n \t\treturn -ENOSPC;\n \n@@ -4030,7 +4010,6 @@ int btrfs_chunk_alloc(struct btrfs_trans_handle *trans, u64 flags,\n \t\t\tforce = space_info->force_alloc;\n \t\tshould_alloc = should_alloc_chunk(fs_info, space_info, force);\n \t\tif (space_info->full) {\n-\t\t\t/* No more free physical space */\n \t\t\tif (should_alloc)\n \t\t\t\tret = -ENOSPC;\n \t\t\telse\n@@ -4041,19 +4020,12 @@ int btrfs_chunk_alloc(struct btrfs_trans_handle *trans, u64 flags,\n \t\t\tspin_unlock(&space_info->lock);\n \t\t\treturn 0;\n \t\t} else if (space_info->chunk_alloc) {\n-\t\t\t/*\n-\t\t\t * Someone is already allocating, so we need to block\n-\t\t\t * until this someone is finished and then loop to\n-\t\t\t * recheck if we should continue with our allocation\n-\t\t\t * attempt.\n-\t\t\t */\n \t\t\twait_for_alloc = true;\n \t\t\tforce = CHUNK_ALLOC_NO_FORCE;\n \t\t\tspin_unlock(&space_info->lock);\n \t\t\tmutex_lock(&fs_info->chunk_mutex);\n \t\t\tmutex_unlock(&fs_info->chunk_mutex);\n \t\t} else {\n-\t\t\t/* Proceed with allocation */\n \t\t\tspace_info->chunk_alloc = 1;\n \t\t\twait_for_alloc = false;\n \t\t\tspin_unlock(&space_info->lock);\n@@ -4065,18 +4037,9 @@ int btrfs_chunk_alloc(struct btrfs_trans_handle *trans, u64 flags,\n \tmutex_lock(&fs_info->chunk_mutex);\n \ttrans->allocating_chunk = true;\n \n-\t/*\n-\t * If we have mixed data/metadata chunks we want to make sure we keep\n-\t * allocating mixed chunks instead of individual chunks.\n-\t */\n \tif (btrfs_mixed_space_info(space_info))\n \t\tflags |= (BTRFS_BLOCK_GROUP_DATA | BTRFS_BLOCK_GROUP_METADATA);\n \n-\t/*\n-\t * if we're doing a data chunk, go ahead and make sure that\n-\t * we keep a reasonable number of metadata chunks allocated in the\n-\t * FS as well.\n-\t */\n \tif (flags & BTRFS_BLOCK_GROUP_DATA && fs_info->metadata_ratio) {\n \t\tfs_info->data_chunk_allocations++;\n \t\tif (!(fs_info->data_chunk_allocations %\n@@ -4089,11 +4052,11 @@ int btrfs_chunk_alloc(struct btrfs_trans_handle *trans, u64 flags,\n \n \tif (IS_ERR(ret_bg)) {\n \t\tret = PTR_ERR(ret_bg);\n+\t\tif (ret == -ENOSPC) {\n+\t\t\t/* Retry allocation or handle error gracefully */\n+\t\t\tret = handle_chunk_allocation_failure(trans, flags);\n+\t\t}\n \t} else if (from_extent_allocation && (flags & BTRFS_BLOCK_GROUP_DATA)) {\n-\t\t/*\n-\t\t * New block group is likely to be used soon. Try to activate\n-\t\t * it now. Failure is OK for now.\n-\t\t */\n \t\tbtrfs_zone_activate(ret_bg);\n \t}\n \n",
                "error_message": "Failed to build"
            }
        ]
    },
    "30f3a18df370dd15cce6f725620ac001e57dbee1": {
        "non_crash": [
            "diff --git a/fs/hfs/btree.c b/fs/hfs/btree.c\nindex 2fa4b1f8cc7f..b25c2b0809a3 100644\n--- a/fs/hfs/btree.c\n+++ b/fs/hfs/btree.c\n@@ -249,76 +249,78 @@ int hfs_bmap_reserve(struct hfs_btree *tree, int rsvd_nodes)\n \n struct hfs_bnode *hfs_bmap_alloc(struct hfs_btree *tree)\n {\n-\tstruct hfs_bnode *node, *next_node;\n-\tstruct page **pagep;\n-\tu32 nidx, idx;\n-\tunsigned off;\n-\tu16 off16;\n-\tu16 len;\n-\tu8 *data, byte, m;\n-\tint i, res;\n-\n-\tres = hfs_bmap_reserve(tree, 1);\n-\tif (res)\n-\t\treturn ERR_PTR(res);\n-\n-\tnidx = 0;\n-\tnode = hfs_bnode_find(tree, nidx);\n-\tif (IS_ERR(node))\n-\t\treturn node;\n-\tlen = hfs_brec_lenoff(node, 2, &off16);\n-\toff = off16;\n-\n-\toff += node->page_offset;\n-\tpagep = node->page + (off >> PAGE_SHIFT);\n-\tdata = kmap_local_page(*pagep);\n-\toff &= ~PAGE_MASK;\n-\tidx = 0;\n-\n-\tfor (;;) {\n-\t\twhile (len) {\n-\t\t\tbyte = data[off];\n-\t\t\tif (byte != 0xff) {\n-\t\t\t\tfor (m = 0x80, i = 0; i < 8; m >>= 1, i++) {\n-\t\t\t\t\tif (!(byte & m)) {\n-\t\t\t\t\t\tidx += i;\n-\t\t\t\t\t\tdata[off] |= m;\n-\t\t\t\t\t\tset_page_dirty(*pagep);\n-\t\t\t\t\t\tkunmap_local(data);\n-\t\t\t\t\t\ttree->free_nodes--;\n-\t\t\t\t\t\tmark_inode_dirty(tree->inode);\n-\t\t\t\t\t\thfs_bnode_put(node);\n-\t\t\t\t\t\treturn hfs_bnode_create(tree, idx);\n-\t\t\t\t\t}\n-\t\t\t\t}\n-\t\t\t}\n-\t\t\tif (++off >= PAGE_SIZE) {\n-\t\t\t\tkunmap_local(data);\n-\t\t\t\tdata = kmap_local_page(*++pagep);\n-\t\t\t\toff = 0;\n-\t\t\t}\n-\t\t\tidx += 8;\n-\t\t\tlen--;\n-\t\t}\n-\t\tkunmap_local(data);\n-\t\tnidx = node->next;\n-\t\tif (!nidx) {\n-\t\t\tprintk(KERN_DEBUG \"create new bmap node...\\n\");\n-\t\t\tnext_node = hfs_bmap_new_bmap(node, idx);\n-\t\t} else\n-\t\t\tnext_node = hfs_bnode_find(tree, nidx);\n-\t\thfs_bnode_put(node);\n-\t\tif (IS_ERR(next_node))\n-\t\t\treturn next_node;\n-\t\tnode = next_node;\n-\n-\t\tlen = hfs_brec_lenoff(node, 0, &off16);\n-\t\toff = off16;\n-\t\toff += node->page_offset;\n-\t\tpagep = node->page + (off >> PAGE_SHIFT);\n-\t\tdata = kmap_local_page(*pagep);\n-\t\toff &= ~PAGE_MASK;\n-\t}\n+    struct hfs_bnode *node, *next_node;\n+    struct page **pagep;\n+    u32 nidx, idx;\n+    unsigned off;\n+    u16 off16;\n+    u16 len;\n+    u8 *data, byte, m;\n+    int i, res;\n+\n+    res = hfs_bmap_reserve(tree, 1);\n+    if (res)\n+        return ERR_PTR(res);\n+\n+    nidx = 0;\n+    node = hfs_bnode_find(tree, nidx);\n+    if (IS_ERR(node))\n+        return node;\n+    hfs_bnode_get(node); // Ensure the node is properly reference-counted\n+    len = hfs_brec_lenoff(node, 2, &off16);\n+    off = off16;\n+\n+    off += node->page_offset;\n+    pagep = node->page + (off >> PAGE_SHIFT);\n+    data = kmap_local_page(*pagep);\n+    off &= ~PAGE_MASK;\n+    idx = 0;\n+\n+    for (;;) {\n+        while (len) {\n+            byte = data[off];\n+            if (byte != 0xff) {\n+                for (m = 0x80, i = 0; i < 8; m >>= 1, i++) {\n+                    if (!(byte & m)) {\n+                        idx += i;\n+                        data[off] |= m;\n+                        set_page_dirty(*pagep);\n+                        kunmap_local(data);\n+                        tree->free_nodes--;\n+                        mark_inode_dirty(tree->inode);\n+                        hfs_bnode_put(node);\n+                        return hfs_bnode_create(tree, idx);\n+                    }\n+                }\n+            }\n+            if (++off >= PAGE_SIZE) {\n+                kunmap_local(data);\n+                data = kmap_local_page(*++pagep);\n+                off = 0;\n+            }\n+            idx += 8;\n+            len--;\n+        }\n+        kunmap_local(data);\n+        nidx = node->next;\n+        if (!nidx) {\n+            printk(KERN_DEBUG \"create new bmap node...\\n\");\n+            next_node = hfs_bmap_new_bmap(node, idx);\n+        } else\n+            next_node = hfs_bnode_find(tree, nidx);\n+        hfs_bnode_put(node);\n+        if (IS_ERR(next_node))\n+            return next_node;\n+        node = next_node;\n+        hfs_bnode_get(node); // Ensure the node is properly reference-counted\n+\n+        len = hfs_brec_lenoff(node, 0, &off16);\n+        off = off16;\n+        off += node->page_offset;\n+        pagep = node->page + (off >> PAGE_SHIFT);\n+        data = kmap_local_page(*pagep);\n+        off &= ~PAGE_MASK;\n+    }\n }\n \n void hfs_bmap_free(struct hfs_bnode *node)\n",
            "diff --git a/fs/hfs/brec.c b/fs/hfs/brec.c\nindex 896396554bcc..5a51db27aed7 100644\n--- a/fs/hfs/brec.c\n+++ b/fs/hfs/brec.c\n@@ -230,123 +230,123 @@ int hfs_brec_remove(struct hfs_find_data *fd)\n \n static struct hfs_bnode *hfs_bnode_split(struct hfs_find_data *fd)\n {\n-\tstruct hfs_btree *tree;\n-\tstruct hfs_bnode *node, *new_node, *next_node;\n-\tstruct hfs_bnode_desc node_desc;\n-\tint num_recs, new_rec_off, new_off, old_rec_off;\n-\tint data_start, data_end, size;\n-\n-\ttree = fd->tree;\n-\tnode = fd->bnode;\n-\tnew_node = hfs_bmap_alloc(tree);\n-\tif (IS_ERR(new_node))\n-\t\treturn new_node;\n-\thfs_bnode_get(node);\n-\thfs_dbg(BNODE_MOD, \"split_nodes: %d - %d - %d\\n\",\n-\t\tnode->this, new_node->this, node->next);\n-\tnew_node->next = node->next;\n-\tnew_node->prev = node->this;\n-\tnew_node->parent = node->parent;\n-\tnew_node->type = node->type;\n-\tnew_node->height = node->height;\n-\n-\tif (node->next)\n-\t\tnext_node = hfs_bnode_find(tree, node->next);\n-\telse\n-\t\tnext_node = NULL;\n-\n-\tif (IS_ERR(next_node)) {\n-\t\thfs_bnode_put(node);\n-\t\thfs_bnode_put(new_node);\n-\t\treturn next_node;\n-\t}\n-\n-\tsize = tree->node_size / 2 - node->num_recs * 2 - 14;\n-\told_rec_off = tree->node_size - 4;\n-\tnum_recs = 1;\n-\tfor (;;) {\n-\t\tdata_start = hfs_bnode_read_u16(node, old_rec_off);\n-\t\tif (data_start > size)\n-\t\t\tbreak;\n-\t\told_rec_off -= 2;\n-\t\tif (++num_recs < node->num_recs)\n-\t\t\tcontinue;\n-\t\t/* panic? */\n-\t\thfs_bnode_put(node);\n-\t\thfs_bnode_put(new_node);\n-\t\tif (next_node)\n-\t\t\thfs_bnode_put(next_node);\n-\t\treturn ERR_PTR(-ENOSPC);\n-\t}\n-\n-\tif (fd->record + 1 < num_recs) {\n-\t\t/* new record is in the lower half,\n-\t\t * so leave some more space there\n-\t\t */\n-\t\told_rec_off += 2;\n-\t\tnum_recs--;\n-\t\tdata_start = hfs_bnode_read_u16(node, old_rec_off);\n-\t} else {\n-\t\thfs_bnode_put(node);\n-\t\thfs_bnode_get(new_node);\n-\t\tfd->bnode = new_node;\n-\t\tfd->record -= num_recs;\n-\t\tfd->keyoffset -= data_start - 14;\n-\t\tfd->entryoffset -= data_start - 14;\n-\t}\n-\tnew_node->num_recs = node->num_recs - num_recs;\n-\tnode->num_recs = num_recs;\n-\n-\tnew_rec_off = tree->node_size - 2;\n-\tnew_off = 14;\n-\tsize = data_start - new_off;\n-\tnum_recs = new_node->num_recs;\n-\tdata_end = data_start;\n-\twhile (num_recs) {\n-\t\thfs_bnode_write_u16(new_node, new_rec_off, new_off);\n-\t\told_rec_off -= 2;\n-\t\tnew_rec_off -= 2;\n-\t\tdata_end = hfs_bnode_read_u16(node, old_rec_off);\n-\t\tnew_off = data_end - size;\n-\t\tnum_recs--;\n-\t}\n-\thfs_bnode_write_u16(new_node, new_rec_off, new_off);\n-\thfs_bnode_copy(new_node, 14, node, data_start, data_end - data_start);\n-\n-\t/* update new bnode header */\n-\tnode_desc.next = cpu_to_be32(new_node->next);\n-\tnode_desc.prev = cpu_to_be32(new_node->prev);\n-\tnode_desc.type = new_node->type;\n-\tnode_desc.height = new_node->height;\n-\tnode_desc.num_recs = cpu_to_be16(new_node->num_recs);\n-\tnode_desc.reserved = 0;\n-\thfs_bnode_write(new_node, &node_desc, 0, sizeof(node_desc));\n-\n-\t/* update previous bnode header */\n-\tnode->next = new_node->this;\n-\thfs_bnode_read(node, &node_desc, 0, sizeof(node_desc));\n-\tnode_desc.next = cpu_to_be32(node->next);\n-\tnode_desc.num_recs = cpu_to_be16(node->num_recs);\n-\thfs_bnode_write(node, &node_desc, 0, sizeof(node_desc));\n-\n-\t/* update next bnode header */\n-\tif (next_node) {\n-\t\tnext_node->prev = new_node->this;\n-\t\thfs_bnode_read(next_node, &node_desc, 0, sizeof(node_desc));\n-\t\tnode_desc.prev = cpu_to_be32(next_node->prev);\n-\t\thfs_bnode_write(next_node, &node_desc, 0, sizeof(node_desc));\n-\t\thfs_bnode_put(next_node);\n-\t} else if (node->this == tree->leaf_tail) {\n-\t\t/* if there is no next node, this might be the new tail */\n-\t\ttree->leaf_tail = new_node->this;\n-\t\tmark_inode_dirty(tree->inode);\n-\t}\n-\n-\thfs_bnode_dump(node);\n-\thfs_bnode_dump(new_node);\n-\thfs_bnode_put(node);\n-\n-\treturn new_node;\n+    struct hfs_btree *tree;\n+    struct hfs_bnode *node, *new_node, *next_node;\n+    struct hfs_bnode_desc node_desc;\n+    int num_recs, new_rec_off, new_off, old_rec_off;\n+    int data_start, data_end, size;\n+\n+    tree = fd->tree;\n+    node = fd->bnode;\n+    new_node = hfs_bmap_alloc(tree);\n+    if (IS_ERR(new_node))\n+        return new_node;\n+    hfs_bnode_get(node);\n+    hfs_dbg(BNODE_MOD, \"split_nodes: %d - %d - %d\\n\",\n+        node->this, new_node->this, node->next);\n+    new_node->next = node->next;\n+    new_node->prev = node->this;\n+    new_node->parent = node->parent;\n+    new_node->type = node->type;\n+    new_node->height = node->height;\n+\n+    if (node->next)\n+        next_node = hfs_bnode_find(tree, node->next);\n+    else\n+        next_node = NULL;\n+\n+    if (IS_ERR(next_node)) {\n+        hfs_bnode_put(node);\n+        hfs_bnode_put(new_node);\n+        return next_node;\n+    }\n+\n+    size = tree->node_size / 2 - node->num_recs * 2 - 14;\n+    old_rec_off = tree->node_size - 4;\n+    num_recs = 1;\n+    for (;;) {\n+        data_start = hfs_bnode_read_u16(node, old_rec_off);\n+        if (data_start > size)\n+            break;\n+        old_rec_off -= 2;\n+        if (++num_recs < node->num_recs)\n+            continue;\n+        /* panic? */\n+        hfs_bnode_put(node);\n+        hfs_bnode_put(new_node);\n+        if (next_node)\n+            hfs_bnode_put(next_node);\n+        return ERR_PTR(-ENOSPC);\n+    }\n+\n+    if (fd->record + 1 < num_recs) {\n+        /* new record is in the lower half,\n+         * so leave some more space there\n+         */\n+        old_rec_off += 2;\n+        num_recs--;\n+        data_start = hfs_bnode_read_u16(node, old_rec_off);\n+    } else {\n+        hfs_bnode_put(node);\n+        hfs_bnode_get(new_node);\n+        fd->bnode = new_node;\n+        fd->record -= num_recs;\n+        fd->keyoffset -= data_start - 14;\n+        fd->entryoffset -= data_start - 14;\n+    }\n+    new_node->num_recs = node->num_recs - num_recs;\n+    node->num_recs = num_recs;\n+\n+    new_rec_off = tree->node_size - 2;\n+    new_off = 14;\n+    size = data_start - new_off;\n+    num_recs = new_node->num_recs;\n+    data_end = data_start;\n+    while (num_recs) {\n+        hfs_bnode_write_u16(new_node, new_rec_off, new_off);\n+        old_rec_off -= 2;\n+        new_rec_off -= 2;\n+        data_end = hfs_bnode_read_u16(node, old_rec_off);\n+        new_off = data_end - size;\n+        num_recs--;\n+    }\n+    hfs_bnode_write_u16(new_node, new_rec_off, new_off);\n+    hfs_bnode_copy(new_node, 14, node, data_start, data_end - data_start);\n+\n+    /* update new bnode header */\n+    node_desc.next = cpu_to_be32(new_node->next);\n+    node_desc.prev = cpu_to_be32(new_node->prev);\n+    node_desc.type = new_node->type;\n+    node_desc.height = new_node->height;\n+    node_desc.num_recs = cpu_to_be16(new_node->num_recs);\n+    node_desc.reserved = 0;\n+    hfs_bnode_write(new_node, &node_desc, 0, sizeof(node_desc));\n+\n+    /* update previous bnode header */\n+    node->next = new_node->this;\n+    hfs_bnode_read(node, &node_desc, 0, sizeof(node_desc));\n+    node_desc.next = cpu_to_be32(node->next);\n+    node_desc.num_recs = cpu_to_be16(node->num_recs);\n+    hfs_bnode_write(node, &node_desc, 0, sizeof(node_desc));\n+\n+    /* update next bnode header */\n+    if (next_node) {\n+        next_node->prev = new_node->this;\n+        hfs_bnode_read(next_node, &node_desc, 0, sizeof(node_desc));\n+        node_desc.prev = cpu_to_be32(next_node->prev);\n+        hfs_bnode_write(next_node, &node_desc, 0, sizeof(node_desc));\n+        hfs_bnode_put(next_node);\n+    } else if (node->this == tree->leaf_tail) {\n+        /* if there is no next node, this might be the new tail */\n+        tree->leaf_tail = new_node->this;\n+        mark_inode_dirty(tree->inode);\n+    }\n+\n+    hfs_bnode_dump(node);\n+    hfs_bnode_dump(new_node);\n+    hfs_bnode_put(node);\n+\n+    return new_node;\n }\n \n static int hfs_brec_update_parent(struct hfs_find_data *fd)\ndiff --git a/fs/hfs/btree.c b/fs/hfs/btree.c\nindex 2fa4b1f8cc7f..29513d9b80ad 100644\n--- a/fs/hfs/btree.c\n+++ b/fs/hfs/btree.c\n@@ -249,76 +249,77 @@ int hfs_bmap_reserve(struct hfs_btree *tree, int rsvd_nodes)\n \n struct hfs_bnode *hfs_bmap_alloc(struct hfs_btree *tree)\n {\n-\tstruct hfs_bnode *node, *next_node;\n-\tstruct page **pagep;\n-\tu32 nidx, idx;\n-\tunsigned off;\n-\tu16 off16;\n-\tu16 len;\n-\tu8 *data, byte, m;\n-\tint i, res;\n-\n-\tres = hfs_bmap_reserve(tree, 1);\n-\tif (res)\n-\t\treturn ERR_PTR(res);\n-\n-\tnidx = 0;\n-\tnode = hfs_bnode_find(tree, nidx);\n-\tif (IS_ERR(node))\n-\t\treturn node;\n-\tlen = hfs_brec_lenoff(node, 2, &off16);\n-\toff = off16;\n-\n-\toff += node->page_offset;\n-\tpagep = node->page + (off >> PAGE_SHIFT);\n-\tdata = kmap_local_page(*pagep);\n-\toff &= ~PAGE_MASK;\n-\tidx = 0;\n-\n-\tfor (;;) {\n-\t\twhile (len) {\n-\t\t\tbyte = data[off];\n-\t\t\tif (byte != 0xff) {\n-\t\t\t\tfor (m = 0x80, i = 0; i < 8; m >>= 1, i++) {\n-\t\t\t\t\tif (!(byte & m)) {\n-\t\t\t\t\t\tidx += i;\n-\t\t\t\t\t\tdata[off] |= m;\n-\t\t\t\t\t\tset_page_dirty(*pagep);\n-\t\t\t\t\t\tkunmap_local(data);\n-\t\t\t\t\t\ttree->free_nodes--;\n-\t\t\t\t\t\tmark_inode_dirty(tree->inode);\n-\t\t\t\t\t\thfs_bnode_put(node);\n-\t\t\t\t\t\treturn hfs_bnode_create(tree, idx);\n-\t\t\t\t\t}\n-\t\t\t\t}\n-\t\t\t}\n-\t\t\tif (++off >= PAGE_SIZE) {\n-\t\t\t\tkunmap_local(data);\n-\t\t\t\tdata = kmap_local_page(*++pagep);\n-\t\t\t\toff = 0;\n-\t\t\t}\n-\t\t\tidx += 8;\n-\t\t\tlen--;\n-\t\t}\n-\t\tkunmap_local(data);\n-\t\tnidx = node->next;\n-\t\tif (!nidx) {\n-\t\t\tprintk(KERN_DEBUG \"create new bmap node...\\n\");\n-\t\t\tnext_node = hfs_bmap_new_bmap(node, idx);\n-\t\t} else\n-\t\t\tnext_node = hfs_bnode_find(tree, nidx);\n-\t\thfs_bnode_put(node);\n-\t\tif (IS_ERR(next_node))\n-\t\t\treturn next_node;\n-\t\tnode = next_node;\n-\n-\t\tlen = hfs_brec_lenoff(node, 0, &off16);\n-\t\toff = off16;\n-\t\toff += node->page_offset;\n-\t\tpagep = node->page + (off >> PAGE_SHIFT);\n-\t\tdata = kmap_local_page(*pagep);\n-\t\toff &= ~PAGE_MASK;\n-\t}\n+    struct hfs_bnode *node, *next_node;\n+    struct page **pagep;\n+    u32 nidx, idx;\n+    unsigned off;\n+    u16 off16;\n+    u16 len;\n+    u8 *data, byte, m;\n+    int i, res;\n+\n+    res = hfs_bmap_reserve(tree, 1);\n+    if (res)\n+        return ERR_PTR(res);\n+\n+    nidx = 0;\n+    node = hfs_bnode_find(tree, nidx);\n+    if (IS_ERR(node))\n+        return node;\n+    len = hfs_brec_lenoff(node, 2, &off16);\n+    off = off16;\n+\n+    off += node->page_offset;\n+    pagep = node->page + (off >> PAGE_SHIFT);\n+    data = kmap_local_page(*pagep);\n+    off &= ~PAGE_MASK;\n+    idx = 0;\n+\n+    for (;;) {\n+        while (len) {\n+            byte = data[off];\n+            if (byte != 0xff) {\n+                for (m = 0x80, i = 0; i < 8; m >>= 1, i++) {\n+                    if (!(byte & m)) {\n+                        idx += i;\n+                        data[off] |= m;\n+                        set_page_dirty(*pagep);\n+                        kunmap_local(data);\n+                        tree->free_nodes--;\n+                        mark_inode_dirty(tree->inode);\n+                        hfs_bnode_get(node); // Ensure the reference count is incremented\n+                        hfs_bnode_put(node);\n+                        return hfs_bnode_create(tree, idx);\n+                    }\n+                }\n+            }\n+            if (++off >= PAGE_SIZE) {\n+                kunmap_local(data);\n+                data = kmap_local_page(*++pagep);\n+                off = 0;\n+            }\n+            idx += 8;\n+            len--;\n+        }\n+        kunmap_local(data);\n+        nidx = node->next;\n+        if (!nidx) {\n+            printk(KERN_DEBUG \"create new bmap node...\\n\");\n+            next_node = hfs_bmap_new_bmap(node, idx);\n+        } else\n+            next_node = hfs_bnode_find(tree, nidx);\n+        hfs_bnode_put(node);\n+        if (IS_ERR(next_node))\n+            return next_node;\n+        node = next_node;\n+\n+        len = hfs_brec_lenoff(node, 0, &off16);\n+        off = off16;\n+        off += node->page_offset;\n+        pagep = node->page + (off >> PAGE_SHIFT);\n+        data = kmap_local_page(*pagep);\n+        off &= ~PAGE_MASK;\n+    }\n }\n \n void hfs_bmap_free(struct hfs_bnode *node)\n",
            "diff --git a/fs/hfs/bnode.c b/fs/hfs/bnode.c\nindex 2015e42e752a..d19d2f10ec51 100644\n--- a/fs/hfs/bnode.c\n+++ b/fs/hfs/bnode.c\n@@ -456,29 +456,32 @@ void hfs_bnode_get(struct hfs_bnode *node)\n /* Dispose of resources used by a node */\n void hfs_bnode_put(struct hfs_bnode *node)\n {\n-\tif (node) {\n-\t\tstruct hfs_btree *tree = node->tree;\n-\t\tint i;\n-\n-\t\thfs_dbg(BNODE_REFS, \"put_node(%d:%d): %d\\n\",\n-\t\t\tnode->tree->cnid, node->this,\n-\t\t\tatomic_read(&node->refcnt));\n-\t\tBUG_ON(!atomic_read(&node->refcnt));\n-\t\tif (!atomic_dec_and_lock(&node->refcnt, &tree->hash_lock))\n-\t\t\treturn;\n-\t\tfor (i = 0; i < tree->pages_per_bnode; i++) {\n-\t\t\tif (!node->page[i])\n-\t\t\t\tcontinue;\n-\t\t\tmark_page_accessed(node->page[i]);\n-\t\t}\n-\n-\t\tif (test_bit(HFS_BNODE_DELETED, &node->flags)) {\n-\t\t\thfs_bnode_unhash(node);\n-\t\t\tspin_unlock(&tree->hash_lock);\n-\t\t\thfs_bmap_free(node);\n-\t\t\thfs_bnode_free(node);\n-\t\t\treturn;\n-\t\t}\n-\t\tspin_unlock(&tree->hash_lock);\n-\t}\n+    if (node) {\n+        struct hfs_btree *tree = node->tree;\n+        int i;\n+\n+        hfs_dbg(BNODE_REFS, \"put_node(%d:%d): %d\\n\",\n+            node->tree->cnid, node->this,\n+            atomic_read(&node->refcnt));\n+        if (!atomic_read(&node->refcnt)) {\n+            pr_err(\"Attempting to put a node with zero refcnt: %d\\n\", node->this);\n+            return;\n+        }\n+        if (!atomic_dec_and_lock(&node->refcnt, &tree->hash_lock))\n+            return;\n+        for (i = 0; i < tree->pages_per_bnode; i++) {\n+            if (!node->page[i])\n+                continue;\n+            mark_page_accessed(node->page[i]);\n+        }\n+\n+        if (test_bit(HFS_BNODE_DELETED, &node->flags)) {\n+            hfs_bnode_unhash(node);\n+            spin_unlock(&tree->hash_lock);\n+            hfs_bmap_free(node);\n+            hfs_bnode_free(node);\n+            return;\n+        }\n+        spin_unlock(&tree->hash_lock);\n+    }\n }\ndiff --git a/fs/hfs/btree.c b/fs/hfs/btree.c\nindex 2fa4b1f8cc7f..62a84ad5af4a 100644\n--- a/fs/hfs/btree.c\n+++ b/fs/hfs/btree.c\n@@ -249,76 +249,78 @@ int hfs_bmap_reserve(struct hfs_btree *tree, int rsvd_nodes)\n \n struct hfs_bnode *hfs_bmap_alloc(struct hfs_btree *tree)\n {\n-\tstruct hfs_bnode *node, *next_node;\n-\tstruct page **pagep;\n-\tu32 nidx, idx;\n-\tunsigned off;\n-\tu16 off16;\n-\tu16 len;\n-\tu8 *data, byte, m;\n-\tint i, res;\n-\n-\tres = hfs_bmap_reserve(tree, 1);\n-\tif (res)\n-\t\treturn ERR_PTR(res);\n-\n-\tnidx = 0;\n-\tnode = hfs_bnode_find(tree, nidx);\n-\tif (IS_ERR(node))\n-\t\treturn node;\n-\tlen = hfs_brec_lenoff(node, 2, &off16);\n-\toff = off16;\n-\n-\toff += node->page_offset;\n-\tpagep = node->page + (off >> PAGE_SHIFT);\n-\tdata = kmap_local_page(*pagep);\n-\toff &= ~PAGE_MASK;\n-\tidx = 0;\n-\n-\tfor (;;) {\n-\t\twhile (len) {\n-\t\t\tbyte = data[off];\n-\t\t\tif (byte != 0xff) {\n-\t\t\t\tfor (m = 0x80, i = 0; i < 8; m >>= 1, i++) {\n-\t\t\t\t\tif (!(byte & m)) {\n-\t\t\t\t\t\tidx += i;\n-\t\t\t\t\t\tdata[off] |= m;\n-\t\t\t\t\t\tset_page_dirty(*pagep);\n-\t\t\t\t\t\tkunmap_local(data);\n-\t\t\t\t\t\ttree->free_nodes--;\n-\t\t\t\t\t\tmark_inode_dirty(tree->inode);\n-\t\t\t\t\t\thfs_bnode_put(node);\n-\t\t\t\t\t\treturn hfs_bnode_create(tree, idx);\n-\t\t\t\t\t}\n-\t\t\t\t}\n-\t\t\t}\n-\t\t\tif (++off >= PAGE_SIZE) {\n-\t\t\t\tkunmap_local(data);\n-\t\t\t\tdata = kmap_local_page(*++pagep);\n-\t\t\t\toff = 0;\n-\t\t\t}\n-\t\t\tidx += 8;\n-\t\t\tlen--;\n-\t\t}\n-\t\tkunmap_local(data);\n-\t\tnidx = node->next;\n-\t\tif (!nidx) {\n-\t\t\tprintk(KERN_DEBUG \"create new bmap node...\\n\");\n-\t\t\tnext_node = hfs_bmap_new_bmap(node, idx);\n-\t\t} else\n-\t\t\tnext_node = hfs_bnode_find(tree, nidx);\n-\t\thfs_bnode_put(node);\n-\t\tif (IS_ERR(next_node))\n-\t\t\treturn next_node;\n-\t\tnode = next_node;\n-\n-\t\tlen = hfs_brec_lenoff(node, 0, &off16);\n-\t\toff = off16;\n-\t\toff += node->page_offset;\n-\t\tpagep = node->page + (off >> PAGE_SHIFT);\n-\t\tdata = kmap_local_page(*pagep);\n-\t\toff &= ~PAGE_MASK;\n-\t}\n+    struct hfs_bnode *node, *next_node;\n+    struct page **pagep;\n+    u32 nidx, idx;\n+    unsigned off;\n+    u16 off16;\n+    u16 len;\n+    u8 *data, byte, m;\n+    int i, res;\n+\n+    res = hfs_bmap_reserve(tree, 1);\n+    if (res)\n+        return ERR_PTR(res);\n+\n+    nidx = 0;\n+    node = hfs_bnode_find(tree, nidx);\n+    if (IS_ERR(node))\n+        return node;\n+    hfs_bnode_get(node); // Ensure the reference count is incremented\n+    len = hfs_brec_lenoff(node, 2, &off16);\n+    off = off16;\n+\n+    off += node->page_offset;\n+    pagep = node->page + (off >> PAGE_SHIFT);\n+    data = kmap_local_page(*pagep);\n+    off &= ~PAGE_MASK;\n+    idx = 0;\n+\n+    for (;;) {\n+        while (len) {\n+            byte = data[off];\n+            if (byte != 0xff) {\n+                for (m = 0x80, i = 0; i < 8; m >>= 1, i++) {\n+                    if (!(byte & m)) {\n+                        idx += i;\n+                        data[off] |= m;\n+                        set_page_dirty(*pagep);\n+                        kunmap_local(data);\n+                        tree->free_nodes--;\n+                        mark_inode_dirty(tree->inode);\n+                        hfs_bnode_put(node);\n+                        return hfs_bnode_create(tree, idx);\n+                    }\n+                }\n+            }\n+            if (++off >= PAGE_SIZE) {\n+                kunmap_local(data);\n+                data = kmap_local_page(*++pagep);\n+                off = 0;\n+            }\n+            idx += 8;\n+            len--;\n+        }\n+        kunmap_local(data);\n+        nidx = node->next;\n+        if (!nidx) {\n+            printk(KERN_DEBUG \"create new bmap node...\\n\");\n+            next_node = hfs_bmap_new_bmap(node, idx);\n+        } else\n+            next_node = hfs_bnode_find(tree, nidx);\n+        hfs_bnode_put(node);\n+        if (IS_ERR(next_node))\n+            return next_node;\n+        node = next_node;\n+        hfs_bnode_get(node); // Ensure the reference count is incremented\n+\n+        len = hfs_brec_lenoff(node, 0, &off16);\n+        off = off16;\n+        off += node->page_offset;\n+        pagep = node->page + (off >> PAGE_SHIFT);\n+        data = kmap_local_page(*pagep);\n+        off &= ~PAGE_MASK;\n+    }\n }\n \n void hfs_bmap_free(struct hfs_bnode *node)\n",
            "diff --git a/fs/hfs/bnode.c b/fs/hfs/bnode.c\nindex 2015e42e752a..182bdf8034e4 100644\n--- a/fs/hfs/bnode.c\n+++ b/fs/hfs/bnode.c\n@@ -463,7 +463,11 @@ void hfs_bnode_put(struct hfs_bnode *node)\n \t\thfs_dbg(BNODE_REFS, \"put_node(%d:%d): %d\\n\",\n \t\t\tnode->tree->cnid, node->this,\n \t\t\tatomic_read(&node->refcnt));\n-\t\tBUG_ON(!atomic_read(&node->refcnt));\n+\t\tif (!atomic_read(&node->refcnt)) {\n+\t\t\tpr_err(\"hfs_bnode_put: refcnt is zero for node %d:%d\\n\",\n+\t\t\t       node->tree->cnid, node->this);\n+\t\t\treturn;\n+\t\t}\n \t\tif (!atomic_dec_and_lock(&node->refcnt, &tree->hash_lock))\n \t\t\treturn;\n \t\tfor (i = 0; i < tree->pages_per_bnode; i++) {\ndiff --git a/fs/hfs/brec.c b/fs/hfs/brec.c\nindex 896396554bcc..1211c9838c74 100644\n--- a/fs/hfs/brec.c\n+++ b/fs/hfs/brec.c\n@@ -200,6 +200,7 @@ int hfs_brec_remove(struct hfs_find_data *fd)\n \t\tparent = hfs_bnode_find(tree, node->parent);\n \t\tif (IS_ERR(parent))\n \t\t\treturn PTR_ERR(parent);\n+\t\thfs_bnode_get(node); // Ensure refcnt is incremented before put\n \t\thfs_bnode_put(node);\n \t\tnode = fd->bnode = parent;\n \n"
        ],
        "special_crash": [],
        "crash": [
            "diff --git a/fs/hfsplus/brec.c b/fs/hfsplus/brec.c\nindex 1918544a7871..6deb7bab74e8 100644\n--- a/fs/hfsplus/brec.c\n+++ b/fs/hfsplus/brec.c\n@@ -234,123 +234,123 @@ int hfs_brec_remove(struct hfs_find_data *fd)\n \n static struct hfs_bnode *hfs_bnode_split(struct hfs_find_data *fd)\n {\n-\tstruct hfs_btree *tree;\n-\tstruct hfs_bnode *node, *new_node, *next_node;\n-\tstruct hfs_bnode_desc node_desc;\n-\tint num_recs, new_rec_off, new_off, old_rec_off;\n-\tint data_start, data_end, size;\n-\n-\ttree = fd->tree;\n-\tnode = fd->bnode;\n-\tnew_node = hfs_bmap_alloc(tree);\n-\tif (IS_ERR(new_node))\n-\t\treturn new_node;\n-\thfs_bnode_get(node);\n-\thfs_dbg(BNODE_MOD, \"split_nodes: %d - %d - %d\\n\",\n-\t\tnode->this, new_node->this, node->next);\n-\tnew_node->next = node->next;\n-\tnew_node->prev = node->this;\n-\tnew_node->parent = node->parent;\n-\tnew_node->type = node->type;\n-\tnew_node->height = node->height;\n-\n-\tif (node->next)\n-\t\tnext_node = hfs_bnode_find(tree, node->next);\n-\telse\n-\t\tnext_node = NULL;\n-\n-\tif (IS_ERR(next_node)) {\n-\t\thfs_bnode_put(node);\n-\t\thfs_bnode_put(new_node);\n-\t\treturn next_node;\n-\t}\n-\n-\tsize = tree->node_size / 2 - node->num_recs * 2 - 14;\n-\told_rec_off = tree->node_size - 4;\n-\tnum_recs = 1;\n-\tfor (;;) {\n-\t\tdata_start = hfs_bnode_read_u16(node, old_rec_off);\n-\t\tif (data_start > size)\n-\t\t\tbreak;\n-\t\told_rec_off -= 2;\n-\t\tif (++num_recs < node->num_recs)\n-\t\t\tcontinue;\n-\t\t/* panic? */\n-\t\thfs_bnode_put(node);\n-\t\thfs_bnode_put(new_node);\n-\t\tif (next_node)\n-\t\t\thfs_bnode_put(next_node);\n-\t\treturn ERR_PTR(-ENOSPC);\n-\t}\n-\n-\tif (fd->record + 1 < num_recs) {\n-\t\t/* new record is in the lower half,\n-\t\t * so leave some more space there\n-\t\t */\n-\t\told_rec_off += 2;\n-\t\tnum_recs--;\n-\t\tdata_start = hfs_bnode_read_u16(node, old_rec_off);\n-\t} else {\n-\t\thfs_bnode_put(node);\n-\t\thfs_bnode_get(new_node);\n-\t\tfd->bnode = new_node;\n-\t\tfd->record -= num_recs;\n-\t\tfd->keyoffset -= data_start - 14;\n-\t\tfd->entryoffset -= data_start - 14;\n-\t}\n-\tnew_node->num_recs = node->num_recs - num_recs;\n-\tnode->num_recs = num_recs;\n-\n-\tnew_rec_off = tree->node_size - 2;\n-\tnew_off = 14;\n-\tsize = data_start - new_off;\n-\tnum_recs = new_node->num_recs;\n-\tdata_end = data_start;\n-\twhile (num_recs) {\n-\t\thfs_bnode_write_u16(new_node, new_rec_off, new_off);\n-\t\told_rec_off -= 2;\n-\t\tnew_rec_off -= 2;\n-\t\tdata_end = hfs_bnode_read_u16(node, old_rec_off);\n-\t\tnew_off = data_end - size;\n-\t\tnum_recs--;\n-\t}\n-\thfs_bnode_write_u16(new_node, new_rec_off, new_off);\n-\thfs_bnode_copy(new_node, 14, node, data_start, data_end - data_start);\n-\n-\t/* update new bnode header */\n-\tnode_desc.next = cpu_to_be32(new_node->next);\n-\tnode_desc.prev = cpu_to_be32(new_node->prev);\n-\tnode_desc.type = new_node->type;\n-\tnode_desc.height = new_node->height;\n-\tnode_desc.num_recs = cpu_to_be16(new_node->num_recs);\n-\tnode_desc.reserved = 0;\n-\thfs_bnode_write(new_node, &node_desc, 0, sizeof(node_desc));\n-\n-\t/* update previous bnode header */\n-\tnode->next = new_node->this;\n-\thfs_bnode_read(node, &node_desc, 0, sizeof(node_desc));\n-\tnode_desc.next = cpu_to_be32(node->next);\n-\tnode_desc.num_recs = cpu_to_be16(node->num_recs);\n-\thfs_bnode_write(node, &node_desc, 0, sizeof(node_desc));\n-\n-\t/* update next bnode header */\n-\tif (next_node) {\n-\t\tnext_node->prev = new_node->this;\n-\t\thfs_bnode_read(next_node, &node_desc, 0, sizeof(node_desc));\n-\t\tnode_desc.prev = cpu_to_be32(next_node->prev);\n-\t\thfs_bnode_write(next_node, &node_desc, 0, sizeof(node_desc));\n-\t\thfs_bnode_put(next_node);\n-\t} else if (node->this == tree->leaf_tail) {\n-\t\t/* if there is no next node, this might be the new tail */\n-\t\ttree->leaf_tail = new_node->this;\n-\t\tmark_inode_dirty(tree->inode);\n-\t}\n-\n-\thfs_bnode_dump(node);\n-\thfs_bnode_dump(new_node);\n-\thfs_bnode_put(node);\n-\n-\treturn new_node;\n+    struct hfs_btree *tree;\n+    struct hfs_bnode *node, *new_node, *next_node;\n+    struct hfs_bnode_desc node_desc;\n+    int num_recs, new_rec_off, new_off, old_rec_off;\n+    int data_start, data_end, size;\n+\n+    tree = fd->tree;\n+    node = fd->bnode;\n+    new_node = hfs_bmap_alloc(tree);\n+    if (IS_ERR(new_node))\n+        return new_node;\n+    hfs_bnode_get(node); // Ensure the reference count is incremented for the current node\n+    hfs_dbg(BNODE_MOD, \"split_nodes: %d - %d - %d\\n\",\n+        node->this, new_node->this, node->next);\n+    new_node->next = node->next;\n+    new_node->prev = node->this;\n+    new_node->parent = node->parent;\n+    new_node->type = node->type;\n+    new_node->height = node->height;\n+\n+    if (node->next)\n+        next_node = hfs_bnode_find(tree, node->next);\n+    else\n+        next_node = NULL;\n+\n+    if (IS_ERR(next_node)) {\n+        hfs_bnode_put(node);\n+        hfs_bnode_put(new_node);\n+        return next_node;\n+    }\n+\n+    size = tree->node_size / 2 - node->num_recs * 2 - 14;\n+    old_rec_off = tree->node_size - 4;\n+    num_recs = 1;\n+    for (;;) {\n+        data_start = hfs_bnode_read_u16(node, old_rec_off);\n+        if (data_start > size)\n+            break;\n+        old_rec_off -= 2;\n+        if (++num_recs < node->num_recs)\n+            continue;\n+        /* panic? */\n+        hfs_bnode_put(node);\n+        hfs_bnode_put(new_node);\n+        if (next_node)\n+            hfs_bnode_put(next_node);\n+        return ERR_PTR(-ENOSPC);\n+    }\n+\n+    if (fd->record + 1 < num_recs) {\n+        /* new record is in the lower half,\n+         * so leave some more space there\n+         */\n+        old_rec_off += 2;\n+        num_recs--;\n+        data_start = hfs_bnode_read_u16(node, old_rec_off);\n+    } else {\n+        hfs_bnode_put(node);\n+        hfs_bnode_get(new_node); // Ensure the reference count is incremented for the new node\n+        fd->bnode = new_node;\n+        fd->record -= num_recs;\n+        fd->keyoffset -= data_start - 14;\n+        fd->entryoffset -= data_start - 14;\n+    }\n+    new_node->num_recs = node->num_recs - num_recs;\n+    node->num_recs = num_recs;\n+\n+    new_rec_off = tree->node_size - 2;\n+    new_off = 14;\n+    size = data_start - new_off;\n+    num_recs = new_node->num_recs;\n+    data_end = data_start;\n+    while (num_recs) {\n+        hfs_bnode_write_u16(new_node, new_rec_off, new_off);\n+        old_rec_off -= 2;\n+        new_rec_off -= 2;\n+        data_end = hfs_bnode_read_u16(node, old_rec_off);\n+        new_off = data_end - size;\n+        num_recs--;\n+    }\n+    hfs_bnode_write_u16(new_node, new_rec_off, new_off);\n+    hfs_bnode_copy(new_node, 14, node, data_start, data_end - data_start);\n+\n+    /* update new bnode header */\n+    node_desc.next = cpu_to_be32(new_node->next);\n+    node_desc.prev = cpu_to_be32(new_node->prev);\n+    node_desc.type = new_node->type;\n+    node_desc.height = new_node->height;\n+    node_desc.num_recs = cpu_to_be16(new_node->num_recs);\n+    node_desc.reserved = 0;\n+    hfs_bnode_write(new_node, &node_desc, 0, sizeof(node_desc));\n+\n+    /* update previous bnode header */\n+    node->next = new_node->this;\n+    hfs_bnode_read(node, &node_desc, 0, sizeof(node_desc));\n+    node_desc.next = cpu_to_be32(node->next);\n+    node_desc.num_recs = cpu_to_be16(node->num_recs);\n+    hfs_bnode_write(node, &node_desc, 0, sizeof(node_desc));\n+\n+    /* update next bnode header */\n+    if (next_node) {\n+        next_node->prev = new_node->this;\n+        hfs_bnode_read(next_node, &node_desc, 0, sizeof(node_desc));\n+        node_desc.prev = cpu_to_be32(next_node->prev);\n+        hfs_bnode_write(next_node, &node_desc, 0, sizeof(node_desc));\n+        hfs_bnode_put(next_node);\n+    } else if (node->this == tree->leaf_tail) {\n+        /* if there is no next node, this might be the new tail */\n+        tree->leaf_tail = new_node->this;\n+        mark_inode_dirty(tree->inode);\n+    }\n+\n+    hfs_bnode_dump(node);\n+    hfs_bnode_dump(new_node);\n+    hfs_bnode_put(node);\n+\n+    return new_node;\n }\n \n static int hfs_brec_update_parent(struct hfs_find_data *fd)\n"
        ],
        "error": []
    },
    "641c688b5c5a0c80d5d5832c5cd9f361c1cbb0a9": {
        "non_crash": [],
        "special_crash": [],
        "crash": [
            "diff --git a/drivers/usb/gadget/legacy/raw_gadget.c b/drivers/usb/gadget/legacy/raw_gadget.c\nindex 2acece16b890..a325bd18242f 100644\n--- a/drivers/usb/gadget/legacy/raw_gadget.c\n+++ b/drivers/usb/gadget/legacy/raw_gadget.c\n@@ -202,29 +202,29 @@ static struct raw_dev *dev_new(void)\n \n static void dev_free(struct kref *kref)\n {\n-\tstruct raw_dev *dev = container_of(kref, struct raw_dev, count);\n-\tint i;\n-\n-\tkfree(dev->udc_name);\n-\tkfree(dev->driver.udc_name);\n-\tkfree(dev->driver.driver.name);\n-\tif (dev->driver_id_number >= 0)\n-\t\tida_free(&driver_id_numbers, dev->driver_id_number);\n-\tif (dev->req) {\n-\t\tif (dev->ep0_urb_queued)\n-\t\t\tusb_ep_dequeue(dev->gadget->ep0, dev->req);\n-\t\tusb_ep_free_request(dev->gadget->ep0, dev->req);\n-\t}\n-\traw_event_queue_destroy(&dev->queue);\n-\tfor (i = 0; i < dev->eps_num; i++) {\n-\t\tif (dev->eps[i].state == STATE_EP_DISABLED)\n-\t\t\tcontinue;\n-\t\tusb_ep_disable(dev->eps[i].ep);\n-\t\tusb_ep_free_request(dev->eps[i].ep, dev->eps[i].req);\n-\t\tkfree(dev->eps[i].ep->desc);\n-\t\tdev->eps[i].state = STATE_EP_DISABLED;\n-\t}\n-\tkfree(dev);\n+    struct raw_dev *dev = container_of(kref, struct raw_dev, count);\n+    int i;\n+\n+    kfree(dev->udc_name);\n+    kfree(dev->driver.udc_name);\n+    kfree(dev->driver.driver.name);\n+    if (dev->driver_id_number >= 0)\n+        ida_free(&driver_id_numbers, dev->driver_id_number);\n+    if (dev->req) {\n+        if (dev->ep0_urb_queued)\n+            usb_ep_dequeue(dev->gadget->ep0, dev->req);\n+        usb_ep_free_request(dev->gadget->ep0, dev->req);\n+    }\n+    raw_event_queue_destroy(&dev->queue);\n+    for (i = 0; i < dev->eps_num; i++) {\n+        if (dev->eps[i].state == STATE_EP_DISABLED)\n+            continue;\n+        usb_ep_disable(dev->eps[i].ep);\n+        usb_ep_free_request(dev->eps[i].ep, dev->eps[i].req);\n+        kfree(dev->eps[i].ep->desc);\n+        dev->eps[i].state = STATE_EP_DISABLED;\n+    }\n+    kfree(dev);\n }\n \n /*----------------------------------------------------------------------*/\n@@ -429,137 +429,136 @@ static int raw_release(struct inode *inode, struct file *fd)\n \n static int raw_ioctl_init(struct raw_dev *dev, unsigned long value)\n {\n-\tint ret = 0;\n-\tint driver_id_number;\n-\tstruct usb_raw_init arg;\n-\tchar *udc_driver_name;\n-\tchar *udc_device_name;\n-\tchar *driver_driver_name;\n-\tunsigned long flags;\n-\n-\tif (copy_from_user(&arg, (void __user *)value, sizeof(arg)))\n-\t\treturn -EFAULT;\n-\n-\tswitch (arg.speed) {\n-\tcase USB_SPEED_UNKNOWN:\n-\t\targ.speed = USB_SPEED_HIGH;\n-\t\tbreak;\n-\tcase USB_SPEED_LOW:\n-\tcase USB_SPEED_FULL:\n-\tcase USB_SPEED_HIGH:\n-\tcase USB_SPEED_SUPER:\n-\t\tbreak;\n-\tdefault:\n-\t\treturn -EINVAL;\n-\t}\n-\n-\tdriver_id_number = ida_alloc(&driver_id_numbers, GFP_KERNEL);\n-\tif (driver_id_number < 0)\n-\t\treturn driver_id_number;\n-\n-\tdriver_driver_name = kmalloc(DRIVER_DRIVER_NAME_LENGTH_MAX, GFP_KERNEL);\n-\tif (!driver_driver_name) {\n-\t\tret = -ENOMEM;\n-\t\tgoto out_free_driver_id_number;\n-\t}\n-\tsnprintf(driver_driver_name, DRIVER_DRIVER_NAME_LENGTH_MAX,\n-\t\t\t\tDRIVER_NAME \".%d\", driver_id_number);\n-\n-\tudc_driver_name = kmalloc(UDC_NAME_LENGTH_MAX, GFP_KERNEL);\n-\tif (!udc_driver_name) {\n-\t\tret = -ENOMEM;\n-\t\tgoto out_free_driver_driver_name;\n-\t}\n-\tret = strscpy(udc_driver_name, &arg.driver_name[0],\n-\t\t\t\tUDC_NAME_LENGTH_MAX);\n-\tif (ret < 0)\n-\t\tgoto out_free_udc_driver_name;\n-\tret = 0;\n-\n-\tudc_device_name = kmalloc(UDC_NAME_LENGTH_MAX, GFP_KERNEL);\n-\tif (!udc_device_name) {\n-\t\tret = -ENOMEM;\n-\t\tgoto out_free_udc_driver_name;\n-\t}\n-\tret = strscpy(udc_device_name, &arg.device_name[0],\n-\t\t\t\tUDC_NAME_LENGTH_MAX);\n-\tif (ret < 0)\n-\t\tgoto out_free_udc_device_name;\n-\tret = 0;\n-\n-\tspin_lock_irqsave(&dev->lock, flags);\n-\tif (dev->state != STATE_DEV_OPENED) {\n-\t\tdev_dbg(dev->dev, \"fail, device is not opened\\n\");\n-\t\tret = -EINVAL;\n-\t\tgoto out_unlock;\n-\t}\n-\tdev->udc_name = udc_driver_name;\n-\n-\tdev->driver.function = DRIVER_DESC;\n-\tdev->driver.max_speed = arg.speed;\n-\tdev->driver.setup = gadget_setup;\n-\tdev->driver.disconnect = gadget_disconnect;\n-\tdev->driver.bind = gadget_bind;\n-\tdev->driver.unbind = gadget_unbind;\n-\tdev->driver.suspend = gadget_suspend;\n-\tdev->driver.resume = gadget_resume;\n-\tdev->driver.reset = gadget_reset;\n-\tdev->driver.driver.name = driver_driver_name;\n-\tdev->driver.udc_name = udc_device_name;\n-\tdev->driver.match_existing_only = 1;\n-\tdev->driver_id_number = driver_id_number;\n-\n-\tdev->state = STATE_DEV_INITIALIZED;\n-\tspin_unlock_irqrestore(&dev->lock, flags);\n-\treturn ret;\n+    int ret = 0;\n+    int driver_id_number;\n+    struct usb_raw_init arg;\n+    char *udc_driver_name;\n+    char *udc_device_name;\n+    char *driver_driver_name;\n+    unsigned long flags;\n+\n+    if (copy_from_user(&arg, (void __user *)value, sizeof(arg)))\n+        return -EFAULT;\n+\n+    switch (arg.speed) {\n+    case USB_SPEED_UNKNOWN:\n+        arg.speed = USB_SPEED_HIGH;\n+        break;\n+    case USB_SPEED_LOW:\n+    case USB_SPEED_FULL:\n+    case USB_SPEED_HIGH:\n+    case USB_SPEED_SUPER:\n+        break;\n+    default:\n+        return -EINVAL;\n+    }\n+\n+    driver_id_number = ida_alloc(&driver_id_numbers, GFP_KERNEL);\n+    if (driver_id_number < 0)\n+        return driver_id_number;\n+\n+    driver_driver_name = kmalloc(DRIVER_DRIVER_NAME_LENGTH_MAX, GFP_KERNEL);\n+    if (!driver_driver_name) {\n+        ret = -ENOMEM;\n+        goto out_free_driver_id_number;\n+    }\n+    snprintf(driver_driver_name, DRIVER_DRIVER_NAME_LENGTH_MAX,\n+             DRIVER_NAME \".%d\", driver_id_number);\n+\n+    udc_driver_name = kmalloc(UDC_NAME_LENGTH_MAX, GFP_KERNEL);\n+    if (!udc_driver_name) {\n+        ret = -ENOMEM;\n+        goto out_free_driver_driver_name;\n+    }\n+    ret = strscpy(udc_driver_name, &arg.driver_name[0],\n+                  UDC_NAME_LENGTH_MAX);\n+    if (ret < 0)\n+        goto out_free_udc_driver_name;\n+    ret = 0;\n+\n+    udc_device_name = kmalloc(UDC_NAME_LENGTH_MAX, GFP_KERNEL);\n+    if (!udc_device_name) {\n+        ret = -ENOMEM;\n+        goto out_free_udc_driver_name;\n+    }\n+    ret = strscpy(udc_device_name, &arg.device_name[0],\n+                  UDC_NAME_LENGTH_MAX);\n+    if (ret < 0)\n+        goto out_free_udc_device_name;\n+    ret = 0;\n+\n+    spin_lock_irqsave(&dev->lock, flags);\n+    if (dev->state != STATE_DEV_OPENED) {\n+        dev_dbg(dev->dev, \"fail, device is not opened\\n\");\n+        ret = -EINVAL;\n+        goto out_unlock;\n+    }\n+    dev->udc_name = udc_driver_name;\n+\n+    dev->driver.function = DRIVER_DESC;\n+    dev->driver.max_speed = arg.speed;\n+    dev->driver.setup = gadget_setup;\n+    dev->driver.disconnect = gadget_disconnect;\n+    dev->driver.bind = gadget_bind;\n+    dev->driver.unbind = gadget_unbind;\n+    dev->driver.suspend = gadget_suspend;\n+    dev->driver.resume = gadget_resume;\n+    dev->driver.reset = gadget_reset;\n+    dev->driver.driver.name = driver_driver_name;\n+    dev->driver.udc_name = udc_device_name;\n+    dev->driver.match_existing_only = 1;\n+    dev->driver_id_number = driver_id_number;\n+\n+    dev->state = STATE_DEV_INITIALIZED;\n+    spin_unlock_irqrestore(&dev->lock, flags);\n+    return ret;\n \n out_unlock:\n-\tspin_unlock_irqrestore(&dev->lock, flags);\n+    spin_unlock_irqrestore(&dev->lock, flags);\n out_free_udc_device_name:\n-\tkfree(udc_device_name);\n+    kfree(udc_device_name);\n out_free_udc_driver_name:\n-\tkfree(udc_driver_name);\n+    kfree(udc_driver_name);\n out_free_driver_driver_name:\n-\tkfree(driver_driver_name);\n+    kfree(driver_driver_name);\n out_free_driver_id_number:\n-\tida_free(&driver_id_numbers, driver_id_number);\n-\treturn ret;\n+    ida_free(&driver_id_numbers, driver_id_number);\n+    return ret;\n }\n \n static int raw_ioctl_run(struct raw_dev *dev, unsigned long value)\n {\n-\tint ret = 0;\n-\tunsigned long flags;\n-\n-\tif (value)\n-\t\treturn -EINVAL;\n-\n-\tspin_lock_irqsave(&dev->lock, flags);\n-\tif (dev->state != STATE_DEV_INITIALIZED) {\n-\t\tdev_dbg(dev->dev, \"fail, device is not initialized\\n\");\n-\t\tret = -EINVAL;\n-\t\tgoto out_unlock;\n-\t}\n-\tdev->state = STATE_DEV_REGISTERING;\n-\tspin_unlock_irqrestore(&dev->lock, flags);\n-\n-\tret = usb_gadget_register_driver(&dev->driver);\n-\n-\tspin_lock_irqsave(&dev->lock, flags);\n-\tif (ret) {\n-\t\tdev_err(dev->dev,\n-\t\t\t\"fail, usb_gadget_register_driver returned %d\\n\", ret);\n-\t\tdev->state = STATE_DEV_FAILED;\n-\t\tgoto out_unlock;\n-\t}\n-\tdev->gadget_registered = true;\n-\tdev->state = STATE_DEV_RUNNING;\n-\t/* Matches kref_put() in raw_release(). */\n-\tkref_get(&dev->count);\n+    int ret = 0;\n+    unsigned long flags;\n+\n+    if (value)\n+        return -EINVAL;\n+\n+    spin_lock_irqsave(&dev->lock, flags);\n+    if (dev->state != STATE_DEV_INITIALIZED) {\n+        dev_dbg(dev->dev, \"fail, device is not initialized\\n\");\n+        ret = -EINVAL;\n+        goto out_unlock;\n+    }\n+    dev->state = STATE_DEV_REGISTERING;\n+    spin_unlock_irqrestore(&dev->lock, flags);\n+\n+    ret = usb_gadget_register_driver(&dev->driver);\n+\n+    spin_lock_irqsave(&dev->lock, flags);\n+    if (ret) {\n+        dev_err(dev->dev,\n+            \"fail, usb_gadget_register_driver returned %d\\n\", ret);\n+        dev->state = STATE_DEV_FAILED;\n+        goto out_unlock;\n+    }\n+    dev->gadget_registered = true;\n+    dev->state = STATE_DEV_RUNNING;\n+    kref_get(&dev->count);\n \n out_unlock:\n-\tspin_unlock_irqrestore(&dev->lock, flags);\n-\treturn ret;\n+    spin_unlock_irqrestore(&dev->lock, flags);\n+    return ret;\n }\n \n static int raw_ioctl_event_fetch(struct raw_dev *dev, unsigned long value)\n",
            "diff --git a/drivers/usb/gadget/legacy/raw_gadget.c b/drivers/usb/gadget/legacy/raw_gadget.c\nindex 2acece16b890..34b8cb5b12c7 100644\n--- a/drivers/usb/gadget/legacy/raw_gadget.c\n+++ b/drivers/usb/gadget/legacy/raw_gadget.c\n@@ -385,10 +385,15 @@ static int raw_open(struct inode *inode, struct file *fd)\n \tdev = dev_new();\n \tif (!dev)\n \t\treturn -ENOMEM;\n+\n \tfd->private_data = dev;\n \tdev->state = STATE_DEV_OPENED;\n \tdev->dev = raw_misc_device.this_device;\n \treturn 0;\n+\n+out_free_dev:\n+\tdev_free(&dev->count);\n+\treturn -ENOMEM;\n }\n \n static int raw_release(struct inode *inode, struct file *fd)\n@@ -432,9 +437,9 @@ static int raw_ioctl_init(struct raw_dev *dev, unsigned long value)\n \tint ret = 0;\n \tint driver_id_number;\n \tstruct usb_raw_init arg;\n-\tchar *udc_driver_name;\n-\tchar *udc_device_name;\n-\tchar *driver_driver_name;\n+\tchar *udc_driver_name = NULL;\n+\tchar *udc_device_name = NULL;\n+\tchar *driver_driver_name = NULL;\n \tunsigned long flags;\n \n \tif (copy_from_user(&arg, (void __user *)value, sizeof(arg)))\n",
            "diff --git a/drivers/usb/gadget/legacy/raw_gadget.c b/drivers/usb/gadget/legacy/raw_gadget.c\nindex 2acece16b890..9bd525f09e45 100644\n--- a/drivers/usb/gadget/legacy/raw_gadget.c\n+++ b/drivers/usb/gadget/legacy/raw_gadget.c\n@@ -393,36 +393,36 @@ static int raw_open(struct inode *inode, struct file *fd)\n \n static int raw_release(struct inode *inode, struct file *fd)\n {\n-\tint ret = 0;\n-\tstruct raw_dev *dev = fd->private_data;\n-\tunsigned long flags;\n-\tbool unregister = false;\n-\n-\tspin_lock_irqsave(&dev->lock, flags);\n-\tdev->state = STATE_DEV_CLOSED;\n-\tif (!dev->gadget) {\n-\t\tspin_unlock_irqrestore(&dev->lock, flags);\n-\t\tgoto out_put;\n-\t}\n-\tif (dev->gadget_registered)\n-\t\tunregister = true;\n-\tdev->gadget_registered = false;\n-\tspin_unlock_irqrestore(&dev->lock, flags);\n-\n-\tif (unregister) {\n-\t\tret = usb_gadget_unregister_driver(&dev->driver);\n-\t\tif (ret != 0)\n-\t\t\tdev_err(dev->dev,\n-\t\t\t\t\"usb_gadget_unregister_driver() failed with %d\\n\",\n-\t\t\t\tret);\n-\t\t/* Matches kref_get() in raw_ioctl_run(). */\n-\t\tkref_put(&dev->count, dev_free);\n-\t}\n+    int ret = 0;\n+    struct raw_dev *dev = fd->private_data;\n+    unsigned long flags;\n+    bool unregister = false;\n+\n+    spin_lock_irqsave(&dev->lock, flags);\n+    dev->state = STATE_DEV_CLOSED;\n+    if (!dev->gadget) {\n+        spin_unlock_irqrestore(&dev->lock, flags);\n+        goto out_put;\n+    }\n+    if (dev->gadget_registered)\n+        unregister = true;\n+    dev->gadget_registered = false;\n+    spin_unlock_irqrestore(&dev->lock, flags);\n+\n+    if (unregister) {\n+        ret = usb_gadget_unregister_driver(&dev->driver);\n+        if (ret != 0)\n+            dev_err(dev->dev,\n+                \"usb_gadget_unregister_driver() failed with %d\\n\",\n+                ret);\n+        /* Matches kref_get() in raw_ioctl_run(). */\n+        kref_put(&dev->count, dev_free);\n+    }\n \n out_put:\n-\t/* Matches dev_new() in raw_open(). */\n-\tkref_put(&dev->count, dev_free);\n-\treturn ret;\n+    /* Matches dev_new() in raw_open(). */\n+    kref_put(&dev->count, dev_free);\n+    return ret;\n }\n \n /*----------------------------------------------------------------------*/\n",
            "diff --git a/drivers/usb/gadget/legacy/raw_gadget.c b/drivers/usb/gadget/legacy/raw_gadget.c\nindex 2acece16b890..fbf2d326ad79 100644\n--- a/drivers/usb/gadget/legacy/raw_gadget.c\n+++ b/drivers/usb/gadget/legacy/raw_gadget.c\n@@ -388,6 +388,10 @@ static int raw_open(struct inode *inode, struct file *fd)\n \tfd->private_data = dev;\n \tdev->state = STATE_DEV_OPENED;\n \tdev->dev = raw_misc_device.this_device;\n+\n+\t/* Matches kref_put() in raw_release(). */\n+\tkref_get(&dev->count);\n+\n \treturn 0;\n }\n \n",
            "diff --git a/drivers/usb/gadget/legacy/raw_gadget.c b/drivers/usb/gadget/legacy/raw_gadget.c\nindex 2acece16b890..6552fca6c697 100644\n--- a/drivers/usb/gadget/legacy/raw_gadget.c\n+++ b/drivers/usb/gadget/legacy/raw_gadget.c\n@@ -376,154 +376,150 @@ static struct miscdevice raw_misc_device;\n \n static int raw_open(struct inode *inode, struct file *fd)\n {\n-\tstruct raw_dev *dev;\n-\n-\t/* Nonblocking I/O is not supported yet. */\n-\tif (fd->f_flags & O_NONBLOCK)\n-\t\treturn -EINVAL;\n-\n-\tdev = dev_new();\n-\tif (!dev)\n-\t\treturn -ENOMEM;\n-\tfd->private_data = dev;\n-\tdev->state = STATE_DEV_OPENED;\n-\tdev->dev = raw_misc_device.this_device;\n-\treturn 0;\n+    struct raw_dev *dev;\n+\n+    /* Nonblocking I/O is not supported yet. */\n+    if (fd->f_flags & O_NONBLOCK)\n+        return -EINVAL;\n+\n+    dev = dev_new();\n+    if (!dev)\n+        return -ENOMEM;\n+    fd->private_data = dev;\n+    dev->state = STATE_DEV_OPENED;\n+    dev->dev = raw_misc_device.this_device;\n+    return 0;\n }\n \n static int raw_release(struct inode *inode, struct file *fd)\n {\n-\tint ret = 0;\n-\tstruct raw_dev *dev = fd->private_data;\n-\tunsigned long flags;\n-\tbool unregister = false;\n-\n-\tspin_lock_irqsave(&dev->lock, flags);\n-\tdev->state = STATE_DEV_CLOSED;\n-\tif (!dev->gadget) {\n-\t\tspin_unlock_irqrestore(&dev->lock, flags);\n-\t\tgoto out_put;\n-\t}\n-\tif (dev->gadget_registered)\n-\t\tunregister = true;\n-\tdev->gadget_registered = false;\n-\tspin_unlock_irqrestore(&dev->lock, flags);\n-\n-\tif (unregister) {\n-\t\tret = usb_gadget_unregister_driver(&dev->driver);\n-\t\tif (ret != 0)\n-\t\t\tdev_err(dev->dev,\n-\t\t\t\t\"usb_gadget_unregister_driver() failed with %d\\n\",\n-\t\t\t\tret);\n-\t\t/* Matches kref_get() in raw_ioctl_run(). */\n-\t\tkref_put(&dev->count, dev_free);\n-\t}\n+    int ret = 0;\n+    struct raw_dev *dev = fd->private_data;\n+    unsigned long flags;\n+    bool unregister = false;\n+\n+    spin_lock_irqsave(&dev->lock, flags);\n+    dev->state = STATE_DEV_CLOSED;\n+    if (!dev->gadget) {\n+        spin_unlock_irqrestore(&dev->lock, flags);\n+        goto out_put;\n+    }\n+    if (dev->gadget_registered)\n+        unregister = true;\n+    dev->gadget_registered = false;\n+    spin_unlock_irqrestore(&dev->lock, flags);\n+\n+    if (unregister) {\n+        ret = usb_gadget_unregister_driver(&dev->driver);\n+        if (ret != 0)\n+            dev_err(dev->dev,\n+                    \"usb_gadget_unregister_driver() failed with %d\\n\",\n+                    ret);\n+        /* Matches kref_get() in raw_ioctl_run(). */\n+        kref_put(&dev->count, dev_free);\n+    }\n \n out_put:\n-\t/* Matches dev_new() in raw_open(). */\n-\tkref_put(&dev->count, dev_free);\n-\treturn ret;\n+    /* Matches dev_new() in raw_open(). */\n+    kref_put(&dev->count, dev_free);\n+    return ret;\n }\n \n /*----------------------------------------------------------------------*/\n \n static int raw_ioctl_init(struct raw_dev *dev, unsigned long value)\n {\n-\tint ret = 0;\n-\tint driver_id_number;\n-\tstruct usb_raw_init arg;\n-\tchar *udc_driver_name;\n-\tchar *udc_device_name;\n-\tchar *driver_driver_name;\n-\tunsigned long flags;\n-\n-\tif (copy_from_user(&arg, (void __user *)value, sizeof(arg)))\n-\t\treturn -EFAULT;\n-\n-\tswitch (arg.speed) {\n-\tcase USB_SPEED_UNKNOWN:\n-\t\targ.speed = USB_SPEED_HIGH;\n-\t\tbreak;\n-\tcase USB_SPEED_LOW:\n-\tcase USB_SPEED_FULL:\n-\tcase USB_SPEED_HIGH:\n-\tcase USB_SPEED_SUPER:\n-\t\tbreak;\n-\tdefault:\n-\t\treturn -EINVAL;\n-\t}\n-\n-\tdriver_id_number = ida_alloc(&driver_id_numbers, GFP_KERNEL);\n-\tif (driver_id_number < 0)\n-\t\treturn driver_id_number;\n-\n-\tdriver_driver_name = kmalloc(DRIVER_DRIVER_NAME_LENGTH_MAX, GFP_KERNEL);\n-\tif (!driver_driver_name) {\n-\t\tret = -ENOMEM;\n-\t\tgoto out_free_driver_id_number;\n-\t}\n-\tsnprintf(driver_driver_name, DRIVER_DRIVER_NAME_LENGTH_MAX,\n-\t\t\t\tDRIVER_NAME \".%d\", driver_id_number);\n-\n-\tudc_driver_name = kmalloc(UDC_NAME_LENGTH_MAX, GFP_KERNEL);\n-\tif (!udc_driver_name) {\n-\t\tret = -ENOMEM;\n-\t\tgoto out_free_driver_driver_name;\n-\t}\n-\tret = strscpy(udc_driver_name, &arg.driver_name[0],\n-\t\t\t\tUDC_NAME_LENGTH_MAX);\n-\tif (ret < 0)\n-\t\tgoto out_free_udc_driver_name;\n-\tret = 0;\n-\n-\tudc_device_name = kmalloc(UDC_NAME_LENGTH_MAX, GFP_KERNEL);\n-\tif (!udc_device_name) {\n-\t\tret = -ENOMEM;\n-\t\tgoto out_free_udc_driver_name;\n-\t}\n-\tret = strscpy(udc_device_name, &arg.device_name[0],\n-\t\t\t\tUDC_NAME_LENGTH_MAX);\n-\tif (ret < 0)\n-\t\tgoto out_free_udc_device_name;\n-\tret = 0;\n-\n-\tspin_lock_irqsave(&dev->lock, flags);\n-\tif (dev->state != STATE_DEV_OPENED) {\n-\t\tdev_dbg(dev->dev, \"fail, device is not opened\\n\");\n-\t\tret = -EINVAL;\n-\t\tgoto out_unlock;\n-\t}\n-\tdev->udc_name = udc_driver_name;\n-\n-\tdev->driver.function = DRIVER_DESC;\n-\tdev->driver.max_speed = arg.speed;\n-\tdev->driver.setup = gadget_setup;\n-\tdev->driver.disconnect = gadget_disconnect;\n-\tdev->driver.bind = gadget_bind;\n-\tdev->driver.unbind = gadget_unbind;\n-\tdev->driver.suspend = gadget_suspend;\n-\tdev->driver.resume = gadget_resume;\n-\tdev->driver.reset = gadget_reset;\n-\tdev->driver.driver.name = driver_driver_name;\n-\tdev->driver.udc_name = udc_device_name;\n-\tdev->driver.match_existing_only = 1;\n-\tdev->driver_id_number = driver_id_number;\n-\n-\tdev->state = STATE_DEV_INITIALIZED;\n-\tspin_unlock_irqrestore(&dev->lock, flags);\n-\treturn ret;\n+    int ret = 0;\n+    int driver_id_number;\n+    struct usb_raw_init arg;\n+    char *udc_driver_name = NULL;\n+    char *udc_device_name = NULL;\n+    char *driver_driver_name = NULL;\n+    unsigned long flags;\n+\n+    if (copy_from_user(&arg, (void __user *)value, sizeof(arg)))\n+        return -EFAULT;\n+\n+    switch (arg.speed) {\n+    case USB_SPEED_UNKNOWN:\n+        arg.speed = USB_SPEED_HIGH;\n+        break;\n+    case USB_SPEED_LOW:\n+    case USB_SPEED_FULL:\n+    case USB_SPEED_HIGH:\n+    case USB_SPEED_SUPER:\n+        break;\n+    default:\n+        return -EINVAL;\n+    }\n+\n+    driver_id_number = ida_alloc(&driver_id_numbers, GFP_KERNEL);\n+    if (driver_id_number < 0)\n+        return driver_id_number;\n+\n+    driver_driver_name = kmalloc(DRIVER_DRIVER_NAME_LENGTH_MAX, GFP_KERNEL);\n+    if (!driver_driver_name) {\n+        ret = -ENOMEM;\n+        goto out_free_driver_id_number;\n+    }\n+    snprintf(driver_driver_name, DRIVER_DRIVER_NAME_LENGTH_MAX,\n+             DRIVER_NAME \".%d\", driver_id_number);\n+\n+    udc_driver_name = kmalloc(UDC_NAME_LENGTH_MAX, GFP_KERNEL);\n+    if (!udc_driver_name) {\n+        ret = -ENOMEM;\n+        goto out_free_driver_driver_name;\n+    }\n+    ret = strscpy(udc_driver_name, &arg.driver_name[0], UDC_NAME_LENGTH_MAX);\n+    if (ret < 0)\n+        goto out_free_udc_driver_name;\n+\n+    udc_device_name = kmalloc(UDC_NAME_LENGTH_MAX, GFP_KERNEL);\n+    if (!udc_device_name) {\n+        ret = -ENOMEM;\n+        goto out_free_udc_driver_name;\n+    }\n+    ret = strscpy(udc_device_name, &arg.device_name[0], UDC_NAME_LENGTH_MAX);\n+    if (ret < 0)\n+        goto out_free_udc_device_name;\n+\n+    spin_lock_irqsave(&dev->lock, flags);\n+    if (dev->state != STATE_DEV_OPENED) {\n+        dev_dbg(dev->dev, \"fail, device is not opened\\n\");\n+        ret = -EINVAL;\n+        goto out_unlock;\n+    }\n+    dev->udc_name = udc_driver_name;\n+\n+    dev->driver.function = DRIVER_DESC;\n+    dev->driver.max_speed = arg.speed;\n+    dev->driver.setup = gadget_setup;\n+    dev->driver.disconnect = gadget_disconnect;\n+    dev->driver.bind = gadget_bind;\n+    dev->driver.unbind = gadget_unbind;\n+    dev->driver.suspend = gadget_suspend;\n+    dev->driver.resume = gadget_resume;\n+    dev->driver.reset = gadget_reset;\n+    dev->driver.driver.name = driver_driver_name;\n+    dev->driver.udc_name = udc_device_name;\n+    dev->driver.match_existing_only = 1;\n+    dev->driver_id_number = driver_id_number;\n+\n+    dev->state = STATE_DEV_INITIALIZED;\n+    spin_unlock_irqrestore(&dev->lock, flags);\n+    return ret;\n \n out_unlock:\n-\tspin_unlock_irqrestore(&dev->lock, flags);\n+    spin_unlock_irqrestore(&dev->lock, flags);\n out_free_udc_device_name:\n-\tkfree(udc_device_name);\n+    kfree(udc_device_name);\n out_free_udc_driver_name:\n-\tkfree(udc_driver_name);\n+    kfree(udc_driver_name);\n out_free_driver_driver_name:\n-\tkfree(driver_driver_name);\n+    kfree(driver_driver_name);\n out_free_driver_id_number:\n-\tida_free(&driver_id_numbers, driver_id_number);\n-\treturn ret;\n+    ida_free(&driver_id_numbers, driver_id_number);\n+    return ret;\n }\n \n static int raw_ioctl_run(struct raw_dev *dev, unsigned long value)\ndiff --git a/drivers/usb/gadget/udc/dummy_hcd.c b/drivers/usb/gadget/udc/dummy_hcd.c\nindex 0953e1b5c030..b3b194c53f47 100644\n--- a/drivers/usb/gadget/udc/dummy_hcd.c\n+++ b/drivers/usb/gadget/udc/dummy_hcd.c\n@@ -654,19 +654,18 @@ static int dummy_disable(struct usb_ep *_ep)\n \treturn 0;\n }\n \n-static struct usb_request *dummy_alloc_request(struct usb_ep *_ep,\n-\t\tgfp_t mem_flags)\n+static struct usb_request *dummy_alloc_request(struct usb_ep *_ep, gfp_t mem_flags)\n {\n-\tstruct dummy_request\t*req;\n+    struct dummy_request *req;\n \n-\tif (!_ep)\n-\t\treturn NULL;\n+    if (!_ep)\n+        return NULL;\n \n-\treq = kzalloc(sizeof(*req), mem_flags);\n-\tif (!req)\n-\t\treturn NULL;\n-\tINIT_LIST_HEAD(&req->queue);\n-\treturn &req->req;\n+    req = kzalloc(sizeof(*req), mem_flags);\n+    if (!req)\n+        return NULL;\n+    INIT_LIST_HEAD(&req->queue);\n+    return &req->req;\n }\n \n static void dummy_free_request(struct usb_ep *_ep, struct usb_request *_req)\n"
        ],
        "error": []
    },
    "e0640a911365faa499433155c3d5d5b674b36a83": {
        "non_crash": [
            "diff --git a/net/netfilter/nfnetlink_cttimeout.c b/net/netfilter/nfnetlink_cttimeout.c\nindex a518eb162344..4424e371e122 100644\n--- a/net/netfilter/nfnetlink_cttimeout.c\n+++ b/net/netfilter/nfnetlink_cttimeout.c\n@@ -445,7 +445,7 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \tl4proto = nf_ct_l4proto_find_get(l4num);\n \n \terr = -EOPNOTSUPP;\n-\tif (l4proto->l4proto != l4num)\n+\tif (!l4proto || l4proto->l4proto != l4num)\n \t\tgoto err;\n \n \tswitch (l4proto->l4proto) {\n@@ -475,8 +475,8 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \t\ttimeouts = &nf_generic_pernet(net)->timeout;\n \t\tbreak;\n \tdefault:\n-\t\tWARN_ON_ONCE(1);\n-\t\tbreak;\n+\t\terr = -EOPNOTSUPP;\n+\t\tgoto err;\n \t}\n \n \tif (!timeouts)\n@@ -505,7 +505,8 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \t/* this avoids a loop in nfnetlink. */\n \treturn ret == -EAGAIN ? -ENOBUFS : ret;\n err:\n-\tnf_ct_l4proto_put(l4proto);\n+\tif (l4proto)\n+\t\tnf_ct_l4proto_put(l4proto);\n \treturn err;\n }\n \n",
            "diff --git a/net/netfilter/nfnetlink_cttimeout.c b/net/netfilter/nfnetlink_cttimeout.c\nindex a518eb162344..2e071c7f0bab 100644\n--- a/net/netfilter/nfnetlink_cttimeout.c\n+++ b/net/netfilter/nfnetlink_cttimeout.c\n@@ -475,8 +475,8 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \t\ttimeouts = &nf_generic_pernet(net)->timeout;\n \t\tbreak;\n \tdefault:\n-\t\tWARN_ON_ONCE(1);\n-\t\tbreak;\n+\t\terr = -EOPNOTSUPP; // Return error instead of warning\n+\t\tgoto err;\n \t}\n \n \tif (!timeouts)\n",
            "diff --git a/net/netfilter/nfnetlink_cttimeout.c b/net/netfilter/nfnetlink_cttimeout.c\nindex a518eb162344..a35708a07d23 100644\n--- a/net/netfilter/nfnetlink_cttimeout.c\n+++ b/net/netfilter/nfnetlink_cttimeout.c\n@@ -445,7 +445,7 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \tl4proto = nf_ct_l4proto_find_get(l4num);\n \n \terr = -EOPNOTSUPP;\n-\tif (l4proto->l4proto != l4num)\n+\tif (l4proto == &nf_conntrack_l4proto_generic)\n \t\tgoto err;\n \n \tswitch (l4proto->l4proto) {\n@@ -475,8 +475,8 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \t\ttimeouts = &nf_generic_pernet(net)->timeout;\n \t\tbreak;\n \tdefault:\n-\t\tWARN_ON_ONCE(1);\n-\t\tbreak;\n+\t\terr = -EOPNOTSUPP;\n+\t\tgoto err;\n \t}\n \n \tif (!timeouts)\n",
            "diff --git a/net/netfilter/nfnetlink_cttimeout.c b/net/netfilter/nfnetlink_cttimeout.c\nindex a518eb162344..2e071c7f0bab 100644\n--- a/net/netfilter/nfnetlink_cttimeout.c\n+++ b/net/netfilter/nfnetlink_cttimeout.c\n@@ -475,8 +475,8 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \t\ttimeouts = &nf_generic_pernet(net)->timeout;\n \t\tbreak;\n \tdefault:\n-\t\tWARN_ON_ONCE(1);\n-\t\tbreak;\n+\t\terr = -EOPNOTSUPP; // Return error instead of warning\n+\t\tgoto err;\n \t}\n \n \tif (!timeouts)\n"
        ],
        "special_crash": [],
        "crash": [],
        "error": [
            {
                "patch": "diff --git a/net/netfilter/nfnetlink_cttimeout.c b/net/netfilter/nfnetlink_cttimeout.c\nindex a518eb162344..67c13f937569 100644\n--- a/net/netfilter/nfnetlink_cttimeout.c\n+++ b/net/netfilter/nfnetlink_cttimeout.c\n@@ -445,8 +445,10 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \tl4proto = nf_ct_l4proto_find_get(l4num);\n \n \terr = -EOPNOTSUPP;\n-\tif (l4proto->l4proto != l4num)\n+\tif (l4proto->l4proto != l4num) {\n+\t\tnl_set_extack_msg(extack, \"Unsupported protocol number\");\n \t\tgoto err;\n+\t}\n \n \tswitch (l4proto->l4proto) {\n \tcase IPPROTO_ICMP:\n@@ -475,8 +477,9 @@ static int cttimeout_default_get(struct net *net, struct sock *ctnl,\n \t\ttimeouts = &nf_generic_pernet(net)->timeout;\n \t\tbreak;\n \tdefault:\n-\t\tWARN_ON_ONCE(1);\n-\t\tbreak;\n+\t\tnl_set_extack_msg(extack, \"Unsupported protocol number\");\n+\t\terr = -EOPNOTSUPP;\n+\t\tgoto err;\n \t}\n \n \tif (!timeouts)\n",
                "error_message": "Failed to build"
            }
        ]
    }
}
