Commit 46134e60 authored by Juliusz Chroboczek's avatar Juliusz Chroboczek Committed by Juliusz Chroboczek

Remove token bucket.

This is no longer useful and complicates the code.
parent b40390cf
...@@ -80,8 +80,6 @@ add_interface(char *ifname, struct interface_conf *if_conf) ...@@ -80,8 +80,6 @@ add_interface(char *ifname, struct interface_conf *if_conf)
strncpy(ifp->name, ifname, IF_NAMESIZE); strncpy(ifp->name, ifname, IF_NAMESIZE);
ifp->conf = if_conf ? if_conf : default_interface_conf; ifp->conf = if_conf ? if_conf : default_interface_conf;
ifp->bucket_time = now.tv_sec;
ifp->bucket = BUCKET_TOKENS_MAX;
ifp->hello_seqno = (random() & 0xFFFF); ifp->hello_seqno = (random() & 0xFFFF);
if(interfaces == NULL) if(interfaces == NULL)
......
...@@ -114,8 +114,6 @@ struct interface { ...@@ -114,8 +114,6 @@ struct interface {
struct buffered_update *buffered_updates; struct buffered_update *buffered_updates;
int num_buffered_updates; int num_buffered_updates;
int update_bufsize; int update_bufsize;
time_t bucket_time;
unsigned int bucket;
time_t last_update_time; time_t last_update_time;
time_t last_specific_update_time; time_t last_specific_update_time;
unsigned short hello_seqno; unsigned short hello_seqno;
......
...@@ -891,31 +891,6 @@ parse_packet(const unsigned char *from, struct interface *ifp, ...@@ -891,31 +891,6 @@ parse_packet(const unsigned char *from, struct interface *ifp,
return; return;
} }
/* Under normal circumstances, there are enough moderation mechanisms
elsewhere in the protocol to make sure that this last-ditch check
should never trigger. But I'm superstitious. */
static int
check_bucket(struct interface *ifp)
{
if(ifp->bucket <= 0) {
int seconds = now.tv_sec - ifp->bucket_time;
if(seconds > 0) {
ifp->bucket = MIN(BUCKET_TOKENS_MAX,
seconds * BUCKET_TOKENS_PER_SEC);
}
/* Reset bucket time unconditionally, in case clock is stepped. */
ifp->bucket_time = now.tv_sec;
}
if(ifp->bucket > 0) {
ifp->bucket--;
return 1;
} else {
return 0;
}
}
static int static int
fill_rtt_message(struct interface *ifp) fill_rtt_message(struct interface *ifp)
{ {
...@@ -949,20 +924,15 @@ flushbuf(struct interface *ifp) ...@@ -949,20 +924,15 @@ flushbuf(struct interface *ifp)
if(ifp->buf.len > 0) { if(ifp->buf.len > 0) {
debugf(" (flushing %d buffered bytes on %s)\n", debugf(" (flushing %d buffered bytes on %s)\n",
ifp->buf.len, ifp->name); ifp->buf.len, ifp->name);
if(check_bucket(ifp)) { DO_HTONS(packet_header + 2, ifp->buf.len);
DO_HTONS(packet_header + 2, ifp->buf.len); fill_rtt_message(ifp);
fill_rtt_message(ifp); rc = babel_send(protocol_socket,
rc = babel_send(protocol_socket, packet_header, sizeof(packet_header),
packet_header, sizeof(packet_header), ifp->buf.buf, ifp->buf.len,
ifp->buf.buf, ifp->buf.len, (struct sockaddr*)&ifp->buf.sin6,
(struct sockaddr*)&ifp->buf.sin6, sizeof(ifp->buf.sin6));
sizeof(ifp->buf.sin6)); if(rc < 0)
if(rc < 0) perror("send");
perror("send");
} else {
fprintf(stderr, "Warning: bucket full, dropping packet to %s.\n",
ifp->name);
}
} }
VALGRIND_MAKE_MEM_UNDEFINED(ifp->buf.buf, ifp->buf.size); VALGRIND_MAKE_MEM_UNDEFINED(ifp->buf.buf, ifp->buf.size);
ifp->buf.len = 0; ifp->buf.len = 0;
...@@ -1194,27 +1164,19 @@ flush_unicast(int dofree) ...@@ -1194,27 +1164,19 @@ flush_unicast(int dofree)
/* Preserve ordering of messages */ /* Preserve ordering of messages */
flushbuf(unicast_neighbour->ifp); flushbuf(unicast_neighbour->ifp);
if(check_bucket(unicast_neighbour->ifp)) { memset(&sin6, 0, sizeof(sin6));
memset(&sin6, 0, sizeof(sin6)); sin6.sin6_family = AF_INET6;
sin6.sin6_family = AF_INET6; memcpy(&sin6.sin6_addr, unicast_neighbour->address, 16);
memcpy(&sin6.sin6_addr, unicast_neighbour->address, 16); sin6.sin6_port = htons(protocol_port);
sin6.sin6_port = htons(protocol_port); sin6.sin6_scope_id = unicast_neighbour->ifp->ifindex;
sin6.sin6_scope_id = unicast_neighbour->ifp->ifindex; DO_HTONS(packet_header + 2, unicast_buffered);
DO_HTONS(packet_header + 2, unicast_buffered); fill_rtt_message(unicast_neighbour->ifp);
fill_rtt_message(unicast_neighbour->ifp); rc = babel_send(protocol_socket,
rc = babel_send(protocol_socket, packet_header, sizeof(packet_header),
packet_header, sizeof(packet_header), unicast_buffer, unicast_buffered,
unicast_buffer, unicast_buffered, (struct sockaddr*)&sin6, sizeof(sin6));
(struct sockaddr*)&sin6, sizeof(sin6)); if(rc < 0)
if(rc < 0) perror("send(unicast)");
perror("send(unicast)");
} else {
fprintf(stderr,
"Warning: bucket full, dropping unicast packet "
"to %s if %s.\n",
format_address(unicast_neighbour->address),
unicast_neighbour->ifp->name);
}
done: done:
VALGRIND_MAKE_MEM_UNDEFINED(unicast_buffer, UNICAST_BUFSIZE); VALGRIND_MAKE_MEM_UNDEFINED(unicast_buffer, UNICAST_BUFSIZE);
......
...@@ -22,9 +22,6 @@ THE SOFTWARE. ...@@ -22,9 +22,6 @@ THE SOFTWARE.
#define MAX_BUFFERED_UPDATES 200 #define MAX_BUFFERED_UPDATES 200
#define BUCKET_TOKENS_MAX 4000
#define BUCKET_TOKENS_PER_SEC 1000
#define MESSAGE_PAD1 0 #define MESSAGE_PAD1 0
#define MESSAGE_PADN 1 #define MESSAGE_PADN 1
#define MESSAGE_ACK_REQ 2 #define MESSAGE_ACK_REQ 2
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment