Skip to content

Commit

Permalink
update eb70743
Browse files Browse the repository at this point in the history
  • Loading branch information
GHA committed Jan 2, 2025
0 parents commit 6a2bc7e
Show file tree
Hide file tree
Showing 452 changed files with 31,970 additions and 0 deletions.
4 changes: 4 additions & 0 deletions .buildinfo
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
# Sphinx build info version 1
# This file hashes the configuration used when building these files. When it is not found, a full rebuild will be done.
config: 8e1e065af2310fbfc93a91e292cb14ff
tags: 645f666f9bcd5a90fca523b33c5a78b7
Empty file added .nojekyll
Empty file.
Binary file added _images/D1.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D10.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D101.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D102.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D103.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D11.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D111.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D112.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D12.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D121.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D13.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D131.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D14.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D15.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D16.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D17.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D171.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D18.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D2.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D20.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D21.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D22.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D23.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D24.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D3.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added _images/D31.png
Binary file added _images/D32.png
Binary file added _images/D4.png
Binary file added _images/D41.png
Binary file added _images/D5.png
Binary file added _images/D51.png
Binary file added _images/D52.png
Binary file added _images/D53.png
Binary file added _images/D54.png
Binary file added _images/D6.png
Binary file added _images/D61.png
Binary file added _images/D62.png
Binary file added _images/D63.png
Binary file added _images/D64.png
Binary file added _images/D7.png
Binary file added _images/D71.png
Binary file added _images/D72.png
Binary file added _images/D73.png
Binary file added _images/D8.png
Binary file added _images/D81.png
Binary file added _images/D82.png
Binary file added _images/D83.png
Binary file added _images/D84.png
Binary file added _images/D9.png
Binary file added _images/D91.png
Binary file added _images/D92.png
Binary file added _images/D93.png
Binary file added _images/H2.png
Binary file added _images/J1.png
Binary file added _images/J11.png
Binary file added _images/J12.png
Binary file added _images/J13.png
Binary file added _images/J14.png
Binary file added _images/J15.png
Binary file added _images/J16.png
Binary file added _images/J17.png
Binary file added _images/J18.png
Binary file added _images/J2.png
Binary file added _images/J21.png
Binary file added _images/J22.png
Binary file added _images/J23.png
Binary file added _images/J24.png
Binary file added _images/J3.png
Binary file added _images/J31.png
Binary file added _images/J32.png
Binary file added _images/J33.png
Binary file added _images/J34.png
Binary file added _images/J4.png
Binary file added _images/J41.png
Binary file added _images/J42.png
Binary file added _images/J43.png
Binary file added _images/J5.png
Binary file added _images/J51.png
Binary file added _images/J52.png
Binary file added _images/J53.png
Binary file added _images/J54.png
Binary file added _images/J6.png
Binary file added _images/J61.png
Binary file added _images/J62.png
Binary file added _images/J63.png
Binary file added _images/J64.png
Binary file added _images/J7.png
Binary file added _images/J71.png
Binary file added _images/J72.png
Binary file added _images/J73.png
Binary file added _images/J74.png
Binary file added _images/J8.png
Binary file added _images/J81.png
Binary file added _images/J82.png
Binary file added _images/J83.png
Binary file added _images/J9.png
Binary file added _images/J91.png
Binary file added _images/J92.png
Binary file added _images/M1.png
Binary file added _images/MODE1.png
Binary file added _images/MODE11.png
Binary file added _images/POT1.png
Binary file added _images/PROG_B1.png
Binary file added _images/PROG_B11.png
Binary file added _images/PROG_B12.png
Binary file added _images/PROG_B2.png
Binary file added _images/PROG_B3.png
Binary file added _images/PROG_B4.png
Binary file added _images/PROG_B5.png
Binary file added _images/PWR1.png
Binary file added _images/PWR11.png
Binary file added _images/PWR12.png
Binary file added _images/PWR2.png
Binary file added _images/PWR3.png
Binary file added _images/PWR4.png
Binary file added _images/PWR5.png
Binary file added _images/PWR6.png
Binary file added _images/S1.png
Binary file added _images/S11.png
Binary file added _images/S12.png
Binary file added _images/S2.png
Binary file added _images/S3.png
Binary file added _images/SW1.png
Binary file added _images/SW11.png
Binary file added _images/SW2.png
Binary file added _images/SW21.png
Binary file added _images/SW3.png
Binary file added _images/SW31.png
Binary file added _images/SW4.png
Binary file added _images/SW41.png
Binary file added _images/SW5.png
Binary file added _images/SW51.png
Binary file added _images/SW6.png
Binary file added _images/U12.png
Binary file added _images/U14.png
Binary file added _images/U15.png
Binary file added _images/U3.png
Binary file added _images/U4.png
Binary file added _images/U8.png
Binary file added _images/USR_BTN1.png
Binary file added _images/USR_BTN2.png
Binary file added _images/USR_BTN3.png
Binary file added _images/USR_BTN4.png
Binary file added _images/annotation.png
Binary file added _images/annotation_zoom.png
Binary file added _images/arty-a7.png
Binary file added _images/ddr5-test-bed-1.0.1.png
Binary file added _images/dqs_vict_vs_aggr.png
Binary file added _images/f4pga_visualizer_aggr_vs_vict.png
Binary file added _images/lpddr4-test-bed-1.0.0.png
Binary file added _images/lpddr4-test-board-1.0.4-descriptions.png
Binary file added _images/lpddr4-test-board-1.0.4.png
Binary file added _images/lpddr5-test-bed-1.0.0.png
Binary file added _images/rdimm-ddr4-tester-1.2.0-descriptions.png
Binary file added _images/rdimm-ddr4-tester-1.2.0.png
Binary file added _images/rdimm-ddr5-cell-retention-plot.png
Binary file added _images/rdimm-ddr5-memory-testing-setup.png
Binary file added _images/rdimm-ddr5-tester-1.0.0-descriptions.png
Binary file added _images/rdimm-ddr5-tester-1.0.0.png
Binary file added _images/rdimm-ddr5-tester-2.0.0-descriptions.png
Binary file added _images/rdimm-ddr5-tester-2.0.0.png
Binary file added _images/rdimm-ddr5-tester-pcie-integration.png
Binary file added _images/rowhammer_tester_architecture.png
Binary file added _images/sodimm-ddr5-tester-descriptions.png
Binary file added _images/sodimm-ddr5-tester.png
Binary file added _images/zcu104.png
18 changes: 18 additions & 0 deletions _sources/arty.md.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
# Arty-A7 board

The [Arty-A7 board](https://reference.digilentinc.com/reference/programmable-logic/arty-a7/start) allows testing its on-board DDR3 module.
The board is designed around the Artix-7 Field Programmable Gate Array (FPGA) from AMD(Xilinx).

:::{figure-md} arty-a7
![arty-a7](images/arty-a7.png)

Arty-A7 board
:::

The following instructions explain how to set up the board.
For FPGA digital design documentation for this board, refer to the [Digital design](build/arty/documentation/index.rst) chapter.

## Board configuration

Connect the board USB and Ethernet cables to your computer and configure the network.
The bitstream will be loaded from flash memory upon device power-on or after pressing the PROG button.
231 changes: 231 additions & 0 deletions _sources/building_linux.md.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,231 @@
# Building Linux target

The memory controllers synhesized for Rowhammer testing can be utilized as parts of a regular digital design that is capable of booting an operating system.
In such scenario the memory controller is used by the operating system for interacting with a DRAM memory.
This chapter describes a separate target configuration that has been created in order to synthesize a Linux-capable system that you can run on Antmicro's [RDIMM DDR5 Tester](rdimm_ddr5_tester.md).

## Base DDR5 Tester Linux Options

The `ddr5_tester_linux` target is configured via specifying the ``TARGET_ARGS`` variable and requires the following arguments:

| Option | Documentation |
|:------------------------:|:-------------------------------------------------------------------------------------------------------------------------------:|
| `--build` | When specified will invoke synthesis and hardware analysis tool (Vivado by default).<br /> Will produce programmable bitstream. |
| `--l2-size` | Specifies the L2 cache size. |
| `--iodelay-clk-freq` | IODELAY clock frequency. |
| `--module` | The DDR5 module to be used. |
| `--with-wishbone-memory` | VexRiscV SMP specific option.<br /> Disables native LiteDRAM interface. |
| `--wishbone-force-32b` | VexRiscV SMP specific option.<br /> Forces the wishbone bus to be 32 bits wide. |

Additionally, you can set up ``EtherBone`` or ``Ethernet`` to communicate with the system as described below.

### Ethernet Options

| Option | Documentation |
|:---------------------:|:--------------------------------------------------------------:|
| `--with-ethernet` | Sets up Ethernet for the DDR5 Tester board. |
| `--remote-ip-address` | The IP address of the remote machine connected to DDR5 Tester. |
| `--local-ip-address` | Local (DDR5 Tester's) IP address. |

### Etherbone Options

| Option | Documentation |
|:------------------:|:-----------------------------------------:|
| `--with-etherbone` | Sets up Ethernet for DDR5 Tester board. |
| `--ip-address` | IP address to be used for the EtherBone. |
| `--mac-address` | MAC address to be used for the EtherBone. |

## Building the RDIMM DDR5 Tester Linux Target

After configuring the RDIMM DDR5 Tester Linux, the target can be build with `make build`.
Below you can see a use example of a DDR5 Tester Linux Target with Ethernet configured:

```sh
make build TARGET=ddr5_tester_linux TARGET_ARGS="--build --l2-size 256 --iodelay-clk-freq 400e6 --module MTC10F1084S1RC --with-wishbone-memory --wishbone-force-32b --with-ethernet --remote-ip-address 192.168.100.100 --local-ip-address 192.168.100.50"
```

## Interacting with RDIMM DDR5 Tester Linux Target

First, load the bitstream onto the RDIMM DDR5 Tester with the help of `OpenFPGALoader`:

```bash
openFPGALoader --board antmicro_ddr5_tester build/ddr5_tester_linux/gateware/antmicro_ddr5_tester.bit --freq 3e6
```

In order to connect to the board, assign the `192.168.100.100` IP Address to the Ethernet interface that is plugged to the DDR5 Tester board and set up the device if needed, e.g. by running:

```sh
ip addr add 192.168.100.100/24 dev $ETH
ip link set dev $ETH up
```

Where ``ETH`` is the name of your Ethernet interface.
When the Ethernet interface has been set up correctly, you may access the BIOS console on the DDR5 Tester with:

```sh
picocom -b 115200 /dev/ttyUSB2
```

## Setting up a TFTP Server

Several Linux boot methods can be invoked here but booting via Ethernet is recommended.
In order to enable netboot, you need to set up a TFTP server first.

```{note}
Running a TFTP server varies between distributions in terms of TFTP implementation names and locations of the configuration file.
```

As an example, below is a quick guide on how to configure a TFTP server for Arch Linux.
Firstly, if not equipped already, get an implementation of a TFTP server, for example:

```sh
pacman -S tftp-hpa
```

The TFTP server is configured via a `/etc/conf.d/tftpd` file.
Here's a suggested configuration for the DDR5 Tester Linux boot process:

```sh
TFTP_USERNAME="tftp"
TFTPD_OPTIONS="--secure"
TFTP_DIRECTORY="/srv/tftp"
TFTP_ADDRESS="192.168.100.100:69"
```

``TFTP_ADDRESS`` is specified with the ``--remote-ip-address`` option whilst building the target and the port is the default one for the TFTP server.
The ``TFTP_DIRECTORY`` is the TFTP's root directory.

To start the TFTP service, run:

```sh
systemctl start tftpd
```

To check whether the TFTP sever is set up properly, run:

```sh
cd /srv/tftp/ && echo "TEST TFTP SERVER" > test

cd ~/ && tftp 192.168.100.100 -c get test
```

The ``test`` file should appear in the home directory with "TEST TFTP SERVER" as its content.

## Booting Linux on RDIMM DDR5 Tester Linux Target

You will need the following binaries:

* Linux kernel Image
* Compiled devicetree
* Opensbi's `fw_jump.bin`
* rootfs.cpio

All of these can be obtained with the use of provided `firmware/ddr5_tester/buildroot` buildroot external configuration.
To build binaries with buildroot, run:

```sh
git clone --single-branch -b 2023.05.x https://github.com/buildroot/buildroot.git
pushd buildroot
make BR2_EXTERNAL="$(pwd)/../firmware/ddr5_tester/buildroot" ddr5_vexriscv_defconfig
```

Then, transfer the binaries to the TFTP root directory:

```sh
mv buildroot/output/images/* /srv/tftp/
mv /srv/tftp/fw_jump.bin /srv/tftp/opensbi.bin
```

The address map of the binaries alongside boot arguments can be contained within the `boot.json` file, for example:

```json
{
"/srv/tftp/Image": "0x40000000",
"/srv/tftp/rv32.dtb": "0x40ef0000",
"/srv/tftp/rootfs.cpio": "0x42000000",
"/srv/tftp/opensbi.bin": "0x40f00000",
"bootargs": {
"r1": "0x00000000",
"r2": "0x40ef0000",
"r3": "0x00000000",
"addr": "0x40f00000"
}
```

With Linux boot binaries in the TFTP's root directory with `boot.json`, netboot can be invoked from the BIOS console with:

```sh
netboot /srv/tftp/boot.json
```

Upon successful execution a similar log will be printed:

```
litex> netboot /srv/tftp/boot.json
Booting from network...
Local IP: 192.168.100.50
Remote IP: 192.168.100.100
Booting from /srv/tftp/boot.json (JSON)...
Copying /srv/tftp/Image to 0x40000000... (7395804 bytes)
Copying /srv/tftp/rv32.dtb to 0x40ef0000... (2463 bytes)
Copying /srv/tftp/rootfs.cpio to 0x42000000... (22128128 bytes)
Copying /srv/tftp/opensbi.bin to 0x40f00000... (1007056 bytes)
Executing booted program at 0x40f00000

--============= Liftoff! ===============--
```

Then, the OpenSBI and Linux boot log should follow:

```
OpenSBI v1.3-24-g84c6dc1
____ _____ ____ _____
/ __ \ / ____| _ \_ _|
| | | |_ __ ___ _ __ | (___ | |_) || |
| | | | '_ \ / _ \ '_ \ \___ \| _ < | |
| |__| | |_) | __/ | | |____) | |_) || |_
\____/| .__/ \___|_| |_|_____/|____/_____|
| |
|_|

Platform Name : LiteX / VexRiscv-SMP
Platform Features : medeleg
Platform HART Count : 8
Platform IPI Device : aclint-mswi
Platform Timer Device : aclint-mtimer @ 100000000Hz
Platform Console Device : litex_uart
(...)
[ 0.000000] Linux version 5.11.0 (riscv32-buildroot-linux-gnu-gcc.br_real (Buildroot 2023.05.2-154-g787a633711) 11.4.0, GNU ld (GNU Binutils) 2.38) #2 SMP Mon Sep 25 10:52:22 CEST 2023
[ 0.000000] earlycon: sbi0 at I/O port 0x0 (options '')
[ 0.000000] printk: bootconsole [sbi0] enabled
(...)
```

And then:

```
Welcome to Buildroot
buildroot login: root
_ _
| | (_)
| | _ _ __ _ ___ __
| | | | '_ \| | | \ \/ /
| |___| | | | | |_| |> <
\_____/_|_| |_|\__,_/_/\_\
_ _ _
(_) | | |
__ ___| |_| |__
\ \ /\ / / | __| '_ \
\ V V /| | |_| | | |
\_/\_/ |_|\__|_| |_|
__________________ _____
| _ \ _ \ ___ \ ___|
| | | | | | | |_/ /___ \
| | | | | | | / \ \
| |/ /| |/ /| |\ \/\__/ /
|___/ |___/ \_| \_\____/

32-bit RISC-V Linux running on DDR5 Tester.

login[65]: root login on 'console'
```
Loading

0 comments on commit 6a2bc7e

Please sign in to comment.