2014-10-02 17:41:34 +08:00
|
|
|
/*
|
|
|
|
* BIRD Library -- Token Bucket Filter
|
|
|
|
*
|
|
|
|
* (c) 2014 Ondrej Zajicek <santiago@crfreenet.org>
|
|
|
|
* (c) 2014 CZ.NIC z.s.p.o.
|
|
|
|
*
|
|
|
|
* Can be freely distributed and used under the terms of the GNU GPL.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "nest/bird.h"
|
2017-06-01 18:33:20 +08:00
|
|
|
#include "lib/timer.h"
|
2014-10-02 17:41:34 +08:00
|
|
|
|
2017-11-29 00:06:10 +08:00
|
|
|
int
|
|
|
|
tbf_limit(struct tbf *f)
|
2014-10-02 17:41:34 +08:00
|
|
|
{
|
2017-11-29 00:06:10 +08:00
|
|
|
btime delta = current_time() - f->timestamp;
|
2014-10-02 17:41:34 +08:00
|
|
|
|
2017-11-29 00:06:10 +08:00
|
|
|
if (delta > 0)
|
|
|
|
{
|
|
|
|
u64 next = f->count + delta * f->rate;
|
|
|
|
u64 burst = (u64) f->burst << 20;
|
|
|
|
f->count = MIN(next, burst);
|
|
|
|
f->timestamp += delta;
|
|
|
|
}
|
2014-10-02 17:41:34 +08:00
|
|
|
|
2017-11-29 00:06:10 +08:00
|
|
|
if (f->count < 1000000)
|
2014-10-02 17:41:34 +08:00
|
|
|
{
|
2017-11-29 00:06:10 +08:00
|
|
|
f->drop++;
|
|
|
|
return 1;
|
2014-10-02 17:41:34 +08:00
|
|
|
}
|
|
|
|
else
|
2017-11-29 00:06:10 +08:00
|
|
|
{
|
|
|
|
f->count -= 1000000;
|
|
|
|
f->drop = 0;
|
|
|
|
return 0;
|
|
|
|
}
|
2014-10-02 17:41:34 +08:00
|
|
|
}
|