

# Lab Report for Lab 6

Source Code Link: <https://github.com/imezabu/cs391r1-lab6.git>

## Lab6 1.1

### Approach

For 1.1, our group followed the instructions outlined in the getting started guide to ultimately implement the block design for our pico32rv module as shown below. Each wire was chosen to connect the correct input to its related output all throughout the block design. To make sure that our resulting bitstream from the block design was generated, we checked our directory to see if the file was in the correct path.

Code:



### **Testing:**

Testbench Code:

```
debug_nets.tcl  
final_pico_wrapper.bit
```

(Excerpt(s) of the testbench(es) for this problem.)

Testing Approach:

Our testing approach was to just generate the bitstream and then connect it to the FPGA board. We just followed the instructions in the Getting Started pdf. For testing the values of simple\_test, we had to use busybox devmem as opposed to devmem2 since it kept stalling and giving us bus errors.

### **Results:**

Waveforms (Group): n/a

There were no waveforms for this portion of the lab.

Outcomes:

We were able to get everything running and were able to properly generate the bitstream to then be run and connected to our board. However, we ran into some issues when initially generating everything. When we first started it took over 30+ minutes to generate our first bitstream, and we had to kill the process and re-run it. Additionally, when first trying to run everything, we had a lot of errors due to incorrect wire connections. This led us to reconnect all the wires and ports once again. After killing the initial process and re-running it we were finally able to generate a proper bitstream after 10 mins and with more threads.

## Lab6 1.2

### **Approach**

This portion only involves running tests with our FPGA board and connecting/loading up the bitstream to the FPGA board. Our approach was to just mainly the Getting Started Guide and understanding the board itself along the way. Lots of trial and error. We had to use SCP to send the bitstream and c files over to our FPGA board. From there, we ran lpd\_32bit.sh, flashed the bitstream onto the pico, compiled our files, and finally loaded them onto the fpga board. Connecting to it via vivado allowed us to start and stop our program using our probes.

Code: n/a

## Testing:

### Testbench Code:

```
1 //Basic Sorting Algorithm
2
3 // Sorting Func
4 void sortingAlgo(int array[], int size) {
|   int count = 0;
7
8     //Bubble Sort
9     for (int i=0; i<size; i++) {
10       for (int j=0; j<size-i; j++) {
11         if (array[j] > array[j+1]) {
12           int first = array[j];
13           array[j] = array[j+1];
14           array[j+1] = first;
15         }
16         // for (int b=0; b<size; b++) {
17         //   printf("%d ", array[b]);
18         // }
19         count += 1;
20       }
21     }
22     //printf("%d ", count);
23
24   }
25
26 // Main Func
27 int main() {
28
29   // 7 element array
30   int array[] = {456, 8, 5, 72, 84, 300, 391};
31
32   // Calling the algorithm
33   sortingAlgo(array, 7);
34
35   return 0;
36 }
```

Our own C file:

(Excerpt(s) of the testbench(es) for this problem.)

### Testing Approach:

- Using minicom -> whenever we minicommed we couldn't differentiate which port to use  
-> correct one was 1
- Couldn't get any text to pop up -> had to press reset on each port until port usb1 gets a response -> prompted to login
- Couldn't type anything or take any inputs -> had to mess around with the settings – changed a hardware setting -> disable hardware flow control
- All of your .s file weren't properly downloading from blackboard -> had to make our own and copy and paste it; didn't have the right permissions
- Had to figure out the correct way to use SCP to copy over files
- Devmem was not installed, installed busybox and had to prepend everything with "busybox"
- Couldn't get the probes to properly appear -> had to redo block design so they get detected and regenerated the bitstream

- Program ran but then it kept hanging -> had to get new firmware
  - Devmem2 sometimes had bus errors -> use busybox devmem

We worked to follow the instructions very directly from the slides, but on many occasions had to debug issues that occurred even when following these instructions. Aside from these issues, we were able to directly follow the steps from Chapter 2 and Chapter 3 of the getting started guide, and were able to get everything running (loading the binary file to Bram, connecting to the FPGA board, running it on the fpga, and testing for the correct values).

## **Results:**

Waveforms (Group): n/a

There were no waveforms for this portion.

## Outcomes:

We were able to verify the writes by running the provided commands, at times having to alter the command somewhat due to issues encountered earlier. Happily, we confirmed that we were reading all the correct values that were listed in the instructions.



Additionally, we were able to upload our own C file, which ran successfully.

### **Reflections:**

In reflection, this portion of the lab posed a fair deal of challenges. The directions were largely clear, however, when things failed or we encountered an error, it was largely on us to try to investigate some reasonably unfamiliar problems on our own to try to continue our work. Thankfully, after one entirely progress halting issue where our FPGA kept hanging and wouldn't let us test our writes, we were provided a solution to update the FPGA's firmware, which did resolve our issue, allowing us to complete the lab. Other than these key challenges, it was neat to go from wiring a virtual block design, to implementing all our virtual design work to a physical device, and running binary compiled C code on it with success.

### **Individual Contributions:**

Beren Akpinar: For lab 6, I mainly helped create our block design and ensure that all wires were connected correctly. After creating the block design, I generated the bitstream and debugged any errors we got in this step to progress further along in the getting started guide. Lastly, I also helped my teammates in trying to understand why our FPGA board wouldn't connect after resetting it on the last step.

Ruby Chen: For lab 6 I mainly helped with making the block design and getting through the initial first two chapters of the Getting Started pdf. I also helped when it came to generating the bitstream, loading the binary files, and running the test programs. However, most of this lab was done in a group at one computer so we all contributed that way. Then I helped with setting up the repo and documentation.

Michael Ross: For lab 6, I assisted with the initial block design creation, assisting in debugging issues with further setup steps, and assisted with documentation in this report.

Isaac Meza: For lab 6, I assisted with loading the bitstream to the FPGA board, compiling and loading the binaries, and getting the design detected by vivado as well as running the actual program on the board.