School of EECS, Peking University “Advanced Compiler Techniques” (Fall 2011) Lecture 1: Course Introduction Guo, Yao.

Slides:



Advertisements
Similar presentations
Software & Services Group, Developer Products Division Copyright© 2010, Intel Corporation. All rights reserved. *Other brands and names are the property.
Advertisements

Compilation 2011 Static Analysis Johnni Winther Michael I. Schwartzbach Aarhus University.
Compiler Construction by Muhammad Bilal Zafar (AP)
Program Representations. Representing programs Goals.
CPSC Compiler Tutorial 9 Review of Compiler.
Lecture 01 - Introduction Eran Yahav 1. 2 Who? Eran Yahav Taub 734 Tel: Monday 13:30-14:30
PLLab, NTHU Cs2403 Programming Languages Implementation Issues Cs2403 Programming Language Spring 2005 Kun-Yuan Hsieh.
Cpeg421-08S/final-review1 Course Review Tom St. John.
Reasons to study concepts of PL
Reference Book: Modern Compiler Design by Grune, Bal, Jacobs and Langendoen Wiley 2000.
Programming Languages Structure
BİL744 Derleyici Gerçekleştirimi (Compiler Design)1.
Lecture 1CS 380C 1 380C Last Time –Course organization –Read Backus et al. Announcements –Hadi lab Q&A Wed 1-2 in Painter 5.38N –UT Texas Learning Center:
Summer 02-03Programming Language Concepts1 Programming Language Concepts (CS 360) Lecture 1: Overview, Grammars, and Little Languages Jeremy R. Johnson.
1.3 Executing Programs. How is Computer Code Transformed into an Executable? Interpreters Compilers Hybrid systems.
CPSC 388 – Compiler Design and Construction Lecture: MWF 11:00am-12:20pm, Room 106 Colton.
Overview of the Course. Critical Facts Welcome to CISC 672 — Advanced Compiler Construction Instructor: Dr. John Cavazos Office.
Advanced Compiler Techniques LIU Xianhua School of EECS, Peking University Course Introduction.
CS 355 – Programming Languages
410/510 1 of 20 Week 1 – Lecture 1 Introduction The Textbook Assessment Programming & Tools A v. small compiler Compiler Construction.
(1.1) COEN 171 Programming Languages Winter 2000 Ron Danielson.
High level & Low level language High level programming languages are more structured, are closer to spoken language and are more intuitive than low level.
COP4020 Programming Languages
U NIVERSITY OF D ELAWARE C OMPUTER & I NFORMATION S CIENCES D EPARTMENT Optimizing Compilers CISC 673 Spring 2011 Course Overview John Cavazos University.
CS 363 Comparative Programming Languages
Chapter 1 Introduction Dr. Frank Lee. 1.1 Why Study Compiler? To write more efficient code in a high-level language To provide solid foundation in parsing.
Compiler course 1. Introduction. Outline Scope of the course Disciplines involved in it Abstract view for a compiler Front-end and back-end tasks Modules.
CS 326 Programming Languages, Concepts and Implementation Instructor: Mircea Nicolescu Lecture 2.
Copyright © 2006 Addison-Wesley. All rights reserved.1-1 ICS 410: Programming Languages.
1 COMP 3438 – Part II-Lecture 1: Overview of Compiler Design Dr. Zili Shao Department of Computing The Hong Kong Polytechnic Univ.
Copyright © 2007 Addison-Wesley. All rights reserved.1-1 Reasons for Studying Concepts of Programming Languages Increased ability to express ideas Improved.
U NIVERSITY OF M ASSACHUSETTS, A MHERST Department of Computer Science Advanced Compilers CMPSCI 710 Spring 2004 Lecture 1 Emery Berger University of Massachusetts,
Unit-1 Introduction Prepared by: Prof. Harish I Rathod
1.  10% Assignments/ class participation  10% Pop Quizzes  05% Attendance  25% Mid Term  50% Final Term 2.
Topic #1: Introduction EE 456 – Compiling Techniques Prof. Carl Sable Fall 2003.
Overview of Previous Lesson(s) Over View  A program must be translated into a form in which it can be executed by a computer.  The software systems.
1 Compiler Design (40-414)  Main Text Book: Compilers: Principles, Techniques & Tools, 2 nd ed., Aho, Lam, Sethi, and Ullman, 2007  Evaluation:  Midterm.
Chapter 1 Introduction Study Goals: Master: the phases of a compiler Understand: what is a compiler Know: interpreter,compiler structure.
Introduction to Compiling
Compiler Design Introduction 1. 2 Course Outline Introduction to Compiling Lexical Analysis Syntax Analysis –Context Free Grammars –Top-Down Parsing –Bottom-Up.
Compiler Introduction 1 Kavita Patel. Outlines 2  1.1 What Do Compilers Do?  1.2 The Structure of a Compiler  1.3 Compilation Process  1.4 Phases.
Course Overview for Compilers J. H. Wang Sep. 14, 2015.
Course Overview for Compilers J. H. Wang Sep. 20, 2011.
Programming Language Concepts (CIS 635) Elsa L Gunter 4303 GITC NJIT,
Presented by : A best website designer company. Chapter 1 Introduction Prof Chung. 1.
CS416 Compiler Design1. 2 Course Information Instructor : Dr. Ilyas Cicekli –Office: EA504, –Phone: , – Course Web.
Compilers Principles, Techniques, & Tools Taught by Jing Zhang
Component 1.6.
Compiler Design (40-414) Main Text Book:
Concepts of Programming Languages
Chapter 1 Introduction.
CS 326 Programming Languages, Concepts and Implementation
Lecture 1: Course Introduction
PROGRAMMING LANGUAGES
Chapter 1 Introduction.
课程名 编译原理 Compiling Techniques
Compiler Lecture 1 CS510.
Advanced Compilers CMPSCI 710 Spring 2003 Lecture 1
CS416 Compiler Design lec00-outline September 19, 2018
Course supervisor: Lubna Siddiqui
Introduction CI612 Compiler Design CI612 Compiler Design.
CSE401 Introduction to Compiler Construction
COP4020 Programming Languages
Subject: Language Processor
CS416 Compiler Design lec00-outline February 23, 2019
CISC 7120X Programming Languages and Compilers
Compilers Principles, Techniques, & Tools Taught by Jing Zhang
Lec00-outline May 18, 2019 Compiler Design CS416 Compiler Design.
Optimizing Compilers CISC 673 Spring 2009 Course Overview
Presentation transcript:

School of EECS, Peking University “Advanced Compiler Techniques” (Fall 2011) Lecture 1: Course Introduction Guo, Yao

2 “Advanced Compiler Techniques” Fall 2011 Outline Course Overview Course Overview Course Topics Course Topics Course Requirements Course Requirements Grading Grading Preparation Materials Preparation Materials Compiler Review Compiler Review Program Analysis Basics Program Analysis Basics

3 Fall 2011 “Advanced Compiler Techniques” Course Overview Graduate level compiler course Graduate level compiler course Focusing on advanced materials on program analysis and optimization. Focusing on advanced materials on program analysis and optimization. Assuming that you have basic knowledge & techniques on compiler construction. Assuming that you have basic knowledge & techniques on compiler construction. Gain hands-on experience through a programming project to implement a specific program analysis or optimization technique. Gain hands-on experience through a programming project to implement a specific program analysis or optimization technique. Course website: Course website:

4 Administrivia Time: 9-12 (6:40pm-) every Thursday Time: 9-12 (6:40pm-) every Thursday Location: Location: TA: TBD TA: TBD Office Hour: 4-5:30pm Tuesdays Office Hour: 4-5:30pm Tuesdays or by appointment thru or by appointment thru Contact: Contact: Phone: Phone: Include [ACT11] in the subject. Include [ACT11] in the subject.

5 Fall 2011 “Advanced Compiler Techniques” Course Materials Dragon Book Dragon Book Aho, Lam, Sethi, Ullman, “Compilers: Principles, Techniques, and Tools”, 2nd ed, Addison 2007 Aho, Lam, Sethi, Ullman, “Compilers: Principles, Techniques, and Tools”, 2nd ed, Addison 2007 Related Papers Related Papers Class website Class website

6 Fall 2011 “Advanced Compiler Techniques” Requirements Basic Requirements Basic Requirements Read materials before/after class. Read materials before/after class. Work on your homework individually. Work on your homework individually. Discussions are encouraged but don’t copy others’ work. Discussions are encouraged but don’t copy others’ work. Get you hands dirty! Get you hands dirty! Experiment with ideas presented in class and gain first- hand knowledge! Experiment with ideas presented in class and gain first- hand knowledge! Come to class and DON’T hesitate to speak if you have any questions/comments/suggestions! Come to class and DON’T hesitate to speak if you have any questions/comments/suggestions! Student participation is important! Student participation is important!

7 Fall 2011 “Advanced Compiler Techniques” Grading Grading based on Grading based on Homework: 20% Homework: 20% ~5 homework assignments ~5 homework assignments Midterm: 30% Midterm: 30% Week 10 or 11 (Nov 10/17) Week 10 or 11 (Nov 10/17) Final Project: 40% Final Project: 40% Class participation: 10% Class participation: 10%

8 Fall 2011 “Advanced Compiler Techniques” Final Project Groups of 2-3 students Groups of 2-3 students Pair Programming recommended! Pair Programming recommended! Topic Topic Problem of your choice (recommend project list will be provided) Problem of your choice (recommend project list will be provided) Should be an interesting enough (non-trivial) problem Should be an interesting enough (non-trivial) problem Suggested environment Suggested environment Soot (McGill Univ.) Soot (McGill Univ.) Joeq, IBM Jikes, SUIF, gcc, etc. Joeq, IBM Jikes, SUIF, gcc, etc.

9 Fall 2011 “Advanced Compiler Techniques” Project Req. Week 5: Introduction Week 5: Introduction Week 7: Proposal due Week 7: Proposal due Week 8: Proposal Presentation Week 8: Proposal Presentation Week 13: Progress Report due Week 13: Progress Report due Week 16: Final Presentation Week 16: Final Presentation Week 17: Final Report due Week 17: Final Report due

10 Fall 2011 “Advanced Compiler Techniques” Course Topics Basic analyses & optimizations Basic analyses & optimizations Data flow analysis & implementation Data flow analysis & implementation Control flow analysis Control flow analysis SSA form & its application SSA form & its application Pointer analysis Pointer analysis Instruction scheduling Instruction scheduling Localization & Parallelization optimization Localization & Parallelization optimization Selected topics (TBD) Selected topics (TBD) Program slicing, program testing Program slicing, program testing Power-aware Compilation Power-aware Compilation GPU Optimization GPU Optimization

11 Fall 2011 “Advanced Compiler Techniques” About You!

School of EECS, Peking University “Advanced Compiler Techniques” (Fall 2011) Compiler Review

13 Fall 2011 “Advanced Compiler Techniques” What is a Compiler? A program that translates a program in one language to another language A program that translates a program in one language to another language The essential interface between applications & architectures The essential interface between applications & architectures Typically lowers the level of abstraction Typically lowers the level of abstraction analyzes and reasons about the program & architecture analyzes and reasons about the program & architecture We expect the program to be optimized, i.e., better than the original We expect the program to be optimized, i.e., better than the original ideally exploiting architectural strengths and hiding weaknesses ideally exploiting architectural strengths and hiding weaknesses

14 Fall 2011 “Advanced Compiler Techniques” Compiler vs. Interpreter (1/5) Compilers: Translate a source (human- writable) program to an executable (machine-readable) program Compilers: Translate a source (human- writable) program to an executable (machine-readable) program Interpreters: Convert a source program and execute it at the same time. Interpreters: Convert a source program and execute it at the same time.

15 Fall 2011 “Advanced Compiler Techniques” Compiler vs. Interpreter (2/5) Ideal concept: Compiler Executable Source codeExecutable Input dataOutput data Interpreter Source code Input data Output data

16 Fall 2011 “Advanced Compiler Techniques” Compiler vs. Interpreter (3/5) Most languages are usually thought of as using either one or the other: Most languages are usually thought of as using either one or the other: Compilers: FORTRAN, COBOL, C, C++, Pascal, PL/1 Compilers: FORTRAN, COBOL, C, C++, Pascal, PL/1 Interpreters: Lisp, scheme, BASIC, APL, Perl, Python, Smalltalk Interpreters: Lisp, scheme, BASIC, APL, Perl, Python, Smalltalk BUT: not always implemented this way BUT: not always implemented this way Virtual Machines (e.g., Java) Virtual Machines (e.g., Java) Linking of executables at runtime Linking of executables at runtime JIT (Just-in-time) compiling JIT (Just-in-time) compiling

17 Fall 2011 “Advanced Compiler Techniques” Compiler vs. Interpreter (4/5) Actually, no sharp boundary between them. General situation is a combo: Actually, no sharp boundary between them. General situation is a combo: Translator Virtual machine Source code Intermed. code Input Data Output

18 Fall 2011 “Advanced Compiler Techniques” Compiler vs. Interpreter (5/5) Compiler Pros Pros Less space Less space Fast execution Fast execution Cons Cons Slow processing Slow processing Partly Solved (Separate compilation) Partly Solved (Separate compilation) Debugging Debugging Improved thru IDEs Improved thru IDEs Interpreter Pros Easy debugging Fast Development Cons Not for large projects Exceptions: Perl, Python Requires more space Slower execution Interpreter in memory all the time

19 Fall 2011 “Advanced Compiler Techniques” Phase of compilations

20 Fall 2011 “Advanced Compiler Techniques” Scanning/Lexical analysis Break program down into its smallest meaningful symbols (tokens, atoms) Break program down into its smallest meaningful symbols (tokens, atoms) Tools for this include lex, flex Tools for this include lex, flex Tokens include e.g.: Tokens include e.g.: “Reserved words”: do if float while “Reserved words”: do if float while Special characters: ( {, + - = ! / Special characters: ( {, + - = ! / Names & numbers: myValue 3.07e02 Names & numbers: myValue 3.07e02 Start symbol table with new symbols found Start symbol table with new symbols found

21 Fall 2011 “Advanced Compiler Techniques” Parsing Construct a parse tree from symbols Construct a parse tree from symbols A pattern-matching problem A pattern-matching problem Language grammar defined by set of rules that identify legal (meaningful) combinations of symbols Language grammar defined by set of rules that identify legal (meaningful) combinations of symbols Each application of a rule results in a node in the parse tree Each application of a rule results in a node in the parse tree Parser applies these rules repeatedly to the program until leaves of parse tree are “atoms” Parser applies these rules repeatedly to the program until leaves of parse tree are “atoms” If no pattern matches, it’s a syntax error If no pattern matches, it’s a syntax error yacc, bison are tools for this (generate c code that parses specified language) yacc, bison are tools for this (generate c code that parses specified language)

22 Fall 2011 “Advanced Compiler Techniques” Parse tree Output of parsing Output of parsing Top-down description of program syntax Top-down description of program syntax Root node is entire program Root node is entire program Constructed by repeated application of rules in Context Free Grammar (CFG) Constructed by repeated application of rules in Context Free Grammar (CFG) Leaves are tokens that were identified during lexical analysis Leaves are tokens that were identified during lexical analysis

23 Fall 2011 “Advanced Compiler Techniques” Example: Parsing rules for Pascal These are like the following: program PROGRAM identifier (identifier more_identifiers) ; block. program PROGRAM identifier (identifier more_identifiers) ; block. more_identifiers, identifier more_identifiers | ε more_identifiers, identifier more_identifiers | ε block variables BEGIN statement more_statements END block variables BEGIN statement more_statements END statement do_statement | if_statement | assignment | … statement do_statement | if_statement | assignment | … if_statement IF logical_expression THEN statement ELSE … if_statement IF logical_expression THEN statement ELSE …

24 Fall 2011 “Advanced Compiler Techniques” Pascal code example program gcd (input, output) var i, j : integer begin read (i, j) while i <> j do if i>j then i := i – j; else j := j – i ; writeln (i); end.

25 Fall 2011 “Advanced Compiler Techniques” Example: parse tree

26 Fall 2011 “Advanced Compiler Techniques” Semantic analysis Discovery of meaning in a program using the symbol table Discovery of meaning in a program using the symbol table Do static semantics check Do static semantics check Simplify the structure of the parse tree ( from parse tree to abstract syntax tree (AST) ) Simplify the structure of the parse tree ( from parse tree to abstract syntax tree (AST) ) Static semantics check Static semantics check Making sure identifiers are declared before use Making sure identifiers are declared before use Type checking for assignments and operators Type checking for assignments and operators Checking types and number of parameters to subroutines Checking types and number of parameters to subroutines Making sure functions contain return statements Making sure functions contain return statements Making sure there are no repeats among switch statement labels Making sure there are no repeats among switch statement labels

27 Fall 2011 “Advanced Compiler Techniques” Example: AST

28 Fall 2011 “Advanced Compiler Techniques” (Intermediate) Code generation Go through the parse tree from bottom up, turning rules into code. Go through the parse tree from bottom up, turning rules into code. e.g. e.g. A sum expression results in the code that computes the sum and saves the result A sum expression results in the code that computes the sum and saves the result Result: inefficient code in a machine- independent language Result: inefficient code in a machine- independent language

29 Fall 2011 “Advanced Compiler Techniques” Machine independent optimization Perform various transformations that improve the code, e.g. Perform various transformations that improve the code, e.g. Find and reuse common subexpressions Find and reuse common subexpressions Take calculations out of loops if possible Take calculations out of loops if possible Eliminate redundant operations Eliminate redundant operations

30 Fall 2011 “Advanced Compiler Techniques” Target code generation Convert intermediate code to machine instructions on intended target machine Convert intermediate code to machine instructions on intended target machine Determine storage addresses for entries in symbol table Determine storage addresses for entries in symbol table

31 Fall 2011 “Advanced Compiler Techniques” Machine-dependent optimization Make improvements that require specific knowledge of machine architecture, e.g. Make improvements that require specific knowledge of machine architecture, e.g. Optimize use of available registers Optimize use of available registers Reorder instructions to avoid waits Reorder instructions to avoid waits

32 Fall 2011 “Advanced Compiler Techniques” When should we compile? Ahead-of-time: before you run the program Ahead-of-time: before you run the program Offline profiling: compile several times Offline profiling: compile several times compile/run/profile.... then run again compile/run/profile.... then run again Just-in-time: while you run the program required for dynamic class loading, i.e., Java, Python, etc. Just-in-time: while you run the program required for dynamic class loading, i.e., Java, Python, etc.

33 Fall 2011 “Advanced Compiler Techniques” Aren’t compilers a solved problem? “Optimization for scalar machines is a problem that was solved ten years ago.” -- David Kuck, Fall David Kuck, Fall 1990

34 Fall 2011 “Advanced Compiler Techniques” Aren’t compilers a solved problem? “Optimization for scalar machines is a problem that was solved ten years ago.” -- David Kuck, Fall 1990 Architectures keep changing Architectures keep changing Languages keep changing Languages keep changing Applications keep changing - SPEC CPU? Applications keep changing - SPEC CPU? When to compile keeps changing When to compile keeps changing

35 “Advanced Compiler Techniques” Fall 2011 Role of compilers Bridge complexity and evolution in architecture, languages, & applications Bridge complexity and evolution in architecture, languages, & applications Help programs with correctness, reliability, program understanding Help programs with correctness, reliability, program understanding Compiler optimizations can significantly improve performance Compiler optimizations can significantly improve performance 1 to 10x on conventional processors 1 to 10x on conventional processors Performance stability: one line change can dramatically alter performance Performance stability: one line change can dramatically alter performance unfortunate, but true unfortunate, but true

36 Fall 2011 “Advanced Compiler Techniques” Performance Anxiety But does performance really matter? But does performance really matter? Computers are really fast Computers are really fast Moore’s law (roughly): hardware performance doubles every 18 months Moore’s law (roughly): hardware performance doubles every 18 months Real bottlenecks lie elsewhere: Real bottlenecks lie elsewhere: Disk Disk Network Network Human! (think interactive apps) Human! (think interactive apps) Human typing avg. 8 cps (max 25 cps) Human typing avg. 8 cps (max 25 cps) Waste time “thinking” Waste time “thinking”

37 Fall 2011 “Advanced Compiler Techniques” Compilers Don’t Help Much Do compilers improve performance anyway? Do compilers improve performance anyway? Proebsting’s law (Todd Proebsting, Microsoft Research): Proebsting’s law (Todd Proebsting, Microsoft Research): Difference between optimizing and non- optimizing compiler ~ 4x Difference between optimizing and non- optimizing compiler ~ 4x Assume compiler technology represents 36 years of progress (actually more) Assume compiler technology represents 36 years of progress (actually more)  Compilers double program performance every 18 years!  Not quite Moore’s Law…

38 Fall 2011 “Advanced Compiler Techniques” A Big BUT Why use high-level languages anyway? Why use high-level languages anyway? Easier to write & maintain Easier to write & maintain Safer (think Java) Safer (think Java) More convenient (think libraries, GC…) More convenient (think libraries, GC…) But: people will not accept massive performance hit for these gains But: people will not accept massive performance hit for these gains Compile with optimization! Compile with optimization! Still use C and C++!! Still use C and C++!! Hand-optimize their code!!! Hand-optimize their code!!! Even write assembler code (gasp)!!!! Even write assembler code (gasp)!!!!  Apparently performance does matter…

39 Fall 2011 “Advanced Compiler Techniques” Why Compilers Matter Key part of compiler’s job: make the costs of abstraction reasonable Key part of compiler’s job: make the costs of abstraction reasonable Remove performance penalty for: Remove performance penalty for: Using objects Using objects Safety checks (e.g., array-bounds) Safety checks (e.g., array-bounds) Writing clean code (e.g., recursion) Writing clean code (e.g., recursion) Use program analysis to transform code: primary topic of this course Use program analysis to transform code: primary topic of this course

40 Fall 2011 “Advanced Compiler Techniques” Program Analysis Source code analysis is the process of extracting information about a program from its source code or artifacts (e.g., from Java byte code or execution traces) generated from the source code using automatic tools. Source code analysis is the process of extracting information about a program from its source code or artifacts (e.g., from Java byte code or execution traces) generated from the source code using automatic tools. Source code is any static, textual, human readable, fully executable description of a computer program that can be compiled automatically into an executable form. Source code is any static, textual, human readable, fully executable description of a computer program that can be compiled automatically into an executable form. To support dynamic analysis the description can include documents needed to execute or compile the program, such as program inputs. To support dynamic analysis the description can include documents needed to execute or compile the program, such as program inputs. Source: Dave Binkely-”Source Code Analysis – A Roadmap”, FOSE’07

41 Fall 2011 “Advanced Compiler Techniques” Anatomy of an Analysis 1. Parser parses the source code into one or more internal representations. parses the source code into one or more internal representations. 2. Internal representation CFG, call graph, AST, SSA, VDG, FSA CFG, call graph, AST, SSA, VDG, FSA Most common: Graphs Most common: Graphs 3. Actual Analysis

42 Fall 2011 “Advanced Compiler Techniques” Analysis Properties Static vs. Dynamic Static vs. Dynamic Sound vs. unsound Sound vs. unsound Safe vs. Unsafe Safe vs. Unsafe Flow sensitive vs. Flow insensitive Flow sensitive vs. Flow insensitive Context sensitive vs. Context insensitive Context sensitive vs. Context insensitive Precision-Cost trade-off Precision-Cost trade-off

43 Fall 2011 “Advanced Compiler Techniques” Levels of Analysis (in order of increasing detail & complexity) Local (single-block) [1960’s] Local (single-block) [1960’s] Straight-line code Straight-line code Simple to analyze; limited impact Simple to analyze; limited impact Global (Intraprocedural) [1970’s – today] Global (Intraprocedural) [1970’s – today] Whole procedure Whole procedure Dataflow & dependence analysis Dataflow & dependence analysis Interprocedural [late 1970’s – today] Interprocedural [late 1970’s – today] Whole-program analysis Whole-program analysis Tricky: Tricky: Very time and space intensive Very time and space intensive Hard for some PL’s (e.g., Java) Hard for some PL’s (e.g., Java)

44 Fall 2011 “Advanced Compiler Techniques” Optimization = Analysis + Transformation Key analyses: Key analyses: Control-flow Control-flow if-statements, branches, loops, procedure calls if-statements, branches, loops, procedure calls Data-flow Data-flow definitions and uses of variables definitions and uses of variables Representations: Representations: Control-flow graph Control-flow graph Control-dependence graph Control-dependence graph Def/use, use/def chains Def/use, use/def chains SSA (Static Single Assignment) SSA (Static Single Assignment)

45 Fall 2011 “Advanced Compiler Techniques” Applications architecture recovery architecture recovery clone detection clone detection program comprehension program comprehension debugging debugging fault location fault location model checking in formal analysis model checking in formal analysis model-driven development model-driven development optimization techniques in software engineering optimization techniques in software engineering reverse engineering reverse engineering software maintenance software maintenance visualizations of analysis results visualizations of analysis results etc. etc. etc. etc.

46 Fall 2011 “Advanced Compiler Techniques” Current Challenges Pointer Analysis Pointer Analysis Concurrent Program Analysis Concurrent Program Analysis Dynamic Analysis Dynamic Analysis Information Retrieval Information Retrieval Data Mining Data Mining Multi-Language Analysis Multi-Language Analysis Non-functional Properties Non-functional Properties Self-Healing Systems Self-Healing Systems Real-Time Analysis Real-Time Analysis

47 Fall 2011 “Advanced Compiler Techniques” Exciting times New and changing architectures  Hitting the microprocessor wall  Multicore/manycore  Tiled architectures, tiled memory systems Object-oriented languages becoming dominant paradigm  Java and C# coming to your OS soon - Jnode, Singularity  Security and reliability, ease of programming Key challenges and approaches  Latency & parallelism still key to performance  Language & runtime implementation efficiency  Software/hardware cooperation is another key issue Compiler ProgrammerRuntime Code Specification Future behavior Feedback Feedback H/S Profiling

48 Fall 2011 “Advanced Compiler Techniques” Next Time Control-Flow Analysis Control-Flow Analysis Local Optimizations Local Optimizations Data-Flow Analysis Basics Data-Flow Analysis Basics Read Read Dragonbook: § , § Dragonbook: § , §