summaryrefslogtreecommitdiff
path: root/isisd/isis_pdu.c
diff options
context:
space:
mode:
authorhasso <hasso>2004-09-20 14:55:29 +0000
committerhasso <hasso>2004-09-20 14:55:29 +0000
commita211d65dfda5ae4028ec7bb524f85f3f4bae24c2 (patch)
treea166f2d4d75c55a6eaf3439c91488a2d34eeab16 /isisd/isis_pdu.c
parent12a5cae75ef639e416d82b88d887c5d77d279aa3 (diff)
2004-09-20 LIU Xin <lx at ns.6test.edu.cn>
* isis_dr.c, isis_events.c: Remove hello multiplier usage while scheduling DIS election. * isis_pdu.c: Don't call isis_event_dis_status_change() whenever l[1|2]_desig_is is different from hdr.lan_id.
Diffstat (limited to 'isisd/isis_pdu.c')
-rw-r--r--isisd/isis_pdu.c46
1 files changed, 16 insertions, 30 deletions
diff --git a/isisd/isis_pdu.c b/isisd/isis_pdu.c
index cd685286..bf8c14f7 100644
--- a/isisd/isis_pdu.c
+++ b/isisd/isis_pdu.c
@@ -825,40 +825,26 @@ process_lan_hello (int level, struct isis_circuit *circuit, u_char * ssnpa)
circuit->u.bc.lan_neighs[level - 1]);
}
- switch (level)
- {
- case 1:
- if (memcmp (circuit->u.bc.l1_desig_is, hdr.lan_id, ISIS_SYS_ID_LEN + 1))
- {
- thread_add_event (master, isis_event_dis_status_change, circuit, 0);
- if (adj->dis_record[level-1].dis == ISIS_IS_DIS)
+ if(adj->dis_record[level-1].dis==ISIS_IS_DIS)
+ switch (level)
+ {
+ case 1:
+ if (memcmp (circuit->u.bc.l1_desig_is, hdr.lan_id, ISIS_SYS_ID_LEN + 1))
+ {
+ thread_add_event (master, isis_event_dis_status_change, circuit, 0);
memcpy (&circuit->u.bc.l1_desig_is, hdr.lan_id,
ISIS_SYS_ID_LEN + 1);
- }
- break;
- case 2:
- if (memcmp (circuit->u.bc.l2_desig_is, hdr.lan_id, ISIS_SYS_ID_LEN + 1))
- {
- thread_add_event (master, isis_event_dis_status_change, circuit, 0);
- if (adj->dis_record[level-1].dis == ISIS_IS_DIS)
+ }
+ break;
+ case 2:
+ if (memcmp (circuit->u.bc.l2_desig_is, hdr.lan_id, ISIS_SYS_ID_LEN + 1))
+ {
+ thread_add_event (master, isis_event_dis_status_change, circuit, 0);
memcpy (&circuit->u.bc.l2_desig_is, hdr.lan_id,
ISIS_SYS_ID_LEN + 1);
- }
- break;
- }
-
-#if 0
- /* Old solution: believe the lan-header always
- */
- if (level == 1)
- {
- memcpy (circuit->u.bc.l1_desig_is, hdr.lan_id, ISIS_SYS_ID_LEN + 1);
- }
- else if (level == 2)
- {
- memcpy (circuit->u.bc.l2_desig_is, hdr.lan_id, ISIS_SYS_ID_LEN + 1);
- }
-#endif
+ }
+ break;
+ }
adj->hold_time = hdr.hold_time;
adj->last_upd = time (NULL);