





# THE UNIVERSITY OF KANSAS

#### **SCHOOL OF ENGINEERING**

# DEPARTMENT OF ELECTRICAL ENGINEERING AND COMPUTER SCIENCE

EECS 645 – Computer Architecture

Spring 2021

Homework 01

Student Name: Student ID:

# **Vivado Simulator Tutorial**

- Describe in behavioral VHDL a modulo-m up/down counter with the following interface:
  - Generics
    - Modulo base (*m* with default value of 16)
  - Inputs
    - Clock (clk  $\rightarrow$  1 bit)
    - Asynchronous reset (rst  $\rightarrow$  1 bit)
    - Counting direction (up\_down → 1 bit)
      - 1 → Counting up,
      - 0  $\rightarrow$  Counting down
  - Outputs
    - Count value (count  $\rightarrow \lceil \log_2(m) \rceil$  bits)
- In Vivado
  - Create a project
  - Add design and simulation source files
  - Run behavioral simulation
  - Your waveform configuration should be identical to the provided waveform snapshot, see Figure 1.
- Steps:
  - 1) Download the file "HW01 VSim Tutorial.zip" from blackboard and extract its contents.
  - 2) Rename the folder "HW01\_VSim\_Tutorial" to "HW01\_VSim\_Tutorial\_<your last name>", for example "HW01 VSim Tutorial El-Araby".
  - 3) Launch Vivado and create a new project, for example "vivado\_project", with the default settings under the following directory "\HW01\_VSim\_Tutorial\_<your last name>\mod\_m\_up\_dn\_count\" resulting in the following project directory "\HW01 VSim Tutorial <your last name>\mod m up dn count\vivado project\"
  - 4) Add to the project the VHDL design and simulation source files from the folders; "\HW01\_VSim\_Tutorial\_<your last name>\mod\_m\_up\_dn\_count\design\_sources" and "\HW01\_VSim\_Tutorial\_<your last name>\mod\_m\_up\_dn\_count\simulation\_sources" respectively.
  - 5) Edit the VHDL file in the folder "\HW01\_VSim\_Tutorial\_<your last name>\mod\_m\_up\_dn\_count\design\_sources\" according to your design such that it describes the required *modulo-m* up/down counter.
  - 6) Set the simulation time to the proper time, e.g., 1,000 ns, and then launch Vivado Simulator.
  - 7) Verify the correctness of your design. Your waveform configuration should be identical to the waveform snapshot shown in Figure 1. You may go back to step 5 to correct your code until your design works properly as required.
  - 8) After you are done, compress the folder "\HW01\_VSim\_Tutorial\_<your last name>" to "HW01\_VSim\_Tutorial\_<your last name>.zip", for example "HW01\_VSim\_Tutorial\_El-Araby.zip" and upload it to blackboard before the due date and time.

#### **Grade Distribution:**

- Functional Correctness, i.e., correct source code  $\rightarrow$  25 / 100
- Proper Setup of Vivado Project → 75 / 100

#### **NOTE:**

Homework submission is a "Single Attempt", i.e., carefully review everything that you want to submit before hitting the "submit" button and make sure that you have uploaded all documents you want to submit and have not missed anything.



Figure 1. Snapshot of Correct Waveform Configuration