Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751868AbdFVOda (ORCPT ); Thu, 22 Jun 2017 10:33:30 -0400 Received: from Galois.linutronix.de ([146.0.238.70]:55977 "EHLO Galois.linutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750812AbdFVOd2 (ORCPT ); Thu, 22 Jun 2017 10:33:28 -0400 Date: Thu, 22 Jun 2017 16:32:07 +0200 (CEST) From: Thomas Gleixner To: root cc: mingo@redhat.com, hpa@zytor.com, pbonzini@redhat.com, x86@kernel.org, corbet@lwn.net, tony.luck@intel.com, bp@alien8.de, peterz@infradead.org, mchehab@kernel.org, akpm@linux-foundation.org, krzk@kernel.org, jpoimboe@redhat.com, luto@kernel.org, borntraeger@de.ibm.com, thgarnie@google.com, rgerst@gmail.com, minipli@googlemail.com, douly.fnst@cn.fujitsu.com, nicstange@gmail.com, fweisbec@gmail.com, dvlasenk@redhat.com, bristot@redhat.com, yamada.masahiro@socionext.com, mika.westerberg@linux.intel.com, yu.c.chen@intel.com, aaron.lu@intel.com, rostedt@goodmis.org, me@kylehuey.com, len.brown@intel.com, prarit@redhat.com, hidehiro.kawai.ez@hitachi.com, fengtiantian@huawei.com, pmladek@suse.com, jeyu@redhat.com, Larry.Finger@lwfinger.net, zijun_hu@htc.com, luisbg@osg.samsung.com, johannes.berg@intel.com, niklas.soderlund+renesas@ragnatech.se, zlpnobody@gmail.com, adobriyan@gmail.com, fgao@48lvckh6395k16k5.yundunddos.com, ebiederm@xmission.com, subashab@codeaurora.org, arnd@arndb.de, matt@codeblueprint.co.uk, mgorman@techsingularity.net, linux-kernel@vger.kernel.org, linux-doc@vger.kernel.org, linux-edac@vger.kernel.org, kvm@vger.kernel.org Subject: Re: [PATCH 2/2] x86/idle: use dynamic halt poll In-Reply-To: <1498130534-26568-3-git-send-email-root@ip-172-31-39-62.us-west-2.compute.internal> Message-ID: References: <1498130534-26568-1-git-send-email-root@ip-172-31-39-62.us-west-2.compute.internal> <1498130534-26568-3-git-send-email-root@ip-172-31-39-62.us-west-2.compute.internal> User-Agent: Alpine 2.20 (DEB 67 2015-01-07) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1395 Lines: 58 On Thu, 22 Jun 2017, root wrote: > @@ -962,6 +962,7 @@ __visible void __irq_entry smp_apic_timer_interrupt(struct pt_regs *regs) > * interrupt lock, which is the WrongThing (tm) to do. > */ > entering_ack_irq(); > + check_poll(); No way, that we sprinkle this function into every interrupt hotpath. There are enough genuine ways to do that w/o touching a gazillion of files. > #ifdef CONFIG_HYPERVISOR_GUEST > +static unsigned int grow_poll_ns(unsigned int old, unsigned int grow, > + unsigned int max) > +{ > + unsigned int val; > + > + /* 10us as base poll duration */ > + if (old == 0 && grow) > + return 10000; > + > + val = old * grow; > + if (val > max) > + val = max; > + > + return val; > +} > + > +static unsigned int shrink_poll_ns(unsigned int old, unsigned int shrink) > +{ > + if (shrink == 0) > + return 0; > + > + return old / shrink; > +} > + > +void check_poll(void) > +{ > + unsigned int val, poll_duration; > + unsigned long begin_ns, now_ns; > + > + if (!poll_threshold_ns) > + return; If at all then this needs to be a static key based decision. > + > + begin_ns = this_cpu_read(poll_begin_ns); > + /* Not from halt state */ > + if (!begin_ns) > + return; If you integrate this stuff into the proper place, then the whole mess goes away. We really do not need another facility to track idle state. We have enough already, really. Thanks, tglx