[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH 8/9] cpu/topology: add s390x support for smp machine
From: |
Like Xu |
Subject: |
[Qemu-devel] [PATCH 8/9] cpu/topology: add s390x support for smp machine properties |
Date: |
Fri, 29 Mar 2019 16:48:44 +0800 |
Signed-off-by: Like Xu <address@hidden>
---
hw/s390x/s390-virtio-ccw.c | 2 ++
hw/s390x/sclp.c | 1 +
target/openrisc/sys_helper.c | 5 +++++
target/s390x/cpu.c | 3 +++
target/s390x/excp_helper.c | 6 ++++++
5 files changed, 17 insertions(+)
diff --git a/hw/s390x/s390-virtio-ccw.c b/hw/s390x/s390-virtio-ccw.c
index d11069b..8cb71e0 100644
--- a/hw/s390x/s390-virtio-ccw.c
+++ b/hw/s390x/s390-virtio-ccw.c
@@ -77,6 +77,7 @@ out:
static void s390_init_cpus(MachineState *machine)
{
MachineClass *mc = MACHINE_GET_CLASS(machine);
+ unsigned int smp_cpus = machine->topo.smp_cpus;
int i;
/* initialize possible_cpus */
@@ -398,6 +399,7 @@ static CpuInstanceProperties
s390_cpu_index_to_props(MachineState *ms,
static const CPUArchIdList *s390_possible_cpu_arch_ids(MachineState *ms)
{
int i;
+ unsigned int max_cpus = ms->topo.max_cpus;
if (ms->possible_cpus) {
g_assert(ms->possible_cpus && ms->possible_cpus->len == max_cpus);
diff --git a/hw/s390x/sclp.c b/hw/s390x/sclp.c
index 4510a80..1de3fb6 100644
--- a/hw/s390x/sclp.c
+++ b/hw/s390x/sclp.c
@@ -56,6 +56,7 @@ static void read_SCP_info(SCLPDevice *sclp, SCCB *sccb)
{
ReadInfo *read_info = (ReadInfo *) sccb;
MachineState *machine = MACHINE(qdev_get_machine());
+ unsigned int max_cpus = machine->topo.max_cpus;
int cpu_count;
int rnsize, rnmax;
IplParameterBlock *ipib = s390_ipl_get_iplb();
diff --git a/target/openrisc/sys_helper.c b/target/openrisc/sys_helper.c
index 05f66c4..a8b03c6 100644
--- a/target/openrisc/sys_helper.c
+++ b/target/openrisc/sys_helper.c
@@ -24,6 +24,9 @@
#include "exec/helper-proto.h"
#include "exception.h"
#include "sysemu/sysemu.h"
+#ifndef CONFIG_USER_ONLY
+#include "hw/boards.h"
+#endif
#define TO_SPR(group, number) (((group) << 11) + (number))
@@ -194,6 +197,8 @@ target_ulong HELPER(mfspr)(CPUOpenRISCState *env,
target_ulong rd,
target_ulong spr)
{
#ifndef CONFIG_USER_ONLY
+ MachineState *ms = MACHINE(qdev_get_machine());
+ unsigned int max_cpus = ms->topo.max_cpus;
OpenRISCCPU *cpu = openrisc_env_get_cpu(env);
CPUState *cs = CPU(cpu);
int idx;
diff --git a/target/s390x/cpu.c b/target/s390x/cpu.c
index 698dd9c..4b614c5 100644
--- a/target/s390x/cpu.c
+++ b/target/s390x/cpu.c
@@ -37,6 +37,7 @@
#include "hw/qdev-properties.h"
#ifndef CONFIG_USER_ONLY
#include "hw/hw.h"
+#include "hw/boards.h"
#include "sysemu/arch_init.h"
#include "sysemu/sysemu.h"
#endif
@@ -193,6 +194,8 @@ static void s390_cpu_realizefn(DeviceState *dev, Error
**errp)
}
#if !defined(CONFIG_USER_ONLY)
+ MachineState *ms = MACHINE(qdev_get_machine());
+ unsigned int max_cpus = ms->topo.max_cpus;
if (cpu->env.core_id >= max_cpus) {
error_setg(&err, "Unable to add CPU with core-id: %" PRIu32
", maximum core-id: %d", cpu->env.core_id,
diff --git a/target/s390x/excp_helper.c b/target/s390x/excp_helper.c
index f84bfb1..d3eec86 100644
--- a/target/s390x/excp_helper.c
+++ b/target/s390x/excp_helper.c
@@ -31,6 +31,7 @@
#ifndef CONFIG_USER_ONLY
#include "sysemu/sysemu.h"
#include "hw/s390x/s390_flic.h"
+#include "hw/boards.h"
#endif
void QEMU_NORETURN tcg_s390_program_interrupt(CPUS390XState *env, uint32_t
code,
@@ -279,7 +280,12 @@ static void do_ext_interrupt(CPUS390XState *env)
g_assert(cpu_addr < S390_MAX_CPUS);
lowcore->cpu_addr = cpu_to_be16(cpu_addr);
clear_bit(cpu_addr, env->emergency_signals);
+#ifndef CONFIG_USER_ONLY
+ MachineState *ms = MACHINE(qdev_get_machine());
+ if (bitmap_empty(env->emergency_signals, ms->topo.max_cpus)) {
+#elif
if (bitmap_empty(env->emergency_signals, max_cpus)) {
+#endif
env->pending_int &= ~INTERRUPT_EMERGENCY_SIGNAL;
}
} else if ((env->pending_int & INTERRUPT_EXTERNAL_CALL) &&
--
1.8.3.1
- [Qemu-devel] [PATCH 0/9] refactor cpu topo into machine properties, Like Xu, 2019/03/29
- [Qemu-devel] [PATCH 3/9] cpu/topology: add uncommon arch support for smp machine properties, Like Xu, 2019/03/29
- [Qemu-devel] [PATCH 1/9] cpu/topology: add struct CpuTopology to MachineState, Like Xu, 2019/03/29
- [Qemu-devel] [PATCH 5/9] cpu/topology: add i386 support for smp machine properties, Like Xu, 2019/03/29
- [Qemu-devel] [PATCH 2/9] cpu/topology: add general support for machine properties, Like Xu, 2019/03/29
- [Qemu-devel] [PATCH 4/9] cpu/topology: add ARM support for smp machine properties, Like Xu, 2019/03/29
- [Qemu-devel] [PATCH 7/9] cpu/topology: add riscv support for smp machine properties, Like Xu, 2019/03/29
- [Qemu-devel] [PATCH 9/9] cpu/topology: replace smp global variables with machine propertie, Like Xu, 2019/03/29
- [Qemu-devel] [PATCH 8/9] cpu/topology: add s390x support for smp machine properties,
Like Xu <=
- [Qemu-devel] [PATCH 6/9] cpu/topology: add PPC support for smp machine properties, Like Xu, 2019/03/29
- Re: [Qemu-devel] [PATCH 0/9] refactor cpu topo into machine properties, no-reply, 2019/03/29
- Re: [Qemu-devel] [PATCH 0/9] refactor cpu topo into machine properties, Igor Mammedov, 2019/03/29