scripts/coccinelle: add error-use-after-free.cocci
Add script to find and fix trivial use-after-free of Error objects. How to use: spatch --sp-file scripts/coccinelle/error-use-after-free.cocci \ --macro-file scripts/cocci-macro-file.h --in-place \ --no-show-diff ( FILES... | --use-gitgrep . ) Signed-off-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com> Message-Id: <20200324153630.11882-2-vsementsov@virtuozzo.com> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Reviewed-by: Markus Armbruster <armbru@redhat.com> [Pastos in commit message and comment fixed, globbing in MAINTAINERS expanded] Signed-off-by: Markus Armbruster <armbru@redhat.com>
This commit is contained in:
parent
146aa0f104
commit
d1d3a99795
@ -2053,6 +2053,11 @@ F: include/qemu/error-report.h
|
|||||||
F: qapi/error.json
|
F: qapi/error.json
|
||||||
F: util/error.c
|
F: util/error.c
|
||||||
F: util/qemu-error.c
|
F: util/qemu-error.c
|
||||||
|
F: scripts/coccinelle/err-bad-newline.cocci
|
||||||
|
F: scripts/coccinelle/error-use-after-free.cocci
|
||||||
|
F: scripts/coccinelle/error_propagate_null.cocci
|
||||||
|
F: scripts/coccinelle/remove_local_err.cocci
|
||||||
|
F: scripts/coccinelle/use-error_fatal.cocci
|
||||||
|
|
||||||
GDB stub
|
GDB stub
|
||||||
M: Alex Bennée <alex.bennee@linaro.org>
|
M: Alex Bennée <alex.bennee@linaro.org>
|
||||||
|
52
scripts/coccinelle/error-use-after-free.cocci
Normal file
52
scripts/coccinelle/error-use-after-free.cocci
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
// Find and fix trivial use-after-free of Error objects
|
||||||
|
//
|
||||||
|
// Copyright (c) 2020 Virtuozzo International GmbH.
|
||||||
|
//
|
||||||
|
// This program is free software; you can redistribute it and/or
|
||||||
|
// modify it under the terms of the GNU General Public License as
|
||||||
|
// published by the Free Software Foundation; either version 2 of the
|
||||||
|
// License, or (at your option) any later version.
|
||||||
|
//
|
||||||
|
// This program is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU General Public License for more details.
|
||||||
|
//
|
||||||
|
// You should have received a copy of the GNU General Public License
|
||||||
|
// along with this program. If not, see
|
||||||
|
// <http://www.gnu.org/licenses/>.
|
||||||
|
//
|
||||||
|
// How to use:
|
||||||
|
// spatch --sp-file scripts/coccinelle/error-use-after-free.cocci \
|
||||||
|
// --macro-file scripts/cocci-macro-file.h --in-place \
|
||||||
|
// --no-show-diff ( FILES... | --use-gitgrep . )
|
||||||
|
|
||||||
|
@ exists@
|
||||||
|
identifier fn, fn2;
|
||||||
|
expression err;
|
||||||
|
@@
|
||||||
|
|
||||||
|
fn(...)
|
||||||
|
{
|
||||||
|
<...
|
||||||
|
(
|
||||||
|
error_free(err);
|
||||||
|
+ err = NULL;
|
||||||
|
|
|
||||||
|
error_report_err(err);
|
||||||
|
+ err = NULL;
|
||||||
|
|
|
||||||
|
error_reportf_err(err, ...);
|
||||||
|
+ err = NULL;
|
||||||
|
|
|
||||||
|
warn_report_err(err);
|
||||||
|
+ err = NULL;
|
||||||
|
|
|
||||||
|
warn_reportf_err(err, ...);
|
||||||
|
+ err = NULL;
|
||||||
|
)
|
||||||
|
... when != err = NULL
|
||||||
|
when != exit(...)
|
||||||
|
fn2(..., err, ...)
|
||||||
|
...>
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user