## Modules

## Martin Mihle Nygaard (martimn@ifi.uio.no)

- a) I first implemented bin2ssd as an entity, which worked fine, but after feedback from my first attempt I've now changed it to a function wrapped in a package. See bin2ssd\_pck.vhd for implementation, and tb\_bin2ssd.vhd for a working test bench¹.
- b) I chose to alternate the displays at at least 50 Hz. I then need to calculate the number of  $100 \times 10^6$  Hz cycles fit in 50 Hz, which is given by

$$\frac{100 \times 10^6 \, \mathrm{Hz}}{50 \, \mathrm{Hz}} = 2 \times 10^6.$$

The appropriate amount of bits is given by  $\lfloor \log_2 2 \times 10^6 \rfloor = 20$ , I round down get a faster (rather than slower) counter. More precisely, this gives a refresh rate of  $\approx 95\,\mathrm{Hz}$ .

Se seg7ctrl.vhd for implementation, and tb\_seg7ctrl.vhd for a working test bench.

Setting either inputs d0 or d1 to 0000 will clear the displays.

A possible schematic of the entity **seg7ctrl** is shown in figure 1, at least as I imagine it.

c) See seg7ctrl\_arch.vhd, self\_test\_unit.vhd, self\_test\_system.vhd for implementations, with a test bench in tb self test system.vhd.

First, I misunderstood this as "light up display for one clock cycle once per second", which wouldn't possible be visible to the human eye; and I was somewhat confused on how to factor the code and components, too. Hopefully it's up to spec now, after some guidance from helpful lab supervisors.

d) It's alive! See constraints.xdc and self\_test\_system.bit for constraints and bit file, respectively. I was a bit unsure how to include the timing and utilization reports (and had no supervisor on hand), but I've included timing.rpx and utilization\_report.txt, which Vivado allowed me to export. I've also included a video as proof of a functional, programmed board.

I read the "hidden" message as: WELL donE YoU ArE good.

 $<sup>^1 \</sup>text{Unless Canvas}$  screws up the file names again  $\dots$ 



Figure 1: Possible schematic of  $\mathtt{seg7ctr1}$ . Reset functionality is not illustrated. (Future me: this isn't actually far off what Vivado synthesizes the design to!).