compiler introduction
Recently, I spent some time learning compiler techniques. First, I read the first few chapters of dragon book. Then I turned to blogs teaching me how to build a compiler in short time.
After a short surfing, I found no blogs beat Bison’s manual and the examples in it. So I read it through carefully. Later, I found a good blog https://thinkingeek.com/archives/
Lexical analyzer & Parser
There are a lot of blogs online with title “writing your own parser in language xxx”. Just follow one of them to get familiar with the basic usage of flex
and bison
. Why these two? There are many “better” alternatives like ANTLR
and those written in some popular non-C language like goyacc
, but flex + bison
are classical.
Flex’s manual is very short. You can quickly get an idea of what it is doing. Bison’s manual, on the other hand, is long. But there is lots of meat inside. The concept section is a refresh of what you learned in the dragon book.
Bison’s manual has three examples. Just follow them to get started.
Static single-assignment form (SSA form)
Instruction selection
Gabriel’s paper Survey on Instruction Selection: An Extensive and Modern Literature Review is an extensive report on the instruction selection techniques. To summarize, macro expansion, tree covering and DAG covering are among the most popular ways to do instruction selection. LLVM uses DAG covering and chapter 4.3.3 has a paragraph talking about it.
On the other hand, I recently find a small compiler backend called QBE. It does instruction selection by macro expansion. See arm64/emit.c. Each operand maps to a instruction macro string with special symbols %0
, %=
, etc to be filled out later.
References
TODO:
- Write a markdown parser.
- Study Clang parser.
- write a compiler
- write a interpreter.