readme.md 6/1/2022

## Vexriscy SoC with UART & SDRAM + AXI-RAM:

AXI-SDRAM application for Vexriscv based 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 application using litex\_sim tool in litex.

Run the following command to generate your SoC:

```
litex_sim --cpu-type vexriscv --bus-standard axi-lite --with-sdram --multiaxiram --sim-debug --no-compile-gateware
```

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 SDRAM.

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

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

Run the following command to execute your application code onto the processor:

```
litex_sim --cpu-type vexriscv --bus-standard axi-lite --with-sdram --multiaxiram --sdram-init=demo.bin --sim-debug
```

### Output:

readme.md 6/1/2022

Build your hardware, easily! (c) Copyright 2012-2022 Enjoy-Digital (c) Copyright 2007-2015 M-Labs BIOS built on May 27 2022 16:50:49 BIOS CRC passed (599a1ef6) LiteX git sha1: a4cc859d --========== SoC ===========---CPU: VexRiscv @ 1MHz AXI-LITE 32-bit @ 4GiB BUS: 32-bit data CSR: ROM: 128KiB SRAM: 8KiB L2: 8KiB SDRAM: 65536KiB 32-bit @ 1MT/s (CL-2 CWL-2) --======= Initialization ========---Initializing SDRAM @0x40000000... Switching SDRAM to software control. Switching SDRAM to hardware control. --========= Boot ==========---Booting from serial... Press Q or ESC to abort boot completely. sL5DdSMmkekro Timeout Executing booted program at 0x40000000

readme.md 6/1/2022

================= ============ ----TEST-8 AXIRAM---------TEST-7 SDRAM-----================ ============ Data written: 4294967295 Data written: 4008636142 Data read: 4294967295 Data read: 4008636142 DATA MATCHED DATA MATCHED Data written: 4294967295 Data written: 4008636142 Data read: 4294967295 Data read: 4008636142 DATA MATCHED DATA MATCHED Data written: 4294967295 Data written: 4008636142 Data read: 4008636142 Data read: 4294967295 DATA MATCHED DATA MATCHED Data written: 4294967295 Data written: 4008636142 Data read: 4294967295 Data read: 4008636142 DATA MATCHED DATA MATCHED

TEST-1 SDRAM: PASSED
TEST-2 AXIRAM: PASSED
TEST-3 SDRAM: PASSED
TEST-4 AXIRAM: PASSED
TEST-5 SDRAM: PASSED
TEST-6 AXIRAM: PASSED
TEST-7 SDRAM: PASSED
TEST-7 SDRAM: PASSED
TEST-7 SDRAM: PASSED

# **Application**

In this application code, we write and read data to the SDRAM and the results are shown on console.