## CLO215 HW-Assignment 2

- Report by Aastha Rajani (2021cs10093) and Piya Bundela (2021cs10118)

In this assignment we have been asked to implement a stopwatch and display it on the basys board. We have to control this stopwatch using four switches namely start, pause, continue, and reset.

The inbuilt frequency of the clock in the basys board is 100 MHz, whereas we have to display the minutes, seconds and every tenth of a second (10 Hz), so we have implemented a clock of 10Hz(clk\_out) in module named timing\_circuit. We have then defined four process in the module named num\_new.

- 1. This process takes clk\_out as an input and increments the value of tenth of second(in1) at every rising\_edge of this clock. It also builds a new clock(o1) whose rising edge occurs after every 10 tenth of seconds.
- 2. This process takes o1 as an input and increments the unit value of seconds(in2) at every rising\_edge of this clock. It also builds a new clock(o2) whose rising edge occurs after every 10 units of seconds.
- 3. This process takes o2 as an input and increments the tens value of seconds(in3) at every rising\_edge of this clock. It also builds a new clock(o3) whose rising\_edge occurs after every 6 tens of seconds.
- 4. This process takes o3 as an input and increments the value of minute(in4) at every rising\_edge of this clock. It also builds a new clock(out\_wave) whose rising\_edge occurs after every 10 minutes. We have then defined a new module int\_to\_bin which converts a given integer to its binary representation.
  - These four bits i.e., in1, in2, in3, in4 are converted to their respective four\_bit binary representations. These sixteen bits go as an input to the main module (which is the 1<sup>st</sup> assignment). This returns 7 outputs and 4 anode pins which correspondingly results in the display of numbers in the basys board.

Coming to switches, we have been asked to handle transitions from 0 to 1 only, so we have defined another module named switch

It takes for inputs start, pause, continue, and reset and outputs enable\_watch and reset\_watch.

We have declared four signals start\_prev, pause\_prev, continue\_prev, reset\_prev which basically stores the previous values of start, pause, continue and reset in order to record the transitions from 0 to1.

- 1. If start\_prev is 0 and start is 1, we set the value of enable\_watch to be 1 and reset\_watch to be 0.
- 2. If pause\_prev is 0 and pause is 1, we set the value enable\_watch to be 0 and reset\_watch to be 0.
- 3. If continue\_prev is 0 and continue is 1, we set the value enable\_watch to be 1 and reset\_watch to be 0.
- 4. If reset\_prev is 0 and reset is 1, we set the value enable\_watch to be 0 and reset\_watch to be 1.

If the reset\_watch is 1 we set all the digits to be 0, else we continue with the processes mentioned above.

## Simulation(test-bench)



## Synthesis report



