From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751740AbbFBH6g (ORCPT ); Tue, 2 Jun 2015 03:58:36 -0400 Received: from mail-wi0-f182.google.com ([209.85.212.182]:34817 "EHLO mail-wi0-f182.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752043AbbFBH6a (ORCPT ); Tue, 2 Jun 2015 03:58:30 -0400 Date: Tue, 2 Jun 2015 09:58:25 +0200 From: Ingo Molnar To: "Naveen N. Rao" Cc: Balbir Singh , "linux-kernel@vger.kernel.org" , Peter Zijlstra , srikar@linux.vnet.ibm.com Subject: Re: [PATCH] proc/schedstat: Expose /proc//schedstat if delay accounting is enabled Message-ID: <20150602075825.GA12057@gmail.com> References: <1432537954-26665-1-git-send-email-naveen.n.rao@linux.vnet.ibm.com> <20150529061620.GA17421@naverao1-tp.ibm.com> <20150529080424.GA27235@gmail.com> <20150529085504.GD17421@naverao1-tp.ibm.com> <20150529091837.GA30451@gmail.com> <20150529094547.GE17421@naverao1-tp.ibm.com> <20150529095435.GA30949@gmail.com> <20150529170600.GF17421@naverao1-tp.ibm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20150529170600.GF17421@naverao1-tp.ibm.com> User-Agent: Mutt/1.5.23 (2014-03-12) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org * Naveen N. Rao wrote: > On 2015/05/29 11:54AM, Ingo Molnar wrote: > > > > > > So all this should really be cleaned up: > > > > > > > > include/linux/sched.h:#if defined(CONFIG_SCHEDSTATS) || defined(CONFIG_TASK_DELAY_ACCT) > > > > include/linux/sched.h:#endif /* defined(CONFIG_SCHEDSTATS) || defined(CONFIG_TASK_DELAY_ACCT) */ > > > > include/linux/sched.h:#if defined(CONFIG_SCHEDSTATS) || defined(CONFIG_TASK_DELAY_ACCT) > > > > kernel/sched/core.c:#if defined(CONFIG_SCHEDSTATS) || defined(CONFIG_TASK_DELAY_ACCT) > > > > kernel/sched/stats.h:#if defined(CONFIG_SCHEDSTATS) || defined(CONFIG_TASK_DELAY_ACCT) > > > > kernel/sched/stats.h:#endif /* CONFIG_SCHEDSTATS || CONFIG_TASK_DELAY_ACCT */ > > > > > > > > by introducing an intermediate Kconfig variable, named CONFIG_SCHED_INFO or so, > > > > and selected by both SCHEDSTATS and TASK_DELAY_ACCT. > > > > > > > > Please make it two patches: the first one adds CONFIG_SCHED_INFO and cleans up the > > > > code to use it, the second one uses it for the procps change. > > > > > > Sure, will do. > > > > > > On a related note, even though sum_exec_runtime is available unconditionally, I > > > dump all zeroes in my patch if !sched_info_on() to make it clear that some of > > > the fields are not available. Is this ok or should be display sum_exec_runtime > > > regardless of sched_info? > > > > So I'd suggest printing -1 for non-available fields, that should be unambigous > > enough and makes it also possible to write out 0 in some cases. > > Per Documentation/scheduler/sched-stats.txt (and the linked latency.c there), > user-space seems to be expecting unsigned values here. Would displaying -1 here > be ok? Probably not (the code is silly, why doesn't it split up the string and use atol()?) - hopefully real user-space is better? Can you try some real, packaged up tools that read schedstats, to see whether they work with -1? Thanks, Ingo