Course Syllabus
Prerequisites: You need to have taken a basic undergraduate or graduate compiler course. You need to be able to read and write C++.
Compilers are awesome. If you don't think so, read this paper Links to an external site.. If you still don't think so, then probably this isn't a good class for you to take. We'll be studying the technologies that live in the "middle end" of a compiler, focusing particularly on static analysis and the optimizations that are driven by static analysis. We will not talk about parsing at all because parsing is boring. Programming assignments and projects will be based on LLVM. You will implement at least one brand new LLVM optimization before finishing this class. You will also use compiler technology to find at least one bug in an open source program, and you will report that bug to people who can do something about it.
Since this is a high-level special topics class, its direction will be partially driven by you, the students. The rest of the driving will be done by me. To see what I'm interested in, take a look at some compiler papers I've written:
- Understanding Integer Overflow in C/C++ Links to an external site.
- Deniable Backdoors Using Compiler Bugs Links to an external site.
- Provably Correct Peephole Optimizations with Alive Links to an external site.
- Taming Compiler Fuzzers Links to an external site.
- Test Case Reduction for C Compiler Bugs Links to an external site.
- Testing Static Analyzers with Randomly Generated Programs Links to an external site.
- Finding and Understanding Bugs in C Compilers Links to an external site.
- Eliminating the Call Stack to Save RAM Links to an external site.
- Volatiles are Miscompiled and What to Do About It Links to an external site.
- Efficient Memory Safety for TinyOS Links to an external site.
- Offline Compression for On-Chip RAM Links to an external site.
I also sometimes write about compilers at my blog Links to an external site..
Course Summary:
Date | Details | Due |
---|---|---|
Thu Aug 25, 2016 | Assignment Homework 1 | due by 1:50pm |
Tue Aug 30, 2016 | Calendar Event read chapters 1 and 2 of SPA | 12am |
Thu Sep 1, 2016 | Calendar Event read chapter 3 of SPA and Section 1 (pages 1-9) of Type Systems | 12am |
Tue Sep 6, 2016 | Calendar Event read chapter 4 of SPA | 12am |
Thu Sep 8, 2016 | Assignment Homework 2 | due by 1:55pm |
Tue Sep 13, 2016 | Calendar Event read chapter 5 of SPA | 12am |
Tue Sep 20, 2016 | Assignment Homework 3 | due by 1:50pm |
Tue Sep 27, 2016 | Calendar Event read chapters 1 and 2 of the SSA Book http://ssabook.gforge.inria.fr/latest/book.pdf | 12am |
Assignment Homework 4 | due by 1:50pm | |
Thu Sep 29, 2016 | Calendar Event read this paper: http://compilers.cs.uni-saarland.de/papers/bbhlmz13cc.pdf | 12am |
Tue Oct 4, 2016 | Assignment Homework 4b | due by 1:50pm |
Assignment Homework 5 | due by 1:50pm | |
Thu Oct 6, 2016 | Assignment Homework 5b | due by 1:50pm |
Tue Oct 25, 2016 | Assignment Homework 6 | due by 11:59pm |
Tue Nov 1, 2016 | Assignment Homework 7 | due by 1:59pm |
Thu Nov 10, 2016 | Assignment Homework 8 | due by 1:59pm |
Thu Nov 17, 2016 | Assignment Homework 9 | due by 1:50pm |
Tue Nov 22, 2016 | Assignment review the llvm undefined behavior submission | due by 1:50pm |
Thu Dec 8, 2016 | Assignment Homework 10 | due by 1:50pm |
Tue Dec 13, 2016 | Calendar Event all late work is due (there is no final exam) | 1pm |