# ECE 497: Special Project Weekly Report

Week 04

Alexander Lukens Karl Hallsby

Illinois Institute of Technology

February 18, 2021

### What We Did

- Attempted to flash default chip to Alex's FPGA.
- Successfully passed USB connection to FPGA through to VirtualBox VM, interfaced with FPGA in Vivado
- Conducted "Hello World" project on FPGA to ensure that bitstream was being sent to FPGA correctly.
- Used FPGA Prototyping Flow in Chipyard to generate a bitstream for the Arty FPGA board. Strangely, the default "example" project for the Arty did not pass all timing constraints.
  - ► Will require additional investigation
- When creating bitstream in Chipyard, Vivado runs several tests on the design and produces detailed reports in a Chipyard folder.

- Successfully created custom config file using building blocks provided by Chipyard, produced 8-core "small Rocket core" SoC with otherwise default settings
- ► Utilized RISC-V toolchain to compile basic test program (hello world plus simple for loop)
- ▶ Working getting *our* code out to a separate directory, for Git storage.

#### 7.3. Baremetal RISC-V Programs

Hello, World!

To build baremetal RISC-V programs to run in simulation, we use the riscv64-unknown-elf cross-compiler and a fork of the libgloss board support package. To build such a program yourself, simply invoke the cross-compiler with the flags "-fno-common -fno-builtin-printf -specs=htif\_nano.specs" and the link with the arguments "-static -specs=htif\_nano.specs". For instance, if we want to run a "Hello, World" program in baremetal, we could do the following.

```
#include <stdio.h>
int main(void)
{
    printf("Hello, World!\n");
    return 0;
}

$ riscv64-unknown-elf-gcc -fno-common -fno-builtin-printf -specs=htif_nano.specs -c hello.c
$ riscv64-unknown-elf-gcc -static -specs=htif_nano.specs hello.o -o hello.riscv
$ soike hello.riscv
```

Figure: Commands to compile for RISC-V Simulator

Figure: hello.c code

Figure: hello.c output from simulator

#### What We Learned

- ► The repository is incredibly complicated
- ▶ **VERY** deep directory nesting (Partly due to Scala/Java project directory conventions).
- Putting the generated chip on an FPGA seems to be much more difficult than originally thought.
- Generating a non-default chip can be very easy or very hard.
  - Some of the options that must be overridden to ensure a different chip is built and simulated/benchmarked are not easy to understand or find.
  - Generating these SoC configurations requires LOTS of memory.

## Next Steps

- Continue trying to write the default chip out to Alex's FPGA and test.
- Using Alex's discovery in Vivado, collect gate counts of components within the default chip.
- Practice generating other non-default chips to understand all the options used when generating a new chip.
- Hopefully, start defining a new, custom, chip using what we know, and building a very small proof-of-concept.

## References