|
|
|
|
|
by olliej
5941 days ago
|
|
One of the big issues is that any JS function can technically walks its own call stack, which makes inlining very difficult, and for many of these tests the ability to inline is actually a fairly substantial advantage. The basic problem faced by a JS engine is that if it wants to be able to inline a function it has to be able to either: * Prove that it knows everything that the function may do -- in effect this means you can't inline any functions that themselves call functions, or any functions that interact with any values you can't consider constant, or identify before you enter the inlined code; or * Have the ability to at any point in time reconstruct the call stack, and all arguments correctly. One of these choices is exceedingly limiting in what you can do, and the other is vastly complex. |
|
Only the use of such a feature should trip the "do it the safe but slow way" switch. Maybe that's not possible here though, I don't know that much about compiler optimization.
edit: I'm not implying it's easy either, but if it's possible the V8 team has the skills to implement it.