Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1288095pxb; Thu, 4 Mar 2021 07:49:39 -0800 (PST) X-Google-Smtp-Source: ABdhPJw2jlTxAv6rAVaDNv0D1ssZKS50DioqzRTq4AFec8jLD0EQyOSlyx8SEwbbnUYfdNetCcnQ X-Received: by 2002:a17:906:8474:: with SMTP id hx20mr4939693ejc.129.1614872979046; Thu, 04 Mar 2021 07:49:39 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1614872979; cv=none; d=google.com; s=arc-20160816; b=LHv/LSpCCBCqoAcLRh7M3Ce/xi+vZSqFzkQyraNsoACr2XwjFbuGAkDmNLKc9aaB4w QqPDA4umZ/Xbde8hYYKRGUJRoW5YYAXn5d39Jop/UWSuXrwa/EkfTtKf8RIPKu050K+o YQfbiOLBKEVzjsNhK/bFBfE/pKTGxiDrFjk8EIiwC8+tUnPJzvBEwCQ2DPW9ujaIpY8N PKtafKxEXcgc6aCdwssnmj6+lhPgVGlYNt3o30A+nprqNPBRrD074VDxeLvG7HwAIMG+ XVNMTO4wbA9jpRed8sVYuhWZ+QXSTAaIvLLzJ0md1h1EH0ddcH4kOD21Jg1u5Vq5zO0g v8sQ== 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 :dkim-signature; bh=Eu5OJzH7maufbREWovWushZstOy2hgo0oLSHqoVL++k=; b=IU0IzqBpa3NVVOaHTihFsEhvka9AjQifdBjoEhbT+p9CgI0zQZNBeHdYKk7m4BFyuG CHv9GWCzg5p49P5h5mlDeGTMHi9clLuNfaDXj1vq0zHwzXqn+tikELwvyG0lWsXIov5k aklbIxyn26wvTIuEdGi/ntfv03pbG+EZutQ66ZYl/RPJ6Y2wzoo0nYr4+hP5q0zXZVx8 CEtt0ScLpYdErc6faBZDC60BsTGs2YNBFxfHd7108k9gaG7fVN2mEx9TDIYS0q4ngfwm 1NAveRJtmYjAy9O7fnLymQmwc75sZZUrCSYeqgPeq9cnhtfvTAe7Hr28JFviyG8pNK+i xHQA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=imRENuLr; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u2si9091907ejg.288.2021.03.04.07.49.16; Thu, 04 Mar 2021 07:49:39 -0800 (PST) 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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=imRENuLr; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237364AbhCDJEA (ORCPT + 99 others); Thu, 4 Mar 2021 04:04:00 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48976 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237295AbhCDJDY (ORCPT ); Thu, 4 Mar 2021 04:03:24 -0500 Received: from mail-ej1-x62e.google.com (mail-ej1-x62e.google.com [IPv6:2a00:1450:4864:20::62e]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2F74AC061762 for ; Thu, 4 Mar 2021 01:02:22 -0800 (PST) Received: by mail-ej1-x62e.google.com with SMTP id lr13so47846422ejb.8 for ; Thu, 04 Mar 2021 01:02:22 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=Eu5OJzH7maufbREWovWushZstOy2hgo0oLSHqoVL++k=; b=imRENuLrcxxdbwjnbS0xNPn/qyDaRMGGVsSekjpuWvRIXE+UCPxeYOsD4eCQ+IUeZ8 gJN7qL20TeeXL+pID9+i370/fmIt0EJGeHbzVuTKu5YneKqwx1nhBFUIMpN4xrZe1N9n iNy4ETNY6nF2xx+SKmZmPYiXhT1Ndw3WXpPUZFxZvm+Zq5PWtrPi6IzSeelu2xpKLOn6 yNzRCxGwvMPkjYhsa1Vw2hE4nD0xQq+ivHc5TiO2Zk3730LtYE/R3gP2oLNltZhPmM6+ Ym38u7T8f0xPtu7eIjhEKV86KUjASeCE11TCMmF3bRubdPe4U/Kcq9ijfdY/icoungF4 8q2g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=Eu5OJzH7maufbREWovWushZstOy2hgo0oLSHqoVL++k=; b=Xg63PFMOPzOMx2+FkbB3HH81S04+xUgEKI/9S0LAKf4cQT9jwOShYXQ2/lMgG07f5v oWiwFC2E8e1fIL/zRYWtVCyj0Vv6DMPjRVzby15W3I3z+gx9GP+9hAY8PbOyhdNuZc8b rDZ7aV91HJxEvKPvXoe0mKqmI2U6wa3o+6Y6dIW6Tk7TcVnnYb68hfUoyiqEUOAqhCya 59rcDyGYkFefg/vRrFdp1UBnUH1mVT8YczHBUVsorb/vzDt+xzaUtcoGs/rHCa2MFSlS gpuc9F2bqkchmU96pD9DflkAatYpdzu2SF477o7lQfh6hRo36UMWlkorpRUgZrzL7Ti0 3cng== X-Gm-Message-State: AOAM532CwSbeeHftmHeqmIzgLRoVqkmdDUpCdD11nxqs24lN8K0rygts +RJBt6/Y6rZkXxd7DETGC34w4Zl/rEG4AA== X-Received: by 2002:a17:906:5043:: with SMTP id e3mr3142322ejk.260.1614848540740; Thu, 04 Mar 2021 01:02:20 -0800 (PST) Received: from localhost.localdomain ([95.87.199.88]) by smtp.gmail.com with ESMTPSA id f22sm23123552eje.34.2021.03.04.01.02.19 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 04 Mar 2021 01:02:20 -0800 (PST) From: "Yordan Karadzhov (VMware)" To: linux-kernel@vger.kernel.org Cc: tglx@linutronix.de, peterz@infradead.org, rostedt@goodmis.org, "Yordan Karadzhov (VMware)" Subject: [RFC PATCH 3/5] tracing: Add method for recording "func_repeats" events Date: Thu, 4 Mar 2021 11:01:39 +0200 Message-Id: <20210304090141.207309-4-y.karadz@gmail.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20210304090141.207309-1-y.karadz@gmail.com> References: <20210304090141.207309-1-y.karadz@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch only provides the implementation of the method. Later we will used it in a combination with a new option for function tracing. Signed-off-by: Yordan Karadzhov (VMware) --- kernel/trace/trace.c | 21 +++++++++++++++++++++ kernel/trace/trace.h | 4 ++++ 2 files changed, 25 insertions(+) diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c index 5f5fa08c0644..5c62fda666af 100644 --- a/kernel/trace/trace.c +++ b/kernel/trace/trace.c @@ -3109,6 +3109,27 @@ static void ftrace_trace_userstack(struct trace_array *tr, #endif /* CONFIG_STACKTRACE */ +void trace_last_func_repeats(struct trace_array *tr, + struct trace_func_repeats *last_info, + unsigned int trace_ctx) +{ + struct trace_buffer *buffer = tr->array_buffer.buffer; + struct func_repeats_entry *entry; + struct ring_buffer_event *event; + + event = __trace_buffer_lock_reserve(buffer, TRACE_FUNC_REPEATS, + sizeof(*entry), trace_ctx); + if (!event) + return; + + entry = ring_buffer_event_data(event); + entry->ip = last_info->ip; + entry->pip = last_info->parent_ip; + entry->count = last_info->count; + + __buffer_unlock_commit(buffer, event); +} + /* created for use with alloc_percpu */ struct trace_buffer_struct { int nesting; diff --git a/kernel/trace/trace.h b/kernel/trace/trace.h index 09bf12c038f4..0ef823bb9594 100644 --- a/kernel/trace/trace.h +++ b/kernel/trace/trace.h @@ -696,6 +696,10 @@ static inline void __trace_stack(struct trace_array *tr, unsigned int trace_ctx, } #endif /* CONFIG_STACKTRACE */ +void trace_last_func_repeats(struct trace_array *tr, + struct trace_func_repeats *last_info, + unsigned int trace_ctx); + extern u64 ftrace_now(int cpu); extern void trace_find_cmdline(int pid, char comm[]); -- 2.25.1