Download presentation
Presentation is loading. Please wait.
Published byGrant Anthony Modified over 8 years ago
1
CS 153: Concepts of Compiler Design November 9 Class Meeting Department of Computer Science San Jose State University Fall 2015 Instructor: Ron Mak www.cs.sjsu.edu/~mak 1
2
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 2 Code Templates Syntax diagrams Specify the source language grammar Help us write the parsers Code templates Specify what object code to generate Help us write the code emitters
3
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 3 Code Template for a Pascal Program Translate a Pascal program into a public clas s. Program variables become class fields. Must have a default constructor. Each procedure or function becomes a private static method. The main program code becomes the public static main method.
4
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 4 Compilation Strategy We’ll compile a Pascal program as if it were a public Java class. The Pascal program name becomes the Java class name. The main program becomes the main method of the Java class. We’ll compile each program variable as if it were a field of the class. Fields do have names in a Jasmin program. Recall that local variables and parameters are referred to only by their slot numbers.
5
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 5 Compilation Strategy, cont’d We’ll compile each Pascal procedure or function as if it were a private static method of the Java class. Local variables and formal parameters of the method do not have names in a Jasmin program. Jasmin instructions refer to local variables and parameters by their slot numbers of the local variables array.
6
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 6 Jasmin Type Descriptors Java Scalar typeJasmin Type Descriptor intI floatF booleanZ charC Java Array typeJasmin Type Descriptor java.lang.String[][Ljava/lang/String; Newton[][][[LNewton; int[][][][[[I; Java ClassJasmin Type Descriptor java.lang.StringLjava/lang/String; java.util.HashMapLjava/util/HashMap; NewtonLNewton;
7
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 7 Program Fields
8
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 8 Program Fields, cont’d For example: PROGRAM test; VAR i, j, k : integer; x, y : real; p, q : boolean; ch : char; index : 1..10; Compiles to:.field private static _runTimer LRunTimer;.field private static _standardIn LPascalTextIn;.field private static ch C.field private static i I.field private static index I.field private static j I.field private static k I.field private static p Z.field private static q Z.field private static x F.field private static y F Classes RunTimer and PascalTextIn are defined in the Pascal Runtime Library PascalRTL.jar which contains runtime routines written in Java. Pascal program variables
9
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 9 Code Template for the Main Method, cont’d
10
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 10 Code Template for the Main Method, cont’d The main method prologue initializes the runtime timer _runTimer and the standard input _standardIn fields. The main method epilogue prints the elapsed run time..limit locals.limit stack specify the size of the local variables array and the maximum size of the operand stack, respectively.
11
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 11 Loading a Program Variable’s Value To load (push) a program variable’s value onto the operand stack: getstatic program-name / variable-name type-descriptor Examples: Java Scalar typeJasmin Type Descriptor intI floatF booleanZ charC getstatic Test/count I getstatic Test/radius F
12
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 12 Storing a Program Variable’s Value To store (pop) a value from the operand stack into a program variable: putstatic program-name / variable-name type-descriptor Examples: Java Scalar typeJasmin Type Descriptor intI floatF booleanZ charC putstatic Test/count I putstatic Test/radius F
13
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 13 Pcl2 Pcl2 has a.jjt grammar file to generate a parse tree. The process() method of the backend CodeGenerator class generates the Jasmin object code for an entire Pascal program. program header program fields (variables) class constructor main method header main method prologue main method’s compound statement (using the visitor pattern) main method epilogue
14
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 14 Pcl2 Code Generator You can use the visitor design pattern to generate Jasmin object code for the main program’s compound statement: CodeGeneratorVisitor codeVisitor = new CodeGeneratorVisitor(); Node rootNode = iCode.getRoot(); rootNode.jjtAccept(codeVisitor, programName);
15
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 15 Pcl2 Code Generator public class CodeGeneratorVisitor extends PclParserVisitorAdapter implements PclParserTreeConstants { public Object visit(ASTintegerConstant node, Object data) { int value = (Integer) node.getAttribute(VALUE); // Emit a load constant instruction. CodeGenerator.objectFile.println(" ldc " + value); CodeGenerator.objectFile.flush(); return data; } public Object visit(ASTrealConstant node, Object data)... public Object visit(ASTassignmentStatement node, Object data)... public Object visit(ASTadd node, Object data)... public Object visit(ASTvariable node, Object data)... } The visit() methods emit the appropriate Jasmin code for various types of tree nodes: You should check whether to use a shortcut instruction Demo
16
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 16 Code for Procedures and Functions
17
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 17 Code for Procedures and Functions Each a private static method. Method signature: Routine’s name Type descriptors of the formal parameters. Example: TYPE arr = ARRAY [1..5] OF real; FUNCTION func(i, j : integer; x, y : real; p : boolean; ch : char; vector : arr; length : integer) : real;.method private static func(IIFFZC[FI)F Compiles to:
18
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 18 Compiling Local Variables Compiles to: TYPE arr = ARRAY [1..5] OF real; FUNCTION func(i, j : integer; x, y : real; p : boolean; ch : char; vector : arr; length : integer) : real; VAR n : integer; z : real; w : arr;.method private static func(IIFFZC[FI)F.var 5 is ch C.var 0 is i I.var 1 is j I.var 7 is length I.var 8 is n I.var 4 is p Z.var 6 is vector [F.var 10 is w [F.var 2 is x F.var 3 is y F.var 9 is z F.var 11 is func F Add a slot number for the local variables array to each variable’s symbol table entry.
19
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 19 Generating Code for Expressions Recall that in our Pascal interpreter, the expression executor does a postorder traversal of the expression parse tree. Pascal’s operator precedence rules are encoded in the structure of the parse tree. alpha + 3/(beta - gamma) + 5
20
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 20 Generating Code for Expressions A compiler’s expression code generator also does a postorder traversal to generate code. Assume that alpha, beta, and gamma are local real variables alpha local variable slot #0 beta local variable slot #1 gamma local variable slot #2 Generated code: 1 fload_0 2 ldc 3.0 3 fload_1 4 fload_2 5 fsub 6 fdiv 7 fadd 8 ldc 5.0 9 fadd alpha + 3/(beta - gamma) + 5
21
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 21 Key Points Pascal program public Jasmin class Pascal program (level 1) variables private static Jasmin class fields (with names) Pascal procedure or function private static Jasmin method Pascal procedure or function local variables and formal parameters local variables array slot numbers (no names)
22
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 22 Tips Write special code emitters for loading (pushing) values onto the operand stack. If loading constants: Determine whether you can emit a shortcut instruction.
23
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 23 Tips, cont’d If loading variables: Determine whether it’s a program variable (emit a getstatic instruction with the field name) or a local variable (emit a load instruction with the slot number). Determine whether you can emit a shortcut instruction for a local variable. Similarly, write special code emitters for storing (popping) values off the operand stack into variables.
24
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 24 Assignment #7 Generate parse trees with JJTree. Extra credit (up to 10 points): Using pcl2 as a model, write the first version of your backend code generator. Walk your parse tree in the back end and generate some valid Jasmin code.
25
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 25 What Would James Gosling Do? What Jasmin code should you generate? public class Test { private static float test() { float alpha = 0; //* slot #0 float beta = 10; //* slot #1 float gamma = 20; //* slot #2 int thirty = 30; //* slot #3 int forty = 40; //* slot #4 int fifty = 50; //* slot #5 if (forty == fifty) { return alpha + 3/(beta - gamma) + 5; } else { return alpha + thirty/(beta - gamma) + fifty; }
26
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 26 What Would James Gosling Do, cont’d Run javap to disassemble the.class file : javap –l –p –s –c Test.class fload_0 ldc3.000000 fload_1 fload_2 fsub fdiv fadd ldc5.000000 fadd freturn return alpha + 3/(beta - gamma) + 5; fload_0 iload_3 i2f fload_1 fload_2 fsub fdiv fadd iload5 i2f fadd freturn return alpha + thirty/(beta - gamma) + fifty; float alpha = 0; //* #0 float beta = 10; //* #1 float gamma = 20; //* #2 int thirty = 30; //* #3 int forty = 40; //* #4 int fifty = 50; //* #5 Demo
27
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 27 What Would James Gosling Do, cont’d If you have a construct in your source language and you don’t know what Jasmin code to generate for it: Write the equivalent construct in Java. Compile the Java into a.class file. Run javap to get an idea of what code you should generate. Unfortunately, javap output is not compatible with the Jasmin assembler. Jasmin won’t assemble javap-generated programs.
28
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 28 Comparing Integer Values Jasmin has a set of instructions each of which compares the top two integer values on the operand stack and then branches if the comparison is true. InstructionAction if_icmpeq label Branch to label if [TOS-1] == [TOS] if_icmpne label Branch to label if [TOS-1] != [TOS] if_icmpgt label Branch to label if [TOS-1] > [TOS] if_icmpge label Branch to label if [TOS-1] >= [TOS] if_icmplt label Branch to label if [TOS-1] < [TOS] if_icmple label Branch to label if [TOS-1] <= [TOS]
29
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 29 Comparing Integer Values, cont’d The two values are popped off the operand stack. [TOS] is the value at the top of the stack. [TOS-1] is the value just under the one at the top of the stack. InstructionAction if_icmpeq label Branch to label if [TOS-1] == [TOS] if_icmpne label Branch to label if [TOS-1] != [TOS] if_icmpgt label Branch to label if [TOS-1] > [TOS] if_icmpge label Branch to label if [TOS-1] >= [TOS] if_icmplt label Branch to label if [TOS-1] < [TOS] if_icmple label Branch to label if [TOS-1] <= [TOS]
30
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 30 Comparing Integer Values, cont’d You can also simply compare the single integer value at the top of the operand stack to 0 and then branch if the comparison is true. The top value is popped off the stack. InstructionAction ifeq label Branch to label if [TOS] == 0 ifne label Branch to label if [TOS] != 0 ifgt label Branch to label if [TOS] > 0 ifge label Branch to label if [TOS] >= 0 iflt label Branch to label if [TOS1] < 0 ifle label Branch to label if [TOS] <= 0
31
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 31 Comparing Other Values Instructions lcmp, fcmp, and dcmp compare two long, float, or double values at the top of the operand stack. Each pops the top two values off the operand stack and then pushes the integer value -1, 0, or 1 onto the stack. If [TOS-1] < [TOS], push -1 onto the stack. If [TOS-1] = [TOS], push 0 onto the stack. If [TOS-1] > [TOS], push 1 onto the stack. Use instructions iflt, ifeq, or ifgt to test for the -1, 0, or 1.
32
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 32 Expression Syntax Diagrams What code should we generate for a relational expression?
33
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 33 Relational Expressions Suppose i and j are local integer variables, and that: i slot #0 j slot #1 0 represents false and 1 represents true. For the expression i < j leave either 0 or 1 on top of the operand stack: iload_0 ; push the value of i (slot #0) iload_1 ; push the value of j (slot #1) if_icmplt L003 ; branch if i < j iconst_0 ; push false goto L004 ; go to next statement L003: iconst_1 ; push true L004: The code in red are the only parts that change based on the expression. Your code generator also needs to emit labels.
34
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 34 Relational Expression Code Template iload_0 iload_1 if_icmplt L003 iconst_0 goto L004 L003: iconst_1 L004:
35
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 35 Assignment Statement Code Template The code template for an assignment statement to a local variable := code for x store n Where x is i, l, f, or d depending on the type of the computed value of. You can generate a shortcut store instruction such as istore_3 (3 is a slot number) whenever possible.
36
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 36 IF Statement Code Templates The code that evaluates the boolean expression leaves either 0 (false) or 1 (true) on top of the operand stack. ifeq branches if [TOS] is 0 (the expression is false)
37
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 37 Example: IF Statement PROGRAM IfTest; VAR i, j, t, f : integer; BEGIN {IF statements}... IF i < j THEN t := 300; IF i = j THEN t := 200 ELSE f := -200;... END. getstaticiftest/i I getstaticiftest/j I if_icmpltL002 iconst_0 gotoL003 L002: iconst_1 L003: ifeqL001 sipush300 putstaticiftest/t I L001: getstaticiftest/i I getstaticiftest/j I if_icmpeqL005 iconst_0 gotoL006 L005: iconst_1 L006: ifeqL007 sipush200 putstaticiftest/t I gotoL004 L007: sipush200 ineg putstaticiftest/f I L004:
38
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 38 Looping Statement Code Template The code that evaluates the boolean expression leaves either 0 (false) or 1 (true) on top of the operand stack. ifne branches if [TOS] is not 0 (the expression value is true) There might not be any code before or after the test.
39
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 39 Example: Newton’s Square Root Function #0 #1 #2 FUNCTION sqrt(x : real) : real; VAR i : integer; root : real; BEGIN i := 0; root := x; REPEAT root := (x/root + root)/2; i := i + 1; UNTIL i > 10; sqrt := root; END; iconst_0 istore_1 ; i := 0 fload_0 fstore_2 ; root := x L000: fload_0 ; x fload_2 ; root fdiv ; / fload_2 ; root fadd ; + fconst_2 ; 2.0 fdiv ; / fstore_2 ; ==> root iinc 1 1 ; i := i + 1; iload_1 ; i bipush 10 ; 10 if_icmpgt L001 ; if i > 10 goto L001 iconst_0 ; false goto L002 L001: iconst_1 ; true L002: ifne L001 ; if true goto L003 goto L000 L003: fload_2 freturn ; return root
40
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 40 Example: FOR Statement PROGRAM ForTest; VAR j, k, n : integer; BEGIN {FOR statements}... FOR k := j TO 5 DO BEGIN n := k; END;... END. getstaticfortest/j I putstaticfortest/k I L001: getstaticfortest/k I iconst_5 if_icmpgtL003 iconst_0 gotoL004 L003: iconst_1 L004: ifneL002 getstaticfortest/k I putstaticfortest/n I getstaticfortest/k I iconst_1 iadd putstaticfortest/k I gotoL001 L002: Remember that program variables are translated into Jasmin static fields, and so they have names, not slot numbers. This is code emitted for a general > test. It can be much improved!
41
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 41 SELECT Statement
42
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 42 Example: CASE Statement VAR i, j : integer;... CASE i OF 100,105: j := 1000; 200,256,282: j := 2000; END iload_0 ; i lookupswitch 100: L010 105: L010 200: L020 256: L020 282: L020 default: L099 L010: sipush 1000 istore_1 ; j := 1000 goto L099 L020: sipush 2000 istore_1 ; j := 2000 goto L099 L099: #0#1
43
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 43 Pascal Procedures and Functions Analogous to Java methods. Two major simplifications for our Pascal compiler: Standard Pascal is not object-oriented. Therefore, Pascal procedures and functions are more like the private static methods of a Java class. Java does not have nested methods. The JVM does not easily implement nested methods. Therefore, we will compile only “top level” (level 1) Pascal procedures and functions.
44
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 44 Procedures and Functions, cont’d A Pascal program: PROGRAM ADDER; VAR i, j, sum : integer; FUNCTION add(n1, n2 : integer) : integer; VAR s : integer; BEGIN s := i + j + n1 + n2; add := s; END; BEGIN i := 10; j := 20; sum := add(100, 200); writeln('Sum = ', sum) END. The roughly equivalent Java class: Fields and methods are private static. public class Adder { private static int i, j, sum; private static int add(int n1, int n2) { int s = i + j + n1 + n2; return s; } public static void main(String args[]) { i = 10; j = 20; sum = add(100, 200); System.out.println("Sum = " + sum); }
45
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 45 Code for a Pascal Main Program PROGRAM ADDER; VAR i, j, sum : integer; FUNCTION add(n1, n2 : integer) : integer; VAR s : integer; BEGIN s := i + j + n1 + n2; add := s; END; BEGIN i := 10; j := 20; sum := add(100, 200); writeln('Sum = ', sum) END..class public super Adder.super java/lang/Object.private field static i I.private field static j I.private field static sum I.method public ()V aload_0 invokenonvirtual java/lang/Object/ ()V return.limit stack 1.limit locals 1.end method... Each Jasmin class must have a constructor named. The local variable in slot #0 contains the value of “this”. Each constructor must call the superclass constructor. Private static class fields. Void method. No parameters.
46
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 46 Code for a Pascal Function Use getstatic with a fully qualified name and type to push the value of a static field onto the operand stack..method static add(II)I getstatic Adder/i I getstatic Adder/j I iadd iload_0 ; n1 (slot #0) iadd iload_1 ; n2 (slot #1) iadd istore_2 ; s (slot #2) iload_2 ireturn ; s.limit stack 2.limit locals 3.end method PROGRAM ADDER; VAR i, j, sum : integer; FUNCTION add(n1, n2 : integer) : integer; VAR s : integer; BEGIN s := i + j + n1 + n2; add := s; END; BEGIN i := 10; j := 20; sum := add(100, 200); writeln('Sum = ', sum) END.
47
Computer Science Dept. Fall 2015: November 9 CS 153: Concepts of Compiler Design © R. Mak 47 Code to Call a Function (Static Method) Use putstatic with a fully qualified field name and type signature to pop a value off the operand stack and store it into a static field. Use invokestatic with a fully-qualified method name and a type signature to call a static method. PROGRAM ADDER; VAR i, j, sum : integer; FUNCTION add(n1, n2 : integer) : integer; VAR s : integer; BEGIN s := i + j + n1 + n2; add := s; END; BEGIN i := 10; j := 20; sum := add(100, 200); writeln('Sum = ', sum) END..method public static main([Ljava/lang/String;)V.limit stack 4.limit locals 1 bipush 10 putstatic Adder/i I bipush 20 putstatic Adder/j I bipush 100 sipush 200 invokestatic Adder/add(II)I putstatic Adder/sum I... A function call leaves its return value on top of the operand stack of the caller.
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.