Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp1743295ybl; Sat, 11 Jan 2020 01:55:47 -0800 (PST) X-Google-Smtp-Source: APXvYqzMYIZB/RrMu+/imvl8JxGW8KTwnH3Ox0wmId4nfWb2QvTEUefL/+LUB+U7FFrk2QmEJrH8 X-Received: by 2002:a05:6830:121a:: with SMTP id r26mr6281036otp.225.1578736547344; Sat, 11 Jan 2020 01:55:47 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1578736547; cv=none; d=google.com; s=arc-20160816; b=DCW2s+fO6msyuctx4pKB+dEOiVXYNGglybAyRHQqqIUF/HSIF196fSIGccnAeKc27O jxlx+oCeCHmF1/6Nns7P6ZeZDX/HCDTYT4K77tF5bqF5Id1umI59XFi+H5RdrU1/rpxo 2VZCJLvjiaQmyKAQQCSMJICwF9Op89q/OXvp0/5viPSw7gEom/y097NFNcQErkKnMwwJ B/Oi1MIAGsbwfZb5rk+p7KvDiGK+ACqUmPlTHqbMlj5GlfBxz8u+ItpM3CM0va6VlZ5R CJkBZDeUbtVEr1rVp0rb65x3UJUNYf0v4COho/841kYuBRSRlk3dsNy9FNWIVWiAPaL0 lnDA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature; bh=rRx0oxYUmYgrX33kOC4ocpdLEvnNwi616mBkkVOTRWU=; b=IOsoVmCJUCsVi7xgamD9CsJgyhFKs2bqA1EZ5vMNnyPqhiiF9q9P5YYzuShApDZ7G9 Q+eXClCmfNZD9SXZHemgRb2ZwyGnEoL/w2YaXIHpD8sj3SyQhsbdQYCi5zN8jvHBkFti 4sEZan9d6l3skRiVT7xDatQV+bcPet7LxPu832IdNTGdoy2r/wv2RM+XvGbJ237K/J4+ W64Xw1T1gMODobxzyRPeu1eV57JSv3G6U925L55envv3vJkM984r1ZAkgcl02u8BW+zS ZwKvoCkNww0iMRkyBgUNUhlmwlJZqh6fdxWGqXWXV4GSoecSZjuSZf8S4ZrxrEt302eQ rnew== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=b3WbOO1N; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id s16si2988460oih.4.2020.01.11.01.55.36; Sat, 11 Jan 2020 01:55:47 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=b3WbOO1N; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729042AbgAKJxy (ORCPT + 99 others); Sat, 11 Jan 2020 04:53:54 -0500 Received: from us-smtp-delivery-1.mimecast.com ([207.211.31.120]:26916 "EHLO us-smtp-1.mimecast.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1728917AbgAKJxx (ORCPT ); Sat, 11 Jan 2020 04:53:53 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1578736432; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:in-reply-to:in-reply-to:references:references; bh=rRx0oxYUmYgrX33kOC4ocpdLEvnNwi616mBkkVOTRWU=; b=b3WbOO1Nw7RpJQWLu7l7qSoTHNctWhOMM2WjiCW2/S26GiYIP56jYPXF9cOQZ9X6OkPRif 0CVy/fBjSUkJ7rg8rX1o//kLyUr8ZJ1NRZxckpB1mYCjXO0QptVf/AY8AcEWBrwuUbY4fV ktooM2UCRrbRJl3jbCEsYAexTJFch/Q= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-203-3HZU6Wq0Mmifg7xM_EVMDg-1; Sat, 11 Jan 2020 04:53:45 -0500 X-MC-Unique: 3HZU6Wq0Mmifg7xM_EVMDg-1 Received: from smtp.corp.redhat.com (int-mx08.intmail.prod.int.phx2.redhat.com [10.5.11.23]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 7183C801E78; Sat, 11 Jan 2020 09:53:42 +0000 (UTC) Received: from intel-purley-fpgabmp-02.ml3.eng.bos.redhat.com (intel-purley-fpgabmp-02.ml3.eng.bos.redhat.com [10.19.176.206]) by smtp.corp.redhat.com (Postfix) with ESMTP id D5A7F272A3; Sat, 11 Jan 2020 09:53:41 +0000 (UTC) From: Scott Wood To: Peter Zijlstra , Frederic Weisbecker , Thomas Gleixner , Ingo Molnar Cc: linux-kernel@vger.kernel.org, Scott Wood Subject: [PATCH v2 2/2] timers/nohz: Update nohz load in remote tick Date: Sat, 11 Jan 2020 04:53:39 -0500 Message-Id: <1578736419-14628-3-git-send-email-swood@redhat.com> In-Reply-To: <1578736419-14628-1-git-send-email-swood@redhat.com> References: <1578736419-14628-1-git-send-email-swood@redhat.com> X-Scanned-By: MIMEDefang 2.84 on 10.5.11.23 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: "Peter Zijlstra (Intel)" The way loadavg is tracked during nohz only pays attention to the load upon entering nohz. This can be particularly noticeable if full nohz is entered while non-idle, and then the cpu goes idle and stays that way for a long time. Use the remote tick to ensure that full nohz cpus report their deltas within a reasonable time. Signed-off-by: Peter Zijlstra (Intel) [swood: added changelog and removed recheck of stopped tick] Signed-off-by: Scott Wood --- include/linux/sched/nohz.h | 2 ++ kernel/sched/core.c | 4 +++- kernel/sched/loadavg.c | 33 +++++++++++++++++++++++---------- 3 files changed, 28 insertions(+), 11 deletions(-) diff --git a/include/linux/sched/nohz.h b/include/linux/sched/nohz.h index 1abe91ff6e4a..6d67e9a5af6b 100644 --- a/include/linux/sched/nohz.h +++ b/include/linux/sched/nohz.h @@ -15,9 +15,11 @@ static inline void nohz_balance_enter_idle(int cpu) { } #ifdef CONFIG_NO_HZ_COMMON void calc_load_nohz_start(void); +void calc_load_nohz_remote(struct rq *rq); void calc_load_nohz_stop(void); #else static inline void calc_load_nohz_start(void) { } +static inline void calc_load_nohz_remote(struct rq *rq) { } static inline void calc_load_nohz_stop(void) { } #endif /* CONFIG_NO_HZ_COMMON */ diff --git a/kernel/sched/core.c b/kernel/sched/core.c index dfb8ea801700..2e4a505e48af 100644 --- a/kernel/sched/core.c +++ b/kernel/sched/core.c @@ -3676,6 +3676,7 @@ static void sched_tick_remote(struct work_struct *work) if (cpu_is_offline(cpu)) goto out_unlock; + curr = rq->curr; update_rq_clock(rq); if (!is_idle_task(curr)) { @@ -3688,10 +3689,11 @@ static void sched_tick_remote(struct work_struct *work) } curr->sched_class->task_tick(rq, curr, 0); + calc_load_nohz_remote(rq); out_unlock: rq_unlock_irq(rq, &rf); - out_requeue: + /* * Run the remote tick once per second (1Hz). This arbitrary * frequency is large enough to avoid overload but short enough diff --git a/kernel/sched/loadavg.c b/kernel/sched/loadavg.c index 28a516575c18..de22da666ac7 100644 --- a/kernel/sched/loadavg.c +++ b/kernel/sched/loadavg.c @@ -231,16 +231,11 @@ static inline int calc_load_read_idx(void) return calc_load_idx & 1; } -void calc_load_nohz_start(void) +static void calc_load_nohz_fold(struct rq *rq) { - struct rq *this_rq = this_rq(); long delta; - /* - * We're going into NO_HZ mode, if there's any pending delta, fold it - * into the pending NO_HZ delta. - */ - delta = calc_load_fold_active(this_rq, 0); + delta = calc_load_fold_active(rq, 0); if (delta) { int idx = calc_load_write_idx(); @@ -248,6 +243,24 @@ void calc_load_nohz_start(void) } } +void calc_load_nohz_start(void) +{ + /* + * We're going into NO_HZ mode, if there's any pending delta, fold it + * into the pending NO_HZ delta. + */ + calc_load_nohz_fold(this_rq()); +} + +/* + * Keep track of the load for NOHZ_FULL, must be called between + * calc_load_nohz_{start,stop}(). + */ +void calc_load_nohz_remote(struct rq *rq) +{ + calc_load_nohz_fold(rq); +} + void calc_load_nohz_stop(void) { struct rq *this_rq = this_rq(); @@ -268,7 +281,7 @@ void calc_load_nohz_stop(void) this_rq->calc_load_update += LOAD_FREQ; } -static long calc_load_nohz_fold(void) +static long calc_load_nohz_read(void) { int idx = calc_load_read_idx(); long delta = 0; @@ -323,7 +336,7 @@ static void calc_global_nohz(void) } #else /* !CONFIG_NO_HZ_COMMON */ -static inline long calc_load_nohz_fold(void) { return 0; } +static inline long calc_load_nohz_read(void) { return 0; } static inline void calc_global_nohz(void) { } #endif /* CONFIG_NO_HZ_COMMON */ @@ -346,7 +359,7 @@ void calc_global_load(unsigned long ticks) /* * Fold the 'old' NO_HZ-delta to include all NO_HZ CPUs. */ - delta = calc_load_nohz_fold(); + delta = calc_load_nohz_read(); if (delta) atomic_long_add(delta, &calc_load_tasks); -- 1.8.3.1