Received: by 2002:a05:6a10:d5a5:0:0:0:0 with SMTP id gn37csp2658317pxb; Fri, 8 Oct 2021 12:13:46 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwejLxlL3C3bpvzK+W65QgXle8gasy91gVI8z+0kBFXQTxER+QQMNyyB0pS7BpoDbYuPPEK X-Received: by 2002:a17:906:5ac7:: with SMTP id x7mr6709713ejs.42.1633720425979; Fri, 08 Oct 2021 12:13:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1633720425; cv=none; d=google.com; s=arc-20160816; b=pVF4+Ep0wcg1kSdeP2XDpm47On+v9LWB4iUiY9xFBgxbnyZbP4gLHryIvFvsefUxnH WbDoIp6e5TxBhqDwIsE7ZjEUs/OcgR4l8Fy9hP6HXJoYLljHgELE/c+JO4jqjYJM+V8R 8SeRyt4ChHTHDxekidO6ypr8HuAZr6Kk0/4TgJrMw5B9WUqgOIM7hKJaxEzs1FTJlh2l MG9LCgWs6s2BLKOGqoX+xrTLzPYO46vNN12oicrgtsoKajy1SbZie9NqZNE1EJ8YTiuJ EIOiAJb4sReK8h6KXCFBQD1Zh5uBgw5dqdElE1Aoj6+Em+SdQpc2Vzas+VxwTNpUpxon WSKg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=ldIzFUwtxnrZqKoupFUQTIbY3JR1sJkBUEh84q56PXY=; b=gEb1wwbs2us8+wDeO7oHoFizRqrs13TvfdvEG4QJVZ78OVmDrZXE5Oboc3P2iHLsKI tT2PVKHGpTh1uI0z6/xmnBhphn789noHPQMc0wHRVApyrQRxt4XOikR+kkAni1ALGa0s yVQJKg4O+n2zhef/qLVJEvpWvKSN3jL0RdLNTshFCY7pIuIUHr6Iou+nZPV0FymoZt2J If2OtIb0RzsTvethbzD4MiggiwwqZ3I9/4hKSFZr9V2hviqL2ED+pCjtS0rk/DjtwuaX yRvgWjXmVL6ZEQX9aylesiKjurCMc6eRvUPHwAKtfVeKfhk/EflwCfFMJwOcmPpLqMdk Qekw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=EYJZNWZs; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b11si177485edk.586.2021.10.08.12.13.21; Fri, 08 Oct 2021 12:13:45 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=EYJZNWZs; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240320AbhJHTN4 (ORCPT + 99 others); Fri, 8 Oct 2021 15:13:56 -0400 Received: from mail.kernel.org ([198.145.29.99]:51908 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231342AbhJHTNz (ORCPT ); Fri, 8 Oct 2021 15:13:55 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 6ECDD60F4F; Fri, 8 Oct 2021 19:11:59 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1633720319; bh=7mZMBOTiR9t6hATvGff5yzuCPWoz+H/q3mYoiQ5Cj+g=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=EYJZNWZsl4SPabnCRBKQywUhLz6FyLBnSmBpTTUYkVuwo7e2cHSsAJzwfm4HwEc2z ZXDJh1wq5wzwl+lQ88/DpPqmh0OF3H6JfWCQrl40GE38sJ6LpttnmTNZaKqp3V6XMH Vd953amFZRlR8e6NKnxbHy/TXeUlqMSr8oqPHZseeCcHOMsvr8bXrdV4cMMU6d0rrv cYd1tDgzKCcS690gp7xZjtQhDFX5Tt+O257HgCuAkwZZbV99f+FpgB60YXD+HpiAMW 7pRx64VubnjW595jTJAKTlY6x16MBPnSxANM6M7rBSTBT2mOxIxYDANwA9r+ZIAfVZ 6wqfUuJJDsXPQ== Received: by quaco.ghostprotocols.net (Postfix, from userid 1000) id CC96E410A1; Fri, 8 Oct 2021 16:11:56 -0300 (-03) Date: Fri, 8 Oct 2021 16:11:56 -0300 From: Arnaldo Carvalho de Melo To: Shunsuke Nakamura Cc: Rob Herring , peterz@infradead.org, mingo@redhat.com, mark.rutland@arm.com, alexander.shishkin@linux.intel.com, jolsa@redhat.com, namhyung@kernel.org, linux-kernel@vger.kernel.org, linux-perf-users@vger.kernel.org Subject: Re: [PATCH v2 2/2] libperf tests: Add test_stat_multiplexing test Message-ID: References: <20210922101627.3396398-1-nakamura.shun@fujitsu.com> <20210922101627.3396398-3-nakamura.shun@fujitsu.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20210922101627.3396398-3-nakamura.shun@fujitsu.com> X-Url: http://acmel.wordpress.com Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Em Wed, Sep 22, 2021 at 07:16:27PM +0900, Shunsuke Nakamura escreveu: > From: nakamura shunsuke > > Adds a test for a counter obtained using read() system call during multiplexing You forgot to add Rob to the CC list, can I have Acked-by or Reviewed-by? Thanks, - Arnaldo > Committer testing: > > $ sudo make tests -C tools/lib/perf/ V=1 > make: Entering directory '/home/nakamura/build_work/build_kernel/linux_kernel/linux/tools/lib/perf' > make -f /home/nakamura/build_work/build_kernel/linux_kernel/linux/tools/build/Makefile.build dir=. obj=libperf > make -C /home/nakamura/build_work/build_kernel/linux_kernel/linux/tools/lib/api/ O= libapi.a > make -f /home/nakamura/build_work/build_kernel/linux_kernel/linux/tools/build/Makefile.build dir=./fd obj=libapi > make -f /home/nakamura/build_work/build_kernel/linux_kernel/linux/tools/build/Makefile.build dir=./fs obj=libapi > make -f /home/nakamura/build_work/build_kernel/linux_kernel/linux/tools/build/Makefile.build dir=. obj=tests > make -f /home/nakamura/build_work/build_kernel/linux_kernel/linux/tools/build/Makefile.build dir=./tests obj=tests > running static: > - running tests/test-cpumap.c...OK > - running tests/test-threadmap.c...OK > - running tests/test-evlist.c... > count = 502273264, run = 264105562, enable = 444092845 > count = 501850699, run = 264100505, enable = 444088400 > count = 499613780, run = 264096660, enable = 444085073 > count = 499569398, run = 264501528, enable = 444081268 > count = 500717228, run = 265495387, enable = 444077029 > count = 501260539, run = 266488226, enable = 444071569 > count = 501023910, run = 267469613, enable = 444065303 > count = 501188267, run = 268461294, enable = 444058413 > count = 503096683, run = 269450511, enable = 444050567 > count = 503141904, run = 269587790, enable = 444041735 > count = 503454490, run = 268590361, enable = 444030544 > count = 504838207, run = 267592624, enable = 444021005 > count = 505458594, run = 266594648, enable = 444001280 > count = 504269433, run = 265595795, enable = 443991377 > count = 502625858, run = 264599374, enable = 443982141 > Expected: 502065774 > High: 505458594 Low: 499569398 Average: 502292150 > Average Error = 0.05% > count = 26129, run = 134550, enable = 134550 > count = 34035, run = 140540, enable = 140540 > count = 40189, run = 141126, enable = 141126 > count = 45263, run = 138290, enable = 138290 > count = 51381, run = 136966, enable = 136966 > count = 57499, run = 134993, enable = 134993 > count = 63617, run = 132320, enable = 132320 > count = 71714, run = 132047, enable = 132047 > count = 77832, run = 128157, enable = 128157 > count = 0, run = 0, enable = 123662 > count = 0, run = 0, enable = 116753 > count = 0, run = 0, enable = 110304 > count = 0, run = 0, enable = 103834 > count = 0, run = 0, enable = 97465 > count = 0, run = 0, enable = 91110 > OK > - running tests/test-evsel.c... > loop = 65536, count = 334303 > loop = 131072, count = 656954 > loop = 262144, count = 1321090 > loop = 524288, count = 2652616 > loop = 1048576, count = 5262140 > loop = 65536, count = 393726 > loop = 131072, count = 989345 > loop = 262144, count = 1986206 > loop = 524288, count = 3831652 > loop = 1048576, count = 7747957 > OK > running dynamic: > - running tests/test-cpumap.c...OK > - running tests/test-threadmap.c...OK > - running tests/test-evlist.c... > count = 501975838, run = 247092568, enable = 415093723 > count = 502491858, run = 247087145, enable = 415088830 > count = 502571026, run = 247083574, enable = 415085139 > count = 502743767, run = 247080183, enable = 415081197 > count = 503259008, run = 247779561, enable = 415076990 > count = 503169622, run = 248773141, enable = 415072091 > count = 503430373, run = 249816445, enable = 415066529 > count = 502597951, run = 250808797, enable = 415059863 > count = 502211776, run = 251799199, enable = 415051831 > count = 501921896, run = 252000721, enable = 415042717 > count = 501441904, run = 251309399, enable = 415031152 > count = 501224474, run = 250311107, enable = 415021479 > count = 500502827, run = 249260579, enable = 415012168 > count = 500775622, run = 248259621, enable = 415002830 > count = 501377375, run = 247261134, enable = 414993890 > Expected: 501953755 > High: 503430373 Low: 500502827 Average: 502113021 > Average Error = 0.03% > count = 26098, run = 131826, enable = 131826 > count = 33689, run = 138284, enable = 138284 > count = 39808, run = 139152, enable = 139152 > count = 45927, run = 138880, enable = 138880 > count = 51049, run = 135405, enable = 135405 > count = 57168, run = 133406, enable = 133406 > count = 63287, run = 130736, enable = 130736 > count = 71392, run = 130474, enable = 130474 > count = 77794, run = 127203, enable = 127203 > count = 0, run = 0, enable = 123172 > count = 0, run = 0, enable = 116856 > count = 0, run = 0, enable = 110557 > count = 0, run = 0, enable = 104282 > count = 0, run = 0, enable = 97929 > count = 0, run = 0, enable = 91792 > OK > - running tests/test-evsel.c... > loop = 65536, count = 334400 > loop = 131072, count = 656908 > loop = 262144, count = 1315441 > loop = 524288, count = 2657481 > loop = 1048576, count = 5258193 > loop = 65536, count = 491938 > loop = 131072, count = 965755 > loop = 262144, count = 1666277 > loop = 524288, count = 3516123 > loop = 1048576, count = 6759204 > OK > make: Leaving directory '/home/nakamura/build_work/build_kernel/linux_kernel/linux/tools/lib/perf' > > > Signed-off-by: Shunsuke Nakamura > --- > tools/lib/perf/tests/test-evlist.c | 183 +++++++++++++++++++++++++++++ > 1 file changed, 183 insertions(+) > > diff --git a/tools/lib/perf/tests/test-evlist.c b/tools/lib/perf/tests/test-evlist.c > index c67c83399170..ca7a9542f40e 100644 > --- a/tools/lib/perf/tests/test-evlist.c > +++ b/tools/lib/perf/tests/test-evlist.c > @@ -21,6 +21,10 @@ > #include "tests.h" > #include > > +#define EVENT_NUM 15 > +#define WAIT_COUNT 100000000UL > + > + > static int libperf_print(enum libperf_print_level level, > const char *fmt, va_list ap) > { > @@ -413,6 +417,184 @@ static int test_mmap_cpus(void) > return 0; > } > > +static double display_error(long long average, > + long long high, > + long long low, > + long long expected) { > + > + double error; > + > + error = (((double)average - expected) / expected) * 100.0; > + > + __T_VERBOSE(" Expected: %lld\n", expected); > + __T_VERBOSE(" High: %lld Low: %lld Average: %lld\n", > + high, low, average); > + > + __T_VERBOSE(" Average Error = %.2f%%\n",error); > + > + return error; > + > +} > + > +static int test_stat_multiplexing(void) > +{ > + struct perf_counts_values expected_counts = { .val = 0 }; > + struct perf_counts_values multiplexing_counts[EVENT_NUM] = {{ .val = 0 },}; > + struct perf_thread_map *threads; > + struct perf_evlist *evlist; > + struct perf_evsel *evsel; > + struct perf_event_attr attr = { > + .type = PERF_TYPE_HARDWARE, > + .config = PERF_COUNT_HW_INSTRUCTIONS, > + .read_format = PERF_FORMAT_TOTAL_TIME_ENABLED | > + PERF_FORMAT_TOTAL_TIME_RUNNING, > + .disabled = 1, > + }; > + int err, i, nonzero=0; > + unsigned long count; > + long long max = 0, min = 0, avg = 0; > + double error = 0.0; > + > + > + /* read for non-multiplexing event count */ > + threads = perf_thread_map__new_dummy(); > + __T("failed to create threads", threads); > + > + perf_thread_map__set_pid(threads, 0, 0); > + > + evsel = perf_evsel__new(&attr); > + __T("failed to create evsel", evsel); > + > + err = perf_evsel__open(evsel, NULL, threads); > + __T("failed to open evsel", err == 0); > + > + err = perf_evsel__enable(evsel); > + __T("failed to enable evsel", err == 0); > + > + /* wait loop */ > + count = WAIT_COUNT; > + while(count--); > + > + perf_evsel__read(evsel, 0, 0, &expected_counts); > + __T("failed to read value for evsel", expected_counts.val != 0); > + __T("failed to read non-multiplexing event count", > + expected_counts.ena == expected_counts.run); > + > + err = perf_evsel__disable(evsel); > + __T("failed to enable evsel", err == 0); > + > + perf_evsel__close(evsel); > + perf_evsel__delete(evsel); > + > + perf_thread_map__put(threads); > + > + > + /* read for multiplexing event count */ > + threads = perf_thread_map__new_dummy(); > + __T("failed to create threads", threads); > + > + perf_thread_map__set_pid(threads, 0, 0); > + > + evlist = perf_evlist__new(); > + __T("failed to create evlist", evlist); > + > + for (i = 0; i < EVENT_NUM; i++) { > + evsel = perf_evsel__new(&attr); > + __T("failed to create evsel1", evsel); > + > + perf_evlist__add(evlist, evsel); > + } > + perf_evlist__set_maps(evlist, NULL, threads); > + > + err = perf_evlist__open(evlist); > + __T("failed to open evsel", err == 0); > + > + perf_evlist__enable(evlist); > + > + /* wait loop */ > + count = WAIT_COUNT; > + while(count--); > + > + i = 0; > + perf_evlist__for_each_evsel(evlist, evsel) { > + perf_evsel__read(evsel, 0, 0, &multiplexing_counts[i]); > + __T("failed to read value for evsel", multiplexing_counts[i].val != 0); > + i++; > + } > + > + perf_evlist__disable(evlist); > + > + > + min = multiplexing_counts[0].val; > + for (i = 0; i < EVENT_NUM; i++) { > + __T_VERBOSE("\tcount = %lu, run = %lu, enable = %lu\n", > + multiplexing_counts[i].val, multiplexing_counts[i].run, > + multiplexing_counts[i].ena); > + > + if (multiplexing_counts[i].val > max) > + max = multiplexing_counts[i].val; > + > + if (multiplexing_counts[i].val < min) > + min = multiplexing_counts[i].val; > + > + avg += multiplexing_counts[i].val; > + > + if (multiplexing_counts[i].val != 0) > + nonzero++; > + } > + > + avg = avg / nonzero; > + > + error = display_error(avg, max, min, expected_counts.val); > + > + __T("Error out of range!", ((error <= 1.0) && (error >= -1.0))); > + > + perf_evlist__close(evlist); > + perf_evlist__delete(evlist); > + > + perf_thread_map__put(threads); > + > + > + /* Verify that no division by zero occurs */ > + threads = perf_thread_map__new_dummy(); > + __T("failed to create threads", threads); > + > + perf_thread_map__set_pid(threads, 0, 0); > + > + evlist = perf_evlist__new(); > + __T("failed to create evlist", evlist); > + > + for (i = 0; i < EVENT_NUM; i++) { > + evsel = perf_evsel__new(&attr); > + __T("failed to create evsel1", evsel); > + > + perf_evlist__add(evlist, evsel); > + } > + perf_evlist__set_maps(evlist, NULL, threads); > + > + err = perf_evlist__open(evlist); > + __T("failed to open evsel", err == 0); > + > + perf_evlist__enable(evlist); > + > + /* Reproduce run=0 by not executing wait loop. */ > + > + i = 0; > + perf_evlist__for_each_evsel(evlist, evsel) { > + perf_evsel__read(evsel, 0, 0, &multiplexing_counts[i]); > + __T_VERBOSE("\tcount = %lu, run = %lu, enable = %lu\n", > + multiplexing_counts[i].val, multiplexing_counts[i].run, > + multiplexing_counts[i].ena); > + i++; > + } > + > + perf_evlist__close(evlist); > + perf_evlist__delete(evlist); > + > + perf_thread_map__put(threads); > + return 0; > +} > + > int test_evlist(int argc, char **argv) > { > __T_START; > @@ -424,6 +606,7 @@ int test_evlist(int argc, char **argv) > test_stat_thread_enable(); > test_mmap_thread(); > test_mmap_cpus(); > + test_stat_multiplexing(); > > __T_END; > return tests_failed == 0 ? 0 : -1; > -- > 2.27.0 -- - Arnaldo