From: David Gibson <david@gibson.dropbear.id.au>
To: Igor Mammedov <imammedo@redhat.com>
Cc: qemu-devel@nongnu.org, agraf@suse.de, thuth@redhat.com,
lvivier@redhat.com, qemu-ppc@nongnu.org,
mdroth@linux.vnet.ibm.com, peter.maydell@linaro.org
Subject: Re: [Qemu-devel] [PATCH 37/43] spapr: reuse machine->possible_cpus instead of cores[]
Date: Sat, 25 Feb 2017 00:03:57 +1100 [thread overview]
Message-ID: <20170224130357.GF17615@umbus.fritz.box> (raw)
In-Reply-To: <1487761555-93223-1-git-send-email-imammedo@redhat.com>
[-- Attachment #1: Type: text/plain, Size: 12541 bytes --]
On Wed, Feb 22, 2017 at 12:05:55PM +0100, Igor Mammedov wrote:
> Replace SPAPR specific cores[] array with generic
> machine->possible_cpus and store core objects there.
> It makes cores bookkeeping similar to x86 cpus and
> will allow to unify similar code.
> It would allow to replace cpu_index based NUMA node
> mapping with property based one (for -device created
> cores) since possible_cpus carries board defined
> topology/layout.
>
> Signed-off-by: Igor Mammedov <imammedo@redhat.com>
> Acked-by: David Gibson <david@gibson.dropbear.id.au>
> Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Sorry Igor, Peter has applied the original version. Can you resend
these updates as deltas against the applied versions of the patches.
> ---
> v3:
> - drop "// TODO" comment as todo is completed in next patch anyway
> fixes checkpatch error wrt // comment
> v2:
> - remove extra ';' at the end of expression (David Gibson)
> ---
> include/hw/ppc/spapr.h | 1 -
> hw/ppc/spapr.c | 127 ++++++++++++++++++++++++++++++++++---------------
> 2 files changed, 89 insertions(+), 39 deletions(-)
>
> diff --git a/include/hw/ppc/spapr.h b/include/hw/ppc/spapr.h
> index a2d8964..f9b17d8 100644
> --- a/include/hw/ppc/spapr.h
> +++ b/include/hw/ppc/spapr.h
> @@ -94,7 +94,6 @@ struct sPAPRMachineState {
> /*< public >*/
> char *kvm_type;
> MemoryHotplugState hotplug_memory;
> - Object **cores;
> };
>
> #define H_SUCCESS 0
> diff --git a/hw/ppc/spapr.c b/hw/ppc/spapr.c
> index 37cb338..735f53d 100644
> --- a/hw/ppc/spapr.c
> +++ b/hw/ppc/spapr.c
> @@ -1751,13 +1751,28 @@ static void spapr_validate_node_memory(MachineState *machine, Error **errp)
> }
> }
>
> +/* find cpu slot in machine->possible_cpus by core_id */
> +static CPUArchId *spapr_find_cpu_slot(MachineState *ms, uint32_t id, int *idx)
> +{
> + int index = id / smp_threads;
> +
> + if (index >= ms->possible_cpus->len) {
> + return NULL;
> + }
> + if (idx) {
> + *idx = index;
> + }
> + return &ms->possible_cpus->cpus[index];
> +}
> +
> static void spapr_init_cpus(sPAPRMachineState *spapr)
> {
> MachineState *machine = MACHINE(spapr);
> MachineClass *mc = MACHINE_GET_CLASS(machine);
> char *type = spapr_get_cpu_core_type(machine->cpu_model);
> int smt = kvmppc_smt_threads();
> - int spapr_max_cores, spapr_cores;
> + const CPUArchIdList *possible_cpus;
> + int boot_cores_nr = smp_cpus / smp_threads;
> int i;
>
> if (!type) {
> @@ -1765,6 +1780,7 @@ static void spapr_init_cpus(sPAPRMachineState *spapr)
> exit(1);
> }
>
> + possible_cpus = mc->possible_cpu_arch_ids(machine);
> if (mc->query_hotpluggable_cpus) {
> if (smp_cpus % smp_threads) {
> error_report("smp_cpus (%u) must be multiple of threads (%u)",
> @@ -1776,21 +1792,15 @@ static void spapr_init_cpus(sPAPRMachineState *spapr)
> max_cpus, smp_threads);
> exit(1);
> }
> -
> - spapr_max_cores = max_cpus / smp_threads;
> - spapr_cores = smp_cpus / smp_threads;
> } else {
> if (max_cpus != smp_cpus) {
> error_report("This machine version does not support CPU hotplug");
> exit(1);
> }
> -
> - spapr_max_cores = QEMU_ALIGN_UP(smp_cpus, smp_threads) / smp_threads;
> - spapr_cores = spapr_max_cores;
> + boot_cores_nr = possible_cpus->len;
> }
>
> - spapr->cores = g_new0(Object *, spapr_max_cores);
> - for (i = 0; i < spapr_max_cores; i++) {
> + for (i = 0; i < possible_cpus->len; i++) {
> int core_id = i * smp_threads;
>
> if (mc->query_hotpluggable_cpus) {
> @@ -1802,7 +1812,7 @@ static void spapr_init_cpus(sPAPRMachineState *spapr)
> qemu_register_reset(spapr_drc_reset, drc);
> }
>
> - if (i < spapr_cores) {
> + if (i < boot_cores_nr) {
> Object *core = object_new(type);
> int nr_threads = smp_threads;
>
> @@ -2491,10 +2501,11 @@ void *spapr_populate_hotplug_cpu_dt(CPUState *cs, int *fdt_offset,
> static void spapr_core_unplug(HotplugHandler *hotplug_dev, DeviceState *dev,
> Error **errp)
> {
> - sPAPRMachineState *spapr = SPAPR_MACHINE(qdev_get_machine());
> + MachineState *ms = MACHINE(qdev_get_machine());
> CPUCore *cc = CPU_CORE(dev);
> + CPUArchId *core_slot = spapr_find_cpu_slot(ms, cc->core_id, NULL);
>
> - spapr->cores[cc->core_id / smp_threads] = NULL;
> + core_slot->cpu = NULL;
> object_unparent(OBJECT(dev));
> }
>
> @@ -2510,19 +2521,24 @@ static
> void spapr_core_unplug_request(HotplugHandler *hotplug_dev, DeviceState *dev,
> Error **errp)
> {
> - CPUCore *cc = CPU_CORE(dev);
> - int smt = kvmppc_smt_threads();
> - int index = cc->core_id / smp_threads;
> - sPAPRDRConnector *drc =
> - spapr_dr_connector_by_id(SPAPR_DR_CONNECTOR_TYPE_CPU, index * smt);
> + int index;
> + sPAPRDRConnector *drc;
> sPAPRDRConnectorClass *drck;
> Error *local_err = NULL;
> + CPUCore *cc = CPU_CORE(dev);
> + int smt = kvmppc_smt_threads();
>
> + if (!spapr_find_cpu_slot(MACHINE(hotplug_dev), cc->core_id, &index)) {
> + error_setg(errp, "Unable to find CPU core with core-id: %d",
> + cc->core_id);
> + return;
> + }
> if (index == 0) {
> error_setg(errp, "Boot CPU core may not be unplugged");
> return;
> }
>
> + drc = spapr_dr_connector_by_id(SPAPR_DR_CONNECTOR_TYPE_CPU, index * smt);
> g_assert(drc);
>
> drck = SPAPR_DR_CONNECTOR_GET_CLASS(drc);
> @@ -2547,11 +2563,17 @@ static void spapr_core_plug(HotplugHandler *hotplug_dev, DeviceState *dev,
> Error *local_err = NULL;
> void *fdt = NULL;
> int fdt_offset = 0;
> - int index = cc->core_id / smp_threads;
> int smt = kvmppc_smt_threads();
> + CPUArchId *core_slot;
> + int index;
>
> + core_slot = spapr_find_cpu_slot(MACHINE(hotplug_dev), cc->core_id, &index);
> + if (!core_slot) {
> + error_setg(errp, "Unable to find CPU core with core-id: %d",
> + cc->core_id);
> + return;
> + }
> drc = spapr_dr_connector_by_id(SPAPR_DR_CONNECTOR_TYPE_CPU, index * smt);
> - spapr->cores[index] = OBJECT(dev);
>
> g_assert(drc || !mc->query_hotpluggable_cpus);
>
> @@ -2568,7 +2590,6 @@ static void spapr_core_plug(HotplugHandler *hotplug_dev, DeviceState *dev,
> drck->attach(drc, dev, fdt, fdt_offset, !dev->hotplugged, &local_err);
> if (local_err) {
> g_free(fdt);
> - spapr->cores[index] = NULL;
> error_propagate(errp, local_err);
> return;
> }
> @@ -2590,6 +2611,7 @@ static void spapr_core_plug(HotplugHandler *hotplug_dev, DeviceState *dev,
> drck->set_isolation_state(drc, SPAPR_DR_ISOLATION_STATE_UNISOLATED);
> }
> }
> + core_slot->cpu = OBJECT(dev);
> }
>
> static void spapr_core_pre_plug(HotplugHandler *hotplug_dev, DeviceState *dev,
> @@ -2597,13 +2619,12 @@ static void spapr_core_pre_plug(HotplugHandler *hotplug_dev, DeviceState *dev,
> {
> MachineState *machine = MACHINE(OBJECT(hotplug_dev));
> MachineClass *mc = MACHINE_GET_CLASS(hotplug_dev);
> - sPAPRMachineState *spapr = SPAPR_MACHINE(OBJECT(hotplug_dev));
> - int spapr_max_cores = max_cpus / smp_threads;
> - int index;
> Error *local_err = NULL;
> CPUCore *cc = CPU_CORE(dev);
> char *base_core_type = spapr_get_cpu_core_type(machine->cpu_model);
> const char *type = object_get_typename(OBJECT(dev));
> + CPUArchId *core_slot;
> + int index;
>
> if (dev->hotplugged && !mc->query_hotpluggable_cpus) {
> error_setg(&local_err, "CPU hotplug not supported for this machine");
> @@ -2620,13 +2641,13 @@ static void spapr_core_pre_plug(HotplugHandler *hotplug_dev, DeviceState *dev,
> goto out;
> }
>
> - index = cc->core_id / smp_threads;
> - if (index < 0 || index >= spapr_max_cores) {
> + core_slot = spapr_find_cpu_slot(MACHINE(hotplug_dev), cc->core_id, &index);
> + if (!core_slot) {
> error_setg(&local_err, "core id %d out of range", cc->core_id);
> goto out;
> }
>
> - if (spapr->cores[index]) {
> + if (core_slot->cpu) {
> error_setg(&local_err, "core %d already populated", cc->core_id);
> goto out;
> }
> @@ -2758,29 +2779,58 @@ static unsigned spapr_cpu_index_to_socket_id(unsigned cpu_index)
> return cpu_index / smp_threads / smp_cores;
> }
>
> +static const CPUArchIdList *spapr_possible_cpu_arch_ids(MachineState *machine)
> +{
> + int i;
> + int spapr_max_cores = max_cpus / smp_threads;
> + MachineClass *mc = MACHINE_GET_CLASS(machine);
> +
> + if (!mc->query_hotpluggable_cpus) {
> + spapr_max_cores = QEMU_ALIGN_UP(smp_cpus, smp_threads) / smp_threads;
> + }
> + if (machine->possible_cpus) {
> + assert(machine->possible_cpus->len == spapr_max_cores);
> + return machine->possible_cpus;
> + }
> +
> + machine->possible_cpus = g_malloc0(sizeof(CPUArchIdList) +
> + sizeof(CPUArchId) * spapr_max_cores);
> + machine->possible_cpus->len = spapr_max_cores;
> + for (i = 0; i < machine->possible_cpus->len; i++) {
> + int core_id = i * smp_threads;
> +
> + machine->possible_cpus->cpus[i].arch_id = core_id;
> + machine->possible_cpus->cpus[i].props.has_core_id = true;
> + machine->possible_cpus->cpus[i].props.core_id = core_id;
> + /* TODO: add 'has_node/node' here to describe
> + to which node core belongs */
> + }
> + return machine->possible_cpus;
> +}
> +
> static HotpluggableCPUList *spapr_query_hotpluggable_cpus(MachineState *machine)
> {
> int i;
> + Object *cpu;
> HotpluggableCPUList *head = NULL;
> - sPAPRMachineState *spapr = SPAPR_MACHINE(machine);
> - int spapr_max_cores = max_cpus / smp_threads;
> + const char *cpu_type;
>
> - for (i = 0; i < spapr_max_cores; i++) {
> + cpu = machine->possible_cpus->cpus[0].cpu;
> + assert(cpu); /* Boot cpu is always present */
> + cpu_type = object_get_typename(cpu);
> + for (i = 0; i < machine->possible_cpus->len; i++) {
> HotpluggableCPUList *list_item = g_new0(typeof(*list_item), 1);
> HotpluggableCPU *cpu_item = g_new0(typeof(*cpu_item), 1);
> - CpuInstanceProperties *cpu_props = g_new0(typeof(*cpu_props), 1);
>
> - cpu_item->type = spapr_get_cpu_core_type(machine->cpu_model);
> + cpu_item->type = g_strdup(cpu_type);
> cpu_item->vcpus_count = smp_threads;
> - cpu_props->has_core_id = true;
> - cpu_props->core_id = i * smp_threads;
> - /* TODO: add 'has_node/node' here to describe
> - to which node core belongs */
> + cpu_item->props = g_memdup(&machine->possible_cpus->cpus[i].props,
> + sizeof(*cpu_item->props));
>
> - cpu_item->props = cpu_props;
> - if (spapr->cores[i]) {
> + cpu = machine->possible_cpus->cpus[i].cpu;
> + if (cpu) {
> cpu_item->has_qom_path = true;
> - cpu_item->qom_path = object_get_canonical_path(spapr->cores[i]);
> + cpu_item->qom_path = object_get_canonical_path(cpu);
> }
> list_item->value = cpu_item;
> list_item->next = head;
> @@ -2872,6 +2922,7 @@ static void spapr_machine_class_init(ObjectClass *oc, void *data)
> hc->plug = spapr_machine_device_plug;
> hc->unplug = spapr_machine_device_unplug;
> mc->cpu_index_to_socket_id = spapr_cpu_index_to_socket_id;
> + mc->possible_cpu_arch_ids = spapr_possible_cpu_arch_ids;
> hc->unplug_request = spapr_machine_device_unplug_request;
>
> smc->dr_lmb_enabled = true;
--
David Gibson | I'll have my music baroque, and my code
david AT gibson.dropbear.id.au | minimalist, thank you. NOT _the_ _other_
| _way_ _around_!
http://www.ozlabs.org/~dgibson
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 819 bytes --]
next prev parent reply other threads:[~2017-02-24 13:10 UTC|newest]
Thread overview: 52+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-02-22 6:33 [Qemu-devel] [PULL 00/43] ppc-for-2.9 queue 20170222 David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 01/43] spapr: cpu core: separate child threads destruction from machine state operations David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 02/43] spapr: move spapr_core_[foo]plug() callbacks close to machine code in spapr.c David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 03/43] spapr: make cpu core unplug follow expected hotunplug call flow David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 04/43] ppc: implement xsrqpi[x] instruction David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 05/43] ppc: implement xsrqpxp instruction David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 06/43] ppc: implement xssqrtqp instruction David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 07/43] ppc: implement xssubqp instruction David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 08/43] hw/ppc/pnv: Remove superfluous "qemu" prefix from error strings David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 09/43] target-ppc: Add xsmaxcdp and xsmincdp instructions David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 10/43] target-ppc: Add xsmaxjdp and xsminjdp instructions David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 11/43] spapr: fix off-by-one error in spapr_ovec_populate_dt() David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 12/43] target-ppc: implement load atomic instruction David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 13/43] target-ppc: implement store " David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 14/43] target-ppc: generate exception for copy/paste David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 15/43] target-ppc: add slbieg instruction David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 16/43] target-ppc: add slbsync implementation David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 17/43] target-ppc: add wait instruction David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 18/43] target-ppc, tcg: fix usermode segfault with pthread_create() David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 19/43] mac99: replace debug printf with trace points David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 20/43] ppc4xx: " David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 21/43] spapr: " David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 22/43] softfloat: Add round-to-odd rounding mode David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 23/43] softfloat: Add float128_to_uint64_round_to_zero() David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 24/43] softfloat: Add float128_to_uint32_round_to_zero() David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 25/43] target-ppc: Implement round to odd variants of quad FP instructions David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 26/43] target-ppc: Add xscvqpudz and xscvqpuwz instructions David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 27/43] target/ppc: Fix LPCR DPFD mask define David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 28/43] target/ppc/POWER9: Add ISAv3.00 MMU definition David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 29/43] target/ppc/POWER9: Adapt LPCR handling for POWER9 David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 30/43] target/ppc/POWER9: Direct all instr and data storage interrupts to the hypv David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 31/43] hw/pci-host/prep: Do not use hw_error() in realize function David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 32/43] machine: move possible_cpus to MachineState David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 33/43] pc: move pcms->possible_cpus init out of pc_cpus_init() David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 34/43] pc: calculate topology only once when possible_cpus is initialised David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 35/43] pc: pass apic_id to pc_find_cpu_slot() directly so lookup could be done without CPU object David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 36/43] change CPUArchId.cpu type to Object* David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 37/43] spapr: reuse machine->possible_cpus instead of cores[] David Gibson
2017-02-22 11:05 ` [Qemu-devel] [PATCH " Igor Mammedov
2017-02-24 13:03 ` David Gibson [this message]
2017-02-24 13:29 ` Igor Mammedov
2017-02-26 22:46 ` David Gibson
2017-02-27 12:41 ` Igor Mammedov
2017-02-22 6:33 ` [Qemu-devel] [PULL 38/43] machine: unify [pc_|spapr_]query_hotpluggable_cpus() callbacks David Gibson
2017-02-22 11:07 ` [Qemu-devel] [PATCH " Igor Mammedov
2017-02-22 6:33 ` [Qemu-devel] [PULL 39/43] machine: replace query_hotpluggable_cpus() callback with has_hotpluggable_cpus flag David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 40/43] hw/net/spapr_llan: 6 byte mac address device tree entry David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 41/43] target-ppc: fix Book-E TLB matching David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 42/43] hw/ppc/spapr: Check for valid page size when hot plugging memory David Gibson
2017-02-22 6:33 ` [Qemu-devel] [PULL 43/43] hw/ppc/ppc405_uc.c: Avoid integer overflows David Gibson
2017-02-22 7:29 ` [Qemu-devel] [PULL 00/43] ppc-for-2.9 queue 20170222 no-reply
2017-02-24 12:47 ` Peter Maydell
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20170224130357.GF17615@umbus.fritz.box \
--to=david@gibson.dropbear.id.au \
--cc=agraf@suse.de \
--cc=imammedo@redhat.com \
--cc=lvivier@redhat.com \
--cc=mdroth@linux.vnet.ibm.com \
--cc=peter.maydell@linaro.org \
--cc=qemu-devel@nongnu.org \
--cc=qemu-ppc@nongnu.org \
--cc=thuth@redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).