From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from simark.ca by simark.ca with LMTP id WHjyHn9+tmQvDCYAWB0awg (envelope-from ) for ; Tue, 18 Jul 2023 07:58:55 -0400 Authentication-Results: simark.ca; dkim=pass (1024-bit key; secure) header.d=sourceware.org header.i=@sourceware.org header.a=rsa-sha256 header.s=default header.b=OGHq8/jj; dkim-atps=neutral Received: by simark.ca (Postfix, from userid 112) id 7AE6C1E0BD; Tue, 18 Jul 2023 07:58:55 -0400 (EDT) Received: from server2.sourceware.org (server2.sourceware.org [8.43.85.97]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest SHA256) (No client certificate requested) by simark.ca (Postfix) with ESMTPS id 5EC681E00F for ; Tue, 18 Jul 2023 07:58:53 -0400 (EDT) Received: from server2.sourceware.org (localhost [IPv6:::1]) by sourceware.org (Postfix) with ESMTP id CA7953854831 for ; Tue, 18 Jul 2023 11:58:52 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 sourceware.org CA7953854831 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sourceware.org; s=default; t=1689681532; bh=5EQHmZlq1LQX/YIpH0Zmt9SNcs/IKUu2qkXkbZ+e0VU=; h=To:Subject:Date:In-Reply-To:References:List-Id:List-Unsubscribe: List-Archive:List-Post:List-Help:List-Subscribe:From:Reply-To: From; b=OGHq8/jjRDdL9XzdrjCgyVH1cEzEhEIv3+KRD0ctc2rdfnhxoTEGcvLC38SOOJXOy /vBHecJe0vWtmvOWxZTJt+HPft8PVWQhEOWeSxUcNuihbbflzgxdABZGEAVb5/XzEv tQeQKKJ0lzj18pzBrm7BoqwHahwRb8LGAM3y5b90= Received: from mga01.intel.com (mga01.intel.com [192.55.52.88]) by sourceware.org (Postfix) with ESMTPS id BB9F33857009 for ; Tue, 18 Jul 2023 11:57:14 +0000 (GMT) DMARC-Filter: OpenDMARC Filter v1.4.2 sourceware.org BB9F33857009 X-IronPort-AV: E=McAfee;i="6600,9927,10774"; a="397024546" X-IronPort-AV: E=Sophos;i="6.01,214,1684825200"; d="scan'208";a="397024546" Received: from fmsmga005.fm.intel.com ([10.253.24.32]) by fmsmga101.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 18 Jul 2023 04:57:12 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=McAfee;i="6600,9927,10774"; a="1054259947" X-IronPort-AV: E=Sophos;i="6.01,214,1684825200"; d="scan'208";a="1054259947" Received: from unknown (HELO localhost) ([10.216.210.22]) by fmsmga005-auth.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 18 Jul 2023 04:57:11 -0700 To: gdb-patches@sourceware.org, markus.t.metzger@intel.com, simark@simark.ca Subject: [PATCH v10 08/10] btrace, linux: Enable ptwrite packets. Date: Tue, 18 Jul 2023 13:56:35 +0200 Message-Id: <20230718115637.3531-9-felix.willgerodt@intel.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20230718115637.3531-1-felix.willgerodt@intel.com> References: <20230718115637.3531-1-felix.willgerodt@intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-10.4 required=5.0 tests=BAYES_00, DKIMWL_WL_HIGH, DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, DKIM_VALID_EF, GIT_PATCH_0, RCVD_IN_MSPIKE_H3, RCVD_IN_MSPIKE_WL, SPF_HELO_NONE, SPF_NONE, TXREP, T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on server2.sourceware.org X-BeenThere: gdb-patches@sourceware.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Gdb-patches mailing list List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , From: Felix Willgerodt via Gdb-patches Reply-To: Felix Willgerodt Errors-To: gdb-patches-bounces+public-inbox=simark.ca@sourceware.org Sender: "Gdb-patches" Enable ptwrite in the PT config, if it is supported by the kernel. --- gdb/nat/linux-btrace.c | 58 ++++++++++++++++++++++++++++++++++++++++++ gdb/record-btrace.c | 5 ++++ 2 files changed, 63 insertions(+) diff --git a/gdb/nat/linux-btrace.c b/gdb/nat/linux-btrace.c index c5b3f1c93cf..689f4c46dd4 100644 --- a/gdb/nat/linux-btrace.c +++ b/gdb/nat/linux-btrace.c @@ -417,6 +417,57 @@ cpu_supports_bts (void) } } +/* Read config bits. */ + +static bool +linux_read_pt_config_bit (const std::string &feature, uint64_t *config_bit) +{ + std::string filename + = "/sys/bus/event_source/devices/intel_pt/format/" + feature; + gdb_file_up file = gdb_fopen_cloexec (filename.c_str (), "r"); + + if (file.get () == nullptr || config_bit == nullptr) + return false; + + int found = fscanf (file.get (), "config:%lu", config_bit); + + if (found != 1) + { + warning (_("Failed to determine config bit from %s."), + filename.c_str ()); + return false; + } + + return true; +} + + +/* Check whether the linux target supports Intel Processor Trace PTWRITE. */ + +static bool +linux_supports_ptwrite (uint64_t *config_bit) +{ + static const char filename[] + = "/sys/bus/event_source/devices/intel_pt/caps/ptwrite"; + gdb_file_up file = gdb_fopen_cloexec (filename, "r"); + + if (file.get () == nullptr) + return false; + + int status, found = fscanf (file.get (), "%d", &status); + + if (found != 1) + { + warning (_("Failed to determine ptwrite support from %s."), filename); + return false; + } + + if (!linux_read_pt_config_bit ("ptw", config_bit)) + return false; + + return status == 1; +} + /* The perf_event_open syscall failed. Try to print a helpful error message. */ @@ -626,6 +677,13 @@ linux_enable_pt (ptid_t ptid, const struct btrace_config_pt *conf) pt->attr.exclude_hv = 1; pt->attr.exclude_idle = 1; + uint64_t config_bit; + if (conf->ptwrite && linux_supports_ptwrite (&config_bit)) + { + pt->attr.config |= 1 << config_bit; + tinfo->conf.pt.ptwrite = conf->ptwrite; + } + errno = 0; scoped_fd fd (syscall (SYS_perf_event_open, &pt->attr, pid, -1, -1, 0)); if (fd.get () < 0) diff --git a/gdb/record-btrace.c b/gdb/record-btrace.c index c93b3d7c8de..ad3160d42c5 100644 --- a/gdb/record-btrace.c +++ b/gdb/record-btrace.c @@ -3295,4 +3295,9 @@ to see the actual buffer size."), NULL, show_record_pt_buffer_size_value, record_btrace_conf.bts.size = 64 * 1024; record_btrace_conf.pt.size = 16 * 1024; +#if (LIBIPT_VERSION >= 0x200) + record_btrace_conf.pt.ptwrite = true; +#else + record_btrace_conf.pt.ptwrite = false; +#endif } -- 2.34.1 Intel Deutschland GmbH Registered Address: Am Campeon 10, 85579 Neubiberg, Germany Tel: +49 89 99 8853-0, www.intel.de Managing Directors: Christin Eisenschmid, Sharon Heck, Tiffany Doon Silva Chairperson of the Supervisory Board: Nicole Lau Registered Office: Munich Commercial Register: Amtsgericht Muenchen HRB 186928