oss-fuzz/docs/faq.md

53 lines
2.7 KiB
Markdown
Raw Normal View History

2016-10-24 20:42:53 +00:00
# Frequently Asked Questions
2016-12-30 06:35:40 +00:00
## What kind of projects are you accepting?
We are currently in a beta status, and still working out issues in our service. At this point, we
can only commit to supporting established projects that have a critical impact on infrastructure and
user security. We will consider each request on a case-by-case basis, but some things we keep in mind are:
- Exposure to remote attacks (e.g. libraries that are used to process untrusted input)
- Number of users/other projects depending on this project.
We hope to relax this requirement in the future though, so keep an eye out even if we are not able
to accept your project at this time!
2016-11-29 19:41:37 +00:00
## Why do you use a [different issue tracker](https://bugs.chromium.org/p/oss-fuzz/issues/list) for reporting bugs in OSS projects?
2016-10-24 20:42:53 +00:00
Security access control is important for the kind of issues that OSS-Fuzz detects.
2016-11-19 00:55:22 +00:00
We will reconsider github issue tracker once the
[access control feature](https://github.com/isaacs/github/issues/37) is available.
2016-10-25 21:40:30 +00:00
2016-12-30 06:37:33 +00:00
## Why do you require an e-mail associated with a Google account?
2016-12-02 22:53:14 +00:00
The [issue tracker](https://bugs.chromium.org/p/oss-fuzz/issues/list) uses Google accounts for authentication.
Note that any e-mail address [can be associated](https://support.google.com/accounts/answer/176347?hl=en)
with a Google account.
2016-10-25 21:40:30 +00:00
## Why do you use Docker?
2016-11-29 19:41:37 +00:00
Building fuzzers requires building your project with a fresh Clang compiler and special compiler flags.
2016-10-25 21:40:30 +00:00
An easy-to-use Docker image is provided to simplify toolchain distribution. This also limits our exposure
2016-11-23 16:31:47 +00:00
to a multitude of Linux varieties and provides a reproducible and secure environment for fuzzer
2016-10-25 21:40:30 +00:00
building and execution.
2016-12-09 18:48:45 +00:00
2016-12-30 06:37:33 +00:00
## How do you handle timeouts and OOMs?
2016-12-25 04:46:16 +00:00
If a single input to a [fuzz target](glossary.md#fuzz-target)
2016-12-27 09:25:11 +00:00
requires more than **~25 seconds** or more than **2GB RAM** to process, we
report this as a timeout or an OOM (out-of-memory) bug
2016-12-25 04:46:16 +00:00
(examples: [timeouts](https://bugs.chromium.org/p/oss-fuzz/issues/list?can=1&q=%22Crash+Type%3A+Timeout%22),
[OOMs](https://bugs.chromium.org/p/oss-fuzz/issues/list?can=1&q="Crash+Type%3A+Out-of-memory")).
This may or may not be considered as a real bug by the project owners,
but nevertheless we treat all timeouts and OOMs as bugs
since they significantly reduce the efficiency of fuzzing.
2016-12-25 04:52:24 +00:00
Remember that fuzzing is executed with AddressSanitizer or other
2016-12-30 06:13:10 +00:00
sanitizers which introduces a certain overhead in RAM and CPU.
2016-12-25 04:52:24 +00:00
2016-12-25 04:46:16 +00:00
We currently do not have a good way to deduplicate timeout or OOM bugs.
2016-12-30 06:13:10 +00:00
So, we report only one timeout and only one OOM bug per fuzz target.
Once that bug is fixed, we will file another one, and so on.
2016-12-25 04:52:24 +00:00
Currently we do not offer ways to change the memory and time limits.