]> git.ipfire.org Git - thirdparty/u-boot.git/commitdiff
virtio: fix boot device hunting in qemu with virtio
authorLudwig Nussel <ludwig.nussel@siemens.com>
Mon, 4 May 2026 07:10:23 +0000 (09:10 +0200)
committerTom Rini <trini@konsulko.com>
Fri, 8 May 2026 21:49:27 +0000 (15:49 -0600)
Commit 70101c3217ae ("virtio: mmio: Return error codes on probe
failures") returns -ENODEV where it would return 0 before. That path is
apparently hit in qemu and breaks boot device discovery
(virtio_bootdev_hunt() expects only ENOENT). So return -ENOENT in
that path instead.
The remaining two error returns in the function are untouched as I
don't know where they play a role.

Signed-off-by: Ludwig Nussel <ludwig.nussel@siemens.com>
Reviewed-by: Simon Glass <sjg@chromium.org>
Acked-by: Kuan-Wei Chiu <visitorckw@gmail.com>
drivers/virtio/virtio_mmio.c

index 62afe609ec0a751c84fee3f14929f3aad68005fc..d90d8309f991af856434e8927b25af737f01086b 100644 (file)
@@ -372,7 +372,7 @@ static int virtio_mmio_probe(struct udevice *udev)
                 * virtio-mmio device with an ID 0 is a (dummy) placeholder
                 * with no function. End probing now with no error reported.
                 */
-               return -ENODEV;
+               return -ENOENT;
        }
        uc_priv->vendor = readl(priv->base + VIRTIO_MMIO_VENDOR_ID);