450 likes | 589 Vues
Activation Records (Introduction). Mooly Sagiv html://www.math.tau.ac.il/~msagiv/courses/wcc03.html Chapter 6.3. Outline. What is the problem? A possible structure of the activation records A simple stack machine Example compilation. The problem.
E N D
Activation Records(Introduction) Mooly Sagiv html://www.math.tau.ac.il/~msagiv/courses/wcc03.html Chapter 6.3
Outline • What is the problem? • A possible structure of the activation records • A simple stack machine • Example compilation
The problem • The compiler needs to allocate memory for variables • Consistent with program semantics • Scope • Duration • Recursion • Efficient (moderate runtime cost) • Solution?
Typical Virtual Memory Content static area Stack area Heap area Lower addresses
Example Program void main() { printf(“%d\n”, fact(3)); } int fact(int n) { if (n==0) return 1; else return n * fact(n-1) ; }
Activation Record for main(before fact) void main() { printf(“%d\n”, fact(3)); } Administrative part 3 FP SP
Activation Record for main(after fact) void main() { printf(“%d\n”, fact(3)); } Administrative part 3 6 FP SP
Activation Record for main(before printf) void main() { printf(“%d\n”, fact(3)); } Administrative part 6 x87 FP SP “%d\n” x87
Code Generated for main .global _main L1: Push_Const 3 Push_Const 0 JSR _fact WPop Push_Const L2 JSR _printf .data L2 : “%d\n” .end void main() { printf(“%d\n”, fact(3)); }
Activation Record for fact int fact(int n) { if (n==0) return 1; else return n * fact(n-1) ; } n FP+5 Administrative part 3 ret 0 FP SP
Code generated for fact L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS .global _fact L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 int fact(int n) { if (n==0) return 1; else return n * fact(n-1) ; } L4: Push_Constant 1 RTS .end
SP Execution of fact main L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS n FP+5 Administrative part 3 ret 0 FP
Execution of fact L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS main n FP+5 Administrative part 3 0 ret FP SP 3
SP Execution of fact L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS main n FP+5 Administrative part 3 ret 0 FP 3 0
SP Execution of fact L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS main n FP+5 Administrative part 3 ret 0 FP
SP Execution of fact L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS main n FP+5 Administrative part 3 ret 0 FP
SP Execution of fact L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS main n FP+5 Administrative part 3 ret 0 FP 3
SP Execution of fact L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS main n FP+5 Administrative part 3 ret 0 FP 3 3
SP Execution of fact L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS main n FP+5 Administrative part 3 ret 0 FP 3 3 1
SP Execution of fact L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS main n FP+5 Administrative part 3 ret 0 FP 3 2
SP Execution of fact L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS main n FP+5 Administrative part 3 ret 0 FP 3 2 0
3 2 n n ret ret Administrative part Administrative part 2 3 SP main L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS 0 0 FP 1 n 0 ret
2 3 n n ret ret Administrative part Administrative part 2 3 SP main 0 L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS 0 1 n 0 ret Administrative part 0 FP 1
2 3 n n ret ret Administrative part Administrative part 2 3 main FP 0 n 0 0 ret L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS Administrative part 1 SP 1 n 0 ret Administrative part 1
2 3 n n ret ret Administrative part Administrative part 2 3 main 0 L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS 0 1 n 0 ret Administrative part 0 1 FP 1 SP
3 2 n n ret ret Administrative part Administrative part 3 2 SP main 0 L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 JSR _fact Push_Const 0 WPop Mult_Top2 RTS 1 n 0 ret Administrative part 1 FP 1
3 2 n n ret ret Administrative part Administrative part 3 2 SP main 0 L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS 1 n 0 ret Administrative part FP 1
3 2 n n ret ret Administrative part Administrative part 2 3 SP main 0 L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS 0 FP 1 1 n ret
3 2 n n ret ret Administrative part Administrative part 2 3 SP main 0 L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS 0 FP 1 n
3 2 n n ret ret Administrative part Administrative part 3 2 SP main 0 L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS 0 FP
3 n ret Administrative part 3 SP main 0 L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS FP 2 2 n ret
3 n ret Administrative part 3 SP main 0 L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS FP 2
3 n ret Administrative part 6 SP main 0 L3: Push_Local 5 Push_Const 0 Branch_Eq L4 Branch L5 L4: Push_Constant 1 RTS L5: Push_Local 5 Push_Local 5 Push_Const 1 Subtr_Top 2 Push_Const 0 JSR _fact WPop Mult_Top2 RTS FP
SP FP main L1: Push_Const 3 Push_Const 0 JSR _fact WPop Push_Const L2 JSR _printf 3 n 6 ret
SP FP main L1: Push_Const 3 Push_Const 0 JSR _fact WPop Push_Const L2 JSR _printf 6
SP FP main L1: Push_Const 3 Push_Const 0 JSR _fact WPop Push_Const L2 JSR _printf 6 x87
SP main _printf 6 x87 x87 FP Administrative part
Register Code Generated for main .global _main Add_Constant -K1, SP L1: Load_Const 3, R0 JSR _fact Load_Reg R0, R1 Load_Const L2, R0 JSR _printf Add_Constant K1, SP RTS .data L2 : “%d\n” .end void main() { printf(“%d\n”, fact(3)); }
Register Code generated for fact L5: Store_Local R0, 5(FP) Sub_Constant 1, R0 JSR _fact Load_Local 5(FP), R1 Mult_Reg R1, R0 Goto L6 .global _fact Add _Constant -K2, SP L3: Cmp_Constant R0, 0 Branch_Eq L4 Branch L5 int fact(int n) { if (n==0) return 1; else return n * fact(n-1) ; } L4: Load_Constant 1, R0 Goto L6 L6: Add_Constant K2, SP RTS .end
Summary • Activation records is a runtime data structure • Updated by code generated by the compiler • Support from machine instruction