[vlc] Initial integration (#5598)

* [vlc] Initial integration

* Small fixes

* update packages.

* Compile existing fuzzers.

* updated setup to work with static builds.

* Cleanup.

* no more string fuzzer.

* typo.

* updated the project yaml.

Co-authored-by: davkor <david@adalogics.com>
This commit is contained in:
AdamKorcz 2021-05-18 21:24:19 +01:00 committed by GitHub
parent 653f307d16
commit a676448e80
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 85 additions and 0 deletions

22
projects/vlc/Dockerfile Normal file
View File

@ -0,0 +1,22 @@
# Copyright 2021 Google LLC
#
# 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.
#
################################################################################
FROM gcr.io/oss-fuzz-base/base-builder
RUN apt-get update && apt-get install -y make autoconf automake libtool \
pkg-config cmake flex bison gettext libglu1-mesa-dev
RUN git clone --depth 1 https://github.com/videolan/vlc vlc
WORKDIR vlc
COPY build.sh $SRC/

53
projects/vlc/build.sh Executable file
View File

@ -0,0 +1,53 @@
#!/bin/bash -eu
# Copyright 2021 Google LLC
#
# 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.
#
################################################################################
# Use OSS-Fuzz environment rather than hardcoded setup.
sed -i 's/-fsanitize-coverage=trace-pc-guard//g' ./configure.ac
sed -i 's/-fsanitize-coverage=trace-cmp//g' ./configure.ac
sed -i 's/-fsanitize-coverage=trace-pc//g' ./configure.ac
sed -i 's/-lFuzzer//g' ./configure.ac
# In order to build statically we avoid libxml and ogg plugins.
sed -i 's/..\/..\/lib\/libvlc_internal.h/lib\/libvlc_internal.h/g' ./test/src/input/decoder.c
sed -i 's/..\/modules\/libxml_plugin.la//g' ./test/Makefile.am
sed -i 's/..\/modules\/libogg_plugin.la//g' ./test/Makefile.am
sed -i 's/f(misc_xml_xml)//g' ./test/src/input/demux-run.c
sed -i 's/f(demux_ogg)//g' ./test/src/input/demux-run.c
# Ensure that we compile with the correct link flags.
RULE="vlc_demux_libfuzzer_LDADD"
FUZZ_LDFLAGS="vlc_demux_libfuzzer_LDFLAGS=\${LIB_FUZZING_ENGINE}"
sed -i "s/${RULE}/${FUZZ_LDFLAGS}\n${RULE}/g" ./test/Makefile.am
RULE="vlc_demux_dec_libfuzzer_LDADD"
FUZZ_LDFLAGS="vlc_demux_dec_libfuzzer_LDFLAGS=\${LIB_FUZZING_ENGINE}"
sed -i "s/${RULE}/${FUZZ_LDFLAGS}\n${RULE}/g" ./test/Makefile.am
./bootstrap
./configure --disable-ogg --disable-oggspots --disable-libxml2 --disable-lua \
--disable-shared \
--enable-static \
--enable-vlc=no \
--disable-avcodec \
--disable-swscale \
--disable-a52 \
--disable-xcb \
--disable-alsa \
--with-libfuzzer
make V=1 -j$(nproc)
cp ./test/vlc-demux-dec-libfuzzer $OUT/
cp ./test/vlc-demux-libfuzzer $OUT/

10
projects/vlc/project.yaml Normal file
View File

@ -0,0 +1,10 @@
homepage: "https://github.com/videolan/vlc"
language: c
primary_contact: "ossfuzz@videolan.org"
auto_ccs:
- "adam@adalogics.com"
- "david@adalogics.com"
sanitizers:
- address
- undefined
main_repo: 'https://github.com/videolan/vlc'