hw/i386/pc: Defer smbios_set_defaults() to machine_done
Handling most of smbios data generation in the machine_done notifier is similar to how the ARM virt machine handles it which also calls smbios_set_defaults() there. The result is that all pc machines are freed from explicitly worrying about smbios setup. Signed-off-by: Bernhard Beschow <shentey@gmail.com> Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org> Message-ID: <20240208220349.4948-6-shentey@gmail.com> Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
This commit is contained in:
parent
4d3457fef9
commit
a0204a5ed0
@ -48,15 +48,25 @@ const char *fw_cfg_arch_key_name(uint16_t key)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
void fw_cfg_build_smbios(MachineState *ms, FWCfgState *fw_cfg)
|
void fw_cfg_build_smbios(PCMachineState *pcms, FWCfgState *fw_cfg)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_SMBIOS
|
#ifdef CONFIG_SMBIOS
|
||||||
uint8_t *smbios_tables, *smbios_anchor;
|
uint8_t *smbios_tables, *smbios_anchor;
|
||||||
size_t smbios_tables_len, smbios_anchor_len;
|
size_t smbios_tables_len, smbios_anchor_len;
|
||||||
struct smbios_phys_mem_area *mem_array;
|
struct smbios_phys_mem_area *mem_array;
|
||||||
unsigned i, array_count;
|
unsigned i, array_count;
|
||||||
|
MachineState *ms = MACHINE(pcms);
|
||||||
|
PCMachineClass *pcmc = PC_MACHINE_GET_CLASS(pcms);
|
||||||
|
MachineClass *mc = MACHINE_GET_CLASS(pcms);
|
||||||
X86CPU *cpu = X86_CPU(ms->possible_cpus->cpus[0].cpu);
|
X86CPU *cpu = X86_CPU(ms->possible_cpus->cpus[0].cpu);
|
||||||
|
|
||||||
|
if (pcmc->smbios_defaults) {
|
||||||
|
/* These values are guest ABI, do not change */
|
||||||
|
smbios_set_defaults("QEMU", mc->desc, mc->name,
|
||||||
|
pcmc->smbios_legacy_mode, pcmc->smbios_uuid_encoded,
|
||||||
|
pcms->smbios_entry_point_type);
|
||||||
|
}
|
||||||
|
|
||||||
/* tell smbios about cpuid version and features */
|
/* tell smbios about cpuid version and features */
|
||||||
smbios_set_cpuid(cpu->env.cpuid_version, cpu->env.features[FEAT_1_EDX]);
|
smbios_set_cpuid(cpu->env.cpuid_version, cpu->env.features[FEAT_1_EDX]);
|
||||||
|
|
||||||
|
@ -10,6 +10,7 @@
|
|||||||
#define HW_I386_FW_CFG_H
|
#define HW_I386_FW_CFG_H
|
||||||
|
|
||||||
#include "hw/boards.h"
|
#include "hw/boards.h"
|
||||||
|
#include "hw/i386/pc.h"
|
||||||
#include "hw/nvram/fw_cfg.h"
|
#include "hw/nvram/fw_cfg.h"
|
||||||
|
|
||||||
#define FW_CFG_IO_BASE 0x510
|
#define FW_CFG_IO_BASE 0x510
|
||||||
@ -22,7 +23,7 @@
|
|||||||
FWCfgState *fw_cfg_arch_create(MachineState *ms,
|
FWCfgState *fw_cfg_arch_create(MachineState *ms,
|
||||||
uint16_t boot_cpus,
|
uint16_t boot_cpus,
|
||||||
uint16_t apic_id_limit);
|
uint16_t apic_id_limit);
|
||||||
void fw_cfg_build_smbios(MachineState *ms, FWCfgState *fw_cfg);
|
void fw_cfg_build_smbios(PCMachineState *ms, FWCfgState *fw_cfg);
|
||||||
void fw_cfg_build_feature_control(MachineState *ms, FWCfgState *fw_cfg);
|
void fw_cfg_build_feature_control(MachineState *ms, FWCfgState *fw_cfg);
|
||||||
void fw_cfg_add_acpi_dsdt(Aml *scope, FWCfgState *fw_cfg);
|
void fw_cfg_add_acpi_dsdt(Aml *scope, FWCfgState *fw_cfg);
|
||||||
|
|
||||||
|
@ -689,7 +689,7 @@ void pc_machine_done(Notifier *notifier, void *data)
|
|||||||
|
|
||||||
acpi_setup();
|
acpi_setup();
|
||||||
if (x86ms->fw_cfg) {
|
if (x86ms->fw_cfg) {
|
||||||
fw_cfg_build_smbios(MACHINE(pcms), x86ms->fw_cfg);
|
fw_cfg_build_smbios(pcms, x86ms->fw_cfg);
|
||||||
fw_cfg_build_feature_control(MACHINE(pcms), x86ms->fw_cfg);
|
fw_cfg_build_feature_control(MACHINE(pcms), x86ms->fw_cfg);
|
||||||
/* update FW_CFG_NB_CPUS to account for -device added CPUs */
|
/* update FW_CFG_NB_CPUS to account for -device added CPUs */
|
||||||
fw_cfg_modify_i16(x86ms->fw_cfg, FW_CFG_NB_CPUS, x86ms->boot_cpus);
|
fw_cfg_modify_i16(x86ms->fw_cfg, FW_CFG_NB_CPUS, x86ms->boot_cpus);
|
||||||
|
@ -36,7 +36,6 @@
|
|||||||
#include "hw/rtc/mc146818rtc.h"
|
#include "hw/rtc/mc146818rtc.h"
|
||||||
#include "hw/southbridge/piix.h"
|
#include "hw/southbridge/piix.h"
|
||||||
#include "hw/display/ramfb.h"
|
#include "hw/display/ramfb.h"
|
||||||
#include "hw/firmware/smbios.h"
|
|
||||||
#include "hw/pci/pci.h"
|
#include "hw/pci/pci.h"
|
||||||
#include "hw/pci/pci_ids.h"
|
#include "hw/pci/pci_ids.h"
|
||||||
#include "hw/usb.h"
|
#include "hw/usb.h"
|
||||||
@ -225,15 +224,6 @@ static void pc_init1(MachineState *machine,
|
|||||||
&error_abort);
|
&error_abort);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pcmc->smbios_defaults) {
|
|
||||||
MachineClass *mc = MACHINE_GET_CLASS(machine);
|
|
||||||
/* These values are guest ABI, do not change */
|
|
||||||
smbios_set_defaults("QEMU", mc->desc,
|
|
||||||
mc->name, pcmc->smbios_legacy_mode,
|
|
||||||
pcmc->smbios_uuid_encoded,
|
|
||||||
pcms->smbios_entry_point_type);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* allocate ram and load rom/bios */
|
/* allocate ram and load rom/bios */
|
||||||
if (!xen_enabled()) {
|
if (!xen_enabled()) {
|
||||||
pc_memory_init(pcms, system_memory, rom_memory, hole64_size);
|
pc_memory_init(pcms, system_memory, rom_memory, hole64_size);
|
||||||
|
@ -45,7 +45,6 @@
|
|||||||
#include "hw/i386/amd_iommu.h"
|
#include "hw/i386/amd_iommu.h"
|
||||||
#include "hw/i386/intel_iommu.h"
|
#include "hw/i386/intel_iommu.h"
|
||||||
#include "hw/display/ramfb.h"
|
#include "hw/display/ramfb.h"
|
||||||
#include "hw/firmware/smbios.h"
|
|
||||||
#include "hw/ide/pci.h"
|
#include "hw/ide/pci.h"
|
||||||
#include "hw/ide/ahci-pci.h"
|
#include "hw/ide/ahci-pci.h"
|
||||||
#include "hw/intc/ioapic.h"
|
#include "hw/intc/ioapic.h"
|
||||||
@ -188,14 +187,6 @@ static void pc_q35_init(MachineState *machine)
|
|||||||
kvmclock_create(pcmc->kvmclock_create_always);
|
kvmclock_create(pcmc->kvmclock_create_always);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pcmc->smbios_defaults) {
|
|
||||||
/* These values are guest ABI, do not change */
|
|
||||||
smbios_set_defaults("QEMU", mc->desc,
|
|
||||||
mc->name, pcmc->smbios_legacy_mode,
|
|
||||||
pcmc->smbios_uuid_encoded,
|
|
||||||
pcms->smbios_entry_point_type);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* create pci host bus */
|
/* create pci host bus */
|
||||||
phb = OBJECT(qdev_new(TYPE_Q35_HOST_DEVICE));
|
phb = OBJECT(qdev_new(TYPE_Q35_HOST_DEVICE));
|
||||||
|
|
||||||
|
@ -12,7 +12,6 @@
|
|||||||
#include "hw/hotplug.h"
|
#include "hw/hotplug.h"
|
||||||
#include "qom/object.h"
|
#include "qom/object.h"
|
||||||
#include "hw/i386/sgx-epc.h"
|
#include "hw/i386/sgx-epc.h"
|
||||||
#include "hw/firmware/smbios.h"
|
|
||||||
#include "hw/cxl/cxl.h"
|
#include "hw/cxl/cxl.h"
|
||||||
|
|
||||||
#define HPET_INTCAP "hpet-intcap"
|
#define HPET_INTCAP "hpet-intcap"
|
||||||
|
Loading…
Reference in New Issue
Block a user