在 2023/8/22 下午8:26, Bibo Mao 写道:
Implement the callback for getting the architecture-dependent CPU
ID, the cpu ID is physical id described in ACPI MADT table, this
will be used for cpu hotplug.

Signed-off-by: Bibo Mao <maob...@loongson.cn>
Change-Id: I53bcfb9f4279e491f33e8b99a9102534ad53409e
---

Drop Chang-Id.

Otherwise
Reviewed-by: Song Gao <gaos...@loongson.cn>

Thanks.
Song Gao

  hw/loongarch/virt.c    | 2 ++
  target/loongarch/cpu.c | 8 ++++++++
  target/loongarch/cpu.h | 1 +
  3 files changed, 11 insertions(+)

diff --git a/hw/loongarch/virt.c b/hw/loongarch/virt.c
index e19b042ce8..6f6b577749 100644
--- a/hw/loongarch/virt.c
+++ b/hw/loongarch/virt.c
@@ -815,6 +815,8 @@ static void loongarch_init(MachineState *machine)
          cpu = cpu_create(machine->cpu_type);
          cpu->cpu_index = i;
          machine->possible_cpus->cpus[i].cpu = OBJECT(cpu);
+        lacpu = LOONGARCH_CPU(cpu);
+        lacpu->phy_id = machine->possible_cpus->cpus[i].arch_id;
      }
      fdt_add_cpu_nodes(lams);
diff --git a/target/loongarch/cpu.c b/target/loongarch/cpu.c
index ad93ecac92..7be3769672 100644
--- a/target/loongarch/cpu.c
+++ b/target/loongarch/cpu.c
@@ -690,6 +690,13 @@ static struct TCGCPUOps loongarch_tcg_ops = {
  static const struct SysemuCPUOps loongarch_sysemu_ops = {
      .get_phys_page_debug = loongarch_cpu_get_phys_page_debug,
  };
+
+static int64_t loongarch_cpu_get_arch_id(CPUState *cs)
+{
+    LoongArchCPU *cpu = LOONGARCH_CPU(cs);
+
+    return cpu->phy_id;
+}
  #endif
static gchar *loongarch_gdb_arch_name(CPUState *cs)
@@ -715,6 +722,7 @@ static void loongarch_cpu_class_init(ObjectClass *c, void 
*data)
      cc->set_pc = loongarch_cpu_set_pc;
      cc->get_pc = loongarch_cpu_get_pc;
  #ifndef CONFIG_USER_ONLY
+    cc->get_arch_id = loongarch_cpu_get_arch_id;
      dc->vmsd = &vmstate_loongarch_cpu;
      cc->sysemu_ops = &loongarch_sysemu_ops;
  #endif
diff --git a/target/loongarch/cpu.h b/target/loongarch/cpu.h
index fa371ca8ba..033081593c 100644
--- a/target/loongarch/cpu.h
+++ b/target/loongarch/cpu.h
@@ -371,6 +371,7 @@ struct ArchCPU {
      CPUNegativeOffsetState neg;
      CPULoongArchState env;
      QEMUTimer timer;
+    uint32_t  phy_id;
/* 'compatible' string for this CPU for Linux device trees */
      const char *dtb_compatible;



Reply via email to