diff options
author | David Woodhouse <dwmw@amazon.co.uk> | 2023-10-20 18:00:18 +0100 |
---|---|---|
committer | Michael Tokarev <mjt@tls.msk.ru> | 2023-11-09 16:39:13 +0300 |
commit | 287303495cbf7b554d193da7d76b226f2de86b59 (patch) | |
tree | 27069d99692177aeb5e3e7de1062be449b69aa14 | |
parent | 30a4cc2723c67f4c99633e9695835ddb6fcdbfe0 (diff) |
hw/xen: use correct default protocol for xen-block on x86
Even on x86_64 the default protocol is the x86-32 one if the guest doesn't
specifically ask for x86-64.
Cc: qemu-stable@nongnu.org
Fixes: b6af8926fb85 ("xen: add implementations of xen-block connect and disconnect functions...")
Signed-off-by: David Woodhouse <dwmw@amazon.co.uk>
Reviewed-by: Paul Durrant <paul@xen.org>
(cherry picked from commit a1c1082908dde4867b1ac55f546bea0c17d52318)
Signed-off-by: Michael Tokarev <mjt@tls.msk.ru>
-rw-r--r-- | hw/block/xen-block.c | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/hw/block/xen-block.c b/hw/block/xen-block.c index 3906b9058b..c754126711 100644 --- a/hw/block/xen-block.c +++ b/hw/block/xen-block.c @@ -115,9 +115,13 @@ static void xen_block_connect(XenDevice *xendev, Error **errp) return; } - if (xen_device_frontend_scanf(xendev, "protocol", "%ms", - &str) != 1) { - protocol = BLKIF_PROTOCOL_NATIVE; + if (xen_device_frontend_scanf(xendev, "protocol", "%ms", &str) != 1) { + /* x86 defaults to the 32-bit protocol even for 64-bit guests. */ + if (object_dynamic_cast(OBJECT(qdev_get_machine()), "x86-machine")) { + protocol = BLKIF_PROTOCOL_X86_32; + } else { + protocol = BLKIF_PROTOCOL_NATIVE; + } } else { if (strcmp(str, XEN_IO_PROTO_ABI_X86_32) == 0) { protocol = BLKIF_PROTOCOL_X86_32; |