## ECE 551 Exercise04

## This is a 10pt problem of HW1

Submit whatever you have for both the DUT and test results to the dropbox by end of the class period.

Submit a **structural** Verilog file that models a module that can synchronize a signal to your system clock (*clk*) and output a signal that is high for 1 clock cycle when that signal has a rising edge. Assume a D-FF is already defined that has an interface of:(D, clk,Q) and a module name of *dff*.

So essentially a circuit to solve metastability, then detect a rising edge.

Name your file **synch\_detect.v** and ensure the module name is also **synch\_detect**.

Interface is:

**asynch\_sig\_in** → input to synchronize and detect falling edge on **clk** → clock signal

**rise\_edge** → output of your block that is high for 1 clock cycle after rising edge occurs on **async\_sig\_in**. (NOTE: There will be some latency in this signal due to the meta-stability flops)

The code for **dff.v**, and a testbench are provided (**synch\_detect\_tb.v**) are provided in the Exercise04 folder.

Create a ModelSim project, download, and test your design. The test bench is self checking and should give a happy message in the console window if your DUT is good.