Better common router-id handling.
diff --git a/ospf6d/ChangeLog b/ospf6d/ChangeLog
index 3142bea..17da81d 100644
--- a/ospf6d/ChangeLog
+++ b/ospf6d/ChangeLog
@@ -1,3 +1,9 @@
+2004-10-11 Hasso Tepper <hasso at quagga.net>
+
+ * osp6_top.c, ospf6_top.h: Better handling for router-id. If we use
+ common one, don't output it into configuration - only statically
+ configured one.
+
2004-10-10 Paul Jakma <paul@dishone.st>
* Makefile.am: fix listing of ospf_snmp.c in noinst_HEADERS
diff --git a/ospf6d/ospf6_top.c b/ospf6d/ospf6_top.c
index 9fd3264..b0fe5ca 100644
--- a/ospf6d/ospf6_top.c
+++ b/ospf6d/ospf6_top.c
@@ -311,7 +311,10 @@
return CMD_SUCCESS;
}
- o->router_id = router_id;
+ o->router_id_static = router_id;
+ if (o->router_id == 0)
+ o->router_id = router_id;
+
return CMD_SUCCESS;
}
@@ -618,9 +621,10 @@
if (CHECK_FLAG (ospf6->flag, OSPF6_DISABLED))
return CMD_SUCCESS;
- inet_ntop (AF_INET, &ospf6->router_id, router_id, sizeof (router_id));
+ inet_ntop (AF_INET, &ospf6->router_id_static, router_id, sizeof (router_id));
vty_out (vty, "router ospf6%s", VNL);
- vty_out (vty, " router-id %s%s", router_id, VNL);
+ if (ospf6->router_id_static != 0)
+ vty_out (vty, " router-id %s%s", router_id, VNL);
ospf6_redistribute_config_write (vty);
ospf6_area_config_write (vty);
diff --git a/ospf6d/ospf6_top.h b/ospf6d/ospf6_top.h
index 9fd0395..eae20e6 100644
--- a/ospf6d/ospf6_top.h
+++ b/ospf6d/ospf6_top.h
@@ -30,6 +30,9 @@
/* my router id */
u_int32_t router_id;
+ /* static router id */
+ u_int32_t router_id_static;
+
/* start time */
struct timeval starttime;