It's moderately common for a machine type to need to keep track of information that is specific to the platform it implements, but per-cpu.
While it could keep such information inside the MachineState, this makes lookup from the CPUState awkward. So, this series adds a standard way to stash machine-specific per-cpu information using a void pointer in the PowerPCCPU object. The machine is responsible for alloc()ing, free()ing and (if applicable) migrating this state. The meat of the series is the last two patches. The first 5 clean up a number of minor uglies I encountered while implementing. Chganges since v2: * Fix compile (and other) errors in KVM code. Changes since v1: * Simplify the error handling cleanup in 2/7 to use &error_abort instead of more propagations David Gibson (7): spapr: Clean up cpu realize/unrealize paths pnv: Fix some error handling cpu realize() pnv_core: Allocate cpu thread objects individually pnv: Clean up cpu realize path pnv: Add cpu unrealize path target/ppc: Replace intc pointer with a general machine_data pointer target/ppc, spapr: Move VPA information to machine_data hw/intc/xics.c | 5 +- hw/intc/xics_spapr.c | 16 +++-- hw/ppc/pnv.c | 8 +-- hw/ppc/pnv_core.c | 100 ++++++++++++++++++-------------- hw/ppc/spapr.c | 8 +-- hw/ppc/spapr_cpu_core.c | 85 +++++++++++++-------------- hw/ppc/spapr_hcall.c | 77 +++++++++++++----------- include/hw/ppc/pnv_core.h | 11 +++- include/hw/ppc/spapr_cpu_core.h | 13 +++++ include/hw/ppc/xics.h | 4 +- target/ppc/cpu.h | 8 +-- target/ppc/kvm.c | 36 ++++++------ target/ppc/translate_init.inc.c | 8 --- 13 files changed, 203 insertions(+), 176 deletions(-) -- 2.17.1