提交 77311139 编写于 作者: A Akinobu Mita 提交者: Linus Torvalds

mm/debug-pagealloc.c: use plain __ratelimit() instead of printk_ratelimit()

printk_ratelimit() should not be used, because it shares ratelimiting
state with all other unrelated printk_ratelimit() callsites.
Signed-off-by: NAkinobu Mita <akinobu.mita@gmail.com>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 16fb9512
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
#include <linux/mm.h> #include <linux/mm.h>
#include <linux/page-debug-flags.h> #include <linux/page-debug-flags.h>
#include <linux/poison.h> #include <linux/poison.h>
#include <linux/ratelimit.h>
static inline void set_page_poison(struct page *page) static inline void set_page_poison(struct page *page)
{ {
...@@ -59,6 +60,7 @@ static bool single_bit_flip(unsigned char a, unsigned char b) ...@@ -59,6 +60,7 @@ static bool single_bit_flip(unsigned char a, unsigned char b)
static void check_poison_mem(unsigned char *mem, size_t bytes) static void check_poison_mem(unsigned char *mem, size_t bytes)
{ {
static DEFINE_RATELIMIT_STATE(ratelimit, 5 * HZ, 10);
unsigned char *start; unsigned char *start;
unsigned char *end; unsigned char *end;
...@@ -74,7 +76,7 @@ static void check_poison_mem(unsigned char *mem, size_t bytes) ...@@ -74,7 +76,7 @@ static void check_poison_mem(unsigned char *mem, size_t bytes)
break; break;
} }
if (!printk_ratelimit()) if (!__ratelimit(&ratelimit))
return; return;
else if (start == end && single_bit_flip(*start, PAGE_POISON)) else if (start == end && single_bit_flip(*start, PAGE_POISON))
printk(KERN_ERR "pagealloc: single bit error\n"); printk(KERN_ERR "pagealloc: single bit error\n");
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册