{
    "version": 1,
    "title": "WARNING in erofs_iget",
    "display-title": "WARNING in erofs_iget",
    "id": "82136e2452d5e1ea212f5bf76fcd8db36512f981",
    "status": "fixed",
    "fix-commits": [
        {
            "title": "erofs: fix order >= MAX_ORDER warning due to crafted negative i_size",
            "link": "https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=1dd73601a1cba37a0ed5f89a8662c90191df5873",
            "hash": "1dd73601a1cba37a0ed5f89a8662c90191df5873",
            "repo": "git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git",
            "branch": "master"
        }
    ],
    "discussions": [
        "https://lore.kernel.org/all/000000000000ac8efa05e7feaa1f@google.com/T/",
        "https://lore.kernel.org/all/20220909023948.28925-1-hsiangkao@linux.alibaba.com/T/",
        "https://lore.kernel.org/all/20221019083249.951566199@linuxfoundation.org/T/",
        "https://lore.kernel.org/all/20221022072415.034382448@linuxfoundation.org/T/"
    ],
    "crashes": [
        {
            "title": "WARNING in erofs_iget",
            "syz-reproducer": "/text?tag=ReproSyz&x=16fea393080000",
            "c-reproducer": "/text?tag=ReproC&x=1501b0c5080000",
            "kernel-config": "/text?tag=KernelConfig&x=892a57667b7af6cf",
            "kernel-source-git": "https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/log/?id=42cf58c272ee1dae902e8cc1166c246589abd1d8",
            "kernel-source-commit": "42cf58c272ee1dae902e8cc1166c246589abd1d8",
            "syzkaller-git": "https://github.com/google/syzkaller/commits/28811d0ac5274e8b3730fcf2ad0634d723fcd878",
            "syzkaller-commit": "28811d0ac5274e8b3730fcf2ad0634d723fcd878",
            "compiler-description": "gcc (Debian 10.2.1-6) 10.2.1 20210110, GNU ld (GNU Binutils for Debian) 2.35.2",
            "architecture": "amd64",
            "crash-report-link": "/text?tag=CrashReport&x=1662e2f5080000"
        }
    ],
    "patch_modified_functions": [
        [
            "erofs_fill_symlink",
            "fs/erofs/inode.c"
        ]
    ],
    "patch_commit_date": "2022-09-09T02:39:48+00:00",
    "cause_commit_date": null,
    "subsystems": [
        "erofs",
        "mm"
    ],
    "parent_of_fix_commit": "80e78fcce86de0288793a0ef0f6acf37656ee4cf",
    "patch": "diff --git a/fs/erofs/inode.c b/fs/erofs/inode.c\nindex 95a403720e8c..16cf9a283557 100644\n--- a/fs/erofs/inode.c\n+++ b/fs/erofs/inode.c\n@@ -214,7 +214,7 @@ static int erofs_fill_symlink(struct inode *inode, void *kaddr,\n \n \t/* if it cannot be handled with fast symlink scheme */\n \tif (vi->datalayout != EROFS_INODE_FLAT_INLINE ||\n-\t    inode->i_size >= EROFS_BLKSIZ) {\n+\t    inode->i_size >= EROFS_BLKSIZ || inode->i_size < 0) {\n \t\tinode->i_op = &erofs_symlink_iops;\n \t\treturn 0;\n \t}\n",
    "patch_modified_files": [
        "fs/erofs/inode.c"
    ]
}