Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp2542521ybc; Wed, 20 Nov 2019 16:20:10 -0800 (PST) X-Google-Smtp-Source: APXvYqx5SWHNKMasRsmebtuOGecrZuVxp3N15R+Z0aHEYTlsUhkypmZ5hDWgnUIkOoRbxid1DAlZ X-Received: by 2002:a17:906:bce5:: with SMTP id op5mr9291897ejb.325.1574295610374; Wed, 20 Nov 2019 16:20:10 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574295610; cv=none; d=google.com; s=arc-20160816; b=luxQNp4KAoARJ7aUDJNOdkL2IeiAI2H8dz+BNeDqIUSN6oY1jurnlCwM30CYMgKjj3 nqwUubpVXzzLfRa4AAX0fX1/201NOXw9kpLCVDyTeBmKNfps8emOVQ0o3J8XUcBAoscQ QhKGkPbi//oOByZF8dYEsyEZ7PgfmjB4OkUwX3IU8YpBvgDwRnKzggAhRzl0OMU/JrFM XuV7uK1hKH4DIUTMKei8jVOew1+YN0f0Lr7Cf8uDoaPgaS1o0sfXvLAScXwl+zPretP8 3YlneoLOavjPS0I1/ntH7MmyW843UkjPTolGvjq8a7GQMPLU0/ZADOlkw5smzCVAqMZh 910A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=tVHQUCE/iBCXYv8wPcRUK7GeNs8ZdDBflh9DwN2F4mE=; b=xMevMZkhHFw9Wx2AWok+pQzHFrEKkZqjcoieP4eU328dA9pYT1Dy2ja7HeSo/Nmpcl LNgqGckWAWnYbOJAjnhHxvJbVceUaamS0UkCto7qEeRyAA/gDBvULRKq8HEn4Po4A20C U9Osor4lwYS/zjKUtQqLvhJIEa0eYqXbFwaC00tCAHCGJVZQj0+i0Zx9Ar/MpmdveNhq I+gaw+tasGVlJrIkQat+oCcCxtPFlLqNBs+rIyXZ4YyxtLUntcPm6XDosNyKXY+EqM2m BnMfONGqmI+rhMOyEmCW8lB2TxO1qexRTtvt0v+MQ3o3L3YM+GS/vq4062iMsvbe1ImZ PCxg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l20si526646ejx.389.2019.11.20.16.19.45; Wed, 20 Nov 2019 16:20:10 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726985AbfKUAPf (ORCPT + 99 others); Wed, 20 Nov 2019 19:15:35 -0500 Received: from mga04.intel.com ([192.55.52.120]:65026 "EHLO mga04.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726912AbfKUAPf (ORCPT ); Wed, 20 Nov 2019 19:15:35 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga008.jf.intel.com ([10.7.209.65]) by fmsmga104.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 20 Nov 2019 16:15:34 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.69,223,1571727600"; d="scan'208";a="200927573" Received: from tassilo.jf.intel.com (HELO tassilo.localdomain) ([10.7.201.21]) by orsmga008.jf.intel.com with ESMTP; 20 Nov 2019 16:15:34 -0800 Received: by tassilo.localdomain (Postfix, from userid 1000) id 8CB41300B64; Wed, 20 Nov 2019 16:15:34 -0800 (PST) From: Andi Kleen To: acme@kernel.org Cc: jolsa@kernel.org, linux-kernel@vger.kernel.org, Andi Kleen Subject: [PATCH 03/12] perf cpumap: Maintain cpumaps ordered and without dups Date: Wed, 20 Nov 2019 16:15:13 -0800 Message-Id: <20191121001522.180827-4-andi@firstfloor.org> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20191121001522.180827-1-andi@firstfloor.org> References: <20191121001522.180827-1-andi@firstfloor.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Andi Kleen Enforce this in _trim() Needed for followon change. Signed-off-by: Andi Kleen --- tools/perf/lib/cpumap.c | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/tools/perf/lib/cpumap.c b/tools/perf/lib/cpumap.c index 2ca1fafa620d..d81656b4635e 100644 --- a/tools/perf/lib/cpumap.c +++ b/tools/perf/lib/cpumap.c @@ -68,14 +68,28 @@ static struct perf_cpu_map *cpu_map__default_new(void) return cpus; } +static int cmp_int(const void *a, const void *b) +{ + return *(const int *)a - *(const int*)b; +} + static struct perf_cpu_map *cpu_map__trim_new(int nr_cpus, int *tmp_cpus) { size_t payload_size = nr_cpus * sizeof(int); struct perf_cpu_map *cpus = malloc(sizeof(*cpus) + payload_size); + int i, j; if (cpus != NULL) { - cpus->nr = nr_cpus; memcpy(cpus->map, tmp_cpus, payload_size); + qsort(cpus->map, nr_cpus, sizeof(int), cmp_int); + /* Remove dups */ + j = 0; + for (i = 0; i < nr_cpus; i++) { + if (i == 0 || cpus->map[i] != cpus->map[i - 1]) + cpus->map[j++] = cpus->map[i]; + } + cpus->nr = j; + assert(j <= nr_cpus); refcount_set(&cpus->refcnt, 1); } -- 2.23.0