What I learned from my first serious attempt low-level Haskell programming

Lennart Augustsson lennart at augustsson.net
Wed Apr 11 02:58:41 EDT 2007


OK, so there are few extra costs for unknown tail calls.
First, there might be a pipeline stall if the jump address isn't  
loaded into a register far enough in advance before the jump.
Second, you need to pass information about the number of arguments in  
the caller.
And finally, you need to test the number of arguments in the callee.

Under the best of circumstances the argument check costs a load  
immediate, a compare, and a non-taken branch.  But looking at the  
output from ghc I doubt this is the case.

	-- Lennart

On Apr 10, 2007, at 23:13 , Stefan O'Rear wrote:

> On Tue, Apr 10, 2007 at 07:59:04PM +0100, Lennart Augustsson wrote:
>> So then tail calls should be very cheap when most of the arguments
>> don't change.
>>
>> On Apr 10, 2007, at 10:17 , Simon Marlow wrote:
>>
>>> Lennart Augustsson wrote:
>>>> It's not that hard to figure out an order to permute the arguments
>>>> on the stack before a tail call that minimizes that number of
>>>> moves and temporary locations.  Lmlc did this 20 years ago. :)
>>>
>>> Right, and that's what GHC does too, with a strongly-connected-
>>> component analysis of the dependencies between assignments of the
>>> args for the tail call.
>>>
>>> Cheers,
>>> 	Simon
>
> The tailcall in question is NOT statically known (it is a variant of
> CPS), so simpleminded tail recursion optimizations will not help much.
>
> Stefan



More information about the Libraries mailing list