-
Notifications
You must be signed in to change notification settings - Fork 41
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
std function call destroys the stack #4
Comments
At present, |
Actually, that Rubi pushes its argument from left to right is fine and consistent. It's the intermix of standard library function calls (back into C) that mess up the stack. I'm not sure to what degree are we to refine Rubi prototype? The simplest way would be excluding standard function calls from expressions and regarding them as statements in Rubi syntax. Otherwise, we could change std function calls to
Adapting Rubi functions to C calling conventions would have similar effect. Their argument counts are known anyway. I can't think of a simple way to support variadic functions though. Either swaping arguments on the stack after all of them have been evaluated or counting argument number prior to code gen would be a little mess. |
@suhorng : |
In computation, intermediate results are kept on the stack, yet standard function calls assume space for arguments be reserved on the stack.
However,
The text was updated successfully, but these errors were encountered: