stack traces when debugging GHC

Moritz Angermann moritz at lichtzwerge.de
Sat Apr 11 23:39:29 UTC 2015


> On 12 Apr 2015, at 04:26, Simon Marlow <marlowsd at gmail.com> wrote:
> 
>> On 09/02/2015 02:51, Richard Eisenberg wrote:
>> Hi devs,
>> 
>> I've just made a miraculous discovery and I want to share!
>> 
>> It has happened many times that I create some bizarre error in GHC and have no clue where it comes from. In the past, I've ended up using pprTrace to label all calls of the failing function, sometimes recursively, until I get an idea of what's going on. This is terribly painful. And then, I noticed that the function Debug.Trace.traceStack (just in the `base` package, not part of GHC) will print out a stack trace, when profiling is enabled. So, I tried building a profiled build of GHC, with -DDEBUG and -fprof-auto (just by editing the "prof" section of build.mk).
>> 
>> And then, voila, ASSERTs now print stack traces! And, with a small change in Outputable, I can get pprTrace to print stack traces, too! Hooray!
> 
> I should have advertised this more widely, thanks for pointing it out.
> 
>> I'd love to put this on the wiki. Any clue where this might be found?
> 
> I see you've added a reference buried in Debugging/Compiler.  Why don't we just make traceStack the default?  Perhaps with a flag to disable (or enable) the stack trace.

I think this is a great idea and would really like to see this being the default.

> 
> Cheers,
> Simon
> _______________________________________________
> ghc-devs mailing list
> ghc-devs at haskell.org
> http://mail.haskell.org/cgi-bin/mailman/listinfo/ghc-devs


More information about the ghc-devs mailing list