The test code for virtio is fairly simplistic and does not actually create
a block device. Add a way to specify the device type in the device tree.
Add a block device so that we can do more testing.

Signed-off-by: Simon Glass <s...@chromium.org>
---

(no changes since v1)

 arch/sandbox/dts/test.dts       | 6 ++++++
 drivers/virtio/virtio_sandbox.c | 3 ++-
 2 files changed, 8 insertions(+), 1 deletion(-)

diff --git a/arch/sandbox/dts/test.dts b/arch/sandbox/dts/test.dts
index 2e580f980fc..9d96e479ca8 100644
--- a/arch/sandbox/dts/test.dts
+++ b/arch/sandbox/dts/test.dts
@@ -1527,12 +1527,18 @@
 
        sandbox_virtio1 {
                compatible = "sandbox,virtio1";
+               virtio-type = <4>;      /* rng */
        };
 
        sandbox_virtio2 {
                compatible = "sandbox,virtio2";
        };
 
+       sandbox-virtio-blk {
+               compatible = "sandbox,virtio1";
+               virtio-type = <2>;      /* block */
+       };
+
        sandbox_scmi {
                compatible = "sandbox,scmi-devices";
                clocks = <&clk_scmi 2>, <&clk_scmi 0>;
diff --git a/drivers/virtio/virtio_sandbox.c b/drivers/virtio/virtio_sandbox.c
index cf7761c75ee..b34f1d60455 100644
--- a/drivers/virtio/virtio_sandbox.c
+++ b/drivers/virtio/virtio_sandbox.c
@@ -161,7 +161,8 @@ static int virtio_sandbox_probe(struct udevice *udev)
 
        /* fake some information for testing */
        priv->device_features = BIT_ULL(VIRTIO_F_VERSION_1);
-       uc_priv->device = VIRTIO_ID_RNG;
+       uc_priv->device = dev_read_u32_default(udev, "virtio-type",
+                                              VIRTIO_ID_RNG);
        uc_priv->vendor = ('u' << 24) | ('b' << 16) | ('o' << 8) | 't';
 
        return 0;
-- 
2.39.0.246.g2a6d74b583-goog

Reply via email to