view graal/com.oracle.graal.truffle.test/sl/TestInliningRecursive1.sl @ 19773:e66a6f8d63e3

Truffle: implement recursive inlining and with a maximum depth of 4.
author Christian Humer <christian.humer@gmail.com>
date Wed, 11 Mar 2015 15:44:32 +0100
parents 04d6bb76cfb3
children
line wrap: on
line source

/* 
 * Test recursive calls do not get inlined and do not crash.
 */
function fib(a) { 
    if (a == 2 || a == 1) {
        return 1;
    }
    return fib(a-1) + fib(a-2);
}

function test() {
    i = 0;
    sum = 0;
    while (i < 100) {
        sum = sum + fib(7);
        i = i + 1;
    }
    return sum;
}

function main() {
    callUntilOptimized(test);
}