

# Lab 4 Report

Lab Members:

Rudraksh Mohapatra

Carlos Henrique Aranguren

Sofia Baroudi

Zack Seifert

## 1. Block diagrams for note\_player and sine\_reader.

### a. note\_player



### b. Sine\_reader



## 2. Annotated Waveforms

### a. Song\_reader.v

play goes high here to start playback;  
FSM leaves IDLE.

READ: ref\_addr[6:0]=0100000 (song=01,  
idx=00).

new\_note 1-cycle  
pulse → outputs  
updated this cycle.

note=100011 (35),  
duration=100100 (36)  
captured in  
SEND\_NOTE.



b. Sine\_reader.v



c. Note\_player.v



#### d. MCU.v

MCU\_tb



### 3.FSM state diagrams for song\_reader and the MCU.

Song\_reader.v:

### **song\_reader FSM**



**MCU.v:**



#### 4. Timing diagrams for the song\_reader, note\_player, and sine\_reader showing the delay in reading from the ROMs

- song\_reader

| Cycle | play | note_done | ref_addr[6:0] | rom_data_q<br>{note,dur} | new_note | note   | duration | state                     |
|-------|------|-----------|---------------|--------------------------|----------|--------|----------|---------------------------|
| 0     | 1    | 0         | 01_00000      | xxxxxxxxxxxx             | 0        | 000000 | 000000   | IDLE                      |
| 1     | 1    | 0         | 01_00000      | xxxxxxxxxxxx             | 0        | 000000 | 000000   | READ                      |
| 2     | 1    | 0         | 01_00000      | n0,d0                    | 0        | 000000 | 000000   | WAIT_ROM<br>(ROM latency) |
| 3     | 1    | 0         | 01_00000      | n0,d0                    | 1        | n0     | d0       | SEND_NOTE<br>(pulse)      |

|     |     |     |          |              |     |     |     |                                       |
|-----|-----|-----|----------|--------------|-----|-----|-----|---------------------------------------|
| 4   | 1   | 0   | 01_00000 | n0,d0        | 0   | n0  | d0  | WAIT_DONE                             |
| 5   | 1   | 1   | 01_00001 | xxxxxxxxxxxx | 0   | n0  | d0  | READ (idx++)                          |
| 6   | 1   | 0   | 01_00001 | n1,d1        | 0   | n0  | d0  | WAIT_ROM                              |
| 7   | 1   | 0   | 01_00001 | n1,d1        | 1   | n1  | d1  | SEND_NOTE                             |
| 8   | 1   | 0   | 01_00001 | n1,d1        | 0   | n1  | d1  | WAIT_DONE                             |
| 9   | 1   | 1   | 01_00010 | xxxxxxxxxxxx | 0   | n1  | d1  | READ (idx++)                          |
| ... | ... | ... | ...      | ...          | ... | ... | ... | ...                                   |
| k   | 1   | 1   | 01_11111 | n31,d31      | 0   | n31 | d31 | READ or<br>DONE if<br>d31=0           |
| k+1 | 0   | 0   | —        | —            | 0   | —   | —   | IDLE after<br>song_done<br>and play=0 |

- note\_player

| Cycle | reset | load_new_note | play_enable | beat | n<br>o<br>t<br>e<br>—<br>t<br>o<br>—<br>l<br>o<br>a<br>d | dur_to_load | n<br>o<br>t<br>e<br>—<br>q | d<br>u<br>r<br>—<br>q | f<br>r<br>e<br>—<br>q | step_size | gen_next | sine_sample | sine_ready | new_sample_ready | done_with_note |
|-------|-------|---------------|-------------|------|----------------------------------------------------------|-------------|----------------------------|-----------------------|-----------------------|-----------|----------|-------------|------------|------------------|----------------|
| 0     | 1     | 0             | 0           | 0    | —                                                        | —           | 0<br>0                     | 0<br>0                | 0<br>0                | xxxx      | 0        | 0000        | 0          | 0                | 0              |

|     |   |   |   |   |        |    |        |        |        |      |   |      |   |   |                   |
|-----|---|---|---|---|--------|----|--------|--------|--------|------|---|------|---|---|-------------------|
| 1   | 0 | 1 | 1 | 0 | n<br>0 | d0 | n<br>0 | d<br>0 | n<br>0 | xxxx | 0 | 0000 | 0 | 0 | 0                 |
| 2   | 0 | 0 | 1 | 0 | —      | —  | n<br>0 | d<br>0 | n<br>0 | S0   | 1 | s0   | 1 | 1 | 0                 |
| 3   | 0 | 0 | 1 | 0 | —      | —  | n<br>0 | d<br>0 | n<br>0 | S0   | 1 | s1   | 1 | 1 | 0                 |
| ... | 0 | 0 | 1 | 1 | —      | —  | n<br>0 | d<br>0 | n<br>0 | S0   | 1 | sk   | 1 | 1 | 0<br>(count down) |
| t   | 0 | 0 | 1 | 1 | —      | —  | n<br>0 | 0<br>0 | n<br>0 | S0   | 1 | s*   | 1 | 1 | 1<br>(done pulse) |
| t+1 | 0 | 1 | 1 | 0 | n<br>1 | d1 | n<br>1 | d<br>1 | n<br>1 | S1   | 1 | s0   | 1 | 1 | 0 (next note)     |

- sine\_reader

| Cycle | reset | generate_next | phase<br>(Q.F) | rom_addr   | rom_data | quad/quad_d | sample | sample_ready |
|-------|-------|---------------|----------------|------------|----------|-------------|--------|--------------|
| 0     | 1     | 0             | 0.0            | 0000000000 | xxxx     | 00/xx       | 0000   | 0            |
| 1     | 0     | 1             | P1             | A0         | xxxx     | q0/xx       | 0000   | 1            |
| 2     | 0     | 1             | P2             | A1         | D0       | q1/q0       | 0000   | 1            |
| 3     | 0     | 1             | P3             | A2         | D1       | q1/q1       | ±D0    | 1            |
| 4     | 0     | 1             | P4             | A3         | D2       | q2/q2       | ±D1    | 1            |
| 5     | 0     | 0             | hold           | A3         | D2       | hold/hold   | ±D1    | 0            |

**5.The critical path of your design. You can find it by going to “Design Runs” then double clicking on the Worst Negative Slack (WNS). Then, click on the Worst Negative Slack value under “Setup.” This report lists the longest paths in your design, with the one with the least positive/most negative being the critical path. Report the slack, source, and destination of the critical path. Look at the list of locations the signal visits under ‘Maximum Data Path’. Do you recognize where in your logic this path comes from?**

| Design Timing Summary                         |                                         |                                                        |
|-----------------------------------------------|-----------------------------------------|--------------------------------------------------------|
| Setup                                         | Hold                                    | Pulse Width                                            |
| Worst Negative Slack (WNS): <b>-2.323 ns</b>  | Worst Hold Slack (WHS): <b>0.022 ns</b> | Worst Pulse Width Slack (WPWS): <b>2.00 ns</b>         |
| Total Negative Slack (TNS): <b>-35.124 ns</b> | Total Hold Slack (THS): <b>0.000 ns</b> | Total Pulse Width Negative Slack (TPWS): <b>0.0 ns</b> |
| Number of Failing Endpoints: <b>17</b>        | Number of Failing Endpoints: <b>0</b>   | Number of Failing Endpoints: <b>0</b>                  |
| Total Number of Endpoints: <b>510</b>         | Total Number of Endpoints: <b>510</b>   | Total Number of Endpoints: <b>302</b>                  |

Worst Negative Slack: -2.323ns.



Path 101 is the longest path, and the source and destination are:

|             |                                                                                                                                       |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Source      | adau1761_codec/pipeline_ff_l/q_reg[8]/C (rising edge-triggered cell FDRE clocked by clk_out1_clk_wiz_0)                               |
| Destination | adau1761_codec/i2c_interface/Inst_i2s_data_interface/sr_out_reg[48]/D (rising edge-triggered cell FDRE clocked by clk_out1_clk_wiz_0) |

This path describes the entire logic chain between two flip flops in the note\_player module.

# Lab 5 Report

Lab Members:

Rudraksh Mohapatra  
Carlos Henrique Aranguren  
Sofia Baroudi  
Zack Seifert

## 1. Block/FSM diagrams

### 1. Wave\_capture\_tb



### 2. Wave\_display



### 3. Timing diagram for wave\_display

| Cycle | read_address | read_value | read_value_adjusted | sample_prev | sample_curr | valid_pixel  |
|-------|--------------|------------|---------------------|-------------|-------------|--------------|
| 0     | 0            | 10         | 37                  | 0           | 0           | 0            |
| 1     | 1            | 20         | 42                  | 0           | 37          | depends on y |

|   |   |    |    |    |    |              |
|---|---|----|----|----|----|--------------|
| 2 | 2 | 30 | 47 | 37 | 42 | depends on y |
| 3 | 3 | 40 | 52 | 42 | 47 | depends on y |

## 2. Annotated Wave forms

### 1. Wave\_capture\_tb



### 2. Wave\_display\_tb



### 3. Critical Path of design

| Summary                              |                                                                                                                      |            |          |                     |
|--------------------------------------|----------------------------------------------------------------------------------------------------------------------|------------|----------|---------------------|
| Name                                 | Path 105                                                                                                             |            |          |                     |
| Slack                                | <a href="#">1.289ns</a>                                                                                              |            |          |                     |
| Source                               | <a href="#">wd_top/wd/sample_prev_ff/q_reg[1]/C</a> (rising edge-triggered cell FDRE clocked by clk_out1_clk_wiz_0)  |            |          |                     |
| Destination                          | <a href="#">U3/inst/srl16ly_0/srl[39].sr16_l/D</a> (rising edge-triggered cell SRL16E clocked by clk_out2_clk_wiz_0) |            |          |                     |
| Path Group                           | clk_out2_clk_wiz_0                                                                                                   |            |          |                     |
| Path Type                            | Setup (Max at Slow Process Corner)                                                                                   |            |          |                     |
| Requirement                          | 10.000ns (clk_out2_clk_wiz_0 rise@40.000ns - clk_out1_clk_wiz_0 rise@30.000ns)                                       |            |          |                     |
| Data Path Delay                      | 8.169ns (logic 2.345ns (28.708%) route 5.824ns (71.292%))                                                            |            |          |                     |
| Logic Levels                         | 7 (CARRY4=2 LUT3=1 LUT4=1 LUT5=1 LUT6=2)                                                                             |            |          |                     |
| Clock Path Skew                      | <a href="#">-0.315ns</a>                                                                                             |            |          |                     |
| Clock Uncertainty                    | <a href="#">0.210ns</a>                                                                                              |            |          |                     |
| Source Clock Path                    |                                                                                                                      |            |          |                     |
| Delay Type                           | Incr (ns)                                                                                                            | Path (...) | Location | Netlist Resource(s) |
| (clock clk_out1_clk_wiz_0 rise edge) | (r) 30.000                                                                                                           | 30.000     |          |                     |

The Maximum Data Path goes through several flip flops as well as checking if the location of the current pixel is valid. This makes us assume that the maximum data path occurs in wave\_display where it tries to check for the window in which to plot the signal.