Compiler Optimization
Motivation for SSA Form
Many optimizations can be simplified by using SSA form. Consider this counterexample with the presented algorithms.
// 1.
x = 10;
if(...) {
// 2.
    x = 20;
    y = x;
} else {
// 3.
    y = x;
}
// 4.1.  Constant Folding
Algorithm:
- Create a map where is a variable. Initialize to undefined. 
- For each statement, if it is of form: - x = cset- M[x] = c
- x = yset- M[x] = M[y]- Replace y with M[y] if defined 
 
- v = Op x yset- M[v] = Op(M[x], M[y])where Op(...) may return undefined- Replace - Op x ywith Op(M[x], M[y]) if defined
- Otherwise replace x with M[x] if defined and y with M[y] if defined 
 
 
This only works with SSA. Consider the above snippet as the counterexample.
2. Copy Propagation
Algorithm:
- Create a map . Initialize - M[x]=x
- For each statement, if it is of form: - x = yset- M[x] = M[y]
- v = Op x yreplace with- v = Op M[x] M[y]
 
Again, this only works with SSA.
3. Dead Code Elimination
Algorithm:
Last updated
Was this helpful?