Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp2454731pxa; Mon, 3 Aug 2020 17:02:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwnzcKH2z7La9Q9V0vQsTAEaVzEd9K4ORiBEST9DQForbOSRxmdBhuijEowBDhRBSDxJFDB X-Received: by 2002:a17:906:388b:: with SMTP id q11mr19903435ejd.100.1596499359621; Mon, 03 Aug 2020 17:02:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1596499359; cv=none; d=google.com; s=arc-20160816; b=qSp5QvGshrMXW0ksrNfr3Rgv5c3c/quhEEOPY/bn0PjZz+yJ9veZ+b+o09VGSp3Ltl CtpP915W2JgdqM7P8UZD/HJSKGRrX5wla1Xur4qqlyMhOIHd9wTcPoeFxTu0hAGLqbaa 77VxlrPvvDyplIgy/rpUYHQo1KS4VQGD6o1m6DJvD1zqXkp5AKmIHkleAh7sKvHssqxj Knf7ujv8iRJoflKHYnFrpv3ABtqEjRT0+TYH62EIqrvfGCuvR6KFYSYN63gQBBFmkQGy 9UdlcJ3DrShv6spdHQzdhTZIrOUJmxmYE8PwTxFmrr75zfZ0UO4hZVgPzm/Qy7kDtY+l DqHw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:in-reply-to :subject:cc:to:from:user-agent:references; bh=wIDakq5nz1RMjET9mR6ft128gt+j5LFbk4tqkBaQ/AA=; b=syPCcGtCJ4t/JjvYtChlmAncoh5MqKjKMyhzWeYPU0Yl9rzmg5kWAjnTBpLCtxvPI/ RRCj7MWqqVjvJuGaowrisi5N3ZMQROdEVquohRgtIHbCgqOvYG2Hd6RRNcNbB2VOkvYB FxCFRNusVUuRaJ3lMMy+XFUgpHJ9yjzCgP012hPMWr/KiEGYItwWmM3RaajnqLHKmvrT 6NsVNH7BgeD8PJBUaKXKhxkIQWkOOBNH+23Xk25lH4n3f5S5Bq/jtUYGqZQiwgCw8IAk 3mIpkEhXXNLiyJsnmJ5kMM6xesONiDMOrFpL96x+uIPggGJDIsXj8eOsfexS0U0z6gKa fccQ== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id mh23si9450015ejb.493.2020.08.03.17.02.16; Mon, 03 Aug 2020 17:02:39 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729549AbgHCX71 (ORCPT + 99 others); Mon, 3 Aug 2020 19:59:27 -0400 Received: from foss.arm.com ([217.140.110.172]:35568 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729146AbgHCX70 (ORCPT ); Mon, 3 Aug 2020 19:59:26 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 0F6131FB; Mon, 3 Aug 2020 16:59:26 -0700 (PDT) Received: from e113632-lin (e113632-lin.cambridge.arm.com [10.1.194.46]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 46F193F71F; Mon, 3 Aug 2020 16:59:24 -0700 (PDT) References: <20200729033934.22349-1-alison.wang@nxp.com> <877dumbtoi.fsf@kurt> <20200729094943.lsmhsqlnl7rlnl6f@skbuf> <87mu3ho48v.fsf@kurt> <20200730082228.r24zgdeiofvwxijm@skbuf> <873654m9zi.fsf@kurt> <87lfiwm2bj.fsf@nanos.tec.linutronix.de> <20200803114112.mrcuupz4ir5uqlp6@skbuf> <87d047n4oh.fsf@nanos.tec.linutronix.de> <875z9zmt4i.fsf@nanos.tec.linutronix.de> User-agent: mu4e 0.9.17; emacs 26.3 From: Valentin Schneider To: Thomas Gleixner Cc: Vladimir Oltean , Kurt Kanzenbach , Alison Wang , catalin.marinas@arm.com, will@kernel.org, paulmck@kernel.org, mw@semihalf.com, leoyang.li@nxp.com, vladimir.oltean@nxp.com, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Anna-Maria Gleixner , Peter Zijlstra Subject: Re: [RFC PATCH] arm64: defconfig: Disable fine-grained task level IRQ time accounting In-reply-to: <875z9zmt4i.fsf@nanos.tec.linutronix.de> Date: Tue, 04 Aug 2020 00:59:19 +0100 Message-ID: MIME-Version: 1.0 Content-Type: text/plain Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 03/08/20 20:22, Thomas Gleixner wrote: > Valentin, > > Valentin Schneider writes: >> On 03/08/20 16:13, Thomas Gleixner wrote: >>> Vladimir Oltean writes: >>>>> 1) When irq accounting is disabled, RT throttling kicks in as >>>>> expected. >>>>> >>>>> 2) With irq accounting the RT throttler does not kick in and the RCU >>>>> stall/lockups happen. >>>> What is this telling us? >>> >>> It seems that the fine grained irq time accounting affects the runtime >>> accounting in some way which I haven't figured out yet. >>> >> >> With IRQ_TIME_ACCOUNTING, rq_clock_task() will always be incremented by a >> lesser-or-equal value than when not having the option; you start with the >> same delta_exec but slice some for the IRQ accounting, and leave the rest >> for the rq_clock_task() (+paravirt). >> >> IIUC this means that if you spend e.g. 10% of the time in IRQ and 90% of >> the time running the stress-ng RT tasks, despite having RT tasks hogging >> the entirety of the "available time" it is still only 90% runtime, which is >> below the 95% default and the throttling doesn't happen. > > totaltime = irqtime + tasktime > > Ignoring irqtime and pretending that totaltime is what the scheduler > can control and deal with is naive at best. > Agreed, however AFAICT rt_time is only incremented by rq_clock_task() deltas, which don't include IRQ time with IRQ_TIME_ACCOUNTING=y. That would then be directly compared to the sysctl runtime. Adding some prints in sched_rt_runtime_exceeded() and running this test case on my Juno, I get: # IRQ_TIME_ACCOUNTING=y cpu=2 rt_time=713455220 runtime=950000000 rq->avg_irq.util_avg=265 (rt_time oscillates between [70.1e7, 75.1e7]; avg_irq between [220, 270]) # IRQ_TIME_ACCOUNTING=n cpu=2 rt_time=963035300 runtime=949951811 (rt_time oscillates between [94.1e7, 96.1e7]; Throttling happens for IRQ_TIME_ACCOUNTING=n and doesn't for IRQ_TIME_ACCOUNTING=y - clearly the accounted rt_time isn't high enough for that to happen, and it does look like what is missing in rt_time (or what should be subtracted from the available runtime) is there in the avg_irq. Or is that another case where I shouldn't have been writing emails at this hour? > Thanks, > > tglx