# Reverberation Module Test Report

#### Amlan Nayak (amlan)

## 1 Bugs Found

- The err\_ signal was found to be incorrectly implemented. It does not assert (1'b0) when prgrm\_go prematurely deasserts in the middle of programming. This was caught by a directed test in the Testing err\_ signal section of the testbench. During programming of delay line 0, prgrm\_go\_ was deasserted, which should have triggered the error signal, but it did not and the assertion caught it.
- The err\_ also does not trigger when the control block is programmed with Read Mode (prgrm\_in[0] == 1'b1). This was caught by another assertion.

FIX: In line 68 of /DAR/design/delay\_prgrm.v, assign nxt\_err to the err\_flop:

```
always @(posedge clk) err_ <= (!rst)? 1'b1: nxt_err_;</pre>
```

### 2 Assumptions

— Programming the tap for a single delay line takes 7 cycles - 6 for programming and 1 more cycle for the tap register to acquire its new value.

### 3 Execution Instructions

No additional files were created for the testbench. All of the tests and assertions are written in the <code>audio\_app.test\_top.sv</code> file. To compile the design and the testbench, <code>>cd</code> into the DAR directory and then execute the command <code>>make all</code>. To run the simulation use either <code>>make run</code> or <code>>./simv</code>. In order to pull up the VPD, please use <code>>make dve</code>