Advanced Compilers: The Self-Guided Online Course

(cs.cornell.edu)

83 points | by ibobev 3 hours ago

2 comments

  • titzer 35 minutes ago
    The section on dynamic compilers is more or less all about trace compilation. Generally, trace compilation is a dead end and has been abandoned repeatedly. The more important concepts here are type feedback and speculation and deoptimization, as well as making fast compilers and tiering.

    The course overall looks good, and it's great that so much is available online, so well done, Adrian.

    • samps 21 minutes ago
      Thanks, Ben. I admit I mostly think tracing is just a mind-expanding concept to learn about, even if history has proven it’s not very practical as an organizing principle. But as you say, I’d love to offer more context on “what actually seems to work” industrially.
    • giancarlostoro 25 minutes ago
      Got any other recommended resources on building compilers?
  • j2kun 19 minutes 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.
    • ferguess_k 15 minutes ago
      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?