oss-fuzz/projects/ecc-diff-fuzzer/build.sh

157 lines
4.0 KiB
Bash
Executable File

#!/bin/bash -eu
# Copyright 2018 Google Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
################################################################################
# build projects
#nettle
(
cd nettle
tar -xvf ../gmp-6.2.1.tar.bz2
cd gmp-6.2.1
#do not use assembly instructions as we do not know if they will be available on the machine who will run the fuzzer
#we could do instead --enable-fat
./configure --disable-shared --disable-assembly
make -j$(nproc)
make install
cd ..
autoreconf
./configure --disable-shared --disable-openssl
make -j$(nproc)
make install
)
#cryptopp
(
cd cryptopp
make -j$(nproc)
make install
)
#gcrypt
(
cd libgpg-error
# fix for following error
# error: gettext infrastructure mismatch: using a Makefile.in.in from gettext version 0.19 but the autoconf macros are from gettext version 0.20
timeout 3 gettextize -f || true
./autogen.sh
if [ "$ARCHITECTURE" = 'i386' ]; then
./configure -host=i386 --disable-doc --enable-static --disable-shared
else
./configure --disable-doc --enable-static --disable-shared
fi
make -j$(nproc)
make install
cd ../gcrypt
./autogen.sh
if [ "$ARCHITECTURE" = 'i386' ]; then
./configure -host=i386 --enable-static --disable-shared --disable-doc --enable-maintainer-mode
else
./configure --enable-static --disable-shared --disable-doc --enable-maintainer-mode
fi
make -j$(nproc)
make install
)
#mbedtls
(
cd mbedtls
cmake . -DENABLE_PROGRAMS=0 -DENABLE_TESTING=0
make -j$(nproc) all
make install
)
#openssl
(
cd openssl
#option to not have the same exported function poly1305_blocks as in gcrypt
if [ "$ARCHITECTURE" = 'i386' ]; then
setarch i386 ./config no-poly1305 no-shared no-threads -m32
else
./config no-poly1305 no-shared no-threads
fi
make build_generated libcrypto.a
make install
)
#libecc
(
cd libecc
#required by libecc
(export CFLAGS="$CFLAGS -fPIC"; make; cp build/*.a /usr/local/lib; cp -r src/* /usr/local/include/)
)
#botan
(
cd botan
if [ "$ARCHITECTURE" = 'i386' ]; then
./configure.py --cc-bin=$CXX --cc-abi-flags="$CXXFLAGS" \
--disable-shared --disable-modules=locking_allocator --disable-shared-library \
--without-os-features=getrandom,getentropy --cpu x86_32
else
./configure.py --cc-bin=$CXX --cc-abi-flags="$CXXFLAGS" \
--disable-shared --disable-modules=locking_allocator --disable-shared-library \
--without-os-features=getrandom,getentropy
fi
make -j$(nproc)
make install
)
#quickjs
(
cd quickjs
if [ "$ARCHITECTURE" = 'i386' ]; then
make qjsc
cp qjsc /usr/local/bin/
make clean
# Makefile should not override CFLAGS
sed -i -e 's/CFLAGS=/CFLAGS+=/' Makefile
CFLAGS="-m32" make libquickjs.a
else
make && make install
fi
cp quickjs*.h /usr/local/include/
cp libquickjs.a /usr/local/lib/
)
export CARGO_BUILD_TARGET="x86_64-unknown-linux-gnu"
#build fuzz target
cd ecfuzzer
if [ "$ARCHITECTURE" = 'i386' ]; then
export GOARCH=386
#needed explicitly because of cross compilation cf https://golang.org/cmd/cgo/
export CGO_ENABLED=1
export CARGO_BUILD_TARGET=i686-unknown-linux-gnu
fi
zip -r fuzz_ec_seed_corpus.zip corpus/
cp fuzz_ec_seed_corpus.zip $OUT/
cp fuzz_ec.dict $OUT/
cp fuzz_ec.dict $OUT/fuzz_ec_noblocker.dict
mkdir build
cd build
#no afl with long javascript initialization
if [ "$FUZZING_ENGINE" != 'afl' ]; then
cmake ..
make -j$(nproc)
cp ecfuzzer $OUT/fuzz_ec
rm -Rf *
fi
#another target without javascript
cmake -DDISABLE_JS=ON ..
make -j$(nproc)
cp ecfuzzer $OUT/fuzz_ec_noblocker