diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2015-02-19 13:23:41 +0100 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2015-02-21 23:45:08 +0100 |
commit | 52a1a55f3014e0a9ad2461e2e17896ee27ba794d (patch) | |
tree | cddf3562467f07a6bbf0522f522b760ec4f113c2 /tools/coverity.c | |
parent | 7a459be8e7551cd1a00a7f4e9f28a9d3ec1fa337 (diff) | |
download | ffmpeg-52a1a55f3014e0a9ad2461e2e17896ee27ba794d.tar.gz |
Add coverity model file
The comments/header of the file are taken from qemu, they provide some
basic documentation
The code from the examples
Ive no means to test this except uploading to coverity for FFmpeg, so each
commit should stay simple, making it easy to revert.
Also please help making this a useful and effective file by contributing
changes/code to it and reviewing contributions.
I am happy to upload changes but i cannot really maintain this (alone) as
i cannot test changes.
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'tools/coverity.c')
-rw-r--r-- | tools/coverity.c | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/tools/coverity.c b/tools/coverity.c new file mode 100644 index 0000000000..80fc1c2ad5 --- /dev/null +++ b/tools/coverity.c @@ -0,0 +1,42 @@ +/* Coverity Scan model +* +* Copyright (C) 2014 Red Hat, Inc. +* +* Authors: +* Markus Armbruster <armbru@redhat.com> +* Paolo Bonzini <pbonzini@redhat.com> +* +* This work is licensed under the terms of the GNU GPL, version 2 or, at your +* option, any later version. See the COPYING file in the top-level directory. +*/ +/* +* This is the source code for our Coverity user model file. The +* purpose of user models is to increase scanning accuracy by explaining +* code Coverity can't see (out of tree libraries) or doesn't +* sufficiently understand. Better accuracy means both fewer false +* positives and more true defects. Memory leaks in particular. +* +* - A model file can't import any header files. Some built-in primitives are +* available but not wchar_t, NULL etc. +* - Modeling doesn't need full structs and typedefs. Rudimentary structs +* and similar types are sufficient. +* - An uninitialized local variable signifies that the variable could be +* any value. +* +* The model file must be uploaded by an admin in the analysis settings of +* https://scan.coverity.com/projects/54 +* +* above text is based on https://github.com/qemu/qemu/blob/master/scripts/coverity-model.c +*/ + +#define NULL (void *)0 + +// Based on https://scan.coverity.com/models +void *av_malloc(size_t size) { + int has_memory; + __coverity_negative_sink__(size); + if(has_memory) + return __coverity_alloc__(size); + else + return 0; +} |