summaryrefslogtreecommitdiffstats
path: root/lib/ratelimit.c
diff options
context:
space:
mode:
authorBorislav Petkov <bp@suse.de>2016-08-02 17:04:04 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2016-08-02 19:35:06 -0400
commit6b1d174b0c27b5de421eda55c2731f32b6bd9852 (patch)
tree3095928a9c579090ef8db9cb6df7125ec1c638db /lib/ratelimit.c
parentb5644a153d2701ffc335cfb9ef49967bd5b6a3c2 (diff)
ratelimit: extend to print suppressed messages on release
Extend the ratelimiting facility to print the amount of suppressed lines when it is being released. This use case is aimed at short-termed, burst-like users for which we want to output the suppressed lines stats only once, after it has been disposed of. For an example, see /dev/kmsg usage in a follow-on patch. Also, change the printk() line we issue on release to not use "callbacks" as it is misleading: we're not suppressing callbacks but printk() calls. This has been separated from a previous patch by Linus. Link: http://lkml.kernel.org/r/20160716061745.15795-2-bp@alien8.de Signed-off-by: Borislav Petkov <bp@suse.de> Cc: Dave Young <dyoung@redhat.com> Cc: Franck Bui <fbui@suse.com> Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Cc: Ingo Molnar <mingo@kernel.org> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Steven Rostedt <rostedt@goodmis.org> Cc: Uwe Kleine-König <u.kleine-koenig@pengutronix.de> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'lib/ratelimit.c')
-rw-r--r--lib/ratelimit.c10
1 files changed, 6 insertions, 4 deletions
diff --git a/lib/ratelimit.c b/lib/ratelimit.c
index 2c5de86460c5..08f8043cac61 100644
--- a/lib/ratelimit.c
+++ b/lib/ratelimit.c
@@ -46,12 +46,14 @@ int ___ratelimit(struct ratelimit_state *rs, const char *func)
46 rs->begin = jiffies; 46 rs->begin = jiffies;
47 47
48 if (time_is_before_jiffies(rs->begin + rs->interval)) { 48 if (time_is_before_jiffies(rs->begin + rs->interval)) {
49 if (rs->missed) 49 if (rs->missed) {
50 printk(KERN_WARNING "%s: %d callbacks suppressed\n", 50 if (!(rs->flags & RATELIMIT_MSG_ON_RELEASE)) {
51 func, rs->missed); 51 pr_warn("%s: %d callbacks suppressed\n", func, rs->missed);
52 rs->missed = 0;
53 }
54 }
52 rs->begin = jiffies; 55 rs->begin = jiffies;
53 rs->printed = 0; 56 rs->printed = 0;
54 rs->missed = 0;
55 } 57 }
56 if (rs->burst && rs->burst > rs->printed) { 58 if (rs->burst && rs->burst > rs->printed) {
57 rs->printed++; 59 rs->printed++;