unicorn/qemu
Peter Maydell d5298c5370
qom/cpu: Add cluster_index to CPUState
For TCG we want to distinguish which cluster a CPU is in, and
we need to do it quickly. Cache the cluster index in the CPUState
struct, by having the cluster object set cpu->cluster_index for
each CPU child when it is realized.

This means that board/SoC code must add all CPUs to the cluster
before realizing the cluster object. Regrettably QOM provides no
way to prevent adding children to a realized object and no way for
the parent to be notified when a new child is added to it, so
we don't have any way to enforce/assert this constraint; all
we can do is document it in a comment. We can at least put in a
check that the cluster contains at least one CPU, which should
catch the typical cases of "realized cluster too early" or
"forgot to parent the CPUs into it".

The restriction on how many clusters can exist in the system
is imposed by TCG code which will be added in a subsequent commit,
but the check to enforce it in cluster.c fits better in this one.

Backports relevant parts of commit 7ea7b9ad532e59c3efbcabff0e3484f4df06104c from qemu
2019-01-30 12:59:59 -05:00
..
accel tcg: Add opcodes for vector minmax arithmetic 2019-01-29 16:24:52 -05:00
crypto
default-configs
docs
fpu include/fpu/softfloat: Fix compilation with Clang on s390x 2019-01-24 18:37:51 -05:00
hw
include qom/cpu: Add cluster_index to CPUState 2019-01-30 12:59:59 -05:00
qapi qapi: Rewrite string-input-visitor's integer and list parsing 2018-12-18 04:57:25 -05:00
qobject
qom qom/cpu: Add cluster_index to CPUState 2019-01-30 12:59:59 -05:00
scripts decodetree: re.fullmatch was added in 3.4 2019-01-25 13:47:47 -05:00
target target/arm: Don't clear supported PMU events when initializing PMCEID1 2019-01-29 17:12:23 -05:00
tcg tcg/aarch64: Implement vector minmax arithmetic 2019-01-29 16:44:09 -05:00
util qemu-thread: Don't block SEGV, ILL and FPE 2019-01-13 19:50:32 -05:00
aarch64.h target/arm: Don't clear supported PMU events when initializing PMCEID1 2019-01-29 17:12:23 -05:00
aarch64eb.h target/arm: Don't clear supported PMU events when initializing PMCEID1 2019-01-29 17:12:23 -05:00
accel.c
arm.h target/arm: Don't clear supported PMU events when initializing PMCEID1 2019-01-29 17:12:23 -05:00
armeb.h target/arm: Don't clear supported PMU events when initializing PMCEID1 2019-01-29 17:12:23 -05:00
CODING_STYLE
configure configure: Force the C standard to gnu99 2019-01-22 20:18:58 -05:00
COPYING
COPYING.LIB
cpus.c
exec.c exec.c: Use correct attrs in cpu_memory_rw_debug() 2019-01-29 17:05:50 -05:00
gen_all_header.sh
glib_compat.c
HACKING
header_gen.py target/arm: Don't clear supported PMU events when initializing PMCEID1 2019-01-29 17:12:23 -05:00
ioport.c
LICENSE
m68k.h tcg: Add opcodes for vector minmax arithmetic 2019-01-29 16:24:52 -05:00
Makefile
Makefile.objs
Makefile.target configure: Remove old -fno-gcse workaround for GCC 4.6.x and 4.7.[012] 2018-12-18 03:52:36 -05:00
memory.c
memory_ldst.inc.c
memory_mapping.c
mips.h tcg: Add opcodes for vector minmax arithmetic 2019-01-29 16:24:52 -05:00
mips64.h tcg: Add opcodes for vector minmax arithmetic 2019-01-29 16:24:52 -05:00
mips64el.h tcg: Add opcodes for vector minmax arithmetic 2019-01-29 16:24:52 -05:00
mipsel.h tcg: Add opcodes for vector minmax arithmetic 2019-01-29 16:24:52 -05:00
powerpc.h tcg: Add opcodes for vector minmax arithmetic 2019-01-29 16:24:52 -05:00
qemu-timer.c
riscv32.h
riscv64.h
rules.mak
sparc.h tcg: Add opcodes for vector minmax arithmetic 2019-01-29 16:24:52 -05:00
sparc64.h tcg: Add opcodes for vector minmax arithmetic 2019-01-29 16:24:52 -05:00
unicorn_common.h
VERSION
vl.c
vl.h
x86_64.h tcg: Add opcodes for vector minmax arithmetic 2019-01-29 16:24:52 -05:00