[llvm] r193937 - When LLVM is embedded in a larger application, it's not OK for LLVM to intercept crashes. LLVM already has

Filip Pizlo fpizlo at apple.com
Sat Nov 2 21:51:57 PDT 2013


On Nov 2, 2013, at 9:49 PM, Alp Toker <alp at nuanti.com> wrote:

> 
> On 03/11/2013 04:40, Filip Pizlo wrote:
>> I certainly could.  I'm just playing out the trade-offs and I don't
>> see the upside of reverting.  I think we agree that we will replace
>> this API with something more thought-out.  So, we agree that this new
>> function of mine will have a short shelf-life and should not make it
>> into a release.  We can either leave my horrible function in svn for
>> the next few days, or we can revert it.  Leaving it in has the
>> downside that maybe others will take a liking to it.  Reverting it
>> means more hassle for C API clients, like me.  Seems like leaving it
>> in is the lesser evil?
> 
> Filip, as long as you're committed to following this up -- amending the
> comment now and removing the function in the next few days, this is OK
> with me as long as others don't object.

Thank you! :-)

Here's my proposal for how to do it:

- Enabling pretty stack tracing is done via an explicit function call, which has pthread_once-like behavior (you can call it many times and it's idempotent).
- PrettyStackTraceProgram will call this function.
- The function will be exposed via the C API and DisablePrettyStackTrace will be removed.

This *should* mean that none of LLVM's command-line tools should need any changes, since AFAICT, they all do PrettyStackTraceProgram.

Does this sound like the right thing for clang and others?  If so, I can hack up the patch.

-Filip


> 
> FWIW I'll be around to help test as soon as you have an Enable() patch.
> 
> Most of all, please make sure the function doesn't inadvertently end up
> in 3.4 (!) or it'll be the wrong outcome to a long-standing bug.
> 
> Alp.
> 
> -- 
> http://www.nuanti.com
> the browser experts

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20131102/36bdb7e5/attachment.html>


More information about the llvm-commits mailing list