

# DC Lab1 Report

## Team 04

B10901163 張顥譽 B10901176 蔡弘祥 B10901179 鄭承瑞

### File Structure

- team04\_lab1
  - team04\_lab1\_report
  - src
    - Top.sv
    - DE2\_115.qsf
    - DE2\_115.sdc
    - DE2\_115.sv
    - SevenHexDecoder.sv
    - Debounce.sv

### System Architecture





### Signal and Button Explanation

| Button | Signal       | Description               |
|--------|--------------|---------------------------|
| None   | i_clk        | Clock signal              |
| key1   | i_RST_N      | Reset the machine         |
| key0   | i_start      | Start the machine         |
| key2   | i_stop       | Freeze the current result |
| key3   | i_show       | Display the last result   |
| None   | o_random_out | Output signal             |

### State Transition Explanation

The machine operates with several states. The initial state is S\_IDLE, and pressing the key0 (i\_start) will move it into the S\_FAST state. The machine goes through different processing states such as S\_FAST, S\_MEDIUM, and S\_SLOW. If key2 (i\_stop) is pressed in any of these states, the machine transitions to S\_DONE, freezing the result. After the result is frozen, pressing key3 (i\_show)

will transition the machine to S\_SHOW, where the last result is displayed. To start the next operation, pressing key0 will take the machine back to S\_FAST.

The machine's state transitions automatically based on the clock cycle counts. These transitions are:

- S\_FAST to S\_MEDIUM after  $2^{25}$  cycles.
- S\_MEDIUM to S\_SLOW after  $2^{25}$  cycles.
- S\_SLOW to S\_DONE after  $2^{25}$  cycles.
- S\_SHOW to S\_DONE after  $2^{24}$  cycles.

Additionally, pressing key1 (i\_RST\_N) will reset the machine to the initial state S\_IDLE.

## Display Change Rate Explanation

The machine changes its display output at different rates depending on the state it is in:

| State    | Change Period         |
|----------|-----------------------|
| S_FAST   | $2^{19}$ clock cycles |
| S_MEDIUM | $2^{21}$ clock cycles |
| S_SLOW   | $2^{23}$ clock cycles |

## fitter analyzer



## timing analyze



## setup clock50

Quartus II 64-Bit - C:/Users/USER/Desktop/HW1/HW1 - DE2\_115

File Edit View Project Assignments Processing Tools Window Help

Project Navigator 0 # x DE2\_115

Table of Contents

File Summary Messages Suppressed Messages Flow Messages Flow Suppressed Messages

Flow Summary Settings Generated Files Device Options: C:/Users/USER/Desktop/HW1/HW1

TimeQuest Timing Analyzer

Summary Parallel Completion Clocks

Show 1200mV I<sub>C</sub> Model

Timing Closure Recommender Hold Summary Recovery Summary Removable 'CLOCK\_SF' Removal Pulse Width Summary Worst-Case Timing Paths Datasheet Report Metability Summary Show 1200mV I<sub>C</sub> Model

Tasks

Compilation 0 # x

Flow: Compilation Customer...

Tasks

Compile Design Analysis & Synthesis Filter (Place & Route) Assembler (Generate program) TimeQuest Timing Analysis EDNA Netlist Writer Program Device (Open Programmer)

All Find... Find Next

Type ID Message

332123 Deriving Clock Uncertainty. Please refer to report\_adc in TimeQuest to see clock uncertainties.

332145 Timing requirements not met

332146 Worst-case setup slack is -0.011

332146 Worst-case hold slack is -0.017

332146 Worst-case recovery slack is -0.718

332146 Worst-case removal slack is 0.238

332146 Worst-case minimum pulse width slack is -3.000

332102 Design is not fully constrained for setup requirements

332102 Design is not fully constrained for hold requirements

Quartus II 64-bit TimeQuest Timing Analyzer was successful. 0 errors, 5 warnings

293000 Quartus II Full Compilation was successful. 0 errors, 446 warnings

Messages

System (65) Processing (195) /

啟用 Windows

Search altera.com

IP Catalog

Installed IP Project Directory No Selection Available

Library Basic Functions RISC DSP Interface Protocols Memory Interfaces and Controllers Processors and Peripherals University Program

Search for Partner IP

Quartus II 64-Bit - C:/Users/USER/Desktop/HW1/HW1 - DE2\_115

File Edit View Project Assignments Processing Tools Window Help

Project Navigator 0 # x DE2\_115

Table of Contents

File Summary Messages Suppressed Messages Flow Messages Flow Suppressed Messages

Flow Summary Settings Generated Files Device Options: C:/Users/USER/Desktop/HW1/HW1

TimeQuest Timing Analyzer

Summary Parallel Completion Clocks

Show 1200mV I<sub>C</sub> Model

Timing Closure Recommender Hold Summary Recovery Summary Removable 'CLOCK\_SF' Removal Pulse Width Summary Worst-Case Timing Paths Datasheet Report Metability Summary Show 1200mV I<sub>C</sub> Model

Tasks

Compilation 0 # x

Flow: Compilation Customer...

Tasks

Compile Design Analysis & Synthesis Filter (Place & Route) Assembler (Generate program) TimeQuest Timing Analysis EDNA Netlist Writer Program Device (Open Programmer)

All Find... Find Next

Type ID Message

332123 Deriving Clock Uncertainty. Please refer to report\_adc in TimeQuest to see clock uncertainties.

332145 Timing requirements not met

332146 Worst-case setup slack is -0.011

332146 Worst-case hold slack is -0.017

332146 Worst-case recovery slack is -0.718

332146 Worst-case removal slack is 0.238

332146 Worst-case minimum pulse width slack is -3.000

332102 Design is not fully constrained for setup requirements

332102 Design is not fully constrained for hold requirements

Quartus II 64-bit TimeQuest Timing Analyzer was successful. 0 errors, 5 warnings

293000 Quartus II Full Compilation was successful. 0 errors, 446 warnings

Messages

System (65) Processing (195) /

啟用 Windows

Search altera.com

IP Catalog

Installed IP Project Directory No Selection Available

Library Basic Functions RISC DSP Interface Protocols Memory Interfaces and Controllers Processors and Peripherals University Program

Search for Partner IP



Quartus II 64-Bit - C:\Users\user\Desktop\HW1\HW1 - DE2\_115

File Edit View Project Assignments Processing Tools Window Help

Project Navigator

Task List

Messages

Table of Contents

File Hierarchy

Task

Flow: Compilation

Session: System (65) \ Processing (199) /

Type ID Message

- 332123 Deriving Clock Uncertainty. Please refer to report\_mdc in TimeQuest to see clock uncertainties.
- > 332146 Timing requirements not met.
- > 332146 Worst-case setup slack is -1.011
- > 332146 Worst-case hold slack is -0.017
- > 332146 Worst-case recovery slack is -0.718
- > 332146 Worst-case removal slack is 0.238
- < 332146 Worst-case minimum cycles width slack is -0.400

Session: System (65) \ Processing (199) /

Quartus II 64-Bit - C:\Users\user\Desktop\HW1\HW1 - DE2\_115

File Edit View Project Assignments Processing Tools Window Help

Project Navigator

Task List

Messages

Table of Contents

File Hierarchy

Task

Flow: Compilation

Session: System (65) \ Processing (199) /

Type ID Message

- 332123 Deriving Clock Uncertainty. Please refer to report\_mdc in TimeQuest to see clock uncertainties.
- > 332146 Timing requirements not met.
- > 332146 Worst-case setup slack is -1.011
- > 332146 Worst-case hold slack is -0.017
- > 332146 Worst-case recovery slack is -0.718
- > 332146 Worst-case removal slack is 0.238
- < 332146 Worst-case minimum cycles width slack is -0.400

Session: System (65) \ Processing (199) /

Quantus II 64-Bit - C:\Users\user\Desktop\HW1\HW1 - DE2\_115

File Edit View Project Assignments Processing Tools Window Help

Project Navigator

Table of Contents

Slow 120MHz I2C Model

Sock From Node To Node Launch Clock Latency Clock Relationship Clock Skew Data Delay

Timing Closure Analyzer

Summary Parallel Compilation Clocks

Worst-Case Timing Path Hold CLOCK\_SF Hold KEY\_SF Recovery CLOCK\_SF Recovery Pulse Width CLOCK\_SF

Database Report Metability Summary Slow 120MHz I2C Model Fast 120MHz I2C Model Multicore Timing Analysis Advanced I/O Timing Clock Transfers

Messages

Type ID Message

- 332123 Deriving Clock Uncertainty. Please refer to report\_mdc in TimeQuest to see clock uncertainties.
- 332146 Timing requirements not met
- 332146 Worst-case setup slack is -1.011
- 332146 Worst-case hold slack is -0.017
- 332146 Worst-case recovery slack is -0.718
- 332146 Worst-case removal slack is 0.238
- 332146 Worst-case max. pulse width slack is -0.400

Session: (S)\ Processing (H) /

IP Catalog

Installed IP Project Directory No Selection Available Library Basic Functions RISC DSP Interface Protocols Memory Interfaces and Controller Processors and Peripherals University Program Search for Partner IP

Search altera.com

## minimum pulse width clock50

Quantus II 64-Bit - C:\Users\user\Desktop\HW1\HW1 - DE2\_115

File Edit View Project Assignments Processing Tools Window Help

Project Navigator

Table of Contents

Slow 120MHz I2C Model Maximum Pulse Width 'CLOCK\_SF'

Sock Actual Width Required Width Type Clock Clock Edge Target

Timing Closure Analyzer

Summary Parallel Compilation Clocks

Worst-Case Timing Path Hold KEY\_SF Hold CLOCK\_SF Hold KEY\_SF Recovery CLOCK\_SF Recovery Pulse Width CLOCK\_SF

Database Report Metability Summary Slow 120MHz I2C Model Fast 120MHz I2C Model Multicore Timing Analysis Advanced I/O Timing Clock Transfers

Messages

Type ID Message

- 332123 Deriving Clock Uncertainty. Please refer to report\_mdc in TimeQuest to see clock uncertainties.
- 332146 Timing requirements not met
- 332146 Worst-case setup slack is -1.011
- 332146 Worst-case hold slack is -0.017
- 332146 Worst-case recovery slack is -0.718
- 332146 Worst-case removal slack is 0.238
- 332146 Worst-case max. pulse width slack is -0.400

Session: (S)\ Processing (H) /

IP Catalog

Installed IP Project Directory No Selection Available Library Basic Functions RISC DSP Interface Protocols Memory Interfaces and Controller Processors and Peripherals University Program Search for Partner IP

Search altera.com







## 問題解決

時間長度不合適

因為一開始沒有抓好 clock timing，因此一開始以為有

bug，把很多正確邏輯改的很怪，但是後來調整到一個適

合的時間後，七段顯示器看起來就正常多了

心得

這是第一次用 **FPGA**，真的是非常難用，原本寫好 **verilog**  
以為寫好就直接燒上去就很 **arduino** 一樣簡單，沒想到還是出了一堆 **bug**