Project

General

Profile

Fuzzing cva6 » History » Version 2

Egor Zheliba, 02/24/2025 12:12 PM

1 1 Egor Zheliba
h1. Fuzzing CVA6
2
3
CVA6 (бывший Ariane) — это 64-битное RISC-V ядро с открытым исходным кодом, разработанное сообществом OpenHW Group. Ниже описаны основные шаги по запуску фаззинга CVA6 в рамках проекта FuzzRV.
4
5
1. Для начала необходимо склонировать репозиторий (с подтягиванием сабмодулей):
6
<pre>
7
git clone --recursive https://forge.ispras.ru/git/fuzzrv.git
8
</pre>
9
10
2. Переходим в корневую директорию проекта и переключаемся на ветку main (при необходимости):
11
<pre>
12
cd /path/to/fuzzrv
13
git checkout main
14
</pre>
15
16
3. Собираем Docker-образ для проекта *cva6*:
17
<pre>
18
python3 infra/helper.py build_image cva6
19
</pre>
20
После успешной сборки можно проверить наличие образа командой:
21
<pre>
22
docker images
23
</pre>
24
Как минимум должен появиться образ с названием: *gcr.io/oss-fuzz/cva6*
25
26
4. Компилируем фаззер:
27
<pre>
28 2 Egor Zheliba
python3 infra/helper.py build_fuzzers --sanitizer address/memory/undefined --engine libfuzzer --architecture x86_64 cva6
29 1 Egor Zheliba
</pre>
30
или, например, для aarch64:
31
<pre>
32 2 Egor Zheliba
python3 infra/helper.py build_fuzzers --sanitizer address/memory/undefined --engine libfuzzer --architecture aarch64 cva6
33 1 Egor Zheliba
</pre>
34
35
Параметры:
36 2 Egor Zheliba
* --sanitizer address/memory/undefined – опциональный флаг, можно выбрать нужный санитайзер.
37
* --architecture x86_64/aarch64 – целевая архитектура (по умолчанию x86_64).
38 1 Egor Zheliba
39
Если сборка прошла успешно, в директории *build/out/cva6* появится исполняемый файл (фаззер).
40
41
5. Запуск фаззинга:
42
<pre>
43
python3 infra/helper.py run_fuzzer --architecture x86_64 cva6 cva6_fuzzer
44
</pre>
45
46
Параметр --architecture также можно не указывать (по умолчанию x86_64).
47
48
При запуске начнётся процесс фаззинга. Тесты-мутанты, давшие новое покрытие, сохраняются в директории *fuzzrv/build/out/cva6/new_coverage*.