blob: 1d7a4a1e94ac194a2cc7d6af8ff5936efcc6003b [file] [log] [blame]
Paul Jakma2518efd2006-08-27 06:49:29 +000012006-08-25 Paul Jakma <paul.jakma@sun.com>
2
3 * (general) Bug #134. Be more robust to backward time changes,
4 use the newly added libzebra time functions.
5 In most cases: recent_time -> recent_relative_time()
6 gettimeofday -> quagga_gettime (QUAGGA_CLK_MONOTONIC, ..)
7 time -> quagga_time.
8 (ospf_make_md5_digest) time() call deliberately not changed.
9 (ospf_external_lsa_refresh) remove useless gettimeofday, LSA
10 tv_orig time was already set in ospf_lsa_new, called via
11 ospf_external_lsa_new.
12
Paul Jakmaba122e72006-08-27 06:24:34 +0000132006-08-04 Paul Jakma <paul.jakma@sun.com>
14
15 * ospf_lsdb.c: (ospf_lsdb_delete_entry) new function, consolidate
16 exact same functionality replicated in other functions.
17 (ospf_lsdb_add) Strip out code by using ospf_lsdb_delete_entry.
18 (ospf_lsdb_delete) ditto.
19 (ospf_lsdb_delete_all) ditto.
20
Paul Jakma8dd24ee2006-08-27 06:29:30 +0000212006-08-03 Paul Jakma <paul.jakma@sun.com>
22
23 * ospf_packet.c: (ospf_make_db_desc) Unset the DD More bit
24 after constructing the packet, if appropriate.
25 (ospf_db_desc_proc) Speed up Exchange, slave should raise
26 ExchangeDone earlier, as RFC mandates, by forming its reply
27 before deciding whether both sides are done, avoids a
28 needless round of empty DD packet exchanges at the end of
29 Exchange, hence speeding up ExchangeDone.
Paul Jakmaf0894cf2006-08-27 06:40:04 +000030 Implement draft-ogier-ospf-dbex-opt DB-exchange optimisation.
Paul Jakma8dd24ee2006-08-27 06:29:30 +000031 (ospf_db_desc) use UNSET_FLAG macro.
32
Andrew J. Schorr16700082006-07-27 22:29:06 +0000332006-07-27 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
34
35 * ospfd.c: (ospf_router_id_update) Fix and document the algorithm for
36 selecting the router ID: if there is not a statically configured ID,
37 then stick to the most recent value to avoid disruptive changes.
38 This should fix bug #288.
39
Paul Jakma1fe6ed32006-07-26 09:37:26 +0000402006-07-26 Paul Jakma <paul.jakma@sun.com>
41
42 * ospf_lsa.{c,h}: (ospf_lsa_unlock) Change to take a double pointer
43 to the LSA to be 'unlocked', so that, if the LSA is freed, the
44 callers pointer to the LSA can be NULLed out, allowing any further
45 use of that pointer to provoke a crash sooner rather than later.
46 * ospf_*.c: (general) Adjust callers of ospf_lsa_unlock to match
47 previous. Try annotate 'locking' somewhat to show which 'locks'
48 are protecting what LSA reference, if not obvious.
49 * ospf_opaque.c: (ospf_opaque_lsa_install) Trivial: remove useless
50 goto, replace with return.
51 * ospf_packet.c: (ospf_make_ls_ack) Trivial: merge two list loops,
52 the dual-loop predated the delete-safe list-loop macro.
53
Paul Jakma3fed4162006-07-25 20:44:12 +0000542006-07-25 Paul Jakma <paul.jakma@sun.com>
55
56 * ospf_neigbor.h: (struct ospf_neighbor) Add some additional
57 neighbour state statistics fields, timestamps for progressive
58 and regressive state changes, and pointer to event string
59 for the latter state change.
60 * ospf_nsm.c: (nsm_notice_state_change) Update new state changs
61 history as required.
62 * ospf_vty.c: (show_ip_ospf_neighbor_detail_sub) Print out above
63 new per-neighbour state change stats.
64
Paul Jakma539e1522006-07-11 17:49:22 +0000652006-07-10 Paul Jakma <paul.jakma@sun.com>
66
67 * ospf_nsm.c: (nsm_change_state) call nsm_clear_adj for all
68 adjacency losses, hence removing need for nsm_reset_nbr.
69 (nsm_reset_nbr) kill it, clear_adj in previous does fine.
70 (nsm_kill_nbr,nsm_start) remove nsm_reset_nbr call.
71 (ospf_nsm_event) Allow NSM function to be NULL, this along with
72 removal of nsm_reset_nbr, allows a bunch of now useless functiosn
73 to be removed.
74 Remove some useless variables.
75 (nsm_ignore) now useless, remove.
76 (nsm_bad_ls_req) ditto
77 (nsm_seq_number_mismatch) "
78 (nsm_oneway_received) "
79 (nsm_inactivity_timer) "
80 (nsm_ll_down) "
81 (NSM) replace removed action functions with NULL.
Paul Jakma3d63f382006-07-11 17:52:53 +000082 (nsm_notice_state_changes) Move state change logging code to new
83 func to declutter nsm_change_state and ospf_nsm_event.
84 Log event with AdjChange, it's useful to know.
85 (nsm_change_state) move adjchange and snmp logging to previous.
86 (ospf_nsm_event) call nsm_notice_state_changes from here.
87 Move the debug message to entry of function, so it gets out
88 even if something goes wrong.
Paul Jakma90c33172006-07-11 17:57:25 +000089 Record state change timestamp and event in nbr struct.
90 * ospf_neighbor.h: (struct ospf_neighbor) Add fields to record
91 timestamp of last NSM change and event.
92 * ospf_vty.c: (show_ip_ospf_neighbor_detail_sub) Print
93 last state change timestamp and event, if available.
Paul Jakma539e1522006-07-11 17:49:22 +000094
Andrew J. Schorr13cd3dc2006-07-11 01:50:30 +0000952006-07-10 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
96
97 * ospf_packet.c: (ospf_hello) Improve NetworkMask mismatch warning
98 message to include interface name and conflicting prefix lengths.
99
Paul Jakma1f2c2742006-07-10 07:45:13 +00001002006-07-07 Paul Jakma <paul.jakma@sun.com>
101
102 * ospf_nsm.h: Add a NSM_Deleted neighbour state, to act as dummy
103 state indicating the neighbour is to be deleted.
104 * ospf_nsm.c: (general) Use the NSM_Deleted state to delete
105 neighbours, thus allowing code to be slightly more obvious
106 in its flow.
107 (nsm_timer_set) Add NSM_Deleted. Add another timer the code
108 missed.
109 (nsm_kill_nbr) No need for special case call to nsm_change_state
110 anymore.
111 Make the assert and error-handling for same case more readable
112 (Andrew Schorr)
113 Remove the call to ospf_nbr_delete, nsm_change_state can do
114 this generally now via NSM_Deleted.
115 (struct ... NSM) Add the dummy NSM_Deleted state, the 3 events
116 that can lead to nsm_kill_nbr all now transition the NBR to
117 NSM_Deleted and the general change_state function can be left
118 to do the work.
119 (ospf_nsm_event) Special casing of events and early-return can
120 be removed now.
121 On transition into Deleted, delete the nbr.
122 * ospf_dump.c: (ospf_nsm_state_msg) Add Deleted.
123
Paul Jakmaaa2737a2006-07-06 11:12:39 +00001242006-07-06 Paul Jakma <paul.jakma@sun.com>
125
126 * ospf_nsm.c: (ospf_nsm_event) LLDown event also results in nbr
127 being deleted, requires early-return too. Likely explains
128 some crash reports after interface events.
129
Paul Jakmaf7a76ab2006-07-04 13:57:49 +00001302006-07-04 Paul Jakma <paul.jakma@sun.com>
131
132 * ospf_nsm.c: (general) Various small cleanups from Andrew's
133 review of last set of patches.
134 (nsm_timer_set) Loading, Full and default can share
135 same code too.
136 (nsm_should_adj) Can just be one big OR.
137 (nsm_twoway_received) Collapse into return statement.
138
Paul Jakmad7b0fb62006-07-04 13:35:24 +00001392006-07-02 Paul Jakma <paul.jakma@sun.com>
140
141 * ospf_nsm.c: (nsm_should_adj) New function, just consolidate the
142 10.4 adjacency check from nsm_twoway_received/nsm_adj_ok.
143 (nsm_twoway_received/nsm_adj_ok) Use former.
Paul Jakmad1b1cd82006-07-04 13:50:44 +0000144 (nsm_clear_adj) clear adjacency related state for a
145 neighbour, needed for some state changes from > ExStart down
146 to ExStart or less, which need not go through nsm_reset_nbr.
147 (nsm_reset_nbr) move code to former. Should be static.
Paul Jakmaba0beb42006-07-04 13:44:19 +0000148 (ospf_nsm_event) Don't allow action functions to change
149 next_state if the NSM tables do not indicate next_state is
150 conditional, log warning if one tries - existing code
151 appears fine though.
Paul Jakmad1b1cd82006-07-04 13:50:44 +0000152 Remove long dead code.
153 Use nsm_clear_adj for state changes that take down
154 adjacencies to TwoWay/ExStart.
Paul Jakmae55dd532006-07-04 13:46:14 +0000155 (nsm_timer_set) ls_req timer should be OFF in early states.
156 Compact several identical sections.
157 Set inactivity timer to OFF for Down, for documentary
158 purposes.
Paul Jakmad1b1cd82006-07-04 13:50:44 +0000159 (nsm_kill_nbr) Oops, action function shouldn't try return
160 1 for error.
Paul Jakma5db95bc2006-07-04 13:52:29 +0000161 * ospf_lsa.c: (ospf_translated_nssa_refresh) CID #13.
Paul Jakmad7b0fb62006-07-04 13:35:24 +0000162
Andrew J. Schorr1c066bf2006-06-30 16:53:47 +00001632006-06-30 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
164
165 * ospf_vty.c: (show_ip_ospf_neighbor_id) Should show all instances
166 of that neighbor (since it may appear on multiple interfaces)
167 instead of bailing out after showing the first match.
168
Andrew J. Schorr76947872006-06-30 03:21:05 +00001692006-06-29 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
170
171 * ospf_nsm.c: (nsm_twoway_received) When deciding whether to
172 change from state Init to ExStart, the test for whether the
173 neighboring router is DR or BDR should be against the
174 local router's notion of DR/BDR, not the neighbor's view.
175
Andrew J. Schorrd7e60dd2006-06-29 20:20:52 +00001762006-06-28 Erik Muller <erikm@internap.com>
177
178 * ospfd.h: Define 2 new struct ospf config flags:
179 OSPF_LOG_ADJACENCY_CHANGES and OSPF_LOG_ADJACENCY_DETAIL
180 * ospf_nsm.c (nsm_change_state): Log adjacency changes if
181 requested.
182 * ospf_vty.c (ospf_log_adjacency_changes): New command function
183 to implement ospf subcommand "log-adjacency-changes [detail]".
184 (no_ospf_log_adjacency_changes) Turn off log-adjacency-changes.
185 (show_ip_ospf) Show whether adjacency changes are logged.
186 (ospf_config_write) Add "log-adjacency-changes [detail]" to config.
187 (ospf_vty_init) Add ospf_log_adjacency_changes and
188 no_ospf_log_adjacency_changes.
189
Paul Jakma9560fa82006-06-26 12:50:06 +00001902006-06-26 Paul Jakma <paul.jakma@sun.com>
191
192 * ospf_abr.c: (general) NSSA translate-candidate ABRs need to
193 be ASBRs, or other routers may rightfully refuse to install
194 translated type-5s LSAs. reported by dendroot@gmail.com.
195 (ospf_abr_nssa_check_status) Detect change in translator
196 state when ABR, and inc/dec redistribute count as when we
197 leave/enter the disabled state - so that translate-enabled
198 ABR properly sets ASBR bit on non-NSSA areas.
199 Run the resulting function through indent to clean it up.
200 * ospf_lsa.c: (router_lsa_flags) For purposes of ASBR bit,
201 NSSA area is same as stub area.
202
Andrew J. Schorr0ffb7092006-06-24 19:40:13 +00002032006-06-24 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
204
Andrew J. Schorr9aecfae2006-06-24 20:05:02 +0000205 * ospf_snmp.c: (ospfTrapNbrStateChange, ospfTrapIfStateChange) Improve
206 info log message to indicate why the trap is being sent.
207
2082006-06-24 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
209
Andrew J. Schorr0ffb7092006-06-24 19:40:13 +0000210 * ospf_dump.c: (config_write_debug) Fix typo to show debug ospf nsm
211 status properly (not ism status).
212
Andrew J. Schorr6e72cb62006-06-18 00:45:48 +00002132006-06-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
214
215 * ospf_vty.c: ({no_,}ospf_passive_interface) Replace if_lookup_by_name
216 with a call to if_get_by_name -- if the interface does not exist
217 already, it should be created. And remove the obsolete warning
218 message.
219
Paul Jakma429ac782006-06-15 18:40:49 +00002202006-06-15 Paul Jakma <paul.jakma@sun.com>
221
222 * ospf_interface.h: (struct ospf_if_info) Add reference counts
223 for multicast group memberships. Add various macros to help
224 manipulate/check membership state.
225 * ospf_interface.c: (ospf_if_set_multicast) Maintain the
226 ospf_if_info reference counts, and only actually drop
227 memberships if it hits 0, to avoid losing membership when
228 OSPF is disabled on an interface with multiple active OSPF
229 interfaces.
230 * ospf_packet.c: (ospf_{hello,read}) Use the new macros to
231 check/set
232 multicast membership.
233 * ospf_vty.c: (show_ip_ospf_interface_sub) ditto.
234
Paul Jakmaac904de2006-06-15 12:04:57 +00002352006-05-31 Paul Jakma <paul.jakma@sun.com>
236
237 * ospf_lsdb.c: (ospf_lsdb_delete) robustify against NULL arguments,
238 print warning.
239 * ospf_lsa.c: (ospf_discard_from_db) ditto.
240 (ospf_maxage_lsa_remover) Check lsa->lsdb for validity, possible
241 mitigation (but not solution) for bug #269.
242
Paul Jakma88871b12006-06-15 11:41:19 +00002432006-05-30 Paul Jakma <paul.jakma@sun.com>
244
245 * ospf_packet.c: (ospf_read) Debug message about packets
246 received on unenabled interfaces should be conditional on
247 debug being set.
248
Paul Jakmad1c65c22006-06-27 08:01:43 +00002492006-05-23 Paul Jakma <paul.jakma@sun.com>
250
251 * ospf_vty.c: (general) Replace in-place route redistribution
252 command and help strings with the new auto-generated defines
253 from lib/route_types.h
254
Paul Jakmaae128052006-05-12 23:15:30 +00002552006-05-13 Paul Jakma <paul.jakma@sun.com>
256
257 * ospf_lsa.c: (ospf_translated_nssa_refresh) fix the sanity
258 check to match the assert, small error in CID #13 fix.
259
Paul Jakma70461d72006-05-12 22:57:57 +00002602006-05-12 Paul Jakma <paul.jakma@sun.com>
261
262 * ospf_lsa.c: (ospf_lsa_action) Get rid of the ospf_lookup
263 call, which is not checked for NULL return, by stripping out
264 functionality which is never used, hence fixing Coverity CID
265 #29.
266 (struct lsa_action) remove unused member.
Paul Jakmae54e6e52006-05-12 23:11:14 +0000267 (ospf_translated_nssa_refresh) Add non-assert sanity check,
268 in case DEBUG isn't defined.
269 Debug message when no type7 exists should print the ID from
270 the type5, not the type7, fixes CID #13.
271 * ospf_interface.c: (ospf_if_exists) Fix missing NULL return
Paul Jakmae43be0e2006-05-12 23:00:06 +0000272 check on ospf_lookup, CID #27.
Paul Jakma6db3a6f2006-05-12 23:02:46 +0000273 * ospf_asbr.c: (ospf_redistribute_withdraw) remove ospf_lookup
274 call by taking the struct ospf * as argument, which the
275 caller has, fixing CID #28.
276 * ospf_asbr.h: (ospf_redistribute_withdraw) update declaration
277 * ospf_zebra.c: (ospf_redistribute_unset) update call to
278 ospf_redistribute_withdraw to match.
Paul Jakmabfd7c7d2006-05-12 23:04:45 +0000279 * ospf_ia.c: (ospf_update_router_route) ospf->backbone could be
280 NULL when passed to ospf_find_asbr_route_through_area,
281 check for NULL first, CID #14.
Paul Jakmadeb15612006-05-12 23:07:27 +0000282 * ospf_ism.c: (ism_change_state) NULL check on oi->area is
283 useless, it's always valid. Only possibility where it
284 couldn't be is if there is a race between abr_task and
285 cleaning up oi's, in which case a NULL check here isn't going
286 to do anything. Fixes CID #15.
Paul Jakma70461d72006-05-12 22:57:57 +0000287
Paul Jakmacac3b5c2006-05-11 13:31:11 +00002882006-05-11 Paul Jakma <paul.jakma@sun.com>
289
290 * ospf_vty.c: (general) Audit ospf_lookup calls in commands,
291 ensure check for NULL result, make vty messages consistent.
292 (show_ip_ospf_interface) Missing NULL check on ospf_lookup
293 result, fixes Coverity CID #70.
Paul Jakma1a8ec2b2006-05-11 13:34:08 +0000294 (no_ospf_area_filter_list) Check NULL result from
295 ospf_area_lookup_by_area_id, fixes Coverity CID #69
Paul Jakma894f8b62006-05-12 22:50:40 +0000296 * ospf_route.c: (ospf_route_delete_same_ext) Fix deref before
297 NULL check by moving into check-protected block, fix CID #49.
Paul Jakma214a4452006-05-12 22:51:49 +0000298 * ospf_abr.c: (ospf_area_range_cost_set) Shouldn't create a new
299 range, should just lookup to see if one exists, the new range
300 is just leaked. Fixes CID #46.
Paul Jakma4021b602006-05-12 22:55:41 +0000301 * ospf_lsa.c: (ospf_default_originate_timer) Let the thread
302 take (struct ospf *) as thread argument, rather than (struct
303 ospf *)->default_originate, thus avoiding having to call
304 ospf_lookup.
305 * ospf_zebra.c: (ospf_redistribute_default_set) change setup
306 of ospf_default_originate_timer thread to match.
307 * ospfd.c: (ospf_router_id_update) ditto.
Paul Jakmacac3b5c2006-05-11 13:31:11 +0000308
Paul Jakma9c27ef92006-05-04 07:32:57 +00003092006-04-24 Paul Jakma <paul.jakma@sun.com>
310
311 * (general) More Virtual-link fixes, again with much help in
312 testing / debug from Juergen Kammer. Primarily in SPF.
313 * ospf_spf.h: Add guard. ospf_interface.h will include this
314 header.
315 * ospf_interface.h: Modify ospf_vl_lookup definition to take
316 struct ospf as argument, so as to allow for NULL area
317 argument.
318 (struct ospf_vl_data) Remove out_oi, instead add a struct
319 vertex_nexthop, to use as initial nexthop for backbone paths
320 through a vlink.
321 * ospf_interface.c: (ospf_vl_lookup) Modified to allow
322 NULL area to be passed to indicate "any" (first) area.
323 Add extra debug.
324 (ospf_vl_set_params) vl_oi -> nexthop. Add extra debug.
325 (ospf_vl_up_check) Fix debug, inet_ntoa returns a static
326 buffer..
327 * ospf_route.c: (ospf_intra_add_router) Vlinks dont go through
328 backbone, don't bother checking.
329 * ospf_spf.c: (static struct list vertex_list) Record vertices
330 that will need to be freed.
331 (cmp) Order network before router vertices, as required,
332 wasn't implemented.
333 (vertex_nexthop_free) Mild additional robustness check.
334 (vertex_parent_free) Take void argument, as this function
335 is passed as list deconstructor for vertex parent list.
336 (ospf_vertex_new) More debug. Set deconstructor for parent
337 list. Track allocated vertices on the vertex_list.
338 (ospf_vertex_free) Get rid of the tricky recursive cleanup of
339 vertices. Now frees only the given vertex.
340 (ospf_vertex_add_parent) Fix assert.
341 (ospf_nexthop_calculation) Fix calculation of nexthop for
342 VLink vertices, lookup the vl_data and use its previously
343 recorded nexthop information.
344 (ospf_spf_calculate) Vertices are freed simply by deleting
345 vertex_list nodes and letting ospf_vertex_free as deconstructor
346 work per-node.
347 (ospf_spf_calculate_timer) Trivial optimisation, leave
348 backbone SPF calculation till last to reduce SPF churn on
349 VLink updates.
350 * ospf_vty.c: (ospf_find_vl_data) update call to ospf_vl_lookup
351 (no_ospf_area_vlink_cmd) ditto.
352 (show_ip_ospf_interface_sub) For Vlinks, the peer address is
353 more interesting than the output interface.
354
Paul Jakma478aab92006-04-03 21:25:32 +00003552006-04-03 Paul Jakma <paul.jakma@sun.com>
356
357 * (general) Fix issues with handling of Vlinks and entries
358 in the nbrs route-table which were highlighted by the
359 nsm/nbr_self fixes from bug #234. Many thanks to Juergen
360 Kammer for his help and efforts in testing out debug patches to
361 pinpoint the issue.
362 * ospf_interface.c: (ospf_vl_new) Add nbr_self for Vlink.
363 * ospf_neighbor.c: (ospf_nbr_key) new static function, helper
364 to create key in nbrs table for a given nbr.
365 (ospf_nbr_delete) Use ospf_nbr_key. Add an assert() to
366 document an expected state.
367 (ospf_nbr_add_self) Ditto.
368 (ospf_nbr_lookup_by_addr) Add an assert.
369 * ospf_nsm.c: (nsm_kill_nbr) Can never kill the nbr_self
370 psuedo-neighbour.
371
Paul Jakma075c2012006-03-30 14:34:31 +00003722006-03-27 Paul Jakma <paul.jakma@sun.com>
373
374 * ospf_lsa.c: (ospf_lsa_checksum) Add an explicit cast to avoid
375 the ambiguities of ANSI and C99 C with respect to type
376 conversion. Detailed problem report and test case with
377 example data supplied by Dmitry Ivanov <dimss@telecentrs.lv>.
378
Paul Jakma1a8ee0e2006-03-30 14:20:00 +00003792006-03-25 Paul Jakma <paul.jakma@sun.com>
380
381 * ospf_interface.c: (ospf_if_lookup_recv_if) Ignore loopbacks,
382 we can never ever receive packets on those. Should fix
383 case where CARP is run with address in same subnet as real
384 interface. Problem report and diagnosis thanks to:
385 Landon Fuller <landonf@opendarwin.org>.
386 However, ospf_read() still can't deal deterministically with
387 multiple interfaces in same subnet.
388
Paul Jakmac2b478d2006-03-30 14:16:11 +00003892006-03-23 Steve Lawson <steve.lawson@aheadcomusa.com>
390
391 * ospf_lsa.c: (ospf_lsa_install) Fix incorrect byte-order
392 conversion of OSPF_MAX_SEQUENCE_NUMBER
393
paule8e19462006-01-19 20:16:55 +00003942006-01-19 Paul Jakma <paul.jakma@sun.com>
395
396 * (general) various miscellaneous compiler warning fixes.
397 Remove redundant break statements from switch clauses
398 which return.
399 return from main, not exit, cause it annoys SOS.
400 Remove stray semi-colons which cause empty-statement
401 warnings.
402
paul779adb02006-01-18 15:07:38 +00004032006-01-18 Juergen Kammer <j.kammer@eurodata.de>
404
405 * ospf_lsa.c: (ospf_router_lsa_new) dont take reference to the
406 stream data until it is constructed, data reference is
407 volatile due to the potential resize in link_info_set
408
4092006-01-18 Paul Jakma <paul.jakma@sun.com>
410
411 * ospf_lsa.c: (link_info_set) Resize the stream if required and
412 possible. Return number of links added.
413 (lsa_link_*_set) use return value from previous.
414 * ospf_lsa.h: Add OSPF_ROUTER_LSA_LINK_SIZE define.
415
paulc6371712006-01-17 17:49:53 +00004162006-01-17 Paul Jakma <paul.jakma@sun.com>
417
418 * ospf_packet.c: (ospf_verify_header) print out the types
419 involved if there's a mismatch.
420 * ospf_zebra.c: (ospf_zebra_add) Adjust to new zserv format.
421
paul818e56c2006-01-10 23:27:05 +00004222006-01-10 Len Sorensen <lennartsorensen@ruggedcom.com>
423
424 * (general) Bug #234, see also [quagga-dev 3902].
425 Fix problem with nbr_self not being properly reinitialised
426 when an interface comes up, after having been down.
paul1a643f82006-01-11 01:08:19 +0000427 Some re-arrangement done by Paul Jakma, any bugs introduced
428 on top of Len's suggested changes are his.
paul818e56c2006-01-10 23:27:05 +0000429 * ospf_neighbor.c: (ospf_nbr_add_self) centralise
430 initialisation of nbr_self parameters here.
431 * ospf_interface.c: (ospf_if_new) deleting initialisation of
432 parameters of nbr_self, just rely on call to
433 ospf_nbr_add_self.
434 (ospf_if_cleanup) ditto.
435 * ospfd.c: (ospf_network_run) ditto.
436
paul98429f62006-01-10 22:11:54 +00004372006-01-10 Juris Kalnins <juris@mt.lv>
438
439 * ospf_zebra.c: (ospf_interface_address_delete) fix rare leak of
440 struct connected in an error case.
paul818e56c2006-01-10 23:27:05 +0000441 * ospf_packet.c: (ospf_make_md5_digest) fix odd, if not
442 undefined effect, assignment of an increment expression.
paul98429f62006-01-10 22:11:54 +0000443
paul86752842006-01-10 20:34:46 +00004442006-01-10 Paul Jakma <paul.jakma@sun.com>
445
446 * ospfd.c: (ospf_network_run) checking to see if router-id
447 is set should be on ospf->router_id, not router_id_static.
448 This was causing ospfd to not start if router-id had not
449 been configured statically.
450 (ospf_if_update) ditto.
paulc42c1772006-01-10 20:36:49 +0000451 * ospf_vty.c: (config_write_ospf_distribute) trim down
452 redundant strings.
paul86752842006-01-10 20:34:46 +0000453
paul00c290e2005-11-26 09:21:43 +00004542005-11-26 Paul Jakma <paul.jakma@sun.com>
455
456 * ospf_api.c: (struct opaque_lsa) change from gcc zero-length
457 array to C99 incomplete type array.
paulc9c93d52005-11-26 13:31:11 +0000458 * (general) s/graceful/deferred/ in all files, the former term
459 is confusing wrt OSPF Graceful-Restart.
460 * ospfd.c: (ospf_deferred_shutdown_check) dont return
461 a function which returns void. SOS complains about this.
462 (ospf_finish)
paul00c290e2005-11-26 09:21:43 +0000463
paulb29800a2005-11-20 14:50:45 +00004642005-11-20 Paul Jakma <paul.jakma@sun.com>
465
466 * ospfd.h: remove the OSPF_ROUTER_ID_UPDATE_DELAY define
467 (struct ospf) remove the router_id timer thread.
468 remove export of ospf_router_id_update_timer.
469 * ospfd.c: (ospf_router_id_update) call ospf_if_update to
470 poke interfaces into action after ID has been configured.
471 (ospf_router_id_update_timer) removed.
472 (ospf_finish_final) t_router_id_update timer is gone.
473 (ospf_network_run) router-id update timer gone.
474 call ospf_router_id_update directly if ID not configured.
475 In the per-iface loop, don't ospf_if_up interfaces if
476 ID is still not configured. The update function will call
477 ospf_if_update anyway.
478 (ospf_if_update) ID update timer is gone. Just return if no
479 ID is set.
480 * ospf_vty.c: (ospf_router_id) call ospf_router_id_update, no
481 timer needed.
482 * ospf_zebra.c: (ospf_router_id_update_zebra) call
483 ospf_router_id_update directly, not via timer.
paulc24d6022005-11-20 14:54:12 +0000484 * ospf_abr.c: (ospf_abr_announce_network_to_area) check
485 returned LSA of ospf_summary_lsa_refresh and print warning if
486 it failed.
487 (ospf_abr_announce_network_to_area) similar
488 (ospf_abr_announce_rtr_to_area) similar
489 * ospf_lsa.c: (ospf_router_lsa_new) check LSA returned is valid.
490 (ospf_router_lsa_originate) similar
491 (ospf_router_lsa_refresh, ospf_network_lsa_new) similar
492 (ospf_summary_lsa_new) Check ID is valid.
493 (ospf_summary_lsa_originate) ditto, and check returned LSA from
494 previous function is !NULL.
495 (ospf_summary_lsa_refresh) check ospf_summary_lsa_new return
496 is !NULL.
497 (ospf_summary_asbr_lsa_new) ID valid check.
498 (ospf_summary_asbr_lsa_originate) similar.
paulb29800a2005-11-20 14:50:45 +0000499
ajs70cd3472005-11-16 19:33:22 +00005002005-11-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
501
ajs649654a2005-11-16 20:17:52 +0000502 * ospf_dump.h: Define OSPF_TIME_DUMP_SIZE as appropriate buffer size
503 for use with ospf_timer_dump and ospf_timeval_dump.
504 * ospf_vty.c: Change all buffer sizes used with ospf_timer_dump and
505 ospf_timeval_dump to have size OSPF_TIME_DUMP_SIZE.
506 (show_ip_ospf_interface_sub) Fix possible buffer overflow in
507 call to ospf_timer_dump.
508
5092005-11-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
510
ajs70cd3472005-11-16 19:33:22 +0000511 * ospf_ism.h: (OSPF_ISM_TIMER_OFF) Improve macro syntax by enclosing
512 in 'do {...} while(0)'.
513
paul31a59762005-11-14 11:11:11 +00005142005-11-14 Paul Jakma <paul.jakma@sun.com>
515
516 * ospfd.c: (ospf_new) stub-shutdown should just default to
517 unconfigured, too strange otherwise.
518 (ospf_finish_final) t_opaque_lsa_self TIMER_OFF should be
519 preprocessor conditional on HAVE_OPAQUE_LSA.
520 * ospfd.h: (struct ospf) remove the SHUTDOWN_DEFAULT define.
521 no longer used, plus it wasn't in range that the command
522 accepted.
523 * ospf_zebra.h: Depends on vty.h, include it.
524
paul58e1bef2005-11-11 12:10:03 +00005252005-11-11 Paul Jakma <paul.jakma@sun.com>
526
527 * ospf_spf.c: (ospf_canonical_nexthops_free) Free only
528 the nexthops pointing to the root vertex. We may visit a
529 vertex twice or the vertex may have some inherited nexthops,
530 if we free other nexthops we could crash.
531
paulc8c15212005-11-04 12:31:39 +00005322005-11-04 Paul Jakma <paul.jakma@sun.com>
533
534 * ospf_{dump,spf,vty}.c: Oops, use the internal tv_sub
535 function rather than unportable timersub.
536
paul484315f2005-11-03 09:08:29 +00005372005-11-03 Paul Jakma <paul.jakma@sun.com>
538
539 * ospf_apiserver.c: (apiserver_sync_callback) stray semi-colon
540 * ospf_packet.c: include checksum.h, remove the in_cksum extern
541 * prototypes.
542 * ospf_te.h: Add braces, quell warning.
paul6d452762005-11-03 11:15:44 +0000543 * ospf_packet.c: Change level of some warnings to
544 informational.
paulc8c15212005-11-04 12:31:39 +0000545
paul88d6cf32005-10-29 12:50:09 +00005462005-10-29 Paul Jakma <paul.jakma@sun.com>
547
548 * (general) RFC3137 stub-router support
549 * ospfd.h: Add OSPF_OUTPUT_COST_INFINITE define.
550 (struct ospf_master) Add a OSPF_MASTER_SHUTDOWN flag for
551 options, to allow shutdown to distinguish between complete
552 shutdown and shutdown of a subset of ospf instances.
553 (struct ospf)
554 Add stub_router_{startup,shutdown_}time, configuration of startup
555 and shutdown time for stub-router.
556 Add t_graceful_shutdown struct thread, timer for graceful
557 shutdown, if needed.
558 (struct ospf_area) Add stub_router_state - run time state of
559 stub-router for an area. Add flags for ADMIN, IS and WAS
560 states.
561 Add t_stub_router, timer thread to resend router-lsa for an
562 area.
563 * ospf_lsa.c: (ospf_link_cost) new simple function to spit out
564 either the given lnks cost or infinite cost if stub-router is
565 in effect.
566 (lsa_link_{ptop,broadcast,virtuallink,ptomp}_set) use
567 previous function for transit-links.
568 (ospf_stub_router_timer) timer thread for end of startup stub
569 router. Change state as required for the area and setup
570 re-origination of router-lsa.
571 (ospf_stub_router_check) Check/do whether stub-router should be
572 enabled, and whether it requires timer to be setup.
573 (ospf_router_lsa_new) call previous function at top.
574 (ospf_router_lsa_originate) no external callers, made static.
575 * ospf_lsa.h: (ospf_router_lsa_originate) removed.
576 * ospf_main.c: (sigint) make static.
577 remove call to exit, as ospf_terminate now deals with
578 exiting.
579 * ospf_route.c: (ospf_terminate) removed, now in ospfd.c.
580 * ospf_vty.c: (show_ip_ospf_area) print out state of
581 stub-router, if active.
582 (show_ip_ospf) print out configuration of stub-router
583 support, and details of graceful-shutdown if the timer is
584 active.
585 ((no)?ospf_max_metric_router_lsa_{admin,startup,shutdown}) new
586 commands to (de-)?configure stub-router support.
587 (config_write_stub_router) write out config of stub-router.
588 (ospf_config_write) call previous.
589 (ospf_vty_init) install the new stub-router commands.
590 * ospfd.c: various functions made static.
591 (ospf_new) Set defaults for stub-router. Graceful shutdown
592 is made to default on, just to be adventerous.
593 (ospf_graceful_shutdown_finish) new function, final part of
594 shutdown.
595 (ospf_graceful_shutdown_timer) timer thread wrapper for
596 graceful-shutdown.
597 (ospf_graceful_shutdown_check) check whether to setup timer
598 for shutdown or proceed directly to final shutdown.
599 (ospf_terminate) moved here from ospf_route.c, call
600 ospf_finish for each instance.
601 (ospf_finish) renamed to ospf_finish_final and made static.
602 (ospf_finish) new function, exported wrapper around
603 ospf_graceful_shutdown_check.
604 (ospf_finish_final) complete shutdown of an instance.
605 Add missing TIMER_OFF's of two timer threads.
606 (ospf_area_free) opaque self lsa timer should be turned off.
607
paulb8ad39d2005-10-23 15:23:05 +00006082005-10-23 Paul Jakma <paul.jakma@sun.com>
609
paule029d442005-10-23 15:26:24 +0000610 * ospf_apiserver.c: (ospf_apiserver_term) This function should
611 not have side-effects (eg segv) if no apiserver instances are
612 active, ie be robust.
paulb8ad39d2005-10-23 15:23:05 +0000613 * ospf_vty.c: (show_ip_ospf) fix display of SPF timer if it
614 has not yet been run.
615
paulf9ad9372005-10-21 00:45:17 +00006162005-10-21 Paul Jakma <paul.jakma@sun.com>
617
paulea4ffc92005-10-21 20:04:41 +0000618 * ospf_dump.c: (ospf_timeval_dump) fix ms adjustment, thanks to
619 Andrew Schorr.
620 * ospf_vty.c: (ospf_config_write) fix write out of spf timers
621 configuration.
622
6232005-10-21 Paul Jakma <paul.jakma@sun.com>
624
pauld24f6e22005-10-21 09:23:12 +0000625 * (general) SPF millisecond resolution timer with adaptive,
626 linear back-off holdtime. Prettification of ospf_timer_dump.
627 * ospf_dump.c: (ospf_timeval_dump) new function. The guts of
628 ospf_timer_dump, but made to be more dynamic in printing out
629 the relative timeval, sliding the precision printed out
630 according to the value.
631 (ospf_timer_dump) guts moved to ospf_timeval_dump.
632 * ospf_dump.h: export ospf_timeval_dump.
633 * ospf_flood.c: (ospf_flood) remove gettimeofday, use
634 the libzebra exported recent_time instead, as it's not
635 terribly critical to have time exactly right - the dropped
636 LSA will be retransmited to us if we don't ACK it.
637 * ospf_packet.c: (ospf_ls_upd_timer) Ditto, but here we're
638 not transmitting, just putting LSA back on update transmit list.
639 * ospfd.h: delay and holdtimes should be unsigned.
640 Add spf_max_holdtime and spf_hold_multiplier.
641 Update default defines for delay and hold time to be in msec.
642 (struct ospf) change the SPF timestamp to a struct timeval.
643 Remove ospf_timers_spf_(un)?set.
644 * ospfd.c: (ospf_timers_spf_{set,unset}) removed.
645 (ospf_new) initialise spf_max_holdtime and spf_hold_multiplier
646 * ospf_spf.c: (ospf_spf_calculate) SPF timestamp is a timeval
647 now, update with gettimeofday.
648 (ospf_spf_calculate_schedule) Change SPF timers to millisecond
649 resolution.
650 Make the holdtime be adaptive, with a linear increase in
651 holdtime ever consecutive SPF run which occurs within holdtime
652 of previous SPF, bounded by spf_max_holdtime.
653 * ospf_vty.c: Update spf timers commands.
654 (ospf_timers_spf_set) trivial helper.
655 (ospf_timers_throttle_spf_cmd) new command to set SPF delay,
656 initial hold and max hold times with millisecond resolution.
657 (ospf_timers_spf_cmd) Deprecated. Accept the old values,
658 convert to msec, truncate to new limits.
659 (no_ospf_timers_throttle_spf_cmd) set timers to defaults.
660 (no_ospf_timers_spf_cmd) deprecated form, same as previous.
661 (show_ip_ospf_cmd) Display SPF parameters and times.
662 (show_ip_ospf_neighbour_header) Centralise the 'sh ip os ne'
663 header.
664 (show_ip_ospf_neighbor_sub) Fix the field widths. Get rid of
665 the multiple spaces which were making the lines even longer.
666 (show_ip_ospf_neighbor_cmd) Use show_ip_ospf_neighbour_header
667 (show_ip_ospf_neighbor_all_cmd) ditto and fix the field
668 widths for NBMA neighbours.
669 (show_ip_ospf_neighbor_int) Use header function.
670 (show_ip_ospf_nbr_nbma_detail_sub) use sizeof for timebuf,
671 local array - safer.
672 (show_ip_ospf_neighbor_detail_sub) ditto
673 (ospf_vty_init) install the new SPF throttle timer commands.
674
6752005-10-21 Paul Jakma <paul.jakma@sun.com>
676
paulf9ad9372005-10-21 00:45:17 +0000677 * (general) OSPF fast, sub-second hello and 1s dead-interval
678 support.
679 * ospf_dump.c: (ospf_timer_dump) Print out milliseconds too.
680 Callers typically specify a length of 9, so most see
681 millisecs unless they specify the additional length.
682 * ospf_interface.h: (struct ospf_interface) new interface param,
683 fast_hello.
684 * ospf_interface.c: (ospf_if_table_lookup) add brackets,
685 gcc warning fix.
686 (ospf_new_if_params) Initialise fast_hello param.
687 (ospf_free_if_params) Check whether fast_hello is configured.
688 (ospf_if_new_hook) set fast_hello to default.
689 * ospf_ism.h: Wrap OSPF_ISM_TIMER_ON inside do {} while (0) to
690 prevent funny side-effects from its if statement when this
691 macro is used conditionally by other macros.
692 (OSPF_ISM_TIMER_MSEC_ON) new macro, set in milliseconds.
693 (OSPF_HELLO_TIMER_ON) new macro to set hello timer according
694 to whether fast_hello is set.
695 * ospf_ism.c: Update all setting of the hello timer to use
696 either OSPF_ISM_TIMER_MSEC_ON or OSPF_HELLO_TIMER_ON. The
697 former is used when hello is to be sent immediately.
698 * ospf_nsm.c: ditto
699 * ospf_packet.c: (ospf_hello) hello-interval is not checked
700 for mismatch if fast_hello is set.
701 (ospf_read) Annoying nit, fix "no ospf_interface" to be debug
702 rather than a warning, as it can be perfectly normal to
703 receive packets when logical subnets are used.
704 (ospf_make_hello) Set hello-interval to 0 if fast-hellos are
705 configured.
706 * ospf_vty.c: (ospf_auto_cost_reference_bandwidth) annoying
707 nit, don't vty_out if this command is given, it gets tired
708 quick.
709 (show_ip_ospf_interface_sub) Print the hello-interval
710 according to whether fast-hello is set or not.
711 Print the extra 5 millisec characters from (ospf_timer_dump)
712 if fast-hello is configured.
713 (ospf_vty_dead_interval_set) new function, common to all
714 forms of dead-interval command, to set dead-interval and
715 fast-hello correctly. If a dead-interval is given, unset
716 fast-hello, else if a hello-multiplier is set, set
717 dead-interval to 1 and fast-hello to given multiplier.
718 (ip_ospf_dead_interval_addr_cmd) use
719 ospf_vty_dead_interval_set().
720 (ip_ospf_dead_interval_minimal_addr_cmd) ditto.
721 (no_ip_ospf_dead_interval) Unset fast-hello.
722 (no_ip_ospf_hello_interval) Bug-fix, unset of hello-interval
723 should set it to OSPF_HELLO_INTERVAL_DEFAULT, not
724 OSPF_ROUTER_DEAD_INTERVAL_DEFAULT.
725 (config_write_interface) Write out fast-hello.
726 (ospf_config_write) Write a comment about
727 "auto-cost reference-bandwidth" having to be equal on all
728 routers. Hopefully just as noticeable as old practice of
729 writing to vty, but less annoying.
730 (ospf_vty_if_init) install the two new dead-interval
731 commands.
732 * ospfd.h: Add defines for OSPF_ROUTER_DEAD_INTERVAL_MINIMAL
733 and OSPF_FAST_HELLO_DEFAULT.
734
pauleb3da6d2005-10-18 04:20:33 +00007352005-10-18 Paul Jakma <paul.jakma@sun.com>
736
737 * (general) SPF memory management cleanup and fix for rare
738 double-free bug.
739 * ospf_spf.h: (struct vertex_parent) New struct to hold parent
740 specific data, eg the backlink and the parent vertex pointer,
741 and point to the appropriate general struct vertex_nexthop.
742 (struct vertex_nexthop) remove parent vertex pointer, so
743 this struct can be shared across vertices.
744 (struct vertex) rename list child to list children. Remove
745 list of nexthops, replace with list of vertex_parents.
746 * ospf_spf.c: (update_stat) trivial, remove cast from void *.
747 (vertex_nexthop_new) remove init of parent - field is gone
748 from struct vertex_nexthop.
749 (ospf_canonical_nexthops_free) Remove the canonical
750 vertex_nexthop memory objects. These are the vertex_nexthops
751 attached to the first level of router vertices from the root.
752 (vertex_parent_new) new function, create a vertex_parent.
753 (vertex_parent_free) ditto, but free it.
754 (ospf_vertex_new) Update to match changes to struct vertex.
755 (ospf_vertex_free) Recursively free a struct vertex and its
756 children. The parent list is used as a reference count.
757 vertex_nexthops must be free seperately, if required.
758 (ospf_vertex_dump) update to match struct vertex changes.
759 Print out backlink of parents too.
760 (ospf_vertex_add_parent) ditto.
761 (ospf_lsa_has_link) update comment.
762 (ospf_nexthop_add_unique) removed, not needed anymore.
763 (ospf_nexthop_merge) ditto.
764 (ospf_spf_consider_nexthop) renamed to ospf_spf_add_parent.
765 Simplified to just create vertex_parent and add it.
766 (ospf_spf_flush_parents) new function, flush out the parent
767 list.
768 (ospf_nexthop_calculation) Take the relevant route_lsa_link
769 as an argument, which simplifies things and removes the need
770 for the hack in ospf_nexthop_add_unique - ospf_spf_next
771 already knew exactly which link the cost calculated was for.
772 Update to match struct vertex changes too.
773 (ospf_spf_next) Don't create a vertex for W unnecessarily, if
774 it's there's a vertex already created for W, use it, and
775 hence there's no need to free it either.
776 Update some manipulation/comparisons of distance to match.
777 Flush the parent list if a lower cost path is found.
778 (ospf_spf_route_free) unused, removed.
779 (ospf_spf_dump) match the struct vertex changes, and dump the
780 ifname if possible.
781 (ospf_spf_calculate) At end of SPF, free the canonical nexthops
782 and call ospf_vertex_free on the root vertex to free the
783 entire tree.
784 * ospf_interface.c: (ospf_vl_set_params) match struct vertex
785 changes.
786 * ospf_route.c: (ospf_intra_route_add) ditto
787 (ospf_route_copy_nexthops_from_vertex) ditto
788
paul36238142005-10-11 04:12:54 +00007892005-10-11 Paul Jakma <paul.jakma@sun.com>
790
791 * ospf_api.c: sign warnings.
792 * ospf_apiserver.c: sign warning and convert all the struct
793 in_addr initialisations so as not to make assumptions about
794 how this struct is organised, initialise the s_addr member
795 explicitely.
796 * ospf_packet.c: Add const qualifier to auth_key.
797
vincent77df1f72005-10-06 07:46:22 +00007982005-10-06 Alain Ritoux <alain.ritoux@6wind.com>
799
800 * ospf_snmp.c: Avoid mixing interface and ospf_interface objects
801 which now allows snmpwalk to work with ospfIfTable and
802 also with ospfIfMetricTable
803
ajsf52d13c2005-10-01 17:38:06 +00008042005-10-01 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
805
806 * ospf_dump.c: Remove local hard-coded table ospf_redistributed_proto.
807 (ospf_redist_string) New function implemented using new library
808 function zebra_route_string(). Note that there are a few differences
809 in the output that will result: the new function returns strings
810 that are lower-case, whereas the old table was mixed case. Also,
811 the old table mapped ZEBRA_ROUTE_OSPF6 to "OSPFv3", whereas the
812 new function returns "ospf6".
813 * ospfd.h: Remove extern struct message ospf_redistributed_proto[],
814 and add extern const char *ospf_redist_string(u_int route_type)
815 instead.
816 * ospf_asbr.c: (ospf_external_info_add) In two messages, use
817 ospf_redist_string instead of LOOKUP(ospf_redistributed_proto).
818 * ospf_vty.c: Remove local hard-coded table distribute_str.
819 (config_write_ospf_redistribute,config_write_ospf_distribute): Use
820 new library function zebra_route_string() instead of distribute_str[].
821 * ospf_zebra.c: (ospf_redistribute_set,ospf_redistribute_unset,
822 ospf_redistribute_default_set,ospf_redistribute_check)
823 In debug messages, use ospf_redist_string() instead of
824 LOOKUP(ospf_redistributed_proto).
825
jardin6638c1a2005-10-01 00:08:54 +00008262005-09-30 Vincent Jardin <vincent.jardin@6wind.com>
827
828 * ospf_dump.c, ospf_ia.c, ospf_spf.c, ospf_ase.c:
829 remove unused DEBUG
830
vincentba682532005-09-29 13:52:57 +00008312005-09-29 Alain Ritoux <alain.ritoux@6wind.com>
832
vincent5e4914c2005-09-29 16:34:30 +0000833 * ospf_ism.c: generate SNMP traps on Interface state change
834 * ospf_nsm.c: generate SNMP traps on Neighbour state change
835 * ospf_snmp.[ch]: support for SNMP traps for interface and neighbours.
836
8372005-09-29 Alain Ritoux <alain.ritoux@6wind.com>
838
vincentba682532005-09-29 13:52:57 +0000839 * ospf_vty.c: forece default route LSA to be re_issued whenever
840 cost is changed ( [no] ip ospf area XXX default-cost YYY)
841 Support ignore-mtu option
842 * ospfd.h: define OSPF_MTU_IGNORE_DEFAULT
843 * ospf_packet.c: support ignore-mtu option
844 * ospf_interface.h: field added for skipping MTU check
845 * ospf_interface.c: fix memory leak in ospf_crypt_key_delete()
846 Set mtu_ignore field to default value
847 * ospf_abr.[ch]: export ospf_abr_announce_network_to_area()
848 * ospf_ism.h: add MACRO to convert internal ISM status into SNMP
849 correct values
850 * ospf_snmp.c: add sanity check on LSA type in lsdb_lookup_next()
851 convert OSPFIFSTATE internal status into SNMP values
852
vincentc1a03d42005-09-28 15:47:44 +00008532005-09-28 Alain Ritoux <alain.ritoux@6wind.com>
854
855 * ospf_packet.c: use new md5 API
856
ajs5339cfd2005-09-19 13:28:05 +00008572005-09-19 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
858
859 * ospf_lsa.h: (ospf_external_lsa_flush) Comment out the 5th argument
860 (nexthop) since it is not used in the function (except inside
861 some commented-out code).
862 * ospf_lsa.c: (ospf_external_lsa_flush,ospf_external_lsa_refresh)
863 Comment out the 5th argument to ospf_external_lsa_flush.
864 * ospf_asbr.c: (ospf_redistribute_withdraw) Comment out 5th arg
865 to ospf_external_lsa_flush.
866 * ospf_vty.c: (no_ospf_default_information_originate) Eliminate 5th
867 uninitialized nexthop arg to ospf_external_lsa_flush.
868 * ospf_zebra.c: (ospf_zebra_read_ipv4) Comment out 5th arg
869 to ospf_external_lsa_flush.
870 * ospfd.c: (ospf_network_set) Comment out 5th arg
871 to ospf_external_lsa_flush.
872
ajse6a0bf92005-09-17 18:53:38 +00008732005-09-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
874
875 * ospf_opaque.c:
876 (ospf_opaque_lsa_refresh_schedule,ospf_opaque_lsa_flush_schedule)
877 No need to call ospf_lookup(), just use lsa0->area->ospf instead.
878
hassobb5b7552005-08-21 20:01:15 +00008792005-08-21 Hasso Tepper <hasso at quagga.net>
880
881 * ospf_vty.c: Make "show ip ospf neighbor xxx" commands work.
882 Interface should be specified by name now.
883
hasso54bedb52005-08-17 13:31:47 +00008842005-08-17 Hasso Tepper <hasso at quagga.net>
885
886 * ospf_vty.c: Check carefully if interface exists before trying to
887 print info about it.
888
hasso01018ce2005-08-05 07:40:15 +00008892005-08-05 Hasso Tepper <hasso at quagga.net>
890
891 * ospf_zebra.c: Don't assert/stop before type == ZEBRA_ROUTE_MAX if
892 dealing with routemaps. There is ospf->route_map[ZEBRA_ROUTE_MAX]
893 for default-information.
894
paulc8987752005-07-26 06:07:22 +00008952005-07-26 Paul Jakma <paul.jakma@sun.com>
896
897 * ospf_abr.c: (ospf_abr_announce_network_to_area) SET_FLAG
898 should be on lsa not old, which may be freed for one thing,
899 obviously.
900
pauld57834f2005-07-12 20:04:22 +00009012005-07-12 Paul Jakma <paul.jakma@sun.com>
902
903 * ospfd.h: add OSPF_ABR_DEFAULT for convenience, make
904 OSPF_ABR_CISCO be the default ABR type.
905 * ospfd.c: (ospf_new) initialise abr_type to OSPF_ABR_DEFAULT
906 * ospf_vty.c: (no_ospf_abr_type_cmd) add standard as a negatable
907 abr_type. default abr_type should be OSPF_ABR_DEFAULT.
908 (ospf_config_write) test whether default abr_type against
909 OSPF_ABR_DEFAULT, rather than any specific ABR_TYPE.
910
hasso8469bd72005-06-20 20:50:10 +00009112005-06-20 Hasso Tepper <hasso at quagga.net>
hassof4833e92005-06-20 20:42:26 +0000912
913 * ospf_nsm.c: Make database exchange for NSSA database work.
914
paul7461d452005-06-13 13:57:16 +00009152005-06-13 Paul Jakma <paul.jakma@sun.com>
916
917 * ospf_spf.c: Try get more information on a SEGV under
918 ospf_spf_vertex_add_parent.
919 (ospf_vertex_free) NULL out the child and nexthop lists
920 (ospf_vertex_add_parent) nexthop and child can not be NULL
921 vertex_nexthop's parent->child list can not be NULL
922 (ospf_spf_next) w and cw are per-loop iteration variables, move
923 declarations into loop body.
924
hasso1ddd7292005-06-07 19:54:04 +00009252005-06-07 Hasso Tepper <hasso at quagga.net>
926
927 * ospf_apiserver.c: Fix obvious error in notifying clients about ISM
928 changes - oi->ifp->status doesn't give to us info about ISM,
929 oi->state does.
930
paul7e440862005-06-01 11:20:51 +00009312005-06-01 Akihiro Mizutani <mizutani@net-chef.net>
932
933 * ospf_ism.c (ospf_elect_bdr/ospf_elect_dr): Fix DR election bug.
934
paul500e4182005-05-26 17:11:13 +00009352005-05-26 Paul Jakma <paul.jakma@sun.com>
936
937 * ospf_abr.c: (ospf_abr_update_aggregate) Fix comment, cost bug itself
938 had been fixed long ago by Sowmini.
939
paula3387a42005-05-18 23:29:57 +00009402005-05-19 Paul Jakma <paul.jakma@sun.com>
941
942 * ospf_interface.c: (ospf_if_table_lookup) Fix a serious bug
943 a less serious one.
944 1: this function is supposed to lookup
945 entries in the oifs ospf_interface route_table and return either
946 an existing oi or NULL to indicate not found, its caller depends
947 on this, yet this function uses route_node_get which /always/
948 returns a route_node - one is created if none exists. Use
949 route_node_lookup instead. This should fix root cause of the
950 reports of the (ospf_add_to_if) assert being hit.
951 2: oi's are inserted into this table with prefixlength set to
952 /32 (indeed, it should be a hash table, not a route_table),
953 however prefixlength to lookup was not changed, if no valid entry
954 can be inserted other than /32, then nothng but /32 should be
955 looked up. This possibly only worked by fluke..
956 Fix confirmed by 2 reporters (one list, one IRC), definitely a
957 backport candidate once it has been incubated in HEAD for a while.
958 Thanks to Patrick Friedel and Ivan Warren for testing.
959
paul69310a62005-05-11 18:09:59 +00009602005-05-11 Paul Jakma <paul.jakma@sun.com>
961
962 * (general) Fix memory leaks in opaque AS-scope LSAs, reported and
963 with much debugging done by by scott collins <scollins@agile.tv>.
964 * ospf_lsa.c: (ospf_discard_from_db) dont call
965 ospf_ase_unregister_external_lsa for opaque-lsa's, opaques are
966 never registered with ase in the first place.
967 * ospf_packet.c: (general) Disabuse opaque related code of its
968 tendency to try gather up things into temporary lists.
969 (ospf_ls_upd) remove the temporary lists opaque uses, call
970 opaque functions inline, just like all other types.
971 (ospf_ls_ack) ditto.
972 (ospf_recv_packet) fixup sign warning.
973 * ospf_opaque.c: (general) fix the unneeded use of lists, and
974 untwist some of the logic.
975 (ospf_opaque_self_originated_lsa_received) take a single LSA
976 as argument, not a list of them. Remove the list loop. Logic
977 otherwise unchanged.
978 (ospf_opaque_ls_ack_received) Mostly ditto. But untwist the logic,
979 move the actions up into the switch block, remove the goto's and
980 sanitise the logic near the end a bit.
981 * ospf_opaque.h: Adjust definitions of aforementioned functions
982 in ospf_opaque.c to match.
983
paul42c98192005-05-07 02:22:51 +00009842005-05-07 Yar Tikhiy <yar@comp.chem.msu.su>
985
986 * ospf_network.c: Log ifindex on multicast membership leave/join
987 events.
988
paul4dadc292005-05-06 21:37:42 +00009892005-05-06 Paul Jakma <paul.jakma@sun.com>
990
991 * (general) extern and static qualifiers added.
992 unspecified arguments in definitions fixed, typically they should
993 be 'void'.
994 function casts added for callbacks.
995 Guards added to headers which lacked them.
996 Proper headers included rather than relying on incomplete
997 definitions.
998 gcc noreturn function attribute where appropriate.
999 * ospf_opaque.c: remove the private definition of ospf_lsa's
1000 ospf_lsa_refresh_delay.
1001 * ospf_lsa.h: export ospf_lsa_refresh_delay
1002 * ospf_packet.c: (ospf_make_md5_digest) make *auth_key const,
1003 correct thing to do - removes need for the casts later.
1004 * ospf_vty.c: Use vty.h's VTY_GET_INTEGER rather than ospf_vty's
1005 home-brewed versions, shuts up several warnings.
1006 * ospf_vty.h: remove VTY_GET_UINT32. VTY_GET_IPV4_ADDRESS and
1007 VTY_GET_IPV4_PREFIX moved to lib/vty.h.
1008 * ospf_zebra.c: (ospf_distribute_list_update_timer) hacky
1009 overloading of the THREAD_ARG pointer should at least use
1010 uintptr_t.
1011
paul9e67dc22005-04-15 12:10:17 +000010122005-04-15 Zhipeng Gong <zpgong@cdc.3upsystems.com>
1013
1014 * ospf_abr.c: (ospf_abr_announce_network_to_area) dont forget
1015 to approve LSAs for the case where metric has changed, lsa gets
1016 flushed otherwise. (backport candidate).
1017
ajs634f9ea2005-04-11 15:51:40 +000010182005-04-11 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1019
1020 * ospf_zebra.c (ospf_zebra_add): Call zclient_send_message instead
1021 of writen.
1022
ajsd2fc8892005-04-02 18:38:43 +000010232005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1024
ajse4319de2005-04-02 23:23:55 +00001025 * ospf_interface.h: (ospf_if_lookup_by_name) Remove declaration of a
1026 function that does not exist.
1027
10282005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1029
ajs21fefa92005-04-02 23:16:41 +00001030 * ospf_zebra.c: (zebra_interface_if_lookup) Must use
1031 if_lookup_by_name_len.
1032
10332005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1034
ajsa3491982005-04-02 22:50:38 +00001035 * ospf_interface.c: (ospf_vl_new) Use strnlen to fix call to if_create.
1036
10372005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1038
ajsd2fc8892005-04-02 18:38:43 +00001039 * ospf_vty.c: (show_ip_ospf_interface_sub) Show ifindex and interface
1040 flags to help with debugging.
1041 * ospf_zebra.c: (ospf_interface_delete) After deleting, set ifp->ifindex
1042 to IFINDEX_INTERNAL.
1043 (zebra_interface_if_lookup) Make function static. Tighten up code.
1044
ajsaca72fd2005-03-31 15:18:21 +000010452005-03-31 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1046
1047 * ospf_dump.c: (show_debugging_ospf) Show if ospf event debugging
1048 is turned on.
1049
ajsfd651fa2005-03-29 16:08:16 +000010502005-03-29 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1051
ajsa608bbf2005-03-29 17:03:49 +00001052 * ospf_zebra.c: (ospf_interface_state_up) If the MTU of an operative
1053 interface changes, print a debug message and call ospf_if_reset()
1054 to simulate down/up on the interface.
1055 * ospf_interface.h: Declare new function ospf_if_reset().
1056 * ospf_interface.c: (ospf_if_reset) New function to call ospf_if_down
1057 and ospf_if_up for all ospf interfaces attached to an interface.
1058
10592005-03-29 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1060
ajs5dcbdf82005-03-29 16:13:49 +00001061 * ospf_packet.c: (ospf_write_frags) Enhance error message to
1062 show MTU. Also make function static.
1063 (ospf_write) Enhance error message to show interface name and MTU.
1064 Also make function static.
1065
10662005-03-29 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1067
1068 * ospf_vty.c: (show_ip_ospf_interface_sub) Display interface MTU and
1069 bandwidth; this is useful for debugging problems. Also, the function
1070 should be static.
ajsfd651fa2005-03-29 16:08:16 +00001071
hasso1b639042005-03-27 13:32:25 +000010722005-03-27 Hasso Tepper <hasso at quagga.net>
1073
1074 * ospf_snmp.c: Don't crash in snmp query if ospf instance doesn't
1075 exist at all.
1076
hasso343f5cc2005-03-25 19:48:40 +000010772005-03-25 Hasso Tepper <hasso at quagga.net>
1078
1079 * ospfd.h: Include log.h, fixes compile with gcc-4.0.
1080
ajs9dbc7972005-03-13 19:27:22 +000010812005-03-13 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1082
1083 * ospf_lsa.c: (ospf_lsa_refresh_walker) If the system clock jumps
1084 backward, then current time may be less than
1085 ospf->lsa_refresher_started. This was causing invalid values
1086 for ospf->lsa_refresh_queue.index resulting in infinite loops.
1087 Problem fixed by casting the expression to unsigned before taking
1088 the modulus.
1089
ajs5c333492005-02-23 15:43:01 +000010902005-02-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1091
1092 * ospfd.h: Add new field struct stream *ibuf to struct ospf.
1093 * ospfd.c: (ospf_new) Check return code from ospf_sock_init.
1094 Allocate ibuf using stream_new(OSPF_MAX_PACKET_SIZE+1).
1095 (ospf_finish) Call stream_free(ospf->ibuf.
1096 * ospf_packet.c: (ospf_read) Call stream_reset(ospf->ibuf) and then
1097 pass it to ospf_recv_packet for use in receiving the packet
1098 (instead of allocating a new stream for each packet received).
1099 Eliminate all calls to stream_free(ibuf).
1100 (ospf_recv_packet) The struct stream *ibuf is now passed in as
1101 an argument. No need to use recvfrom to peek at the packet
1102 header (to see how big it is), just use ospf->ibuf which is
1103 always large enough (this eliminates a system call to recvfrom).
1104 Therefore, no need to allocate a stream just for this packet,
1105 and no need to free it when done.
1106
hasso462f20d2005-02-23 11:29:02 +000011072005-02-23 Vincenzo Eramo <eramo at infocom.ing.uniroma1.it>
1108
1109 * ospf_lsa.h: New flag to the LSA structure for the SPF calculation.
1110 * ospf_lsdb.h: Export ospf_lsdb_clean_stat() function.
1111 * ospf_spf.h: Add link to the LSA stat structure into vertex.
1112 * ospf_spf.c: New functions cmp() and update_stat() to manage
1113 candidates. Remove ospf_spf_has_vertex(), ospf_vertex_lookup(),
1114 ospf_install_candidate() and ospf_spf_register() functions not needed
1115 any more. Update ospf_vertex_new(), ospf_spf_next() and
1116 ospf_spf_calculate() functions to use pqueue instead of linked list.
1117
hassoe40dcce2005-02-21 14:58:42 +000011182005-02-21 Hasso Tepper <hasso at quagga.net>
1119
1120 * ospf_ase.c: Don't show messages related to the ase calculations if
1121 we are not debugging.
1122
hasso306541b2005-02-19 17:58:40 +000011232005-02-19 Hasso Tepper <hasso at quagga.net>
1124
1125 * ospf_api.h: char isn't always signed, but it has to be it here.
1126
paulfa81b712005-02-19 01:19:20 +000011272005-02-19 Paul Jakma <paul.jakma@sun.com>
1128
1129 * ospf_packet.c: (ospf_stream_copy) remove
1130 (ospf_packet_dup) use stream_copy instead of ospf_stream_copy
1131
ajs038163f2005-02-17 19:55:59 +000011322005-02-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1133
1134 * ospf_packet.c: (ospf_recv_packet) If there is somehow a runt
1135 packet in the queue, it must be discarded. Improve warning messages.
1136 Fix scope to static.
1137 (ospf_read) Fix bug: should reset the read thread in all cases
1138 to make sure we continue to get incoming messages.
1139
paul658b03a2005-02-15 10:10:55 +000011402005-02-15 Paul Jakma <paul.jakma@sun.com>
1141
1142 * ospf_packet.c: (ospf_recv_packet) Fix silly error wrt allocating
1143 ibuf. Thanks Andrew.
1144
paulbfdc44a2005-02-14 23:48:42 +000011452005-02-14 Paul Jakma <paul.jakma@sun.com>
1146
1147 * ospf_packet.c: (ospf_recv_packet) use stream_recvmsg.
1148
hasso082253f2005-02-11 08:31:54 +000011492005-02-11 Hasso Tepper <hasso at quagga.net>
1150
1151 * ospf_lsdb.c: Fix sum of checksums calculation.
1152
ajs083ee9d2005-02-09 15:35:50 +000011532005-02-09 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1154
1155 * ospf_packet.c: (ospf_write) If sendmsg fails, give more info in the
1156 error message.
1157
ajsba6454e2005-02-08 15:37:30 +000011582005-02-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1159
ajs8cfde372005-02-08 15:59:16 +00001160 * ospf_interface.h: Reduce structure padding by putting new u_char
1161 field multicast_memberships in a better spot (grouped with
1162 other u_char fields type and state).
1163
11642005-02-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1165
ajsba6454e2005-02-08 15:37:30 +00001166 * ospf_interface.h: Improve passive_interface comment. Add new
1167 multicast_memberships bitmask to struct ospf_interface to track
1168 active multicast subscriptions. Declare new function
1169 ospf_if_set_multicast.
1170 * ospf_interface.c: (ospf_if_set_multicast) New function to configure
1171 multicast memberships properly based on the current
1172 multicast_memberships status and the current values of the
1173 ospf_interface state, type, and passive_interface status.
1174 (ospf_if_up) Remove call to ospf_if_add_allspfrouters (this is
1175 now handled by ism_change_state's call to ospf_if_set_multicast).
1176 (ospf_if_down) Remove call to ospf_if_drop_allspfrouters (now
1177 handled by ism_change_state).
1178 * ospf_ism.c: (ospf_dr_election) Remove logic to join or leave
1179 the DRouters multicast group (now handled by ism_change_state's call
1180 to ospf_if_set_multicast).
1181 (ism_change_state) Add call to ospf_if_set_multicast to change
1182 multicast memberships as necessary to reflect the new interface state.
1183 * ospf_packet.c: (ospf_hello) When a Hello packet is received on a
1184 passive interface: 1. Increase the severity of the error message
1185 from LOG_INFO to LOG_WARNING; 2. Add more information to the error
1186 message (packet destination address and interface address);
1187 and 3. If the packet was sent to ospf-all-routers, then try
1188 to fix the multicast group memberships.
1189 (ospf_read) When a packet is received on an interface whose state
1190 is ISM_Down, enhance the warning message to show the packet
1191 destination address, and try to update/fix the multicast group
1192 memberships if the packet was sent to a multicast address.
1193 When a packet is received for ospf-designated-routers, but the
1194 current interface state is not DR or BDR, then increase the
1195 severity level of the error message from LOG_INFO to LOG_WARNING,
1196 and try to fix the multicast group memberships.
1197 * ospf_vty.c: (ospf_passive_interface) Call ospf_if_set_multicast for
1198 any ospf interface that may have changed from active to passive.
1199 (no_ospf_passive_interface) Call ospf_if_set_multicast for
1200 any ospf interface that may have changed from passive to active.
1201 (show_ip_ospf_interface_sub) Show multicast group memberships.
1202
paul3a9eb092005-02-08 11:29:41 +000012032005-02-08 Paul Jakma <paul@dishone.st>
1204
1205 * ospf_packet.c: (various) Remove unneeded stream_set_putp abuse.
1206
ajs847947f2005-02-02 18:38:48 +000012072005-02-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1208
1209 * ospf_packet.c: (ospf_read) Fix bug: must check for state ISM_Down,
1210 not for event ISM_InterfaceDown. And improve the message by
1211 adding the interface flags.
1212
ajs0b7d97d2005-01-30 17:24:02 +000012132005-01-30 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1214
1215 * ospf_network.c: (ospf_sock_init) Save errno before calling
1216 ospfd_privs.change.
1217
ajsc3eab872005-01-29 15:52:07 +000012182005-01-29 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1219
1220 * ospf_packet.c: (ospf_packet_add) If oi->obuf is NULL, print
1221 an error message and return.
1222 (ospf_read) If the interface state is ISM_InterfaceDown, issue
1223 a warning message and ignore the packet.
1224
gdt86f1fd92005-01-10 14:20:43 +000012252005-01-10 Greg Troxel <gdt@fnord.ir.bbn.com>
1226
1227 * ospf_packet.h: Remove commented out definition of
1228 OSPF_MAX_PACKET; neither it or the uncommented one are used any more.
1229
1230 * ospf_packet.c (ospf_make_ls_upd): Leave room for authentication
1231 when deciding if an update will fit.
1232 (ospf_packet_authspace): Factor out calculation of size required
1233 for authentication.
1234 (ospf_make_db_desc): Use ospf_max_packet, not OSPF_MAX_PACKET.
1235 Don't confuse readers that there is a macro.
1236
ajs3dc56b52004-12-30 15:11:19 +000012372004-12-30 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1238
1239 * ospf_network.c: Improve all setsockopt error messages to give detailed
1240 information on the arguments.
1241
ajsb87f7722004-12-29 20:41:26 +000012422004-12-29 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1243
ajs17eaa722004-12-29 21:04:48 +00001244 * ospf_packet.c: (ospf_db_desc) Reduce severity of "Negotiation done"
1245 messages from LOG_WARNING to LOG_INFO, since this seems to be
1246 normal.
1247
12482004-12-29 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1249
ajsb87f7722004-12-29 20:41:26 +00001250 * ospf_packet.c: (ospf_read) Always look up the interface if
1251 ospf_recv_packet returns NULL ifp, since some platforms such
1252 as Solaris 8 appear to support ifindex retrieval but don't.
1253
hasso1d806282004-12-22 09:43:20 +000012542004-12-22 Hasso Tepper <hasso at quagga.net>
1255
1256 * ospf_dump.c: Show debug configuration in vtysh.
hassoc6b87812004-12-22 13:09:59 +00001257 * ospf_vty.c: Fix "show ip ospf" output. Router can't be elected in
1258 any case if it's configured as "translate-never".
hassofe71a972004-12-22 16:16:02 +00001259 * ospf_lsdb.[ch]: New function to calculate sum of checksums.
1260 * ospf_vty.c: Bugfix to show really number of AS external LSAs, not
1261 number of all LSAs with AS scope, this includes opaque as LSAs as
1262 well, show this number separately. Show numbers and sums of
1263 checksums for each type of LSAs.
1264 * ospf_lsa.c: Calculate checksum before putting LSA into database.
hasso1d806282004-12-22 09:43:20 +00001265
ajsbc18d612004-12-15 15:07:19 +000012662004-12-15 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1267
1268 * ospf_interface.h: Declare new function ospf_default_iftype.
1269 * ospf_interface.c: (ospf_default_iftype) New function to centralize
1270 this logic in one place.
1271 * ospf_zebra.c: (ospf_interface_add) Use new function
1272 ospf_default_iftype.
1273 * ospf_vty.c: (no_ip_ospf_network,config_write_interface) Fix logic
1274 by using new function ospf_default_iftype.
1275
ajs3aa8d5f2004-12-11 18:00:06 +000012762004-12-11 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1277
1278 * ospf_packet.c: (ospf_db_desc) Should be static, not global.
1279 (ospf_hello,ospf_db_desc,ospf_ls_upd,ospf_ls_ack) Improve warning
1280 messages to include identifying information (e.g. router id).
1281 * ospf_nsm.c: (nsm_change_state) Improve info message to include
1282 router id and state names.
1283
gdt91f3e522004-12-09 14:51:03 +000012842004-12-09 Greg Troxel <gdt@fnord.ir.bbn.com>
1285
gdt3fb9de72004-12-09 16:30:04 +00001286 * ospf_apiserver.c (ospf_apiserver_term): Obtain struct
1287 ospf_apiserver * from listnode. Remove unused variables. Follows
1288 suggestion from Jay Fenlason.
gdt91f3e522004-12-09 14:51:03 +00001289
ajs9b0e25c2004-12-08 19:06:51 +000012902004-12-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1291
1292 * *.c: Change level of debug messages to LOG_DEBUG.
1293
ajs274a4a42004-12-07 15:39:31 +000012942004-12-07 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1295
1296 * ospf_main.c: (main) The 2nd argument to openzlog has been removed.
1297
ajs887c44a2004-12-03 16:36:46 +000012982004-12-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1299
ajs1210fa62004-12-03 16:43:24 +00001300 * ospf_packet.c: (ospf_db_desc) Reduce priority on a debug message
1301 from LOG_NOTICE to LOG_DEBUG.
1302
13032004-12-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1304
ajs887c44a2004-12-03 16:36:46 +00001305 * ospf_main.c: (sigint) Use zlog_notice for termination message.
1306 (main) Issue a startup announcement using zlog_notice.
1307
ajsbec595a2004-11-30 22:38:43 +000013082004-11-30 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1309
1310 * ospf_packet.c: (ospf_db_desc_proc) Fix spelling of packet in warning
1311 message and in comment.
1312 (ospf_db_desc) Warning message that a packet is being discarded
1313 should give the router id of the packet source. Fix spelling
1314 of packet in two warning messages.
1315 (ospf_ls_req) Warning message that a link state request is being
1316 discarded should give the router id of the neighbor that sent it.
1317
ajs5b85fac2004-11-26 19:36:42 +000013182004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1319
1320 * ospf_main.c: Remove #include "debug.h" (was not being used, and
1321 lib/debug.h has now been deleted).
1322
hassoc0652302004-11-25 19:33:48 +000013232004-11-25 Hasso Tepper <hasso at quagga.net>
1324
1325 * ospf_main.c: Make group to run as configurable.
1326
gdt69e13252004-11-15 18:51:15 +000013272004-11-15 Greg Troxel <gdt@fnord.ir.bbn.com>
1328
1329 * ospf_packet.c (ospf_recv_packet): Assume CMSG_SPACE is present
1330 and works (lib/zebra.h provides if OS doesn't).
1331
paul788dab12004-11-15 11:48:37 +000013322004-11-15 Paul Jakma <paul@dishone.st>
1333
1334 * ospf_{apiserver,te}.c: ospf_lsa_free's should be ospf_lsa_unlock.
1335
paul05e85fa2004-11-12 10:52:19 +000013362004-11-12 Paul Jakma <paul@dishone.st>
1337
1338 * ospf_ia.c: (process_summary_lsa) Only an ABR has any reason to
1339 ignore stub area summary default. Even so it seems a strange
1340 check, add a comment to that effect.
1341
paulf3ae74c2004-11-04 20:35:31 +000013422004-11-04 Paul Jakma <paul@dishone.st>
1343
1344 * ospfd.c: (ospf_network_match_iface) revert to previous network
1345 statement match behaviour.
1346
paul62d8e962004-11-02 20:26:45 +000013472004-11-02 Paul Jakma <paul@dishone.st>
1348
1349 * ospf_packet.c: (ospf_write_frags) remove iov arg, msg already points
1350 to it. Add convenience pointer to msg->msg_iov[1], and use this,
1351 fixing the unfortunate borkenness introduced in moving of this code
1352 to a function.
1353 (ospf_write) remove iovp and fix up call to previous.
1354 (ospf_ls_upd_packet_new) cast size to long int - unfortunately
1355 glibc's size_t format modifier is not portable.
1356
paul37ccfa32004-10-31 11:24:51 +000013572004-10-31 Paul Jakma <paul@dishone.st>
1358
1359 * ospf_packet.c: (ospf_write_frags) Add debug output
1360 (ospf_write) set type early, so we can pass it to
1361 ospf_write_frags.
1362 (ospf_ls_upd_packet_new) print size in debug output when too large
1363 packet is encountered.
paul64511f32004-10-31 18:01:13 +00001364 * ospf_zebra.c: (ospf_distribute_list_update_timer) Ugly misuse of
1365 THREAD_ARG to store an integer, but it should at least use same
1366 same type to retrieve the value. Assert value is sane.
paul37ccfa32004-10-31 11:24:51 +00001367
paulac191232004-10-22 12:05:17 +000013682004-10-22 Paul Jakma <paul@dishone.st>
1369
1370 * ospf_network.c: (ospf_sock_init) call neutral setsock_ifindex()
1371 function.
1372 * ospf_packet.c: (ospf_read) manually look up ifindex
paul4ccb2c42004-10-22 22:52:33 +00001373 if system could not have returned one, eg openbsd, thanks to Rivo
1374 Nurges for highlighting problem and fix.
paul06f953f2004-10-22 17:00:38 +00001375 Change setsockopt_pktinfo to setsockopt_ifindex.
paulac191232004-10-22 12:05:17 +00001376
hasso3fb9cd62004-10-19 19:44:43 +000013772004-10-19 Andrew J. Schorr <aschorr@telemetry-investments.com>
1378
1379 * ospf_snmp.c: (ospf_snmp_if_update) Fix logic to handle PtP links
1380 with dedicated subnets properly.
1381 * ospf_lsa.c: (lsa_link_ptop_set) ditto.
1382 * ospfd.c: (ospf_network_match_iface) ditto.
1383 (ospf_network_run) ditto.
1384 * ospf_interface.c: (ospf_if_is_configured) ditto.
1385 (ospf_if_lookup_by_prefix) ditto.
1386 (ospf_if_lookup_recv_if) ditto.
1387 * ospf_vty.c: (show_ip_ospf_interface_sub) Display the peer or
1388 broadcast address if present.
1389
hassod68614d2004-10-13 09:32:48 +000013902004-10-13 Hasso Tepper <hasso at quagga.net>
1391
1392 * ospf_main.c: Unbreak compilation with ospfapi disabled.
hassoc75105a2004-10-13 10:33:26 +00001393 * ospf_snmp.c: Remove defaults used to initialize smux connection to
1394 snmpd. Connection is initialized only if smux peer is configured.
hassod68614d2004-10-13 09:32:48 +00001395
hassof4d58ce2004-10-12 06:13:54 +000013962004-10-12 Hasso Tepper <hasso at quagga.net>
1397
1398 * ospf_main.c, ospf_opaque.c: Unbreak ospfclient compilation - move
1399 static variable from ospf_main.c into ospf_opaque.c.
1400
hassoc3abdb72004-10-11 16:27:03 +000014012004-10-11 Hasso Tepper <hasso at quagga.net>
1402
1403 * ospf_main.c, ospf_opaque.c: Disable ospfapi init by default. New
1404 command line switch to enable it.
1405
paul6b333612004-10-11 10:11:25 +000014062004-10-11 Paul Jakma <paul@dishone.st>
1407
1408 * ospf_dump.c: (ospf_ip_header_dump) Assume header is in host order
1409 remove ntohs that should have dissappeared. Take struct ip
1410 as argument, caller has to know there's an IP header at start of
1411 stream anyway.
1412 * ospf_dump.h: update declaration of ospf_ip_header_dump.
1413 * ospf_packet.c: (ospf_write) correct call to
1414 sockopt_iphdrincl_swab_htosys which was munging the header.
1415 (ospf_recv_packet) ip_len is needed for old OpenBSD fixup.
1416 (ospf_read) sockopt_iphdrincl_swab_systoh ip header as soon as
1417 we have it.
paul6c835672004-10-11 11:00:30 +00001418 * (global) Const char update and signed/unsigned fixes.
1419 * (various headers) size defines should be unsigned.
1420 * ospf_interface.h: remove duplicated defines, include the
1421 authoritative header - though, these defines should probably
1422 be moved to a dedicated header, or ospfd.h.
1423 * ospf_lsa.h: (struct lsa) ls_seqnum should be unsigned.
1424 * ospf_packet.c: (ospf_write) cast result of shift to unsigned.
paul6b333612004-10-11 10:11:25 +00001425
hassoeb1ce602004-10-08 08:17:22 +000014262004-10-08 Hasso Tepper <hasso at quagga.net>
1427
1428 * *.[c|h]: Fix compiler warnings: make some strings const, signed ->
1429 unsigned, remove unused variables etc.
1430
gdt54ade992004-10-07 19:38:20 +000014312004-10-07 Greg Troxel <gdt@claude.ir.bbn.com>
1432
1433 * ospf_apiserver.c (ospf_apiserver_unregister_opaque_type): Don't
1434 use of variable names 'node' and 'nextnode' to avoid possible
1435 conflict with list macros. Move variable declaration inside for
1436 loop after a statement to top of function.
1437
paulaa20c6f2004-10-07 14:19:36 +000014382004-10-07 Paul Jakma <paul@dishone.st>
1439
1440 * ospf_snmp.c: Missed list typedef update
1441 * ospf_dump.c: Include sockopt.h for header swab functions.
1442
paul18b12c32004-10-05 14:38:29 +000014432004-10-05 Paul Jakma <paul@dishone.st>
1444
1445 * ospf_packet.c: replace ospf_swap_iph_to... with
1446 sockopt_iphdrincl_swab_...
1447
hasso18a6dce2004-10-03 18:18:34 +000014482004-10-03 James R. Leu <jleu at mindspring.com>
1449
1450 * ospf_zebra.c: Read router id related messages from zebra daemon.
1451 Schedule router-id update thread if it's changed.
1452 * ospfd.c: Remove own router-id selection function. Use router id from
1453 zebra daemon if it isn't manually overriden in configuration.
1454
paul68defd62004-09-27 07:27:13 +000014552004-09-27 Paul Jakma <paul@dishone.st>
1456
paul6a99f832004-09-27 12:56:30 +00001457 * ospf_dump.c: (ospf_ip_header_dump) Use HAVE_IP_HDRINCL_BSD_ORDER
1458 Apply to offset too. Print ip_cksum, lets not worry about
1459 possible 2.0.37 compile problems.
1460 * ospf_packet.c: (ospf_swap_iph_to{n,h}) Use
1461 HAVE_IP_HDRINCL_BSD_ORDER.
1462 (ospf_recv_packet) ditto.
1463 (ospf_write) Fixup iov argument to ospf_write_frags.
1464 (struct msghdr).msg_name is caddr_t on most platforms.
paul68defd62004-09-27 07:27:13 +00001465 (ospf_recv_packet) ditto. And msg_flags is not always there
1466 memset struct then set fields we care about rather than
1467 initialise all fields individually.
1468
hassoc9e52be2004-09-26 16:09:34 +000014692004-09-26 Hasso Tepper <hasso at quagga.net>
1470
1471 * ospf_abr.c, ospf_dump.c, ospf_lsa.c, ospf_packet.c, ospf_vty.c,
1472 ospf_zebra.c: Fix compiler warnings.
1473
paul87d6f872004-09-24 08:01:38 +000014742004-09-24 Paul Jakma <paul@dishone.st>
1475
1476 * ospf_apiserver.{c,h}: lists typedef removal cleanup.
1477 update some list loops to LIST_LOOP. some miscellaneous indent
1478 fixups.
1479 (ospf_apiserver_unregister_opaque_type) fix listnode_delete of
1480 referenced node in loop.
paul1603c062004-09-24 08:23:24 +00001481 (ospf_apiserver_term) loops calling ospf_apiserver_free, which
1482 deletes referenced nodes from apiserver_list, fixed.
paul87d6f872004-09-24 08:01:38 +00001483 * ospf_interface.h: lists typedef removal cleanup.
1484 * ospf_opaque.{c,h}: lists typedef removal cleanup. update some list
1485 loops to LIST_LOOP. miscellaneous style and indent fixups.
1486 * ospf_te.{c,h}: ditto
1487 * ospf_packet.c: lists typedef removal cleanup.
paula2570682004-09-24 08:09:57 +00001488 (ospf_write) ifdef fragmentation support. move actual
1489 fragmentation out to a new, similarly ifdefed, function.
1490 (ospf_write_frags) fragmented write support, moved from previous.
paul87d6f872004-09-24 08:01:38 +00001491
hasso52dc7ee2004-09-23 19:18:23 +000014922004-09-23 Hasso Tepper <hasso at quagga.net>
1493
1494 * *.[c|h]: list -> struct list *, listnode -> struct listnode *.
1495
paul68b73392004-09-12 14:21:37 +000014962004-09-12 Paul Jakma <paul@dishone.st>
1497
1498 * ospf_packet.c: Fix bugzilla #107
1499 (ospf_packet_max) get rid of the magic 88 constant
1500 (ospf_swab_iph_ton) new function. set ip header to network order,
1501 taking BSDisms into account.
1502 (ospf_swab_iph_toh) the inverse.
1503 (ospf_write) Add support for IP fragmentation, will only work on
1504 linux though, other kernels make it impossible. get rid of the
1505 magic 4 constant.
1506 (ospf_make_ls_upd) Bound check to end of stream, not to
1507 interface mtu.
1508 (ospf_ls_upd_packet_new) New function, allocate upd packet
1509 taking oversized LSAs into account.
1510 (ospf_ls_upd_queue_send) use ospf_ls_upd_packet_new to allocate,
1511 rather than statically allocating mtu sized packet buffer, which
1512 actually was wrong - it didnt take ip header into account, which
1513 should not be included in packet buffer.
1514 (ospf_ls_upd_send_queue_event) minor tweaks and remove
1515 TODO comment.
1516
gdt630e4802004-08-31 17:28:41 +000015172004-08-31 David Wiggins <dwiggins@bbn.com>
1518
1519 * ospf_spf.c (ospf_spf_calculate): Many more comments and debug
1520 print statements. New function ospf_vertex_dump used in debugging.
1521
15222004-08-31 David Wiggins <dwiggins@bbn.com>
1523
1524 * ospf_spf.h (struct vertex): Comments for flags and structure members.
1525
15262004-08-31 David Wiggins <dwiggins@bbn.com>
1527
1528 * ospf_route.c: When finding an alternate route, log cost as well.
1529
15302004-08-31 David Wiggins <dwiggins@bbn.com>
1531
1532 * ospf_interface.c (ospf_lookup_if_params): Initialize af in
1533 struct prefix allocated on stack.
1534
15352004-08-31 David Wiggins <dwiggins@bbn.com>
1536
1537 * ospf_packet.c (ospf_ls_ack_send_delayed): In p2mp mode, send
1538 acks to AllSPFRouters, rather than All-DR.
1539
hasso7b901432004-08-31 13:37:42 +000015402004-08-27 Hasso Tepper <hasso at quagga.net>
1541
1542 * ospf_vty.c: Don't print ospf network type under interface only
1543 if interface is in broadcast mode and interface type really is
1544 broadcast. Fixes Bugzilla #108.
1545
gdtd7d93992004-08-27 12:03:42 +000015462004-08-27 David Wiggins <dwiggins@bbn.com>
1547
1548 * ospf_spf.c (ospf_nexthop_calculation): Initialize address family
1549 in on-stack struct prefix_ipv4. Fixes point-to-multipoint SPF
1550 calculation.
1551
gdtd0deca62004-08-26 13:14:07 +000015522004-08-26 Greg Troxel <gdt@fnord.ir.bbn.com>
1553
1554 * ospf_packet.c (ospf_recv_packet): adjust size declaration of
gdtd7d93992004-08-27 12:03:42 +00001555 buffer used to get interface index so that it compiles on other
1556 than Linux and includes the required alignment space. Probably
1557 this was only working on sparc/sparc64 because most of
1558 sockaddr_dl was not being written.
gdtd0deca62004-08-26 13:14:07 +00001559
paul863082d2004-08-19 04:43:43 +000015602004-08-19 Paul Jakma <paul@dishone.st>
1561
1562 * ospf_packet.c: update to match sockopt renames.
1563
paul75ee0b82004-08-05 09:10:31 +000015642004-08-04 Paul Jakma <paul@dishone.st>
1565
1566 * ospf_spf.c: (ospf_spf_consider_nexthop) Add comment about issue.
1567 Compare only against list head - all nexthops must be same cost
1568 anyway, fixes a reference-listnode-after-delete bug noted by
1569 Kir Kostuchenko.
1570 (ospf_nexthop_calculation) Use ospf_spf_consider_nexthop for all
1571 candidates attached to root.
1572
paul36c64ef2004-07-27 11:19:11 +000015732004-07-27 Paul Jakma <paul@dishone.st>
1574
paul48fe13b2004-07-27 17:40:44 +00001575 * ospf_packet.c: (ospf_ls_upd_send_queue_event) fix thinko from
1576 last fix for ospfd wedging due to oversize LSAs: dont list loop on
1577 ospf_ls_upd_queue_send() - guaranteed segfault.
1578
15792004-07-27 Paul Jakma <paul@dishone.st>
1580
paul36c64ef2004-07-27 11:19:11 +00001581 * ospf_opaque.c: (ospf_opaque_lsa_flush_schedule) do not NULL out
1582 the LSA as then free_opaque_info_per_id() can never unlock (and
1583 free) the LSA. Reported by Gunnar Stigen.
1584
paul2dd8bb42004-07-23 15:13:48 +000015852004-07-23 Paul Jakma <paul@dishone.st>
1586
1587 * ospf_network.c: Replace PKTINFO/RECVIF with call to
1588 setsockopt_pktinfo
1589 * ospf_packet.c: Use getsockopt_pktinfo_ifindex and
1590 SOPT_SIZE_CMSG_PKTINFO_IPV4.
1591
paul59ea14c2004-07-14 20:50:36 +000015922004-07-14 Paul Jakma <paul@dishone.st>
1593
1594 * ospf_packet.c: (ospf_ls_upd_send_queue_event) Partial fix for
1595 problem reported by Peter Frost amongst others, where function
1596 will spin indefinitely if update list contains LSAs greater than
1597 MTU-headers or other condition leading to update list never being
1598 cleared. Problem of what to do with these LSAs remains.
1599 (ospf_make_ls_upd) add comment about large LSA problem,
1600 indentation cleanup.
1601
gdtb2c1b282004-07-01 12:35:36 +000016022004-07-01 Greg Troxel <gdt@fnord.ir.bbn.com>
1603
1604 * Makefile.am (lib_LTLIBRARIES): make libospf shared
1605
gdt87efd642004-06-30 17:36:11 +000016062004-06-30 Greg Troxel <gdt@poblano.ir.bbn.com>
1607
1608 * Makefile.am: Add shlib support.
1609
hassobeebba72004-06-20 21:00:27 +000016102004-06-10 Hasso Tepper <hasso@estpak.ee>
1611
1612 * *: Removed ifdefs HAVE_NSSA.
1613
paul553ff112004-06-06 09:41:00 +000016142004-06-06 Paul Jakma <paul@dishone.st>
1615
1616 * ospf_dump.c,ospf_lsa.c: Fix typos of merge of previous.
1617 ospf_flood.c: (ospf_process_self_originated_lsa) fix zlog format
1618
paul0c2be262004-05-31 14:16:54 +000016192004-05-31 Sagun Shakya <sagun.shakya@sun.com>
1620
1621 * ospf_dump.c: (ospf_lsa_header_dump) LOOKUP can return null if
1622 index is out of range.
1623 ospf_flood.c: endianness fix
1624 ospf_lsa.c: Missing ntohl's on (struct lsa *)->data->ls_seqnum
1625 in various places.
1626
hassodd669bb2004-05-10 07:43:59 +000016272004-05-10 Hasso Tepper <hasso@estpak.ee>
1628
1629 * ospf_zebra.c, ospfd.c: Move ospf_prefix_list_update() function
1630 to ospf_zebra.c from ospfd.c and add redistribution updates if
1631 route-map is used in redistribution.
1632 * ospf_main.c: Remove now useless call to ospf_init().
1633
paul0a589352004-05-08 11:48:26 +000016342004-05-08 Paul Jakma <paul@dishone.st>
1635
1636 * ospf_zebra.c: Sync with lib/zclient changes
1637
pauld3f0d622004-05-05 15:27:15 +000016382004-05-05 Paul Jakma <paul@dishone.st>
1639
paul5bd41892004-05-05 17:29:24 +00001640 * ospf_network.c: (ospf_sock_init) Check whether IP_HDRINCL is
1641 defined. Warn at compile and runtime. Use
1642 IPTOS_PREC_INTERNETCONTROL otherwise.
pauld3f0d622004-05-05 15:27:15 +00001643 * ospf_packet.c: (ospf_associate_packet_vl) cleanup, move
1644 some of the checks up to ospf_read, return either a
1645 virtual link oi, or NULL.
1646 (ospf_read) Cleanup, make it responsible for checks. Remove
1647 the nbr lookup - moved to ospf_neighbor. Adjust all nbr
1648 lookups to use new wrappers exported by ospf_neighbor.
1649 * ospf_neighbor.h: Add ospf_neigbour_get and ospf_nbr_lookup.
1650 * ospf_neighbor.c: (ospf_neigbour_get) Index ospf_interface
1651 neighbour table by router-id for virtual-link ospf_interfaces,
1652 not by peer_addr (which breaks for asymmetric vlinks)
1653 (ospf_nbr_lookup) add a wrapper for nbr lookups to deal with
1654 above.
paulcd59da62004-05-05 17:26:55 +00001655 * ospf_interface.c: (ospf_vl_set_params) Catch changes of interface
1656 address for either end of a virtual-link, and hence potential cost
1657 changes.
1658
hassoa0a39762004-04-23 08:51:10 +000016592004-04-22 Hasso Tepper <hasso@estpak.ee>
1660
1661 * ospf_zebra.c: Don't ignore reject/bh routes, it's the only way
1662 to "summarize" routes in ASBR at the moment.
1663
hasso8585d4e2004-04-20 17:25:12 +000016642004-04-20 Hasso Tepper <hasso@estpak.ee>
1665
1666 * ospfd.c: Unset NP flag if area is going to be normal or stub.
1667 Fixes UNH OSPF_NSSA.1.2a comment.
1668 * ospf_abr.c: Originate default into stub/nssa area even if
1669 summaries are disabled.
1670 * ospf_zebra.c: Don't attempt to redistribute 127.0.0.0/8.
1671
hassoc266ac72004-04-19 17:31:00 +000016722004-04-19 Hasso Tepper <hasso@estpak.ee>
1673
1674 * ospf_vty.c: Don't warn that export- and import-list can't be
1675 configured to backbone area if they are applied and are working
1676 fine.
1677
hasso128d31d2004-04-04 12:52:33 +000016782004-02-19 Sowmini Varadhan <sowmini.varadhan@sun.com>
1679
1680 * ospf_packet.c: Don't drop packets in Solaris x86.
1681 [quagga-dev 1005].
1682
hasso0d85b992004-03-18 19:18:33 +000016832004-03-18 Amir Guindehi <amir@datacore.ch>
1684
1685 * ospf_opaque.c: Attempt to correct the incorrect behavior of
1686 Quagga's ospfd in the special situation that a node's opaque
1687 capability has changed as "ON -> OFF -> ON". [quagga-dev 843].
1688
paul7f352b82004-02-19 19:37:47 +000016892004-02-19 Sowmini Varadhan <sowmini.varadhan@sun.com>
1690
1691 * ospf_abr.c: (ospf_abr_update_aggregate) UNH 3.12b,c, address range
1692 should be configured with the highest cost path within the range,
1693 not lowest.
1694
paul940b01a2004-02-17 20:07:30 +000016952004-02-17 Paul Jakma <paul@dishone.st>
1696
1697 * ospf_zebra.c: (ospf_interface_delete) Do not delete the interface
1698 params, nor the interface structure, if an interface delete
1699 message is received from zebra.
1700 * ospf_interface.c: (ospf_if_delete_hook) Delete the interface
1701 params and interface, ie that which was previously removed in
1702 (ospf_interface_delete) above.
1703
hasso2db3d052004-02-11 21:52:13 +000017042004-02-11 Hasso Tepper <hasso@estpak.ee>
1705 * ospf_interface.c, ospf_zebra.c: Don't attempt to read path->oi->ifp
1706 if oi doesn't exist any more.
1707
hassocb05eb22004-02-11 21:10:19 +000017082004-02-11 Vadim Suraev <vadim.suraev@terayon.com>
1709 * ospf_packet.c (ospf_ls_upd): Router should flush received network
1710 LSA if it was originated with older router-id ([zebra 14710] #6).
1711
17122003-12-08 Mattias Amnefelt <mattiasa@kth.se>
paul239aecc2003-12-08 10:34:54 +00001713
1714 * ospf_packet.c: (ospf_recv_packet) OpenBSD now leaves iph.ip_len
1715 network byte order.
1716
gdt8f40e892003-12-05 14:01:43 +000017172003-12-05 Greg Troxel <gdt@poblano.ir.bbn.com>
1718
1719 * ospfd.c (ospf_network_match_iface): Rewrite code for clarity
1720 while trying not to change semantics. Add ifdefed-out code to
1721 avoid matching ppp interfaces whose destination address does not
1722 also match the prefix under consideration, to help out people with
1723 problems due to as-yet-unfixed bugs with p2p interfaces coming and
1724 going.
1725
paul736d3442003-07-24 23:22:57 +000017262003-07-25 kamatchi soundaram <kamatchi@tdd.sj.nec.com>
1727
1728 * ospf_packet.c (ospf_ls_upd_send_queue_event): get next route
1729 node in body of the loop to avoid chance that route node
1730 is unlocked and deleted before the next iteration tries to
1731 get next route node.
1732
paul0a825c72003-05-24 13:48:16 +000017332003-05-24 Kenji Yabuuchi
1734
1735 * ospf_interface.c(ospf_if_lookup_recv_if): Use the most specific
1736 match for interface lookup.
1737
paul551a8972003-05-18 15:22:55 +000017382003-05-18 Hasso Tepper <hasso@estpak.ee>
paul445f1432003-05-16 19:00:31 +00001739
paul551a8972003-05-18 15:22:55 +00001740 * ospf_vty.c: Show NSSA LSA route info in "show ip ospf database"
1741 output
paul445f1432003-05-16 19:00:31 +00001742
pauld7480322003-05-16 17:31:51 +000017432003-05-16 Hasso Tepper <hasso@estpak.ee>
1744
1745 * ospf_lsa.c: Fix handling of NSSA
1746
paul551a8972003-05-18 15:22:55 +000017472003-04-23 Hasso Tepper <hasso@estpak.ee>
1748
1749 * ospf_vty.c: fix "router xxx" node commands in vtysh
1750
paul445f1432003-05-16 19:00:31 +000017512003-04-19 Hasso Tepper <hasso@estpak.ee>
1752
1753 * {ospf_abr,ospfd}.c: area id's DECIMAL -> ADDRESS
1754 * ospf_routemap.c: sync daemon's route-map commands to have same
1755 syntax.
1756
17572003-04-19 Sergey Vyshnevetskiy <serg@vostok.net>
1758
1759 * ospf_packet.c: Add missing param to zlog
1760 * ospf_flood.c: remove unused vars
1761
17622003-04-17 Denis Ovsienko <zebra@pilot.org.ua>
1763
1764 * ospf_interface.c: fix incorrect memset
1765
paul28a13842003-05-16 20:30:37 +000017662003-04-10 Amir Guindehi <amir@datacore.ch>
paul445f1432003-05-16 19:00:31 +00001767
1768 * ospf_lsa.[ch]: opaque LSA fix, use ospf_lookup.
1769
17702003-04-03 David Watson <dwatson@eecs.umich.edu>
1771
1772 * ospf_lsa.c: byte order fix
1773
paul07661cb2003-03-18 00:03:05 +000017742002-03-17 Amir Guindehi <amir@datacore.ch>
1775
1776 * ospf_apiserver.[ch]: Merge Ralph Keller's OSPFAPI support.
1777 * ospf_api.[ch]: Merge Ralph Keller's OSPFAPI support.
1778 * ospfclient: OSPFAPI demonstration client.
1779
17802003-01-23 Masahiko Endo <endo@suri.co.jp>
1781
1782 * ospf_ism.c: NSM event schedule bug fix.
1783
17842002-10-30 Greg Troxel <gdt@ir.bbn.com>
1785
1786 * ospf_packet.c (ospf_make_md5_digest): MD5 length fix.
1787
paul718e3742002-12-13 20:15:29 +000017882002-10-23 endo@suri.co.jp (Masahiko Endo)
1789
1790 * ospf_opaque.c: Update Opaque LSA patch.
1791
17922002-10-23 Ralph Keller <keller@tik.ee.ethz.ch>
1793
1794 * ospf_vty.c (show_ip_ospf_database): Fix CLI parse.
1795
17962002-10-23 Juris Kalnins <juris@mt.lv>
1797
1798 * ospf_interface.c (ospf_if_stream_unset): When write queue
1799 becomes empty stop write timer.
1800
18012002-10-10 Greg Troxel <gdt@ir.bbn.com>
1802
1803 * ospf_packet.c (ospf_check_md5_digest): Change >= to > to make it
1804 conform to RFC.
1805
18062002-07-07 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1807
1808 * zebra-0.93 released.
1809
18102002-06-19 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1811
1812 * ospf_spf.c (ospf_nexthop_calculation): Add NULL set to oi and
1813 check of l2. Reported by: Daniel Drown <dan-zebra@drown.org>
1814 (ospf_lsa_has_link): LSA Length calculation fix. Reported by:
1815 Paul Jakma <paulj@alphyra.ie>.
1816
1817 * ospfd.c (ospf_if_update): Fix nextnode reference bug. Reported
1818 by: juris@mt.lv.
1819
18202002-01-21 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1821
1822 * ospfd.c: Merge [zebra 11445] Masahiko ENDO's Opaque-LSA support.
1823
18242001-08-27 Kunihiro Ishiguro <kunihiro@zebra.org>
1825
1826 * ospf_interface.c (ospf_add_to_if): Use /32 address to register
1827 OSPF interface information.
1828 (ospf_delete_from_if): Likewise.
1829
1830 * ospf_zebra.c (ospf_interface_address_delete): Likewise.
1831
18322001-08-23 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1833
1834 * ospf_zebra.c (ospf_redistribute_unset): When redistribute type
1835 is OSPF, do not unset redistribute flag.
1836
18372001-08-19 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1838
1839 * zebra-0.92a released.
1840
18412001-08-15 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1842
1843 * zebra-0.92 released.
1844
18452001-08-12 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1846
1847 * ospfd.c (ospf_config_write): auto-cost reference-bandwidth
1848 configuration display.
1849
18502001-07-24 David Watson <dwatson@eecs.umich.edu>
1851
1852 * ospf_spf.c (ospf_spf_next): Modify ospf_vertex_add_parent to
1853 check for an existing link before connecting the parent and child.
1854 ospf_nexthop_calculation is also modified to check for duplicate
1855 entries when copying from the parent. Finally, ospf_spf_next
1856 removes duplicates when it merges two equal cost candidates.
1857
18582001-07-23 itojun@iijlab.net
1859
1860 * ospfd.c (show_ip_ospf_neighbor): Check ospf_top before use it
1861 [zebra 8549].
1862
18632001-07-23 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1864
1865 * ospf_packet.c (ospf_write): Remove defined(__OpenBSD__) to make
1866 it work on OpenBSD.
1867
18682001-06-26 Kunihiro Ishiguro <kunihiro@zebra.org>
1869
1870 * ospf_zebra.c (config_write_ospf_default_metric): Display
1871 default-metric configuration.
1872
18732001-06-18 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1874
1875 * ospf_ia.h (OSPF_EXAMINE_SUMMARIES_ALL): Remove old macros.
1876
18772001-05-28 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1878
1879 * ospf_snmp.c (ospfIfEntry): Fix interface lookup bug to avoid
1880 crush.
1881 (ospfIfMetricEntry): Likewise.
1882
18832001-03-18 Kunihiro Ishiguro <kunihiro@zebra.org>
1884
1885 * ospf_packet.c (ospf_read): Fix typo. Reported by: "Jen B
1886 Lin'Kova" <jen@stack.net>.
1887
18882001-03-15 Gleb Natapov <gleb@nbase.co.il>
1889
1890 * ospf_interface.c (ip_ospf_network): Set interface parameter.
1891 (interface_config_write): Add check for OSPF_IFTYPE_LOOPBACK.
1892
1893 * ospf_zebra.c (ospf_interface_add): Set interface parameter.
1894
18952001-02-21 Kunihiro Ishiguro <kunihiro@zebra.org>
1896
1897 * ospf_packet.c (ospf_recv_packet): Solaris also need to add
1898 (iph.ip_hl << 2) to iph.ip_len.
1899
19002001-02-09 Kunihiro Ishiguro <kunihiro@zebra.org>
1901
1902 * ospfd.h (OSPF_LS_REFRESH_TIME): Fix OSPF_LS_REFRESH_TIME value.
1903 Suggested by: David Watson <dwatson@eecs.umich.edu>.
1904
1905 * ospf_zebra.c (zebra_init): Remove zebra node.
1906
1907 * ospfd.c (ospf_area_range_set): Function name is changed from
1908 ospf_ara_range_cmd.
1909 (ospf_area_range_unset): New function which separated from DEFUN.
1910 New commands are added:
1911 "no area A.B.C.D range A.B.C.D/M advertise"
1912 "no area <0-4294967295> range A.B.C.D/M advertise"
1913 "no area A.B.C.D range A.B.C.D/M not-advertise"
1914 "no area <0-4294967295> range A.B.C.D/M not-advertise"
1915
1916 * ospf_lsa.c (ospf_lsa_more_recent): Fix previous change.
1917
19182001-02-08 Matthew Grant <grantma@anathoth.gen.nz>
1919
1920 * ospf_network.c (ospf_if_add_allspfrouters): Use
1921 setsockopt_multicast_ipv4.
1922 (ospf_if_drop_allspfrouters): Likewise.
1923
1924 * ospf_lsa.c (ospf_router_lsa_install): Add rt_recalc flag.
1925 (ospf_network_lsa_install): Likewise.
1926 (ospf_summary_lsa_install): Likewise.
1927 (ospf_summary_asbr_lsa_install): Likewise.
1928 (ospf_external_lsa_install): Likewise.
1929 (ospf_lsa_install): Call ospf_lsa_different to check this LSA is
1930 new one or not.
1931
19322001-02-08 Kunihiro Ishiguro <kunihiro@zebra.org>
1933
1934 * ospf_zebra.c (ospf_interface_delete): Do not free interface
1935 structure when ospfd receive interface delete message to support
1936 pseudo interface.
1937
19382001-02-01 Dick Glasspool <dick@ipinfusion.com>
1939
1940 * ospfd.c (area_range_notadvertise): Change area range "suppress"
1941 command to "not-advertise".
1942
1943 * ospfd.h (OSPF_LS_REFRESH_TIME): Change OSPF_LS_REFRESH_TIME from
1944 1800 to 60.
1945
1946 * ospf_abr.c (ospf_abr_update_aggregate): When update_aggregate is
1947 updating the area-range, the lowest cost is now saved.
1948
1949 * ospf_lsa.c (ospf_lsa_more_recent): Routing to compare sequence
1950 numbers rather than creating overflow during calculation.
1951
19522001-02-01 Kunihiro Ishiguro <kunihiro@zebra.org>
1953
1954 * zebra-0.91 is released.
1955
19562001-01-31 Kunihiro Ishiguro <kunihiro@zebra.org>
1957
1958 * ospf_packet.c (ospf_db_desc_proc): Do not continue process when
1959 NSM_SeqNumberMismatch is scheduled.
1960 (ospf_ls_req): Free ls_upd when return from this function.
1961 (ospf_ls_upd_timer): When update list is empty do not call
1962 ospf_ls_upd_send(). Suggested by: endo@suri.co.jp (Masahiko
1963 Endo).
1964
19652001-01-26 Kunihiro Ishiguro <kunihiro@zebra.org>
1966
1967 * ospf_lsa.c (ospf_maxage_flood): Flood LSA when it reaches
1968 MaxAge. RFC2328 Section 14.
1969 (ospf_maxage_lsa_remover): Call above function during removing
1970 MaxAge LSA.
1971
19722001-01-26 Dick Glasspool <dick@ipinfusion.com>
1973
1974 * ospf_flood.c (ospf_flood_through_as): Function is updated for
1975 NSSA Translations now done at ospf_abr.c with no change in P-bit.
1976
1977 * ospf_lsa.c (ospf_get_nssa_ip): Get 1st IP connection for Forward
1978 Addr.
1979 (ospf_install_flood_nssa): Leave Type-7 LSA at Lock Count = 2.
1980
1981 * ospf_ase.c (ospf_ase_calculate_route): Add debug codes.
1982
1983 * ospf_abr.c (ospf_abr_translate_nssa): Recalculate LSA checksum.
1984
1985 * ospf_packet.h (OSPF_SEND_PACKET_LOOP): Added for test packet.
1986
1987 * ospf_dump.c (ospf_lsa_type_msg): Add OSPF_GROUP_MEMBER_LSA and
1988 OSPF_AS_NSSA_LSA.
1989
1990 * ospfd.c (data_injection): Function to inject LSA. This is
1991 debugging command.
1992
19932001-01-11 Kunihiro Ishiguro <kunihiro@zebra.org>
1994
1995 * ospf_route.c (ospf_route_match_same): Remove function.
1996 (ospf_route_match_same_new): Renamed to ospf_route_match_same.
1997
1998 * ospf_zebra.c (ospf_interface_address_delete): Add check for
1999 oi->address. Suggested by Matthew Grant
2000 <grantma@anathoth.gen.nz>.
2001 (ospf_zebra_add): Remove function.
2002 (ospf_zebra_add_multipath): Rename to ospf_zebra_add.
2003
2004 * ospf_interface.c: Remove HAVE_IF_PSEUDO part.
2005
2006 * ospf_zebra.c: Likewise.
2007
20082001-01-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2009
2010 * ospf_ase.c: Remove OLD_RIB part.
2011
2012 * ospf_route.c: Likewise.
2013
2014 * zebra-0.90 is released.
2015
2016 * ospf_packet.c (ospf_recv_packet): Use ip_len adjestment code to
2017 NetBSD.
2018
20192001-01-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2020
2021 * ospf_route.c (ospf_route_delete): Use
2022 ospf_zebra_delete_multipath.
2023
20242001-01-09 Matthew Grant <grantma@anathoth.gen.nz>
2025
2026 * ospf_interface.c (ospf_if_cleanup): Function name is renamed
2027 from ospf_if_free(). Rewrite whole procudure to support primary
2028 address deletion.
2029
2030 * ospf_zebra.c (ospf_interface_address_delete): Add primary
2031 address deletion process.
2032
20332001-01-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2034
2035 * ospf_packet.c (ospf_recv_packet): OpenBSD has same ip_len
2036 treatment like FreeBSD.
2037
20382001-01-09 endo@suri.co.jp (Masahiko Endo)
2039
2040 * ospf_packet.c (ospf_recv_packet): FreeBSD kernel network code
2041 strips IP header size from receiving IP Packet. So we adjust
2042 ip_len to whole IP packet size by adding IP header size.
2043
20442001-01-08 endo@suri.co.jp (Masahiko Endo)
2045
2046 * ospf_network.c (ospf_serv_sock): When socket() is failed return
2047 immediately.
2048 (ospf_serv_sock): Close socket when it is not used.
2049
2050 * ospf_packet.c (ospf_write): Set sin_len when HAVE_SIN_LEN is
2051 defined.
2052 (ospf_write): When bind is fined, close sock.
2053
20542001-01-07 Gleb Natapov <gleb@nbase.co.il>
2055
2056 * ospf_zebra.c (ospf_interface_state_up): Fixes coredump that
2057 appears when you try to configure bandwidth on the ppp interface
2058 that is not yet configured in ospfd.
2059
20602001-01-07 Michael Rozhavsky <mrozhavsky@opticalaccess.com>
2061
2062 * ospf_route.c (show_ip_ospf_route_external): "show ip ospf route"
2063 will print nexthops for AS-external routes.
2064
2065 * ospf_ase.c (ospf_ase_route_match_same): New function to compare
2066 ASE route under multipath environment.
2067 (ospf_ase_compare_tables): Likewise.
2068
20692001-01-01 Kunihiro Ishiguro <kunihiro@zebra.org>
2070
2071 * ospfd.h (OSPF_VTYSH_PATH): Change "/tmp/ospfd" to "/tmp/.ospfd".
2072
20732000-12-28 Kunihiro Ishiguro <kunihiro@zebra.org>
2074
2075 * ospf_route.c (ospf_route_install): Install multipath information
2076 to zebra daemon.
2077
2078 * ospf_zebra.c (ospf_zebra_add_multipath): Function for passing
2079 multipath information to zebra daemon.
2080
20812000-12-25 Dick Glasspool <dick@ipinfusion.com>
2082
2083 * ospf_packet.c (ospf_write): Call ospf_packet_delete when sendto
2084 fail.
2085 (DISCARD_LSA): Add argument N for logging point of DISCARD_LSA is
2086 called.
2087
2088 * ospf_lsa.c (ospf_external_lsa_refresh): NSSA install_flood will
2089 leave Type-7 LSA at Lock Count = 2.
2090
2091 * ospf_flood.c (ospf_flood_through): Flood_though_as updated for
2092 NSSA no P-bit off during Area flooding, but P-bit is turned off
2093 for mulitple NSSA AS flooding.
2094
2095 * ospf_ase.c (ospf_ase_calculate_timer): Added calculations for
2096 Type-7 LSDB.
2097
2098 * ospf_abr.c (ospf_abr_translate_nssa): Removed one unlock call.
2099 (ospf_abr_announce_nssa_defaults): Corrected Debug from EVENT to
2100 NSSA.
2101
21022000-12-25 Michael Rozhavsky <mrozhavsky@opticalaccess.com>
2103
2104 * ospf_zebra.c (ospf_zebra_read_ipv4): Checking the age of the
2105 found LSA and if the LSA is MAXAGE we should call refresh instead
2106 of originate.
2107
21082000-12-18 Dick Glasspool <dick@ipinfusion.com>
2109
2110 * ospf_abr.c: Removed redundant "...flood" in
2111 announce_network_to_area(). Repaired nssa Unlock by using
2112 discard.
2113
2114 * ospf_packet.c: Removed old NSSA translate during mk_ls_update.
2115
2116 * ospfd.c: Free up all data bases including NSSA.
2117
2118 * ospf_lsa.c: Now allow removal of XLATE LSA's Check in
2119 discard_callback. Added routine to get ip addr from within the
2120 ifp.
2121
2122 * ospf_flood.c: Now set Forward Address for outgoing Type-7.
2123
2124 * ospf_lsa.h: Added prototype for the below. struct in_addr
2125 ospf_get_ip_from_ifp (struct interface *ifp).
2126
21272000-12-14 Gleb Natapov <gleb@nbase.co.il>
2128
2129 * ospf_packet.c (ospf_recv_packet): New OSPF pakcet read method.
2130 Now maximum packet length may be 65535 bytes (maximum IP packet
2131 length).
2132
2133 * ospf_interface.c (ospf_if_stream_set): Don't make input buffer.
2134
2135 * ospfd.c (config_write_network_area): Remove unnecessary area
2136 lookup code.
2137
21382000-12-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2139
2140 * ospf_packet.c (ospf_read): Accept packet bigger than MTU value.
2141
21422000-12-13 Gleb Natapov <gleb@nbase.co.il>
2143
2144 * ospfd.c (config_write_network_area): Fix bug in
2145 config_write_network_area function.
2146
21472000-12-12 Gleb Natapov <gleb@nbase.co.il>
2148
2149 * ospf_abr.c (ospf_abr_announce_network_to_area): Make Summary
2150 LSA's origination and refreshment as same as other type of LSA.
2151
2152 * ospf_lsa.c (ospf_summary_lsa_refresh): Return struct ospf_lsa *.
2153
2154 * ospf_lsa.c (ospf_summary_asbr_lsa_refresh): Likewise.
2155
21562000-12-08 Dick Glasspool <dick@ipinfusion.com>
2157
2158 The bulk of NSSA changes are contained herein; This version will
2159 require manual setting of "always" for NSSA Translator, and will
2160 not perform aggregation yet.
2161
2162 * ospf_dump.c: "debug ospf nssa" is added.
2163
2164 * ospf_dump.h: Likewise.
2165
2166 * ospf_packet.c (ospf_hello): Display router ID on Bad NSSA Hello.
2167
2168 * ospfd.c: Discard_LSA to stay away from LOCAL_XLT Process NSSA
2169 'never, candidate, always'. Change "suppress" to "not-advertise".
2170
2171 * ospfd.h: Add TranslatorRole to struct ospf_area. Add anyNSSA to
2172 struct ospf.
2173
2174 * ospf_ase.c (ospf_ase_calculate_route): External to stay away
2175 from LOCAL_XLT
2176
2177 * ospf_nsm.c (ospf_db_summary_add): External to stay away from
2178 LOCAL_XLT
2179
2180 * ospf_abr.c: Major logic added for abr_nssa_task(). If ABR, and
2181 NSSA translator, then do it. Approve the global list, and flush
2182 any unapproved.
2183
2184 * ospf_lsa.h: New LSA flag OSPF_LSA_LOCAL_XLT to indicate that the
2185 Type-5 resulted from a Local Type-7 translation; not used for
2186 flooding, but used for flushing.
2187
2188 * ospf_flood.c: New NSSA flooding.
2189
21902000-12-08 Michael Rozhavsky <mrozhavsky@opticalaccess.com>
2191
2192 * ospfd.c (ospf_find_vl_data): New function for looking up virtual
2193 link data.
2194 (ospf_vl_set_security): Virtual link configuration with
2195 authentication.
2196 (ospf_vl_set_timers): Set timers for virtual link.
2197
2198 * New commands are added.
2199 "area A.B.C.D virtual-link A.B.C.D"
2200 "area A.B.C.D virtual-link A.B.C.D hello-interval <1-65535> retransmit-interval <3-65535> transmit-delay <1-65535> dead-interval <1-65535>"
2201 "area A.B.C.D virtual-link A.B.C.D hello-interval <1-65535> retransmit-interval <3-65535> transmit-delay <1-65535> dead-interval <1-65535> authentication-key AUTH_KEY"
2202 "area A.B.C.D virtual-link A.B.C.D authentication-key AUTH_KEY"
2203 "area A.B.C.D virtual-link A.B.C.D hello-interval <1-65535> retransmit-interval <3-65535> transmit-delay <1-65535> dead-interval <1-65535> message-digest-key <1-255> md5 KEY"
2204 "area A.B.C.D virtual-link A.B.C.D message-digest-key <1-255> md5 KEY"
2205
2206 * ospf_packet.c (ospf_check_md5_digest): Add neighbor's
2207 cryptographic sequence number treatment.
2208 (ospf_check_auth): OSPF input buffer is added to argument.
2209 (ospf_read): Save neighbor's cryptographic sequence number.
2210
2211 * ospf_nsm.c (nsm_change_status): Clear cryptographic sequence
2212 number when neighbor status is changed to NSM down.
2213
2214 * ospf_neighbor.c (ospf_nbr_new): Set zero to crypt_seqnum.
2215
2216 * ospf_neighbor.h (struct ospf_neighbor): Add cryptographic
2217 sequence number to neighbor structure.
2218
22192000-11-29 Kunihiro Ishiguro <kunihiro@zebra.org>
2220
2221 * ospf_snmp.c (ospfIfLookup): OSPF MIB updates.
2222 (ospfExtLsdbEntry): Add OspfExtLsdbTable treatment.
2223
22242000-11-28 Michael Rozhavsky <mrozhavsky@opticalaccess.com>
2225
2226 * ospfd.c (ospf_interface_down): Clear a ls_upd_queue queue of the
2227 interface.
2228 (ospf_ls_upd_queue_empty): New function to empty ls update queue
2229 of the OSPF interface.
2230 (no_router_ospf): 'no router ospf' unregister redistribution
2231 requests from zebra.
2232
22332000-11-28 Kunihiro Ishiguro <kunihiro@zebra.org>
2234
2235 * ospf_ism.c (ism_change_status): Increment status change number.
2236
2237 * ospf_interface.h (struct ospf_interface): Add new member for
2238 status change statistics.
2239
2240 * Makefile.am: Update dependencies.
2241
2242 * ospf_zebra.c (ospf_interface_add): OSPF SNMP interface update.
2243 (ospf_interface_delete): OSPF SNMP interface delete.
2244
2245 * ospf_snmp.h: New file is added.
2246
22472000-11-23 Dick Glasspool <dick@ipinfusion.com>
2248
2249 * ospfd.h: Add new ospf_area structure member for
2250 NSSATranslatorRole and NSSATranslator state.
2251
2252 * ospfd.c: Provided for eventual commands to specify NSSA
2253 elections for "translator- ALWAYS/NEVER/CANDIDATE". Provided for
2254 decimal integer version of area-suppress.
2255
2256 * ospf_flood.c: Flood Type-7's only into NSSA (not AS).
2257
2258 * ospf_lsa.c: Undo some previous changes for NSSA. If NSSA
2259 translator, advertise Nt bit.
2260
2261 * ospf_route.c: 1st version of "sh ip os border-routers".
2262
22632000-11-23 Michael Rozhavsky <mrozhavsky@opticalaccess.com>
2264
2265 * ospfd.c (area_vlink): Virtual link can not configured in stub
2266 area.
2267
22682000-11-23 Gleb Natapov <gleb@nbase.co.il>
2269
2270 * ospf_packet.c (ospf_db_desc): In states Loading and Full the
2271 slave must resend its last Database Description packet in response
2272 to duplicate Database Description packets received from the
2273 master. For this reason the slave must wait RouterDeadInterval
2274 seconds before freeing the last Database Description packet.
2275 Reception of a Database Description packet from the master after
2276 this interval will generate a SeqNumberMismatch neighbor
2277 event. RFC2328 Section 10.8
2278 (ospf_make_db_desc): DD Master flag treatment.
2279
2280 * ospf_nsm.c (nsm_twoway_received): Move DD related procedure to
2281 nsm_change_status().
2282 (nsm_bad_ls_req): Likewise.
2283 (nsm_adj_ok): Likewise.
2284 (nsm_seq_number_mismatch): Likewise.
2285 (nsm_oneway_received): Likewise.
2286
2287 * ospf_neighbor.h (struct ospf_neighbor): New structure member
2288 last_send_ts for timestemp when last Database Description packet
2289 was sent.
2290
2291 * ospf_nsm.c (ospf_db_desc_timer): Make it sure nbr->last_send is
2292 there. Call ospf_db_desc_resend() in any case.
2293
22942000-11-16 Michael Rozhavsky <mrozhavsky@opticalaccess.com>
2295
2296 * ospf_lsa.c (lsa_link_broadcast_set): When there is no DR on
2297 network (suppose you have only one router with interface priority
2298 0). It's router LSA does not contain the link information about
2299 this network.
2300
2301 * ospf_nsm.c (nsm_timer_set): When you change a priority of
2302 interface from/to 0 ISM_NeighborChange event should be scheduled
2303 in order to elect new DR/BDR on the network.
2304
2305 * ospf_interface.c (ip_ospf_priority): Likewise.
2306
2307 * ospf_flood.c (ospf_ls_retransmit_add): When we add some LSA into
2308 retransmit list we need to check whether the present old LSA in
2309 retransmit list is not more recent than the new
2310 one.
2311
23122000-11-09 Dick Glasspool <dick@ipinfusion.com>
2313
2314 * ospf_packet.c: Allows for NSSA Type-7 LSA's throughout the NSSA
2315 area. Any that exit the NSSA area are translated to type-5 LSA's.
2316 The instantiated image is restored after translation.
2317 (ospf_ls_upd_send_list): Renamed to ospf_ls_upd_queu_send().
2318 (ospf_ls_upd_send): Old function which enclosed by #ifdef 0 is
2319 removed.
2320 (ospf_ls_ack_send): Likewise.
2321
2322 * ospf_flood.c: NSSA-LSA's without P-bit will be restricted to
2323 local area. Otherwise they are allowed out the area to be
2324 translated by ospf_packet.c.
2325
2326 * ospf_lsa.c: Undo some previous changes for NSSA.
2327
2328 * ospf_lsdb.h: New access for type 7.
2329
23302000-11-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2331
2332 * ospf_route.c (ospf_path_exist): New function to check nexthop
2333 and interface are in current OSPF path or not.
2334 (ospf_route_copy_nexthops_from_vertex): Add nexthop to OSPF path
2335 when it is not there. Reported by Michael Rozhavsky
2336 <mrozhavsky@opticalaccess.com>
2337
23382000-11-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2339
2340 * ospf_dump.c (config_write_debug): Add seventh string "detail" is
2341 added for flag is OSPF_DEBUG_SEND | OSPF_DEBUG_RECV |
2342 OSPF_DEBUG_DETAIL.
2343
23442000-11-06 Michael Rozhavsky <mrozhavsky@opticalaccess.com>
2345
2346 * ospf_lsa.c (router_lsa_flags): ASBR can't exit in stub area.
2347
23482000-11-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2349
2350 * ospf_lsa.c (ospf_router_lsa_originate): Reduce unconditional
2351 logging.
2352
23532000-11-06 Dick Glasspool <dick@ipinfusion.com>
2354
2355 * ospfd.h: Add ait_ntoa function prototype.
2356
2357 * ospfd.c (ait_ntoa): New function for displaying area ID and
2358 Stub/NSSA status.
2359 (show_ip_ospf_interface_sub): Use ait_ntoa.
2360 (show_ip_ospf_nbr_static_detail_sub): Likewise.
2361 (show_ip_ospf_neighbor_detail_sub): Likewise.
2362
2363 * ospf_route.c (ospf_intra_route_add): Set external routing type
2364 to ospf route.
2365 (ospf_intra_add_router): Likewise.
2366 (ospf_intra_add_transit): Likewise.
2367 (ospf_intra_add_stub): Likewise.
2368 (ospf_add_discard_route): Likewise.
2369 (show_ip_ospf_route_network): Use ait_ntoa.
2370 (show_ip_ospf_route_network): Likewise.
2371 (show_ip_ospf_route_router): Likewise.
2372
2373 * ospf_lsa.c (show_lsa_detail): Use ait_ntoa.
2374 (show_lsa_detail_adv_router): Likewise.
2375 (show_ip_ospf_database_summary): Likewise.
2376
2377 * ospf_route.h (struct route_standard): Add new member
2378 external_routing.
2379
2380 * ospf_ia.c (process_summary_lsa): Set external routing tyep to ospf
2381 route.
2382 (ospf_update_network_route): Likewise.
2383 (ospf_update_router_route): Likewise.
2384
23852000-11-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2386
2387 * ospf_flood.c (ospf_process_self_originated_lsa): Enclose
2388 OSPF_AS_NSSA_LSA treatment with #ifdef HAVE_NSSA.
2389
23902000-11-03 Kunihiro Ishiguro <kunihiro@zebra.org>
2391
2392 * Unconditional logging is enclosed with if (IS_DEBUG_OSPF_EVENT).
2393 Please specify "debug ospf event" for enable logging.
2394
2395 * ospf_ism.c: Do not extern debug flag varible. It is done by
2396 ospf_debug.h
2397 * ospf_asbr.c: Likewise.
2398 * ospf_lsa.c: Likewise.
2399 * ospf_nsm.c: Likewise.
2400 * ospf_zebra.c: Likewise.
2401
2402 * ospf_dump.c (debug_ospf_event): New command "debug ospf event"
2403 is added.
2404
2405 * ospfd.c (router_ospf): Change logging from vty_out() to
2406 zlog_info().
2407 (ospf_area_stub_cmd): Likewise.
2408
2409 * ospf_dump.h: Extern term_debug flags.
2410 (OSPF_DEBUG_EVENT): Add new flag.
2411 (IS_DEBUG_OSPF_EVENT): Add new macro.
2412
24132000-11-03 Dick Glasspool <dick@ipinfusion.com>
2414
2415 * ospf_flood.c (ospf_process_self_originated_lsa):
2416 OSPF_AS_NSSA_LSA is treated as same as OSPF_AS_EXTERNAL_LSA.
2417 (ospf_flood): Type-5's have no change. Type-7's can be received,
2418 and will Flood the AS as Type-5's They will also flood the local
2419 NSSA Area as Type-7's. The LSDB will be updated as Type-5's, and
2420 during re-fresh will be converted back to Type-7's (if within an
2421 NSSA).
2422 (ospf_flood_through): Incoming Type-7's were allowed here if our
2423 neighbor was an NSSA. So Flood our area with the Type-7 and also
2424 if we are an ABR, flood thru AS as Type-5.
2425
2426 * ospf_lsa.c (ospf_external_lsa_refresh): Flood NSSA both NSSA
2427 area and other area.
2428
2429 * ospf_packet.c (ospf_db_desc_proc): When AS External LSA is
2430 exists in DD packet, make it sure that this area is not stub.
2431 (ospf_ls_upd_list_lsa): When LSA type is NSSA then set lsa's area
2432 to NULL.
2433 (ospf_ls_upd): If the LSA is AS External LSA and the area is stub
2434 then discard the lsa. If the LSA is NSSA LSA and the area is not
2435 NSSA then discard the lsa.
2436
24372000-11-03 Kunihiro Ishiguro <kunihiro@zebra.org>
2438
2439 * ospfd.c (ospf_interface_run): Fix bug of Hello packet's option
2440 is not properly set when interface comes up.
2441
24422000-11-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2443
2444 * ospfd.h (OSPF_OPTION_O): Add new hello header option.
2445
24462000-11-01 Dick Glasspool <dick@ipinfusion.com>
2447
2448 * ospf_lsa.h: Define OSPF_MAX_LSA to 8 when HAVE_NSSA is enabled.
2449 (OSPF_GROUP_MEMBER_LSA): Define OSPF_GROUP_MEMBER_LSA.
2450
2451 * ospf_lsa.c (show_database_desc): Add "Group Membership LSA"
2452 string.
2453
24542000-10-31 Dick Glasspool <dick@ipinfusion.com>
2455
2456 * ospf_lsa.h (OSPF_AS_NSSA_LSA): Define OSPF_AS_NSSA_LSA.
2457
2458 * ospf_lsa.c (show_ip_ospf_database): NSSA database display
2459 function is added. ALIASES which have "show ip ospf database
2460 nssa-external" is added.
2461 (show_ip_ospf_border_routers): New command "show ip ospf
2462 border-routers" is added.
2463
24642000-10-30 Dick Glasspool <dick@ipinfusion.com>
2465
2466 * ospfd.c (router_ospf): NSSA Enabled message is added for
2467 testing.
2468 (ospf_area_type_set): Are type set for NSSA area.
2469 (ospf_area_stub_cmd): Special translation of no_summary into NSSA
2470 and summary information. If NSSA is enabled pass the information
2471 to ospf_area_type_set().
2472 (area_nssa): New commands are added:
2473 "area A.B.C.D nssa"
2474 "area <0-4294967295> nssa"
2475 "area A.B.C.D nssa no-summary"
2476 "area <0-4294967295> nssa no-summary"
2477 (ospf_no_area_stub_cmd): Special translation of no_summary into
2478 NSSA and summary information. If external_routing is
2479 OSPF_AREA_NSSA unset area with ospf_area_type_set (area,
2480 OSPF_AREA_DEFAULT).
2481 (show_ip_ospf_area): Display NSSA status.
2482 (config_write_ospf_area): Show NSSA configuration.
2483
2484 * ospf_packet.c (ospf_hello): For NSSA support, ensure that NP is
2485 on and E is off.
2486
24872000-10-26 Gleb Natapov <gleb@nbase.co.il>
2488
2489 * ospf_lsa.c (ospf_network_lsa_body_set): The network-LSA lists
2490 those routers that are fully adjacent to the Designated Router;
2491 each fully adjacent router is identified by its OSPF Router ID.
2492 The Designated Router includes itself in this list. RFC2328,
2493 Section 12.4.2.
2494
24952000-10-23 Jochen Friedrich <jochen@scram.de>
2496
2497 * ospf_snmp.c: ospf_oid and ospfd_oid are used in smux_open after
2498 it is registered. So those variables must be static.
2499
25002000-10-18 K N Sridhar <sridhar@euler.ece.iisc.ernet.in>
2501
2502 * ospfd.c: Add area_default_cost_decimal_cmd and
2503 no_area_default_cost_decimal_cmd alias.
2504
25052000-10-05 Gleb Natapov <gleb@nbase.co.il>
2506
2507 * ospfd.c (ospf_network_new): Fix setting area format.
2508 (no_router_ospf): Check area existance when calling
2509 ospf_interface_down().
2510
2511 * ospf_flood.c (ospf_external_info_check): Fix bug of refreshing
2512 default route.
2513
25142000-10-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2515
2516 * zebra-0.89 is released.
2517
25182000-09-29 Kunihiro Ishiguro <kunihiro@zebra.org>
2519
2520 * ospf_snmp.c (ospfHostEntry): OSPF Host MIB is implemented.
2521
2522 * ospfd.c (ospf_nbr_static_cmp): OSPF neighbor is sorted by it's
2523 address.
2524
25252000-09-28 Michael Rozhavsky <mike@nbase.co.il>
2526
2527 * ospf_interface.c (ospf_if_free): Fix deleting self neighbor twice.
2528
25292000-09-27 Kunihiro Ishiguro <kunihiro@zebra.org>
2530
2531 * ospf_packet.c (ospf_read): Solaris on x86 has ip_len with host
2532 byte order.
2533
25342000-09-25 Toshiaki Takada <takada@zebra.org>
2535
2536 * ospfd.c (ospf_compatible_rfc1583), (no_ospf_compatible_rfc1583):
2537 Add CISCO compatible command.
2538
25392000-09-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2540
2541 * ospf_abr.c (ospf_area_range_lookup): New function is added for
2542 area range lookup in OSPF-MIB.
2543 (ospf_area_range_lookup_next): Likewise.
2544
25452000-09-22 Kunihiro Ishiguro <kunihiro@zebra.org>
2546
2547 * ospfd.c (no_router_ospf): Delete virtual link before deleting
2548 area structure.
2549
2550 * ospf_lsa.c (ospf_external_lsa_refresh_type): Check
2551 EXTERNAL_INFO(type).
2552
2553 * ospfd.c (no_router_ospf): Call ospf_vl_delete() instead of
2554 ospf_vl_data_free().
2555
2556 * ospf_interface.c (ospf_vl_shutdown): Execute ISM_InterfaceDown
2557 when ospf_vl_shutdown is called.
2558 (ospf_vl_delete): Call ospf_vl_shutdown() to delete virtual link
2559 interface's thread.
2560
25612000-09-21 Gleb Natapov <gleb@nbase.co.il>
2562
2563 * ospf_lsa.c: New implementation of OSPF refresh.
2564
25652000-09-20 Kunihiro Ishiguro <kunihiro@zebra.org>
2566
2567 * ospf_snmp.c (ospfLsdbLookup): Add LSDB MIB implementation.
2568
25692000-09-18 Kunihiro Ishiguro <kunihiro@zebra.org>
2570
2571 * ospf_snmp.c (ospfStubAreaEntry): Add OSPF stub area MIB.
2572
25732000-09-18 Gleb Natapov <gleb@nbase.co.il>
2574
2575 * ospf_route.h (route_standard): Change member from `struct area'
2576 to area_id.
2577
2578 * ospf_abr.c (ospf_abr_announce_network), (ospf_abr_should_announce),
2579 (ospf_abr_process_network_rt), (ospf_abr_announce_rtr),
2580 (ospf_abr_process_router_rt):
2581 * ospf_ase.c (ospf_find_asbr_route),
2582 (ospf_find_asbr_router_through_area),
2583 * ospf_ia.c (ospf_find_abr_route), (ospf_ia_router_route),
2584 (process_summary_lsa), (ospf_update_network_route),
2585 (ospf_update_router_route):
2586 * ospf_route.c (ospf_intra_route_add), (ospf_intra_add_router),
2587 (ospf_intra_add_transit), (ospf_intra_add_stub),
2588 (ospf_route_table_dump), (show_ip_ospf_route_network),
2589 (show_ip_ospf_route_router), (ospf_asbr_route_cmp),
2590 (ospf_prune_unreachable_routers):
2591 * ospf_spf.c (ospf_rtrs_print):
2592 * ospfd.c (ospf_rtrs_free): Fix the struct change above.
2593
25942000-09-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2595
2596 * ospf_network.c (ospf_serv_sock_init): Enclose SO_BINDTODEVICE
2597 with ifdef.
2598
25992000-09-13 Gleb Natapov <gleb@nbase.co.il>
2600
2601 * ospf_ism.c (ospf_elect_dr), (ospf_elect_bdr): Fix DR election.
2602
2603 * ospf_network.c (ospf_serv_sock_init): Add socket option
2604 SO_BINDTODEVICE on read socket.
2605
2606 * ospf_packet.c (ospf_hello): Ignore Hello packet if E-bit does
2607 not match.
2608
2609 * ospfd.c (ospf_area_check_free), (ospf_area_get),
2610 (ospf_area_add_if): New function added.
2611
26122000-09-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2613
2614 * ospf_route.c (ospf_intra_add_router): Update ABR and ASBR router
2615 count.
2616
2617 * ospf_spf.c (ospf_spf_init): Rest ABR and ASBR router count
2618 starting SPF calculation.
2619
2620 * ospfd.h (struct ospf_area): Add ABR and ASBR router count.
2621
26222000-09-12 Kunihiro Ishiguro <kunihiro@zebra.org>
2623
2624 * ospfd.c (ospf_area_id_cmp): New area structure is sorted by area
2625 ID.
2626
2627 * ospf_lsa.c (ospf_router_lsa_originate): For OSPF MIB update
2628 lsa_originate_count.
2629 (ospf_network_lsa_originate): Likewise.
2630 (ospf_summary_lsa_originate): Likewise.
2631 (ospf_summary_asbr_lsa_originate): Likewise.
2632 (ospf_external_lsa_originate): Likewise.
2633
26342000-09-11 Kunihiro Ishiguro <kunihiro@zebra.org>
2635
2636 * ospf_snmp.c (ospf_variables): ospfRouterID's type RouterID
2637 syntax is IpAddress.
2638 (ospf_admin_stat): New function for OSPF administrative status
2639 check.
2640
26412000-09-10 Jochen Friedrich <jochen@scram.de>
2642
2643 * ospf_snmp.c: Implement OSPF MIB skeleton.
2644
26452000-09-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2646
2647 * ospf_snmp.c: New file is added.
2648
26492000-09-07 David Lipovkov <davidl@nbase.co.il>
2650
2651 * ospf_zebra.c (ospf_interface_delete): Add pseudo interface
2652 treatment.
2653
2654 * ospf_interface.c (interface_config_write): Likewise.
2655
26562000-08-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2657
2658 * zebra-0.88 is released.
2659
26602000-08-17 Michael Rozhavsky <mike@nbase.co.il>
2661
2662 * ospfd.c (ospf_area_free): Remove virtual link configuration only
2663 when Area is removed.
2664
26652000-08-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2666
2667 * ospfd.c (network_area): Revert check for EXTERNAL_INFO
2668 (ZEBRA_ROUTE_CONNECT).
2669 (no_network_area): Likewise.
2670
26712000-08-16 Kunihiro Ishiguro <kunihiro@zebra.org>
2672
2673 * ospfd.h (struct ospf): Add distance_table and
2674 distance_{all,intra,inter,external}.
2675
2676 * ospf_zebra.c: Add OSPF distance related functions.
2677
26782000-08-15 Gleb Natapov <gleb@nbase.co.il>
2679
2680 * ospf_asbr.c (ospf_external_info_find_lsa): New function added.
2681
2682 * ospf_lsa.c (ospf_default_external_info),
2683 (ospf_default_originate_timer), (ospf_external_lsa_refresh_default):
2684 New function added.
2685
2686 * ospf_zebra.c
2687 (ospf_default_information_originate_metric_type_routemap),
2688 (ospf_default_information_originate_always_metric_type_routemap):
2689 Change name and add route-map function.
2690 (ospf_default_information_originate_metric_routemap),
2691 (ospf_default_information_originate_routemap),
2692 (ospf_default_information_originate_type_metric_routemap):
2693 New DEFUN added.
2694
26952000-08-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2696
2697 * ospf_zebra.c (zebra_interface_if_set_value): Change ifindex
2698 restore size from two octet to four.
2699
27002000-08-14 Michael Rozhavsky <mike@nbase.co.il>
2701
2702 * ospf_ase.c (ospf_ase_incremental_update): Implement incremental
2703 AS-external-LSA in 16.6 of RFC2328.
2704
27052000-08-14 Matthew Grant <grantma@anathoth.gen.nz>
2706
2707 * ospf_interface.c (ospf_if_get_output_cost): Change cost
2708 calculation algorithm.
2709
2710 * ospf_packet (ospf_ls_upd): Fix problem of LSA retransmitting.
2711
27122000-08-11 Michael Rozhavsky <mike@nbase.co.il>
2713
2714 * ospf_lsa.c (ospf_maxage_lsa_remover): Fix maxage remover for
2715 AS-external-LSAs.
2716
27172000-08-10 Toshiaki Takada <takada@zebra.org>
2718
2719 * ospfd.c (auto_cost_reference_bandwidth): New DEFUN added.
2720 `auto-cost reference-bandwidth' OSPF router command added.
2721
27222000-08-08 Gleb Natapov <gleb@nbase.co.il>
2723
2724 * ospf_routemap.c (ospf_route_map_update): New function added.
2725 Add route-map event hook.
2726
27272000-08-08 Toshiaki Takada <takada@zebra.org>
2728
2729 * ospf_zebra.c (ospf_distribute_check_connected): If redistribute
2730 prefix is connected route on OSPF enabled interface, suppress to
2731 announce it.
2732
27332000-08-08 Matthew Grant <grantma@anathoth.gen.nz>
2734
2735 * ospf_interface.c (ospf_if_get_output_cost):
2736 New function added. Handle bandwidth parameter for cost
2737 calculation.
2738
27392000-08-08 Michael Rozhavsky <mike@nbase.co.il>
2740
2741 * ospf_interface.c (interface_config_write): Show interface
2742 configuration regardless interface is down.
2743
2744 * ospf_ase.c (ospf_ase_caocluate_route): Whole rewritten external
2745 route calculate function.
2746
27472000-08-08 Gleb Natapov <gleb@nbase.co.il>
2748
2749 * ospf_routemap.c: New file added.
2750
2751 * ospf_asbr.c (ospf_reset_route_map_set_values),
2752 (ospf_route_map_set_compare): New function added.
2753
2754 * ospf_lsa.c (ospf_external_lsa_body_set): Set routemap metric
2755 with AS-external-LSA.
2756
27572000-08-05 Kunihiro Ishiguro <kunihiro@zebra.org>
2758
2759 * ospf_ase.c (ospf_ase_calculate_route_add): Pass new->cost to
2760 ospf_zebra_add as metric.
2761 (ospf_ase_calculate_route_add): Likewise.
2762
2763 * ospf_route.c (ospf_route_install): Pass or->cost to
2764 ospf_zebra_add as metric.
2765
2766 * ospf_zebra.c (ospf_zebra_add): Add metric arguemnt.
2767 (ospf_zebra_delete): Likewise.
2768
27692000-08-03 Matthew Grant <grantma@anathoth.gen.nz>
2770
2771 * ospf_flood.c (ospf_flood_delayed_lsa_ack): New function added.
2772 Dispatch delayed-ACK with flooding AS-external-LSA across virtual
2773 link.
2774
27752000-07-31 Matthew Grant <grantma@anathoth.gen.nz>
2776
2777 * ospfd.c (show_ip_ospf_area): Fix lack of VTY_NEWLINE when
2778 `show ip ospf'.
2779
2780 * ospf_interface.c (ospf_if_free): Fix bug of crash with
2781 Point-to-Point interface.
2782
27832000-07-27 Michael Rozhavsky <mike@nbase.co.il>
2784
2785 * ospf_flood.c (ospf_process_self_originated_lsa):
2786 Make sure to clear LSA->param (redistributed external information)
2787 before refreshment.
2788
27892000-07-27 Gleb Natapov <gleb@nbase.co.il>
2790
2791 * ospfd.c (refresh_group_limit), (refresh_per_slice),
2792 (refresh_age_diff): New defun added. Refresher related parameter
2793 can be configurable.
2794
27952000-07-27 Akihiro Mizutani <mizutani@dml.com>
2796
2797 * ospf_interface.c (interface_config_write): Print `description'
2798 config directive to work.
2799
28002000-07-24 Akihiro Mizutani <mizutani@dml.com>
2801
2802 * ospf_interface.c (ospf_if_init): Use install_default for
2803 INTERFACE_NODE.
2804
28052000-07-24 Gleb Natapov <gleb@nbase.co.il>
2806
2807 * ospf_packet.c (ospf_ls_upd_send_list), (ospf_ls_upd_send_event),
2808 (ospf_ls_ack_send_list), (ospf_ls_ack_send_event): New function added.
2809 This make sending always as many LS update/Ack combined in one ospf
2810 packet.
2811
28122000-07-24 Gleb Natapov <gleb@nbase.co.il>
2813
2814 * ospf_packet.c (ospf_ls_upd_list_lsa): Set NULL to lsa->area if
2815 LSA is AS-external-LSA.
2816
2817 * ospf_nsm.c (nsm_reset_nbr): Do not cancel Inactivity timer.
2818
28192000-07-21 Toshiaki Takada <takada@zebra.org>
2820
2821 * ospf_zebra.c (ospf_default_originate_timer): Set timer for
2822 `default-information originate'. Fix some default originate
2823 related functions.
2824
28252000-07-12 Toshiaki Takada <takada@zebra.org>
2826
2827 * ospf_lsa.c (stream_put_ospf_metric): New function added.
2828
28292000-07-12 Toshiaki Takada <takada@zebra.org>
2830
2831 * ospf_lsa.c (show_ip_ospf_database_router),
2832 (show_ip_ospf_database_network), (show_ip_ospf_database_summary),
2833 (show_ip_ospf_database_summary_asbr), (show_ip_ospf_database_externel),
2834 (show_router_lsa), (show_any_lsa), (show_router_lsa_self),
2835 (show_any_lsa_self): Functions removed.
2836
2837 (show_lsa_prefix_set), (show_lsa_detail_proc), (show_lsa_detail),
2838 (show_lsa_detail_adv_router_proc), (show_lsa_detail_adv_router):
2839 New functions added. Replace above functions.
2840
2841 (show_ip_ospf_database_all), (show_ip_ospf_database_self_originated):
2842 Functions removed.
2843 (show_ip_ospf_database_summary): New functions added. Replace
2844 above functions.
2845
2846 (show_ip_ospf_database_cmd): DEFUN rearranged.
2847 (show_ip_ospf_database_type_id_cmd),
2848 (show_ip_ospf_database_type_id_adv_router_cmd),
2849 (show_ip_ospf_database_type_is_self_cmd): New ALIASes added.
2850 (show_ip_ospf_database_type_adv_rotuer_cmd): New DEFUN added.
2851 (show_ip_ospf_database_type_self_cmd): New ALIAS added.
2852
28532000-07-11 Toshiaki Takada <takada@zebra.org>
2854
2855 * ospf_asbr.c (ospf_external_info_new),
2856 (ospf_external_info_free): New functions added.
2857
2858 * ospf_lsa.h (ospf_lsa): Add new member `void *param' to set
2859 origination parameter for external-LSA.
2860 Remove member `redistribute'.
2861
2862 * ospf_zebra.c (ospf_redistirbute_set): When `redistribute'
2863 command executed, metric and metric-type values are overridden.
2864 If one of those is changed refresh AS-external-LSAs for appropriate
2865 type.
2866
28672000-07-11 Michael Rozhavsky <mike@nbase.co.il>
2868
2869 * ospf_lsa.c (ospf_summary_lsa_refresh),
2870 (ospf_summary_asbr_lsa_refresh): Make sure to refresh summary-LSAs.
2871
2872 * ospf_abr.c (set_metric): New function added.
2873
28742000-07-07 Toshiaki Takada <takada@zebra.org>
2875
2876 * ospf_zebra.c (ospf_default_information_originate_metric_type),
2877 (ospf_default_information_originate_type_metric): New defun added.
2878 Metic and Metric type can be set to default route.
2879 (ospf_default_information_originate_always_metric_type):
2880 (ospf_default_information_originate_always_type_metric):
2881 New defun added. Metric and Metric type can be set to default
2882 always route.
2883
2884 * ospf_zebra.c (ospf_default_metric), (no_ospf_default_metric):
2885 New defun added.
2886
28872000-07-06 Gleb Natapov <gleb@nbase.co.il>
2888
2889 * ospf_flood.c (ospf_flood_through_area): Fix bug of considering
2890 on the same interface the LSA was received from.
2891
28922000-07-06 Michael Rozhavsky <mike@nbase.co.il>
2893
2894 * ospfd.c (ospf_config_write): Fix bug of printing `area stub'
2895 command with `write mem'.
2896
2897 * ospfd.c (no_router_ospf): Remove installed routes from zebra.
2898
2899 * ospf_zebra.c (ospf_interface_delete): Fix function to handle
2900 zebra interface delete event.
2901
29022000-07-06 Toshiaki Takada <takada@zebra.org>
2903
2904 * ospf_zebra.c (ospf_default_information_originate),
2905 (ospf_default_information_originate_always): New DEFUN added.
2906
29072000-07-05 Michael Rozhavsky <mike@nbase.co.il>
2908
2909 * ospf_route.c (ospf_terminate): Make sure to remove external route
2910 when SIGINT received.
2911
29122000-07-03 Gleb Natapov <gleb@nbase.co.il>
2913
2914 * ospf_flood.c, ospf_ism.c, ospf_lsa,c, ospfd.c: Make sure to free
2915 many structure with `no router ospf'.
2916
29172000-06-30 Gleb Natapov <gleb@nbase.co.il>
2918
2919 * ospf_neighbor.c (ospf_nbr_new),
2920 ospf_nsm.c (nsm_timer_set): Start LS update timer only
2921 when neighbor enters Exchange state.
2922
29232000-06-29 Gleb Natapov <gleb@nbase.co.il>
2924
2925 * ospf_nsm.c (nsm_timer_set), (nsm_exchange_done),
2926 ospf_packet.c (ospf_db_desc_proc):
2927 Do not cancel DD retransmit timer when Master.
2928
29292000-06-29 Gleb Natapov <gleb@nbase.co.il>
2930
2931 * ospf_abr.c (ospf_abr_announce_network_to_area),
2932 (ospf_abr_announce_rtr_to_area)
2933 ospf_ase.c (ospf_ase_rtrs_register_lsa),
2934 ospf_flood.c (ospf_process_self_originated_lsa),
2935 (ospf_flood_through_area), (ospf_ls_request_delete),
2936 ospf_interface.c (ospf_if_free),
2937 ospf_ism.c (ism_change_status),
2938 ospf_lsa.c (ospf_router_lsa_update_timer),
2939 (ospf_router_lsa_install), (ospf_network_lsa_install),
2940 (ospf_lsa_maxage_delete), (ospf_lsa_action),
2941 (ospf_schedule_lsa_flood_area),
2942 ospf_nsm.c (nsm_change_status),
2943 ospf_packet.c (ospf_make_ls_req_func), (ospf_make_ls_ack):
2944 Use ospf_lsa_{lock,unlock} for all looking-up of LSA.
2945
2946 * ospf_flood.c (ospf_ls_request_free): Function deleted.
2947
2948 * ospf_lsa.c (ospf_discard_from_db): New function added.
2949
29502000-06-26 Toshiaki Takada <takada@zebra.org>
2951
2952 * ospfd.h (ospf): struct member `external_lsa' name changed to
2953 `lsdb'.
2954
29552000-06-26 Toshiaki Takada <takada@zebra.org>
2956
2957 * ospf_lsa.c (ospf_lsa_install), (ospf_router_lsa_install),
2958 (ospf_network_lsa_install), (ospf_summary_lsa_install),
2959 (ospf_summary_asbr_lsa_install), (ospf_external_lsa_install):
2960 Functions re-arranged.
2961
2962 * ospf_lsa.c (IS_LSA_MAXAGE), (IS_LSA_SELF): Macro added.
2963
29642000-06-20 Michael Rozhavsky <mike@nbase.co.il>
2965
2966 * ospf_packet.c (ospf_ls_req), (ospf_ls_upd), (ospf_ls_ack): Add
2967 verification of LS type.
2968
29692000-06-20 Gleb Natapov <gleb@nbase.co.il>
2970
2971 * ospf_ase.c (ospf_ase_calculate_timer): Add more sanity check
2972 whether rn->info is NULL.
2973
29742000-06-20 Toshiaki Takada <takada@zebra.org>
2975
2976 * ospfd.c (show_ip_ospf_interface_sub): Show Router-ID of both
2977 DR and Backup correctly with `show ip ospf interface' command.
2978
29792000-06-20 Toshiaki Takada <takada@zebra.org>
2980
2981 * ospf_lsa.c (ospf_lsa_lock), (ospf_lsa_unlock),
2982 (ospf_lsa_discard): These functions are used for avoiding
2983 unexpected reference to freed LSAs.
2984
29852000-06-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2986
2987 * ospf_packet.c (ospf_ls_upd): Initialize lsa by NULL to avoid
2988 warning.
2989
29902000-06-12 Kunihiro Ishiguro <kunihiro@zebra.org>
2991
2992 * ospf_ase.h (ospf_ase_rtrs_register_lsa): Add prototype.
2993
29942000-06-12 Toshiaki Takada <takada@zebra.org>
2995
2996 * ospf_lsa.c (ospf_external_lsa_install): Make sure to register
2997 LSA to rtrs_external when replacing AS-external-LSAs in LSDB.
2998 Fix core dump.
2999
30002000-06-10 Toshiaki Takada <takada@zebra.org>
3001
3002 * ospf_lsdb.c (id_to_prefix), (ospf_lsdb_hash_key),
3003 (ospf_lsdb_hash_cmp), (ospf_lsdb_new), (ospf_lsdb_iterator),
3004 (lsdb_free), (ospf_lsdb_free), (ospf_lsdb_add), (ospf_lsdb_delete),
3005 (find_lsa), (ospf_lsdb_lookup), (find_by_id),
3006 (ospf_lsdb_lookup_by_id), (ospf_lsdb_lookup_by_header): Functinos
3007 removed for migration to new_lsdb.
3008
3009 * ospf_lsa.c (ospf_summary_lsa_install),
3010 (ospf_summary_asbr_lsa_install), (ospf_maxage_lsa_remover),
3011 (ospf_lsa_maxage_walker), (ospf_lsa_lookup),
3012 (ospf_lsa_lookup_by_id): Use new_lsdb instead of ospf_lsdb.
3013 (count_lsa), (ospf_lsa_count_table), (ospf_lsa_count),
3014 (ospf_get_free_id_for_prefix): Funcitions removed.
3015
30162000-06-09 Gleb Natapov <gleb@nbase.co.il>
3017
3018 * ospf_ism.c (ism_interface_down): Prevent some unneeded DR changes.
3019
3020 * ospf_packet.c (ospf_db_desc_proc): Fix memory leak.
3021 (ospf_hello): Always copy router-ID when hello is received.
3022
30232000-06-08 Gleb Natapov <gleb@nbase.co.il>
3024
3025 * ospf_lsa.h (struct ospf_lsa): Add member of pointer to struct
3026 ospf_area.
3027
30282000-06-08 Michael Rozhavsky <mike@nbase.co.il>
3029
3030 * ospf_ase.c (ospf_asbr_route_same): New function added.
3031 This function makes sure external route calculation more
3032 precisely.
3033
30342000-06-07 Michael Rozhavsky <mike@nbase.co.il>
3035
3036 * ospf_ism.c (ism_change_status): Use ospf_lsa_flush_area for
3037 network-LSA deletion instead of using ospf_lsdb_delete.
3038 Also cancel network-LSA origination timer.
3039
30402000-06-07 Levi Harper <lharper@kennedytech.com>
3041
3042 * ospf_interface.c (ospf_if_down): Close read fd when an interface
3043 goes down.
3044
30452000-06-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3046
3047 * ospf_asbr.c (ospf_external_info_lookup): Add explicit brace for
3048 avoid ambiguous else.
3049
3050 * ospf_flood.c (ospf_external_info_check): Likewise.
3051
30522000-06-05 Toshiaki Takada <takada@zebra.org>
3053
3054 * ospf_nsm.c (nsm_adj_ok): Fix bug of DR election.
3055
30562000-06-04 Toshiaki Takada <takada@zebra.org>
3057
3058 * ospf_zebra.c (ospf_default_information_originate),
3059 (no_ospf_default_information_originate): New DEFUN added.
3060
30612000-06-03 Toshiaki Takada <takada@zebra.org>
3062
3063 * ospf_lsa.h, ospf_asbr.h (external_info): Struct moved from
3064 ospf_lsa.h to ospf_asbr.h.
3065
3066 * ospf_lsa.c, ospf_asbr.c (ospf_external_info_add),
3067 (ospf_external_info_delete): Function moved from ospf_lsa.c
3068 to ospf_asbr.c.
3069
30702000-06-03 Toshiaki Takada <takada@zebra.org>
3071
3072 * ospf_flood.c (ospf_external_info_check): New function added.
3073 (ospf_process_self_orignated_lsa): Make sure to flush
3074 self-originated AS-external-LSA, when router reboot and no longer
3075 originate those AS-external-LSA.
3076
30772000-06-02 Toshiaki Takada <takada@zebra.org>
3078
3079 * ospf_network.c (ospf_serv_sock): Remove SO_DONTROUTE
3080 socket option.
3081
3082 * ospf_packet.c (ospf_write): Set MSG_DONTROUTE flag for
3083 unicast destination packets.
3084
30852000-06-02 Toshiaki Takada <takada@zebra.org>
3086
3087 * ospf_lsdb.c (new_lsdb_delete): Delete entry from LSDB only when
3088 specified LSA matches.
3089
30902000-06-02 Gleb Natapov <gleb@nbase.co.il>
3091
3092 * ospf_network.c (ospf_serv_sock): Set SO_DONTROUTE
3093 socket option.
3094
30952000-06-01 Akihiro Mizutani <mizutani@dml.com>
3096
3097 * ospf_dump.c: Replace string `Debugging functions\n' with DEBUG_STR.
3098 Replace string `OSPF information\n' with OSPF_STR.
3099
31002000-06-01 Toshiaki Takada <takada@zebra.org>
3101
3102 * ospf_lsdb.[ch]: Use new_lsdb struct for network-LSA instead of
3103 ospf_lsdb.
3104
31052000-06-01 Toshiaki Takada <takada@zebra.org>
3106
3107 * ospf_dump.c (config_debug_ospf_packet), (config_debug_ospf_event),
3108 (config_debug_ospf_ism), (config_debug_ospf_nsm),
3109 (config_debug_ospf_lsa), (config_debug_ospf_zebra),
3110 (term_debug_ospf_packet), (term_debug_ospf_event),
3111 (term_debug_ospf_ism), (term_debug_ospf_nsm),
3112 (term_debug_ospf_lsa), (term_debug_ospf_zebra): Repalce debug_ospf_*
3113 variable to use for debug option flags.
3114
3115 (debug_ospf_packet), (debug_ospf_ism), (debug_ospf_nsm),
3116 (debug_ospf_lsa), (debug_ospf_zebra): Set {config,term}_debug_*
3117 flags when vty->node is CONFIG_NODE, otherwise set only term_debug_*
3118 flags.
3119
3120 * ospf_dump.h (CONF_DEBUG_PACKET_ON), (CONF_DEBUG_PACKET_OFF),
3121 (TERM_DEBUG_PACKET_ON), (TERM_DEBUG_PACKET_OFF),
3122 (CONF_DEBUG_ON), (CONF_DEBUG_OFF), (IS_CONF_DEBUG_OSPF_PACKET),
3123 (IS_CONF_DEBUG_OSPF): New Macro added.
3124
31252000-05-31 Toshiaki Takada <takada@zebra.org>
3126
3127 * ospfd.c (clear_ip_ospf_neighbor): New DEFUN added.
3128 Currently this command is used for only debugging.
3129
3130 * ospf_nsm.c (nsm_change_status): Make sure thread cancellation
3131 for network-LSA when DR has no full neighbors.
3132
3133 * ospf_nsm.c (ospf_db_summary_clear): New function added.
3134
31352000-05-30 Toshiaki Takada <takada@zebra.org>
3136
3137 * ospf_lsdb.c (new_lsdb_insert): LSAs are always freed by
3138 maxage_lsa_remover when LSA is replaced.
3139
31402000-05-25 Gleb Natapov <gleb@nbase.co.il>
3141
3142 * ospf_flood.c (ospf_ls_retransmit_delete_nbr_all): Add argument
3143 `struct ospf_area' to remove LSA from Link State retransmission list
3144 of neighbor from only one Area.
3145
31462000-05-24 Michael Rozhavsky <mike@nbase.co.il>
3147
3148 * ospf_lsdb.c (ospf_lsdb_add): Preserve flags field when
3149 overriting old LSA with new LSA.
3150
31512000-05-24 Gleb Natapov <gleb@nbase.co.il>
3152
3153 * ospf_lsa.c (ospf_router_lsa_body_set): Fix bug of router-LSA
3154 size calculation.
3155
31562000-05-22 Michael Rozhavsky <mike@nbase.co.il>
3157
3158 * ospf_route.c (ospf_intra_add_stub):
3159 * ospf_spf.h (struct vertex): Use u_int32_t for distance (cost)
3160 value instead of u_int16_t.
3161
31622000-05-22 Axel Gerlach <agerlach@datus.datus.com>
3163
3164 * ospf_ia.c (ospf_ia_network_route): Fix bug of Inter-area route
3165 equal cost path calculation.
3166
31672000-05-21 Toshiaki Takada <takada@zebra.org>
3168
3169 * ospf_ase.c (ospf_ase_calculate_route_delete): New function added.
3170 Make sure, when rotuer route is deleted, related external routes
3171 are also deleted.
3172
31732000-05-20 Toshiaki Takada <takada@zebra.org>
3174
3175 * ospfd.c (ospf_interface_down): Make sure interface flag is disable
3176 and set fd to -1.
3177
31782000-05-16 Toshiaki Takada <takada@zebra.org>
3179
3180 * ospf_asbr.c (ospf_asbr_should_announce), (ospf_asbr_route_remove):
3181 Functions removed.
3182
3183 * ospfd.h (EXTERNAL_INFO): Macro added.
3184 Substitute `ospf_top->external_info[type]' with it.
3185
31862000-05-16 Toshiaki Takada <takada@zebra.org>
3187
3188 * ospf_lsa.c (ospf_rtrs_external_remove): New function added.
3189
31902000-05-14 Gleb Natapov <gleb@nbase.co.il>
3191
3192 * ospf_flood.c (ospf_ls_retransmit_delete_nbr_all)
3193 * ospf_lsdb.c (new_lsdb_insert)
3194 * ospf_packet.c (ospf_ls_ack): Fix database synchonization problem.
3195
31962000-05-14 Gleb Natapov <gleb@nbase.co.il>
3197
3198 * ospf_lsa.h (tv_adjust), (tv_ceil), (tv_floor), (int2tv),
3199 (tv_add), (tv_sub), (tv_cmp): Prototype definition added.
3200
3201 * ospf_nsm.h (ospf_db_summary_delete_all): Prototype definition added.
3202
32032000-05-13 Toshiaki Takada <takada@zebra.org>
3204
3205 * ospf_lsa.[ch] (ospf_lsa): struct timestamp type is changed from
3206 time_t to struct timeval.
3207 (tv_adjust), (tv_ceil), (tv_floor), (int2tv), (tv_add),
3208 (tv_sub), (tv_cmp): timeval utillity functions added.
3209
32102000-05-12 Toshiaki Takada <takada@zebra.org>
3211
3212 * ospf_lsa.[ch] (ospf_schedule_update_router_lsas): Delete function.
3213 Change to use macro OSPF_LSA_UPDATE_TIMER instead of using
3214 this function.
3215 router-LSA refresh timer related stuff is re-organized.
3216
32172000-05-10 Gleb Natapov <gleb@nbase.co.il>
3218
3219 * ospf_interface.c (ospf_vl_set_params):
3220 * ospf_packet.c (ospf_check_network_mask):
3221 * ospf_spf.[ch] (ospf_spf_next):
3222 Remove field address from `struct vertex', and search for peer
3223 address of virtual link in function `ospf_vl_set_params' instead.
3224
32252000-05-10 Gleb Natapov <gleb@nbase.co.il>
3226
3227 * ospf_packet.c (ospf_ls_upd): Fix some memory leak related LSA.
3228
32292000-05-08 Thomas Molkenbur <tmo@datus.com>
3230
3231 * ospf_packet.c (ospf_packet_dup): Replace ospf_steram_copy()
3232 with ospf_stream_dup() to fix memory leak.
3233
32342000-05-08 Michael Rozhavsky <mike@nbase.co.il>
3235
3236 * ospf_flood.c (ospf_flood_through_area): Fix the problem of
3237 LSA update without DROther.
3238
32392000-05-04 Gleb Natapov <gleb@nbase.co.il>
3240
3241 * ospf_spf.c (ospf_vertex_free): Fix memory leak of SPF calculation.
3242
32432000-05-03 Toshiaki Takada <takada@zebra.org>
3244
3245 * ospf_neighbor.c (ospf_db_summary_add): Use new_lsdb struct
3246 instead linked-list.
3247 (ospf_db_summary_count), (ospf_db_summary_isempty):
3248 New function added.
3249
3250 * ospf_lsa.c (ospf_rotuer_lsa): Re-arrange and divide functions.
3251
32522000-05-02 Gleb Natapov <gleb@nbase.co.il>
3253
3254 * ospf_lsdb.c (new_lsdb_cleanup): Fix memory leak. When LSDB are
3255 not needed any more, then free them.
3256
32572000-05-02 Toshiaki Takada <takada@zebra.org>
3258
3259 * ospfd.c (timers_spf), (no_timers_spf): New defun added.
3260 SPF calculation timers related stuff is rearranged.
3261
3262 * ospf_spf.c (ospf_spf_calculate_timer_add): Function removed.
3263 SPF timer is scheduled by SPF calculation delay and holdtime
3264 configuration variable.
3265
3266 * ospf_lsa.c (ospf_external_lsa_nexthop_get): Set AS-external-LSA's
3267 forwarding address when nexthop learned by other protocols is
3268 in the OSPF domain.
3269
3270 * ospf_zebra.c (ospf_redistribute_source_metric_type),
3271 (ospf_redistribute_source_type_metric): Re-arrange DEFUNs and
3272 ALIASes.
3273
32742000-05-01 Toshiaki Takada <takada@zebra.org>
3275
3276 * ospf_flood.c (ospf_ls_retransmit_count),
3277 (ospf_ls_retransmit_isempty): New function added.
3278
3279 (ospf_ls_retransmit_add), (ospf_ls_retransmit_delete),
3280 (ospf_ls_retransmit_clear), (ospf_ls_retransmit_lookup),
3281 (ospf_ls_retransmit_delete_all), (ospf_ls_retransmit_delete_nbr_all),
3282 (ospf_ls_retransmit_add_nbr_all): Replace these functions to use
3283 new_lsdb.
3284
32852000-04-29 Toshiaki Takada <takada@zebra.org>
3286
3287 * ospfd.c (no_network_area): Add check Area-ID whether specified
3288 Area-ID with prefix matches config.
3289
32902000-04-27 Toshiaki Takada <takada@zebra.org>
3291
3292 * ospf_lsa.c (ospf_maxage_lsa_remover): Fix problem of
3293 remaining withdrawn routes on zebra.
3294
32952000-04-25 Michael Rozhavsky <mike@nbase.co.il>
3296
3297 * ospf_nsm.c (nsm_kill_nbr), (nsm_ll_down), (nsm_change_status),
3298 (ospf_nsm_event): Fix network-LSA re-origination problem.
3299
33002000-04-24 Toshiaki Takada <takada@zebra.org>
3301
3302 * ospf_nsm.c (ospf_db_desc_timer): Fix bug of segmentation fault
3303 with DD retransmission.
3304
3305 * ospf_nsm.c (nsm_kill_nbr): Fix bug of re-origination when
3306 a neighbor disappears.
3307
33082000-04-23 Michael Rozhavsky <mike@nbase.co.il>
3309
3310 * ospf_abr.c (ospf_abr_announce_network_to_area): Fix bug of
3311 summary-LSAs reorigination. Correctly copy OSPF_LSA_APPROVED
3312 flag to new LSA. when summary-LSA is reoriginatd.
3313
3314 * ospf_flood.c (ospf_flood_through_area): Fix bug of flooding
3315 procedure. Change the condition of interface selection.
3316
33172000-04-21 Toshiaki Takada <takada@zebra.org>
3318
3319 * ospf_lsa.c (ospf_refresher_register_lsa): Fix bug of refresh never
3320 occurs.
3321
3322 * ospfd.c (show_ip_ospf_neighbor_id): New defun added.
3323 `show ip ospf neighbor' related commands are re-arranged.
3324
33252000-04-20 Toshiaki Takada <takada@zebra.org>
3326
3327 * ospf_dump.c (debug_ospf_zebra): New defun added.
3328 Suppress zebra related debug information.
3329
33302000-04-19 Toshiaki Takada <takada@zebra.org>
3331
3332 * ospf_zebra.c (ospf_distribute_list_update_timer),
3333 (ospf_distribute_list_update), (ospf_filter_update):
3334 New function added. Re-organize `distribute-list' router ospf
3335 command.
3336
33372000-04-13 Michael Rozhavsky <mike@nbase.co.il>
3338
3339 * ospf_packet.c (ospf_make_ls_upd): Add check for MAX_AGE.
3340
33412000-04-14 Michael Rozhavsky <mike@nbase.co.il>
3342
3343 * ospf_packet.c (ospf_make_ls_upd): Increment LS age by configured
3344 interface transmit_delay.
3345
33462000-04-14 Sira Panduranga Rao <pandu@euler.ece.iisc.ernet.in>
3347
3348 * ospf_interface.c (ip_ospf_cost), (no_ip_ospf_cost):
3349 Add to schedule router_lsa origination when the interface cost changes.
3350
33512000-04-12 Toshiaki Takada <takada@zebra.org>
3352
3353 * ospf_lsa.c (ospf_refresher_register_lsa),
3354 (ospf_refresher_unregister_lsa): Fix bug of core dumped.
3355
3356 * ospfd.c (no_router_ospf): Fix bug of core dumped.
3357
33582000-03-29 Toshiaki Takada <takada@zebra.org>
3359
3360 * ospf_nsm.c (nsm_oneway_received): Fix bug of MS flag unset.
3361
33622000-03-29 Michael Rozhavsky <mike@nbase.co.il>
3363
3364 * ospf_lsa.c (ospf_network_lsa):
3365 * ospf_nsm.c (ospf_nsm_event): Fix bug of Network-LSA originated
3366 in stub network.
3367
33682000-03-28 Toshiaki Takada <takada@zebra.org>
3369
3370 * ospf_nsm.c (nsm_bad_ls_req), (nsm_seq_number_mismatch),
3371 (nsm_oneway_received): Fix bug of NSM state flapping between
3372 ExStart and Exchange.
3373
33742000-03-28 Toshiaki Takada <takada@zebra.org>
3375
3376 * ospf_packet.h (strcut ospf_header): Fix the size of ospf_header,
3377 change u_int8_t to u_char.
3378
33792000-03-27 Toshiaki Takada <takada@zebra.org>
3380
3381 * ospf_lsa.c (ospf_lsa_checksum): Take care of BIGENDIAN architecture.
3382
33832000-03-27 Toshiaki Takada <takada@zebra.org>
3384
3385 * ospfd.c (ospf_interface_run): Make sure Address family matches.
3386
33872000-03-26 Love <lha@s3.kth.se>
3388
3389 * ospf_packet.c (ospf_write): Chack result of sendto().
3390
33912000-03-26 Sira Panduranga Rao <pandu@euler.ece.iisc.ernet.in>
3392
3393 * ospf_nsm.c (nsm_oneway_received): Fix bug of 1-WayReceived in NSM.
3394
33952000-03-23 Libor Pechacek <farco@clnet.cz>
3396
3397 * ospf_lsa.c (ospf_network_lsa)
3398 * ospf_lsdb.c (new_lsdb_insert): Fix bug of accessing to
3399 unallocated memory.
3400
34012000-03-23 Toshiaki Takada <takada@zebra.org>
3402
3403 * ospfd.c (ospf_config_write): Fix bug of duplicate line for
3404 `area A.B.C.D authentication'.
3405
34062000-03-22 Toshiaki Takada <takada@zebra.org>
3407
3408 * ospf_debug.c (debug_ospf_lsa), (no_debug_ospf_lsa): Defun added.
3409 Suppress all zlog related to LSAs with this config option.
3410
34112000-03-21 Kunihiro Ishiguro <kunihiro@zebra.org>
3412
3413 * ospf_nsm.c (ospf_nsm_event): Add check for NSM_InactivityTimer.
3414
34152000-03-21 Toshiaki Takada <takada@zebra.org>
3416
3417 * ospf_packet.c (ospf_ls_upd_timer), (ospf_ls_req):
3418 Fix bug of memory leak about linklist.
3419
3420 * ospf_flood.c (ospf_flood_through_area): Likewise.
3421
34222000-03-18 Sira Panduranga Rao <pandu@euler.ece.iisc.ernet.in>
3423
3424 * ospf_flood.c (ospf_ls_retransmit_lookup): Add checksum comparison
3425 to identify LSA uniquely. This fix routes lost.
3426
34272000-03-18 Toshiaki Takada <takada@zebra.org>
3428
3429 * ospf_ase.c (ospf_find_asbr_route): Add sanity check with router
3430 routing table.
3431
34322000-03-17 Alex Zinin <zinin@amt.ru>
3433
3434 * ospf_spf.[ch]: Bug fix.
3435 The 2nd stage of Dijkstra could consider one vertex
3436 more than once if there is more than one link
3437 between the routers, thus adding extra CPU overhead
3438 and extra next-hops.
3439 Fixed.
3440
34412000-03-15 Sira Panduranga Rao <pandu@euler.ece.iisc.ernet.in>
3442
3443 * ospf_nsm.c (nsm_inactivity_timer): Changed to call nsm_kill_nbr().
3444
34452000-03-14 Toshiaki Takada <takada@zebra.org>
3446
3447 * ospf_route.c (ospf_route_copy_nexthops): Fix bug of memory leak of
3448 ospf_path. Actually ignore merging ospf_route with completely same
3449 paths.
3450
34512000-03-12 Toshiaki Takada <takada@zebra.org>
3452
3453 * ospf_lsa.c (show_as_external_lsa_detail): fix bug of
3454 external route tag byte order.
3455
34562000-03-11 Toshiaki Takada <takada@zebra.org>
3457
3458 * ospf_lsdb.c (ospf_lsdb_insert): New function added.
3459
34602000-03-09 Toshiaki Takada <takada@zebra.org>
3461
3462 * ospf_lsa.c (ospf_external_lsa_install),
3463 (ospf_lsa_lookup), (show_ip_ospf_database_all),
3464 (show_ip_ospf_database_self_originate): Use struct new_lsdb for
3465 LSDB of AS-external-LSAs instead of ospf_lsdb.
3466
3467 * ospf_lsa.c (ospf_lsa_unique_id): New function added.
3468 Use for assigning Unique Link State ID instead of
3469 ospf_get_free_id_for_prefix().
3470
34712000-03-09 Toshiaki Takada <takada@zebra.org>
3472
3473 * ospf_ase.c (ospf_ase_calculate_timer): Fix bug of segmentation
3474 fault reported by George Bonser <george@siteROCK.com>.
3475
34762000-03-07 Libor Pechacek <farco@clnet.cz>
3477
3478 * ospfd.c (ospf_interface_down): Fix bug of segmentation fault.
3479
34802000-03-06 Toshiaki Takada <takada@zebra.org>
3481
3482 * ospf_route.c (ospf_route_cmp): Change meaning of return values.
3483
34842000-03-02 Alex Zinin <zinin@amt.ru>
3485 * ospfd.h, ospf_ia.h
3486 New Shortcut ABR code. Now area's flag can be configured
3487 with Default, Enable, and Disable values.
3488 More info will be in the new ver of I-D soon (see IETF web).
3489
34902000-02-25 Toshiaki Takada <takada@zebra.org>
3491
3492 * ospf_lsa.c (ospf_lsa_header_set), (ospf_external_lsa_body_set),
3493 (osfp_external_lsa_originate), (ospf_external_lsa_queue),
3494 (ospf_external_lsa_originate_from_queue): New function added.
3495 (ospf_external_lsa): Function removed.
3496
3497 * ospf_zebra.c (ospf_zebra_read_ipv4): Originate AS-external-LSA
3498 when listen a route from Zebra, instead creating external route.
3499
3500 * ospf_asbr.c (ospf_asbr_route_add_flood_lsa),
3501 (ospf_asbr_route_add_queue_lsa),
3502 (ospf_asbr_route_install_lsa), (ospf_asbr_route_add):
3503 Functions removed.
3504
3505 * ospf_ase.c (process_ase_lsa): Function will not be used.
3506 (ospf_ase_calculate), (ospf_ase_calculate_route_add),
3507 (ospf_ase_calculate_new_route), (ospf_ase_caluculate_asbr_route):
3508 process_ase_lsa () is separated to these functions.
3509
3510 OSPF AS-external-LSA origination is whole re-organized.
3511
35122000-02-18 Toshiaki Takada <takada@zebra.org>
3513
3514 * ospf_packet.c (ospf_ls_upd): Fix bug of OSPF LSA memory leak.
3515
3516 * ospf_asbr.c (ospf_asbr_route_add_flood_lsa),
3517 (ospf_asbr_route_add_queue_lsa): Fix bug of OSPF external route
3518 memory leak.
3519
35202000-02-12 Kunihiro Ishiguro <kunihiro@zebra.org>
3521
3522 * ospf_asbr.c (ospf_asbr_route_install_lsa): Re-calculate LSA
3523 checksum after change Advertised Router field.
3524
35252000-02-09 Toshiaki Takada <takada@zebra.org>
3526
3527 * ospf_asbr.c (ospf_external_route_lookup): Add new function.
3528
35292000-02-08 Toshiaki Takada <takada@zebra.org>
3530
3531 * ospfd.c (ospf_router_id_get), (ospf_router_id_update),
3532 (ospf_router_id_update_timer): Router ID decision algorithm is changed.
3533 Router ID is chosen from all of eligible interface addresses even if
3534 it is not enable to OSPF.
3535
35362000-02-08 Toshiaki Takada <takada@zebra.org>
3537
3538 * ospf_asbr.c (ospf_asbr_route_add): Function divided to
3539 ospf_asbr_route_add_flood_lsa, ospf_asbr_route_add_queue_lsa and
3540 ospf_asbr_route_install_lsa. If Router-ID is not set, then LSA is
3541 waited to install to LSDB.
3542 `0.0.0.0 adv_router' AS-external-LSA origination bug was fixed.
3543
35442000-02-01 Sira Panduranga Rao <pandu@euler.ece.iisc.ernet.in>
3545
3546 * ospf_flood.c (ospf_ls_retransmit_lookup): Compare LS seqnum
3547 in the ACK before deleting.
3548
3549 * ospf_packet.c (ospf_hello): Reset the flags after a shutdown
3550 and no shutdown of the interface.
3551
35522000-01-31 Toshiaki Takada <takada@zebra.org>
3553
3554 * ospf_packet.c (ospf_ls_req): Send multiple Link State Update
3555 packets respond to a Link State Request packet.
3556
3557 * ospfd.c (show_ip_ospf_neighbor_detail_sub): Show thread state.
3558
3559 * ospf_interface.c (ospf_vl_new): Crash when backbone area
3560 is not configured and set virtual-link to no-backbone area,
3561 bug fixed.
3562
35632000-01-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3564
3565 * ospf_neighbor.h (struct ospf_neighbor): Add pointer to last send
3566 LS Request LSA.
3567
3568 * ospf_packet.c (ospf_ls_upd): Comment out LS request list
3569 treatment. That should be done in OSPF flooding procedure.
3570
3571 * ospf_flood.c (ospf_flood_through_area): Enclose
3572 ospf_check_nbr_loding inside if-else close.
3573
35742000-01-31 Toshiaki Takada <takada@zebra.org>
3575
3576 * ospf_packet.c (ospf_make_ls_upd): Fix bug of #LSAs counting.
3577
35782000-01-29 Toshiaki Takada <takada@zebra.org>
3579
3580 * ospf_packet.c (ospf_make_md5_digest): Fix bug of md5 authentication.
3581
35822000-01-28 Toshiaki Takada <takada@zebra.org>
3583
3584 * ospfd.c (show_ip_ospf): Show Number of ASE-LSAs.
3585
35862000-01-27 Kunihiro Ishiguro <kunihiro@zebra.org>
3587
3588 * ospf_packet.c (ospf_make_db_desc): Don't use rm_list for
3589 removing LSA from nbr->db_summary.
3590
35912000-01-27 Sira Panduranga Rao <pandu@euler.ece.iisc.ernet.in>
3592
3593 * ospf_packet.c (ospf_ls_upd_send): Set AllSPFRouters to
3594 destination when the link is point-to-point.
3595 (ospf_ls_ack_send_delayed): Likewise.
3596
35972000-01-27 Kunihiro Ishiguro <kunihiro@zebra.org>
3598
3599 * ospf_flood.c (ospf_ls_request_delete_all): Fix bug of next
3600 pointer lookup after the node is freed.
3601
36022000-01-26 Kunihiro Ishiguro <kunihiro@zebra.org>
3603
3604 * ospf_asbr.c (ospf_asbr_route_add): Instead of scanning all AS
3605 external route, use ospf_top->external_self.
3606
36072000-01-27 Toshiaki Takada <takada@zebra.org>
3608
3609 * ospf_lsa.c (ospf_forward_address_get): New function added.
3610
3611 * ospf_asbr.c (ospf_asbr_check_lsas): Originate AS-external-LSA
3612 only when it should be replaced.
3613
36142000-01-25 Kunihiro Ishiguro <kunihiro@zebra.org>
3615
3616 * ospf_flood.c (ospf_ls_retransmit_clear): Delete list node.
3617
3618 * ospf_lsa.c (ospf_lsa_free): Reduce logging message using
3619 ospf_zlog value.
3620
3621 * ospf_ism.c (ism_change_status): Fix bug of DR -> non DR status
3622 change. Self originated LSA is freed but not deleted from lsdb.
3623
36242000-01-24 Kunihiro Ishiguro <kunihiro@zebra.org>
3625
3626 * ospf_ism.c (ism_interface_down): Don't use router_id for
3627 detecting self neighbor structure. Instead of that compare
3628 pointer itself.
3629
3630 * ospf_neighbor.c (ospf_nbr_free): Cancel all timer when neighbor
3631 is deleted.
3632 (ospf_nbr_free): Free last send packet.
3633
3634 * ospf_neighbor.h (struct ospf_neighbor): Remove host strucutre.
3635 Instead of that src is introduced.
3636
3637 * ospf_nsm.h: Enclose macro defenition with do {} while (0).
3638
36392000-01-17 Kunihiro Ishiguro <kunihiro@zebra.org>
3640
3641 * ospfd.c: Change part of passive interface implementation. For
3642 passive interface just disabling sending/receiving Hello on the
3643 interface.
3644
36452000-01-16 Kai Bankett <kai.bankett@vew-telnet.net>
3646
3647 * ospf_interface.h (OSPF_IF_PASSIVE): Add passive flag.
3648 * ospf_interface.c (ospf_if_lookup_by_name): Add new function.
3649 * ospf_lsa.c (ospf_router_lsa): Skip passive interface.
3650 * ospfd.c (passive_interface): New command passive-interface is
3651 added.
3652 (ospf_config_write): Print passive interface.
3653
36542000-01-15 Toshiaki Takada <takada@zebra.org>
3655
3656 * ospf_interface.h (crypt_key): New struct added to store
3657 multiple cryptographic autheitication keys.
3658 (ospf_interface): struct changed.
3659
3660 * ospf_interface.c: ospf_crypt_key_new, ospf_crypt_key_add,
3661 ospf_crypt_key_lookup, ospf_crypt_key_delete: new functions added.
3662
3663 * ospf_packet.c (ip_ospf_message_digest_key): Changed to store
3664 multiple cryptographic authentication keys.
3665
36662000-01-14 Toshiaki Takada <takada@zebra.org>
3667
3668 * ospf_interface.c: DEFUN (if_ospf_*) commands changed name to
3669 ip_ospf_* ().
3670 Old notation `ospf *' still remains backward compatibility.
3671
36721999-12-29 Alex Zinin <zinin@amt.ru>
3673 * ospf_lsa.c: ospf_lsa_more_recent() bug fix
3674 * ospf_nsm.c, ospf_packet.c: remove nbr data struct when
3675 int goes down, also check DD flags correctly (bug fix)
3676
36771999-12-28 Alex Zinin <zinin@amt.ru>
3678 * "redistribute <source> metric-type (1|2) metric <XXX>" added
3679
36801999-12-23 Alex Zinin <zinin@amt.ru>
3681 * added RFC1583Compatibility flag
3682 * added dynamic interface up/down functionality
3683
36841999-11-19 Toshiaki Takada <takada@zebra.org>
3685
3686 * ospf_neighbor.h (struct ospf_neighbor): Add member state_change
3687 for NSM state change statistics.
3688
36891999-11-19 Toshiaki Takada <takada@zebra.org>
3690
3691 * ospfd.c (show_ip_ospf_neighbor_detail),
3692 (show_ip_ospf_neighbor_int_detail): DEFUN Added.
3693
36941999-11-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3695
3696 * ospf_asbr.c (ospf_asbr_check_lsas): Add check of
3697 lsa->refresh_list.
3698
36991999-11-11 Toshiaki Takada <takada@zebra.org>
3700
3701 * ospf_ia.[ch] (OSPF_EXAMINE_SUMMARIES_ALL): Macro added.
3702 This macro is expanded to ospf_examine_summaries ()
3703 for SUMMARY_LSA and SUMMARY_LSA_ASBR.
3704 (OSPF_EXAMINE_TRANSIT_SUMMARIES_ALL): Macro added.
3705 This macro is expanded to ospf_examine_transit_summaries ()
3706 for SUMMARY_LSA and SUMMARY_LSA_ASBR.
3707
37081999-11-11 Toshiaki Takada <takada@zebra.org>
3709
3710 * ospf_lsa.[ch] (ospf_find_self_summary_lsa_by_prefix): Changed to
3711 macro OSPF_SUMMARY_LSA_SELF_FIND_BY_PREFIX.
3712 (ospf_find_self_summary_asbr_lsa_by_prefix): Changed to
3713 macro OSPF_SUMMARY_ASBR_LSA_SELF_FIND_BY_PREFIX.
3714 (ospf_find_self_external_lsa_by_prefix): Changed to
3715 macro OSPF_EXTERNAL_LSA_SELF_FIND_BY_PREFIX.
3716
37171999-11-11 Toshiaki Takada <takada@zebra.org>
3718
3719 * ospfd.c (ospf_abr_type): ospf_abr_type_cisco, ospf_abr_type_ibm,
3720 ospf_abr_type_shortcut and ospf_abr_type_standard DEFUNs are
3721 combined.
3722 * ospfd.c (no_ospf_abr_type): no_ospf_abr_type_cisco,
3723 no_ospf_abr_type_ibm and no_ospf_abr_type_shortcut DEFUNS are
3724 combined.
3725
37261999-11-10 Toshiaki Takada <takada@zebra.org>
3727
3728 * ospf_route.c (ospf_lookup_int_by_prefix): Move function to
3729 ospf_interface.c and change name to ospf_if_lookup_by_prefix ().
3730
37311999-11-01 Alex Zinin <zinin@amt.ru>
3732 * ospf_packet.c
3733 some correction to LSU processing
3734
3735 * ospf_lsa.c ospfd.h
3736 randomize initial LSA refreshment interval
3737 and limit the size of LSA-group to 10
3738 to let randomization work more effectively.
3739
37401999-10-31 Alex Zinin <zinin@amt.ru>
3741 * ospf_interface.c
3742 cancel t_network_lsa_self
3743 when freeing int structure
3744
3745 * ospf_abr.c ospf_asbr.c ospf_flood.c ospf_lsa.c
3746 ospf_lsa.h ospf_lsdb.h ospfd.c ospfd.h
3747
3748 Summary and ASE LSA refreshment functions
3749 added---LSA refreshment is paced to 70 LSAs
3750 per sec to avoid link overflow. Refreshment events
3751 are further randomized within a 10 sec interval
3752 to avoid syncing.
3753
3754 Also the sigfault of memcmp() in ospf_lsa_is_different()
3755 is fixed.
3756
37571999-10-30 Alex Zinin <zinin@amt.ru>
3758 * ospf_nsm.c
3759 Fix the bug where MAX_AGE LSAs
3760 are included into the DB summary.
3761
3762 * ospf_interface.c
3763 allocate 2*MTU input buffer instead of just MTU
3764 for the cases when the other router mistakenly
3765 sends larger packets thus causing fragmentation, etc.
3766
3767 * ospf_nsm.c
3768 in nsm_reset_nbr() lists should be freed
3769 not when they are empty.
3770
37711999-10-29 Kunihiro Ishiguro <kunihiro@zebra.org>
3772
3773 * ospf_zebra.c (ospf_acl_hook): Move OSPF_IS_ASBR and OSPF_IS_ABR
3774 check inside of if (ospf_top).
3775
37761999-10-29 Alex Zinin <zinin@amt.ru>
3777 * ospf_lsa.c ospf_lsdb.c :
3778 add assertion in lsa and lsa->data alloc functions,
3779 as well as in lsdb_add for new->data
3780
3781 * ospf_lsdb.c: free hash table correctly
3782
37831999-10-28 John Capo <jc@irbs.com>
3784
3785 * ospf_packet.h (OSPF_PACKET_MAX): Correct MAX packet length
3786 calculation
3787
37881999-10-27 Kunihiro Ishiguro <kunihiro@zebra.org>
3789
3790 * OSPF-TRAP-MIB.txt: New file added. Edited version of RFC1850.
3791
3792 * OSPF-MIB.txt: New file added. Edited version of RFC1850.
3793
37941999-10-27 Alex Zinin <zinin@amt.ru>
3795 * ospfd, ospf_zebra, ospf_abr
3796 "area import-list" command is added.
3797 This command allows to filter the inter-area routes
3798 injected into an area. Access list hook function
3799 extended to invalidate area exp/imp lists.
3800
38011999-10-25 Yoshinobu Inoue <shin@nd.net.fujitsu.co.jp>
3802
3803 * ospfd.c (ospf_interface_run): Enable to detect P2P network
3804 on an OSPF interface.
3805
38061999-10-19 Jordan Mendelson <jordy@wserv.com>
3807
3808 * ospf_lsdb.c (ospf_lsdb_add): Fix bug of crash
3809 in ospf_ls_retransmit_lookup ().
3810
38111999-10-19 Vladimir B. Grebenschikov <vova@express.ru>
3812
3813 * ospf_route.c: Workaround about installation of OSPF routes into
3814 the zebra daemon. Add checking of existance routes. Free
3815 ospf_top->old_table if it exists.
3816
38171999-10-15 Jordan Mendelson <jordy@wserv.com>
3818
3819 * Add support for MD5 authentication.
3820
38211999-10-12 Alex Zinin <zinin@amt.ru>
3822 * ospfd.c, ospfd.h, ospf_abr.c:
3823 a new command "area export-list" was added, it allows
3824 the admin. to control which intra-area routes are
3825 announced to other areas by the ABR
3826
38271999-10-12 Alex Zinin <zinin@amt.ru>
3828 * ospf_asbr.c (ospf_asbr_check_lsas): Fix bug of coredump
3829 when "no redistribute" is used after a distribute list
3830 denying some networks was used
3831
38321999-10-05 Toshiaki Takada <takada@zebra.org>
3833
3834 * ospf_route.c (ospf_path_dup): New function added.
3835
38361999-10-05 Toshiaki Takada <takada@zebra.org>
3837
3838 * ospf_interface.[ch]: Some of VL related funciton name changed.
3839
38401999-09-27 Alex Zinin <zinin@amt.ru>
3841
3842 * ospf_zebra.c: Distribute-list functionality added
3843
38441999-09-27 Toshiaki Takada <takada@zebra.org>
3845
3846 * ospfd.c (show_ip_ospf): Fix bug of segmentation fault when no ospf
3847 instance exists.
3848
38491999-09-25 Kunihiro Ishiguro <kunihiro@zebra.org>
3850
3851 * ospfd.c (ospf_interface_down): Fix bug of misusing nextnode()
3852 instead of node->next. Reported by Hiroki Ishibashi
3853 <ishibasi@dcd.abk.nec.co.jp>.
3854
3855 * ospf_route.c (show_ip_ospf_route): Add check for ospf is enabled
3856 or not.
3857
38581999-09-23 Alex Zinin <zinin@amt.ru>
3859
3860 * stub area support added
3861
38621999-09-23 Alex Zinin <zinin@amt.ru>
3863
3864 * fwd_addr in ASE-LSAs is now set correctly
3865 * ASE routing changed to check the fwd_addr
3866 and skip the route if the addr points to one
3867 of our interfaces to avoid loops.
3868
38691999-09-22 Alex Zinin <zinin@amt.ru>
3870
3871 * ospf_interface:
3872 ospf_vls_in_area() added, it returns
3873 the number of VLs configured through the area
3874
3875 * ospf_interface.c ospf_lsa.c ospf_lsdb.c ospfd.c
3876 honor correct mem alloc
3877
38781999-09-22 Alex Zinin <zinin@amt.ru>
3879
3880 * memory.[ch]:
3881 Some OSPF mem types added,
3882 plus more info in "show mem"
3883
38841999-09-21 Alex Zinin <zinin@amt.ru>
3885
3886 * ospfd.c:
3887 "area range substitute" added.
3888 It can be used on NAT-enabled (IP-masquarade)
3889 routers to announce private networks
3890 from an area as public ones into the outside
3891 world (not in the RFC, btw :)
3892
38931999-09-21 Alex Zinin <zinin@amt.ru>
3894
3895 * ospfd.c:
3896 "area range suppress" added.
3897 This command allows to instruct the router
3898 to be silent about specific ranges, i.e.,
3899 it is a method of route filtering on area
3900 borders
3901
39021999-09-21 Alex Zinin <zinin@amt.ru>
3903
3904 * ospfd.c VLs removed when "no network area" executed
3905
39061999-09-20 Alex Zinin <zinin@amt.ru>
3907
3908 * ospf_ase.c bug fix for not-zero fwd_addr
3909 and directly connected routes.
3910
39111999-09-20 Yon Uriarte <yon@plannet.de>
3912
3913 * ospf_packet.c (ospf_make_ls_req): Introduce delta value for
3914 checking the length of OSPF packet exceeds MTU or not.
3915
3916 * ospf_lsa.c (ospf_lsa_different): Apply ntohs for checking
3917 l1->data->length.
3918
39191999-09-18 Alex Zinin <zinin@amt.ru>
3920
3921 * ospf_lsa.c bug fix for ospf_network_lsa() to
3922 include itself into the RID list
3923
39241999-09-10 Alex Zinin <zinin@amt.ru>
3925
3926 * Alternative ABR behaviors IBM/Cisco/Shortcut
3927 implemented
3928
39291999-09-10 Alex Zinin <zinin@amt.ru>
3930
3931 * router and network-LSA origination
3932 changed to honor MinLSInterval
3933
39341999-09-08 Alex Zinin <zinin@amt.ru>
3935
3936 * modified ABR behavior to honor VLs and transit
3937 areas
3938
39391999-09-07 Alex Zinin <zinin@amt.ru>
3940
3941 * completed VL functionality
3942
39431999-09-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3944
3945 * ospf_asbr.c: New file.
3946 ospf_asbr.h: New file.
3947
3948 * ospf_zebra.c (ospf_redistribute_connected): Add redistribute
3949 related stuff.
3950
39511999-09-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3952
3953 * ospfd.h (OSPF_FLAG_VIRTUAL_LINK): Change OSPF_FLAG_VEND to
3954 OSPF_FLAG_VIRTUAL_LINK for comprehensiveness.
3955
39561999-09-03 Kunihiro Ishiguro <kunihiro@zebra.org>
3957
3958 * ospf_spf.c (ospf_spf_register): Change name from
3959 ospf_spf_route_add() to ospf_spf_register().
3960 Include "ospfd/ospf_abr.h" for ospf_abr_task() prototype.
3961
39621999-09-02 Kunihiro Ishiguro <kunihiro@zebra.org>
3963
3964 * ospf_lsa.c (ospf_external_lsa_install): Change to update
3965 lsa->data rather than install new one, when same id lsa is already
3966 installed.
3967
39681999-09-01 Kunihiro Ishiguro <kunihiro@zebra.org>
3969
3970 * ospf_lsa.c (ospf_router_lsa_install): Return lsa value.
3971 (ospf_network_lsa_install): Likewise.
3972 (ospf_summary_lsa_install): Likewise.
3973 (ospf_summary_asbr_lsa_install): Likewise.
3974 (ospf_external_lsa_install): Likewise.
3975
3976 * ospf_spf.c (ospf_spf_calculate): Comment out debug function
3977 ospf_rtrs_print().
3978
39791999-08-31 Kunihiro Ishiguro <kunihiro@zebra.org>
3980
3981 * ospf_spf.c (ospf_rtrs_free): Add ospf_spf_calculate() for
3982 freeing rtrs.
3983
39841999-08-31 Toshiaki Takada <takada@zebra.org>
3985
3986 * ospf_lsa.c (show_ip_ospf_database_summary),
3987 (show_ip_ospf_database_summary_asbr),
3988 (show_ip_ospf_database_external): New function added.
3989 `show ip ospf database summary',
3990 `show ip ospf database asbr-summary'
3991 `show ip ospf database external' command can be used.
3992
3993 * ospf_lsa.c (ospf_lsa_count_table): New function added.
3994 (show_ip_ospf_database_all): show nothing if a type of LSA
3995 does not exist.
3996
39971999-08-31 Kunihiro Ishiguro <kunihiro@zebra.org>
3998
3999 * ospf_lsa.c (ospf_maxage_lsa_remover): Preserve next pointer when
4000 the node is deleted.
4001
40021999-08-31 Toshiaki Takada <takada@zebra.org>
4003
4004 * ospf_flood.c (ospf_ls_retransmit_lookup): change to return
4005 struct ospf_lsa *.
4006 (ospf_ls_request_new), (ospf_ls_request_free),
4007 (ospf_ls_request_add), (ospf_ls_request_delete),
4008 (ospf_ls_request_delete_all), (ospf_ls_request_lookup):
4009 New function added.
4010
4011 * ospf_packet.c (ospf_ls_upd_send_lsa): New function added.
4012
4013 * ospf_lsa.h (LS_AGE): Slightly change macro definition.
4014
4015 * ospf_lsa.c (ospf_lsa_more_recent), (ospf_lsa_diffrent):
4016 Use LS_AGE macro.
4017
40181999-08-30 Alex Zinin <zinin@amt.ru>
4019
4020 * ospfd.c
4021 fix a bug with area range config write
4022 added "show ip ospf" command, it will be enhanced later on
4023
40241999-08-30 Alex Zinin <zinin@amt.ru>
4025
4026 * ospf_lsa.c
4027 updated ospf_router_lsa() to honor flags (B-bit)
4028
40291999-08-30 Alex Zinin <zinin@amt.ru>
4030
4031 * ospf_abr.c
4032 wrote major functions implementing ABR activity
4033
40341999-08-30 Alex Zinin <zinin@amt.ru>
4035
4036 * ospf_ia.c ospf_route.c ospf_route.h
4037 fixed the bug with ospf_route.origin field.
4038 Now it holds pointer to lsa_header
4039
40401999-08-30 Alex Zinin <zinin@amt.ru>
4041
4042 * ospf_flood.c ospf_flood.h:
4043 transformed ospf_flood_if_select into ospf_flood_through_area()
4044 added new ospf_flood_if_select() and ospf_flood_through_as()
4045
40461999-08-30 Toshiaki Takada <takada@zebra.org>
4047
4048 * ospf_flood.[ch]: New file added.
4049
4050 * ospf_packet.c (ospf_lsa_flooding),
4051 (ospf_lsa_flooding_select_if): functions move to ospf_flood.c
4052
4053 * ospf_neighbor.c (ospf_put_lsa_on_retransm_list),
4054 (ospf_remove_lsa_from_retransm_list),
4055 (ospf_nbr_remove_all_lsas_from_retransm_list),
4056 (ospf_lsa_remove_from_ls_retransmit):
4057 (ospf_lsa_retransmit): functions move to
4058 ospf_flood.c, and change function's name:
4059
4060 ospf_put_lsa_on_retransm_list ()
4061 -> ospf_ls_retransmit_add ()
4062 ospf_remove_lsa_from_retransm_list ()
4063 -> ospf_ls_retransmit_delete ()
4064 ospf_nbr_remove_all_lsas_from_retransm_list ()
4065 -> ospf_ls_retransmit_clear ()
4066 ospf_lsa_remove_from_ls_retransmit ()
4067 -> ospf_ls_retransmit_delete_nbr_all ()
4068 ospf_lsa_retransmit ()
4069 -> ospf_ls_retransmit_add_nbr_all ()
4070
4071 * ospf_lsa.c (ospf_lsa_lookup_from_list): function move to
4072 ospf_flood.c, and change name to ospf_ls_retransmit_lookup ().
4073
40741999-08-30 Kunihiro Ishiguro <kunihiro@zebra.org>
4075
4076 * ospf_neighbor.c (ospf_nbr_lookup_by_addr): Use
4077 route_node_lookup() instead of route_node_get().
4078
4079 * ospf_packet.c (ospf_ls_upd): Temporary comment out (6) check.
4080
40811999-08-30 Kunihiro Ishiguro <kunihiro@zebra.org>
4082
4083 * ospf_route.c (ospf_lookup_int_by_prefix): Add check of
4084 oi->address.
4085
40861999-08-29 Alex Zinin <zinin@amt.ru>
4087 * ospf_lsa.c
4088 MaxAge LSA deletion functions added.
4089
40901999-08-29 Alex Zinin <zinin@amt.ru>
4091 * ospf_neighbor.c
4092 ospf_nbr_lookup_by_addr(): added route_unlock_node()
4093 when function returns NULL if (rn->info == NULL)
4094
40951999-08-29 Alex Zinin <zinin@amt.ru>
4096 * ospfd.c
4097 added a hack for area range deletion
4098
40991999-08-29 Alex Zinin <zinin@amt.ru>
4100 * ospf_lsa.h
4101 included lsdb field into struct ospf_lsa, to find
4102 LSDB easier when removing MaxAge LSAs.
4103
41041999-08-29 Alex Zinin <zinin@amt.ru>
4105 * ospf_lsa.c ospf_neighbor.c ospf_nsm.c
4106 ospf_packet.c changed to honor new retransmit list
4107 management functions
4108
41091999-08-29 Alex Zinin <zinin@amt.ru>
4110 * ospf_neighbor.c , .h added new retransmit list functions.
4111
41121999-08-29 Alex Zinin <zinin@amt.ru>
4113 * Makefile.in
4114 added ospf_ase, ospf_abr, ospf_ia
4115
41161999-08-29 Alex Zinin <zinin@amt.ru>
4117 * ospf_spf.c:
4118 - changed ospf_next_hop_calculation() to include interface
4119 and nexthop addr for directly connected routers---more informative
4120 and solves problem with route installation into the kernel
4121 - changed ospf_nexthop_out_if_addr() to support routers, not only
4122 transit networks
4123 - added ospf_process_stubs();
4124
41251999-08-29 Alex Zinin <zinin@amt.ru>
4126 * ospf_lsa.c:
4127 - changed ospf_router_lsa() to provide correct links
4128 for p-t-p interfaces;
4129 - changed ospf_summary_lsa_install() to support table
4130 of self-originated summary-LSAs;
4131 - added ospf_summary_asbr_lsa_install() and ospf_external_lsa_install()
4132 - changed ospf_lsa_install() accordingly
4133 - changed show_ip_ospf_database_router_links() to support p-t-p
4134
41351999-08-29 Kunihiro Ishiguro <kunihiro@zebra.org>
4136
4137 * ospf_packet.c (ospf_make_db_desc): Only master can clear more
4138 flag.
4139
41401999-08-29 Kunihiro Ishiguro <kunihiro@zebra.org>
4141
4142 * ospf_packet.c (ospf_read): Add check of IP src address.
4143
41441999-08-28 Alex Zinin <zinin@amt.ru>
4145 * ospf_neighbor.h
4146 added ospf_nbr_lookup_by_routerid()
4147
41481999-08-28 Alex Zinin <zinin@amt.ru>
4149 * ospfd.h
4150 added ABR/ASBR flag definitions and fields;
4151 added iflist field to area structure;
4152 summary_lsa_self and summary_lsa_asbr_self are changed
4153 to be route tables;
4154 added ranges field---configured area ranges;
4155 A separate Routers RT added;
4156 area range config commands and config write added
4157
4158
41591999-08-28 Alex Zinin <zinin@amt.ru>
4160 * ospf_route.c :
4161 ospf_route_free()--added code to free the list of paths;
4162 The following functions added:
4163 ospf_intra_add_router();
4164 ospf_intra_add_transit();
4165 ospf_intra_add_stub();
4166 the last function uses new ospf_int_lookup_by_prefix();
4167 show_ip_ospf_route_cmd()--changed to support new RT structure;
4168 added ospf_cmp_routes()--general route comparision function;
4169 added ospf_route_copy_nexthops() and ospf_route_copy_nexthops_from_vertex()
4170 they are used in ASE and IA routing;
4171 added ospf_subst_route() and ospf_add_route();
4172
41731999-08-28 Alex Zinin <zinin@amt.ru>
4174 * ospf_route.h :
4175 changed struct ospf_path to include output interface,
4176 changed struct ospf_route to support IA and ASE routing.
4177 added prototypes of the function used in IA and ASE modules.
4178
41791999-08-28 Alex Zinin <zinin@amt.ru>
4180 * ospf_lsa.h ospf_lsa.c :
4181 added ospf_my_lsa(), an interface independent version of
4182 ospf_lsa_is_self_originated(), it will be used in ASE and IA-routing.
4183
41841999-08-27 Kunihiro Ishiguro <kunihiro@zebra.org>
4185
4186 * ospf_interface.c (interface_config_write): Add check for
4187 oi->nbr_self.
4188
41891999-08-25 Toshiaki Takada <takada@zebra.org>
4190
4191 * ospf_lsa.c (ospf_lsa_dup): New function added.
4192
4193 * ospf_packet.c (ospf_write), (ospf_read): Print send/recv
4194 interface in debug message.
4195
41961999-08-25 Toshiaki Takada <takada@zebra.org>
4197
4198 * ospf_packet.c (ospf_ls_ack_send): The name is changed from
4199 `ospf_ls_ack_send'.
4200 (ospf_ls_ack_send_delayed) (ospf_ls_ack_timer): New function added.
4201 Delayed Link State Acknowledgment is scheduled by timer.
4202
42031999-08-25 Alex Zinin <zinin@amt.ru>
4204
4205 * ospf_lsa.c (ospf_router_lsa): Incorrectly included link to
4206 a stub network instead of link to a transit network into
4207 originated router-LSA, bug fixed.
4208
42091999-08-24 Toshiaki Takada <takada@zebra.org>
4210
4211 * ospfd.c (ospf_update_router_id): New function added.
4212
4213 * ospf_network.c (ospf_write): Create new socket per transmission.
4214 And select outgoing interface whether dst is unicast or multicast.
4215
4216 * ospf_packet.c: LSA flooding will work.
4217
42181999-08-24 VOP <vop@unity.net>
4219
4220 * ospf_route.c: Include "sockunion.h"
4221
42221999-08-24 Kunihiro Ishiguro <kunihiro@zebra.org>
4223
4224 * ospf_network.c (ospf_serv_sock_init): Enclose
4225 IPTOS_PREC_INTERNETCONTROL setting with #ifdef for OS which does
4226 not have the definition.
4227
42281999-08-23 Toshiaki Takada <takada@zebra.org>
4229
4230 * ospf_packet.c: Fix bug of DD processing.
4231
42321999-08-18 Toshiaki Takada <takada@zebra.org>
4233
4234 * ospf_lsa.c (show_ip_ospf_database): Show actual `LS age'.
4235
42361999-08-17 Toshiaki Takada <takada@zebra.org>
4237
4238 * ospf_lsa.h (OSPF_MAX_LSA): The value of OSPF_MAX_LSA is
4239 corrected. The bug of `mes_lookup' is fixed.
4240 This had been reported by Poul-Henning Kamp <phk@freebsd.org>.
4241
4242 * ospf_lsa.c (ospf_router_lsa_install): The name is changed from
4243 `ospf_add_router_lsa'.
4244 (ospf_network_lsa_install): The name is changed from
4245 `ospf_add_network_lsa'.
4246
4247 * ospf_interface.h (ospf_interface): Add member `nbr_self'.
4248
4249 * ospf_interface.c (ospf_if_is_enable): New function added.
4250
42511999-08-16 Toshiaki Takada <takada@zebra.org>
4252
4253 * ospf_lsa.h (struct lsa_header): The name is changed from
4254 `struct ospf_lsa'.
4255 (struct ospf_lsa): New struct added to control each LSA's aging
4256 and timers.
4257
4258 * ospf_lsa.c (ospf_lsa_data_free): The name is change from
4259 `ospf_lsa_free'.
4260 (ospf_lsa_data_new), (ospf_lsa_new), (ospf_lsa_free),
4261 (ospf_lsa_different), (ospf_lsa_install): New function added.
4262
4263 * ospf_packet.c (ospf_ls_upd_list_lsa): New function added.
4264
42651999-08-12 Toshiaki Takada <takada@zebra.org>
4266
4267 * ospf_nsm.c (nsm_reset_nbr): New function added.
4268 KillNbr and LLDown neighbor event call this function.
4269
42701999-08-10 Toshiaki Takada <takada@zebra.org>
4271
4272 * ospf_packet.c (ospf_ls_retransmit)
4273 (ospf_ls_upd_timer): New function added.
4274 Set retransmission timer for Link State Update.
4275
42761999-07-29 Toshiaki Takada <takada@zebra.org>
4277
4278 * ospf_ism.c (ospf_dr_election): Fix bug of DR election.
4279
42801999-07-28 Toshiaki Takada <takada@zebra.org>
4281
4282 * ospf_network.c (ospf_serv_sock_init): Set IP precedence field
4283 with IPTOS_PREC_INTERNET_CONTROL.
4284
4285 * ospf_nsm.c (nsm_change_status): Schedule NeighborChange event
4286 if NSM status change.
4287
4288 * ospf_packet.c (ospf_make_hello): Never include a neighbor in
4289 Hello packet, when the neighbor goes down.
4290
42911999-07-26 Kunihiro Ishiguro <kunihiro@zebra.org>
4292
4293 * Makefile.am (noinst_HEADERS): Add ospf_route.h.
4294
4295 * ospf_route.c (show_ip_ospf_route): Add `show ip ospf route'
4296 command.
4297
42981999-07-25 Toshiaki Takada <takada@zebra.org>
4299
4300 * ospf_lsa.c (ospf_router_lsa): Fix bug of LS sequence number
4301 assignement.
4302
43031999-07-25 Kunihiro Ishiguro <kunihiro@zebra.org>
4304
4305 * ospf_route.c (ospf_route_table_free): New function added.
4306
4307 * ospf_spf.c (ospf_spf_next): Free vertex w when cw's and w's
4308 distance is same.
4309
4310 * ospfd.h (struct ospf): Add old_table.
4311
4312 * ospf_main.c (sighup): Call of log_rotate () removed.
4313
4314 * ospf_lsa.c (ospf_lsa_is_self_originated): Fix bug of checking
4315 area->lsa as self LSA. This should be area->lsa_self.
4316
43171999-07-24 Kunihiro Ishiguro <kunihiro@zebra.org>
4318
4319 * ospf_zebra.c (ospf_zebra_add): ospf_zebra_add
4320 (),ospf_zebra_delete () added.
4321
4322 * ospf_spf.c (ospf_spf_calculate): Call ospf_intra_route_add ().
4323
43241999-07-24 Toshiaki Takada <takada@zebra.org>
4325
4326 * ospf_lsa.c: Change LS sequence number treatment.
4327 (ospf_lsa_is_self_originated): New function added.
4328 (show_ip_ospf_database_self_originated): New DEFUN added.
4329
43301999-07-23 Kunihiro Ishiguro <kunihiro@zebra.org>
4331
4332 * ospf_interface.c (ospf_if_lookup_by_addr): Add loopback check.
4333
43341999-07-22 Toshiaki Takada <takada@zebra.org>
4335
4336 * ospf_spf.c (ospf_nexthop_new), (ospf_nexthop_free),
4337 (ospf_nexthop_dup): function added.
4338 (ospf_nexthop_calculation): function changed.
4339
4340 * ospf_interface.c (ospf_if_lookup_by_addr): function added.
4341
43421999-07-21 Toshiaki Takada <takada@zebra.org>
4343
4344 * ospf_spf.c (ospf_spf_closest_vertex): function removed.
4345
43461999-07-21 Kunihiro Ishiguro <kunihiro@zebra.org>
4347
4348 * ospf_spf.c (ospf_spf_next): Apply ntohs for fetching metric.
4349
43501999-07-21 Toshiaki Takada <takada@zebra.org>
4351
4352 * ospf_neighbor.c (ospf_nbr_lookup_by_router_id): fundtion removed.
4353
4354 * ospf_lsa.c (show_ip_ospf_database_router): describe each
4355 connected link.
4356
43571999-07-21 Kunihiro Ishiguro <kunihiro@zebra.org>
4358
4359 * ospf_spf.c (ospf_spf_next): V is router LSA or network LSA so
4360 change behavior according to LSA type.
4361 (ospf_lsa_has_link): Link check function is added.
4362
43631999-07-20 Kunihiro Ishiguro <kunihiro@zebra.org>
4364
4365 * ospf_spf.c (ospf_spf_calculate_schedule): Add new function for
4366 SPF calcultion schedule addtition.
4367 (ospf_spf_calculate_timer_add): Rough 30 sec interval SPF calc
4368 timer is added.
4369 (ospf_spf_next_router): Delete ospf_spf_next_network ().
4370
4371 * ospf_lsa.c (show_ip_ospf_database_all): Network-LSA display
4372 header typo correction. Display of router LSA's #link added.
4373
43741999-07-19 Toshiaki Takada <takada@zebra.org>
4375
4376 * ospf_packet.c (ospf_check_network_mask): Added new function for
4377 receiving Raw IP packet on an appropriate interface.
4378
43791999-07-16 Toshiaki Takada <takada@zebra.org>
4380
4381 * ospfd.c (ospf_router_id): new DEFUN added.
4382
43831999-07-15 Toshiaki Takada <takada@zebra.org>
4384
4385 * ospf_spf.c (ospf_spf_init), (ospf_spf_free),
4386 (ospf_spf_has_vertex), (ospf_vertex_lookup),
4387 (ospf_spf_next_router), (ospf_spf_next_network),
4388 (ospf_spf_closest_vertex), (ospf_spf_calculate):
4389 function added.
4390
43911999-07-13 Toshiaki Takada <takada@zebra.org>
4392
4393 * ospf_ism.c: fix bug of DR Election.
4394
4395 * ospf_nsm.c: fix bug of adjacency forming.
4396
43971999-07-05 Kunihiro Ishiguro <kunihiro@zebra.org>
4398
4399 * ospfd.c (ospf_init): Change to use install_default.
4400
44011999-07-01 Rick Payne <rickp@rossfell.co.uk>
4402
4403 * ospf_zebra.c (zebra_init): Install standard commands to
4404 ZEBRA_NODE.
4405
44061999-06-30 Toshiaki Takada <takada@zebra.org>
4407
4408 * ospf_dump.c: Whole debug command is improved.
4409 (ISM|NSM) (events|status|timers) debug option added.
4410 (show_debugging_ospf): new DEFUN added.
4411
44121999-06-30 Kunihiro Ishiguro <kunihiro@zebra.org>
4413
4414 * ospf_lsa.c (ospf_lsa_lookup_from_list): Change !IPV4_ADDR_CMP to
4415 IPV4_ADDR_SAME.
4416
44171999-06-29 Toshiaki Takada <takada@zebra.org>
4418
4419 * ospf_dump.c (ospf_summary_lsa_dump): Add summary-LSA dump routine.
4420 (ospf_as_external_lsa_dump): Add AS-external-LSA dump routine.
4421
4422 * ospf_nsm.c (nsm_twoway_received): fix condtion of adjacnet.
4423
4424 * ospf_ism.c (ospf_dr_election): fix DR Election.
4425
4426 * ospf_dump.c (ospf_nbr_state_message): fix `show ip ospf neighbor'
4427 command's state.
4428
44291999-06-29 Kunihiro Ishiguro <kunihiro@zebra.org>
4430
4431 * ospf_dump.c (ospf_router_lsa_dump): Add router-LSA dump routine.
4432
44331999-06-28 Toshiaki Takada <takada@zebra.org>
4434
4435 * ospf_lsa.c (show_ip_ospf_database_network): fix bug of
4436 `show ip ospf database network' command output.
4437
4438 * ospf_nsm.c (nsm_inactivity_timer): Clear list of Link State
4439 Retransmission, Database Summary and Link State Request.
4440
4441 * ospf_packet.c (ospf_ls_req_timer): New function added.
4442 Set Link State Request retransmission timer.
4443
44441999-06-27 Kunihiro Ishiguro <kunihiro@zebra.org>
4445
4446 * ospf_main.c (main): Change default output from ZLOG_SYSLOG to
4447 ZLOG_STDOUT.
4448
4449 * ospfd.c (ospf_init): Register show_ip_ospf_interface_cmd and
4450 show_ip_ospf_neighbor_cmd to VIEW_NODE.
4451
4452 * ospf_lsa.c (ospf_lsa_init): Register show_ip_ospf_database_cmd
4453 and show_ip_ospf_database_type_cmd to VIEW_NODE.
4454
44551999-06-25 Toshiaki Takada <takada@zebra.org>
4456
4457 * ospf_packet.c: fix bug of DD making.
4458 fix bug of LS-Update reading.
4459
44601999-06-23 Toshiaki Takada <takada@zebra.org>
4461
4462 * ospf_packet.c: All type of packets are changed to use
4463 fifo queue structure.
4464 (ospf_fill_header) function added.
4465
44661999-06-22 Toshiaki Takada <takada@zebra.org>
4467
4468 * ospf_packet.c (ospf_packet_new): New function added to handle
4469 sending ospf packet by fifo queue structure.
4470 (ospf_packet_free), (ospf_fifo_new), (ospf_fifo_push),
4471 (ospf_fifo_pop), (ospf_fifo_head), (ospf_fifo_flush),
4472 (ospf_fifo_free): Likewise.
4473
44741999-06-21 Toshiaki Takada <takada@zebra.org>
4475
4476 * ospf_nsm.c (ospf_db_desc_timer): function added.
4477 (nsm_timer_set) function added.
4478 * ospf_dump.c (ospf_option_dump): function added.
4479 * ospf_packet.c (ospf_ls_req) (ospf_make_ls_req): function added.
4480
44811999-06-20 Toshiaki Takada <takada@zebra.org>
4482
4483 * ospf_lsa.c (ospf_lsa_more_recent): function added.
4484 * ospf_neighbor.h (struct ospf_neighbor): Change member ms_flag
4485 to dd_flags.
4486
44871999-06-19 Toshiaki Takada <takada@zebra.org>
4488
4489 * ospf_lsa.c: DEFUN (show_ip_ospf_database) Added.
4490 * ospf_interface.c (if_ospf_cost), (if_ospf_dead_interval),
4491 (if_ospf_hello_interval), (if_ospf_priority),
4492 (if_ospf_retransmit_interval), (if_ospf_transmit_delay)
4493 argument changed from NUMBER to <range>.
4494 DEFUN (if_ospf_network_broadcast),
4495 DEFUN (if_ospf_network_non_broadcast),
4496 DEFUN (if_ospf_network_point_to_multipoint),
4497 DEFUN (if_ospf_network_point_to_point) functions are combined to
4498 DEFUN (if_ospf_network).
4499
45001999-06-18 Toshiaki Takada <takada@zebra.org>
4501
4502 * ospf_lsa.c: ospf_add_router_lsa (), ospf_add_network_lsa (),
4503 ospf_lsa_lookup (), ospf_lsa_count () Added.
4504
45051999-06-15 Toshiaki Takada <takada@zebra.org>
4506
4507 * DEFUN (ospf_debug_ism), DEFUN (ospf_debug_nsm),
4508 DEFUN (no_ospf_debug_ism), DEFUN (no_ospf_debug_nsm) Added.
4509 `debug ospf ism' command shows debug message.
4510 `debuf ospf nsm' command shows debug message.
4511
45121999-06-14 Toshiaki Takada <takada@zebra.org>
4513
4514 * ospf_lsa.c: ospf_network_lsa () Added.
4515 ospf_lsa_checksum () Added.
4516 * DEFUN (ospf_debug_packet), DEFUN (no_ospf_debug_packet) Added.
4517 `debug ospf packet' command shows debug message.
4518
45191999-06-13 Toshiaki Takada <takada@zebra.org>
4520
4521 * ospf_packet.h: Remove struct ospf_ls_req {}, ospf_ls_upd {},
4522 ospf_ls_ack {}.
4523
45241999-06-11 Toshiaki Takada <takada@zebra.org>
4525
4526 * ospf_dump.c: fix IP packet length treatment.
4527
45281999-06-10 Toshiaki Takada <takada@zebra.org>
4529
4530 * ospf_ism.h: Add OSPF_ISM_EVENT_EXECUTE() Macro Added.
4531 * ospf_nsm.h: Add OSPF_NSM_EVENT_EXECUTE() Macro Added.
4532
4533 * ospf_packet.c: ospf_db_desc (), ospf_db_desc_send () Added.
4534 ospf_make_hello (), ospf_make_db_desc () Added.
4535 ospf_db_desc_proc () Added.n
4536
4537 * Database Description packet can be processed.
4538
45391999-06-08 Toshiaki Takada <takada@zebra.org>
4540
4541 * ospf_lsa.c: New file.
4542
45431999-06-07 Toshiaki Takada <takada@zebra.org>
4544
4545 * ospf_neighbor.c: ospf_fully_adjacent_count () Added.
4546
45471999-06-07 Kunihiro Ishiguro <kunihiro@zebra.org>
4548
4549 * ospf_spf.[ch]: New file.
4550
45511999-05-30 Kunihiro Ishiguro <kunihiro@zebra.org>
4552
4553 * ospf_zebra.c: Changed to use lib/zclient.c routines.
4554
4555 * ospf_zebra.h (zebra_start): Remove struct zebra.
4556
45571999-05-29 Kunihiro Ishiguro <kunihiro@zebra.org>
4558
4559 * ospfd.c (ospf_config_write): Add cast (unsigned long int) to
4560 ntohl for sprintf warning.
4561
45621999-05-19 Toshiaki Takada <takada@zebra.org>
4563
4564 * ospf_ism.c (ospf_dr_election): Join AllDRouters Multicast group
4565 if interface state changes to DR or BDR.
4566
45671999-05-14 Stephen R. van den Berg <srb@cuci.nl>
4568
4569 * ospf_main.c (signal_init): SIGTERM call sigint.
4570 (sigint): Logging more better message.
4571
45721999-05-12 Toshiaki Takada <takada@zebra.org>
4573
4574 * ospfd.c: Fix bug of `no router ospf' statement, it will work.
4575
45761999-05-11 Toshiaki Takada <takada@zebra.org>
4577
4578 * ospf_neighbor.c: ospf_nbr_free () Added.
4579
45801999-05-10 Toshiaki Takada <takada@zebra.org>
4581
4582 * ospfd.h: struct ospf_area { }, struct ospf_network { } Changed.
4583 * Fix bug of `no network' statement, it will work.
4584
45851999-05-07 Toshiaki Takada <takada@zebra.org>
4586
4587 * ospf_interface.c, ospf_zebra.c: Fix bug of last interface is not
4588 updated by ospf_if_update ().
4589
45901999-04-30 Kunihiro Ishiguro <kunihiro@zebra.org>
4591
4592 * Makefile.am (noinst_HEADERS): Add ospf_lsa.h for distribution.
4593
45941999-04-25 Toshiaki Takada <takada@zebra.org>
4595
4596 * ospf_interface.c: DEFUN (no_if_ospf_cost),
4597 DEFUN (no_if_ospf_dead_interval),
4598 DEFUN (no_if_ospf_hello_interval),
4599 DEFUN (no_if_ospf_priority),
4600 DEFUN (no_if_ospf_retransmit_interval),
4601 DEFUN (no_if_ospf_transmit_delay) Added.
4602
4603 interface_config_write () suppress showing interface
4604 default values.
4605
46061999-04-25 Kunihiro Ishiguro <kunihiro@zebra.org>
4607
4608 * ospf_dump.c (ospf_timer_dump): If thread is NULL return "inactive".
4609
4610 * ospfd.c (ospf_if_update): Fix bug of using ospf_area { } instead
4611 of ospf_network { }. So `router ospf' statement in ospfd.conf
4612 works again.
4613 (ospf_if_update): Call ospf_get_router_id for updating router ID.
4614
46151999-04-25 Toshiaki Takada <takada@zebra.org>
4616
4617 * ospf_interface.c: DEFUN (if_ospf_network) deleted.
4618 DEFUN (if_ospf_network_broadcast),
4619 DEFUN (if_ospf_network_non_broadcast),
4620 DEFUN (if_ospf_network_point_to_multipoint),
4621 DEFUN (if_ospf_network_point_to_point),
4622 DEFUN (no_if_ospf_network) Added.
4623
46241999-04-23 Toshiaki Takada <takada@zebra.org>
4625
4626 * ospfd.h: struct area { } changed to struct ospf_network { }.
4627 Add struct ospf_area { }.
4628 * ospfd.c: Add ospf_area_lookup_by_area_id (), ospf_network_new (),
4629 and ospf_network_free ().
4630 DEFUN (area_authentication), DEFUN (no_area_authentication) Added.
4631
46321999-04-22 Toshiaki Takada <takada@zebra.org>
4633
4634 * ospf_lsa.h: New file.
4635 * ospf_packet.h: LSA related struct definition are moved to
4636 ospf_lsa.h.
4637 * ospf_packet.c: ospf_verify_header () Added.
4638
46391999-04-21 Toshiaki Takada <takada@zebra.org>
4640
4641 * ospf_ism.c: ospf_elect_dr () and related function is changed.
4642 DR Election bug fixed.
4643 * ospf_dump.c: ospf_nbr_state_message (), ospf_timer_dump () Added.
4644 * ospfd.c: DEFUN (show_ip_ospf_neighbor) Added.
4645
46461999-04-19 Kunihiro Ishiguro <kunihiro@zebra.org>
4647
4648 * ospf_main.c (main): access_list_init () is added for vty
4649 connection filtering.
4650
46511999-04-16 Toshiaki Takada <takada@zebra.org>
4652
4653 * ospfd.c: DEFUN (show_ip_ospf_interface) Added.
4654 * ospf_neighbor.c: ospf_nbr_count () Added.
4655
46561999-04-15 Toshiaki Takada <takada@zebra.org>
4657
4658 * ospfd.h: struct ospf { } Changed.
4659 * ospfd.c: ospf_lookup_by_process_id () Deleted.
4660 * ospf_ism.c: ospf_wait_timer () Added. WaitTimer will work.
4661
46621999-04-14 Toshiaki Takada <takada@zebra.org>
4663
4664 * ospf_ism.c: ospf_elect_dr () Added.
4665 * ospf_network.c: ospf_if_ipmulticast () Added.
4666
46671999-04-11 Toshiaki Takada <takada@zebra.org>
4668
4669 * ospf_interface.c: interface_config_write (),
4670 DEFUN (if_ip_ospf_cost),
4671 DEFUN (if_ip_ospf_dead_interval),
4672 DEFUN (if_ip_ospf_hello_interval),
4673 DEFUN (if_ip_ospf_priority),
4674 DEFUN (if_ip_ospf_retransmit_interval) and
4675 DEFUN (if_ip_ospf_transmit_delay) Added.
4676
46771999-04-08 Toshiaki Takada <takada@zebra.org>
4678
4679 * ospf_dump.c: ospf_packet_db_desc_dump () Added.
4680 * ospf_neighbor.c: ospf_nbr_bidirectional () Added.
4681 * ospf_nsm.c: nsm_twoway_received () Added.
4682
46831999-04-02 Toshiaki Takada <takada@zebra.org>
4684
4685 * ospf_neighbor.c: New file.
4686 * ospf_neighbor.h: New file.
4687 * ospf_nsm.c: New file.
4688 * ospf_nsm.h: New file.
4689 * ospf_packet.c: Add ospf_make_header (), ospf_hello () and
4690 ospf_hello_send (). Now OSPFd can receive Hello and send Hello.
4691
46921999-03-27 Kunihiro Ishiguro <kunihiro@zebra.org>
4693
4694 * ospf_packet.c: Add ospf_recv_packet (). Now OSPF Hello can receive.
4695
46961999-03-19 Toshiaki Takada <takada@zebra.org>
4697
4698 * ospf_packet.c: New file.
4699 * ospf_packet.h: New file.
4700 * ospf_network.c: New file.
4701 * ospf_network.h: New file.
4702 * ospfd.h: move OSPF message structure has moved to ospf_packet.h.
4703
47041999-03-17 Kunihiro Ishiguro <kunihiro@zebra.org>
4705
4706 * ospf_zebra.c (ospf_zebra_get_interface): Fix for IPv6 interface
4707 address.
4708
4709 * Makefile.am (install-sysconfDATA): Overwrite install-sysconfDATA
4710 for install ospfd.conf.sample as owner read only file.
4711
4712 * ospf_main.c (usage): Change to use ZEBRA_BUG_ADDRESS.
4713
47141999-03-15 Toshiaki Takada <takada@zebra.org>
4715
4716 * ospf_ism.c: New file.
4717 * ospf_ism.h: New file.
4718 * ospf_dump.c: New file.
4719 * ospf_dump.h: New file.
4720
4721 * ospfd.h: Add (struct ospf), (struct config_network),
4722 (struct message) structure.
4723
4724 * ospf_interface.c: Add ospf_if_match_network ().
4725 * ospf_interface.h (struct ospf_interface): Change struct members.
4726
4727 * ospfd.c: ospf_lookup_by_process_id (), ospf_network_new (),
4728 DEFUN (network_area): Added.
4729
4730 * ospfd.conf.sample: Change sample configuration.
4731
47321999-03-05 Toshiaki Takada <takada@zebra.org>
4733
4734 * ospf_interface.c: New file.
4735 * ospf_interface.h: New file.
4736 * ospf_zebra.h: New file.
4737 * ospf_zebra.c: Add interface function for zebra daemon.
4738 * ospfd.c: New file.
4739
47401999-02-23 Kunihiro Ishiguro <kunihiro@zebra.org>
4741
4742 * Move IPv6 codes and files to ospf6d directory.
4743
47441999-02-18 Peter Galbavy <Peter.Galbavy@knowledge.com>
4745
4746 * syslog support added
4747
47481998-12-22 Toshiaki Takada <takada@zebra.org>
4749
4750 * ospfd.h: New file.
4751 * ospf_lsa.h: New file.
4752
47531998-12-15 Kunihiro Ishiguro <kunihiro@zebra.org>
4754
4755 * Makefile.am: New file.
4756 * ospf_main.c: New file.
4757