Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751521AbbLURXB (ORCPT ); Mon, 21 Dec 2015 12:23:01 -0500 Received: from mail-ob0-f181.google.com ([209.85.214.181]:35694 "EHLO mail-ob0-f181.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751233AbbLURW7 (ORCPT ); Mon, 21 Dec 2015 12:22:59 -0500 MIME-Version: 1.0 In-Reply-To: References: <566D3EC0.50408@ladisch.de> Date: Mon, 21 Dec 2015 22:52:58 +0530 Message-ID: Subject: Re: Ques: [kernel/time/*] Is there any disadvantage in using sleep_range for more than 20ms delay ? From: Aniroop Mathur To: Thomas Gleixner Cc: Clemens Ladisch , John Stultz , a.mathur@samsung.com, "linux-kernel@vger.kernel.org" Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2764 Lines: 72 On Tue, Dec 15, 2015 at 1:23 AM, Thomas Gleixner wrote: > On Tue, 15 Dec 2015, Aniroop Mathur wrote: >> On Sun, Dec 13, 2015 at 3:17 PM, Clemens Ladisch wrote: >> > Aniroop Mathur wrote: >> >>> 2. If we use msleep(40), is it possible that process could wake up after >> >>> 60 ms or 70 ms or 100 ms or more ? >> > >> > Yes, if lots of other processes compete for the CPU. >> >> You mean to say "yes" for process competing for changing state >> from "waiting" to "ready" or "ready" to "running" ? > > There is no state ready. We change from [un]interruptible to running, > but that's just the wakeup by the timer callback. When the task gets > on the CPU is a different question. > >> Regarding above, could you please help to confirm below things? >> 1. Using msleep(40) with HZ=1000 (1ms), process can still be in >> "waiting" state and will not move to "ready" state even after 42,45 or 50 ms. >> Right ? > > kernel/time/timer.c:apply_slack() > >> 2. Using usleep_range(40000, 41000), it is guaranteed that process will >> change its state from waiting to ready state before or at 41 ms. >> Right ? > > 1) It is supposed to be woken up by the timer in that range, but there > is no guarantee. Depends also on your kernel configuration and > hardware capabilities. > > 2) The state changes from [un]interruptible to running. And again > that does not tell you when it gets on the CPU. > >> Regarding usleep_range disadvatage: >> 1. Usleep_range has a disadvantage that it does not allow the system to >> do optimal timer batching for power savings. Except that, Is there any >> other disadvantage? > > Higher CPU usage. > Really appreciate your input, Mr. Thomas. Suddenly today, I thought again and realised than Less Power Saving and High CPU Usage are disadvantages of usleep_range as a whole and not only when used for delays more than 20ms. I hope my understanding is right. If yes, Could you please help to confirm my above understanding ? and let me know if there is any disadvantage "specifically for large delays" ? Thanks again for your support on this. Regards, Aniroop Mathur >> 2. Is the impact of optimal timer batching in systems like android or ubuntu >> with moderate cpu speed significant or it can be negligible also? >> To understand the impact better, it would be really appreciating if you could >> kindly explain in detail with some case and data input. > > http://bfy.tw/3HaV > http://bfy.tw/3Han > .... > > Thanks, > > tglx -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/