On 03/02/2011 22:41, ezyang wrote:
Assuming that runFuelIO is the only mechanism by which fueled execution
is performed, the only file using fuel is CmmCPS.hs. This file performs:
1. Proc point analysis
2. Proc point transformation
3. Spills and reloads
4. Late reloads
5. Dead assignment elimination
6. Stub dead slots (optional)
7. Stack slot analysis
8. Manifest the SP
9. Proc point analysis
10. Splitting proc points
11. CAF analysis
12. Safe call lowering
Out of these, it only seems like (5) and (11) are optional. Any that I missed?
It's
not very promising (and I think I will go for another angle of attack soon);
I guess fuel will be more useful when we start implementing
optimizations on top of the new codegen.
Amusingly enough the simple control flow optimisation is not subject to fuel
constraints: tis all pure code. :-)
Cheers,
Edward
P.S. I guess if I get stuck, I'll go and remove the dead code we talked about.
That shouldn't be too hard, right? ;-)
Yes, I think starting work on the cleanup would be worthwhile at this
stage. It'll be much easier to dig around in the code to find the bugs
once all the cruft has gone.
Cheers,
Simon
_______________________________________________
Glasgow-haskell-users mailing list
Glasgow-haskell-users@haskell.org
http://www.haskell.org/mailman/listinfo/glasgow-haskell-users