void rip_dev_add_iface(char *);
struct rip_patt *rip_get_iface(void);
-#define THIS_PROTO ((struct rip_proto *) this_proto)
+#define RIP_PROTO ((struct rip_proto_config *) this_proto)
CF_DECLS
CF_ADDTO(proto, rip_proto '}')
rip_proto_start: proto_start RIP {
- this_proto = proto_new(&proto_rip, sizeof(struct rip_proto));
- rip_init_instance(this_proto);
+ RIP_PROTO = proto_new(&proto_rip, sizeof(struct rip_proto));
+ rip_init_instance(RIP_PROTO);
}
;
rip_proto:
rip_proto_start proto_name '{'
| rip_proto proto_item ';'
- | rip_proto INFINITY expr ';' { THIS_PROTO->infinity = $3; }
- | rip_proto PORT expr ';' { THIS_PROTO->port = $3; }
- | rip_proto PERIOD expr ';' { THIS_PROTO->period = $3; }
- | rip_proto GARBAGETIME expr ';' { THIS_PROTO->garbage_time = $3; }
+ | rip_proto INFINITY expr ';' { RIP_PROTO->infinity = $3; }
+ | rip_proto PORT expr ';' { RIP_PROTO->port = $3; }
+ | rip_proto PERIOD expr ';' { RIP_PROTO->period = $3; }
+ | rip_proto GARBAGETIME expr ';' { RIP_PROTO->garbage_time = $3; }
| rip_proto rip_iface_list ';'
;
struct rip_patt *k = cfg_alloc(sizeof(struct rip_patt));
k->i.pattern = cfg_strdup(n);
- add_tail(&THIS_PROTO->iface_list, &k->i.n);
+ add_tail(&RIP_PROTO->iface_list, &k->i.n);
}
struct rip_patt *
rip_get_iface(void)
{
- struct rip_patt *k = TAIL(THIS_PROTO->iface_list);
+ struct rip_patt *k = TAIL(RIP_PROTO->iface_list);
if (!k)
cf_error( "This cannot happen" );
return k;
#include "rip.h"
+#define P ((struct rip_proto *) p)
+#define P_CF ((struct rip_proto_config *)p->cf)
+#define E ((struct rip_entry *) e)
+
static void
rip_reply(struct proto *p)
{
if (ipa_equal(e->whotoldme, s->daddr)) {
DBG( "(split horizont)" );
/* FIXME: should we do it in all cases? */
- packet->block[i].metric = P->infinity;
+ packet->block[i].metric = P_CF->infinity;
}
ipa_hton( packet->block[i].network );
ipa_hton( packet->block[i].netmask );
n = net_get( &master_table, 0, b->network, ipa_mklen( b->netmask )); /* FIXME: should verify that it really is netmask */
r = rte_get_temp(a);
r->u.rip.metric = ntohl(b->metric) + i->metric;
- if (r->u.rip.metric > P->infinity) r->u.rip.metric = P->infinity;
+ if (r->u.rip.metric > P_CF->infinity) r->u.rip.metric = P_CF->infinity;
r->u.rip.tag = ntohl(b->tag);
r->net = n;
r->pflags = 0; /* Here go my flags */
ip_addr network = block->network;
CHK_MAGIC;
- if ((!metric) || (metric > P->infinity)) {
+ if ((!metric) || (metric > P_CF->infinity)) {
log( L_WARN "Got metric %d from %I", metric, whotoldme );
return;
}
rip_sendto( p, whotoldme, port, NULL ); /* no broadcast */
break;
case RIPCMD_RESPONSE: DBG( "*** Rtable from %I\n", whotoldme );
- if (port != P->port) {
+ if (port != P_CF->port) {
log( L_ERR "%I send me routing info from port %d", whotoldme, port );
#if 0
return 0;
rte = SKIP_BACK( struct rte, u.rip.garbage, e );
DBG( "Garbage: " ); rte_dump( rte );
- if (now - rte->lastmod > P->garbage_time) {
+ if (now - rte->lastmod > P_CF->garbage_time) {
debug( "RIP: entry is too old: " ); rte_dump( rte );
rte_discard(rte);
}
P->timer = tm_new( p->pool );
P->timer->data = p;
P->timer->randomize = 5;
- P->timer->recurrent = P->period;
+ P->timer->recurrent = P_CF->period;
P->timer->hook = rip_timer;
tm_start( P->timer, 5 );
rif = new_iface(p, NULL, 0); /* Initialize dummy interface */
rif->sock = sk_new( p->pool );
rif->sock->type = want_multicast?SK_UDP_MC:SK_UDP;
- rif->sock->sport = P->port;
+ rif->sock->sport = P_CF->port;
rif->sock->rx_hook = rip_rx;
rif->sock->data = rif;
rif->sock->rbsize = 10240;
rif->sock->tx_hook = rip_tx;
rif->sock->err_hook = rip_tx_err;
rif->sock->daddr = IPA_NONE;
- rif->sock->dport = P->port;
+ rif->sock->dport = P_CF->port;
rif->sock->ttl = 1; /* FIXME: care must be taken not to send requested responses from this socket */
if (want_multicast)
}
if (new) {
struct rip_interface *rif;
- struct iface_patt *k = iface_patt_match(&P->iface_list, new);
+ struct iface_patt *k = iface_patt_match(&P_CF->iface_list, new);
if (!k) return; /* We are not interested in this interface */
DBG("adding interface %s\n", new->name );
p->rte_insert = rip_rte_insert;
p->rte_remove = rip_rte_remove;
- P->infinity = 16;
- P->port = 520;
- P->period = 30;
- P->garbage_time = 120+180;
+#warning FIXME: this is almost certianly wrong, I need to setup config elsewhere
+ P_CF->infinity = 16;
+ P_CF->port = 520;
+ P_CF->period = 30;
+ P_CF->garbage_time = 120+180;
- init_list(&P->iface_list);
+ init_list(&P_CF->iface_list);
}
static void