X-Git-Url: http://ftp.safe.ca/?a=blobdiff_plain;f=lib%2Fratelimit.c;h=027a03f4c56d4059b23560c984f5699e44e069d8;hb=e0c70b80786296d4f3c35ebe0d52591cebf8f916;hp=5551731ae1d49319ac0c4dc77c417a4feccddf44;hpb=3fff4c42bd0a89869a0eb1e7874cc06ffa4aa0f5;p=safe%2Fjmp%2Flinux-2.6 diff --git a/lib/ratelimit.c b/lib/ratelimit.c index 5551731..027a03f 100644 --- a/lib/ratelimit.c +++ b/lib/ratelimit.c @@ -16,11 +16,16 @@ /* * __ratelimit - rate limiting * @rs: ratelimit_state data + * @func: name of calling function * - * This enforces a rate limit: not more than @rs->ratelimit_burst callbacks - * in every @rs->ratelimit_jiffies + * This enforces a rate limit: not more than @rs->burst callbacks + * in every @rs->interval + * + * RETURNS: + * 0 means callbacks will be suppressed. + * 1 means go ahead and do it. */ -int __ratelimit(struct ratelimit_state *rs) +int ___ratelimit(struct ratelimit_state *rs, const char *func) { unsigned long flags; int ret; @@ -35,7 +40,7 @@ int __ratelimit(struct ratelimit_state *rs) * the entity that is holding the lock already: */ if (!spin_trylock_irqsave(&rs->lock, flags)) - return 1; + return 0; if (!rs->begin) rs->begin = jiffies; @@ -43,7 +48,7 @@ int __ratelimit(struct ratelimit_state *rs) if (time_is_before_jiffies(rs->begin + rs->interval)) { if (rs->missed) printk(KERN_WARNING "%s: %d callbacks suppressed\n", - __func__, rs->missed); + func, rs->missed); rs->begin = 0; rs->printed = 0; rs->missed = 0; @@ -59,4 +64,4 @@ int __ratelimit(struct ratelimit_state *rs) return ret; } -EXPORT_SYMBOL(__ratelimit); +EXPORT_SYMBOL(___ratelimit);