diff options
| author | OGAWA Hirofumi <hirofumi@mail.parknet.co.jp> | 2010-05-24 14:33:11 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2010-05-25 08:07:03 -0700 | 
| commit | f40c396a9ab04eae526990e2b2cef875b424ed4e (patch) | |
| tree | 92b87fb6feb9470f9aa3cacc9344f7907ab2489c | |
| parent | d8521fcc5e0ad3e79bbc4231bb20a6cdc2b50164 (diff) | |
| download | olio-linux-3.10-f40c396a9ab04eae526990e2b2cef875b424ed4e.tar.xz olio-linux-3.10-f40c396a9ab04eae526990e2b2cef875b424ed4e.zip  | |
ratelimit: add ratelimit_state_init()
For now, all users of ratelimit_state allocates it statically, so
DEFINE_RATELIMIT_STATE() is enough.  But, I want to use ratelimit_state
for fs, i.e.  per super_block to suppress too many error reports.
So, this adds ratelimit_state_init() to initialize ratelimite_state
which is dynamically allocated, instead of opencoding.
Signed-off-by: OGAWA Hirofumi <hirofumi@mail.parknet.co.jp>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
| -rw-r--r-- | include/linux/ratelimit.h | 13 | 
1 files changed, 12 insertions, 1 deletions
diff --git a/include/linux/ratelimit.h b/include/linux/ratelimit.h index 668cf1bef03..8f69d09a41a 100644 --- a/include/linux/ratelimit.h +++ b/include/linux/ratelimit.h @@ -2,7 +2,7 @@  #define _LINUX_RATELIMIT_H  #include <linux/param.h> -#include <linux/spinlock_types.h> +#include <linux/spinlock.h>  #define DEFAULT_RATELIMIT_INTERVAL	(5 * HZ)  #define DEFAULT_RATELIMIT_BURST		10 @@ -25,6 +25,17 @@ struct ratelimit_state {  		.burst		= burst_init,				\  	} +static inline void ratelimit_state_init(struct ratelimit_state *rs, +					int interval, int burst) +{ +	spin_lock_init(&rs->lock); +	rs->interval = interval; +	rs->burst = burst; +	rs->printed = 0; +	rs->missed = 0; +	rs->begin = 0; +} +  extern int ___ratelimit(struct ratelimit_state *rs, const char *func);  #define __ratelimit(state) ___ratelimit(state, __func__)  |