]> git.proxmox.com Git - mirror_qemu.git/commitdiff
powerpc: fix -machine usb=no for newworld and pseries machines
authorPaolo Bonzini <pbonzini@redhat.com>
Mon, 23 Mar 2015 17:05:28 +0000 (18:05 +0100)
committerAlexander Graf <agraf@suse.de>
Wed, 25 Mar 2015 21:49:47 +0000 (22:49 +0100)
Capture the explicit setting of "usb=no" into a separate bool, and
use it to skip the update of machine->usb in the board init function.

Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Signed-off-by: Alexander Graf <agraf@suse.de>
hw/core/machine.c
hw/ppc/mac_newworld.c
hw/ppc/spapr.c
include/hw/boards.h

index cb1185ada479892fc027ca6d868d589bd62e126d..25c45e6f9da12c0657e53399b34bb2b245b1474d 100644 (file)
@@ -223,6 +223,7 @@ static void machine_set_usb(Object *obj, bool value, Error **errp)
     MachineState *ms = MACHINE(obj);
 
     ms->usb = value;
+    ms->usb_disabled = !value;
 }
 
 static char *machine_get_firmware(Object *obj, Error **errp)
index 624b4ab50bbba4c6d9c035c353e01fa5c6a8aa3b..7cc5106c79dcfdf9af4043aa150408c510c99dd0 100644 (file)
@@ -371,7 +371,7 @@ static void ppc_core99_init(MachineState *machine)
         /* 970 gets a U3 bus */
         pci_bus = pci_pmac_u3_init(pic, get_system_memory(), get_system_io());
         machine_arch = ARCH_MAC99_U3;
-        machine->usb |= defaults_enabled();
+        machine->usb |= defaults_enabled() && !machine->usb_disabled;
     } else {
         pci_bus = pci_pmac_init(pic, get_system_memory(), get_system_io());
         machine_arch = ARCH_MAC99;
index ca0a060b9258e117348685657ecb9d02583eb05f..61ddc7994df5d52c8a61315e09020ef52fb3c662 100644 (file)
@@ -1580,7 +1580,7 @@ static void ppc_spapr_init(MachineState *machine)
     /* Graphics */
     if (spapr_vga_init(phb->bus)) {
         spapr->has_graphics = true;
-        machine->usb |= defaults_enabled();
+        machine->usb |= defaults_enabled() && !machine->usb_disabled;
     }
 
     if (machine->usb) {
index 78838d13d426bcdaa84d9add4e3e6f5b511af999..1f118811a28eedf8f071aeffb61341db429f516d 100644 (file)
@@ -146,6 +146,7 @@ struct MachineState {
     bool dump_guest_core;
     bool mem_merge;
     bool usb;
+    bool usb_disabled;
     char *firmware;
     bool iommu;
     bool suppress_vmdesc;