Windows CI for frida (#658)

* harness & makefile.toml

* Update build_and_test.yml

* Update build_and_test.yml

* Update build_and_test.yml

* rename

* no stdout

* Update harness_win.cpp

* Update harness_win.cpp

* Update Makefile.toml

* Update build_and_test.yml

* Update Makefile.toml

* Update Makefile.toml

* fix
This commit is contained in:
Dongjia Zhang 2022-05-31 06:06:37 +09:00 committed by GitHub
parent 3a5118fc02
commit bc6a032843
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 50 additions and 8 deletions

View File

@ -212,8 +212,11 @@ jobs:
directory: ${{ runner.temp }}/llvm
- name: Set LIBCLANG_PATH
run: echo "LIBCLANG_PATH=$((gcm clang).source -replace "clang.exe")" >> $env:GITHUB_ENV
- name: install cargo-make
run: cargo install --force cargo-make
- uses: ilammy/msvc-dev-cmd@v1
- name: Build frida
run: cd fuzzers/frida_libpng/ && cargo build --release
run: cd fuzzers/frida_libpng/ && cargo make test
macos:
runs-on: macOS-latest

View File

@ -1,8 +1,7 @@
# Variables
[env]
FUZZER_NAME='frida_fuzzer'
FUZZER_NAME={ source = "${CARGO_MAKE_RUST_TARGET_OS}", default_value = "frida_fuzzer", mapping = {"linux" = "frida_fuzzer", "macos" = "frida_fuzzer", "windows" = "frida_fuzzer.exe"} }
FUZZER = './target/release/${FUZZER_NAME}'
PROJECT_DIR = { script = ["pwd"] }
[tasks.unsupported]
script_runner="@shell"
@ -34,7 +33,7 @@ windows_alias = "unsupported"
script_runner="@shell"
script='''
cd libpng-1.6.37 && ./configure --enable-shared=no --with-pic=yes --enable-hardware-optimizations=yes
cd "${PROJECT_DIR}"
cd ..
make -C libpng-1.6.37
'''
dependencies = [ "libpng" ]
@ -43,7 +42,7 @@ dependencies = [ "libpng" ]
[tasks.harness]
linux_alias = "harness_unix"
mac_alias = "harness_unix"
windows_alias = "unsupported"
windows_alias = "harness_windows"
[tasks.harness_unix]
script_runner="@shell"
@ -53,6 +52,11 @@ clang++ -O3 harness.o libpng-1.6.37/.libs/libpng16.a -shared -lz -o libpng-harne
'''
dependencies = [ "lib" ]
[tasks.harness_windows]
script_runner="@shell"
script='''
cl /c harness_win.cpp && link harness_win.obj /dll
'''
# Fuzzer
[tasks.fuzzer]
@ -66,7 +70,7 @@ cp ./target/release/${FUZZER_NAME} .
[tasks.run]
linux_alias = "run_unix"
mac_alias = "run_unix"
windows_alias = "unsupported"
windows_alias = "run_windows"
[tasks.run_unix]
script_runner = "@shell"
@ -75,11 +79,18 @@ script='''
'''
dependencies = [ "fuzzer", "harness" ]
[tasks.run_windows]
script_runner = "@shell"
script='''
./${FUZZER_NAME} -F LLVMFuzzerTestOneInput -H ./harness_win.dll -l ./harness_win.dll --cores=0
'''
dependencies = [ "fuzzer", "harness" ]
# Test
[tasks.test]
linux_alias = "test_unix"
mac_alias = "test_unix"
windows_alias = "unsupported"
windows_alias = "test_windows"
[tasks.test_unix]
script_runner = "@shell"
@ -89,6 +100,16 @@ timeout 10s ./${FUZZER_NAME} -F LLVMFuzzerTestOneInput -H ./libpng-harness.so -l
'''
dependencies = [ "fuzzer", "harness" ]
[tasks.test_windows]
script_runner = "@shell"
script='''
start "" "frida_fuzzer.exe" -F LLVMFuzzerTestOneInput -H ./harness_win.dll -l ./harness_win.dll --cores=0
#ping is for timeout
ping -n 10 127.0.0.1>NUL && taskkill /im frida_fuzzer.exe /F
>nul 2>nul dir /a-d "corpus_discovered\*" && (echo Files exist) || (exit /b 1337)
'''
dependencies = [ "fuzzer", "harness" ]
# Clean up
[tasks.clean]
linux_alias = "clean_unix"

View File

@ -0,0 +1,18 @@
#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
#include <string.h>
extern "C" __declspec(dllexport) size_t
LLVMFuzzerTestOneInput(const char *data, unsigned int len) {
if (data[0] == 'b') {
if (data[1] == 'a') {
if (data[2] == 'd') {
// STATUS_ACCESS_VIOLATION
int volatile *p = 0x0;
*p = 0;
}
}
}
return 0;
}