Received: by 10.223.176.46 with SMTP id f43csp629451wra; Wed, 24 Jan 2018 03:38:42 -0800 (PST) X-Google-Smtp-Source: AH8x2265PlJQPIZ0VyDMbNrYC1+pmL2njkP2jwc+7j1mpbX//UPZb1cDU4/DxoHk1nlqepyzDmav X-Received: by 10.101.65.131 with SMTP id a3mr10224187pgq.99.1516793922193; Wed, 24 Jan 2018 03:38:42 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1516793922; cv=none; d=google.com; s=arc-20160816; b=UXtiKJXyJsnuM6kqBsXeX0qhp8mWS3MlfanozUVXo3k5HetXQ9S5rW5WUVCr5Y7yEf 1Czz2ZQOBvhxVS59m88y7+lzQy15iuXudKb+JJeBEGAiEhUNqR5QeWAkJFthqEBZuqId f5SYxJBu0JIY1H77AiEzM73xZ9Rjq/XLiQHW7W7mWCZXqU+iquPN5CHmixfo242SgfNo ofiUwf4VW4C8Ef5WNBdcn3lyDTGmxCaWrNUD2IFTPXSIR1Y5/AH6mWOG8Mmrjmi6LmXF 5t4qssQebzuUCexEYcmU164ujtihutrTRkI6ODqa97Z0MHVhENSLvd2HwvrXY5mD6SpY WEnw== 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=DRq/P546SH5Fh2uwuTjwF2Q20RDMN0n18VydfcS0V9w=; b=NcZ6OIVxjM4sSUu8Y0rVFXa3VBjvQa2CiKxkqifnYSCFSTs0c1wjLfvd5pyrnVzK2G YTSkvkoLeIgqIQ1fLdTbLqkPmWMerQ48Tp+4kSNKCQYIm4dvD+28Fj8ibGu9+JqboJnx ozxMMWI851obbB6fFJ7C2+SI7r2AHKQobNeCdanR5HfA3XM3DMo+p1iSfE6YZ21CjIK4 IBRFFXU3Huq0Gr82F2LYNRaL4WKxjTyWj4Ooztp/uldZNYNngB2eb6HSDzev0hoFIxc+ W0CR2JPlekHiWrbktwL8N/yMgsgMxgFmncQlRna4ULllhzJCt6G0DDTEhOqNqundaEdb fukQ== 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 k65si2852095pfa.98.2018.01.24.03.38.28; Wed, 24 Jan 2018 03:38:42 -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 S933301AbeAXLiI (ORCPT + 99 others); Wed, 24 Jan 2018 06:38:08 -0500 Received: from terminus.zytor.com ([65.50.211.136]:49199 "EHLO terminus.zytor.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S933060AbeAXLiH (ORCPT ); Wed, 24 Jan 2018 06:38:07 -0500 Received: from terminus.zytor.com (localhost [127.0.0.1]) by terminus.zytor.com (8.15.2/8.15.2) with ESMTP id w0OBYS1N028671; Wed, 24 Jan 2018 03:34:28 -0800 Received: (from tipbot@localhost) by terminus.zytor.com (8.15.2/8.15.2/Submit) id w0OBYSS3028668; Wed, 24 Jan 2018 03:34:28 -0800 Date: Wed, 24 Jan 2018 03:34:28 -0800 X-Authentication-Warning: terminus.zytor.com: tipbot set sender to tipbot@zytor.com using -f From: tip-bot for Mathieu Poirier Message-ID: Cc: tglx@linutronix.de, adrian.hunter@intel.com, mike.leach@arm.com, jolsa@redhat.com, mingo@kernel.org, alexander.shishkin@linux.intel.com, tor@ti.com, mathieu.poirier@linaro.org, hpa@zytor.com, kim.phillips@arm.com, acme@redhat.com, peterz@infradead.org, linux-kernel@vger.kernel.org, suzuki.poulose@arm.com, namhyung@kernel.org Reply-To: alexander.shishkin@linux.intel.com, mathieu.poirier@linaro.org, tor@ti.com, hpa@zytor.com, peterz@infradead.org, acme@redhat.com, kim.phillips@arm.com, linux-kernel@vger.kernel.org, namhyung@kernel.org, suzuki.poulose@arm.com, tglx@linutronix.de, adrian.hunter@intel.com, jolsa@redhat.com, mike.leach@arm.com, mingo@kernel.org In-Reply-To: <1516211539-5166-7-git-send-email-mathieu.poirier@linaro.org> References: <1516211539-5166-7-git-send-email-mathieu.poirier@linaro.org> To: linux-tip-commits@vger.kernel.org Subject: [tip:perf/core] perf tools: Add functionality to communicate with the openCSD decoder Git-Commit-ID: 8d711bce6e1a07c250ff8ed9afd0003bc1757ba2 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: 8d711bce6e1a07c250ff8ed9afd0003bc1757ba2 Gitweb: https://git.kernel.org/tip/8d711bce6e1a07c250ff8ed9afd0003bc1757ba2 Author: Mathieu Poirier AuthorDate: Wed, 17 Jan 2018 10:52:15 -0700 Committer: Arnaldo Carvalho de Melo CommitDate: Tue, 23 Jan 2018 09:51:47 -0300 perf tools: Add functionality to communicate with the openCSD decoder This patch adds functions to communicate with the openCSD trace decoder, more specifically to access program memory, fetch trace packets and reset the decoder. Co-authored-by: Tor Jeremiassen Signed-off-by: Mathieu Poirier Acked-by: Jiri Olsa Cc: Adrian Hunter Cc: Alexander Shishkin Cc: Kim Phillips Cc: Mike Leach Cc: Namhyung Kim Cc: Peter Zijlstra Cc: Suzuki Poulouse Cc: linux-arm-kernel@lists.infradead.org Link: http://lkml.kernel.org/r/1516211539-5166-7-git-send-email-mathieu.poirier@linaro.org Signed-off-by: Arnaldo Carvalho de Melo --- tools/perf/util/cs-etm-decoder/cs-etm-decoder.c | 60 +++++++++++++++++++++++++ tools/perf/util/cs-etm-decoder/cs-etm-decoder.h | 9 ++++ 2 files changed, 69 insertions(+) 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 57b020b..1fb0184 100644 --- a/tools/perf/util/cs-etm-decoder/cs-etm-decoder.c +++ b/tools/perf/util/cs-etm-decoder/cs-etm-decoder.c @@ -45,6 +45,66 @@ struct cs_etm_decoder { struct cs_etm_packet packet_buffer[MAX_BUFFER]; }; +static u32 +cs_etm_decoder__mem_access(const void *context, + const ocsd_vaddr_t address, + const ocsd_mem_space_acc_t mem_space __maybe_unused, + const u32 req_size, + u8 *buffer) +{ + struct cs_etm_decoder *decoder = (struct cs_etm_decoder *) context; + + return decoder->mem_access(decoder->data, + address, + req_size, + buffer); +} + +int cs_etm_decoder__add_mem_access_cb(struct cs_etm_decoder *decoder, + u64 start, u64 end, + cs_etm_mem_cb_type cb_func) +{ + decoder->mem_access = cb_func; + + if (ocsd_dt_add_callback_mem_acc(decoder->dcd_tree, start, end, + OCSD_MEM_SPACE_ANY, + cs_etm_decoder__mem_access, decoder)) + return -1; + + return 0; +} + +int cs_etm_decoder__reset(struct cs_etm_decoder *decoder) +{ + ocsd_datapath_resp_t dp_ret; + + dp_ret = ocsd_dt_process_data(decoder->dcd_tree, OCSD_OP_RESET, + 0, 0, NULL, NULL); + if (OCSD_DATA_RESP_IS_FATAL(dp_ret)) + return -1; + + return 0; +} + +int cs_etm_decoder__get_packet(struct cs_etm_decoder *decoder, + struct cs_etm_packet *packet) +{ + if (!decoder || !packet) + return -EINVAL; + + /* Nothing to do, might as well just return */ + if (decoder->packet_count == 0) + return 0; + + *packet = decoder->packet_buffer[decoder->head]; + + decoder->head = (decoder->head + 1) & (MAX_BUFFER - 1); + + decoder->packet_count--; + + return 1; +} + static void cs_etm_decoder__gen_etmv4_config(struct cs_etm_trace_params *params, ocsd_etmv4_cfg *config) { 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 a1e9b0a..3d2e620 100644 --- a/tools/perf/util/cs-etm-decoder/cs-etm-decoder.h +++ b/tools/perf/util/cs-etm-decoder/cs-etm-decoder.h @@ -93,4 +93,13 @@ cs_etm_decoder__new(int num_cpu, void cs_etm_decoder__free(struct cs_etm_decoder *decoder); +int cs_etm_decoder__add_mem_access_cb(struct cs_etm_decoder *decoder, + u64 start, u64 end, + cs_etm_mem_cb_type cb_func); + +int cs_etm_decoder__get_packet(struct cs_etm_decoder *decoder, + struct cs_etm_packet *packet); + +int cs_etm_decoder__reset(struct cs_etm_decoder *decoder); + #endif /* INCLUDE__CS_ETM_DECODER_H__ */