On Mon, Feb 26, 2018 at 12:55 PM, Ian Lance Taylor <i...@golang.org> wrote:

> On Sun, Feb 25, 2018 at 8:04 PM, Dave Cheney <d...@cheney.net> wrote:
>
>> I don't understand how that could happen. time.Now calls time.now (which
>> is in assembly) so the former shouldn't be inlined, or omitted from
>> profiling.
>>
>
>
> But on amd64 GNU/Linux time.Now is implemented by calling into the VDSO.
> And it's true that if the profiling signal occurs while executing in the
> VDSO then the profiler will not be able to map the PC to any Go function,
> so the traceback will fail, and the profiler will indeed report  _System
> calling _ExternalCode.  Well spotted.
>


Caleb: what do you think of https://golang.org/cl/97315?  Would that have
helped with your original problem?

Ian




>
>
>
>>
>> On Monday, 26 February 2018 14:02:13 UTC+11, Caleb Spare wrote:
>>>
>>> On a hunch, I profiled a benchmark which just calls time.Now in a loop.
>>> Indeed: 95% of the time is attributed to runtime._System ->
>>> runtime._ExternalCode.
>>>
>>> My program does collect a lot of timing information as it runs and ends
>>> up calling time.Now quite a lot. I don't yet know for sure that most/all of
>>> the runtime._ExternalCode that shows up in my program's profile is
>>> time.Now, but that wouldn't surprise me.
>>>
>>> This makes me curious: would it be feasible to make the profiler
>>> recognize a vDSO call and synthesize a more helpful stack?
>>>
>>> On Sun, Feb 25, 2018 at 3:39 PM, Ian Lance Taylor <ia...@golang.org>
>>> wrote:
>>>
>>>> On Sun, Feb 25, 2018 at 3:30 PM, Caleb Spare <ces...@gmail.com> wrote:
>>>>
>>>>> There's no cgo in this program or any of its non-stdlib dependencies.
>>>>>
>>>>> The server is a static binary built with CGO_ENABLED=0.​ Can there
>>>>> still be cgo code running somehow?
>>>>>
>>>>
>>>> No, if it's CGO_ENABLED=0, then I think cgo code can not be the problem.
>>>>
>>>> But I also can't think of any other plausible reason to have so many
>>>> hits for this case.  It can happen if the profiling signal is received
>>>> while executing in `gogo`, `systemstack`, `mcall`, or `morestack`.  But
>>>> none of those occur all that often and they run for a short time.  It's
>>>> hard to believe that they would show up when profiling a real program.  I
>>>> don't know what is happening here.
>>>>
>>>> The code path you are seeing is the `n == 0` case in `sigprof` in
>>>> runtime/proc.go.
>>>>
>>>> Ian
>>>>
>>>>
>>>>
>>>>
>>>>> On Sun, Feb 25, 2018 at 3:05 PM, Ian Lance Taylor <ia...@golang.org>
>>>>> wrote:
>>>>>
>>>>>> On Sun, Feb 25, 2018 at 2:01 PM, Caleb Spare <ces...@gmail.com>
>>>>>> wrote:
>>>>>>
>>>>>>> How should I interpret runtime._System calling into
>>>>>>> runtime._ExternalCode in a pprof profile?
>>>>>>>
>>>>>>> I saw this taking >10% of CPU time, so I recompiled with
>>>>>>> CGO_ENABLED=0 and even so I see 6.62% of time in runtime._ExternalCode.
>>>>>>>
>>>>>>> runtime._System is a root in the graph so I can't even figure out
>>>>>>> what part of my code this might be related to.
>>>>>>>
>>>>>>> [image: Inline image 1]
>>>>>>>
>>>>>>>
>>>>>>>
>>>>>>
>>>>>>
>>>>>>
>>>>>> This is what you see when a profililng signal occurs while executing
>>>>>> code for which the Go runtime could not generate a traceback, and the
>>>>>> thread was not running the garbage collector.  The most common reason for
>>>>>> being unable to get a traceback is running in cgo code.
>>>>>>
>>>>>> If you are running on an ELF based system like GNU/Linux then
>>>>>> consider, for testing purposes only, importing
>>>>>> github.com/ianlancetaylor/cgosymbolizer.  No need to actually use
>>>>>> the package for anything, just do a blank import somewhere.  If you're
>>>>>> lucky that will give you a more detailed profile.
>>>>>>
>>>>>> Ian
>>>>>>
>>>>>
>>>>>
>>>>
>>> --
>> You received this message because you are subscribed to the Google Groups
>> "golang-nuts" group.
>> To unsubscribe from this group and stop receiving emails from it, send an
>> email to golang-nuts+unsubscr...@googlegroups.com.
>> For more options, visit https://groups.google.com/d/optout.
>>
>
>

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to