Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp17160210ybl; Wed, 1 Jan 2020 23:28:15 -0800 (PST) X-Google-Smtp-Source: APXvYqwhKX70QIixGL7ixMSndkbTB3CM5t+BRwVrl+AOpedL7gVbudrLjEzUx5XhngqPEcfSiVXh X-Received: by 2002:a9d:67ce:: with SMTP id c14mr64616744otn.106.1577950095604; Wed, 01 Jan 2020 23:28:15 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1577950095; cv=none; d=google.com; s=arc-20160816; b=QOi3P2deGs6BA/hEXETsxdm6gudl5TNy/0piAbyHN7ld0GYC9H4DhxRxizNyHYYsPo 6pFBqN1EEm0cT9pemjX3mYGBcqCl8+Mdxd3LhBPkTdHs32rT1rGQGE1msEXwbOcgpIxH /mJdOUvGcOnA0LaqDHlGk8VKU9GCA4FLNhiSVZfe1jTTO0Dgf0wNxqTueQ0mnI0K9dI7 koyqgaOX6j54pU+y5q129ULLBXWsS8xgeyY/199DIttBWpx4bHE8FowP0D5kxOThyqzn O9JW7F+YGuMMtcx+hgzKVF12OaxLf9rT/vh+206uI+AeTL9qBcbTQKDvJiz1SXzzGyh0 VJSw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:subject:cc :to:from; bh=PzU3S7ZiEF5/e1rKcRK6U8v2AFR0pnmlTscP7hRO0+A=; b=Xeyx0xOvmDlV0Ou8Pum6pMqKS492hOW/7cSIUa19R6cEIojQd63JKTJPv7bVwdwOTK Vrjc9RD88i0tr10SyyAlgNHc8dg2nMorMCFPbr/he5CTr/iq8unxwdI20qjHLOCZS771 Mv0Yg08fVIE7+a1xCwRPmPpzx3MJ6r/8DoaEirjYdpWUb1a0zv3v1EcV+Wl5Sqnwoom4 +ohyryBZtfim+a/YI9g44GQ4sIZBE7oaKm5xzGD4BNrYr3+cd/KU+pBF2mTKysBrr3jd UEtjA3FRFYWf0DdQzyZBpXs5nwlO3dL6euHdcSHuKvAZqNSWMPPpS7DK873NP+nktL/V WvCg== 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 p22si28383185ota.43.2020.01.01.23.28.03; Wed, 01 Jan 2020 23:28:15 -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 S1727681AbgABH07 (ORCPT + 99 others); Thu, 2 Jan 2020 02:26:59 -0500 Received: from szxga05-in.huawei.com ([45.249.212.191]:8209 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726078AbgABH06 (ORCPT ); Thu, 2 Jan 2020 02:26:58 -0500 Received: from DGGEMS402-HUB.china.huawei.com (unknown [172.30.72.58]) by Forcepoint Email with ESMTP id D8213B520C4810FCD4B7; Thu, 2 Jan 2020 15:26:55 +0800 (CST) Received: from euler.huawei.com (10.175.104.193) by DGGEMS402-HUB.china.huawei.com (10.3.19.202) with Microsoft SMTP Server id 14.3.439.0; Thu, 2 Jan 2020 15:26:49 +0800 From: Wei Li To: , , , , , , , CC: , , , , Subject: [RFC PATCH] perf tools: cs-etm: fix endless record after being terminated Date: Thu, 2 Jan 2020 15:41:44 +0800 Message-ID: <20200102074144.10407-1-liwei391@huawei.com> X-Mailer: git-send-email 2.17.1 MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.175.104.193] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In __cmd_record(), when receiving SIGINT(ctrl + c), a done flag will be set and the event list will be disabled by evlist__disable() once. While in auxtrace_record.read_finish(), the related events will be enabled again, if they are continuous, the recording seems to be endless. If the cs_etm event is disabled, we don't enable it again here. Note: This patch is NOT tested since i don't have such a machine with coresight feature, but the code seems buggy same as arm-spe and intel-pt. Signed-off-by: Wei Li --- tools/perf/arch/arm/util/cs-etm.c | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/tools/perf/arch/arm/util/cs-etm.c b/tools/perf/arch/arm/util/cs-etm.c index ede040cf82ad..1893a0e3b1e1 100644 --- a/tools/perf/arch/arm/util/cs-etm.c +++ b/tools/perf/arch/arm/util/cs-etm.c @@ -865,9 +865,13 @@ static int cs_etm_read_finish(struct auxtrace_record *itr, int idx) struct evsel *evsel; evlist__for_each_entry(ptr->evlist, evsel) { - if (evsel->core.attr.type == ptr->cs_etm_pmu->type) - return perf_evlist__enable_event_idx(ptr->evlist, - evsel, idx); + if (evsel->core.attr.type == ptr->cs_etm_pmu->type) { + if (evsel->disabled) + return 0; + else + return perf_evlist__enable_event_idx( + ptr->evlist, evsel, idx); + } } return -EINVAL; -- 2.17.1