Fuzzing cva6 » History » Version 1
Egor Zheliba, 02/24/2025 12:11 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 | python3 infra/helper.py build_fuzzers --sanitizer <address/memory/undefined> --engine libfuzzer --architecture x86_64 cva6 |
||
29 | </pre> |
||
30 | или, например, для aarch64: |
||
31 | <pre> |
||
32 | python3 infra/helper.py build_fuzzers --sanitizer <address/memory/undefined> --engine libfuzzer --architecture aarch64 cva6 |
||
33 | </pre> |
||
34 | |||
35 | Параметры: |
||
36 | * --sanitizer <address/memory/undefined> – опциональный флаг, можно выбрать нужный санитайзер. |
||
37 | * --architecture <x86_64/aarch64> – целевая архитектура (по умолчанию x86_64). |
||
38 | |||
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*. |