Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp4925262pxj; Wed, 12 May 2021 16:44:55 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwmXnXLPbKwFuAiUDJljxOFBq3Q/SIa4PC3jlf+pT+WJx2gnkM6v84VtI6uA+eXGjKXQtC3 X-Received: by 2002:a02:b717:: with SMTP id g23mr36182789jam.109.1620863095072; Wed, 12 May 2021 16:44:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620863095; cv=none; d=google.com; s=arc-20160816; b=hmjhmjRky4FUxzfDU8+0GqNsgLr/BHPl08Nn06edGloFJq3EuALg4tVNT2+71i6tdi M2qEEbckMXo31CI4XXjrx+ROx6D4nbcrThmsSABYm1lp1TMEV14WI1clNCnqxIln+Vce iUcavCgdHxivT0e/6zTr4u9uzEIMFj4OSuAxijTDqfi10jdXxhQALnUla4LZoNB7ZYM+ IJyzH3n1D6Ew1WNXoxzF76U8fmMxdC8fimb7mkoz5Ubp74SZ/jdNvh9G1ZSKgpp6wm+a 96pg+fSBqfSQWc8G4e9SfmGdn2JkZqfy7dIQ9ozse6/Eceqrf1+VDZfZLSHogjWlJdO0 QwWA== 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=bu2zwixmGXtGDZ/QKFC/nfeE0n9UJzCf4ODg+FlGFiE=; b=MRnip3hMKBpVoaKBvYoirBzmSAaqiiK/Stw7otujQrNvLv4K+ixfTcHNShtsBy26CK 5GMOrU3Kjimr0AtEN3fVjy4UrDB30P7ONUrzvAlz0/P/oc0PJSvTRFrCJ6Yrh3Nu9USz UyQJzqE4P1oWMlSs9okexFZQ3dgF9d+kwIFUlMscVECz+GfS7j76Jy/rNbH3Wv2p9Noh aabYMwFImZIkwaHhWje7Mxoxf7Fvb+R3uLLPNpzQMTaJPhc341JsM9XhcdlSf/jnrF2p 9dzBAJOjKyvuMIYZUq08/xJ/4cBShL1LsGsm2vZJtaWKqpPqoOlzaLvJtltmd+JDycNf xA9g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=jX780p4F; 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 s19si1270184ilt.149.2021.05.12.16.44.42; Wed, 12 May 2021 16:44:55 -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=jX780p4F; 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 S241219AbhELXnC (ORCPT + 99 others); Wed, 12 May 2021 19:43:02 -0400 Received: from mail.kernel.org ([198.145.29.99]:52026 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S243806AbhELXbT (ORCPT ); Wed, 12 May 2021 19:31:19 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 123E061420; Wed, 12 May 2021 23:29:51 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1620862193; bh=dxV3iEVZ1YkOcnmWOfNT7CrIA2T5269MjJ9rvtPFthY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=jX780p4FdWsV45VR3mel0rV10E/GybpCVEaTRUTHuP/lhMqF452pqw99+ylC/MbKX b0ltvayISW3VV9umiOT+vNKFcyAsjbZMC/TSxRvvvAx4ZwRLZnD1uaFUu/1YZV2Tuu x7Y1JGrhIzzAe6nAYnnMBxJFEYKsdzStlcOx3MUELcjsN7xZUpHEFrRUgFiWtvOI5/ OoBTKWKFxyrhaRRSPDlcC/3fHVn3V3RSwpDpWDUZTLR1AeH+eqJs5mhUvzJR1y7FnW cxZF3lQSBi+8vimtMlAM6yDSAr0jUKdSWY48CmDgNG6Phoyh/81RZXo1hsfltjyy/i X+mi9JHj/XqDQ== From: Frederic Weisbecker To: Thomas Gleixner , Ingo Molnar Cc: LKML , Marcelo Tosatti , "Rafael J . Wysocki" , Peter Zijlstra , Yunfeng Ye , Frederic Weisbecker Subject: [PATCH 07/10] tick/nohz: Change signal tick dependency to wakeup CPUs of member tasks Date: Thu, 13 May 2021 01:29:21 +0200 Message-Id: <20210512232924.150322-8-frederic@kernel.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20210512232924.150322-1-frederic@kernel.org> References: <20210512232924.150322-1-frederic@kernel.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Marcelo Tosatti Rather than waking up all nohz_full CPUs on the system, only wakeup the target CPUs of member threads of the signal. Reduces interruptions to nohz_full CPUs. Acked-by: Peter Zijlstra Signed-off-by: Marcelo Tosatti Cc: Yunfeng Ye Cc: Thomas Gleixner Cc: Rafael J. Wysocki Signed-off-by: Frederic Weisbecker --- include/linux/tick.h | 8 ++++---- kernel/time/posix-cpu-timers.c | 4 ++-- kernel/time/tick-sched.c | 15 +++++++++++++-- 3 files changed, 19 insertions(+), 8 deletions(-) diff --git a/include/linux/tick.h b/include/linux/tick.h index 2258984a0e8a..0bb80a7f05b9 100644 --- a/include/linux/tick.h +++ b/include/linux/tick.h @@ -211,7 +211,7 @@ extern void tick_nohz_dep_set_task(struct task_struct *tsk, enum tick_dep_bits bit); extern void tick_nohz_dep_clear_task(struct task_struct *tsk, enum tick_dep_bits bit); -extern void tick_nohz_dep_set_signal(struct signal_struct *signal, +extern void tick_nohz_dep_set_signal(struct task_struct *tsk, enum tick_dep_bits bit); extern void tick_nohz_dep_clear_signal(struct signal_struct *signal, enum tick_dep_bits bit); @@ -256,11 +256,11 @@ static inline void tick_dep_clear_task(struct task_struct *tsk, if (tick_nohz_full_enabled()) tick_nohz_dep_clear_task(tsk, bit); } -static inline void tick_dep_set_signal(struct signal_struct *signal, +static inline void tick_dep_set_signal(struct task_struct *tsk, enum tick_dep_bits bit) { if (tick_nohz_full_enabled()) - tick_nohz_dep_set_signal(signal, bit); + tick_nohz_dep_set_signal(tsk, bit); } static inline void tick_dep_clear_signal(struct signal_struct *signal, enum tick_dep_bits bit) @@ -288,7 +288,7 @@ static inline void tick_dep_set_task(struct task_struct *tsk, enum tick_dep_bits bit) { } static inline void tick_dep_clear_task(struct task_struct *tsk, enum tick_dep_bits bit) { } -static inline void tick_dep_set_signal(struct signal_struct *signal, +static inline void tick_dep_set_signal(struct task_struct *tsk, enum tick_dep_bits bit) { } static inline void tick_dep_clear_signal(struct signal_struct *signal, enum tick_dep_bits bit) { } diff --git a/kernel/time/posix-cpu-timers.c b/kernel/time/posix-cpu-timers.c index 3bb96a8b49c9..29a5e54e6e10 100644 --- a/kernel/time/posix-cpu-timers.c +++ b/kernel/time/posix-cpu-timers.c @@ -523,7 +523,7 @@ static void arm_timer(struct k_itimer *timer, struct task_struct *p) if (CPUCLOCK_PERTHREAD(timer->it_clock)) tick_dep_set_task(p, TICK_DEP_BIT_POSIX_TIMER); else - tick_dep_set_signal(p->signal, TICK_DEP_BIT_POSIX_TIMER); + tick_dep_set_signal(p, TICK_DEP_BIT_POSIX_TIMER); } /* @@ -1358,7 +1358,7 @@ void set_process_cpu_timer(struct task_struct *tsk, unsigned int clkid, if (*newval < *nextevt) *nextevt = *newval; - tick_dep_set_signal(tsk->signal, TICK_DEP_BIT_POSIX_TIMER); + tick_dep_set_signal(tsk, TICK_DEP_BIT_POSIX_TIMER); } static int do_cpu_nanosleep(const clockid_t which_clock, int flags, diff --git a/kernel/time/tick-sched.c b/kernel/time/tick-sched.c index 1991adf5a922..800719ea4045 100644 --- a/kernel/time/tick-sched.c +++ b/kernel/time/tick-sched.c @@ -444,9 +444,20 @@ EXPORT_SYMBOL_GPL(tick_nohz_dep_clear_task); * Set a per-taskgroup tick dependency. Posix CPU timers need this in order to elapse * per process timers. */ -void tick_nohz_dep_set_signal(struct signal_struct *sig, enum tick_dep_bits bit) +void tick_nohz_dep_set_signal(struct task_struct *tsk, + enum tick_dep_bits bit) { - tick_nohz_dep_set_all(&sig->tick_dep_mask, bit); + int prev; + struct signal_struct *sig = tsk->signal; + + prev = atomic_fetch_or(BIT(bit), &sig->tick_dep_mask); + if (!prev) { + struct task_struct *t; + + lockdep_assert_held(&tsk->sighand->siglock); + __for_each_thread(sig, t) + tick_nohz_kick_task(t); + } } void tick_nohz_dep_clear_signal(struct signal_struct *sig, enum tick_dep_bits bit) -- 2.25.1