Senura Dissanayake Samuel Nieuwenhuis
101283013 101270254
Student 1 Student 2

Increasing the save/restore context time from 10 to 30 ms seemed to give us an increase in clock cycles of roughly 4% per extra 10 ms. For example in trace\_txt\_base.txt, we can see that running the program using trace.txt with no change in save/restore context time gives us a total of 17230 clock cycles. Then, as seen in trace\_txt\_10ms\_context.txt, the number of clock cycles increases to 17770. Then, increasing it to 20 ms gives us a total of 18370 cycles, as shown in trace\_txt\_20ms\_context.txt. Finally, an increase to 30 ms brings the total number of clock cycles to 18970, as seen in trace\_txt\_30ms\_context.txt. So the increase is a fairly consistent value of around 4% per extra 10 ms.

When the ISR execution time increases, the system seems to spend more time handling interrupts and less time performing normal processing. As seen in trace\_1\_40ms\_ISR.txt, where the ISR activity time is set to 40ms, the overall number of cycles is 4232. Then, when we increase it to 80 ms, as seen in trace\_1\_80ms\_ISR.txt, it causes an increase in overall time to 4832 total cycles. Finally, when we increase ISR activity time to 200 ms, we can see from trace\_1\_200ms\_ISR.txt another increase in overall time taken, bringing the total cycles to 6632.

Increasing the save/restore context time and the ISR activity duration both slow down the overall system performance. A higher context switch time means more overhead each time an interrupt occurs, reducing the CPU's availability for normal processing. Similarly, longer ISR activity times cause the processor to spend more time inside the interrupt routine, delaying the execution of regular tasks and possibly blocking other interrupts. Together, these changes increase total execution time, reduce system responsiveness, and can lead to performance bottlenecks, especially in systems with frequent interrupts or time-sensitive operations.

Link to repository: <a href="https://github.com/SamuelNieuwenhuis61003/SYSC4001\_A1">https://github.com/SamuelNieuwenhuis61003/SYSC4001\_A1</a>