1 / 45

Activation Records (Introduction)

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.

Télécharger la présentation

Activation Records (Introduction)

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Activation Records(Introduction) Mooly Sagiv html://www.math.tau.ac.il/~msagiv/courses/wcc03.html Chapter 6.3

  2. Outline • What is the problem? • A possible structure of the activation records • A simple stack machine • Example compilation

  3. The problem • The compiler needs to allocate memory for variables • Consistent with program semantics • Scope • Duration • Recursion • Efficient (moderate runtime cost) • Solution?

  4. Typical Virtual Memory Content static area Stack area Heap area Lower addresses

  5. A Typical Stack Frame

  6. Basic Compiler Phases

  7. Example Program void main() { printf(“%d\n”, fact(3)); } int fact(int n) { if (n==0) return 1; else return n * fact(n-1) ; }

  8. Activation Record for main(before fact) void main() { printf(“%d\n”, fact(3)); } Administrative part 3 FP SP

  9. Activation Record for main(after fact) void main() { printf(“%d\n”, fact(3)); } Administrative part 3 6 FP SP

  10. Activation Record for main(before printf) void main() { printf(“%d\n”, fact(3)); } Administrative part 6 x87 FP SP “%d\n” x87

  11. StackInstructions

  12. 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)); }

  13. 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

  14. 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

  15. 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

  16. 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

  17. 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

  18. 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

  19. 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

  20. 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

  21. 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

  22. 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

  23. 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

  24. 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

  25. 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

  26. 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

  27. 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

  28. 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

  29. 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

  30. 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

  31. 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

  32. 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

  33. 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

  34. 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

  35. 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

  36. 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

  37. SP FP main L1: Push_Const 3 Push_Const 0 JSR _fact WPop Push_Const L2 JSR _printf 3 n 6 ret

  38. SP FP main L1: Push_Const 3 Push_Const 0 JSR _fact WPop Push_Const L2 JSR _printf 6

  39. SP FP main L1: Push_Const 3 Push_Const 0 JSR _fact WPop Push_Const L2 JSR _printf 6 x87

  40. SP main _printf 6 x87 x87 FP Administrative part

  41. Code For Register Machine

  42. RegisterInstructions

  43. 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)); }

  44. 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

  45. Summary • Activation records is a runtime data structure • Updated by code generated by the compiler • Support from machine instruction

More Related