Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp3086320pxk; Mon, 5 Oct 2020 00:15:08 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwbG24Tr9cvMsHiLjbwLf1DXzYnQp7FHneex6w7v/dYI4mA2RYatumOOFD44nBUfjzOk3Qd X-Received: by 2002:a17:906:7f82:: with SMTP id f2mr8293761ejr.264.1601882107881; Mon, 05 Oct 2020 00:15:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601882107; cv=none; d=google.com; s=arc-20160816; b=JLDdpQ8/nfiwfAh9z2Sja8Kz2ve5Eyp0/AeAD525fx3uGXgeo6PgYygyBhrgfxsOlY ToD5Fyckw8x0di1/N03vnesZTYCqWE1NuQPvA7kzsTG7l3lhjd8bSq4nKskXhrgxTWSz buwMCPmMh6UoMMuCmgmm1zwcIg8jrtgAwuwX5xGnqfSh9IKr/5i/wNI9Sde+g+OO7Nk/ 0mfdsR5haLf1BX7J+kP9YcPVpcA8FNticiGgQNokn0TO42Q/J9Q3NH1pygkeJCURLHET Tw1WNgZLghqMAzHpr0cXG2rBqrCejVWEstUpNqkE7hIghITBMKCKJ7gPphl/zkkaP45Y DuFA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :ironport-sdr:ironport-sdr; bh=eOTLMj3H/M0893dc9kplTjh5ctoj1fmi0OxwRVMJNLA=; b=Qyc5sS4TI2Ptnl5YG+A3H5IQV9OoTJVrngl2RR8Ges3Up22tPXJ2tuwYl1FySuLlKo 0oenHKw5VGyOR3X8pIIOrzCOXsW6Ensxc75bXM+ehVBKrpnD3ijt+C7WbkxbzvFU/OSw QUCKGwFkjEiuUzdZFLkRx9jiB/D1QTt7i7UUxI/MS8g1VDD81s/aHzXhpq27QlK4uCjH zXciH1dsniQuLOuaK0U+f/pWBLeb38WCHVaiBFIqZRhmM5LuCcj1kQH0G/VpJgI/EqEY omSkwpBidr056oC9GqIzKLmA3ro4Z9jZrIevnx1+L09CNwesgY2CEL1HDHXw3mMWMVbL E5bA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id k6si6873106edj.301.2020.10.05.00.14.45; Mon, 05 Oct 2020 00:15:07 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1725974AbgJEHNn (ORCPT + 99 others); Mon, 5 Oct 2020 03:13:43 -0400 Received: from mga07.intel.com ([134.134.136.100]:10321 "EHLO mga07.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725943AbgJEHNj (ORCPT ); Mon, 5 Oct 2020 03:13:39 -0400 IronPort-SDR: 4uwCJQp12IEVRp16vWotJD/bawqYlhiVYwyt9NQjD8WKvInHhL2Zjkn8JFQewLdXvBC2wOScTF +8Z8Fq4ga02g== X-IronPort-AV: E=McAfee;i="6000,8403,9764"; a="227479266" X-IronPort-AV: E=Sophos;i="5.77,338,1596524400"; d="scan'208";a="227479266" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga003.jf.intel.com ([10.7.209.27]) by orsmga105.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 05 Oct 2020 00:13:39 -0700 IronPort-SDR: WyCUaNSURm5gSYIIMIwN9N7IhHp3jGvsXmVta0jVXbmHlWWfqBatJPQiKR9iuSkzXbtTVAYSX4 iPS8SYkgZDLg== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.77,338,1596524400"; d="scan'208";a="309718089" Received: from black.fi.intel.com (HELO black.fi.intel.com.) ([10.237.72.28]) by orsmga003.jf.intel.com with ESMTP; 05 Oct 2020 00:13:37 -0700 From: Alexander Shishkin To: Greg Kroah-Hartman Cc: linux-kernel@vger.kernel.org, Tingwei Zhang , Steven Rostedt , Alexander Shishkin Subject: [PATCH 4/8] tracing: Add trace_export support for trace_marker Date: Mon, 5 Oct 2020 10:13:15 +0300 Message-Id: <20201005071319.78508-5-alexander.shishkin@linux.intel.com> X-Mailer: git-send-email 2.28.0 In-Reply-To: <20201005071319.78508-1-alexander.shishkin@linux.intel.com> References: <20201005071319.78508-1-alexander.shishkin@linux.intel.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Tingwei Zhang Add the support to route trace_marker buffer to other destination via trace_export. Signed-off-by: Tingwei Zhang Reviewed-by: Steven Rostedt (VMware) Reviewed-by: Alexander Shishkin Signed-off-by: Alexander Shishkin --- include/linux/trace.h | 1 + kernel/trace/trace.c | 9 +++++++++ 2 files changed, 10 insertions(+) diff --git a/include/linux/trace.h b/include/linux/trace.h index 86033d214972..886a4ffd9d45 100644 --- a/include/linux/trace.h +++ b/include/linux/trace.h @@ -6,6 +6,7 @@ #define TRACE_EXPORT_FUNCTION BIT(0) #define TRACE_EXPORT_EVENT BIT(1) +#define TRACE_EXPORT_MARKER BIT(2) /* * The trace export - an export of Ftrace output. The trace_export diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c index a40ee413123c..6048fba2f590 100644 --- a/kernel/trace/trace.c +++ b/kernel/trace/trace.c @@ -271,6 +271,7 @@ static struct trace_export __rcu *ftrace_exports_list __read_mostly; static DEFINE_STATIC_KEY_FALSE(trace_function_exports_enabled); static DEFINE_STATIC_KEY_FALSE(trace_event_exports_enabled); +static DEFINE_STATIC_KEY_FALSE(trace_marker_exports_enabled); static inline void ftrace_exports_enable(struct trace_export *export) { @@ -279,6 +280,9 @@ static inline void ftrace_exports_enable(struct trace_export *export) if (export->flags & TRACE_EXPORT_EVENT) static_branch_inc(&trace_event_exports_enabled); + + if (export->flags & TRACE_EXPORT_MARKER) + static_branch_inc(&trace_marker_exports_enabled); } static inline void ftrace_exports_disable(struct trace_export *export) @@ -288,6 +292,9 @@ static inline void ftrace_exports_disable(struct trace_export *export) if (export->flags & TRACE_EXPORT_EVENT) static_branch_dec(&trace_event_exports_enabled); + + if (export->flags & TRACE_EXPORT_MARKER) + static_branch_dec(&trace_marker_exports_enabled); } static void ftrace_exports(struct ring_buffer_event *event, int flag) @@ -6687,6 +6694,8 @@ tracing_mark_write(struct file *filp, const char __user *ubuf, } else entry->buf[cnt] = '\0'; + if (static_branch_unlikely(&trace_marker_exports_enabled)) + ftrace_exports(event, TRACE_EXPORT_MARKER); __buffer_unlock_commit(buffer, event); if (tt) -- 2.28.0