Received: by 10.223.185.111 with SMTP id b44csp105848wrg; Fri, 9 Mar 2018 01:51:05 -0800 (PST) X-Google-Smtp-Source: AG47ELs7B0baZcO4LS4lwqsTQL/jBeb8yNMS82wuTaXzbE/qekFbhGOoXY7efTQVAkoL2qwXmqKk X-Received: by 10.101.65.131 with SMTP id a3mr23331620pgq.270.1520589065468; Fri, 09 Mar 2018 01:51:05 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1520589065; cv=none; d=google.com; s=arc-20160816; b=oUKB9S0bwL1yKPWrvERw7SPlYlS+mt2kmPr/JLS9DMVNpOVp9h2nrdNNs12a3OB31+ 2Nb/xS6iVZb28G9P4grPND/6ZA317iK46UWtJlR12yTnfwh+Ts2sfgS0jfkUIc7den1k ionMCVVsJE9jGDGFnQzX1BayQnBvffn6krJGGeTCc5IiHmrBIiak3BXr4JFRXe8beT8d oehVY28TbnosmH0tv0yuEUEM290vuIaGR9dVL6fdOi3O0ZQbZBE7nHV7jb+2dRu5JDKf c+FLAar2Mm2ttnU05nrUFQf8wt258JEt/EGJndv4tOEz5zyrKOUxMO6A8fidQUqJf34p IAPg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:arc-authentication-results; bh=mp5m4foBO7ZU3ijFKdW/BBXu7aF1kF8p9gzwf/O3oBs=; b=fnrZ7lWBUKGn7igConpP12p6alZuM5gXcVbZgdYHHn4AXnPSR0fWIgoOHwEFmUmhXE +O+CcDlTncXhgP3ST52Nsm9wlAnSfcL/0QxpgOBJ9Ja1mGhY7QAbPYlZwED99f9A5+VV H/2ta1MwRDD7MkxFycu1Y74fBymlNUgD08OOP6YjyCng8EMC81VHWg5dPFqT7uLALxo5 XrUE4JR6Ia+JwHHNwVuPhlcA/lQFu/naBJ87fPCxtkMTBPn2YX0xLbCZe9h7dO9UQ754 EjMXsSGUj/ueWv430kxZLxZpLA0i/0LrNE+s7NsUZn6fb9AWNHeYtXGlKNYZigVX4fq1 1Weg== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q9-v6si587926plr.110.2018.03.09.01.50.51; Fri, 09 Mar 2018 01:51:05 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751224AbeCIJtU (ORCPT + 99 others); Fri, 9 Mar 2018 04:49:20 -0500 Received: from cloudserver094114.home.pl ([79.96.170.134]:43512 "EHLO cloudserver094114.home.pl" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751056AbeCIJsx (ORCPT ); Fri, 9 Mar 2018 04:48:53 -0500 Received: from 79.184.254.228.ipv4.supernova.orange.pl (79.184.254.228) (HELO aspire.rjw.lan) by serwer1319399.home.pl (79.96.170.134) with SMTP (IdeaSmtpServer 0.83) id 16c0e988aebdac99; Fri, 9 Mar 2018 10:48:51 +0100 From: "Rafael J. Wysocki" To: Peter Zijlstra , Linux PM , Frederic Weisbecker Cc: Thomas Gleixner , Paul McKenney , Thomas Ilsche , Doug Smythies , Rik van Riel , Aubrey Li , Mike Galbraith , LKML Subject: [RFC/RFT][PATCH v3 0/6] sched/cpuidle: Idle loop rework Date: Fri, 09 Mar 2018 10:34:27 +0100 Message-ID: <2450532.XN8DODrtDf@aspire.rjw.lan> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi All, Thanks a lot for the discussion and testing so far! This is a total respin of the whole series, so please look at it afresh. Patches 2 and 3 are the most similar to their previous versions, but still they are different enough. The summary below still applies: On Sunday, March 4, 2018 11:21:30 PM CET Rafael J. Wysocki wrote: > > The problem is that if we stop the sched tick in > tick_nohz_idle_enter() and then the idle governor predicts short idle > duration, we lose regardless of whether or not it is right. > > If it is right, we've lost already, because we stopped the tick > unnecessarily. If it is not right, we'll lose going forward, because > the idle state selected by the governor is going to be too shallow and > we'll draw too much power (that has been reported recently to actually > happen often enough for people to care). > > This patch series is an attempt to improve the situation and the idea > here is to make the decision whether or not to stop the tick deeper in > the idle loop and in particular after running the idle state selection > in the path where the idle governor is invoked. This way the problem > can be avoided, because the idle duration predicted by the idle governor > can be used to decide whether or not to stop the tick so that the tick > is only stopped if that value is large enough (and, consequently, the > idle state selected by the governor is deep enough). > > The series tires to avoid adding too much new code, rather reorder the > existing code and make it more fine-grained. Patch 1 prepares the tick-sched code for the subsequent modifications and it doesn't change the code's functionality (at least not intentionally). Patch 2 starts pushing the tick stopping decision deeper into the idle loop, but it is limited to do_idle() and tick_nohz_irq_exit(). Patch 3 makes cpuidle_idle_call() decide whether or not to stop the tick and sets the stage for the subsequent changes. Patch 4 adds a bool pointer argument to cpuidle_select() and the ->select governor callback allowing them to return a "nohz" hint on whether or not to stop the tick to the caller. It also adds code to decide what value to return as "nohz" to the menu governor. Patch 5 reorders the idle state selection with respect to the stopping of the tick and causes the additional "nohz" hint from cpuidle_select() to be used for deciding whether or not to stop the tick. Patch 6 causes the menu governor to refine the state selection in case the tick is not going to be stopped and the already selected state may not fit before the next tick time. And the two paragraphs below still apply: > I have tested these patches on a couple of machines, including the very laptop > I'm sending them from, without any obvious issues, but please give them a go > if you can, especially if you have an easy way to reproduce the problem they > are targeting. > > The above said, this is just RFC, so no pets close to the machines running it, > please. The patches are on top of 4.16-rc4 (if you need a git branch with them for easier testing, please let me know). Thanks, Rafael