mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-15 15:04:27 +08:00
bf56cc04ef
Add new rules to detect the cases where sizeof is used in function calls as a argument. Also, for the patch mode third rule should behave same as second rule with arguments reversed. So, change that as well. Signed-off-by: Vaishali Thakkar <vaishali.thakkar@oracle.com> Acked-by: Julia Lawall <julia.lawall@lip6.fr> Signed-off-by: Michal Marek <mmarek@suse.com>
82 lines
1.2 KiB
Plaintext
82 lines
1.2 KiB
Plaintext
/// sizeof when applied to a pointer typed expression gives the size of
|
|
/// the pointer
|
|
///
|
|
// Confidence: High
|
|
// Copyright: (C) 2012 Julia Lawall, INRIA/LIP6. GPLv2.
|
|
// Copyright: (C) 2012 Gilles Muller, INRIA/LiP6. GPLv2.
|
|
// URL: http://coccinelle.lip6.fr/
|
|
// Comments:
|
|
// Options: --no-includes --include-headers
|
|
|
|
virtual org
|
|
virtual report
|
|
virtual context
|
|
virtual patch
|
|
|
|
@depends on patch@
|
|
expression *x;
|
|
expression f;
|
|
expression i;
|
|
type T;
|
|
@@
|
|
|
|
(
|
|
x = <+... sizeof(
|
|
- x
|
|
+ *x
|
|
) ...+>
|
|
|
|
|
f(...,(T)(x),...,sizeof(
|
|
- x
|
|
+ *x
|
|
),...)
|
|
|
|
|
f(...,sizeof(
|
|
- x
|
|
+ *x
|
|
),...,(T)(x),...)
|
|
|
|
|
f(...,(T)(x),...,i*sizeof(
|
|
- x
|
|
+ *x
|
|
),...)
|
|
|
|
|
f(...,i*sizeof(
|
|
- x
|
|
+ *x
|
|
),...,(T)(x),...)
|
|
)
|
|
|
|
@r depends on !patch@
|
|
expression *x;
|
|
expression f;
|
|
expression i;
|
|
position p;
|
|
type T;
|
|
@@
|
|
|
|
(
|
|
*x = <+... sizeof@p(x) ...+>
|
|
|
|
|
*f(...,(T)(x),...,sizeof@p(x),...)
|
|
|
|
|
*f(...,sizeof@p(x),...,(T)(x),...)
|
|
|
|
|
*f(...,(T)(x),...,i*sizeof@p(x),...)
|
|
|
|
|
*f(...,i*sizeof@p(x),...,(T)(x),...)
|
|
)
|
|
|
|
@script:python depends on org@
|
|
p << r.p;
|
|
@@
|
|
|
|
cocci.print_main("application of sizeof to pointer",p)
|
|
|
|
@script:python depends on report@
|
|
p << r.p;
|
|
@@
|
|
|
|
msg = "ERROR: application of sizeof to pointer"
|
|
coccilib.report.print_report(p[0],msg)
|