diff options
author | Ondrej Filip <feela@network.cz> | 2000-05-03 00:31:48 +0200 |
---|---|---|
committer | Ondrej Filip <feela@network.cz> | 2000-05-03 00:31:48 +0200 |
commit | 249fdef7a10ce507bd224ad9be48a86f09d8f21c (patch) | |
tree | d3bdc1e86bfdc616b571df560429d42247fb1d1f /proto | |
parent | c45f48fba5a0904f9c3512c3b42c38183fef348b (diff) | |
download | bird-249fdef7a10ce507bd224ad9be48a86f09d8f21c.tar bird-249fdef7a10ce507bd224ad9be48a86f09d8f21c.zip |
Adding InfTransDelay for outgoing lsa.
Diffstat (limited to 'proto')
-rw-r--r-- | proto/ospf/iface.c | 2 | ||||
-rw-r--r-- | proto/ospf/lsupd.c | 13 | ||||
-rw-r--r-- | proto/ospf/ospf.h | 4 |
3 files changed, 13 insertions, 6 deletions
diff --git a/proto/ospf/iface.c b/proto/ospf/iface.c index 7015f01..c7dfa2f 100644 --- a/proto/ospf/iface.c +++ b/proto/ospf/iface.c @@ -282,7 +282,7 @@ ospf_iface_default(struct ospf_iface *ifa) ifa->an=0; /* FIXME This should respect config */ ifa->cost=COST_D; ifa->rxmtint=RXMTINT_D; - ifa->iftransdelay=IFTRANSDELAY_D; + ifa->inftransdelay=INFTRANSDELAY_D; ifa->priority=PRIORITY_D; ifa->helloint=HELLOINT_D; ifa->deadc=DEADC_D; diff --git a/proto/ospf/lsupd.c b/proto/ospf/lsupd.c index 3390abb..b372a21 100644 --- a/proto/ospf/lsupd.c +++ b/proto/ospf/lsupd.c @@ -105,9 +105,16 @@ flood_lsa(struct ospf_neighbor *n, struct ospf_lsa_header *hn, { u8 *help; struct top_hash_entry *en; - htonlsah(hh,(struct ospf_lsa_header *)(pk+1)); - help=(u8 *)(pk+1); - help+=sizeof(struct ospf_lsa_header); + struct ospf_lsa_header *lh; + u16 age; + + lh=(struct ospf_lsa_header *)(pk+1); + htonlsah(hh,lh); + age=hh->age; + age+=ifa->inftransdelay; + if(age>LSA_MAXAGE) age=LSA_MAXAGE; + lh->age=htons(age); + help=(u8 *)(lh+1); en=ospf_hash_find_header(oa->gr,hh); htonlsab(en->lsa_body,help,hh->type,hh->length); len=hh->length; diff --git a/proto/ospf/ospf.h b/proto/ospf/ospf.h index 40ac691..9ce0be9 100644 --- a/proto/ospf/ospf.h +++ b/proto/ospf/ospf.h @@ -63,7 +63,7 @@ struct ospf_iface { list neigh_list; /* List of neigbours */ u16 cost; /* Cost of iface */ u16 rxmtint; /* number of seconds between LSA retransmissions */ - u16 iftransdelay; /* The estimated number of seconds it takes to + u16 inftransdelay; /* The estimated number of seconds it takes to transmit a Link State Update Packet over this interface. LSAs contained in the update */ u8 priority; /* A router priority for DR election */ @@ -95,7 +95,7 @@ struct ospf_iface { /* Default values for interface parameters */ #define COST_D 10 #define RXMTINT_D 5 -#define IFTRANSDELAY_D 1 +#define INFTRANSDELAY_D 1 #define PRIORITY_D 1 #define HELLOINT_D 10 #define DEADC_D 4 |