## **Computer Architecture Report**

## **Table:**

| Benchmark<br>Programs | Branch Stalls (Control Hazard) (Number of Cycles) | OF Stage<br>(Number of<br>Cycles)<br>(Data Hazard) | Total Cycles<br>(pipelined model) | Total Cycles<br>(Without pipeline) |
|-----------------------|---------------------------------------------------|----------------------------------------------------|-----------------------------------|------------------------------------|
| Descending.out        | 217                                               | 105                                                | 615                               | 1385                               |
| Evenodd.out           | 1                                                 | 3                                                  | 15                                | 30                                 |
| Fibonancci.out        | 33                                                | 39                                                 | 158                               | 390                                |
| Prime.out             | 25                                                | 5                                                  | 59                                | 145                                |
| Palindrome.out        | 15                                                | 51                                                 | 122                               | 245                                |

| Ratio                                   |  |  |  |  |
|-----------------------------------------|--|--|--|--|
| Cycles(non-pipeline) / Cycles(pipeline) |  |  |  |  |
| 2.25                                    |  |  |  |  |
| 2                                       |  |  |  |  |
| 2.468                                   |  |  |  |  |
| 2.457                                   |  |  |  |  |
| 2.008                                   |  |  |  |  |

## **Observations:**

- The number of Clock cycles is directly proportional to the number of hazards
- Any program without any control or data hazards will be five times faster in a pipelines processor as compared to the non-pipelined processor approximately. The deviation might be due to implementation details and the latency initial instructions.
- The implemented solution for pipeline is stalled three cycles for data hazards to seem closer to the actual hardware implementation where all stages are processed parallelly
- Similarly for control hazards, Branch not taken has been implemented, where we allow the next instruction to be fetched and then check whether the branch is taken and if not the processor is allowed to continue normally.