{
    "version": 1,
    "title": "INFO: task hung in hwrng_register",
    "display-title": "INFO: task hung in hwrng_register",
    "id": "17ba20e86ace8566cff1a3ace9042a779bd8bb7c",
    "status": "fixed",
    "fix-commits": [
        {
            "title": "hwrng: virtio - don't wait on cleanup",
            "link": "https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=2bb31abdbe55742c89f4dc0cc26fcbc8467364f6",
            "hash": "2bb31abdbe55742c89f4dc0cc26fcbc8467364f6",
            "repo": "git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git",
            "branch": "master"
        }
    ],
    "cause-commit": {
        "title": "usb: gadget: add raw-gadget interface",
        "link": "https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=f2c2e717642c66f7fe7e5dd69b2e8ff5849f4d10",
        "hash": "f2c2e717642c66f7fe7e5dd69b2e8ff5849f4d10",
        "repo": "git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git",
        "branch": "master"
    },
    "discussions": [
        "https://lore.kernel.org/all/0000000000003991b905c9cb527a@google.com/T/"
    ],
    "crashes": [
        {
            "title": "INFO: task hung in hwrng_register",
            "syz-reproducer": "/text?tag=ReproSyz&x=16cfe231300000",
            "kernel-config": "/text?tag=KernelConfig&x=171d57d5a48c8cad",
            "kernel-source-git": "https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/log/?id=f8e6dfc64f6135d1b6c5215c14cd30b9b60a0008",
            "kernel-source-commit": "f8e6dfc64f6135d1b6c5215c14cd30b9b60a0008",
            "syzkaller-git": "https://github.com/google/syzkaller/commits/3fd2ea69e05557e7e0fef9b68263b4150670671c",
            "syzkaller-commit": "3fd2ea69e05557e7e0fef9b68263b4150670671c",
            "compiler-description": "gcc (Debian 10.2.1-6) 10.2.1 20210110, GNU ld (GNU Binutils for Debian) 2.35.1",
            "architecture": "amd64",
            "crash-report-link": "/text?tag=CrashReport&x=17d3216e300000"
        }
    ],
    "subsystems": [
        "crypto",
        "usb"
    ],
    "parent_of_fix_commit": "bf3175bc50a3754dc427e2f5046e17a9fafc8be7",
    "patch": "diff --git a/drivers/char/hw_random/virtio-rng.c b/drivers/char/hw_random/virtio-rng.c\nindex 208c547dcac1..173aeea835bb 100644\n--- a/drivers/char/hw_random/virtio-rng.c\n+++ b/drivers/char/hw_random/virtio-rng.c\n@@ -82,6 +82,11 @@ static int virtio_read(struct hwrng *rng, void *buf, size_t size, bool wait)\n \t\tret = wait_for_completion_killable(&vi->have_data);\n \t\tif (ret < 0)\n \t\t\treturn ret;\n+\t\t/* if vi->data_avail is 0, we have been interrupted\n+\t\t * by a cleanup, but buffer stays in the queue\n+\t\t */\n+\t\tif (vi->data_avail == 0)\n+\t\t\treturn read;\n \n \t\tchunk = min_t(unsigned int, size, vi->data_avail);\n \t\tmemcpy(buf + read, vi->data, chunk);\n@@ -105,7 +110,7 @@ static void virtio_cleanup(struct hwrng *rng)\n \tstruct virtrng_info *vi = (struct virtrng_info *)rng->priv;\n \n \tif (vi->busy)\n-\t\twait_for_completion(&vi->have_data);\n+\t\tcomplete(&vi->have_data);\n }\n \n static int probe_common(struct virtio_device *vdev)\n",
    "patch_modified_files": [
        "drivers/char/hw_random/virtio-rng.c"
    ]
}