Received: by 10.223.185.116 with SMTP id b49csp1704774wrg; Sat, 17 Feb 2018 03:35:35 -0800 (PST) X-Google-Smtp-Source: AH8x2248mYQ7WJcOqzcfJfSvt5oqJdRe4NiIGPK3E07pHLaG672NLrgTzGv539Ww5/XL/0gRO/i7 X-Received: by 10.98.12.144 with SMTP id 16mr8924103pfm.147.1518867335739; Sat, 17 Feb 2018 03:35:35 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1518867335; cv=none; d=google.com; s=arc-20160816; b=laEcy5VouprWOpCNPSETp1c8t76HiTunuCj1OhMD9vVC9FPo6vhjpzQezQZcYOfhHp L+biUw12V6qEAZI3j+2T6DZMOcajYekPN1H/ct10pnl+mmiHGf157Yksx6ojtJzgstKK 0rdWQrhdswoiDRJxQtQO2EojBkOJut/ap7Bi5TCu5X1Jl9LBwmhX20WrdAJdwnyyZ/FT YGs9ZqhELh7uRM3QGCL8Q3WgXFmmQjXHFn827eHo6SA9+dk1JzjPFMTFv2IsV10EIDvb oaEAZOXcGK+QdLo2yKpivpZB/UxGHJM4RXOJ1aJmSYhqYO8AFJew022bjJU9MuUjVaZ0 rPYA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-disposition :content-transfer-encoding:mime-version:robot-unsubscribe:robot-id :git-commit-id:subject:to:references:in-reply-to:reply-to:cc :message-id:from:date:arc-authentication-results; bh=gBzC5nyZ5JsMi8mnwTa3SbHTK2286R9IxIACRvoVdNY=; b=duv4FEPjhVWdOjJo/l9whibzsTnOrP4xAKrr/lIjYCTt4EKskacrJcsZVOl2tYYLa1 jHrelk9MWCZngIQQYHpRskLpTBC714kdFVUg74qIHvXcpQv29AWpa4typG0jcXfKmYqN 30VYXrTxRzF++8mlDlN+J8lW4Uzsw6Q2BPXAonC+M62d+BclALo5tAMbXUZPr65PTBQ3 whOh+MHQXoBANU5SEFGrdRyYuhDVNo76UKsQLsvNCKybKCl97vBoUVbSwuHe3DaMWrAq Ne+QZigKM+/Sb0pzvHgS+MZwXpwIq0ulCgaK2uRnhpQ0bs/RBdo6bnbYx3lS/wCd464T DnYQ== 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 p22-v6si3412104plo.206.2018.02.17.03.35.21; Sat, 17 Feb 2018 03:35:35 -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 S1751110AbeBQLeJ (ORCPT + 99 others); Sat, 17 Feb 2018 06:34:09 -0500 Received: from terminus.zytor.com ([198.137.202.136]:60473 "EHLO terminus.zytor.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750989AbeBQLeI (ORCPT ); Sat, 17 Feb 2018 06:34:08 -0500 Received: from terminus.zytor.com (localhost [127.0.0.1]) by terminus.zytor.com (8.15.2/8.15.2) with ESMTP id w1HBWuXp006955; Sat, 17 Feb 2018 03:32:56 -0800 Received: (from tipbot@localhost) by terminus.zytor.com (8.15.2/8.15.2/Submit) id w1HBWtZH006952; Sat, 17 Feb 2018 03:32:55 -0800 Date: Sat, 17 Feb 2018 03:32:55 -0800 X-Authentication-Warning: terminus.zytor.com: tipbot set sender to tipbot@zytor.com using -f From: tip-bot for Robert Walker Message-ID: Cc: robert.walker@arm.com, mingo@kernel.org, acme@redhat.com, tglx@linutronix.de, linux-kernel@vger.kernel.org, mathieu.poirier@linaro.org, hpa@zytor.com Reply-To: linux-kernel@vger.kernel.org, tglx@linutronix.de, acme@redhat.com, robert.walker@arm.com, mingo@kernel.org, hpa@zytor.com, mathieu.poirier@linaro.org In-Reply-To: <1518607481-4059-3-git-send-email-robert.walker@arm.com> References: <1518607481-4059-3-git-send-email-robert.walker@arm.com> To: linux-tip-commits@vger.kernel.org Subject: [tip:perf/core] perf inject: Emit instruction records on ETM trace discontinuity Git-Commit-ID: 256e751cac78739a4de2232450d3681b68b5845e X-Mailer: tip-git-log-daemon Robot-ID: Robot-Unsubscribe: Contact to get blacklisted from these emails MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain; charset=UTF-8 Content-Disposition: inline X-Spam-Status: No, score=-2.9 required=5.0 tests=ALL_TRUSTED,BAYES_00 autolearn=ham autolearn_force=no version=3.4.1 X-Spam-Checker-Version: SpamAssassin 3.4.1 (2015-04-28) on terminus.zytor.com Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Commit-ID: 256e751cac78739a4de2232450d3681b68b5845e Gitweb: https://git.kernel.org/tip/256e751cac78739a4de2232450d3681b68b5845e Author: Robert Walker AuthorDate: Wed, 14 Feb 2018 11:24:40 +0000 Committer: Arnaldo Carvalho de Melo CommitDate: Fri, 16 Feb 2018 14:55:45 -0300 perf inject: Emit instruction records on ETM trace discontinuity There may be discontinuities in the ETM trace stream due to overflows or ETM configuration for selective trace. This patch emits an instruction sample with the pending branch stack when a TRACE ON packet occurs indicating a discontinuity in the trace data. A new packet type CS_ETM_TRACE_ON is added, which is emitted by the low level decoder when a TRACE ON occurs. The higher level decoder flushes the branch stack when this packet is emitted. Signed-off-by: Robert Walker Acked-by: Mathieu Poirier Cc: coresight@lists.linaro.org Cc: linux-arm-kernel@lists.infradead.org Link: http://lkml.kernel.org/r/1518607481-4059-3-git-send-email-robert.walker@arm.com Signed-off-by: Arnaldo Carvalho de Melo --- tools/perf/util/cs-etm-decoder/cs-etm-decoder.c | 9 +++ tools/perf/util/cs-etm-decoder/cs-etm-decoder.h | 1 + tools/perf/util/cs-etm.c | 80 ++++++++++++++++++------- 3 files changed, 67 insertions(+), 23 deletions(-) diff --git a/tools/perf/util/cs-etm-decoder/cs-etm-decoder.c b/tools/perf/util/cs-etm-decoder/cs-etm-decoder.c index 8ff69df..640af88 100644 --- a/tools/perf/util/cs-etm-decoder/cs-etm-decoder.c +++ b/tools/perf/util/cs-etm-decoder/cs-etm-decoder.c @@ -328,7 +328,14 @@ cs_etm_decoder__buffer_range(struct cs_etm_decoder *decoder, } return ret; +} +static ocsd_datapath_resp_t +cs_etm_decoder__buffer_trace_on(struct cs_etm_decoder *decoder, + const uint8_t trace_chan_id) +{ + return cs_etm_decoder__buffer_packet(decoder, trace_chan_id, + CS_ETM_TRACE_ON); } static ocsd_datapath_resp_t cs_etm_decoder__gen_trace_elem_printer( @@ -347,6 +354,8 @@ static ocsd_datapath_resp_t cs_etm_decoder__gen_trace_elem_printer( decoder->trace_on = false; break; case OCSD_GEN_TRC_ELEM_TRACE_ON: + resp = cs_etm_decoder__buffer_trace_on(decoder, + trace_chan_id); decoder->trace_on = true; break; case OCSD_GEN_TRC_ELEM_INSTR_RANGE: diff --git a/tools/perf/util/cs-etm-decoder/cs-etm-decoder.h b/tools/perf/util/cs-etm-decoder/cs-etm-decoder.h index a4fdd28..743f5f4 100644 --- a/tools/perf/util/cs-etm-decoder/cs-etm-decoder.h +++ b/tools/perf/util/cs-etm-decoder/cs-etm-decoder.h @@ -24,6 +24,7 @@ struct cs_etm_buffer { enum cs_etm_sample_type { CS_ETM_RANGE = 1 << 0, + CS_ETM_TRACE_ON = 1 << 1, }; struct cs_etm_packet { diff --git a/tools/perf/util/cs-etm.c b/tools/perf/util/cs-etm.c index 6e595d9..1b0d422 100644 --- a/tools/perf/util/cs-etm.c +++ b/tools/perf/util/cs-etm.c @@ -867,6 +867,7 @@ static int cs_etm__sample(struct cs_etm_queue *etmq) */ if (etm->synth_opts.last_branch && etmq->prev_packet && + etmq->prev_packet->sample_type == CS_ETM_RANGE && etmq->prev_packet->last_instr_taken_branch) cs_etm__update_last_branch_rb(etmq); @@ -920,6 +921,40 @@ static int cs_etm__sample(struct cs_etm_queue *etmq) return 0; } +static int cs_etm__flush(struct cs_etm_queue *etmq) +{ + int err = 0; + struct cs_etm_packet *tmp; + + if (etmq->etm->synth_opts.last_branch && + etmq->prev_packet && + etmq->prev_packet->sample_type == CS_ETM_RANGE) { + /* + * Generate a last branch event for the branches left in the + * circular buffer at the end of the trace. + * + * Use the address of the end of the last reported execution + * range + */ + u64 addr = cs_etm__last_executed_instr(etmq->prev_packet); + + err = cs_etm__synth_instruction_sample( + etmq, addr, + etmq->period_instructions); + etmq->period_instructions = 0; + + /* + * Swap PACKET with PREV_PACKET: PACKET becomes PREV_PACKET for + * the next incoming packet. + */ + tmp = etmq->packet; + etmq->packet = etmq->prev_packet; + etmq->prev_packet = tmp; + } + + return err; +} + static int cs_etm__run_decoder(struct cs_etm_queue *etmq) { struct cs_etm_auxtrace *etm = etmq->etm; @@ -971,32 +1006,31 @@ static int cs_etm__run_decoder(struct cs_etm_queue *etmq) */ break; - /* - * If the packet contains an instruction - * range, generate instruction sequence - * events. - */ - if (etmq->packet->sample_type & CS_ETM_RANGE) - err = cs_etm__sample(etmq); + switch (etmq->packet->sample_type) { + case CS_ETM_RANGE: + /* + * If the packet contains an instruction + * range, generate instruction sequence + * events. + */ + cs_etm__sample(etmq); + break; + case CS_ETM_TRACE_ON: + /* + * Discontinuity in trace, flush + * previous branch stack + */ + cs_etm__flush(etmq); + break; + default: + break; + } } } while (buffer.len > buffer_used); - /* - * Generate a last branch event for the branches left in - * the circular buffer at the end of the trace. - */ - if (etm->sample_instructions && - etmq->etm->synth_opts.last_branch) { - struct branch_stack *bs = etmq->last_branch_rb; - struct branch_entry *be = - &bs->entries[etmq->last_branch_pos]; - - err = cs_etm__synth_instruction_sample( - etmq, be->to, etmq->period_instructions); - if (err) - return err; - } - + if (err == 0) + /* Flush any remaining branch stack entries */ + err = cs_etm__flush(etmq); } return err;