Received: by 2002:a25:d7c1:0:0:0:0:0 with SMTP id o184csp4918582ybg; Mon, 21 Oct 2019 17:04:25 -0700 (PDT) X-Google-Smtp-Source: APXvYqwYqZCB4GhMI0XN+1AKM4UHqvEBRBOytXL5X+kwO/Gf+watfGj98bz0sFb2uT3LF/fl1tP/ X-Received: by 2002:a50:d70c:: with SMTP id t12mr27970917edi.252.1571702665500; Mon, 21 Oct 2019 17:04:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1571702665; cv=none; d=google.com; s=arc-20160816; b=Is77lm2eHFteiVtq+WNLtME53PicVwWVedOCUMI7DTL0/Yy5E6ptD8ii2u/vJ0wuBA 1Q5HAIJ52CZ0YWnyx6NtRAFzMWwaAog+6IPXU71WjiLt9PzrznktVh2VM4wgPdyEWx7u 8A927uQ+s/0FWR3kTA6TH8rq4Mk6yhdNyUg3L7akDCIjLmjT3tzuLBdtaymbqW2fHe2p XAnD/V6g9VHh60aGFABzwkVhfNeWKcJton+7StcVGYexcxDz1JJZ3mu4Ai2KvaAxxFuG jmwzAVfBTboWiFaysLCnbv9CHMGssNtFM53PtR1HD5k/WvH1X8G8KnCoLjOXsBdw5tUo XcFg== 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 :robot-unsubscribe:robot-id:message-id:mime-version:references :in-reply-to:cc:subject:to:reply-to:from:date; bh=QUOu9B5mZF5ou5jMG9FVmQRRGd7LXTkMkQ+AQelY730=; b=T00Xt9wv12jSuUOvUc6ynz+EO5B7ktrRJNNFS1i6yy4dS6JMieZu310sKaNJO03P7D fY3P96Ng43Z2b59XsW98eH7vvFtpRdDYtj04Nyjl2LKod0uqVzLmhC4IX9BSs1ef4C+R NUZlrC6/CL0nHytl8X6w9PoK4Op84pCEcJMTiRnu8mGLtX302OYRT3afYGScxcyYjo9f q9HR7vFasHONapJ9dqsRuY9pgQdksxFcVUbb/F2vqGbG8muOlFFVI3LXdtgv8QbiLvoE ndhLdab0dPVfmcJR4b1cVyGxBAFBSiLbnaqUdmAthf/tWYSD/kpb6IXoU1uYp4pAqt2w KLOA== 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 e14si10631021eda.104.2019.10.21.17.04.00; Mon, 21 Oct 2019 17:04:25 -0700 (PDT) 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 S1730563AbfJVADp (ORCPT + 99 others); Mon, 21 Oct 2019 20:03:45 -0400 Received: from Galois.linutronix.de ([193.142.43.55]:38895 "EHLO Galois.linutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728375AbfJVADm (ORCPT ); Mon, 21 Oct 2019 20:03:42 -0400 Received: from [5.158.153.53] (helo=tip-bot2.lab.linutronix.de) by Galois.linutronix.de with esmtpsa (TLS1.2:DHE_RSA_AES_256_CBC_SHA256:256) (Exim 4.80) (envelope-from ) id 1iMgxT-0004G9-5V; Tue, 22 Oct 2019 01:19:27 +0200 Received: from [127.0.1.1] (localhost [IPv6:::1]) by tip-bot2.lab.linutronix.de (Postfix) with ESMTP id D596F1C0489; Tue, 22 Oct 2019 01:19:18 +0200 (CEST) Date: Mon, 21 Oct 2019 23:19:18 -0000 From: "tip-bot2 for Leo Yan" Reply-to: linux-kernel@vger.kernel.org To: linux-tip-commits@vger.kernel.org Subject: [tip: perf/core] perf test: Avoid infinite loop for task exit case Cc: Leo Yan , Alexander Shishkin , Jiri Olsa , Mark Rutland , Namhyung Kim , Arnaldo Carvalho de Melo , Ingo Molnar , Borislav Petkov , linux-kernel@vger.kernel.org In-Reply-To: <20191011091942.29841-2-leo.yan@linaro.org> References: <20191011091942.29841-2-leo.yan@linaro.org> MIME-Version: 1.0 Message-ID: <157169995839.29376.12083653777021293473.tip-bot2@tip-bot2> X-Mailer: tip-git-log-daemon Robot-ID: Robot-Unsubscribe: Contact to get blacklisted from these emails Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-Linutronix-Spam-Score: -1.0 X-Linutronix-Spam-Level: - X-Linutronix-Spam-Status: No , -1.0 points, 5.0 required, ALL_TRUSTED=-1,SHORTCIRCUIT=-0.0001 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The following commit has been merged into the perf/core branch of tip: Commit-ID: 791ce9c48c79210d2ffcdbe69421e7783b32921f Gitweb: https://git.kernel.org/tip/791ce9c48c79210d2ffcdbe69421e7783b32921f Author: Leo Yan AuthorDate: Fri, 11 Oct 2019 17:19:42 +08:00 Committer: Arnaldo Carvalho de Melo CommitterDate: Tue, 15 Oct 2019 08:36:22 -03:00 perf test: Avoid infinite loop for task exit case When executing the task exit testing case, perf gets stuck in an endless loop this case and doesn't return back on Arm64 Juno board. After digging into this issue, since Juno board has Arm's big.LITTLE CPUs, thus the PMUs are not compatible between the big CPUs and little CPUs. This leads to a PMU event that cannot be enabled properly when the traced task is migrated from one variant's CPU to another variant. Finally, the test case runs into infinite loop for cannot read out any event data after return from polling. Eventually, we need to work out formal solution to allow PMU events can be freely migrated from one CPU variant to another, but this is a difficult task and a different topic. This patch tries to fix the Perf test case to avoid infinite loop, when the testing detects 1000 times retrying for reading empty events, it will directly bail out and return failure. This allows the Perf tool can continue its other test cases. Signed-off-by: Leo Yan Cc: Alexander Shishkin Cc: Jiri Olsa Cc: Mark Rutland Cc: Namhyung Kim Link: http://lore.kernel.org/lkml/20191011091942.29841-2-leo.yan@linaro.org Signed-off-by: Arnaldo Carvalho de Melo --- tools/perf/tests/task-exit.c | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/tools/perf/tests/task-exit.c b/tools/perf/tests/task-exit.c index 19fa7cb..adaff90 100644 --- a/tools/perf/tests/task-exit.c +++ b/tools/perf/tests/task-exit.c @@ -54,6 +54,7 @@ int test__task_exit(struct test *test __maybe_unused, int subtest __maybe_unused struct perf_cpu_map *cpus; struct perf_thread_map *threads; struct mmap *md; + int retry_count = 0; signal(SIGCHLD, sig_handler); @@ -133,6 +134,13 @@ retry: out_init: if (!exited || !nr_exit) { evlist__poll(evlist, -1); + + if (retry_count++ > 1000) { + pr_debug("Failed after retrying 1000 times\n"); + err = -1; + goto out_free_maps; + } + goto retry; }