pvpanic: create pvpanic by default for machine 1.5
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com> Signed-off-by: Hu Tao <hutao@cn.fujitsu.com> Reviewed-by: Markus Armbruster <armbru@redhat.com> Message-id: f840042f0e1205041f8feaf0d39ca639884f3a00.1366945969.git.hutao@cn.fujitsu.com Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
parent
b42ffe60d8
commit
3ab135f346
@ -55,6 +55,8 @@ static const int ide_iobase[MAX_IDE_BUS] = { 0x1f0, 0x170 };
|
|||||||
static const int ide_iobase2[MAX_IDE_BUS] = { 0x3f6, 0x376 };
|
static const int ide_iobase2[MAX_IDE_BUS] = { 0x3f6, 0x376 };
|
||||||
static const int ide_irq[MAX_IDE_BUS] = { 14, 15 };
|
static const int ide_irq[MAX_IDE_BUS] = { 14, 15 };
|
||||||
|
|
||||||
|
static bool has_pvpanic = true;
|
||||||
|
|
||||||
/* PC hardware initialisation */
|
/* PC hardware initialisation */
|
||||||
static void pc_init1(MemoryRegion *system_memory,
|
static void pc_init1(MemoryRegion *system_memory,
|
||||||
MemoryRegion *system_io,
|
MemoryRegion *system_io,
|
||||||
@ -216,6 +218,10 @@ static void pc_init1(MemoryRegion *system_memory,
|
|||||||
if (pci_enabled) {
|
if (pci_enabled) {
|
||||||
pc_pci_device_init(pci_bus);
|
pc_pci_device_init(pci_bus);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (has_pvpanic) {
|
||||||
|
pvpanic_init(isa_bus);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void pc_init_pci(QEMUMachineInitArgs *args)
|
static void pc_init_pci(QEMUMachineInitArgs *args)
|
||||||
@ -236,6 +242,7 @@ static void pc_init_pci(QEMUMachineInitArgs *args)
|
|||||||
static void pc_init_pci_1_4(QEMUMachineInitArgs *args)
|
static void pc_init_pci_1_4(QEMUMachineInitArgs *args)
|
||||||
{
|
{
|
||||||
pc_sysfw_flash_vs_rom_bug_compatible = true;
|
pc_sysfw_flash_vs_rom_bug_compatible = true;
|
||||||
|
has_pvpanic = false;
|
||||||
pc_init_pci(args);
|
pc_init_pci(args);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -243,6 +250,7 @@ static void pc_init_pci_1_3(QEMUMachineInitArgs *args)
|
|||||||
{
|
{
|
||||||
enable_compat_apic_id_mode();
|
enable_compat_apic_id_mode();
|
||||||
pc_sysfw_flash_vs_rom_bug_compatible = true;
|
pc_sysfw_flash_vs_rom_bug_compatible = true;
|
||||||
|
has_pvpanic = false;
|
||||||
pc_init_pci(args);
|
pc_init_pci(args);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -252,6 +260,7 @@ static void pc_init_pci_1_2(QEMUMachineInitArgs *args)
|
|||||||
disable_kvm_pv_eoi();
|
disable_kvm_pv_eoi();
|
||||||
enable_compat_apic_id_mode();
|
enable_compat_apic_id_mode();
|
||||||
pc_sysfw_flash_vs_rom_bug_compatible = true;
|
pc_sysfw_flash_vs_rom_bug_compatible = true;
|
||||||
|
has_pvpanic = false;
|
||||||
pc_init_pci(args);
|
pc_init_pci(args);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -260,6 +269,7 @@ static void pc_init_pci_1_0(QEMUMachineInitArgs *args)
|
|||||||
{
|
{
|
||||||
disable_kvm_pv_eoi();
|
disable_kvm_pv_eoi();
|
||||||
enable_compat_apic_id_mode();
|
enable_compat_apic_id_mode();
|
||||||
|
has_pvpanic = false;
|
||||||
pc_init_pci(args);
|
pc_init_pci(args);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -272,6 +282,7 @@ static void pc_init_pci_no_kvmclock(QEMUMachineInitArgs *args)
|
|||||||
const char *kernel_cmdline = args->kernel_cmdline;
|
const char *kernel_cmdline = args->kernel_cmdline;
|
||||||
const char *initrd_filename = args->initrd_filename;
|
const char *initrd_filename = args->initrd_filename;
|
||||||
const char *boot_device = args->boot_device;
|
const char *boot_device = args->boot_device;
|
||||||
|
has_pvpanic = false;
|
||||||
disable_kvm_pv_eoi();
|
disable_kvm_pv_eoi();
|
||||||
enable_compat_apic_id_mode();
|
enable_compat_apic_id_mode();
|
||||||
pc_init1(get_system_memory(),
|
pc_init1(get_system_memory(),
|
||||||
@ -289,6 +300,7 @@ static void pc_init_isa(QEMUMachineInitArgs *args)
|
|||||||
const char *kernel_cmdline = args->kernel_cmdline;
|
const char *kernel_cmdline = args->kernel_cmdline;
|
||||||
const char *initrd_filename = args->initrd_filename;
|
const char *initrd_filename = args->initrd_filename;
|
||||||
const char *boot_device = args->boot_device;
|
const char *boot_device = args->boot_device;
|
||||||
|
has_pvpanic = false;
|
||||||
if (cpu_model == NULL)
|
if (cpu_model == NULL)
|
||||||
cpu_model = "486";
|
cpu_model = "486";
|
||||||
disable_kvm_pv_eoi();
|
disable_kvm_pv_eoi();
|
||||||
|
@ -45,6 +45,8 @@
|
|||||||
/* ICH9 AHCI has 6 ports */
|
/* ICH9 AHCI has 6 ports */
|
||||||
#define MAX_SATA_PORTS 6
|
#define MAX_SATA_PORTS 6
|
||||||
|
|
||||||
|
static bool has_pvpanic = true;
|
||||||
|
|
||||||
/* PC hardware initialisation */
|
/* PC hardware initialisation */
|
||||||
static void pc_q35_init(QEMUMachineInitArgs *args)
|
static void pc_q35_init(QEMUMachineInitArgs *args)
|
||||||
{
|
{
|
||||||
@ -193,11 +195,16 @@ static void pc_q35_init(QEMUMachineInitArgs *args)
|
|||||||
if (pci_enabled) {
|
if (pci_enabled) {
|
||||||
pc_pci_device_init(host_bus);
|
pc_pci_device_init(host_bus);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (has_pvpanic) {
|
||||||
|
pvpanic_init(isa_bus);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void pc_q35_init_1_4(QEMUMachineInitArgs *args)
|
static void pc_q35_init_1_4(QEMUMachineInitArgs *args)
|
||||||
{
|
{
|
||||||
pc_sysfw_flash_vs_rom_bug_compatible = true;
|
pc_sysfw_flash_vs_rom_bug_compatible = true;
|
||||||
|
has_pvpanic = false;
|
||||||
pc_q35_init(args);
|
pc_q35_init(args);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
#include "qemu/log.h"
|
#include "qemu/log.h"
|
||||||
|
|
||||||
#include "hw/nvram/fw_cfg.h"
|
#include "hw/nvram/fw_cfg.h"
|
||||||
|
#include "hw/i386/pc.h"
|
||||||
|
|
||||||
/* The bit of supported pv event */
|
/* The bit of supported pv event */
|
||||||
#define PVPANIC_F_PANICKED 0
|
#define PVPANIC_F_PANICKED 0
|
||||||
@ -107,6 +108,12 @@ static int pvpanic_isa_initfn(ISADevice *dev)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int pvpanic_init(ISABus *bus)
|
||||||
|
{
|
||||||
|
isa_create_simple(bus, TYPE_ISA_PVPANIC_DEVICE);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static Property pvpanic_isa_properties[] = {
|
static Property pvpanic_isa_properties[] = {
|
||||||
DEFINE_PROP_UINT16("ioport", PVPanicState, ioport, 0x505),
|
DEFINE_PROP_UINT16("ioport", PVPanicState, ioport, 0x505),
|
||||||
DEFINE_PROP_END_OF_LIST(),
|
DEFINE_PROP_END_OF_LIST(),
|
||||||
|
@ -171,6 +171,9 @@ static inline bool isa_ne2000_init(ISABus *bus, int base, int irq, NICInfo *nd)
|
|||||||
extern bool pc_sysfw_flash_vs_rom_bug_compatible;
|
extern bool pc_sysfw_flash_vs_rom_bug_compatible;
|
||||||
void pc_system_firmware_init(MemoryRegion *rom_memory);
|
void pc_system_firmware_init(MemoryRegion *rom_memory);
|
||||||
|
|
||||||
|
/* pvpanic.c */
|
||||||
|
int pvpanic_init(ISABus *bus);
|
||||||
|
|
||||||
/* e820 types */
|
/* e820 types */
|
||||||
#define E820_RAM 1
|
#define E820_RAM 1
|
||||||
#define E820_RESERVED 2
|
#define E820_RESERVED 2
|
||||||
|
Loading…
Reference in New Issue
Block a user