qemu-trivial
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Qemu-trivial] [Qemu-devel] [PATCH 7/9] cpu/topology: add riscv supp


From: Like Xu
Subject: Re: [Qemu-trivial] [Qemu-devel] [PATCH 7/9] cpu/topology: add riscv support for smp machine properties
Date: Mon, 1 Apr 2019 10:10:09 +0800
User-agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:60.0) Gecko/20100101 Thunderbird/60.6.1

On 2019/3/30 7:01, Alistair Francis wrote:
On Fri, Mar 29, 2019 at 1:59 AM Like Xu <address@hidden> wrote:

Signed-off-by: Like Xu <address@hidden>
---
  hw/openrisc/openrisc_sim.c | 1 +
  hw/riscv/sifive_e.c        | 4 ++++
  hw/riscv/sifive_plic.c     | 3 +++
  hw/riscv/sifive_u.c        | 4 ++++
  hw/riscv/spike.c           | 2 ++
  hw/riscv/virt.c            | 1 +
  6 files changed, 15 insertions(+)

diff --git a/hw/openrisc/openrisc_sim.c b/hw/openrisc/openrisc_sim.c
index 7d3b734..ecfc973 100644
--- a/hw/openrisc/openrisc_sim.c
+++ b/hw/openrisc/openrisc_sim.c
@@ -131,6 +131,7 @@ static void openrisc_sim_init(MachineState *machine)
      qemu_irq *cpu_irqs[2];
      qemu_irq serial_irq;
      int n;
+    unsigned int smp_cpus = machine->topo.smp_cpus;

OpenRISC and RISC-V are not the same thing, it's probably worth
splitting this out into a separate patch.

Alistair
You're right and thanks.
I may fix it in next version.



      for (n = 0; n < smp_cpus; n++) {
          cpu = OPENRISC_CPU(cpu_create(machine->cpu_type));
diff --git a/hw/riscv/sifive_e.c b/hw/riscv/sifive_e.c
index b1cd113..c65c7b5 100644
--- a/hw/riscv/sifive_e.c
+++ b/hw/riscv/sifive_e.c
@@ -137,6 +137,8 @@ static void riscv_sifive_e_init(MachineState *machine)

  static void riscv_sifive_e_soc_init(Object *obj)
  {
+    MachineState *ms = MACHINE(qdev_get_machine());
+    unsigned int smp_cpus = ms->topo.smp_cpus;
      SiFiveESoCState *s = RISCV_E_SOC(obj);

      object_initialize_child(obj, "cpus", &s->cpus,
@@ -150,6 +152,8 @@ static void riscv_sifive_e_soc_init(Object *obj)

  static void riscv_sifive_e_soc_realize(DeviceState *dev, Error **errp)
  {
+    MachineState *ms = MACHINE(qdev_get_machine());
+    unsigned int smp_cpus = ms->topo.smp_cpus;
      const struct MemmapEntry *memmap = sifive_e_memmap;

      SiFiveESoCState *s = RISCV_E_SOC(dev);
diff --git a/hw/riscv/sifive_plic.c b/hw/riscv/sifive_plic.c
index ac768e6..161fbd9 100644
--- a/hw/riscv/sifive_plic.c
+++ b/hw/riscv/sifive_plic.c
@@ -23,6 +23,7 @@
  #include "qemu/error-report.h"
  #include "hw/sysbus.h"
  #include "hw/pci/msi.h"
+#include "hw/boards.h"
  #include "target/riscv/cpu.h"
  #include "sysemu/sysemu.h"
  #include "hw/riscv/sifive_plic.h"
@@ -432,6 +433,8 @@ static void sifive_plic_irq_request(void *opaque, int irq, 
int level)

  static void sifive_plic_realize(DeviceState *dev, Error **errp)
  {
+    MachineState *ms = MACHINE(qdev_get_machine());
+    unsigned int smp_cpus = ms->topo.smp_cpus;
      SiFivePLICState *plic = SIFIVE_PLIC(dev);
      int i;

diff --git a/hw/riscv/sifive_u.c b/hw/riscv/sifive_u.c
index 5ecc47c..b4a8d66 100644
--- a/hw/riscv/sifive_u.c
+++ b/hw/riscv/sifive_u.c
@@ -321,6 +321,8 @@ static void riscv_sifive_u_init(MachineState *machine)

  static void riscv_sifive_u_soc_init(Object *obj)
  {
+    MachineState *ms = MACHINE(qdev_get_machine());
+    unsigned int smp_cpus = ms->topo.smp_cpus;
      SiFiveUSoCState *s = RISCV_U_SOC(obj);

      object_initialize_child(obj, "cpus", &s->cpus, sizeof(s->cpus),
@@ -336,6 +338,8 @@ static void riscv_sifive_u_soc_init(Object *obj)

  static void riscv_sifive_u_soc_realize(DeviceState *dev, Error **errp)
  {
+    MachineState *ms = MACHINE(qdev_get_machine());
+    unsigned int smp_cpus = ms->topo.smp_cpus;
      SiFiveUSoCState *s = RISCV_U_SOC(dev);
      const struct MemmapEntry *memmap = sifive_u_memmap;
      MemoryRegion *system_memory = get_system_memory();
diff --git a/hw/riscv/spike.c b/hw/riscv/spike.c
index 2a000a5..5fe441c 100644
--- a/hw/riscv/spike.c
+++ b/hw/riscv/spike.c
@@ -171,6 +171,7 @@ static void spike_v1_10_0_board_init(MachineState *machine)
      MemoryRegion *main_mem = g_new(MemoryRegion, 1);
      MemoryRegion *mask_rom = g_new(MemoryRegion, 1);
      int i;
+    unsigned int smp_cpus = machine->topo.smp_cpus;

      /* Initialize SOC */
      object_initialize_child(OBJECT(machine), "soc", &s->soc, sizeof(s->soc),
@@ -253,6 +254,7 @@ static void spike_v1_09_1_board_init(MachineState *machine)
      MemoryRegion *main_mem = g_new(MemoryRegion, 1);
      MemoryRegion *mask_rom = g_new(MemoryRegion, 1);
      int i;
+    unsigned int smp_cpus = machine->topo.smp_cpus;

      /* Initialize SOC */
      object_initialize_child(OBJECT(machine), "soc", &s->soc, sizeof(s->soc),
diff --git a/hw/riscv/virt.c b/hw/riscv/virt.c
index fc4c6b3..9d4d305 100644
--- a/hw/riscv/virt.c
+++ b/hw/riscv/virt.c
@@ -395,6 +395,7 @@ static void riscv_virt_board_init(MachineState *machine)
      char *plic_hart_config;
      size_t plic_hart_config_len;
      int i;
+    unsigned int smp_cpus = machine->topo.smp_cpus;
      void *fdt;

      /* Initialize SOC */
--
1.8.3.1







reply via email to

[Prev in Thread] Current Thread [Next in Thread]