Commit 249e7ced authored by Easwar Hariharan's avatar Easwar Hariharan Committed by Andrew Morton
Browse files

coccinelle: misc: secs_to_jiffies: implement context and report modes

As requested by Ricardo and Jakub, implement report and context modes for
the secs_to_jiffies Coccinelle script.  While here, add the option to look
for opportunities to use secs_to_jiffies() in headers.

Link: https://lkml.kernel.org/r/20250703225145.152288-1-eahariha@linux.microsoft.com


Signed-off-by: default avatarEaswar Hariharan <eahariha@linux.microsoft.com>
Closes: https://lore.kernel.org/all/20250129-secs_to_jiffles-v1-1-35a5e16b9f03@chromium.org/
Closes: https://lore.kernel.org/all/20250221162107.409ae333@kernel.org/


Tested-by: default avatarRicardo Ribalda <ribalda@chromium.org>
Cc: Julia Lawall <julia.lawall@inria.fr>
Cc: Nicolas Palix <nicolas.palix@imag.fr>
Cc: Jakub Kicinski <kuba@kernel.org>
Cc: Ricardo Ribalda <ribalda@chromium.org>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
parent ee13240c
Loading
Loading
Loading
Loading
+44 −5
Original line number Diff line number Diff line
@@ -7,26 +7,65 @@
// Confidence: High
// Copyright: (C) 2024 Easwar Hariharan, Microsoft
// Keywords: secs, seconds, jiffies
//
// Options: --include-headers

virtual patch
virtual report
virtual context

@depends on patch@ constant C; @@
@pconst depends on patch@ constant C; @@

- msecs_to_jiffies(C * 1000)
+ secs_to_jiffies(C)

@depends on patch@ constant C; @@
@pconstms depends on patch@ constant C; @@

- msecs_to_jiffies(C * MSEC_PER_SEC)
+ secs_to_jiffies(C)

@depends on patch@ expression E; @@
@pexpr depends on patch@ expression E; @@

- msecs_to_jiffies(E * 1000)
+ secs_to_jiffies(E)

@depends on patch@ expression E; @@
@pexprms depends on patch@ expression E; @@

- msecs_to_jiffies(E * MSEC_PER_SEC)
+ secs_to_jiffies(E)

@r depends on report && !patch@
constant C;
expression E;
position p;
@@

(
  msecs_to_jiffies(C@p * 1000)
|
  msecs_to_jiffies(C@p * MSEC_PER_SEC)
|
  msecs_to_jiffies(E@p * 1000)
|
  msecs_to_jiffies(E@p * MSEC_PER_SEC)
)

@c depends on context && !patch@
constant C;
expression E;
@@

(
* msecs_to_jiffies(C * 1000)
|
* msecs_to_jiffies(C * MSEC_PER_SEC)
|
* msecs_to_jiffies(E * 1000)
|
* msecs_to_jiffies(E * MSEC_PER_SEC)
)

@script:python depends on report@
p << r.p;
@@

coccilib.report.print_report(p[0], "WARNING opportunity for secs_to_jiffies()")