On Thu, 20 Jul 2023 15:15:12 +0800 xianglai li <lixiang...@loongson.cn> wrote:
> 1.Create a new GED device type for Loongarch, > mount cpu_madt function to update the ACPI table madt changes should be its own patch > 2.Update the APIC table for loongarch based on > CPU information to support CPU hot-(un)plug > > Cc: Xiaojuan Yang <yangxiaoj...@loongson.cn> > Cc: Song Gao <gaos...@loongson.cn> > Cc: "Michael S. Tsirkin" <m...@redhat.com> > Cc: Igor Mammedov <imamm...@redhat.com> > Cc: Ani Sinha <anisi...@redhat.com> > Cc: Paolo Bonzini <pbonz...@redhat.com> > Cc: Richard Henderson <richard.hender...@linaro.org> > Cc: Eduardo Habkost <edua...@habkost.net> > Cc: Marcel Apfelbaum <marcel.apfelb...@gmail.com> > Cc: "Philippe Mathieu-Daudé" <phi...@linaro.org> > Cc: Yanan Wang <wangyana...@huawei.com> > Cc: "Daniel P. Berrangé" <berra...@redhat.com> > Cc: Peter Xu <pet...@redhat.com> > Cc: David Hildenbrand <da...@redhat.com> > Signed-off-by: xianglai li <lixiang...@loongson.cn> > --- > hw/acpi/acpi-cpu-hotplug-stub.c | 9 +++++ > hw/loongarch/acpi-build.c | 35 ++++++++++++++++-- > hw/loongarch/generic_event_device_loongarch.c | 36 +++++++++++++++++++ > hw/loongarch/meson.build | 2 +- > 4 files changed, 79 insertions(+), 3 deletions(-) > create mode 100644 hw/loongarch/generic_event_device_loongarch.c > > diff --git a/hw/acpi/acpi-cpu-hotplug-stub.c b/hw/acpi/acpi-cpu-hotplug-stub.c > index 2aec90d968..af9fda2cf4 100644 > --- a/hw/acpi/acpi-cpu-hotplug-stub.c > +++ b/hw/acpi/acpi-cpu-hotplug-stub.c > @@ -19,6 +19,15 @@ void legacy_acpi_cpu_hotplug_init(MemoryRegion *parent, > Object *owner, > return; > } > > +void build_cpus_aml(Aml *table, MachineState *machine, CPUHotplugFeatures > opts, > + hwaddr mmap_io_base, > + const char *res_root, > + const char *event_handler_method, > + AmlRegionSpace rs) > +{ > + return; > +} > + > void acpi_cpu_ospm_status(CPUHotplugState *cpu_st, ACPIOSTInfoList ***list) > { > return; > diff --git a/hw/loongarch/acpi-build.c b/hw/loongarch/acpi-build.c > index 0b62c3a2f7..312908fb2f 100644 > --- a/hw/loongarch/acpi-build.c > +++ b/hw/loongarch/acpi-build.c > @@ -46,6 +46,23 @@ > #define ACPI_BUILD_DPRINTF(fmt, ...) > #endif > > +void virt_madt_cpu_entry(int uid, > + const CPUArchIdList *apic_ids, > + GArray *entry, bool force_enabled) > +{ > + uint32_t apic_id = apic_ids->cpus[uid].arch_id; > + /* Flags – Local APIC Flags */ > + uint32_t flags = apic_ids->cpus[uid].cpu != NULL || force_enabled ? > + 1 /* Enabled */ : 0; > + > + /* Rev 1.0b, Table 5-13 Processor Local APIC Structure */ > + build_append_int_noprefix(entry, 0, 1); /* Type */ > + build_append_int_noprefix(entry, 8, 1); /* Length */ > + build_append_int_noprefix(entry, uid, 1); /* ACPI Processor ID */ > + build_append_int_noprefix(entry, apic_id, 1); /* APIC ID */ > + build_append_int_noprefix(entry, flags, 4); /* Flags */ > +} > + > /* build FADT */ > static void init_common_fadt_data(AcpiFadtData *data) > { > @@ -121,15 +138,18 @@ build_madt(GArray *table_data, BIOSLinker *linker, > LoongArchMachineState *lams) > build_append_int_noprefix(table_data, 1 /* PCAT_COMPAT */, 4); /* Flags > */ > > for (i = 0; i < arch_ids->len; i++) { > + uint32_t flags; > + > /* Processor Core Interrupt Controller Structure */ > arch_id = arch_ids->cpus[i].arch_id; > + flags = arch_ids->cpus[i].cpu ? 1 : 0; > > build_append_int_noprefix(table_data, 17, 1); /* Type */ > build_append_int_noprefix(table_data, 15, 1); /* Length */ > build_append_int_noprefix(table_data, 1, 1); /* Version */ > - build_append_int_noprefix(table_data, i + 1, 4); /* ACPI Processor > ID */ > + build_append_int_noprefix(table_data, i, 4); /* ACPI Processor > ID */ > build_append_int_noprefix(table_data, arch_id, 4); /* Core ID */ > - build_append_int_noprefix(table_data, 1, 4); /* Flags */ > + build_append_int_noprefix(table_data, flags, 4); /* Flags */ > } > > /* Extend I/O Interrupt Controller Structure */ > @@ -292,6 +312,17 @@ build_la_ged_aml(Aml *dsdt, MachineState *machine) > AML_SYSTEM_MEMORY, > VIRT_GED_MEM_ADDR); > } > + > + if (event & ACPI_GED_CPU_HOTPLUG_EVT) { > + CPUHotplugFeatures opts = { > + .acpi_1_compatible = false, > + .has_legacy_cphp = false > + }; > + > + build_cpus_aml(dsdt, machine, opts, VIRT_GED_CPUHP_ADDR, > + "\\_SB", "\\_GPE._E01", AML_SYSTEM_MEMORY); > + > + } > acpi_dsdt_add_power_button(dsdt); > } > > diff --git a/hw/loongarch/generic_event_device_loongarch.c > b/hw/loongarch/generic_event_device_loongarch.c > new file mode 100644 > index 0000000000..1fe550239b > --- /dev/null > +++ b/hw/loongarch/generic_event_device_loongarch.c > @@ -0,0 +1,36 @@ > +/* > + * loongarch variant of the generic event device for hw reduced acpi > + * > + * 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. > + */ > + > +#include "qemu/osdep.h" > +#include "hw/acpi/generic_event_device.h" > +#include "hw/loongarch/virt.h" > + > +static void acpi_ged_loongarch_class_init(ObjectClass *class, void *data) > +{ > + AcpiDeviceIfClass *adevc = ACPI_DEVICE_IF_CLASS(class); > + > + adevc->madt_cpu = virt_madt_cpu_entry; > +} > + > +static const TypeInfo acpi_ged_loongarch_info = { > + .name = TYPE_ACPI_GED_LOONGARCH, > + .parent = TYPE_ACPI_GED, > + .class_init = acpi_ged_loongarch_class_init, > + .interfaces = (InterfaceInfo[]) { > + { TYPE_HOTPLUG_HANDLER }, > + { TYPE_ACPI_DEVICE_IF }, > + { } > + } > +}; > + > +static void acpi_ged_loongarch_register_types(void) > +{ > + type_register_static(&acpi_ged_loongarch_info); > +} > + > +type_init(acpi_ged_loongarch_register_types) > diff --git a/hw/loongarch/meson.build b/hw/loongarch/meson.build > index c0421502ab..8d21addee3 100644 > --- a/hw/loongarch/meson.build > +++ b/hw/loongarch/meson.build > @@ -3,6 +3,6 @@ loongarch_ss.add(files( > 'fw_cfg.c', > )) > loongarch_ss.add(when: 'CONFIG_LOONGARCH_VIRT', if_true: [files('virt.c'), > fdt]) > -loongarch_ss.add(when: 'CONFIG_ACPI', if_true: files('acpi-build.c')) > +loongarch_ss.add(when: 'CONFIG_ACPI', if_true: files('acpi-build.c', > 'generic_event_device_loongarch.c')) > > hw_arch += {'loongarch': loongarch_ss}