

# Laboratory Exercise #6 Behavioral Modeling of Sequential Circuits

| Name: | Group: |
|-------|--------|
|       |        |

## **Target Course Outcomes:**

**CO1:** Create descriptions of digital hardware components such as in combinational and sequential circuits using synthesizable Verilog HDL constructs.

CO2: Verify the functionality of HDL-based components through design verification tools.

#### **Intended Learning Outcomes:**

- Create design entry of a sequential circuit using behavioral modeling in Verilog HDL code
- Synthesize the Verilog HDL design entry
- Simulate the designed circuit using a testbench file
- Fit a synthesized circuit into an Intel FPGA
- Programming and configuring the FPGA chip on Intel DE-series board (DE10-Lite)

## Supplement:

This exercise requires a basic understanding of the Intel Quartus Prime design flow with ModelSim functional verification, as detailed in Units 1-2 and Laboratory Exercises #1-2. It is also expected that Laboratory Exercise #5 has already been completed before performing this exercise.

#### Instructions:

Perform this hands-on laboratory exercise after attending/watching the onsite/online lecture for Unit 6. This activity is intended to be done individually.

## **Exercise 6A: JK Flip-flop**

Create a **behavioral description** of a **JK flip-flop** using **either if-else statements or a case statement**. Refer to the entity diagram below for reference. Synthesize and simulate the design. Show both a simulation log (standard output) and simulation waveform (timing diagram) in the laboratory report.



Figure 1. Entity Diagram of Negative-edged Triggered JK Flip-flop



**Test Cases:** Assert reset (**Reset**) at the start of the simulation for a couple of **Clk** edges, while varying the **JK** input values. Then, de-assert **Reset** and continue to vary **JK** inputs. Prioritize the simulation waveforms (timing diagram) in the laboratory report.

**FPGA Implementation:** After simulation, load the appropriate design file into the FPGA to test the functionality of the design. Refer to the onsite orientation and other attachments for this section.

#### **Evaluation:**

| Level                                  | 1.0                                                                                                                                                                                                                                                               | 2.0                                                                                                                                                                                                                                                             | 3.0                                                                                                                                                                                                                                                                      | 5.0                                                                                   | Detino |
|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--------|
| Criteria                               | Outstanding                                                                                                                                                                                                                                                       | Competent                                                                                                                                                                                                                                                       | Marginal                                                                                                                                                                                                                                                                 | Not Acceptable                                                                        | Rating |
| CO1: Verilog<br>Design Entry           | Verilog HDL description is correct and follows specified instructions.                                                                                                                                                                                            |                                                                                                                                                                                                                                                                 | Verilog HDL description is correct but DID NOT follow the specified instructions.                                                                                                                                                                                        | NO Verilog HDL<br>description is presented<br>or the design entry is<br>INCORRECT.    |        |
| CO1: Design<br>Synthesis               | Verilog HDL description is<br>synthesized and compiled<br>with NO issues (with 0-1<br>warning). There is clear<br>evidence in the lab report<br>that supports this result.                                                                                        | Verilog HDL description is synthesized and compiled with MINOR issues on constructs (with 2-3 warnings). There is clear evidence in the lab report that supports this result.                                                                                   | Verilog HDL description is synthesized and compiled with MAJOR issues on constructs (with 4 or more warnings). There is evidence in the lab report that supports this result.                                                                                            | Simulation has FAILED or there is NO evidence showing a successful simulation.        |        |
| CO2: Verilog<br>Testbench Entry        | Verilog HDL testbench is correct and follows specified instructions. ALL possible input combinations or AMPLE test stimuli are included to generate sufficient and verifiable output results.                                                                     | -                                                                                                                                                                                                                                                               | Verilog HDL testbench is correct but DID NOT follow specified instructions. Possible input combinations may be INCOMPLETE or test stimuli are NOT SUFFICIENT included to generate verifiable output results.                                                             | NO Verilog testbench is presented or INCOMPLETE.                                      |        |
| CO2: Functional<br>Verification        | Simulation of the synthesized design is functional with NO issues and shows ALL correct and expected results. An analysis is made by providing image annotations and/or discussions of the results. There is clear evidence in the lab report that supports this. | Simulation of the synthesized design is functional. Expected results may be INCOMPLETE but are ALL correct. An analysis is made by providing image annotations and/or discussions of the results. There is clear evidence in the lab report that supports this. | Simulation of the synthesized design is functional. Expected results may be INCOMPLETE or there may be INCORRECT results. NO analysis is made with NO image annotations and/or discussions of the results. There is clear evidence in the lab report that supports this. | Simulation has FAILED or there is NO evidence showing a successful simulation.        |        |
| CO3: Design<br>Flow                    | Synthesized HDL-based design file was properly loaded into the FPGA with NO problems.                                                                                                                                                                             | -                                                                                                                                                                                                                                                               | Synthesized HDL-based design file was loaded into the FPGA with A FEW technical issues.                                                                                                                                                                                  | Synthesized HDL-based design file WAS NOT PROPERLY loaded into the FPGA.              |        |
| CO3: Accuracy<br>of Results on<br>FPGA | Results are ALL<br>ACCURATE as expected<br>and recorded data is<br>validated upon checking.                                                                                                                                                                       |                                                                                                                                                                                                                                                                 | Results are MOSTLY<br>ACCURATE and recorded data<br>is validated upon checking.                                                                                                                                                                                          | Results are<br>ERRONEOUS or<br>recorded data CANNOT<br>be validated upon<br>checking. |        |



#### Exercise 6B: 4-Bit Binary Up/Down Counter

Design a **4-bit binary up/down counter** using **behavioral description** with a function table and entity diagram shown below.



\*Clk: negative-edged (falling-edge) triggered nReset: asynchronous reset (active low)

Figure 2. Entity Diagram of 4-bit Counter

#### **Function Table:**

| nReset | Clk                | Load | Count_en | Up | Counter Operation           |
|--------|--------------------|------|----------|----|-----------------------------|
| 0      | Χ                  | Χ    | X        | Х  | Reset to 0                  |
| 1      | <b>\rightarrow</b> | 1    | Х        | Χ  | Load inputs (parallel load) |
| 1      | <b>→</b>           | 0    | 0        | Χ  | No change                   |
| 1      | <b>\rightarrow</b> | 0    | 1        | 0  | Count down                  |
| 1      | <b>→</b>           | 0    | 1        | 1  | Count up                    |

**Test Cases:** Design the testbench to show ALL counter operations shown in the function table. Prioritize the simulation waveforms (timing diagram) in the laboratory report.

**FPGA Implementation:** After simulation, load the appropriate design file into the FPGA to test the functionality of the design. Refer to the onsite orientation and other attachments for this section. **Additional module needed: Clock divider** 

#### **Evaluation:**

| Level                        | 1.0                                                                    | 2.0       | 3.0                                                                               | 5.0                                                                                | Rating |
|------------------------------|------------------------------------------------------------------------|-----------|-----------------------------------------------------------------------------------|------------------------------------------------------------------------------------|--------|
| Criteria                     | Outstanding                                                            | Competent | Marginal                                                                          | Not Acceptable                                                                     |        |
| CO1: Verilog<br>Design Entry | Verilog HDL description is correct and follows specified instructions. | -         | Verilog HDL description is correct but DID NOT follow the specified instructions. | NO Verilog HDL<br>description is presented<br>or the design entry is<br>INCORRECT. |        |



| CO1: Design<br>Synthesis               | Verilog HDL description is<br>synthesized and compiled<br>with NO issues (with 0-1<br>warning). There is clear<br>evidence in the lab report<br>that supports this result.                                                                                        | Verilog HDL description is<br>synthesized and compiled<br>with MINOR issues on<br>constructs (with 2-3<br>wamings). There is clear<br>evidence in the lab report<br>that supports this result.                                                                  | Verilog HDL description is synthesized and compiled with MAJOR issues on constructs (with 4 or more warnings). There is evidence in the lab report that supports this result.                                                                                            | Simulation has FAILED or there is NO evidence showing a successful simulation.        |  |
|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--|
| CO2: Verilog<br>Testbench Entry        | Verilog HDL testbench is correct and follows specified instructions. ALL possible input combinations or AMPLE test stimuli are included to generate sufficient and verifiable output results.                                                                     |                                                                                                                                                                                                                                                                 | Verilog HDL testbench is correct but DID NOT follow specified instructions. Possible input combinations may be INCOMPLETE or test stimuli are NOT SUFFICIENT included to generate verifiable output results.                                                             | NO Verilog testbench is presented or INCOMPLETE.                                      |  |
| CO2: Functional<br>Verification        | Simulation of the synthesized design is functional with NO issues and shows ALL correct and expected results. An analysis is made by providing image annotations and/or discussions of the results. There is clear evidence in the lab report that supports this. | Simulation of the synthesized design is functional. Expected results may be INCOMPLETE but are ALL correct. An analysis is made by providing image annotations and/or discussions of the results. There is clear evidence in the lab report that supports this. | Simulation of the synthesized design is functional. Expected results may be INCOMPLETE or there may be INCORRECT results. NO analysis is made with NO image annotations and/or discussions of the results. There is clear evidence in the lab report that supports this. | Simulation has FAILED or there is NO evidence showing a successful simulation.        |  |
| CO3: Design<br>Flow                    | Synthesized HDL-based design file was properly loaded into the FPGA with NO problems.                                                                                                                                                                             |                                                                                                                                                                                                                                                                 | Synthesized HDL-based design file was loaded into the FPGA with A FEW technical issues.                                                                                                                                                                                  | Synthesized HDL-based design file WAS NOT PROPERLY loaded into the FPGA.              |  |
| CO3: Accuracy<br>of Results on<br>FPGA | Results are ALL<br>ACCURATE as expected<br>and recorded data is<br>validated upon checking.                                                                                                                                                                       |                                                                                                                                                                                                                                                                 | Results are MOSTLY<br>ACCURATE and recorded data<br>is validated upon checking.                                                                                                                                                                                          | Results are<br>ERRONEOUS or<br>recorded data CANNOT<br>be validated upon<br>checking. |  |

# For the laboratory report (LR #6), include the following items:

#### For both Exercises 6A and 6B:

- o Proof of successful design synthesis (screenshot showing 0 errors)
- Proof of successful simulation results with required number of test cases (screenshots of simulation results with annotations or discussion of results)
- o Proof of successful FPGA implementation (1 sample photo of the board with sample result)
- All Verilog files (.v) must be submitted along with LR #6