On Wed, Mar 22, 2017 at 02:32:45PM +0100, Igor Mammedov wrote: > and remove corresponding part in numa.c that uses > node_cpu bitmaps. > > Signed-off-by: Igor Mammedov Reviewed-by: David Gibson > --- > It's one more less user of node_cpu bitmpas, following > commit will remove the last user along with > node_cpu itself. > --- > hw/core/machine.c | 58 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ > numa.c | 10 ---------- > 2 files changed, 58 insertions(+), 10 deletions(-) > > diff --git a/hw/core/machine.c b/hw/core/machine.c > index d284a63..ab51d2c 100644 > --- a/hw/core/machine.c > +++ b/hw/core/machine.c > @@ -19,6 +19,7 @@ > #include "sysemu/sysemu.h" > #include "qemu/error-report.h" > #include "qemu/cutils.h" > +#include "sysemu/numa.h" > > static char *machine_get_accel(Object *obj, Error **errp) > { > @@ -643,9 +644,66 @@ bool machine_mem_merge(MachineState *machine) > return machine->mem_merge; > } > > +static char *cpu_slot_to_string(const CPUArchId *cpu) > +{ > + GString *s = g_string_new(NULL); > + if (cpu->props.has_socket_id) { > + g_string_append_printf(s, "socket-id: %"PRId64, cpu->props.socket_id); > + } > + if (cpu->props.has_core_id) { > + if (s->len) { > + g_string_append_printf(s, ", "); > + } > + g_string_append_printf(s, "core-id: %"PRId64, cpu->props.core_id); > + } > + if (cpu->props.has_thread_id) { > + if (s->len) { > + g_string_append_printf(s, ", "); > + } > + g_string_append_printf(s, "thread-id: %"PRId64, cpu->props.thread_id); > + } > + return g_string_free(s, false); > +} > + > +static void machine_numa_validate(MachineState *machine) > +{ > + int i; > + GString *s = g_string_new(NULL); > + MachineClass *mc = MACHINE_GET_CLASS(machine); > + const CPUArchIdList *possible_cpus = mc->possible_cpu_arch_ids(machine); > + > + assert(nb_numa_nodes); > + for (i = 0; i < possible_cpus->len; i++) { > + const CPUArchId *cpu_slot = &possible_cpus->cpus[i]; > + > + /* at this point numa mappings are initilized by CLI options > + * or with default mappings so it's sufficient to list > + * all not yet mapped CPUs here */ > + /* TODO: make it hard error in future */ > + if (!cpu_slot->props.has_node_id) { > + char *cpu_str = cpu_slot_to_string(cpu_slot); > + g_string_append_printf(s, "%sCPU %d [%s]", s->len ? ", " : "", i, > + cpu_str); > + g_free(cpu_str); > + } > + } > + if (s->len) { > + error_report("warning: CPU(s) not present in any NUMA nodes: %s", > + s->str); > + error_report("warning: All CPU(s) up to maxcpus should be described " > + "in NUMA config, ability to start up with partial NUMA " > + "mappings is obsoleted and will be removed in future"); > + } > + g_string_free(s, true); > +} > + > void machine_run_board_init(MachineState *machine) > { > MachineClass *machine_class = MACHINE_GET_CLASS(machine); > + > + if (nb_numa_nodes) { > + machine_numa_validate(machine); > + } > machine_class->init(machine); > } > > diff --git a/numa.c b/numa.c > index 8461c96..523558f 100644 > --- a/numa.c > +++ b/numa.c > @@ -293,16 +293,6 @@ static void validate_numa_cpus(void) > bitmap_or(seen_cpus, seen_cpus, > numa_info[i].node_cpu, max_cpus); > } > - > - if (!bitmap_full(seen_cpus, max_cpus)) { > - char *msg; > - bitmap_complement(seen_cpus, seen_cpus, max_cpus); > - msg = enumerate_cpus(seen_cpus, max_cpus); > - error_report("warning: CPU(s) not present in any NUMA nodes: %s", msg); > - error_report("warning: All CPU(s) up to maxcpus should be described " > - "in NUMA config"); > - g_free(msg); > - } > g_free(seen_cpus); > } > -- 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