Error stack strawman
John Lenz
concavelenz at gmail.com
Wed Feb 24 01:01:38 UTC 2016
To be clear I meant, the VM knows *statically* whether to write code for a
regular call or a tail call and that it is *possible* to do something
*clever* by inspecting and rewriting the stack. Specifically, if you can
inspect the stack for something that is inserted before performing the
first tail call it is *possible* possible to distinguish. This is both
complicated and potentially costly and very likely not worth the effort.
On Fri, Feb 19, 2016 at 1:53 AM, Andreas Rossberg <rossberg at google.com>
wrote:
>
>
> On 19 February 2016 at 10:29, Andreas Rossberg <rossberg at google.com>
> wrote:
>
>> On 19 February 2016 at 06:29, John Lenz <concavelenz at gmail.com> wrote:
>>
>>> However, at the CPU level, it seems like you would be better pushing an
>>> return address for a special function that indicated the start of a
>>> sequence of tail calls. That way you trade only some
>>> complexity/performance for tail calls (an inspection of the last entry of
>>> the call stack) and some stack frame building complexity (to recognize this
>>> "special" frame).
>>>
>>
>> There is no way of knowing, neither statically nor dynamically, that you
>> are at "the start of a sequence of tail calls". And doing it for every tail
>> call would of course defeat tail calls.
>>
>
> Or to put that differently: if there was, then the very problem wouldn't
> exist. ;)
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.mozilla.org/pipermail/es-discuss/attachments/20160223/407142eb/attachment.html>
More information about the es-discuss
mailing list