Received: by 2002:a05:6358:489b:b0:bb:da1:e618 with SMTP id x27csp1529211rwn; Thu, 8 Sep 2022 22:58:58 -0700 (PDT) X-Google-Smtp-Source: AA6agR6pwRY2l0LPtdROesCOB0MiaOAocLgltA0P6D+RPVWrjuZSGcyfof4BAdUHTuXjNE5z26ww X-Received: by 2002:a2e:a604:0:b0:25e:87b1:fda5 with SMTP id v4-20020a2ea604000000b0025e87b1fda5mr3292220ljp.428.1662703137847; Thu, 08 Sep 2022 22:58:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1662703137; cv=none; d=google.com; s=arc-20160816; b=FTpdqZhq6uJuq0Ud0FU4mxW1xCdQOgxODzehaULXidYZXKwZFjwfAmcQaxcQCRO36q mbFOvRhkA1M6x5ncFVtwFZSnnjyg4MteTzSYLiRhiMZfTsWBRmCLLid1eaT6UH9G0FkE COC9kZNr9qDuU3KojIwzVNBorUuBwvx4MhXsCC0BAWn3NlfNwpAr0e0OzBZm6hagRHfV ANaB3tD6QAd40FYRV4idAu4azmiiAoYxQIkYeVKXpIg0t4cror9LnhMvPXrgcx68Hcke 1xUYIDxz2fFUtcnczTVUnMSVITD/VI6KMRA9jFxhpqzYN/S7+HHC+CKB14d+YONApmnn hv/g== 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; bh=kqt/DDYJiULvZ4op3L8QbfeTCPhJBke9zAVonx60Hdw=; b=TD7E5kLjZLXn0E4cNRwVwLSSGHzcO2QYzS92NGtEa6PbQF0Yzp02+8d+2AxD3Ow00N Ab5uOQAjnyqLYzx4tL2yhT/HmskOCM8L2S2O9BP2KlfQerLmiFFZS4aSJt3d3dSxdIJB yBBZ9WW/3oYVp8s+vfuprtuqtt3KXz+i+0BmueP2RPVZCjjiJ+jq5KAPwPtvU0c/1O4x epOyS/FuepOzPxeeYrQuL29sM4oFbvQcC7U48NsDZYtrVkUCvTwum2c/HYJIYZ23cdjI ETWT0eTNlbhbU+JqPG62U20OiuEmXuts1cim6bHUEMDrLRZBvXwBb7oRECR4RDGtcKCK 4sTA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=fujitsu.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id f2-20020a2e9e82000000b0026bdc7fad42si383201ljk.425.2022.09.08.22.58.28; Thu, 08 Sep 2022 22:58:57 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=fujitsu.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229923AbiIIFrp (ORCPT + 99 others); Fri, 9 Sep 2022 01:47:45 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54236 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229659AbiIIFro (ORCPT ); Fri, 9 Sep 2022 01:47:44 -0400 X-Greylist: delayed 63 seconds by postgrey-1.37 at lindbergh.monkeyblade.net; Thu, 08 Sep 2022 22:47:41 PDT Received: from esa1.hc1455-7.c3s2.iphmx.com (esa1.hc1455-7.c3s2.iphmx.com [207.54.90.47]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A69CC6B659 for ; Thu, 8 Sep 2022 22:47:41 -0700 (PDT) X-IronPort-AV: E=McAfee;i="6500,9779,10464"; a="87881375" X-IronPort-AV: E=Sophos;i="5.93,302,1654527600"; d="scan'208";a="87881375" Received: from unknown (HELO yto-r1.gw.nic.fujitsu.com) ([218.44.52.217]) by esa1.hc1455-7.c3s2.iphmx.com with ESMTP; 09 Sep 2022 14:46:36 +0900 Received: from yto-m3.gw.nic.fujitsu.com (yto-nat-yto-m3.gw.nic.fujitsu.com [192.168.83.66]) by yto-r1.gw.nic.fujitsu.com (Postfix) with ESMTP id DDFDEDAFD2 for ; Fri, 9 Sep 2022 14:46:34 +0900 (JST) Received: from m3002.s.css.fujitsu.com (msm3.b.css.fujitsu.com [10.128.233.104]) by yto-m3.gw.nic.fujitsu.com (Postfix) with ESMTP id 2D03F263E5 for ; Fri, 9 Sep 2022 14:46:34 +0900 (JST) Received: from localhost.localdomain (unknown [10.125.5.220]) by m3002.s.css.fujitsu.com (Postfix) with ESMTP id 10B3D2020A69; Fri, 9 Sep 2022 14:46:34 +0900 (JST) From: Rei Yamamoto To: tglx@linutronix.de Cc: geert+renesas@glider.be, linux-kernel@vger.kernel.org, yamamoto.rei@jp.fujitsu.com Subject: Re: [PATCH] hrtimer: CPU and entry_time is added to a warning message in hrtimer_interrupt() Date: Fri, 9 Sep 2022 14:22:11 +0900 Message-Id: <20220909052211.2415-1-yamamoto.rei@jp.fujitsu.com> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20220624070917.128409-1-yamamoto.rei@jp.fujitsu.com> References: <20220624070917.128409-1-yamamoto.rei@jp.fujitsu.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-TM-AS-GCONF: 00 X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_MED, SPF_HELO_PASS,SPF_PASS,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 lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, Thomas Gleixner. On Fri, 24 Jun 2022 16:00:11, Rei Yamamoto wrote: > A warning message in hrtimer_interrupt() is output up to 5 times > by default, and CPU and entry_time are also shown. > These changes are helpful that the function spending a lot of time is clear > by using ftrace: > ----- > dmesg > : > [ 1462.836971] start repro_hrtimer_interrupt > [ 1462.836976] test_handler = test_handler [repro] 0xffff9788f7bb3048 > : > [ 1462.879117] hrtimer: CPU 7, entry_time = 1462807264840, interrupt took > 60048886 ns ^^^^^ ^^^^^^^^^^^^^ > > cat /sys/kernel/debug/tracing/trace > : > -0 [007] d.h1. 1462.838075: hrtimer_expire_entry: > ^^^^^ > hrtimer=0000000041fcee42 function=test_handler [repro] now=1462807264840 > ^^^^^^^^^^^^^ > ----- > > Signed-off-by: Rei Yamamoto > --- > include/linux/hrtimer.h | 1 + > kernel/sysctl.c | 10 ++++++++++ > kernel/time/hrtimer.c | 16 +++++++++++++++- > 3 files changed, 26 insertions(+), 1 deletion(-) > > diff --git a/include/linux/hrtimer.h b/include/linux/hrtimer.h > index 0ee140176f10..1a6e03b3015b 100644 > --- a/include/linux/hrtimer.h > +++ b/include/linux/hrtimer.h > @@ -317,6 +317,7 @@ static inline int hrtimer_is_hres_active(struct hrtimer *timer) > struct clock_event_device; > > extern void hrtimer_interrupt(struct clock_event_device *dev); > +extern int sysctl_hrtimer_interrupt_warnings; > > extern unsigned int hrtimer_resolution; > > diff --git a/kernel/sysctl.c b/kernel/sysctl.c > index e52b6e372c60..b0420d60cec9 100644 > --- a/kernel/sysctl.c > +++ b/kernel/sysctl.c > @@ -64,6 +64,7 @@ > #include > #include > #include > +#include > > #include "../lib/kstrtox.h" > > @@ -2038,6 +2039,15 @@ static struct ctl_table kern_table[] = { > .extra1 = SYSCTL_ONE, > .extra2 = SYSCTL_INT_MAX, > }, > +#endif > +#ifdef CONFIG_HIGH_RES_TIMERS > + { > + .procname = "hrtimer_interrupt_warnings", > + .data = &sysctl_hrtimer_interrupt_warnings, > + .maxlen = sizeof(int), > + .mode = 0644, > + .proc_handler = proc_dointvec, > + }, > #endif > { } > }; > diff --git a/kernel/time/hrtimer.c b/kernel/time/hrtimer.c > index 0ea8702eb516..19adcbcf92e4 100644 > --- a/kernel/time/hrtimer.c > +++ b/kernel/time/hrtimer.c > @@ -1773,6 +1773,7 @@ static __latent_entropy void hrtimer_run_softirq(struct softirq_action *h) > } > > #ifdef CONFIG_HIGH_RES_TIMERS > +int sysctl_hrtimer_interrupt_warnings = 5; > > /* > * High resolution timer interrupt > @@ -1866,7 +1867,20 @@ void hrtimer_interrupt(struct clock_event_device *dev) > else > expires_next = ktime_add(now, delta); > tick_program_event(expires_next, 1); > - pr_warn_once("hrtimer: interrupt took %llu ns\n", ktime_to_ns(delta)); > + > + /* > + * If a message is output many times, the delayed funciton > + * may be identified by resetting sysctl_hrtimer_interrupt_warnings > + * and enabling ftrace. > + */ > + if (sysctl_hrtimer_interrupt_warnings) { > + if (sysctl_hrtimer_interrupt_warnings > 0) > + sysctl_hrtimer_interrupt_warnings--; > + pr_warn("hrtimer: CPU %d, entry_time = %llu, " > + "interrupt took %llu ns\n", > + cpu_base->cpu, entry_time, > + ktime_to_ns(delta)); > + } > } > > /* called with interrupts disabled */ Could you pick this patch up? Thanks, Rei