* Make fuzzers/tinyinst_simple support Linux (#1316) Fix a documentation error for `MmapShMemProvider`. * Support shmem for `fuzzers/tinyinst_simple` on Linux. Format code. * Fix CI to install cxxbridge-cmd. * Add `CARGO_TARGET_DIR` in makefile to fix CI.
This commit is contained in:
parent
fde9cda5ee
commit
5eab4fb78b
4
.github/workflows/build_and_test.yml
vendored
4
.github/workflows/build_and_test.yml
vendored
@ -309,6 +309,10 @@ jobs:
|
|||||||
uses: baptiste0928/cargo-install@v1.3.0
|
uses: baptiste0928/cargo-install@v1.3.0
|
||||||
with:
|
with:
|
||||||
crate: wasm-pack
|
crate: wasm-pack
|
||||||
|
- name: install cxxbridge-cmd
|
||||||
|
uses: baptiste0928/cargo-install@v1.3.0
|
||||||
|
with:
|
||||||
|
crate: cxxbridge-cmd
|
||||||
- name: install chrome
|
- name: install chrome
|
||||||
uses: browser-actions/setup-chrome@v1
|
uses: browser-actions/setup-chrome@v1
|
||||||
with:
|
with:
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
[env]
|
[env]
|
||||||
PROFILE = { value = "release", condition = {env_not_set = ["PROFILE"]} }
|
PROFILE = { value = "release", condition = {env_not_set = ["PROFILE"]} }
|
||||||
PROFILE_DIR = {value = "release", condition = {env_not_set = ["PROFILE_DIR"] }}
|
PROFILE_DIR = { value = "release", condition = {env_not_set = ["PROFILE_DIR"] }}
|
||||||
|
CARGO_TARGET_DIR = { value = "target", condition = { env_not_set = ["CARGO_TARGET_DIR"] } }
|
||||||
|
|
||||||
[tasks.unsupported]
|
[tasks.unsupported]
|
||||||
script_runner="@shell"
|
script_runner="@shell"
|
||||||
@ -10,10 +11,15 @@ echo "Cargo-make not integrated yet on this"
|
|||||||
|
|
||||||
# Harness
|
# Harness
|
||||||
[tasks.harness]
|
[tasks.harness]
|
||||||
linux_alias = "unsupported"
|
linux_alias = "harness_linux"
|
||||||
mac_alias = "unsupported"
|
mac_alias = "unsupported"
|
||||||
windows_alias = "harness_windows"
|
windows_alias = "harness_windows"
|
||||||
|
|
||||||
|
[tasks.harness_linux]
|
||||||
|
script='''
|
||||||
|
clang test/test.cpp -o test.exe
|
||||||
|
'''
|
||||||
|
|
||||||
[tasks.harness_windows]
|
[tasks.harness_windows]
|
||||||
script='''
|
script='''
|
||||||
cl test\test.cpp -o test.exe
|
cl test\test.cpp -o test.exe
|
||||||
@ -21,10 +27,15 @@ cl test\test.cpp -o test.exe
|
|||||||
|
|
||||||
# Fuzzer
|
# Fuzzer
|
||||||
[tasks.fuzzer]
|
[tasks.fuzzer]
|
||||||
linux_alias = "unsupported"
|
linux_alias = "fuzzer_linux"
|
||||||
mac_alias = "unsupported"
|
mac_alias = "unsupported"
|
||||||
windows_alias = "fuzzer_windows"
|
windows_alias = "fuzzer_windows"
|
||||||
|
|
||||||
|
[tasks.fuzzer_linux]
|
||||||
|
dependencies = ["harness"]
|
||||||
|
command = "cargo"
|
||||||
|
args = ["build", "--profile", "${PROFILE}"]
|
||||||
|
|
||||||
[tasks.fuzzer_windows]
|
[tasks.fuzzer_windows]
|
||||||
dependencies = ["harness"]
|
dependencies = ["harness"]
|
||||||
command = "cargo"
|
command = "cargo"
|
||||||
@ -32,10 +43,15 @@ args = ["build", "--profile", "${PROFILE}"]
|
|||||||
|
|
||||||
# Run the fuzzer
|
# Run the fuzzer
|
||||||
[tasks.run]
|
[tasks.run]
|
||||||
linux_alias = "unsupported"
|
linux_alias = "run_linux"
|
||||||
mac_alias = "unsupported"
|
mac_alias = "unsupported"
|
||||||
windows_alias = "run_windows"
|
windows_alias = "run_windows"
|
||||||
|
|
||||||
|
[tasks.run_linux]
|
||||||
|
dependencies = ["harness", "fuzzer"]
|
||||||
|
command = "cargo"
|
||||||
|
args = ["run", "--profile", "${PROFILE}"]
|
||||||
|
|
||||||
[tasks.run_windows]
|
[tasks.run_windows]
|
||||||
dependencies = ["harness", "fuzzer"]
|
dependencies = ["harness", "fuzzer"]
|
||||||
command = "cargo"
|
command = "cargo"
|
||||||
@ -44,10 +60,25 @@ args = ["run", "--profile", "${PROFILE}"]
|
|||||||
|
|
||||||
# Run the fuzzer
|
# Run the fuzzer
|
||||||
[tasks.test]
|
[tasks.test]
|
||||||
linux_alias = "unsupported"
|
linux_alias = "test_linux"
|
||||||
mac_alias = "unsupported"
|
mac_alias = "unsupported"
|
||||||
windows_alias = "test_windows"
|
windows_alias = "test_windows"
|
||||||
|
|
||||||
|
[tasks.test_linux]
|
||||||
|
script_runner="@shell"
|
||||||
|
script='''
|
||||||
|
cp ${CARGO_TARGET_DIR}/${PROFILE_DIR}/tinyinst_simple .
|
||||||
|
echo running tests
|
||||||
|
timeout 5s ./tinyinst_simple || true
|
||||||
|
# corpus_discovered folder exists and is not empty
|
||||||
|
if [ -d "corpus_discovered" ] && [ -n "$(ls -A corpus_discovered)" ]; then
|
||||||
|
echo "Fuzzer works!"
|
||||||
|
else
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
'''
|
||||||
|
dependencies = ["harness", "fuzzer"]
|
||||||
|
|
||||||
[tasks.test_windows]
|
[tasks.test_windows]
|
||||||
script_runner = "@shell"
|
script_runner = "@shell"
|
||||||
script='''
|
script='''
|
||||||
@ -57,4 +88,4 @@ start "" "tinyinst_simple.exe"
|
|||||||
ping -n 10 127.0.0.1>NUL && taskkill /im tinyinst_simple.exe /F
|
ping -n 10 127.0.0.1>NUL && taskkill /im tinyinst_simple.exe /F
|
||||||
>nul 2>nul dir /a-d "corpus_discovered\*" && (echo Files exist) || (exit /b 1337)
|
>nul 2>nul dir /a-d "corpus_discovered\*" && (echo Files exist) || (exit /b 1337)
|
||||||
'''
|
'''
|
||||||
dependencies = [ "harness", "fuzzer" ]
|
dependencies = ["harness", "fuzzer"]
|
@ -1,11 +1,12 @@
|
|||||||
# Tinyinst example
|
# Tinyinst example
|
||||||
This is a fuzzer example to show how libafl_tinyinst works
|
This is a fuzzer example to show how libafl_tinyinst works.
|
||||||
|
|
||||||
## How to build
|
## How to build
|
||||||
1. Build the harness with `cl test\test.cpp -o test.exe`
|
1. Install cxxbridge-cmd with `cargo install cxxbridge-cmd`
|
||||||
2. Build the fuzzer with `cargo build --release`. The fuzzer is `target\release\tinyinst_simple.exe`
|
2. Build the harness with `cl test\test.cpp -o test.exe`
|
||||||
|
3. Build the fuzzer with `cargo build --release`. The fuzzer is `target\release\tinyinst_simple.exe`
|
||||||
|
|
||||||
## Run with cargo-make
|
## Run with cargo-make
|
||||||
Or, you can simple run it using cargo-make
|
Or, you can simply run it using cargo-make
|
||||||
1. Open up developer powershell so that you have access to cl (Windows Default Compiler)
|
1. If on Windows, open up a developer powershell so that you have access to cl (Windows Default Compiler)
|
||||||
2. Run `cargo make run` to run the fuzzer
|
2. Run `cargo make run` to run the fuzzer
|
@ -13,7 +13,7 @@ use libafl::{
|
|||||||
state::StdState,
|
state::StdState,
|
||||||
Fuzzer, StdFuzzer,
|
Fuzzer, StdFuzzer,
|
||||||
};
|
};
|
||||||
#[cfg(target_vendor = "apple")]
|
#[cfg(unix)]
|
||||||
use libafl_bolts::shmem::UnixShMemProvider;
|
use libafl_bolts::shmem::UnixShMemProvider;
|
||||||
#[cfg(windows)]
|
#[cfg(windows)]
|
||||||
use libafl_bolts::shmem::Win32ShMemProvider;
|
use libafl_bolts::shmem::Win32ShMemProvider;
|
||||||
@ -25,10 +25,10 @@ use libafl_bolts::{
|
|||||||
use libafl_tinyinst::executor::TinyInstExecutorBuilder;
|
use libafl_tinyinst::executor::TinyInstExecutorBuilder;
|
||||||
static mut COVERAGE: Vec<u64> = vec![];
|
static mut COVERAGE: Vec<u64> = vec![];
|
||||||
|
|
||||||
#[cfg(not(any(target_vendor = "apple", windows)))]
|
#[cfg(not(any(target_vendor = "apple", windows, target_os = "linux")))]
|
||||||
fn main() {}
|
fn main() {}
|
||||||
|
|
||||||
#[cfg(any(target_vendor = "apple", windows))]
|
#[cfg(any(target_vendor = "apple", windows, target_os = "linux"))]
|
||||||
fn main() {
|
fn main() {
|
||||||
// Tinyinst things
|
// Tinyinst things
|
||||||
let tinyinst_args = vec!["-instrument_module".to_string(), "test.exe".to_string()];
|
let tinyinst_args = vec!["-instrument_module".to_string(), "test.exe".to_string()];
|
||||||
@ -44,7 +44,7 @@ fn main() {
|
|||||||
#[cfg(windows)]
|
#[cfg(windows)]
|
||||||
let mut shmem_provider = Win32ShMemProvider::new().unwrap();
|
let mut shmem_provider = Win32ShMemProvider::new().unwrap();
|
||||||
|
|
||||||
#[cfg(target_vendor = "apple")]
|
#[cfg(unix)]
|
||||||
let mut shmem_provider = UnixShMemProvider::new().unwrap();
|
let mut shmem_provider = UnixShMemProvider::new().unwrap();
|
||||||
|
|
||||||
let input = BytesInput::new(b"bad".to_vec());
|
let input = BytesInput::new(b"bad".to_vec());
|
||||||
|
@ -23,8 +23,9 @@ limitations under the License.
|
|||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
|
|
||||||
// shared memory stuff
|
// shared memory stuff
|
||||||
|
#if defined(__linux__)
|
||||||
#if defined(WIN32) || defined(_WIN32) || defined(__WIN32)
|
#include <sys/shm.h>
|
||||||
|
#elif defined(WIN32) || defined(_WIN32) || defined(__WIN32)
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
#else
|
#else
|
||||||
#include <sys/mman.h>
|
#include <sys/mman.h>
|
||||||
@ -36,7 +37,19 @@ unsigned char *shm_data;
|
|||||||
|
|
||||||
bool use_shared_memory;
|
bool use_shared_memory;
|
||||||
|
|
||||||
#if defined(WIN32) || defined(_WIN32) || defined(__WIN32)
|
#if defined(__linux__)
|
||||||
|
|
||||||
|
int setup_shmem(const char *name) {
|
||||||
|
// map shared memory to process address space
|
||||||
|
shm_data = (unsigned char *)shmat(atoi(name), NULL, 0);
|
||||||
|
if (shm_data == (void *)-1) {
|
||||||
|
perror("Error in shmat");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
#elif defined(WIN32) || defined(_WIN32) || defined(__WIN32)
|
||||||
|
|
||||||
int setup_shmem(const char *name) {
|
int setup_shmem(const char *name) {
|
||||||
HANDLE map_file;
|
HANDLE map_file;
|
||||||
@ -71,7 +84,7 @@ int setup_shmem(const char *name) {
|
|||||||
// get shared memory file descriptor (NOT a file)
|
// get shared memory file descriptor (NOT a file)
|
||||||
fd = shm_open(name, O_RDONLY, S_IRUSR | S_IWUSR);
|
fd = shm_open(name, O_RDONLY, S_IRUSR | S_IWUSR);
|
||||||
if (fd == -1) {
|
if (fd == -1) {
|
||||||
printf("Error in shm_open\n");
|
perror("Error in shm_open");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -79,7 +92,7 @@ int setup_shmem(const char *name) {
|
|||||||
shm_data =
|
shm_data =
|
||||||
(unsigned char *)mmap(NULL, SHM_SIZE, PROT_READ, MAP_SHARED, fd, 0);
|
(unsigned char *)mmap(NULL, SHM_SIZE, PROT_READ, MAP_SHARED, fd, 0);
|
||||||
if (shm_data == MAP_FAILED) {
|
if (shm_data == MAP_FAILED) {
|
||||||
printf("Error in mmap\n");
|
perror("Error in mmap");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -101,7 +114,12 @@ char *crash = NULL;
|
|||||||
|
|
||||||
// actual target function
|
// actual target function
|
||||||
|
|
||||||
void FUZZ_TARGET_MODIFIERS fuzz(char *name) {
|
// Use extern "C" to preserve the function name for instrumentation
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C"
|
||||||
|
#endif // __cplusplus
|
||||||
|
void FUZZ_TARGET_MODIFIERS
|
||||||
|
fuzz(char *name) {
|
||||||
char *sample_bytes = NULL;
|
char *sample_bytes = NULL;
|
||||||
uint32_t sample_size = 0;
|
uint32_t sample_size = 0;
|
||||||
|
|
||||||
|
@ -725,7 +725,7 @@ pub mod unix_shmem {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// A [`ShMemProvider`] which uses `shmget`/`shmat`/`shmctl` to provide shared memory mappings.
|
/// A [`ShMemProvider`] which uses [`shm_open`] and [`mmap`] to provide shared memory mappings.
|
||||||
#[cfg(unix)]
|
#[cfg(unix)]
|
||||||
#[derive(Clone, Debug)]
|
#[derive(Clone, Debug)]
|
||||||
pub struct MmapShMemProvider {
|
pub struct MmapShMemProvider {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user