[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-arm] [PATCH v2 11/24] numa: do default mapping based on possib
From: |
Andrew Jones |
Subject: |
Re: [Qemu-arm] [PATCH v2 11/24] numa: do default mapping based on possible_cpus instead of node_cpu bitmaps |
Date: |
Thu, 4 May 2017 13:45:28 +0200 |
User-agent: |
Mutt/1.6.0.1 (2016-04-01) |
On Wed, May 03, 2017 at 02:57:05PM +0200, Igor Mammedov wrote:
> Signed-off-by: Igor Mammedov <address@hidden>
> Reviewed-by: David Gibson <address@hidden>
> ---
> numa.c | 19 ++++++++++++-------
> 1 file changed, 12 insertions(+), 7 deletions(-)
>
> diff --git a/numa.c b/numa.c
> index 5ff1212..c7e3e0a 100644
> --- a/numa.c
> +++ b/numa.c
> @@ -309,6 +309,7 @@ static void validate_numa_cpus(void)
> void parse_numa_opts(MachineState *ms)
> {
> int i;
> + const CPUArchIdList *possible_cpus;
> MachineClass *mc = MACHINE_GET_CLASS(ms);
>
> for (i = 0; i < MAX_NODES; i++) {
> @@ -379,11 +380,6 @@ void parse_numa_opts(MachineState *ms)
>
> numa_set_mem_ranges();
>
> - for (i = 0; i < nb_numa_nodes; i++) {
> - if (!bitmap_empty(numa_info[i].node_cpu, max_cpus)) {
> - break;
> - }
> - }
> /* Historically VCPUs were assigned in round-robin order to NUMA
> * nodes. However it causes issues with guest not handling it nice
> * in case where cores/threads from a multicore CPU appear on
> @@ -391,11 +387,20 @@ void parse_numa_opts(MachineState *ms)
> * rule grouping VCPUs by socket so that VCPUs from the same socket
> * would be on the same node.
> */
> - if (!mc->cpu_index_to_instance_props) {
> + if (!mc->cpu_index_to_instance_props || !mc->possible_cpu_arch_ids) {
> error_report("default CPUs to NUMA node mapping isn't
> supported");
> exit(1);
> }
> - if (i == nb_numa_nodes) {
> +
> + possible_cpus = mc->possible_cpu_arch_ids(ms);
> + for (i = 0; i < possible_cpus->len; i++) {
> + if (possible_cpus->cpus[i].props.has_node_id) {
> + break;
> + }
> + }
> +
> + /* no CPUs are assigned to NUMA nodes */
> + if (i == possible_cpus->len) {
> for (i = 0; i < max_cpus; i++) {
> CpuInstanceProperties props;
> /* fetch default mapping from board and enable it */
> --
> 2.7.4
>
Reviewed-by: Andrew Jones <address@hidden>
- Re: [Qemu-arm] [PATCH v2 10/24] numa: mirror cpu to node mapping in MachineState::possible_cpus, (continued)
Re: [Qemu-arm] [PATCH v2 10/24] numa: mirror cpu to node mapping in MachineState::possible_cpus, Andrew Jones, 2017/05/04
[Qemu-arm] [PATCH v2 11/24] numa: do default mapping based on possible_cpus instead of node_cpu bitmaps, Igor Mammedov, 2017/05/03
- Re: [Qemu-arm] [PATCH v2 11/24] numa: do default mapping based on possible_cpus instead of node_cpu bitmaps,
Andrew Jones <=
[Qemu-arm] [PATCH v2 13/24] pc: get numa node mapping from possible_cpus instead of numa_get_node_for_cpu(), Igor Mammedov, 2017/05/03
[Qemu-arm] [PATCH v2 14/24] spapr: get numa node mapping from possible_cpus instead of numa_get_node_for_cpu(), Igor Mammedov, 2017/05/03
[Qemu-arm] [PATCH v2 15/24] virt-arm: get numa node mapping from possible_cpus instead of numa_get_node_for_cpu(), Igor Mammedov, 2017/05/03
[Qemu-arm] [PATCH v2 12/24] numa: add numa_[has_]node_id() wrappers, Igor Mammedov, 2017/05/03