| ▲ | j2kun 4 hours ago | |||||||||||||
I'm a bit confused about what makes this course "advanced." Most of the topics (dead code elimination, data flow, dominator analysis, SSA form) seem like they belong in a first course on compilers. | ||||||||||||||
| ▲ | jcranmer 3 hours ago | parent | next [-] | |||||||||||||
Well, course numbers are regular enough that you can look up what the "intro compilers" course is: https://www.cs.cornell.edu/courses/cs4120/2026sp/?schedule The short answer is that compilers is basically broken up into two courses, with the first course largely being the minimum necessary to build a compiler (lexing, parsing, codegen, register allocation), and the second course being how to build an optimizing compiler. | ||||||||||||||
| ||||||||||||||
| ▲ | mamcx 3 hours ago | parent | prev | next [-] | |||||||||||||
I have read TONS of material about it*, and none of that is part of the majority of that! In fact, the "backend" be compiler or interpreter is nearly always left as "exercise to reader". You can't imagine how much is left to be discovered, from how make a closure, track environment, do pattern matching, memory representation, etc. EVERYTHING interesting is something you need to look for. P.D: This only one of the years:https://gist.githubusercontent.com/mamcx/e1743571b9a1ea163a7... | ||||||||||||||
| ▲ | ferguess_k 4 hours ago | parent | prev | next [-] | |||||||||||||
I think a lot of the non-professionals start with parsing and do not get exposed to backend. I have read two books about interpreters/compilers and they don't touch the backend very much. Maybe this is introductory for backend? | ||||||||||||||
| ||||||||||||||
| ▲ | vkazanov 2 hours ago | parent | prev [-] | |||||||||||||
What is advanced then? Good coverage of dce, data flow, ssa, intruction selection and reg alloc is actually like 98% of the backend. | ||||||||||||||
| ||||||||||||||