* Naveen N. Rao <[email protected]> wrote:

> On 2015/06/02 09:58AM, Ingo Molnar wrote:
> > 
> > * Naveen N. Rao <[email protected]> wrote:
> > 
> > > On 2015/05/29 11:54AM, Ingo Molnar wrote:
> > > > 
> > > > > 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?
> 
> Hi Ingo,
> Sorry for the delay - I had been off on vacation.
> 
> I see that quite a few packages are using /proc/<pid>/schedstat - pcp, 
> systemd, 
> dstat, android, among others. While most of these seem to be splitting up the 
> fields properly, they are using a variant of strtoull(), which returns 
> ULLONG_MAX for -1, and none of these check for that condition. If any of the 
> tools use the value read to report total execution time or run delay, it will 
> be 
> incorrect.
> 
> At this point, I feel it is better to display all the three fields in 
> schedstat 
> only if sched_info_on() is true, as explained above. What do you suggest?

Ok, agreed - thanks for the analysis.

Mind (re-)submitting the patches accordingly?

Thanks,

        Ingo
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to