2019-10-08 12:56:49 +03:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2019 Red Hat, Inc.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms and conditions of the GNU General Public License,
|
|
|
|
* version 2 or later, as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
|
|
* more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along with
|
|
|
|
* this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef HW_I386_X86_H
|
|
|
|
#define HW_I386_X86_H
|
|
|
|
|
2019-10-22 10:39:50 +03:00
|
|
|
#include "exec/hwaddr.h"
|
2024-05-08 20:55:04 +03:00
|
|
|
#include "exec/memory.h"
|
2019-10-22 10:39:50 +03:00
|
|
|
|
2019-10-08 12:56:49 +03:00
|
|
|
#include "hw/boards.h"
|
2023-02-13 20:30:31 +03:00
|
|
|
#include "hw/intc/ioapic.h"
|
2019-12-12 16:14:40 +03:00
|
|
|
#include "hw/isa/isa.h"
|
2020-09-03 23:43:22 +03:00
|
|
|
#include "qom/object.h"
|
2019-10-22 10:39:50 +03:00
|
|
|
|
2020-09-03 23:43:22 +03:00
|
|
|
struct X86MachineClass {
|
2019-10-22 10:39:50 +03:00
|
|
|
/*< private >*/
|
|
|
|
MachineClass parent;
|
|
|
|
|
|
|
|
/*< public >*/
|
|
|
|
|
2019-11-18 14:13:25 +03:00
|
|
|
/* TSC rate migration: */
|
|
|
|
bool save_tsc_khz;
|
2021-10-20 15:48:10 +03:00
|
|
|
/* use DMA capable linuxboot option rom */
|
|
|
|
bool fwcfg_dma_enabled;
|
2024-02-09 01:03:43 +03:00
|
|
|
/* CPU and apic information: */
|
|
|
|
bool apic_xrupt_override;
|
2020-09-03 23:43:22 +03:00
|
|
|
};
|
2019-10-22 10:39:50 +03:00
|
|
|
|
2020-09-03 23:43:22 +03:00
|
|
|
struct X86MachineState {
|
2019-10-22 10:39:50 +03:00
|
|
|
/*< private >*/
|
|
|
|
MachineState parent;
|
|
|
|
|
|
|
|
/*< public >*/
|
|
|
|
|
|
|
|
/* Pointers to devices and objects: */
|
|
|
|
ISADevice *rtc;
|
|
|
|
FWCfgState *fw_cfg;
|
|
|
|
qemu_irq *gsi;
|
2020-12-03 13:54:14 +03:00
|
|
|
DeviceState *ioapic2;
|
2019-10-22 10:39:50 +03:00
|
|
|
GMappedFile *initrd_mapped_file;
|
2020-09-15 15:09:02 +03:00
|
|
|
HotplugHandler *acpi_dev;
|
2019-10-22 10:39:50 +03:00
|
|
|
|
2024-05-08 20:55:04 +03:00
|
|
|
/*
|
|
|
|
* Map the upper 128 KiB of the BIOS just underneath the 1 MiB address
|
|
|
|
* boundary.
|
|
|
|
*/
|
|
|
|
MemoryRegion isa_bios;
|
|
|
|
|
2019-10-22 10:39:50 +03:00
|
|
|
/* RAM information (sizes, addresses, configuration): */
|
|
|
|
ram_addr_t below_4g_mem_size, above_4g_mem_size;
|
|
|
|
|
2022-07-19 20:00:04 +03:00
|
|
|
/* Start address of the initial RAM above 4G */
|
|
|
|
uint64_t above_4g_mem_start;
|
|
|
|
|
2019-10-22 10:39:50 +03:00
|
|
|
/* CPU and apic information: */
|
2020-10-16 14:38:31 +03:00
|
|
|
unsigned pci_irq_mask;
|
2019-10-22 10:39:50 +03:00
|
|
|
unsigned apic_id_limit;
|
|
|
|
uint16_t boot_cpus;
|
vl: Add sgx compound properties to expose SGX EPC sections to guest
Because SGX EPC is enumerated through CPUID, EPC "devices" need to be
realized prior to realizing the vCPUs themselves, i.e. long before
generic devices are parsed and realized. From a virtualization
perspective, the CPUID aspect also means that EPC sections cannot be
hotplugged without paravirtualizing the guest kernel (hardware does
not support hotplugging as EPC sections must be locked down during
pre-boot to provide EPC's security properties).
So even though EPC sections could be realized through the generic
-devices command, they need to be created much earlier for them to
actually be usable by the guest. Place all EPC sections in a
contiguous block, somewhat arbitrarily starting after RAM above 4g.
Ensuring EPC is in a contiguous region simplifies calculations, e.g.
device memory base, PCI hole, etc..., allows dynamic calculation of the
total EPC size, e.g. exposing EPC to guests does not require -maxmem,
and last but not least allows all of EPC to be enumerated in a single
ACPI entry, which is expected by some kernels, e.g. Windows 7 and 8.
The new compound properties command for sgx like below:
......
-object memory-backend-epc,id=mem1,size=28M,prealloc=on \
-object memory-backend-epc,id=mem2,size=10M \
-M sgx-epc.0.memdev=mem1,sgx-epc.1.memdev=mem2
Signed-off-by: Sean Christopherson <sean.j.christopherson@intel.com>
Signed-off-by: Yang Zhong <yang.zhong@intel.com>
Message-Id: <20210719112136.57018-6-yang.zhong@intel.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2021-09-28 11:40:58 +03:00
|
|
|
SgxEPCList *sgx_epc_list;
|
2019-10-22 10:39:50 +03:00
|
|
|
|
2019-12-12 19:28:01 +03:00
|
|
|
OnOffAuto smm;
|
2020-03-20 13:01:36 +03:00
|
|
|
OnOffAuto acpi;
|
2022-03-10 15:28:10 +03:00
|
|
|
OnOffAuto pit;
|
2022-03-10 15:28:11 +03:00
|
|
|
OnOffAuto pic;
|
2019-12-12 19:28:01 +03:00
|
|
|
|
2021-02-21 03:17:36 +03:00
|
|
|
char *oem_id;
|
|
|
|
char *oem_table_id;
|
2019-10-22 10:39:50 +03:00
|
|
|
/*
|
|
|
|
* Address space used by IOAPIC device. All IOAPIC interrupts
|
|
|
|
* will be translated to MSI messages in the address space.
|
|
|
|
*/
|
|
|
|
AddressSpace *ioapic_as;
|
2021-05-21 07:38:20 +03:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Ratelimit enforced on detected bus locks in guest.
|
|
|
|
* The default value of the bus_lock_ratelimit is 0 per second,
|
|
|
|
* which means no limitation on the guest's bus locks.
|
|
|
|
*/
|
|
|
|
uint64_t bus_lock_ratelimit;
|
2020-09-03 23:43:22 +03:00
|
|
|
};
|
2019-10-22 10:39:50 +03:00
|
|
|
|
2019-12-12 19:28:01 +03:00
|
|
|
#define X86_MACHINE_SMM "smm"
|
2020-03-20 13:01:36 +03:00
|
|
|
#define X86_MACHINE_ACPI "acpi"
|
2022-03-10 15:28:10 +03:00
|
|
|
#define X86_MACHINE_PIT "pit"
|
2022-03-10 15:28:11 +03:00
|
|
|
#define X86_MACHINE_PIC "pic"
|
2021-04-02 11:21:28 +03:00
|
|
|
#define X86_MACHINE_OEM_ID "x-oem-id"
|
|
|
|
#define X86_MACHINE_OEM_TABLE_ID "x-oem-table-id"
|
2021-05-21 07:38:20 +03:00
|
|
|
#define X86_MACHINE_BUS_LOCK_RATELIMIT "bus-lock-ratelimit"
|
2019-10-22 10:39:50 +03:00
|
|
|
|
|
|
|
#define TYPE_X86_MACHINE MACHINE_TYPE_NAME("x86")
|
2020-09-16 21:25:18 +03:00
|
|
|
OBJECT_DECLARE_TYPE(X86MachineState, X86MachineClass, X86_MACHINE)
|
2019-10-08 12:56:49 +03:00
|
|
|
|
2019-09-30 18:26:29 +03:00
|
|
|
uint32_t x86_cpu_apic_id_from_index(X86MachineState *pcms,
|
2019-10-08 12:56:49 +03:00
|
|
|
unsigned int cpu_index);
|
2019-09-30 18:26:29 +03:00
|
|
|
|
|
|
|
void x86_cpu_new(X86MachineState *pcms, int64_t apic_id, Error **errp);
|
|
|
|
void x86_cpus_init(X86MachineState *pcms, int default_cpu_version);
|
2019-10-08 12:56:49 +03:00
|
|
|
CpuInstanceProperties x86_cpu_index_to_props(MachineState *ms,
|
|
|
|
unsigned cpu_index);
|
|
|
|
int64_t x86_get_default_cpu_node_id(const MachineState *ms, int idx);
|
|
|
|
const CPUArchIdList *x86_possible_cpu_arch_ids(MachineState *ms);
|
2020-09-15 15:09:03 +03:00
|
|
|
CPUArchId *x86_find_cpu_slot(MachineState *ms, uint32_t id, int *idx);
|
|
|
|
void x86_rtc_set_cpus_count(ISADevice *rtc, uint16_t cpus_count);
|
|
|
|
void x86_cpu_pre_plug(HotplugHandler *hotplug_dev,
|
|
|
|
DeviceState *dev, Error **errp);
|
|
|
|
void x86_cpu_plug(HotplugHandler *hotplug_dev,
|
|
|
|
DeviceState *dev, Error **errp);
|
|
|
|
void x86_cpu_unplug_request_cb(HotplugHandler *hotplug_dev,
|
|
|
|
DeviceState *dev, Error **errp);
|
|
|
|
void x86_cpu_unplug_cb(HotplugHandler *hotplug_dev,
|
|
|
|
DeviceState *dev, Error **errp);
|
2019-10-08 12:56:49 +03:00
|
|
|
|
2024-04-30 18:06:39 +03:00
|
|
|
void x86_bios_rom_init(X86MachineState *x86ms, const char *default_firmware,
|
2020-10-26 17:30:18 +03:00
|
|
|
MemoryRegion *rom_memory, bool isapc_ram_fw);
|
2019-10-08 12:56:49 +03:00
|
|
|
|
2019-09-30 18:26:29 +03:00
|
|
|
void x86_load_linux(X86MachineState *x86ms,
|
|
|
|
FWCfgState *fw_cfg,
|
|
|
|
int acpi_data_size,
|
2023-02-09 00:05:35 +03:00
|
|
|
bool pvh_enabled);
|
2019-10-08 12:56:49 +03:00
|
|
|
|
2020-09-15 15:09:01 +03:00
|
|
|
bool x86_machine_is_smm_enabled(const X86MachineState *x86ms);
|
|
|
|
bool x86_machine_is_acpi_enabled(const X86MachineState *x86ms);
|
2019-12-12 19:28:01 +03:00
|
|
|
|
2019-12-12 16:14:40 +03:00
|
|
|
/* Global System Interrupts */
|
|
|
|
|
2020-10-16 14:38:31 +03:00
|
|
|
#define ACPI_BUILD_PCI_IRQS ((1<<5) | (1<<9) | (1<<10) | (1<<11))
|
2019-12-12 16:14:40 +03:00
|
|
|
|
|
|
|
typedef struct GSIState {
|
|
|
|
qemu_irq i8259_irq[ISA_NUM_IRQS];
|
|
|
|
qemu_irq ioapic_irq[IOAPIC_NUM_PINS];
|
2020-12-03 13:54:14 +03:00
|
|
|
qemu_irq ioapic2_irq[IOAPIC_NUM_PINS];
|
2019-12-12 16:14:40 +03:00
|
|
|
} GSIState;
|
|
|
|
|
|
|
|
qemu_irq x86_allocate_cpu_irq(void);
|
|
|
|
void gsi_handler(void *opaque, int n, int level);
|
2024-02-09 01:03:41 +03:00
|
|
|
void ioapic_init_gsi(GSIState *gsi_state, Object *parent);
|
2020-12-03 13:54:14 +03:00
|
|
|
DeviceState *ioapic_init_secondary(GSIState *gsi_state);
|
2019-12-12 16:14:40 +03:00
|
|
|
|
2022-04-25 16:50:50 +03:00
|
|
|
/* pc_sysfw.c */
|
|
|
|
void x86_firmware_configure(void *ptr, int size);
|
|
|
|
|
2019-10-08 12:56:49 +03:00
|
|
|
#endif
|