Skip to content

Commit

Permalink
Verifier integration (#570)
Browse files Browse the repository at this point in the history
* Verifier integration with libfuzzer tests.

Signed-off-by: Alan Jowett <[email protected]>

* PR feedback

Signed-off-by: Alan Jowett <[email protected]>

* Remove unused option

Signed-off-by: Alan Jowett <[email protected]>

* Cleanup cmake files

Signed-off-by: Alan Jowett <[email protected]>

---------

Signed-off-by: Alan Jowett <[email protected]>
Co-authored-by: Alan Jowett <[email protected]>
  • Loading branch information
Alan-Jowett and Alan Jowett authored Oct 20, 2024
1 parent 0642da6 commit 2d030d0
Show file tree
Hide file tree
Showing 11 changed files with 830 additions and 122 deletions.
15 changes: 9 additions & 6 deletions .github/workflows/fuzzing.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,13 +10,14 @@ on:
schedule: # Run every day at 21:00 UTC
- cron: '00 21 * * *'
workflow_dispatch: # Run manually
workflow_call:

jobs:
build:
strategy:
matrix:
platform:
- ubuntu-latest
- ubuntu-24.04
arch:
- x86_64

Expand Down Expand Up @@ -48,7 +49,7 @@ jobs:
ccache
- name: Install system dependencies (Linux)
if: matrix.platform == 'ubuntu-latest'
if: matrix.platform == 'ubuntu-24.04'
run: |
sudo apt-get update
Expand All @@ -60,7 +61,8 @@ jobs:
libboost-dev \
libboost-program-options-dev \
libboost-filesystem-dev \
libelf-dev
libelf-dev \
libyaml-cpp-dev
if [[ "${{ matrix.arch }}" == "arm64" ]] ; then
sudo apt install -y \
Expand All @@ -70,7 +72,7 @@ jobs:
fi
- name: Build/install libbpf From Source
if: matrix.platform == 'ubuntu-latest'
if: matrix.platform == 'ubuntu-24.04'
run: ./.github/scripts/build-libbpf.sh
shell: bash

Expand All @@ -92,11 +94,11 @@ jobs:
-G Ninja \
-S . \
-B build \
-DCMAKE_BUILD_TYPE=Debug \
-DCMAKE_BUILD_TYPE=RelWithDebInfo \
-DCMAKE_C_COMPILER=clang \
-DCMAKE_CXX_COMPILER=clang++ \
-DUBPF_ENABLE_LIBFUZZER=1 \
-DCMAKE_BUILD_TYPE=Debug
-DVERIFIER_ENABLE_TESTS=false \
${arch_flags}
- name: Build uBPF
Expand Down Expand Up @@ -136,6 +138,7 @@ jobs:
./ubpf_fuzzer new_corpus -artifact_prefix=artifacts/ -use_value_profile=1 -max_total_time=300
- name: Merge corpus into fuzz/corpus
if: ${{ github.event_name == 'schedule' }}
run: |
./ubpf_fuzzer -merge=1 fuzz/corpus new_corpus
git add fuzz/corpus
Expand Down
5 changes: 4 additions & 1 deletion .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@
name: Main

permissions:
contents: read
contents: write # Required by fuzzing task.
security-events: write # Required by codeql task.
actions: read

Expand Down Expand Up @@ -340,6 +340,9 @@ jobs:
build_codeql: true
disable_retpolines: true

linux_release_fuzzing:
uses: ./.github/workflows/fuzzing.yml

# Disabled until https://github.com/iovisor/ubpf/issues/155 is resolved.
# linux_debug_arm64_sanitizers:
# uses: ./.github/workflows/posix.yml
Expand Down
3 changes: 3 additions & 0 deletions .gitmodules
Original file line number Diff line number Diff line change
Expand Up @@ -4,3 +4,6 @@
[submodule "external/bpf_conformance"]
path = external/bpf_conformance
url = https://github.com/Alan-Jowett/bpf_conformance.git
[submodule "external/ebpf-verifier"]
path = external/ebpf-verifier
url = https://github.com/vbpf/ebpf-verifier.git
1 change: 1 addition & 0 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -43,4 +43,5 @@ endif()

if (UBPF_ENABLE_LIBFUZZER)
add_subdirectory("libfuzzer")
add_subdirectory("external/ebpf-verifier")
endif()
4 changes: 3 additions & 1 deletion custom_tests/srcs/ubpf_test_debug_function.cc
Original file line number Diff line number Diff line change
Expand Up @@ -22,8 +22,10 @@ typedef struct _vm_state {
} vm_state_t;

void
debug_callout(void* context, int program_counter, const uint64_t registers[16], const uint8_t* stack_start, size_t stack_length)
debug_callout(void* context, int program_counter, const uint64_t registers[16], const uint8_t* stack_start, size_t stack_length, uint64_t register_mask, const uint8_t* stack_mask)
{
UNREFERENCED_PARAMETER(register_mask);
UNREFERENCED_PARAMETER(stack_mask);
std::vector<vm_state_t>* vm_states = static_cast<std::vector<vm_state_t>*>(context);
vm_state_t vm_state{};

Expand Down
1 change: 1 addition & 0 deletions external/ebpf-verifier
Submodule ebpf-verifier added at e9c229
51 changes: 39 additions & 12 deletions libfuzzer/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -6,24 +6,51 @@ if (UBPF_SKIP_EXTERNAL)
return()
endif()

set(CMAKE_CXX_STANDARD 20)

add_executable(
ubpf_fuzzer
libfuzz_harness.cc
)

target_include_directories("ubpf_fuzzer" PRIVATE
"${CMAKE_SOURCE_DIR}/vm"
set(UBPF_FUZZER_INCLUDES "${CMAKE_SOURCE_DIR}/vm"
"${CMAKE_BINARY_DIR}/vm"
"${CMAKE_BINARY_DIR}/_deps/gsl-src/include"
"${CMAKE_SOURCE_DIR}/vm/inc"
"${CMAKE_BINARY_DIR}/vm/inc"
"${CMAKE_SOURCE_DIR}/ubpf_plugin"
)
"${CMAKE_SOURCE_DIR}/external/ebpf-verifier/src"
"${CMAKE_SOURCE_DIR}/external/ebpf-verifier/src/crab"
"${CMAKE_SOURCE_DIR}/external/ebpf-verifier/src/crab_utils"
"${CMAKE_CURRENT_BINARY_DIR}")

target_link_libraries(
ubpf_fuzzer
set(UBPF_FUZZER_LIBS
ubpf
ubpf_settings
ebpfverifier)

set(CMAKE_REQUIRED_INCLUDES ${UBPF_FUZZER_INCLUDES})

include(CheckCXXSourceCompiles)

# Check if the ebpf verifier supports checking constraints at labels.
set(CHECK_CONFIG_STORE_PRE_INVARIANTS "
#include <config.hpp>
int main() {
ebpf_verifier_options_t options;
options.store_pre_invariants = true;
return 0;
}
")

check_cxx_source_compiles("${CHECK_CONFIG_STORE_PRE_INVARIANTS}" HAVE_EBPF_VERIFIER_CHECK_CONSTRAINTS_AT_LABEL)

set(CMAKE_CXX_STANDARD 20)

configure_file(
libfuzzer_config.h.inc
"${CMAKE_CURRENT_BINARY_DIR}/libfuzzer_config.h"
)

add_executable(
ubpf_fuzzer
libfuzz_harness.cc
)

target_include_directories("ubpf_fuzzer" PRIVATE ${UBPF_FUZZER_INCLUDES})

target_link_libraries(ubpf_fuzzer PRIVATE ${UBPF_FUZZER_LIBS})

Loading

0 comments on commit 2d030d0

Please sign in to comment.