# Compilers - Phase 3 Analysis

Naved Rizvi Usman Ehtesham Gul

## Analysis

#### Benchmark 1

| Algorithm   | Instructions | Reads | Writes | Branches | Other |
|-------------|--------------|-------|--------|----------|-------|
| Naive       | 501          | 186   | 130    | 38       | 147   |
| Intra-block | 668          | 181   | 222    | 38       | 227   |
| Briggs      | 323          | 9     | 126    | 38       | 150   |

#### Benchmark 2

| Algorithm   | Instructions | Reads | Writes | Branches | Other |
|-------------|--------------|-------|--------|----------|-------|
| Naive       | 1152         | 558   | 316    | 38       | 240   |
| Intra-block | 1133         | 274   | 408    | 38       | 413   |
| Briggs      | 602          | 9     | 312    | 38       | 243   |

### Benchmark 3

| Algorithm   | Instructions | Reads | Writes | Branches | Other |
|-------------|--------------|-------|--------|----------|-------|
| Naive       | 503          | 186   | 139    | 38       | 149   |
| Intra-block | 672          | 183   | 222    | 38       | 229   |
| Briggs      | 328          | 11    | 127    | 38       | 152   |

#### Benchmark 4

| Algorithm   | Instructions | Reads | Writes | Branches | Other |
|-------------|--------------|-------|--------|----------|-------|
| Naive       | 2312         | 757   | 354    | 152      | 1049  |
| Intra-block | 3061         | 742   | 809    | 152      | 1358  |
| Briggs      | 1779         | 101   | 219    | 152      | 1307  |

Comparing intra-block with naive, we see a higher number of instructions in most benchmarks for intra-block. This is possibly because of emitting many load/store instructions at each basic block entry and exit point. The number of reads for intra-block compared to naive is slightly lower than naive except for benchmar\_2, where the number of reads is almost half as the number of reads for naive. This could be because, in benmark\_2, we are over-writing the same variable multiple times and that variable is loaded at the beginning of each basic block. We do not see a big difference in the performance between intra-block and naive because we do not take the liveness analysis of the variables into account. Hence when entering or exiting a block, we load all variables referred to in a block without taking into account if a variable is actually live on entering a block or saving all variables referred to in a block without taking into account if a variable is actually live on exiting a block. In our implementation, we also do a few redundant move instructions which could lead to the reason for the number of writes for intra-block being higher than naive.

Comparing Briggs with the other register allocation algorithms, we see a significant improvement in the instructions count and in the number of reads and a slight improvement in the number of writes. This is because in Briggs, we take the liveness of variables into account and this allows us to re-use registers where possible since for a given pair variables, their live ranges do not overlap and hence the same register can be used to refer to both variables. We also only load on the first reference of a given variable and during the liveness of that variable, we do not have to do any additional load from memory (unlike in naive, where we would have to do this on reference to the same variable) and this leads to a significant decrease in the number of instructions and number of reads. We do see a reduction in the number of writes and that is because we would only write a register back to memory if we are about to enter a function call and then we can load the register back from memory at the end of the function call. We do this as we try to follow a function calling convention to ensure the save and temp registers do not get over-written due to a function call within a given function. We definitely see a benefit of an algorithm like Briggs to register allocation and the liveness analysis of an IR program along with the interference graph of the live ranges of variables allows us to utilize the limited number of physical registers more optimally than naive and intra-block (where intra-block currently uses a weak heuristic: frequency of the number of references of a variable in a basic block). Taking the liveness analysis into account gives a boost in performance as we avoid unnecessary loads and stores; also we take the whole function into account as opposed to taking basic blocks into

| account. If a variable is not deemed to be used from the liveness analysis, then we do not have to take that variable into consideration for register allocation. |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                   |
|                                                                                                                                                                   |
|                                                                                                                                                                   |
|                                                                                                                                                                   |
|                                                                                                                                                                   |
|                                                                                                                                                                   |
|                                                                                                                                                                   |
|                                                                                                                                                                   |
|                                                                                                                                                                   |
|                                                                                                                                                                   |
|                                                                                                                                                                   |
|                                                                                                                                                                   |
|                                                                                                                                                                   |
|                                                                                                                                                                   |
|                                                                                                                                                                   |
|                                                                                                                                                                   |
|                                                                                                                                                                   |
|                                                                                                                                                                   |
|                                                                                                                                                                   |