1 <!DOCTYPE HTML PUBLIC
"-//W3C//DTD HTML 4.01//EN"
2 "http://www.w3.org/TR/html4/strict.dtd">
6 <title>Kaleidoscope: Extending the Language: Control Flow
</title>
7 <meta http-equiv=
"Content-Type" content=
"text/html; charset=utf-8">
8 <meta name=
"author" content=
"Chris Lattner">
9 <link rel=
"stylesheet" href=
"../llvm.css" type=
"text/css">
14 <h1>Kaleidoscope: Extending the Language: Control Flow
</h1>
17 <li><a href=
"index.html">Up to Tutorial Index
</a></li>
20 <li><a href=
"#intro">Chapter
5 Introduction
</a></li>
21 <li><a href=
"#ifthen">If/Then/Else
</a>
23 <li><a href=
"#iflexer">Lexer Extensions
</a></li>
24 <li><a href=
"#ifast">AST Extensions
</a></li>
25 <li><a href=
"#ifparser">Parser Extensions
</a></li>
26 <li><a href=
"#ifir">LLVM IR
</a></li>
27 <li><a href=
"#ifcodegen">Code Generation
</a></li>
30 <li><a href=
"#for">'for' Loop Expression
</a>
32 <li><a href=
"#forlexer">Lexer Extensions
</a></li>
33 <li><a href=
"#forast">AST Extensions
</a></li>
34 <li><a href=
"#forparser">Parser Extensions
</a></li>
35 <li><a href=
"#forir">LLVM IR
</a></li>
36 <li><a href=
"#forcodegen">Code Generation
</a></li>
39 <li><a href=
"#code">Full Code Listing
</a></li>
42 <li><a href=
"LangImpl6.html">Chapter
6</a>: Extending the Language:
43 User-defined Operators
</li>
46 <div class=
"doc_author">
47 <p>Written by
<a href=
"mailto:sabre@nondot.org">Chris Lattner
</a></p>
50 <!-- *********************************************************************** -->
51 <h2><a name=
"intro">Chapter
5 Introduction
</a></h2>
52 <!-- *********************************************************************** -->
56 <p>Welcome to Chapter
5 of the
"<a href="index.html
">Implementing a language
57 with LLVM</a>" tutorial. Parts
1-
4 described the implementation of the simple
58 Kaleidoscope language and included support for generating LLVM IR, followed by
59 optimizations and a JIT compiler. Unfortunately, as presented, Kaleidoscope is
60 mostly useless: it has no control flow other than call and return. This means
61 that you can't have conditional branches in the code, significantly limiting its
62 power. In this episode of
"build that compiler", we'll extend Kaleidoscope to
63 have an if/then/else expression plus a simple 'for' loop.
</p>
67 <!-- *********************************************************************** -->
68 <h2><a name=
"ifthen">If/Then/Else
</a></h2>
69 <!-- *********************************************************************** -->
74 Extending Kaleidoscope to support if/then/else is quite straightforward. It
75 basically requires adding support for this
"new" concept to the lexer,
76 parser, AST, and LLVM code emitter. This example is nice, because it shows how
77 easy it is to
"grow" a language over time, incrementally extending it as new
78 ideas are discovered.
</p>
80 <p>Before we get going on
"how" we add this extension, lets talk about
"what" we
81 want. The basic idea is that we want to be able to write this sort of thing:
84 <div class=
"doc_code">
94 <p>In Kaleidoscope, every construct is an expression: there are no statements.
95 As such, the if/then/else expression needs to return a value like any other.
96 Since we're using a mostly functional form, we'll have it evaluate its
97 conditional, then return the 'then' or 'else' value based on how the condition
98 was resolved. This is very similar to the C
"?:" expression.
</p>
100 <p>The semantics of the if/then/else expression is that it evaluates the
101 condition to a boolean equality value:
0.0 is considered to be false and
102 everything else is considered to be true.
103 If the condition is true, the first subexpression is evaluated and returned, if
104 the condition is false, the second subexpression is evaluated and returned.
105 Since Kaleidoscope allows side-effects, this behavior is important to nail down.
108 <p>Now that we know what we
"want", lets break this down into its constituent
111 <!-- ======================================================================= -->
112 <h4><a name=
"iflexer">Lexer Extensions for If/Then/Else
</a></h4>
113 <!-- ======================================================================= -->
118 <p>The lexer extensions are straightforward. First we add new enum values
119 for the relevant tokens:
</p>
121 <div class=
"doc_code">
124 tok_if = -
6, tok_then = -
7, tok_else = -
8,
128 <p>Once we have that, we recognize the new keywords in the lexer. This is pretty simple
131 <div class=
"doc_code">
134 if (IdentifierStr ==
"def") return tok_def;
135 if (IdentifierStr ==
"extern") return tok_extern;
136 <b>if (IdentifierStr ==
"if") return tok_if;
137 if (IdentifierStr ==
"then") return tok_then;
138 if (IdentifierStr ==
"else") return tok_else;
</b>
139 return tok_identifier;
145 <!-- ======================================================================= -->
146 <h4><a name=
"ifast">AST Extensions for If/Then/Else
</a></h4>
147 <!-- ======================================================================= -->
151 <p>To represent the new expression we add a new AST node for it:
</p>
153 <div class=
"doc_code">
155 /// IfExprAST - Expression class for if/then/else.
156 class IfExprAST : public ExprAST {
157 ExprAST *Cond, *Then, *Else;
159 IfExprAST(ExprAST *cond, ExprAST *then, ExprAST *_else)
160 : Cond(cond), Then(then), Else(_else) {}
161 virtual Value *Codegen();
166 <p>The AST node just has pointers to the various subexpressions.
</p>
170 <!-- ======================================================================= -->
171 <h4><a name=
"ifparser">Parser Extensions for If/Then/Else
</a></h4>
172 <!-- ======================================================================= -->
176 <p>Now that we have the relevant tokens coming from the lexer and we have the
177 AST node to build, our parsing logic is relatively straightforward. First we
178 define a new parsing function:
</p>
180 <div class=
"doc_code">
182 /// ifexpr ::= 'if' expression 'then' expression 'else' expression
183 static ExprAST *ParseIfExpr() {
184 getNextToken(); // eat the if.
187 ExprAST *Cond = ParseExpression();
190 if (CurTok != tok_then)
191 return Error(
"expected then");
192 getNextToken(); // eat the then
194 ExprAST *Then = ParseExpression();
195 if (Then ==
0) return
0;
197 if (CurTok != tok_else)
198 return Error(
"expected else");
202 ExprAST *Else = ParseExpression();
205 return new IfExprAST(Cond, Then, Else);
210 <p>Next we hook it up as a primary expression:
</p>
212 <div class=
"doc_code">
214 static ExprAST *ParsePrimary() {
216 default: return Error(
"unknown token when expecting an expression");
217 case tok_identifier: return ParseIdentifierExpr();
218 case tok_number: return ParseNumberExpr();
219 case '(': return ParseParenExpr();
220 <b>case tok_if: return ParseIfExpr();
</b>
228 <!-- ======================================================================= -->
229 <h4><a name=
"ifir">LLVM IR for If/Then/Else
</a></h4>
230 <!-- ======================================================================= -->
234 <p>Now that we have it parsing and building the AST, the final piece is adding
235 LLVM code generation support. This is the most interesting part of the
236 if/then/else example, because this is where it starts to introduce new concepts.
237 All of the code above has been thoroughly described in previous chapters.
240 <p>To motivate the code we want to produce, lets take a look at a simple
241 example. Consider:
</p>
243 <div class=
"doc_code">
247 def baz(x) if x then foo() else bar();
251 <p>If you disable optimizations, the code you'll (soon) get from Kaleidoscope
254 <div class=
"doc_code">
256 declare double @foo()
258 declare double @bar()
260 define double @baz(double %x) {
262 %ifcond = fcmp one double %x,
0.000000e+00
263 br i1 %ifcond, label %then, label %else
265 then: ; preds = %entry
266 %calltmp = call double @foo()
269 else: ; preds = %entry
270 %calltmp1 = call double @bar()
273 ifcont: ; preds = %else, %then
274 %iftmp = phi double [ %calltmp, %then ], [ %calltmp1, %else ]
280 <p>To visualize the control flow graph, you can use a nifty feature of the LLVM
281 '
<a href=
"http://llvm.org/cmds/opt.html">opt
</a>' tool. If you put this LLVM IR
282 into
"t.ll" and run
"<tt>llvm-as < t.ll | opt -analyze -view-cfg</tt>",
<a
283 href=
"../ProgrammersManual.html#ViewGraph">a window will pop up
</a> and you'll
286 <div style=
"text-align: center"><img src=
"LangImpl5-cfg.png" alt=
"Example CFG" width=
"423"
289 <p>Another way to get this is to call
"<tt>F->viewCFG()</tt>" or
290 "<tt>F->viewCFGOnly()</tt>" (where F is a
"<tt>Function*</tt>") either by
291 inserting actual calls into the code and recompiling or by calling these in the
292 debugger. LLVM has many nice features for visualizing various graphs.
</p>
294 <p>Getting back to the generated code, it is fairly simple: the entry block
295 evaluates the conditional expression (
"x" in our case here) and compares the
296 result to
0.0 with the
"<tt><a href="../LangRef.html#i_fcmp
">fcmp</a> one</tt>"
297 instruction ('one' is
"Ordered and Not Equal"). Based on the result of this
298 expression, the code jumps to either the
"then" or
"else" blocks, which contain
299 the expressions for the true/false cases.
</p>
301 <p>Once the then/else blocks are finished executing, they both branch back to the
302 'ifcont' block to execute the code that happens after the if/then/else. In this
303 case the only thing left to do is to return to the caller of the function. The
304 question then becomes: how does the code know which expression to return?
</p>
306 <p>The answer to this question involves an important SSA operation: the
307 <a href=
"http://en.wikipedia.org/wiki/Static_single_assignment_form">Phi
308 operation
</a>. If you're not familiar with SSA,
<a
309 href=
"http://en.wikipedia.org/wiki/Static_single_assignment_form">the wikipedia
310 article
</a> is a good introduction and there are various other introductions to
311 it available on your favorite search engine. The short version is that
312 "execution" of the Phi operation requires
"remembering" which block control came
313 from. The Phi operation takes on the value corresponding to the input control
314 block. In this case, if control comes in from the
"then" block, it gets the
315 value of
"calltmp". If control comes from the
"else" block, it gets the value
318 <p>At this point, you are probably starting to think
"Oh no! This means my
319 simple and elegant front-end will have to start generating SSA form in order to
320 use LLVM!". Fortunately, this is not the case, and we strongly advise
321 <em>not
</em> implementing an SSA construction algorithm in your front-end
322 unless there is an amazingly good reason to do so. In practice, there are two
323 sorts of values that float around in code written for your average imperative
324 programming language that might need Phi nodes:
</p>
327 <li>Code that involves user variables:
<tt>x =
1; x = x +
1;
</tt></li>
328 <li>Values that are implicit in the structure of your AST, such as the Phi node
332 <p>In
<a href=
"LangImpl7.html">Chapter
7</a> of this tutorial (
"mutable
333 variables"), we'll talk about #
1
334 in depth. For now, just believe me that you don't need SSA construction to
335 handle this case. For #
2, you have the choice of using the techniques that we will
336 describe for #
1, or you can insert Phi nodes directly, if convenient. In this
337 case, it is really really easy to generate the Phi node, so we choose to do it
340 <p>Okay, enough of the motivation and overview, lets generate code!
</p>
344 <!-- ======================================================================= -->
345 <h4><a name=
"ifcodegen">Code Generation for If/Then/Else
</a></h4>
346 <!-- ======================================================================= -->
350 <p>In order to generate code for this, we implement the
<tt>Codegen
</tt> method
351 for
<tt>IfExprAST
</tt>:
</p>
353 <div class=
"doc_code">
355 Value *IfExprAST::Codegen() {
356 Value *CondV = Cond-
>Codegen();
357 if (CondV ==
0) return
0;
359 // Convert condition to a bool by comparing equal to
0.0.
360 CondV = Builder.CreateFCmpONE(CondV,
361 ConstantFP::get(getGlobalContext(), APFloat(
0.0)),
366 <p>This code is straightforward and similar to what we saw before. We emit the
367 expression for the condition, then compare that value to zero to get a truth
368 value as a
1-bit (bool) value.
</p>
370 <div class=
"doc_code">
372 Function *TheFunction = Builder.GetInsertBlock()-
>getParent();
374 // Create blocks for the then and else cases. Insert the 'then' block at the
375 // end of the function.
376 BasicBlock *ThenBB = BasicBlock::Create(getGlobalContext(),
"then", TheFunction);
377 BasicBlock *ElseBB = BasicBlock::Create(getGlobalContext(),
"else");
378 BasicBlock *MergeBB = BasicBlock::Create(getGlobalContext(),
"ifcont");
380 Builder.CreateCondBr(CondV, ThenBB, ElseBB);
384 <p>This code creates the basic blocks that are related to the if/then/else
385 statement, and correspond directly to the blocks in the example above. The
386 first line gets the current Function object that is being built. It
387 gets this by asking the builder for the current BasicBlock, and asking that
388 block for its
"parent" (the function it is currently embedded into).
</p>
390 <p>Once it has that, it creates three blocks. Note that it passes
"TheFunction"
391 into the constructor for the
"then" block. This causes the constructor to
392 automatically insert the new block into the end of the specified function. The
393 other two blocks are created, but aren't yet inserted into the function.
</p>
395 <p>Once the blocks are created, we can emit the conditional branch that chooses
396 between them. Note that creating new blocks does not implicitly affect the
397 IRBuilder, so it is still inserting into the block that the condition
398 went into. Also note that it is creating a branch to the
"then" block and the
399 "else" block, even though the
"else" block isn't inserted into the function yet.
400 This is all ok: it is the standard way that LLVM supports forward
403 <div class=
"doc_code">
406 Builder.SetInsertPoint(ThenBB);
408 Value *ThenV = Then-
>Codegen();
409 if (ThenV ==
0) return
0;
411 Builder.CreateBr(MergeBB);
412 // Codegen of 'Then' can change the current block, update ThenBB for the PHI.
413 ThenBB = Builder.GetInsertBlock();
417 <p>After the conditional branch is inserted, we move the builder to start
418 inserting into the
"then" block. Strictly speaking, this call moves the
419 insertion point to be at the end of the specified block. However, since the
420 "then" block is empty, it also starts out by inserting at the beginning of the
423 <p>Once the insertion point is set, we recursively codegen the
"then" expression
424 from the AST. To finish off the
"then" block, we create an unconditional branch
425 to the merge block. One interesting (and very important) aspect of the LLVM IR
426 is that it
<a href=
"../LangRef.html#functionstructure">requires all basic blocks
427 to be
"terminated"</a> with a
<a href=
"../LangRef.html#terminators">control flow
428 instruction
</a> such as return or branch. This means that all control flow,
429 <em>including fall throughs
</em> must be made explicit in the LLVM IR. If you
430 violate this rule, the verifier will emit an error.
</p>
432 <p>The final line here is quite subtle, but is very important. The basic issue
433 is that when we create the Phi node in the merge block, we need to set up the
434 block/value pairs that indicate how the Phi will work. Importantly, the Phi
435 node expects to have an entry for each predecessor of the block in the CFG. Why
436 then, are we getting the current block when we just set it to ThenBB
5 lines
437 above? The problem is that the
"Then" expression may actually itself change the
438 block that the Builder is emitting into if, for example, it contains a nested
439 "if/then/else" expression. Because calling Codegen recursively could
440 arbitrarily change the notion of the current block, we are required to get an
441 up-to-date value for code that will set up the Phi node.
</p>
443 <div class=
"doc_code">
446 TheFunction-
>getBasicBlockList().push_back(ElseBB);
447 Builder.SetInsertPoint(ElseBB);
449 Value *ElseV = Else-
>Codegen();
450 if (ElseV ==
0) return
0;
452 Builder.CreateBr(MergeBB);
453 // Codegen of 'Else' can change the current block, update ElseBB for the PHI.
454 ElseBB = Builder.GetInsertBlock();
458 <p>Code generation for the 'else' block is basically identical to codegen for
459 the 'then' block. The only significant difference is the first line, which adds
460 the 'else' block to the function. Recall previously that the 'else' block was
461 created, but not added to the function. Now that the 'then' and 'else' blocks
462 are emitted, we can finish up with the merge code:
</p>
464 <div class=
"doc_code">
467 TheFunction-
>getBasicBlockList().push_back(MergeBB);
468 Builder.SetInsertPoint(MergeBB);
469 PHINode *PN = Builder.CreatePHI(Type::getDoubleTy(getGlobalContext()),
2,
472 PN-
>addIncoming(ThenV, ThenBB);
473 PN-
>addIncoming(ElseV, ElseBB);
479 <p>The first two lines here are now familiar: the first adds the
"merge" block
480 to the Function object (it was previously floating, like the else block above).
481 The second block changes the insertion point so that newly created code will go
482 into the
"merge" block. Once that is done, we need to create the PHI node and
483 set up the block/value pairs for the PHI.
</p>
485 <p>Finally, the CodeGen function returns the phi node as the value computed by
486 the if/then/else expression. In our example above, this returned value will
487 feed into the code for the top-level function, which will create the return
490 <p>Overall, we now have the ability to execute conditional code in
491 Kaleidoscope. With this extension, Kaleidoscope is a fairly complete language
492 that can calculate a wide variety of numeric functions. Next up we'll add
493 another useful expression that is familiar from non-functional languages...
</p>
499 <!-- *********************************************************************** -->
500 <h2><a name=
"for">'for' Loop Expression
</a></h2>
501 <!-- *********************************************************************** -->
505 <p>Now that we know how to add basic control flow constructs to the language,
506 we have the tools to add more powerful things. Lets add something more
507 aggressive, a 'for' expression:
</p>
509 <div class=
"doc_code">
511 extern putchard(char)
513 for i =
1, i
< n,
1.0 in
514 putchard(
42); # ascii
42 = '*'
516 # print
100 '*' characters
521 <p>This expression defines a new variable (
"i" in this case) which iterates from
522 a starting value, while the condition (
"i < n" in this case) is true,
523 incrementing by an optional step value (
"1.0" in this case). If the step value
524 is omitted, it defaults to
1.0. While the loop is true, it executes its
525 body expression. Because we don't have anything better to return, we'll just
526 define the loop as always returning
0.0. In the future when we have mutable
527 variables, it will get more useful.
</p>
529 <p>As before, lets talk about the changes that we need to Kaleidoscope to
532 <!-- ======================================================================= -->
533 <h4><a name=
"forlexer">Lexer Extensions for the 'for' Loop
</a></h4>
534 <!-- ======================================================================= -->
538 <p>The lexer extensions are the same sort of thing as for if/then/else:
</p>
540 <div class=
"doc_code">
542 ... in enum Token ...
544 tok_if = -
6, tok_then = -
7, tok_else = -
8,
545 <b> tok_for = -
9, tok_in = -
10</b>
548 if (IdentifierStr ==
"def") return tok_def;
549 if (IdentifierStr ==
"extern") return tok_extern;
550 if (IdentifierStr ==
"if") return tok_if;
551 if (IdentifierStr ==
"then") return tok_then;
552 if (IdentifierStr ==
"else") return tok_else;
553 <b>if (IdentifierStr ==
"for") return tok_for;
554 if (IdentifierStr ==
"in") return tok_in;
</b>
555 return tok_identifier;
561 <!-- ======================================================================= -->
562 <h4><a name=
"forast">AST Extensions for the 'for' Loop
</a></h4>
563 <!-- ======================================================================= -->
567 <p>The AST node is just as simple. It basically boils down to capturing
568 the variable name and the constituent expressions in the node.
</p>
570 <div class=
"doc_code">
572 /// ForExprAST - Expression class for for/in.
573 class ForExprAST : public ExprAST {
575 ExprAST *Start, *End, *Step, *Body;
577 ForExprAST(const std::string
&varname, ExprAST *start, ExprAST *end,
578 ExprAST *step, ExprAST *body)
579 : VarName(varname), Start(start), End(end), Step(step), Body(body) {}
580 virtual Value *Codegen();
587 <!-- ======================================================================= -->
588 <h4><a name=
"forparser">Parser Extensions for the 'for' Loop
</a></h4>
589 <!-- ======================================================================= -->
593 <p>The parser code is also fairly standard. The only interesting thing here is
594 handling of the optional step value. The parser code handles it by checking to
595 see if the second comma is present. If not, it sets the step value to null in
598 <div class=
"doc_code">
600 /// forexpr ::= 'for' identifier '=' expr ',' expr (',' expr)? 'in' expression
601 static ExprAST *ParseForExpr() {
602 getNextToken(); // eat the for.
604 if (CurTok != tok_identifier)
605 return Error(
"expected identifier after for");
607 std::string IdName = IdentifierStr;
608 getNextToken(); // eat identifier.
611 return Error(
"expected '=' after for");
612 getNextToken(); // eat '='.
615 ExprAST *Start = ParseExpression();
616 if (Start ==
0) return
0;
618 return Error(
"expected ',' after for start value");
621 ExprAST *End = ParseExpression();
622 if (End ==
0) return
0;
624 // The step value is optional.
628 Step = ParseExpression();
629 if (Step ==
0) return
0;
632 if (CurTok != tok_in)
633 return Error(
"expected 'in' after for");
634 getNextToken(); // eat 'in'.
636 ExprAST *Body = ParseExpression();
637 if (Body ==
0) return
0;
639 return new ForExprAST(IdName, Start, End, Step, Body);
646 <!-- ======================================================================= -->
647 <h4><a name=
"forir">LLVM IR for the 'for' Loop
</a></h4>
648 <!-- ======================================================================= -->
652 <p>Now we get to the good part: the LLVM IR we want to generate for this thing.
653 With the simple example above, we get this LLVM IR (note that this dump is
654 generated with optimizations disabled for clarity):
657 <div class=
"doc_code">
659 declare double @putchard(double)
661 define double @printstar(double %n) {
663 ; initial value =
1.0 (inlined into phi)
666 loop: ; preds = %loop, %entry
667 %i = phi double [
1.000000e+00, %entry ], [ %nextvar, %loop ]
669 %calltmp = call double @putchard(double
4.200000e+01)
671 %nextvar = fadd double %i,
1.000000e+00
674 %cmptmp = fcmp ult double %i, %n
675 %booltmp = uitofp i1 %cmptmp to double
676 %loopcond = fcmp one double %booltmp,
0.000000e+00
677 br i1 %loopcond, label %loop, label %afterloop
679 afterloop: ; preds = %loop
680 ; loop always returns
0.0
681 ret double
0.000000e+00
686 <p>This loop contains all the same constructs we saw before: a phi node, several
687 expressions, and some basic blocks. Lets see how this fits together.
</p>
691 <!-- ======================================================================= -->
692 <h4><a name=
"forcodegen">Code Generation for the 'for' Loop
</a></h4>
693 <!-- ======================================================================= -->
697 <p>The first part of Codegen is very simple: we just output the start expression
698 for the loop value:
</p>
700 <div class=
"doc_code">
702 Value *ForExprAST::Codegen() {
703 // Emit the start code first, without 'variable' in scope.
704 Value *StartVal = Start-
>Codegen();
705 if (StartVal ==
0) return
0;
709 <p>With this out of the way, the next step is to set up the LLVM basic block
710 for the start of the loop body. In the case above, the whole loop body is one
711 block, but remember that the body code itself could consist of multiple blocks
712 (e.g. if it contains an if/then/else or a for/in expression).
</p>
714 <div class=
"doc_code">
716 // Make the new basic block for the loop header, inserting after current
718 Function *TheFunction = Builder.GetInsertBlock()-
>getParent();
719 BasicBlock *PreheaderBB = Builder.GetInsertBlock();
720 BasicBlock *LoopBB = BasicBlock::Create(getGlobalContext(),
"loop", TheFunction);
722 // Insert an explicit fall through from the current block to the LoopBB.
723 Builder.CreateBr(LoopBB);
727 <p>This code is similar to what we saw for if/then/else. Because we will need
728 it to create the Phi node, we remember the block that falls through into the
729 loop. Once we have that, we create the actual block that starts the loop and
730 create an unconditional branch for the fall-through between the two blocks.
</p>
732 <div class=
"doc_code">
734 // Start insertion in LoopBB.
735 Builder.SetInsertPoint(LoopBB);
737 // Start the PHI node with an entry for Start.
738 PHINode *Variable = Builder.CreatePHI(Type::getDoubleTy(getGlobalContext()),
2, VarName.c_str());
739 Variable-
>addIncoming(StartVal, PreheaderBB);
743 <p>Now that the
"preheader" for the loop is set up, we switch to emitting code
744 for the loop body. To begin with, we move the insertion point and create the
745 PHI node for the loop induction variable. Since we already know the incoming
746 value for the starting value, we add it to the Phi node. Note that the Phi will
747 eventually get a second value for the backedge, but we can't set it up yet
748 (because it doesn't exist!).
</p>
750 <div class=
"doc_code">
752 // Within the loop, the variable is defined equal to the PHI node. If it
753 // shadows an existing variable, we have to restore it, so save it now.
754 Value *OldVal = NamedValues[VarName];
755 NamedValues[VarName] = Variable;
757 // Emit the body of the loop. This, like any other expr, can change the
758 // current BB. Note that we ignore the value computed by the body, but don't
760 if (Body-
>Codegen() ==
0)
765 <p>Now the code starts to get more interesting. Our 'for' loop introduces a new
766 variable to the symbol table. This means that our symbol table can now contain
767 either function arguments or loop variables. To handle this, before we codegen
768 the body of the loop, we add the loop variable as the current value for its
769 name. Note that it is possible that there is a variable of the same name in the
770 outer scope. It would be easy to make this an error (emit an error and return
771 null if there is already an entry for VarName) but we choose to allow shadowing
772 of variables. In order to handle this correctly, we remember the Value that
773 we are potentially shadowing in
<tt>OldVal
</tt> (which will be null if there is
774 no shadowed variable).
</p>
776 <p>Once the loop variable is set into the symbol table, the code recursively
777 codegen's the body. This allows the body to use the loop variable: any
778 references to it will naturally find it in the symbol table.
</p>
780 <div class=
"doc_code">
782 // Emit the step value.
785 StepVal = Step-
>Codegen();
786 if (StepVal ==
0) return
0;
788 // If not specified, use
1.0.
789 StepVal = ConstantFP::get(getGlobalContext(), APFloat(
1.0));
792 Value *NextVar = Builder.CreateFAdd(Variable, StepVal,
"nextvar");
796 <p>Now that the body is emitted, we compute the next value of the iteration
797 variable by adding the step value, or
1.0 if it isn't present. '
<tt>NextVar
</tt>'
798 will be the value of the loop variable on the next iteration of the loop.
</p>
800 <div class=
"doc_code">
802 // Compute the end condition.
803 Value *EndCond = End-
>Codegen();
804 if (EndCond ==
0) return EndCond;
806 // Convert condition to a bool by comparing equal to
0.0.
807 EndCond = Builder.CreateFCmpONE(EndCond,
808 ConstantFP::get(getGlobalContext(), APFloat(
0.0)),
813 <p>Finally, we evaluate the exit value of the loop, to determine whether the
814 loop should exit. This mirrors the condition evaluation for the if/then/else
817 <div class=
"doc_code">
819 // Create the
"after loop" block and insert it.
820 BasicBlock *LoopEndBB = Builder.GetInsertBlock();
821 BasicBlock *AfterBB = BasicBlock::Create(getGlobalContext(),
"afterloop", TheFunction);
823 // Insert the conditional branch into the end of LoopEndBB.
824 Builder.CreateCondBr(EndCond, LoopBB, AfterBB);
826 // Any new code will be inserted in AfterBB.
827 Builder.SetInsertPoint(AfterBB);
831 <p>With the code for the body of the loop complete, we just need to finish up
832 the control flow for it. This code remembers the end block (for the phi node), then creates the block for the loop exit (
"afterloop"). Based on the value of the
833 exit condition, it creates a conditional branch that chooses between executing
834 the loop again and exiting the loop. Any future code is emitted in the
835 "afterloop" block, so it sets the insertion position to it.
</p>
837 <div class=
"doc_code">
839 // Add a new entry to the PHI node for the backedge.
840 Variable-
>addIncoming(NextVar, LoopEndBB);
842 // Restore the unshadowed variable.
844 NamedValues[VarName] = OldVal;
846 NamedValues.erase(VarName);
848 // for expr always returns
0.0.
849 return Constant::getNullValue(Type::getDoubleTy(getGlobalContext()));
854 <p>The final code handles various cleanups: now that we have the
"NextVar"
855 value, we can add the incoming value to the loop PHI node. After that, we
856 remove the loop variable from the symbol table, so that it isn't in scope after
857 the for loop. Finally, code generation of the for loop always returns
0.0, so
858 that is what we return from
<tt>ForExprAST::Codegen
</tt>.
</p>
860 <p>With this, we conclude the
"adding control flow to Kaleidoscope" chapter of
861 the tutorial. In this chapter we added two control flow constructs, and used them to motivate a couple of aspects of the LLVM IR that are important for front-end implementors
862 to know. In the next chapter of our saga, we will get a bit crazier and add
863 <a href=
"LangImpl6.html">user-defined operators
</a> to our poor innocent
870 <!-- *********************************************************************** -->
871 <h2><a name=
"code">Full Code Listing
</a></h2>
872 <!-- *********************************************************************** -->
877 Here is the complete code listing for our running example, enhanced with the
878 if/then/else and for expressions.. To build this example, use:
881 <div class=
"doc_code">
884 g++ -g toy.cpp `llvm-config --cppflags --ldflags --libs core jit native` -O3 -o toy
890 <p>Here is the code:
</p>
892 <div class=
"doc_code">
894 #include
"llvm/DerivedTypes.h"
895 #include
"llvm/ExecutionEngine/ExecutionEngine.h"
896 #include
"llvm/ExecutionEngine/JIT.h"
897 #include
"llvm/LLVMContext.h"
898 #include
"llvm/Module.h"
899 #include
"llvm/PassManager.h"
900 #include
"llvm/Analysis/Verifier.h"
901 #include
"llvm/Analysis/Passes.h"
902 #include
"llvm/Target/TargetData.h"
903 #include
"llvm/Target/TargetSelect.h"
904 #include
"llvm/Transforms/Scalar.h"
905 #include
"llvm/Support/IRBuilder.h"
906 #include
<cstdio
>
907 #include
<string
>
909 #include
<vector
>
910 using namespace llvm;
912 //===----------------------------------------------------------------------===//
914 //===----------------------------------------------------------------------===//
916 // The lexer returns tokens [
0-
255] if it is an unknown character, otherwise one
917 // of these for known things.
922 tok_def = -
2, tok_extern = -
3,
925 tok_identifier = -
4, tok_number = -
5,
928 tok_if = -
6, tok_then = -
7, tok_else = -
8,
929 tok_for = -
9, tok_in = -
10
932 static std::string IdentifierStr; // Filled in if tok_identifier
933 static double NumVal; // Filled in if tok_number
935 /// gettok - Return the next token from standard input.
936 static int gettok() {
937 static int LastChar = ' ';
939 // Skip any whitespace.
940 while (isspace(LastChar))
941 LastChar = getchar();
943 if (isalpha(LastChar)) { // identifier: [a-zA-Z][a-zA-Z0-
9]*
944 IdentifierStr = LastChar;
945 while (isalnum((LastChar = getchar())))
946 IdentifierStr += LastChar;
948 if (IdentifierStr ==
"def") return tok_def;
949 if (IdentifierStr ==
"extern") return tok_extern;
950 if (IdentifierStr ==
"if") return tok_if;
951 if (IdentifierStr ==
"then") return tok_then;
952 if (IdentifierStr ==
"else") return tok_else;
953 if (IdentifierStr ==
"for") return tok_for;
954 if (IdentifierStr ==
"in") return tok_in;
955 return tok_identifier;
958 if (isdigit(LastChar) || LastChar == '.') { // Number: [
0-
9.]+
962 LastChar = getchar();
963 } while (isdigit(LastChar) || LastChar == '.');
965 NumVal = strtod(NumStr.c_str(),
0);
969 if (LastChar == '#') {
970 // Comment until end of line.
971 do LastChar = getchar();
972 while (LastChar != EOF
&& LastChar != '\n'
&& LastChar != '\r');
978 // Check for end of file. Don't eat the EOF.
982 // Otherwise, just return the character as its ascii value.
983 int ThisChar = LastChar;
984 LastChar = getchar();
988 //===----------------------------------------------------------------------===//
989 // Abstract Syntax Tree (aka Parse Tree)
990 //===----------------------------------------------------------------------===//
992 /// ExprAST - Base class for all expression nodes.
995 virtual ~ExprAST() {}
996 virtual Value *Codegen() =
0;
999 /// NumberExprAST - Expression class for numeric literals like
"1.0".
1000 class NumberExprAST : public ExprAST {
1003 NumberExprAST(double val) : Val(val) {}
1004 virtual Value *Codegen();
1007 /// VariableExprAST - Expression class for referencing a variable, like
"a".
1008 class VariableExprAST : public ExprAST {
1011 VariableExprAST(const std::string
&name) : Name(name) {}
1012 virtual Value *Codegen();
1015 /// BinaryExprAST - Expression class for a binary operator.
1016 class BinaryExprAST : public ExprAST {
1020 BinaryExprAST(char op, ExprAST *lhs, ExprAST *rhs)
1021 : Op(op), LHS(lhs), RHS(rhs) {}
1022 virtual Value *Codegen();
1025 /// CallExprAST - Expression class for function calls.
1026 class CallExprAST : public ExprAST {
1028 std::vector
<ExprAST*
> Args;
1030 CallExprAST(const std::string
&callee, std::vector
<ExprAST*
> &args)
1031 : Callee(callee), Args(args) {}
1032 virtual Value *Codegen();
1035 /// IfExprAST - Expression class for if/then/else.
1036 class IfExprAST : public ExprAST {
1037 ExprAST *Cond, *Then, *Else;
1039 IfExprAST(ExprAST *cond, ExprAST *then, ExprAST *_else)
1040 : Cond(cond), Then(then), Else(_else) {}
1041 virtual Value *Codegen();
1044 /// ForExprAST - Expression class for for/in.
1045 class ForExprAST : public ExprAST {
1046 std::string VarName;
1047 ExprAST *Start, *End, *Step, *Body;
1049 ForExprAST(const std::string
&varname, ExprAST *start, ExprAST *end,
1050 ExprAST *step, ExprAST *body)
1051 : VarName(varname), Start(start), End(end), Step(step), Body(body) {}
1052 virtual Value *Codegen();
1055 /// PrototypeAST - This class represents the
"prototype" for a function,
1056 /// which captures its name, and its argument names (thus implicitly the number
1057 /// of arguments the function takes).
1058 class PrototypeAST {
1060 std::vector
<std::string
> Args;
1062 PrototypeAST(const std::string
&name, const std::vector
<std::string
> &args)
1063 : Name(name), Args(args) {}
1065 Function *Codegen();
1068 /// FunctionAST - This class represents a function definition itself.
1070 PrototypeAST *Proto;
1073 FunctionAST(PrototypeAST *proto, ExprAST *body)
1074 : Proto(proto), Body(body) {}
1076 Function *Codegen();
1079 //===----------------------------------------------------------------------===//
1081 //===----------------------------------------------------------------------===//
1083 /// CurTok/getNextToken - Provide a simple token buffer. CurTok is the current
1084 /// token the parser is looking at. getNextToken reads another token from the
1085 /// lexer and updates CurTok with its results.
1087 static int getNextToken() {
1088 return CurTok = gettok();
1091 /// BinopPrecedence - This holds the precedence for each binary operator that is
1093 static std::map
<char, int
> BinopPrecedence;
1095 /// GetTokPrecedence - Get the precedence of the pending binary operator token.
1096 static int GetTokPrecedence() {
1097 if (!isascii(CurTok))
1100 // Make sure it's a declared binop.
1101 int TokPrec = BinopPrecedence[CurTok];
1102 if (TokPrec
<=
0) return -
1;
1106 /// Error* - These are little helper functions for error handling.
1107 ExprAST *Error(const char *Str) { fprintf(stderr,
"Error: %s\n", Str);return
0;}
1108 PrototypeAST *ErrorP(const char *Str) { Error(Str); return
0; }
1109 FunctionAST *ErrorF(const char *Str) { Error(Str); return
0; }
1111 static ExprAST *ParseExpression();
1115 /// ::= identifier '(' expression* ')'
1116 static ExprAST *ParseIdentifierExpr() {
1117 std::string IdName = IdentifierStr;
1119 getNextToken(); // eat identifier.
1121 if (CurTok != '(') // Simple variable ref.
1122 return new VariableExprAST(IdName);
1125 getNextToken(); // eat (
1126 std::vector
<ExprAST*
> Args;
1127 if (CurTok != ')') {
1129 ExprAST *Arg = ParseExpression();
1131 Args.push_back(Arg);
1133 if (CurTok == ')') break;
1136 return Error(
"Expected ')' or ',' in argument list");
1144 return new CallExprAST(IdName, Args);
1147 /// numberexpr ::= number
1148 static ExprAST *ParseNumberExpr() {
1149 ExprAST *Result = new NumberExprAST(NumVal);
1150 getNextToken(); // consume the number
1154 /// parenexpr ::= '(' expression ')'
1155 static ExprAST *ParseParenExpr() {
1156 getNextToken(); // eat (.
1157 ExprAST *V = ParseExpression();
1161 return Error(
"expected ')'");
1162 getNextToken(); // eat ).
1166 /// ifexpr ::= 'if' expression 'then' expression 'else' expression
1167 static ExprAST *ParseIfExpr() {
1168 getNextToken(); // eat the if.
1171 ExprAST *Cond = ParseExpression();
1172 if (!Cond) return
0;
1174 if (CurTok != tok_then)
1175 return Error(
"expected then");
1176 getNextToken(); // eat the then
1178 ExprAST *Then = ParseExpression();
1179 if (Then ==
0) return
0;
1181 if (CurTok != tok_else)
1182 return Error(
"expected else");
1186 ExprAST *Else = ParseExpression();
1187 if (!Else) return
0;
1189 return new IfExprAST(Cond, Then, Else);
1192 /// forexpr ::= 'for' identifier '=' expr ',' expr (',' expr)? 'in' expression
1193 static ExprAST *ParseForExpr() {
1194 getNextToken(); // eat the for.
1196 if (CurTok != tok_identifier)
1197 return Error(
"expected identifier after for");
1199 std::string IdName = IdentifierStr;
1200 getNextToken(); // eat identifier.
1203 return Error(
"expected '=' after for");
1204 getNextToken(); // eat '='.
1207 ExprAST *Start = ParseExpression();
1208 if (Start ==
0) return
0;
1210 return Error(
"expected ',' after for start value");
1213 ExprAST *End = ParseExpression();
1214 if (End ==
0) return
0;
1216 // The step value is optional.
1218 if (CurTok == ',') {
1220 Step = ParseExpression();
1221 if (Step ==
0) return
0;
1224 if (CurTok != tok_in)
1225 return Error(
"expected 'in' after for");
1226 getNextToken(); // eat 'in'.
1228 ExprAST *Body = ParseExpression();
1229 if (Body ==
0) return
0;
1231 return new ForExprAST(IdName, Start, End, Step, Body);
1235 /// ::= identifierexpr
1240 static ExprAST *ParsePrimary() {
1242 default: return Error(
"unknown token when expecting an expression");
1243 case tok_identifier: return ParseIdentifierExpr();
1244 case tok_number: return ParseNumberExpr();
1245 case '(': return ParseParenExpr();
1246 case tok_if: return ParseIfExpr();
1247 case tok_for: return ParseForExpr();
1252 /// ::= ('+' primary)*
1253 static ExprAST *ParseBinOpRHS(int ExprPrec, ExprAST *LHS) {
1254 // If this is a binop, find its precedence.
1256 int TokPrec = GetTokPrecedence();
1258 // If this is a binop that binds at least as tightly as the current binop,
1259 // consume it, otherwise we are done.
1260 if (TokPrec
< ExprPrec)
1263 // Okay, we know this is a binop.
1265 getNextToken(); // eat binop
1267 // Parse the primary expression after the binary operator.
1268 ExprAST *RHS = ParsePrimary();
1271 // If BinOp binds less tightly with RHS than the operator after RHS, let
1272 // the pending operator take RHS as its LHS.
1273 int NextPrec = GetTokPrecedence();
1274 if (TokPrec
< NextPrec) {
1275 RHS = ParseBinOpRHS(TokPrec+
1, RHS);
1276 if (RHS ==
0) return
0;
1280 LHS = new BinaryExprAST(BinOp, LHS, RHS);
1285 /// ::= primary binoprhs
1287 static ExprAST *ParseExpression() {
1288 ExprAST *LHS = ParsePrimary();
1291 return ParseBinOpRHS(
0, LHS);
1295 /// ::= id '(' id* ')'
1296 static PrototypeAST *ParsePrototype() {
1297 if (CurTok != tok_identifier)
1298 return ErrorP(
"Expected function name in prototype");
1300 std::string FnName = IdentifierStr;
1304 return ErrorP(
"Expected '(' in prototype");
1306 std::vector
<std::string
> ArgNames;
1307 while (getNextToken() == tok_identifier)
1308 ArgNames.push_back(IdentifierStr);
1310 return ErrorP(
"Expected ')' in prototype");
1313 getNextToken(); // eat ')'.
1315 return new PrototypeAST(FnName, ArgNames);
1318 /// definition ::= 'def' prototype expression
1319 static FunctionAST *ParseDefinition() {
1320 getNextToken(); // eat def.
1321 PrototypeAST *Proto = ParsePrototype();
1322 if (Proto ==
0) return
0;
1324 if (ExprAST *E = ParseExpression())
1325 return new FunctionAST(Proto, E);
1329 /// toplevelexpr ::= expression
1330 static FunctionAST *ParseTopLevelExpr() {
1331 if (ExprAST *E = ParseExpression()) {
1332 // Make an anonymous proto.
1333 PrototypeAST *Proto = new PrototypeAST(
"", std::vector
<std::string
>());
1334 return new FunctionAST(Proto, E);
1339 /// external ::= 'extern' prototype
1340 static PrototypeAST *ParseExtern() {
1341 getNextToken(); // eat extern.
1342 return ParsePrototype();
1345 //===----------------------------------------------------------------------===//
1347 //===----------------------------------------------------------------------===//
1349 static Module *TheModule;
1350 static IRBuilder
<> Builder(getGlobalContext());
1351 static std::map
<std::string, Value*
> NamedValues;
1352 static FunctionPassManager *TheFPM;
1354 Value *ErrorV(const char *Str) { Error(Str); return
0; }
1356 Value *NumberExprAST::Codegen() {
1357 return ConstantFP::get(getGlobalContext(), APFloat(Val));
1360 Value *VariableExprAST::Codegen() {
1361 // Look this variable up in the function.
1362 Value *V = NamedValues[Name];
1363 return V ? V : ErrorV(
"Unknown variable name");
1366 Value *BinaryExprAST::Codegen() {
1367 Value *L = LHS-
>Codegen();
1368 Value *R = RHS-
>Codegen();
1369 if (L ==
0 || R ==
0) return
0;
1372 case '+': return Builder.CreateFAdd(L, R,
"addtmp");
1373 case '-': return Builder.CreateFSub(L, R,
"subtmp");
1374 case '*': return Builder.CreateFMul(L, R,
"multmp");
1376 L = Builder.CreateFCmpULT(L, R,
"cmptmp");
1377 // Convert bool
0/
1 to double
0.0 or
1.0
1378 return Builder.CreateUIToFP(L, Type::getDoubleTy(getGlobalContext()),
1380 default: return ErrorV(
"invalid binary operator");
1384 Value *CallExprAST::Codegen() {
1385 // Look up the name in the global module table.
1386 Function *CalleeF = TheModule-
>getFunction(Callee);
1388 return ErrorV(
"Unknown function referenced");
1390 // If argument mismatch error.
1391 if (CalleeF-
>arg_size() != Args.size())
1392 return ErrorV(
"Incorrect # arguments passed");
1394 std::vector
<Value*
> ArgsV;
1395 for (unsigned i =
0, e = Args.size(); i != e; ++i) {
1396 ArgsV.push_back(Args[i]-
>Codegen());
1397 if (ArgsV.back() ==
0) return
0;
1400 return Builder.CreateCall(CalleeF, ArgsV.begin(), ArgsV.end(),
"calltmp");
1403 Value *IfExprAST::Codegen() {
1404 Value *CondV = Cond-
>Codegen();
1405 if (CondV ==
0) return
0;
1407 // Convert condition to a bool by comparing equal to
0.0.
1408 CondV = Builder.CreateFCmpONE(CondV,
1409 ConstantFP::get(getGlobalContext(), APFloat(
0.0)),
1412 Function *TheFunction = Builder.GetInsertBlock()-
>getParent();
1414 // Create blocks for the then and else cases. Insert the 'then' block at the
1415 // end of the function.
1416 BasicBlock *ThenBB = BasicBlock::Create(getGlobalContext(),
"then", TheFunction);
1417 BasicBlock *ElseBB = BasicBlock::Create(getGlobalContext(),
"else");
1418 BasicBlock *MergeBB = BasicBlock::Create(getGlobalContext(),
"ifcont");
1420 Builder.CreateCondBr(CondV, ThenBB, ElseBB);
1423 Builder.SetInsertPoint(ThenBB);
1425 Value *ThenV = Then-
>Codegen();
1426 if (ThenV ==
0) return
0;
1428 Builder.CreateBr(MergeBB);
1429 // Codegen of 'Then' can change the current block, update ThenBB for the PHI.
1430 ThenBB = Builder.GetInsertBlock();
1433 TheFunction-
>getBasicBlockList().push_back(ElseBB);
1434 Builder.SetInsertPoint(ElseBB);
1436 Value *ElseV = Else-
>Codegen();
1437 if (ElseV ==
0) return
0;
1439 Builder.CreateBr(MergeBB);
1440 // Codegen of 'Else' can change the current block, update ElseBB for the PHI.
1441 ElseBB = Builder.GetInsertBlock();
1443 // Emit merge block.
1444 TheFunction-
>getBasicBlockList().push_back(MergeBB);
1445 Builder.SetInsertPoint(MergeBB);
1446 PHINode *PN = Builder.CreatePHI(Type::getDoubleTy(getGlobalContext()),
2,
1449 PN-
>addIncoming(ThenV, ThenBB);
1450 PN-
>addIncoming(ElseV, ElseBB);
1454 Value *ForExprAST::Codegen() {
1457 // start = startexpr
1460 // variable = phi [start, loopheader], [nextvariable, loopend]
1466 // nextvariable = variable + step
1467 // endcond = endexpr
1468 // br endcond, loop, endloop
1471 // Emit the start code first, without 'variable' in scope.
1472 Value *StartVal = Start-
>Codegen();
1473 if (StartVal ==
0) return
0;
1475 // Make the new basic block for the loop header, inserting after current
1477 Function *TheFunction = Builder.GetInsertBlock()-
>getParent();
1478 BasicBlock *PreheaderBB = Builder.GetInsertBlock();
1479 BasicBlock *LoopBB = BasicBlock::Create(getGlobalContext(),
"loop", TheFunction);
1481 // Insert an explicit fall through from the current block to the LoopBB.
1482 Builder.CreateBr(LoopBB);
1484 // Start insertion in LoopBB.
1485 Builder.SetInsertPoint(LoopBB);
1487 // Start the PHI node with an entry for Start.
1488 PHINode *Variable = Builder.CreatePHI(Type::getDoubleTy(getGlobalContext()),
2, VarName.c_str());
1489 Variable-
>addIncoming(StartVal, PreheaderBB);
1491 // Within the loop, the variable is defined equal to the PHI node. If it
1492 // shadows an existing variable, we have to restore it, so save it now.
1493 Value *OldVal = NamedValues[VarName];
1494 NamedValues[VarName] = Variable;
1496 // Emit the body of the loop. This, like any other expr, can change the
1497 // current BB. Note that we ignore the value computed by the body, but don't
1499 if (Body-
>Codegen() ==
0)
1502 // Emit the step value.
1505 StepVal = Step-
>Codegen();
1506 if (StepVal ==
0) return
0;
1508 // If not specified, use
1.0.
1509 StepVal = ConstantFP::get(getGlobalContext(), APFloat(
1.0));
1512 Value *NextVar = Builder.CreateFAdd(Variable, StepVal,
"nextvar");
1514 // Compute the end condition.
1515 Value *EndCond = End-
>Codegen();
1516 if (EndCond ==
0) return EndCond;
1518 // Convert condition to a bool by comparing equal to
0.0.
1519 EndCond = Builder.CreateFCmpONE(EndCond,
1520 ConstantFP::get(getGlobalContext(), APFloat(
0.0)),
1523 // Create the
"after loop" block and insert it.
1524 BasicBlock *LoopEndBB = Builder.GetInsertBlock();
1525 BasicBlock *AfterBB = BasicBlock::Create(getGlobalContext(),
"afterloop", TheFunction);
1527 // Insert the conditional branch into the end of LoopEndBB.
1528 Builder.CreateCondBr(EndCond, LoopBB, AfterBB);
1530 // Any new code will be inserted in AfterBB.
1531 Builder.SetInsertPoint(AfterBB);
1533 // Add a new entry to the PHI node for the backedge.
1534 Variable-
>addIncoming(NextVar, LoopEndBB);
1536 // Restore the unshadowed variable.
1538 NamedValues[VarName] = OldVal;
1540 NamedValues.erase(VarName);
1543 // for expr always returns
0.0.
1544 return Constant::getNullValue(Type::getDoubleTy(getGlobalContext()));
1547 Function *PrototypeAST::Codegen() {
1548 // Make the function type: double(double,double) etc.
1549 std::vector
<const Type*
> Doubles(Args.size(),
1550 Type::getDoubleTy(getGlobalContext()));
1551 FunctionType *FT = FunctionType::get(Type::getDoubleTy(getGlobalContext()),
1554 Function *F = Function::Create(FT, Function::ExternalLinkage, Name, TheModule);
1556 // If F conflicted, there was already something named 'Name'. If it has a
1557 // body, don't allow redefinition or reextern.
1558 if (F-
>getName() != Name) {
1559 // Delete the one we just made and get the existing one.
1560 F-
>eraseFromParent();
1561 F = TheModule-
>getFunction(Name);
1563 // If F already has a body, reject this.
1564 if (!F-
>empty()) {
1565 ErrorF(
"redefinition of function");
1569 // If F took a different number of args, reject.
1570 if (F-
>arg_size() != Args.size()) {
1571 ErrorF(
"redefinition of function with different # args");
1576 // Set names for all arguments.
1578 for (Function::arg_iterator AI = F-
>arg_begin(); Idx != Args.size();
1580 AI-
>setName(Args[Idx]);
1582 // Add arguments to variable symbol table.
1583 NamedValues[Args[Idx]] = AI;
1589 Function *FunctionAST::Codegen() {
1590 NamedValues.clear();
1592 Function *TheFunction = Proto-
>Codegen();
1593 if (TheFunction ==
0)
1596 // Create a new basic block to start insertion into.
1597 BasicBlock *BB = BasicBlock::Create(getGlobalContext(),
"entry", TheFunction);
1598 Builder.SetInsertPoint(BB);
1600 if (Value *RetVal = Body-
>Codegen()) {
1601 // Finish off the function.
1602 Builder.CreateRet(RetVal);
1604 // Validate the generated code, checking for consistency.
1605 verifyFunction(*TheFunction);
1607 // Optimize the function.
1608 TheFPM-
>run(*TheFunction);
1613 // Error reading body, remove function.
1614 TheFunction-
>eraseFromParent();
1618 //===----------------------------------------------------------------------===//
1619 // Top-Level parsing and JIT Driver
1620 //===----------------------------------------------------------------------===//
1622 static ExecutionEngine *TheExecutionEngine;
1624 static void HandleDefinition() {
1625 if (FunctionAST *F = ParseDefinition()) {
1626 if (Function *LF = F-
>Codegen()) {
1627 fprintf(stderr,
"Read function definition:");
1631 // Skip token for error recovery.
1636 static void HandleExtern() {
1637 if (PrototypeAST *P = ParseExtern()) {
1638 if (Function *F = P-
>Codegen()) {
1639 fprintf(stderr,
"Read extern: ");
1643 // Skip token for error recovery.
1648 static void HandleTopLevelExpression() {
1649 // Evaluate a top-level expression into an anonymous function.
1650 if (FunctionAST *F = ParseTopLevelExpr()) {
1651 if (Function *LF = F-
>Codegen()) {
1652 // JIT the function, returning a function pointer.
1653 void *FPtr = TheExecutionEngine-
>getPointerToFunction(LF);
1655 // Cast it to the right type (takes no arguments, returns a double) so we
1656 // can call it as a native function.
1657 double (*FP)() = (double (*)())(intptr_t)FPtr;
1658 fprintf(stderr,
"Evaluated to %f\n", FP());
1661 // Skip token for error recovery.
1666 /// top ::= definition | external | expression | ';'
1667 static void MainLoop() {
1669 fprintf(stderr,
"ready> ");
1671 case tok_eof: return;
1672 case ';': getNextToken(); break; // ignore top-level semicolons.
1673 case tok_def: HandleDefinition(); break;
1674 case tok_extern: HandleExtern(); break;
1675 default: HandleTopLevelExpression(); break;
1680 //===----------------------------------------------------------------------===//
1681 //
"Library" functions that can be
"extern'd" from user code.
1682 //===----------------------------------------------------------------------===//
1684 /// putchard - putchar that takes a double and returns
0.
1686 double putchard(double X) {
1691 //===----------------------------------------------------------------------===//
1692 // Main driver code.
1693 //===----------------------------------------------------------------------===//
1696 InitializeNativeTarget();
1697 LLVMContext
&Context = getGlobalContext();
1699 // Install standard binary operators.
1700 //
1 is lowest precedence.
1701 BinopPrecedence['
<'] =
10;
1702 BinopPrecedence['+'] =
20;
1703 BinopPrecedence['-'] =
20;
1704 BinopPrecedence['*'] =
40; // highest.
1706 // Prime the first token.
1707 fprintf(stderr,
"ready> ");
1710 // Make the module, which holds all the code.
1711 TheModule = new Module(
"my cool jit", Context);
1713 // Create the JIT. This takes ownership of the module.
1715 TheExecutionEngine = EngineBuilder(TheModule).setErrorStr(
&ErrStr).create();
1716 if (!TheExecutionEngine) {
1717 fprintf(stderr,
"Could not create ExecutionEngine: %s\n", ErrStr.c_str());
1721 FunctionPassManager OurFPM(TheModule);
1723 // Set up the optimizer pipeline. Start with registering info about how the
1724 // target lays out data structures.
1725 OurFPM.add(new TargetData(*TheExecutionEngine-
>getTargetData()));
1726 // Provide basic AliasAnalysis support for GVN.
1727 OurFPM.add(createBasicAliasAnalysisPass());
1728 // Do simple
"peephole" optimizations and bit-twiddling optzns.
1729 OurFPM.add(createInstructionCombiningPass());
1730 // Reassociate expressions.
1731 OurFPM.add(createReassociatePass());
1732 // Eliminate Common SubExpressions.
1733 OurFPM.add(createGVNPass());
1734 // Simplify the control flow graph (deleting unreachable blocks, etc).
1735 OurFPM.add(createCFGSimplificationPass());
1737 OurFPM.doInitialization();
1739 // Set the global so the code gen can use this.
1740 TheFPM =
&OurFPM;
1742 // Run the main
"interpreter loop" now.
1747 // Print out all of the generated code.
1748 TheModule-
>dump();
1755 <a href=
"LangImpl6.html">Next: Extending the language: user-defined operators
</a>
1758 <!-- *********************************************************************** -->
1761 <a href=
"http://jigsaw.w3.org/css-validator/check/referer"><img
1762 src=
"http://jigsaw.w3.org/css-validator/images/vcss" alt=
"Valid CSS!"></a>
1763 <a href=
"http://validator.w3.org/check/referer"><img
1764 src=
"http://www.w3.org/Icons/valid-html401" alt=
"Valid HTML 4.01!"></a>
1766 <a href=
"mailto:sabre@nondot.org">Chris Lattner
</a><br>
1767 <a href=
"http://llvm.org/">The LLVM Compiler Infrastructure
</a><br>
1768 Last modified: $Date$