<div class="gmail_quote">On Mon, Dec 29, 2008 at 6:55 AM, Duncan Sands <span dir="ltr"><<a href="mailto:baldrick@free.fr">baldrick@free.fr</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">
Hi Talin,<br>
<br>
> 1) I'm trying to figure out the relationship between the __cxa_throw<br>
> function, and the _Unwind_RaiseException function mentioned in the ABI doc.<br>
> My guess is that _Unwind_RaiseException is the language-neutral<br>
> implementation of stack unwinding, and __cxa_throw is the C++ exception<br>
> semantics that are implemented on top of it. If that is the case, should I<br>
> be calling _Unwind_RaiseException since my exceptions are more like Java<br>
> than C++ exceptions?<br>
<br>
try reading this: <a href="http://www.codesourcery.com/public/cxx-abi/abi-eh.html" target="_blank">http://www.codesourcery.com/public/cxx-abi/abi-eh.html</a></blockquote><div><br></div><div>I did :)</div><div><br></div><div>
I was also looking at this article, which purports to use __Unwind_RaiseException directly: <a href="http://www.incasoftware.de/~kamm/projects/index.php/2008/08/19/exception-handling-in-llvmdc-using-llvm/">http://www.incasoftware.de/~kamm/projects/index.php/2008/08/19/exception-handling-in-llvmdc-using-llvm/</a> </div>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">
<br>
> 2) How portable is _Unwind_RaiseException and similar functions? In<br>
> particular, if I call those functions, will I be limiting myself to a subset<br>
> of the platforms that LLVM supports? (The same question can be asked of<br>
> __cxa_throw).<br>
><br>
> Although _Unwind_RaiseException is mentioned as part of the Itanium ABI, it<br>
> is apparently used on many more platform types than just that one processor.<br>
> A code search shows that it is in fact part of the standard gcc-provided<br>
> runtime libs (see<br>
> <a href="http://www.google.com/codesearch/p?hl=en#47R7EH5FbNk/trunk/gcc/gcc/unwind-generic.h&q=_Unwind_RaiseException%20lang:c" target="_blank">http://www.google.com/codesearch/p?hl=en#47R7EH5FbNk/trunk/gcc/gcc/unwind-generic.h&q=_Unwind_RaiseException%20lang:c</a>).<br>
<br>
Exactly, this is part of libgcc and as such you can assume it is available.<br>
<br>
> There is also a mention of "libunwind". Is libunwind a portable<br>
> implementation of the Itanium unwinding ABI?<br>
<br>
I think it's an attempt to have a non-gcc related platform independent<br>
unwinding library.<br>
<br>
> 3) I really like the "invoke/unwind" abstraction that LLVM provides, as it<br>
> divorces the mechanism of unwinding from the creation of an exception<br>
> object. However, looking at the Itanium unwinding API, I don't see how you<br>
> can implement LLVM invoke/unwind on top of it, since the API functions take<br>
> an exception object as a parameter. (I suppose you could use a dummy<br>
> exception to satisfy the ABI, and then implement your own, separate<br>
> exception object, but this destroys some of the efficiency of the unwinding<br>
> implementation.)<br>
<br>
Right, this is indeed one of the main problems in implementing unwind.<br>
On the other hand invoke can be done fairly easily (in spite of appearances,<br>
invoke is not supported by the code generators, only invoke + an eh.selector<br>
call [provides a personality function] is supported; I have a plan to fix<br>
this).<br>
<br>
> Also, the Itanium ABI appears to offer some interesting features that aren't<br>
> exposed by the invoke/unwind mechanism which would be useful. For example,<br>
> the fact that the stack frames are traversed in two passes seems like it<br>
> might make it possible to implement human-readable stack dumps, which would<br>
> be difficult with invoke/unwind.<br>
<br>
Check out <a href="http://llvm.org/docs/LangRef.html#int_frameaddress" target="_blank">http://llvm.org/docs/LangRef.html#int_frameaddress</a></blockquote><div><br></div><div>I knew about that function - the issue isn't so much getting the stack frames, as it is knowing whether or not you'll need them. For most exceptions, we would want to simply have the exception be caught and resume execution, in which case saving the state of the stack is a waste of time. However, in some cases you are going to print out the stack trace, which means you need to record the stack frames before you enter the catch handler (because then it's too late).</div>
<div><br></div><div>The Itanium exception document describes a process where the stack frames between the throw and catch statements can be traversed multiple times. Assuming the compiler knows whether a given catch handler makes reference to the stack trace property of the exception, we can use this information to decide whether or not to allocate space for the stack trace. That is, do a pre-traversal to determine which catch handler will be called and whether stack trace information is needed. If so, then do another traversal to capture the stack trace, and then a final traversal to do the actual unwinding.</div>
<div><br></div><div>Doing something similar using only the LLVM invoke/unwind primitives would be very difficult I think.</div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">
<br>
Ciao,<br>
<font color="#888888"><br>
Duncan.<br>
</font></blockquote></div><br><br clear="all"><br>-- <br>-- Talin<br>