readme.md 6/1/2022

# Vexriscv SoC with UART & Multiple RAMs

This example integrates 2 AXI based RAMs onto a Vexriscv SoC.

#### Instructions:

Copy your demo folder from litex installation directory litex/litex/soc/software/demo and paste it inside your project directory. Use the main.c file provided in this example in the demo application and replace it with the main.c file located inside your newly copied demo folder in project directory.

### 1. Simulation

We can simulate this IP using litex\_sim tool in litex.

Run the following command to generate your SoC:

```
litex_sim --integrated-main-ram-size=0x10000 --cpu-type vexriscv --multiaxiram --sim-debug --no-compile-gateware
```

Run the following command to generate .bin file from .py file:

```
python3 ./demo/demo.py --build-path=build/sim
```

Before running the simulation, you have to create the binary of your application code residing in demo. The python script below converts the application code to demo.bin, which is later loaded on to the RAM.

```
litex_sim --integrated-main-ram-size=0x10000 --cpu-type vexriscv --ram-init=demo.bin --multiaxiram --sim-debug
```

#### Output:

readme.md 6/1/2022

Address: 50000000

Data written: 4008636142 Data read: 4008636142

DATA MATCHED

Address: 50000004

Data written: 4008636142 Data read: 4008636142

DATA MATCHED

Address: 50000008

Data written: 4008636142 Data read: 4008636142

DATA MATCHED

Address: 5000000c

Data written: 4008636142 Data read: 4008636142

DATA MATCHED

Address: 50001000

Data written: 4294967295 Data read: 4294967295

DATA MATCHED

Address: 50001004

Data written: 4294967295 Data read: 4294967295

DATA MATCHED

Address: 50001008

Data written: 4294967295 Data read: 4294967295

DATA MATCHED

Address: 5000100c

Data written: 4294967295 Data read: 4294967295

DATA MATCHED

TEST-1 RAM-1: PASSED

TEST-2 RAM-2: PASSED

TEST-3 RAM-1: PASSED

TEST-4 RAM-2: PASSED

TEST-5 RAM-1: PASSED

TEST-6 RAM-2: PASSED

TEST-7 RAM-1: PASSED

TEST-8 RAM-2: PASSED

-----END-----

==============

## **Application**

readme.md 6/1/2022

This test invokes both memories and writes and read data subsequently and randomly, inorder to make sure that the integration is properly done. Secondly, it stresses the Interconnect as both slave IPs are being communicated with simultaneously.