Received: by 2002:a05:6a10:a841:0:0:0:0 with SMTP id d1csp405060pxy; Thu, 22 Apr 2021 05:03:23 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyfIaRFOxMkx3OfXzhnr5WmUR9z1uFO8vKmNEaamYfoSxntsY4oFdYwBPNqH1rgELJWKRHg X-Received: by 2002:a17:906:7188:: with SMTP id h8mr3071205ejk.227.1619093003627; Thu, 22 Apr 2021 05:03:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1619093003; cv=none; d=google.com; s=arc-20160816; b=PnM/eMX+qRXdV/cjEEBle3fSdtMb+J2Ltbdq0XBu1E5Jd8T182baotj0Kwz1Equ44O AB2SBHsmbKdOfzDmnhqc7vd0WzFNnLsdDdsIHMfmtzbZrzw1UmY/fwlq0+B5WmeFZBjp erwAC3tSXg1mrEL88XLElwGgS/JI9TJGSkkh+gLU4YzmUz2uP/GqqqSVgt08+nDFTpkN 5wWD+eTBA4h8Cv86C7FEdf72+wyGTWdXIEFjMJavvLxSFTt13L8D+mEg3TE9J5eOEo9a RRbMTnHuYzd0DcuzQEiNOvtf3tkdDQzwYndhh8c5Xc9Vg+GbV9HLygdp7Z6h/BqYc7ru tR/Q== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=80h0nY0LBQjER/+7zh00MeBaRX9kTd+HYgFgr6cDj1Q=; b=X/UG8xyA5iLN73ja5Ro/w2lRhHVjARN0gs/Y3N5Lt3AROireHCWz3JR2SwqpEj4a+M lvt3KjGzvgZRva60WjHVjG0ED4lQP/G+0+0ujcGrbZXmfmRZJMnnTg2X5o3jomQgO/Wc gtzH60jaQvFRXjsymCuh0F4FfAEfIqFicVBgtbueeAkNwbIuzoGdPhvAcFBLwad+MwV0 avQ4lIlrWW42aqtFWx3fI6V7ZqlkeTfdYLZJDSYTzLJFAIPMFk3ogdm2qr7+F1W2dVgt bZMoa/xFe22yfK3fMM8hR3u842HeVirwkX+P8aDpqCYB4c9a9uDRrtaGLVS4PCGxHU6d Ug+g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=XpIdIxw0; 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=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id j16si2653246edj.357.2021.04.22.05.02.58; Thu, 22 Apr 2021 05:03:23 -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; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=XpIdIxw0; 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=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236001AbhDVMCl (ORCPT + 99 others); Thu, 22 Apr 2021 08:02:41 -0400 Received: from mail.kernel.org ([198.145.29.99]:56252 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235957AbhDVMCk (ORCPT ); Thu, 22 Apr 2021 08:02:40 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id E03D861164; Thu, 22 Apr 2021 12:02:03 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1619092925; bh=rkCq6YOyLHab1KE6vI7NiCXSOcxoEXY9r+QmW7Dd6DE=; h=From:To:Cc:Subject:Date:From; b=XpIdIxw0hzCja5ovJ6LOCRuVYlPr9Bzbsk1Fz6YCfMyFMk1hJNSY/ls3vhmcVpstc U1iVTyg5FBOXsfNayGUx4ssoaNiASgxQUW1zmb0+Yofan5d3N7VF9kx4jO9cGCv0Cu pD9rv43vWfQr+Vjtqvy37ebs023Bl3FehjVals2cpf9E5T18ZEOvVDOOW/13RKYFT0 PvVcIBvcIAfNk5Kf/Qrs05F+a9Tunmn4kG3rkvq5fE9g5shY6Y7/yaRaoGOtI4wDze STc1mNvzRMhzaJJFr7u5Zv6Z5AC7I0/fuZ3YF/GKlpdwQFjB/+U0bFaIje9XInq4y3 KlBCP6DI+0cVw== From: Frederic Weisbecker To: Peter Zijlstra , Thomas Gleixner Cc: LKML , Frederic Weisbecker , "Rafael J . Wysocki" , Yunfeng Ye , Marcelo Tosatti Subject: [PATCH 0/8] tick/nohz updates v2 Date: Thu, 22 Apr 2021 14:01:50 +0200 Message-Id: <20210422120158.33629-1-frederic@kernel.org> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This set brings various interrupts reducing while running in nohz_full: * Remove one tick interrupt while waking up from idle to a user task running in nohz_full mode. (thanks Yunfeng Ye). * Reduce IPIs when running posix cpu timers, only relevant tasks should be interrupted now instead of all tick nohz CPUs (thanks Marcelo) And a few other cleanups and improvement. Changes since last take: - Remove "tick/nohz: Prevent tick_nohz_get_sleep_length() from returning negative value" since the issue has been solve on the cpuidle side. - Remove "timer: Report ignored local enqueue in nohz mode" and hope that objtool will spot the future offenders. - Changed "tick/nohz: Add tick_nohz_full_this_cpu()" and provide with "tick/nohz: Evaluate the CPU expression after the static key" (please add your SOB on this one). git://git.kernel.org/pub/scm/linux/kernel/git/frederic/linux-dynticks.git timers/nohz-v2 HEAD: 4546d43a9938f6c7eec024f005cb240b8b73637b Thanks, Frederic --- Frederic Weisbecker (3): tick/nohz: Remove superflous check for CONFIG_VIRT_CPU_ACCOUNTING_NATIVE tick/nohz: Update nohz_full Kconfig help tick/nohz: Only wakeup a single target cpu when kicking a task Marcelo Tosatti (2): tick/nohz: Change signal tick dependency to wakeup CPUs of member tasks tick/nohz: Kick only _queued_ task whose tick dependency is updated Yunfeng Ye (2): tick/nohz: Conditionally restart tick on idle exit tick/nohz: Update idle_exittime on actual idle exit Peter Zijlstra (1): tick/nohz: Evaluate the CPU expression after the static key include/linux/sched.h | 2 + include/linux/tick.h | 26 +++++---- kernel/sched/core.c | 5 ++ kernel/time/Kconfig | 11 ++-- kernel/time/posix-cpu-timers.c | 4 +- kernel/time/tick-sched.c | 122 +++++++++++++++++++++++++++++------------ 6 files changed, 117 insertions(+), 53 deletions(-)