提交 021746c1 编写于 作者: W Wei Liu 提交者: Stefano Stabellini

PCMachineState: introduce acpi_build_enabled field

Introduce this field to control whether ACPI build is enabled by a
particular machine or accelerator.

It defaults to true if the machine itself supports ACPI build. Xen
accelerator will disable it because Xen is in charge of building ACPI
tables for the guest.
Signed-off-by: NWei Liu <wei.liu2@citrix.com>
Signed-off-by: NStefano Stabellini <sstabellini@kernel.org>
Reviewed-by: NStefano Stabellini <sstabellini@kernel.org>
Reviewed-by: NEduardo Habkost <ehabkost@redhat.com>
Tested-by: NSander Eikelenboom <linux@eikelenboom.it>
上级 b5863634
...@@ -2953,7 +2953,7 @@ void acpi_setup(void) ...@@ -2953,7 +2953,7 @@ void acpi_setup(void)
return; return;
} }
if (!pcmc->has_acpi_build) { if (!pcms->acpi_build_enabled) {
ACPI_BUILD_DPRINTF("ACPI build disabled. Bailing out.\n"); ACPI_BUILD_DPRINTF("ACPI build disabled. Bailing out.\n");
return; return;
} }
......
...@@ -2159,6 +2159,8 @@ static void pc_machine_initfn(Object *obj) ...@@ -2159,6 +2159,8 @@ static void pc_machine_initfn(Object *obj)
pcms->vmport = ON_OFF_AUTO_AUTO; pcms->vmport = ON_OFF_AUTO_AUTO;
/* nvdimm is disabled on default. */ /* nvdimm is disabled on default. */
pcms->acpi_nvdimm_state.is_enabled = false; pcms->acpi_nvdimm_state.is_enabled = false;
/* acpi build is enabled by default if machine supports it */
pcms->acpi_build_enabled = PC_MACHINE_GET_CLASS(pcms)->has_acpi_build;
} }
static void pc_machine_reset(void) static void pc_machine_reset(void)
......
...@@ -62,6 +62,8 @@ struct PCMachineState { ...@@ -62,6 +62,8 @@ struct PCMachineState {
AcpiNVDIMMState acpi_nvdimm_state; AcpiNVDIMMState acpi_nvdimm_state;
bool acpi_build_enabled;
/* RAM information (sizes, addresses, configuration): */ /* RAM information (sizes, addresses, configuration): */
ram_addr_t below_4g_mem_size, above_4g_mem_size; ram_addr_t below_4g_mem_size, above_4g_mem_size;
......
...@@ -9,6 +9,7 @@ ...@@ -9,6 +9,7 @@
*/ */
#include "qemu/osdep.h" #include "qemu/osdep.h"
#include "hw/i386/pc.h"
#include "hw/xen/xen_backend.h" #include "hw/xen/xen_backend.h"
#include "qmp-commands.h" #include "qmp-commands.h"
#include "sysemu/char.h" #include "sysemu/char.h"
...@@ -114,6 +115,11 @@ static void xen_change_state_handler(void *opaque, int running, ...@@ -114,6 +115,11 @@ static void xen_change_state_handler(void *opaque, int running,
static int xen_init(MachineState *ms) static int xen_init(MachineState *ms)
{ {
PCMachineState *pcms = PC_MACHINE(ms);
/* Disable ACPI build because Xen handles it */
pcms->acpi_build_enabled = false;
xen_xc = xc_interface_open(0, 0, 0); xen_xc = xc_interface_open(0, 0, 0);
if (xen_xc == NULL) { if (xen_xc == NULL) {
xen_pv_printf(NULL, 0, "can't open xen interface\n"); xen_pv_printf(NULL, 0, "can't open xen interface\n");
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册