isci: preallocate requests
[linux-2.6/linux-acpi-2.6/ibm-acpi-2.6.git] / include / linux / ratelimit.h
blob2f007157fab9b9f51370136658b0918f85d15e9a
1 #ifndef _LINUX_RATELIMIT_H
2 #define _LINUX_RATELIMIT_H
4 #include <linux/param.h>
5 #include <linux/spinlock.h>
7 #define DEFAULT_RATELIMIT_INTERVAL (5 * HZ)
8 #define DEFAULT_RATELIMIT_BURST 10
10 struct ratelimit_state {
11 spinlock_t lock; /* protect the state */
13 int interval;
14 int burst;
15 int printed;
16 int missed;
17 unsigned long begin;
20 #define DEFINE_RATELIMIT_STATE(name, interval_init, burst_init) \
22 struct ratelimit_state name = { \
23 .lock = __SPIN_LOCK_UNLOCKED(name.lock), \
24 .interval = interval_init, \
25 .burst = burst_init, \
28 static inline void ratelimit_state_init(struct ratelimit_state *rs,
29 int interval, int burst)
31 spin_lock_init(&rs->lock);
32 rs->interval = interval;
33 rs->burst = burst;
34 rs->printed = 0;
35 rs->missed = 0;
36 rs->begin = 0;
39 extern struct ratelimit_state printk_ratelimit_state;
41 extern int ___ratelimit(struct ratelimit_state *rs, const char *func);
42 #define __ratelimit(state) ___ratelimit(state, __func__)
44 #ifdef CONFIG_PRINTK
46 #define WARN_ON_RATELIMIT(condition, state) \
47 WARN_ON((condition) && __ratelimit(state))
49 #define __WARN_RATELIMIT(condition, state, format...) \
50 ({ \
51 int rtn = 0; \
52 if (unlikely(__ratelimit(state))) \
53 rtn = WARN(condition, format); \
54 rtn; \
57 #define WARN_RATELIMIT(condition, format...) \
58 ({ \
59 static DEFINE_RATELIMIT_STATE(_rs, \
60 DEFAULT_RATELIMIT_INTERVAL, \
61 DEFAULT_RATELIMIT_BURST); \
62 __WARN_RATELIMIT(condition, &_rs, format); \
65 #else
67 #define WARN_ON_RATELIMIT(condition, state) \
68 WARN_ON(condition)
70 #define __WARN_RATELIMIT(condition, state, format...) \
71 ({ \
72 int rtn = WARN(condition, format); \
73 rtn; \
76 #define WARN_RATELIMIT(condition, format...) \
77 ({ \
78 int rtn = WARN(condition, format); \
79 rtn; \
82 #endif
84 #endif /* _LINUX_RATELIMIT_H */