{
    "version": 1,
    "title": "general protection fault in __vb2_queue_free",
    "display-title": "general protection fault in __vb2_queue_free",
    "id": "e9f526f59d5b25decd3b91d4270b5da2aa23c8f6",
    "status": "fixed",
    "fix-commits": [
        {
            "title": "media: vb2: check memory model for VIDIOC_CREATE_BUFS",
            "link": "https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=62dcb4f41836bd3c44b5b651bb6df07ea4cb1551",
            "hash": "62dcb4f41836bd3c44b5b651bb6df07ea4cb1551",
            "repo": "git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git",
            "branch": "master"
        }
    ],
    "discussions": [
        "https://lore.kernel.org/all/00000000000003920305797785a0@google.com/T/",
        "https://lore.kernel.org/all/20190107104437.308206189@linuxfoundation.org/T/",
        "https://lore.kernel.org/all/20190107104452.953560660@linuxfoundation.org/T/",
        "https://lore.kernel.org/all/edb80bbd-7076-8fc1-cfbe-9e9f156793eb@xs4all.nl/T/"
    ],
    "crashes": [
        {
            "title": "",
            "syz-reproducer": "/text?tag=ReproSyz&x=158fdbcb400000",
            "c-reproducer": "/text?tag=ReproC&x=11d7d06d400000",
            "kernel-config": "/text?tag=KernelConfig&x=93932074d01b4a5",
            "kernel-source-git": "https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/log/?id=11743c56785c751c087eecdb98713eef796609e0",
            "kernel-source-commit": "11743c56785c751c087eecdb98713eef796609e0",
            "syzkaller-git": "https://github.com/google/syzkaller/commits/8dbb755a2ec29c46434f3fb35b7bef3aac0c6b3e",
            "syzkaller-commit": "8dbb755a2ec29c46434f3fb35b7bef3aac0c6b3e",
            "compiler-description": "gcc (GCC) 8.0.1 20180413 (experimental)",
            "architecture": "amd64",
            "crash-report-link": "/text?tag=CrashReport&x=119278d5400000"
        }
    ],
    "patch_modified_functions": [
        [
            "vb2_core_create_bufs",
            "drivers/media/common/videobuf2/videobuf2-core.c"
        ]
    ],
    "patch_commit_date": "2018-11-08T12:23:37+00:00",
    "cause_commit_date": null,
    "subsystems": [
        "media"
    ],
    "parent_of_fix_commit": "2912289a518077ddb8214e05336700148e97e235",
    "patch": "diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c\nindex 2fcab61b8ff5..03954c13024c 100644\n--- a/drivers/media/common/videobuf2/videobuf2-core.c\n+++ b/drivers/media/common/videobuf2/videobuf2-core.c\n@@ -812,6 +812,9 @@ int vb2_core_create_bufs(struct vb2_queue *q, enum vb2_memory memory,\n \t\tmemset(q->alloc_devs, 0, sizeof(q->alloc_devs));\n \t\tq->memory = memory;\n \t\tq->waiting_for_buffers = !q->is_output;\n+\t} else if (q->memory != memory) {\n+\t\tdprintk(1, \"memory model mismatch\\n\");\n+\t\treturn -EINVAL;\n \t}\n \n \tnum_buffers = min(*count, VB2_MAX_FRAME - q->num_buffers);\n",
    "patch_modified_files": [
        "drivers/media/common/videobuf2/videobuf2-core.c"
    ]
}