Dave Young | 717115e | 2008-07-25 01:45:58 -0700 | [diff] [blame] | 1 | #ifndef _LINUX_RATELIMIT_H |
| 2 | #define _LINUX_RATELIMIT_H |
Dave Young | 717115e | 2008-07-25 01:45:58 -0700 | [diff] [blame] | 3 | |
Ingo Molnar | 979f693 | 2009-09-22 14:44:11 +0200 | [diff] [blame] | 4 | #include <linux/param.h> |
| 5 | #include <linux/spinlock_types.h> |
| 6 | |
| 7 | #define DEFAULT_RATELIMIT_INTERVAL (5 * HZ) |
| 8 | #define DEFAULT_RATELIMIT_BURST 10 |
Dave Young | 717115e | 2008-07-25 01:45:58 -0700 | [diff] [blame] | 9 | |
| 10 | struct ratelimit_state { |
Ingo Molnar | 979f693 | 2009-09-22 14:44:11 +0200 | [diff] [blame] | 11 | spinlock_t lock; /* protect the state */ |
| 12 | |
| 13 | int interval; |
| 14 | int burst; |
| 15 | int printed; |
| 16 | int missed; |
| 17 | unsigned long begin; |
Dave Young | 717115e | 2008-07-25 01:45:58 -0700 | [diff] [blame] | 18 | }; |
| 19 | |
Ingo Molnar | 979f693 | 2009-09-22 14:44:11 +0200 | [diff] [blame] | 20 | #define DEFINE_RATELIMIT_STATE(name, interval_init, burst_init) \ |
| 21 | \ |
| 22 | struct ratelimit_state name = { \ |
| 23 | .lock = __SPIN_LOCK_UNLOCKED(name.lock), \ |
| 24 | .interval = interval_init, \ |
| 25 | .burst = burst_init, \ |
| 26 | } |
Dave Young | 717115e | 2008-07-25 01:45:58 -0700 | [diff] [blame] | 27 | |
| 28 | extern int __ratelimit(struct ratelimit_state *rs); |
Ingo Molnar | 979f693 | 2009-09-22 14:44:11 +0200 | [diff] [blame] | 29 | |
| 30 | #endif /* _LINUX_RATELIMIT_H */ |