From: John Stultz <johnstul@us.ibm.com>
To: David Henningsson <david.henningsson@canonical.com>
Cc: linux-kernel@vger.kernel.org, tglx@linutronix.de, "Rostedt,
Steven" <rostedt@goodmis.org>
Subject: Re: getnstimeofday stuck for several milliseconds?
Date: Mon, 12 Nov 2012 15:53:51 -0800 [thread overview]
Message-ID: <50A18C0F.9000604@us.ibm.com> (raw)
In-Reply-To: <50977DF5.60703@canonical.com>
On 11/05/2012 12:51 AM, David Henningsson wrote:
> Hi LKML,
>
> I'm trying to make audio more useful in everyday low-latency scenarios
> such as gaming or VOIP.
>
> While doing so, I ran the wakeup_rt tracer, to track the time from
> PulseAudio requesting wakeup (through hrtimers), to the thread
> actually running.
>
> I'm not sure how much overhead added by the wakeup_rt tracer itself,
> but I got 9 ms on one machine and 20 ms on another, which I consider
> to be quite a lot even for a standard kernel (i e without RT or other
> special configuration).
>
> The 9 ms example is pastebinned at [1], and here's where we get stuck
> for most of the time:
>
> <idle>-0 3d... 1105us : ktime_get_real <-intel_idle
> <idle>-0 3d... 1106us!: getnstimeofday <-ktime_get_real
> <idle>-0 3d... 7823us : ktime_get_real <-intel_idle
>
> <idle>-0 3d... 7890us : ktime_get_real <-intel_idle
> <idle>-0 3d... 7891us!: getnstimeofday <-ktime_get_real
> <idle>-0 3d... 9023us : ktime_get_real <-intel_idle
>
Its been awhile since I looked at wakeup_rt trace output, but that looks
more like ~6.7ms and ~1.2ms latencies, not 9ms (are you adding these
together?).
> It seems to me that sometimes we get stuck for several milliseconds
> inside the getnstimeofday function - this was seen on both the 9 ms
> and the 20 ms trace. This looks like a bug to me, and as I'm not sure
> on how to best debug it further, and therefore I'm asking for help (or
> a bug fix!) here.
>
> For reference, the 9 ms trace was from a ~2 year old laptop (core i3
> cpu) running 3.7rc2 vanilla/mainline kernel, and the 20 ms trace was
> from an ~1 year old Atom-based machine running the 3.2-ubuntu kernel.
> While tracing was enabled, I was running a libSDL game for a minute or
> two.
>
> Thanks in advance for looking into this, and let me know if you need
> further information, or anything else I can do to help sorting this
> one out.
Hrmm.. So 6.7ms is still a long time.
Looking at the trace you posted here: http://pastebin.se/6iMRdDfR
The trace also looks like its the cpuidle to interrupt transition where
you're seeing this. I sort of wonder if its mis-attributing the idle
time to the getnstimeofday()? Mainly because you don't seem to spend
much time in intel_idle() otherwise.
Or maybe we're both misreading it and its saying there's a delay between
the first ktime_get_real() from intel_idle() to the second call of
ktime_get_real(), between which we're in deep idle (which would make sense)?
Because unless the timekeeping lock is getting held for a long time, I
don't know why else you'd see such long delays at getnstimeofday().
Cc'ing Steven to see if he can't help understand whats going on here.
thanks
-john
next prev parent reply other threads:[~2012-11-12 23:54 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-11-05 8:51 getnstimeofday stuck for several milliseconds? David Henningsson
2012-11-12 23:53 ` John Stultz [this message]
2012-11-13 0:09 ` John Stultz
2012-11-13 0:15 ` Steven Rostedt
2012-11-13 8:26 ` David Henningsson
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=50A18C0F.9000604@us.ibm.com \
--to=johnstul@us.ibm.com \
--cc=david.henningsson@canonical.com \
--cc=linux-kernel@vger.kernel.org \
--cc=rostedt@goodmis.org \
--cc=tglx@linutronix.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.