hyperv: vmbus: Remove the 2nd IRQ
authorJon Doron <arilou@gmail.com>
Wed, 17 Jun 2020 16:09:02 +0000 (19:09 +0300)
committerPaolo Bonzini <pbonzini@redhat.com>
Fri, 26 Jun 2020 13:39:40 +0000 (09:39 -0400)
It seems like Windows does not really require 2 IRQs to have a
functioning VMBus.

Signed-off-by: Jon Doron <arilou@gmail.com>
Message-Id: <20200617160904.681845-2-arilou@gmail.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
hw/hyperv/vmbus.c
hw/i386/acpi-build.c
include/hw/hyperv/vmbus-bridge.h

index f371240176dbf925706daac822de60753888b9db..a8bcb410263fa37ba49a422e401fe2d8577dbdde 100644 (file)
@@ -2741,8 +2741,7 @@ static const VMStateDescription vmstate_vmbus_bridge = {
 };
 
 static Property vmbus_bridge_props[] = {
-    DEFINE_PROP_UINT8("irq0", VMBusBridge, irq0, 7),
-    DEFINE_PROP_UINT8("irq1", VMBusBridge, irq1, 13),
+    DEFINE_PROP_UINT8("irq", VMBusBridge, irq, 7),
     DEFINE_PROP_END_OF_LIST()
 };
 
index 378515df66c564fb2cb2245c91692035a14aad42..b7bcbbbb2a358f72695bacb9ae38a0eb070ba32c 100644 (file)
@@ -967,9 +967,7 @@ static Aml *build_vmbus_device_aml(VMBusBridge *vmbus_bridge)
     aml_append(dev, aml_name_decl("_PS3", aml_int(0x0)));
 
     crs = aml_resource_template();
-    aml_append(crs, aml_irq_no_flags(vmbus_bridge->irq0));
-    /* FIXME: newer HyperV gets by with only one IRQ */
-    aml_append(crs, aml_irq_no_flags(vmbus_bridge->irq1));
+    aml_append(crs, aml_irq_no_flags(vmbus_bridge->irq));
     aml_append(dev, aml_name_decl("_CRS", crs));
 
     return dev;
index c0a06d832c61a64b0a0fe93d41f02c1913d86f97..33f93de64d8d42ffdb66ac13248c2c9ac48ce5e9 100644 (file)
@@ -19,8 +19,7 @@ typedef struct VMBus VMBus;
 typedef struct VMBusBridge {
     SysBusDevice parent_obj;
 
-    uint8_t irq0;
-    uint8_t irq1;
+    uint8_t irq;
 
     VMBus *bus;
 } VMBusBridge;