blob: f5145321fc4d4674741d7ca3fc2e174fbf2ef823 [file] [log] [blame]
paul8cc41982005-05-06 21:25:49 +000012005-05-06 Paul Jakma <paul@dishone.st>
2
3 * (general) extern and static'ification of functions in code and
4 header.
5 Cleanup any definitions with unspecified arguments.
6 Add casts for callback assignments where the callback is defined,
7 typically, as passing void *, but the function being assigned has
8 some other pointer type defined as its argument, as gcc complains
9 about casts from void * to X* via function arguments.
10 Fix some old K&R style function argument definitions.
11 Add noreturn gcc attribute to some functions, as appropriate.
12 Add unused gcc attribute to some functions (eg ones meant to help
13 while debugging)
14 Add guard defines to headers which were missing them.
15 * command.c: (install_node) add const qualifier, still doesnt shut
16 up the warning though, because of the double pointer.
17 (cmp_node) ditto
18 * keychain.c: (key_str2time) Add GET_LONG_RANGE() macro, derived
19 fromn vty.h ones to fix some of the (long) < 0 warnings.
20 * thread.c: (various) use thread_empty
21 (cpu_record_hash_key) should cast to uintptr_t, a stdint.h type
22 * vty.h: Add VTY_GET_IPV4_ADDRESS and VTY_GET_IPV4_PREFIX so they
23 removed from ospfd/ospf_vty.h
24 * zebra.h: Move definition of ZEBRA_PORT to here, to remove
25 dependence of lib on zebra/zserv.h
26
hassoe7fe8c82005-05-06 19:33:35 +0000272005-05-06 Hasso Tepper <hasso at quagga.net>
28
29 * sockunion.c: Fix warning message.
30
paul0dab9302005-05-03 09:07:56 +0000312005-05-03 Paul Jakma <paul@dishone.st>
32
33 * stream.h: Add comment about the special zero-ing ability of
34 stream_put.
35 (stream_recvmsg, stream_write) should return ssize_t and size_t
36 respectively. Should both be extern linkage.
37 (stream_recvfrom) Stream aware wrapper around recvfrom, in style
38 of stream_read_try.
39 * stream.c: (stream_recvfrom) new function, wrapper around recvfrom.
40 (stream_recvmsg, stream_write) ssize_t and size_t return values
41
ajs3df53782005-04-27 16:29:54 +0000422005-04-27 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
43
ajs8b70d0b2005-04-28 01:31:13 +000044 Add wall-clock timing statistics to 'show thread cpu' output.
45 * thread.h: Define struct rusage_t to contain wall-clock time
46 and cpu time. Change GETRUSAGE macro to collect both pieces
47 of data. Make appropriate changes to struct cpu_thread_history
48 to track CPU time and real time. Change proto for
49 thread_consumed_time to return real and cpu time elapsed.
50 And declare a new global variable 'struct timeval recent_time'.
51 * thread.c (struct timeval recent_time): New global timestamp variable.
52 (timeval_adjust): If timeout is negative, set to 0 (not 10
53 microseconds). And remove upper bound of 1,000,000 seconds, since
54 this does not seem to make any sense (and it breaks
55 funcname_thread_add_timer_timeval).
56 (timeval_cmp): Should return long, not int.
57 (vty_out_cpu_thread_history): Show CPU time and real time.
58 (cpu_record_hash_print): Calculate totals for CPU and real time.
59 (cpu_record_print): Change 'show thread cpu' title to show CPU and
60 real time.
61 (thread_timer_remain_second): Put current time in global recent_time.
62 (funcname_thread_add_timer_timeval): Fix assert. Replace 2-case
63 switch assignment with a ternary expression. Use global recent_time
64 variable. Fix use of timeval_adjust (previously, the value was not
65 actually being adjusted).
66 (thread_cancel): Add missing "break" statement in case
67 THREAD_BACKGROUND.
68 (thread_timer_wait): Use global recent_time value instead of calling
69 gettimeofday. And there's no need to check for negative timeouts,
70 since timeval_subtract already sets these to zero.
71 (thread_timer_process): Timers are sorted, so bail out once we
72 encounter a timer that has not yet popped. And remove some
73 extraneous asserts.
74 (thread_fetch): Do not process foreground timers before calling
75 select. Instead, add them to the ready list just after the select.
76 Also, no need to maintain a count of the number of ready threads,
77 since we don't care how many there are, just whether there's
78 one at the head of the ready list (which is easily checked).
79 Stick current time in global variable recent_time to reduce
80 the number of calls to gettimeofday. Tighten logic for
81 calculating the select timeout.
82 (thread_consumed_time): Now returns real time and puts the elapsed
83 cpu time in an additional argument.
84 (thread_should_yield): Use real (wall-clock) time to decide whether
85 to yield.
86 (thread_call): Maintain CPU and real time statistics.
87 * vty.c (vty_command): For slow commands, show real and cpu time.
88
892005-04-27 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
90
ajs3df53782005-04-27 16:29:54 +000091 * workqueue.c (show_work_queues): Remove unused gettimeofday call.
92
paul84369682005-04-27 12:39:27 +0000932005-04-27 Paul Jakma <paul.jakma@sun.com>
94
95 * workqueue.h: (struct work_queue_item) change retry_count to ran,
96 its a count of number item has been run.
97 * workqueue.c: (show_work_queues) Fix formating of slightly
98 bugfix: fix SIGFPE if wq->runs is 0.
99 (work_queue_run) retry logic was slightly wrong.
100 cycles.best is 0 initialy, granularity is 1, so update best
101 if cycles >= granularity, not just >.
paula7bca0f2005-04-27 12:44:54 +0000102 * memory.h: memtypes is built source, default includes points to
103 top_builddir, so we should refer to lib/memtypes.h
104
ajs07334da2005-04-26 17:14:30 +00001052005-04-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
106
107 * buffer.c (buffer_write): Comment out call to buffer_flush_available.
108 This should speed up buffering at the expense of a possible increase
109 in latency in flushing the data if inside a long-running thread.
110
paulab59ae32005-04-25 13:52:26 +00001112005-04-25 Paul Jakma <paul.jakma@sun.com>
112
paul147aff02005-04-25 16:29:10 +0000113 * workqueue.{c,h}: Helper API for setting up and running queues via
114 background threads.
115 * command.c: install the 'show workqueues' command
116 * memtypes.c: Add work queue mtypes, and a rib-queue type for
117 a zebra rib work queue.
118 * memtypes.h: Updated to match memtypes.c
paulab59ae32005-04-25 13:52:26 +0000119 * Makefile.am: Refer to source files via srcdir variable, fix
120 out-of-tree build breakage.
paul147aff02005-04-25 16:29:10 +0000121 Add new workqueue files to build.
paul2c1de2a2005-04-25 14:02:44 +0000122 * memory.c: Make the string field much wider
123 * memtypes.c: Correct the prefix list str/entry strings
paul907873a2005-04-25 14:53:46 +0000124 * thread.c: Kill unused TIMER_NO_SORT bits
paulab59ae32005-04-25 13:52:26 +0000125
ajsfb9e46b2005-04-22 14:23:34 +00001262005-04-22 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
127
128 * thread.h: Fix type for struct thread_master add_type: should be
129 unsigned char. Also, add some documentation of thread_add_background
130 args. And remove extraneous declaration of
131 show_thread_work_queues_cmd.
132
paula48b4e62005-04-22 00:43:47 +00001332005-04-22 Paul Jakma <paul.jakma@sun.com>
134
paule1e53ed2005-04-22 13:44:17 +0000135 * memory.h: Move include of memtypes.h to after the definition of
136 struct memory_list, gcc 4.0 doesn't like arrays of incomplete
137 types.
paula48b4e62005-04-22 00:43:47 +0000138 * thread.h: Add background thread type and thread_add_background
139 macro and accompanying funcname_... function.
140 export thread_should_yield, background threads can use it.
141 Lower thread yield time to 10ms, 100ms is noticeable lag and
142 a thread would only be /starting/ to finish sometime afterward.
143 * thread.c: (general) Add background thread type and schedule
144 nearly all thread types through the ready list for fairness.
145 (timeval_adjust) static qualifier missing
146 (vty_out_cpu_thread_history) add support for printout of
147 background threads
148 (show_thread_cpu) ditto.
149 (thread_master_debug) add debug of background list
150 (thread_master_create) fixup long line
151 (thread_add_unuse) add asserts for required state.
152 (thread_master_free) free background thread list
153 (funcname_thread_add_timer_timeval) make generic, able to
154 support arbitrary timer-like thread types.
155 (funcname_thread_add_timer) pass thread type to .._add_timer_timeval
156 (funcname_thread_add_timer_msec) ditto
157 (funcname_thread_add_background) Add a background thread, with an
158 optional millisecond delay factor, using .._add_timer_timeval.
159 (thread_cancel) Add background thread type.
160 Move the thread_list_delete common to all cases to bottom of
161 function, after the switch statement..
162 (thread_cancel_event) indent
163 (thread_timer_wait) Static qualifier, and make it able to cope
164 with arbitrary timer-like thread lists, so its of use to
165 background threads too.
166 (thread_process_fd) static qualifier. Again, make it take a list
167 reference rather than thread_master. Fix indentation.
168 (thread_timer_process) Check for ready timer-like threads in the
169 given list and move them on to the ready list - code originally
170 embedded in thread_fetch.
171 (thread_fetch) Schedule all threads, other than events, through
172 the ready list, to ensure fairness. Timer readying code moved to
173 thread_timer_process so it can be reused for background threads.
174 Remove the unneeded quagga_sigevent_process, as pointed out by
175 John Lin <john.ch.lin@gmail.com>.
176 (thread_should_yield) make this available.
177
ajs924b9222005-04-16 17:11:24 +00001782005-04-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
179
180 * thread.h (thread_consumed_time): Declare new function to calculate
181 elapsed microseconds.
182 * thread.c (thread_consumed_time): Must be global not static so we
183 can call it from lib/vty.c:vty_command.
184 (thread_should_yield): Surround with `#if 0' to make clear that this
185 function is not currently being used anywhere.
186 (thread_call): If CONSUMED_TIME_CHECK is defined, print a CPU HOG
187 warning message if the thread takes more than CONSUMED_TIME_CHECK
188 microseconds.
189 * vty.c (vty_command): If CONSUMED_TIME_CHECK is defined, print a CPU
190 HOG warning message if the command takes more than CONSUMED_TIME_CHECK
191 microseconds.
192
pauldc830cb2005-04-16 15:51:05 +00001932005-04-16 Paul Jakma <paul@dishone.st>
194
195 * memtypes.c: the comment about use of comments in the comments
196 headers was causing comment within comment warnings from compiler
197 * memtypes.awk: Add extensive comments on the file format for
198 memtypes.c.
199 tighten the pattern for the MTYPE matching action (suggestion from
200 Andrew) and tighten which field we try the match on.
201
paul2fd2fd52005-04-15 11:47:15 +00002022005-04-15 Paul Jakma <paul@dishone.st>
203
204 * memtypes.c: The new, unified location for memory type definitions.
205 The memtype enum and declarations for memory_lists are built from
206 this automatically and put into memtypes.h.
207 * memtypes.awk: New script to generate memtypes.h from memtypes.c
208 * memory.h: Finally, the enum can banished!
209 * memory.c: Finally, the seperate mtype memory_list definitions can
210 be banished!
211 (log_memstats) Increase width of fields
212 (show_memory_zebra_cmd) display zebra specific memory types.
213 Increase width of fields.
214 * Makefile.am: Add memtypes.{c,h}, add BUILT_SOURCES for memtypes.h
215 Add a rule to build memtypes.h using memtypes.awk.
216 Add memtypes.awk to EXTRA_DIST.
pauld45f1f12005-04-15 22:18:37 +0000217 memtypes.awk is gawk dependent, use the GAWK automake var.
218 * memtypes.h: New file, auto-generated, checked in for convenience.
paul2fd2fd52005-04-15 11:47:15 +0000219
ajs634f9ea2005-04-11 15:51:40 +00002202005-04-11 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
221
222 * zclient.h (struct zclient): Add two fields to support non-blocking
223 I/O: struct buffer *wb, and struct thread *t_write.
224 (zclient_free): Remove function.
225 (zebra_redistribute_send): Change 2nd arg from socket fd to
226 struct zclient * (needed to support non-blocking I/O and buffering).
227 (zclient_send_message): New function to send an arbitrary
228 message with non-blocking I/O.
229 * zclient.c (zclient_new): Create write buffer.
230 (zclient_free): Remove unused function.
231 (zclient_stop): Must cancel new t_write thread. Also, reset
232 all buffers: ibuf, obuf, and wb.
233 (zclient_failed): New helper function for typical error handling.
234 (zclient_flush_data): New thread to flush queued data.
235 (zclient_send_message): New function to send the message in
236 zclient->obuf to zebra using non-blocking I/O and buffering.
237 (zebra_message_send, zapi_ipv4_route, zapi_ipv6_route): Use
238 new zclient_send_message function instead of calling writen.
239 (zclient_start): Set socket non-blocking. Also, change 2nd arg
240 to zebra_redistribute_send from zclient->sock to zclient.
241 (zebra_redistribute_send): Change 2nd arg to struct zclient *.
242 Can now use zclient->obuf to assemble the message instead of
243 allocating a temporary stream. And call zclient_send_message to
244 send the message instead of writen.
245 (zclient_read): Convert to support non-blocking I/O by using
246 stream_read_try instead of deprecated stream_read.
247 (zclient_redistribute): Change 2nd arg to zebra_redistribute_send
248 from zclient->sock to zclient.
249
hasso5bb4c192005-04-09 13:27:50 +00002502005-04-09 Jeroen Simonetti <jeroens@office.netland.nl>
251
252 * routemap.c: Show description in "show route-map" output.
253
ajsd66a7b52005-04-08 16:42:03 +00002542005-04-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
255
ajs67bf16c2005-04-08 19:02:04 +0000256 * sigevent.c: On GNU_LINUX, check whether __USE_GNU is already defined.
257
2582005-04-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
259
ajs926fe8f2005-04-08 18:50:40 +0000260 * vty.c: (vty_log_fixed) Use casts to (void *) to try to eliminate
261 compiler warnings when assigning a (const char *) value to
262 struct iovec iov_base.
263
2642005-04-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
265
ajsd66a7b52005-04-08 16:42:03 +0000266 * zebra.h: If GNU_LINUX is defined, then define _GNU_SOURCE. This
267 fixes a problem where we were not getting the declaration of strnlen
268 in <string.h>.
269
hasso3a2ce6a2005-04-08 01:30:51 +00002702005-04-08 Hasso Tepper <hasso at quagga.net>
271
hasso4a8164e2005-04-08 14:20:18 +0000272 * routemap.[ch]: Added "description ..." command.
273
2742005-04-08 Hasso Tepper <hasso at quagga.net>
275
hasso3a2ce6a2005-04-08 01:30:51 +0000276 * prefix.[hc]: Pass argument to the inet6_ntoa by value making it more
277 inet_ntoa alike.
278
paul1eb8ef22005-04-07 07:30:20 +00002792005-04-07 Paul Jakma <paul.jakma@sun.com>
280
281 * linklist.h: Add usage comments.
282 Rename getdata macro to listgetdata.
283 Rename nextnode to listnextnode and fix its odd behaviour to be
284 less dangerous.
285 Make listgetdata macro assert node is not null, NULL list entries
286 should be bug condition.
287 ALL_LIST_ELEMENTS, new macro, forward-referencing macro for use
288 with for loop, Suggested by Jim Carlson of Sun.
289 Add ALL_LIST_ELEMENTS_RO for cases which obviously do not need the
290 "safety" of previous macro.
291 LISTNODE_ADD and DELETE macros renamed to ATTACH, DETACH, to
292 distinguish from the similarly named functions, and reflect their
293 effect better.
294 Add a QUAGGA_NO_DEPRECATED_INTERFACES define guarded section
295 with the old defines which were modified above,
296 for backwards compatibility - guarded to prevent Quagga using it..
297 * linklist.c: fix up for linklist.h changes.
298 * *.c: fix up for new list loop macro, try audit other loop
299 usage at same time, to some degree.
300
hasso59209902005-04-05 14:36:49 +00003012004-04-05 Hasso Tepper <hasso at quagga.net>
302
303 * lib/prefix.[hc]: inet6_ntoa utility function copied from
304 ripngd/ripngd.c (inet6_ntop).
305
paul3d1dc852005-04-05 00:45:23 +00003062004-04-05 Paul Jakma <paul@dishone.st>
307
308 * vty.c: Improve logging of failures to open vty socket(s).
309 See bugid #163.
310
ajs3cb98de2005-04-02 16:01:05 +00003112005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
312
ajs08dbfb62005-04-03 03:40:52 +0000313 * if.h: Fix comments to reflect that if_lookup_by_name and
314 if_get_by_name now require the argument strings to be NUL-terminated.
315 * if.c: (if_lookup_by_name) Compare using strcmp.
316 (if_get_by_name) Pass strlen(ifname) as 2nd arg to if_create.
317
3182005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
319
ajs018546e2005-04-02 23:05:56 +0000320 * if.c: (if_nametoindex) The man page is rather vague, but it seems
321 like the argument to if_nametoindex has an implicit maximum length
322 of IFNAMSIZ characters.
323
3242005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
325
ajsa3491982005-04-02 22:50:38 +0000326 * if.h: (if_lookup_by_name_len, if_get_by_name_len) New functions.
327 * if.c: (if_lookup_by_name_len, if_get_by_name_len) New functions.
328 (if_get_by_name) Tighten up code.
329 (interface) Use new function if_get_by_name_len.
330 * zclient.c: (zebra_interface_add_read) Use new if_get_by_name_len
331 function.
332 (zebra_interface_state_read) Use new if_lookup_by_name_len function.
333
3342005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
335
ajs851adbd2005-04-02 18:48:39 +0000336 * str.c: Replace strlcpy and strlcat with actual working versions
337 copied from rsync-2.6.2/lib/compat.c.
338
3392005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
340
ajsd2fc8892005-04-02 18:38:43 +0000341 * if.h: Remove define for IFINDEX_INTERNBASE and add define
342 IFINDEX_INTERNAL 0, since all internal (i.e. non-kernel) pseudo-
343 interfaces should have ifindex set to 0.
344 (if_new) Remove function.
345 (if_delete_retain) New function to delete an interface without
346 removing from iflist and freeing the structure.
347 (ifname2ifindex) New function.
348 * if.c: (if_new) Remove function (absorb into if_create).
349 (if_create) Replace function if_new with call to calloc.
350 Set ifp->ifindex to IFINDEX_INTERNAL. Fix off-by-one error
351 in assert to check length of interface name. Add error message
352 if interface with this name already exists.
353 (if_delete_retain) New function to delete an interface without
354 removing from iflist and freeing the structure.
355 (if_delete) Implement with help of if_delete_retain.
356 (ifindex2ifname) Reimplement using if_lookup_by_index.
357 (ifname2ifindex) New function to complement ifindex2ifname.
358 (interface) The interface command should check the name length
359 and fail with a warning message if it is too long.
360 (no_interface) Fix spelling in warning message.
361 (if_nametoindex) Reimplement using if_lookup_by_name.
362 (if_indextoname, ifaddr_ipv4_lookup) Reimplement using
363 if_lookup_by_index.
364
3652005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
366
ajs3cb98de2005-04-02 16:01:05 +0000367 * zebra.h: Should include str.h to pick up missing functions.
368 * str.h: Declare strnlen if needed.
369 * str.c: Do not include str.h since zebra.h now includes it.
370 (strnlen) New function.
371
ajsdb8eaac2005-03-16 16:13:06 +00003722005-03-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
373
374 * zebra.h: Must check whether __attribute__ should be defined before
375 including zassert.h.
376
paulb8961472005-03-14 17:35:52 +00003772005-03-14 Paul Jakma <paul.jakma@sun.com>
378
379 * command.c: (sort_node) use vector_max instead of referencing
380 (struct vector *)->max directly. Test that vector_max is > 0
381 before using it to calculate an index.
382 Fixup vector loop to make main body conditional on vector slot
383 not being empty.
384 (cmd_cmdsize) Fixup vector loop to make main body conditional on
385 vector slot not being empty.
386 (cmd_filter_by_completion) ditto
387 (cmd_filter_by_string) ditto
388 (is_cmd_ambiguous) ditto
389 (cmd_describe_command_real) Change index integers to unsigned.
390 Test that vector_max is > 0 before using it to calculate an index.
391 Return immediately with CMD_ERR_NO_MATCH if vline has no
392 active slots.
393 Fixup vector loop to make main body conditional on vector slot
394 not being empty.
395 (cmd_complete_command_real) ditto.
396 (cmd_execute_command_strict) Fixup vector loop to be conditional
397 on non-null slot.
paul909a2152005-03-14 17:41:45 +0000398 (various) Fix indentation and other whitespace.
paul55468c82005-03-14 20:19:01 +0000399 vector.h: Rename to (struct vector).max to slightly less confusing
400 active, for the number of active slots, distinct from allocated
401 or active-and-not-empty. Rename vector_max to vector_active
402 for same reason.
paulb8961472005-03-14 17:35:52 +0000403
paul9e92eea2005-03-09 13:39:26 +00004042005-03-09 Paul Jakma <paul.jakma@sun.com>
405
406 * command.c: Undo commit of sign warning fix and hidden command
407 in list_cmd. Sign warning is more subtle. list_cmd on its own
408 will be committed after.
paul4275b1d2005-03-09 13:42:23 +0000409 * command.c: (config_list_cmd) Don't list hidden or deprecated
410 commands, hiding these from tab completion is still to be done.
paul9e92eea2005-03-09 13:39:26 +0000411
paulb45da6f2005-03-08 15:16:57 +00004122005-03-08 Paul Jakma <paul.jakma@sun.com>
413
paul9c5d8562005-03-08 15:56:42 +0000414 * command.c: (banner_motd_file_cmd) use XSTRDUP/XFREE.
paul22085182005-03-08 16:00:12 +0000415 (no_banner_motd_cmd) use XFREE.
paul9c5d8562005-03-08 15:56:42 +0000416 (cmd_describe_command_real) sign compile warning fix
417 (cmd_complete_command_real) ditto.
418 (config_list_cmd) Don't list hidden or deprecated commands,
419 hiding these from tab completion is still to be done.
420 * command.h: cmd attr enum should start at 1.
paulb45da6f2005-03-08 15:16:57 +0000421 * vty.c: (vty_hello) suggestions from Andrew, read by line and
422 stub out trailling non-printable characters on each line thus
423 allowing us to specify VTY_NEWLINE to vty_out.
424
paul3b0c5d92005-03-08 10:43:43 +00004252005-03-08 Jeroen Massar <jeroen@unfix.org>
426
427 * vty.c: (vty_hello) display motd file, if set
428 * command.h: add char *motdfile to struct host
429 * command.c: (config_write_host) write out motdfile config
430 (banner_motd_file_cmd) new command, allow motd to be read from
431 file.
432 (no_banner_motd_cmd) free motdfile string, if needs be.
433 (cmd_init) init (struct host).motdfile. Add new motd file
434 commands.
435
hasso12f6ea22005-03-07 08:35:39 +00004362005-03-07 Michael Sandee <voidptr@voidptr.sboost.org>
437
438 * command.c: host.name might be NULL.
439 * vty.c: Fix fd leak.
440
ajs81fb3242005-02-24 16:02:53 +00004412005-02-24 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
442
443 * stream.c: (stream_read_try) Log a warning message if a fatal
444 I/O error occurs.
445 (stream_fifo_new) Fix prototype.
446 * stream.h: Fix prototype for stream_fifo_new (need void arg).
447
ajs9fc7ebf2005-02-23 15:12:34 +00004482005-02-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
449
ajscdb6ee92005-02-23 15:48:32 +0000450 * {vty.h,vty.c}: Remove vty_finish (duplicate of vty_reset).
451
4522005-02-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
453
ajs9fc7ebf2005-02-23 15:12:34 +0000454 * buffer.h: Make the struct buffer and struct buffer_data structures
455 private by moving them inside buffer.c. Add comments for all
456 functions. Rename buffer_write as buffer_put (to be more consistent
457 with the buffer_putc and buffer_putstr functions). Declare a new
458 buffer_write function that is used to write data to a file descriptor
459 and/or add it to the buffer queue. Remove unused function
460 buffer_flush_vty_all. Create a new enum typedef buffer_status_t
461 to be used as the return code for all buffer_flush* functions
462 and buffer_write.
463 * buffer.c: The struct buffer and struct buffer_data declarations
464 are now private to this file. In conjunction with that, remove
465 some unnecessary fields: struct buffer (alloc, unused_head,
466 unused_tail, length), struct buffer_data (prev).
467 (buffer_data_new) Removed: functionality incorporated into buffer_add.
468 (buffer_data_free) Removed: use a macro BUFFER_DATA_FREE instead.
469 (buffer_new) Use calloc instead of malloc + memset(zero).
470 Supply an appropriate default size if the specified size is 0.
471 (buffer_free) Eliminate code duplication by calling buffer_reset to
472 free the contents of the buffer (and remove unused code related
473 to unused_head).
474 (buffer_empty,buffer_putc,buffer_putstr) Aesthetic change (make more
475 compact).
476 (buffer_reset) Use macro BUFFER_DATA_FREE. No need to set
477 alloc and length to 0 (these fields have been removed).
478 (buffer_add) Fix scope to be static. Call XMALLOC directly instead
479 of calling removed buffer_data_new function. Simplify the logic
480 (since it's now a singly-linked list instead of doubly-linked).
481 (buffer_write) Renamed to buffer_put. Change to void, since return
482 code of 1 was meaningless. No need to adjust length field, since
483 it has been removed.
484 (buffer_putw,buffer_flush,buffer_flush_vty_all,buffer_flush_vty)
485 Remove unused functions.
486 (buffer_flush_all) Rewrite using buffer_flush_available to eliminate
487 a possible failure mode if IOV_MAX is less than the number of buffers
488 on the queue.
489 (buffer_flush_window) Incorporate logic from buffer_flush_vty.
490 Log an error message if there is a writev error.
491 (buffer_flush_available) Be more paranoid: check for case where
492 buffer is already empty. Use new ERRNO_IO_RETRY macro, and use
493 new enum for return codes. Simplify deletion logic (since it's
494 now a singly-linked list).
495 (buffer_write) New function for use with non-blocking I/O.
496 * vty.h: Replace the struct vty sb_buffer field with a fixed-size
497 (5-character) sb_buf field and an sb_len field, since using
498 a struct buffer was inappropriate for this task. Add some useful
499 comments about telnet window size negotiation.
500 * vty.c: Include <arpa/telnet.h> (no longer included by zebra.h).
501 Remove VTY_OBUF_SIZE (instead use buffer_new default size).
502 Make telnet_backward_char and telnet_space_char static const.
503 (vty_out) Replace buffer_write with buffer_put.
504 (vty_log_out) Check for I/O errors. If fatal, close the vty session.
505 Consolidate 3 separate writes into a single write call.
506 (vty_will_echo,vty_command,vty_next_line,vty_previous_line,
507 vty_end_config,vty_describe_fold,vty_clear_buf,vty_serv_sock_addrinfo,
508 vty_serv_sock_family,vty_serv_un,vty_use_backup_config,exec_timeout,
509 vty_config_write,vty_save_cwd) Fix scope to static.
510 (vty_new) Let buffer_new use its default buffer size.
511 (vty_write) Fix signature: 2nd arg should be const char *.
512 Replaced buffer_write with buffer_put.
513 (vty_telnet_option) Fix minor bug (window height or width greater than
514 255 was broken). Use sb_buf and sb_len instead of removed sb_buffer
515 (which was being used improperly).
516 (vty_read) On error, use ERRNO_IO_RETRY to decide whether it's fatal.
517 If the error is fatal, call buffer_reset so vty_close does not attempt
518 to flush the data. Use new sb_buf and sb_len instead of sb_buffer
519 to store the SB negotiation string.
520 (vty_flush) When vty->lines is 0, call buffer_flush_available instead
521 of buffer_flush_window. Look at the return code from buffer_flush
522 to detect I/O errors (and in that case, log an error message and
523 close the vty).
524 (vty_create) Fix scope to static. Initialize sb_len to 0 instead
525 of creating sb_buffer.
526 (vty_accept) Set socket nonblocking.
527 (vtysh_accept) Use new set_nonblocking function instead of calling
528 fcntl directly.
529 (vtysh_flush) New function called from vtysh_read (after command
530 execution) and from vtysh_write. This flushes the buffer
531 and reacts appropriately to the return code (by closing the vty
532 or scheduling further flushes).
533 (vtysh_read) Check whether error is fatal using ERRNO_IO_RETRY.
534 If not, just try again later. Otherwise, call buffer_reset before
535 calling vty_close (to avoid trying to flush the buffer in vty_close).
536 Fix logic to allow case where a command does not arrive atomically
537 in a single read call by checking for the terminating NUL char.
538 (vtysh_write) Use new vtysh_flush helper function.
539 (vty_close) No need to call buffer_empty, just call buffer_flush_all
540 in any case (it will check whether the buffer is empty).
541 Do not free sb_buffer (since it has been removed).
542 (vty_log_fixed) Use writev instead of write.
543 * zebra.h: Do not include <arpa/telnet.h>, since this is used only
544 by lib/vty.c.
545
hassoc3c07f22005-02-21 18:17:52 +00005462005-02-21 Vincenzo Eramo <eramo at infocom.ing.uniroma1.it>
547
548 * pqueue.[ch]: Introduce "update" function to meet ospf spf needs. It
549 will allow to update node when:
550 i) a node is inserted into the priority queue;
551 ii) a node position is modified in the priority queue;
552 * pqueue.h: Export trickle_down() function.
553
paul109ac962005-02-19 01:17:07 +00005542005-02-19 Paul Jakma <paul.jakma@sun.com>
555
556 * stream.c: (stream_new) fix dumb mistake.
557
ajsd7e2a812005-02-17 20:02:49 +00005582005-02-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
559
ajs53270112005-02-17 20:07:22 +0000560 * stream.c: (stream_read_try) Use new ERRNO_IO_RETRY macro.
561
5622005-02-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
563
ajsd7e2a812005-02-17 20:02:49 +0000564 * network.h: Define a new ERRNO_IO_RETRY macro to test whether an I/O
565 operation should be retried. This eliminates the need to duplicate
566 the same logic testing for EAGAIN or EINTR in multiple places.
567
ajs42218e72005-02-16 16:25:39 +00005682005-02-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
569
ajs262feb12005-02-16 20:35:47 +0000570 * stream.h: Declare new function stream_read_try suitable for use
571 with non-blocking file descriptors. Indicate that stream_read
572 and stream_read_unblock are deprecated.
573 * stream.c: (stream_read_try) New function for use with non-blocking
574 I/O.
575 (stream_recvmsg) Should return -1 if the stream is too small to
576 contain the data.
577
5782005-02-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
579
ajs42218e72005-02-16 16:25:39 +0000580 * network.c: (set_nonblocking) Should check return code from
581 fcntl(F_GETFL).
582
ajsa269d612005-02-16 00:45:37 +00005832005-02-15 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
584
585 * network.h: Declare new function set_nonblocking. Indicate that
586 readn and writen are deprecated.
587 * network.c: (set_nonblocking) New function to make a file descriptor
588 non-blocking, since it seems silly to have fcntl calls sprinkled
589 throughout the code.
590
paul1dd13d42005-02-14 23:49:09 +00005912005-02-14 Paul Jakma <paul.jakma@sun.com>
paulf2e6c422005-02-12 14:35:49 +0000592
593 * stream.h: Unsigned long updated to size_t
594 * stream.c: ditto
paul050c0132005-02-14 23:47:47 +0000595 * stream.h: Add stream_copy, stream_dup, stream_recvmsg.
596 Add comment describing struct stream abstraction, and various
597 other comments.
598 Deprecate several unsafe/ambigious macros.
599 Add STREAM_WRITEABLE and STREAM_READABLE.
600 Add (stream_getl_from) for symmetry.
601 Update stream_forward_{endp,getp} to use size_t offset.
602 Make stream data a 0 length array, rather than a seperate malloc.
603 * stream.c: Add consistency checks. Update to follow stream.h
604 changes.
605 (stream_new) Alloc stream+data in one go.
606 (stream_copy) new function, copy a stream.
607 (stream_dup) new function, dup a stream.
608 (stream_recvmsg) new function, recvmsg data into a stream.
609 (stream_empty) no need to check getp == 0.
paulf2e6c422005-02-12 14:35:49 +0000610
paul9985f832005-02-09 15:51:56 +00006112005-02-09 Paul Jakma <paul.jakma@sun.com>
612
613 * stream.h: Remove putp. Update reference to putp with endp.
614 Add stream_forward_endp, which daemons were doing manually.
615 Rename stream_forward to stream_forward_getp.
616 stream.c: Remove/update references to putp.
617 introduce stream_forward_endp.
618
ajs548e6f72005-02-08 15:57:25 +00006192005-02-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
620
621 * zebra.h: Change macro definitions SET_FLAG and UNSET_FLAG
622 to use compound assignment operators (aesthetic change).
623
ajs1e221352005-02-03 16:42:40 +00006242005-02-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
625
ajsc4c7d0c2005-02-03 19:22:05 +0000626 * log.c: (zlog_signal,zlog_backtrace_sigsafe) Eliminate use of fileno()
627 since it is not async-signal-safe.
628 (_zlog_assert_failed) Rewrite crashlog logic more compactly.
629 (zlog_set_file,zlog_reset_file,zlog_rotate) Update logfile_fd
630 for use in signal handler.
631
6322005-02-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
633
ajs1e221352005-02-03 16:42:40 +0000634 * log.c: (syslog_sigsafe) Reduce scope of syslog_fd: it is accessed
635 inside this function only.
636 (open_crashlog) New function to open /var/tmp/quagga.<daemon>.crashlog
637 with flags O_WRONLY|O_CREAT|O_EXCL to save some crash info.
638 (zlog_signal,_zlog_assert_failed) Increase logging priority from
639 LOG_ERR to LOG_CRIT. If no file logging is configured, try to use
640 open_crashlog to create a crash logfile.
641 (zlog_backtrace_sigsafe) If a crashlog file descriptor is open,
642 dump a backtrace to that file.
643
ajs847947f2005-02-02 18:38:48 +00006442005-02-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
645
646 * if.h: Declare if_flag_dump.
647
ajs6a52d0d2005-01-30 18:49:28 +00006482005-01-30 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
649
650 * daemon.c: (daemon) Replace perror with zlog_err.
651 * vty.c: (vty_serv_un) Replace perror with zlog_err.
652
ajs3b8b1852005-01-29 18:19:13 +00006532005-01-29 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
654
655 * buffer.h: Fix comment on buffer_getstr to reflect that it now
656 uses XMALLOC.
657 * buffer.c: (buffer_getstr) Use XMALLOC(MTYPE_TMP) instead of malloc.
658 * filter.c: (access_list_remark,ipv6_access_list_remark) Use
659 argv_concat instead of buffer_getstr.
660 * if.c: (interface_desc) Use argv_concat instead of buffer_getstr.
661 * plist.c: (ip_prefix_list_description,ipv6_prefix_list_description)
662 Use argv_concat instead of buffer_getstr.
663
ajsf6834d42005-01-28 20:28:35 +00006642005-01-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
665
ajsafb8b602005-01-28 20:41:07 +0000666 * lib/buffer.h: Document behavior of buffer_getstr function.
667 * lib/buffer.c: (buffer_getstr) Fix bug: must handle case where
668 the string extends beyond the head struct buffer_data.
669
6702005-01-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
671
ajsf6834d42005-01-28 20:28:35 +0000672 * lib/command.h: Document behavior of argv_concat function.
673 * lib/command.c: (argv_concat) Calculate total string length first so
674 we can call malloc just once (instead of realloc'ing to add each
675 string element).
676 (do_echo,config_logmsg) Allow for possible NULL return value from
677 argv_concat.
678
hasso13bfca72005-01-23 21:42:25 +00006792005-01-23 Hasso Tepper <hasso at quagga.net>
680
681 * lib/command.[ch]: Make node_parent() function nonstatic. vtyh.c will
682 use it as well.
683
ajs31364272005-01-18 22:18:59 +00006842005-01-18 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
685
686 * log.h: Test for SA_SIGINFO to see whether zlog_signal takes final
687 two args (siginfo and program_counter).
688 * log.c: (hex_append) Include this function only if SA_SIGINFO or
689 HAVE_GLIBC_BACKTRACE is defined.
690 (zlog_signal) Final two args (siginfo and program_counter) now
691 depend on whether SA_SIGINFO is defined on this platform.
692 * sigevent.c: (program_counter) Do not include this function if
693 SA_SIGINFO is not defined on this platform.
694 (exit_handler,core_handler) Test for SA_SIGINFO to decide whether
695 2nd & 3rd arguments are present and to decide how to invoke
696 zlog_signal.
697 (trap_default_signals) Test for SA_SIGINFO and invoke sigaction
698 appropriately.
699
ajs239c26f2005-01-17 15:22:28 +00007002005-01-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
701
702 * log.h: Change prototype for zlog_backtrace_sigsafe to take additional
703 program_counter argument.
704 * log.c: (zlog_backtrace_sigsafe) Add additional program_counter
705 argument. If it is non-NULL, use backtrace_symbols_fd to resolve
706 the address.
707 (zlog_signal) Call zlog_backtrace_sigsafe with additional
708 program_counter argument.
709
hasso87d683b2005-01-16 23:31:54 +00007102005-01-17 Hasso Tepper <hasso at quagga.net>
711
712 * command.[ch], vty.c: cmd_execute_command() function must not attempt
713 to walk up in the node tree if called from vtysh. Different daemons
714 might have commands with same syntax in different nodes (for example
715 "router-id x.x.x.x" commands in zebra/ospfd/ospf6d daemons).
716
ajscb585b62005-01-14 17:09:38 +00007172005-01-14 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
718
719 * command.c (print_version): Do not bother even to examine host.name,
720 since it is always NULL when this function is called from main.
721
gdtf867d322005-01-14 15:47:33 +00007222005-01-14 Greg Troxel <gdt@fnord.ir.bbn.com>
723
724 * command.c (print_version): Don't print host.name if it is NULL.
725 Fixes segfault on Solaris reported by Goetz von Escher <goetz@open.ch>
726
ajse22f5512005-01-12 16:18:17 +00007272005-01-12 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
728
ajs40abf232005-01-12 17:27:27 +0000729 * sigevent.c: (trap_default_signals) Use the SA_SIGINFO flag to
730 pass additional siginfo_t and ucontext_t arguments to core_handler
731 and exit_handler.
732 (core_handler,exit_handler) Now invoked with 3 arguments (using
733 SA_SIGINFO). Pass additional info to zlog_signal.
734 (program_counter) New function to find program counter in ucontext_t,
735 needs to be enhanced to support more platforms (currently works only
736 on Linux/x86).
737 * log.h: Change the zlog_signal prototype to add new arguments
738 siginfo_t * and program_counter.
739 * log.c: (zlog_signal) Add new arguments siginfo and program_counter.
740 Include si_addr and program counter (if non-NULL) in message.
741 And remove #ifdef HAVE_GLIBC_BACKTRACE around hex_append, since
742 that is now used to render the si_addr and PC pointers.
743
7442005-01-12 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
745
ajse22f5512005-01-12 16:18:17 +0000746 * zebra.h: If not C99 and no va_copy macro available, fall back to
747 memcpy (solves a build problem on FreeBSD 4.x).
748
ajsb99760a2005-01-04 16:24:43 +00007492005-01-04 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
750
751 * zebra.h: Define ZCMSG_FIRSTHDR appropriately based on whether
752 config.h indicates HAVE_BROKEN_CMSG_FIRSTHDR (as determined
753 by the configure test program).
754 * sockopt.c: (getsockopt_cmsg_data) Use ZCMSG_FIRSTHDR instead
755 of CMSG_FIRSTHDR.
756
hassocba8a602005-01-02 18:51:01 +00007572005-01-02 Hasso Tepper <hasso at quagga.net>
758
759 * command.c: Revert int -> unsigned int fixes in
760 cmd_describe_command_real() and cmd_complete_command_real(). index can
761 be actually negative and it caused crash with "do<TAB>" in vty.
762
gdt1d69fdf2004-12-29 18:53:30 +00007632004-12-29 Greg Troxel <gdt@poblano.ir.bbn.com>
764
gdtd44debe2004-12-29 20:06:23 +0000765 * sockopt.c (getsockopt_ipv4_ifindex): Document calling
766 convention. Beef up comments. Handle the case where the cmsghdr
767 has a zero controllen, or more specifically when the wanted option
768 is not present. This is needed for Solaris 8, and in general for
769 any platform for which configure finds a method and it can fail.
770 Mark some changes with XXX to be cleaned up post 0.98.
771
ajsaf04bd72004-12-28 17:00:12 +00007722004-12-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
773
ajs1d75c8c2004-12-28 21:43:17 +0000774 * sockopt.c: (setsockopt_ipv4_ifindex) Improve error message.
775 When neither IP_PKTINFO nor IP_RECVIF is defined, make return value
776 deterministic (-1).
777
7782004-12-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
779
ajsaf04bd72004-12-28 17:00:12 +0000780 * thread.c: (funcname_thread_add_timer_msec) Reduce overflow risk.
781
paul4ba9b922004-12-21 22:34:58 +00007822004-12-21 Paul Jakma <paul.jakma@sun.com>
783
784 * if.h: Add more 'non-generic' IFF_ flags.
785 * if.c: IFF_NOXMIT/IFF_VIRTUAL interfaces are 'loopback like'
paul0e43a2b2004-12-22 00:15:34 +0000786 * stream.c: Dont allocate streams with 0 sized data buffers
paul4ba9b922004-12-21 22:34:58 +0000787
ajs202d08c2004-12-17 20:50:00 +00007882004-12-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
ajs2885f722004-12-17 23:16:33 +0000789
790 * command.c: (do_echo) Added new "echo" command, useful for
791 watchdog pinging to make sure the daemon is responsive.
792
7932004-12-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
ajs202d08c2004-12-17 20:50:00 +0000794
795 * pid_output.c: (pid_output_lock) Eliminate static function, and just
796 use the #ifdef to decide which version of the function to include.
797 This eliminates a compilation problem with gcc4. And fix the
798 non-fcntl version so that it actually compiles. Exit with
799 status 1 instead of -1 on error.
800
ajs81fc57c2004-12-15 17:41:14 +00008012004-12-15 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
802
803 * sigevent.c: (trap_default_signals) Ignore SIGPIPE instead of exiting.
804
ajs3378d202004-12-10 22:43:17 +00008052004-12-10 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
806
807 * log.c: (zlog_signal,_zlog_assert_failed) Change logging level back to
808 LOG_ERR instead of LOG_EMERG.
809
ajsc3324c62004-12-09 17:26:31 +00008102004-12-09 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
811
812 * log.c: (hex_append) No need to include this function if
813 HAVE_GLIBC_BACKTRACE is not defined.
814
ajsb9e70282004-12-08 17:14:45 +00008152004-12-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
816
817 * prefix.c: (prefix_copy) Error message before abort should
818 have severity LOG_ERR, not LOG_INFO.
819 * memory.c: (mtype_log) Log level should be LOG_DEBUG, not LOG_INFO.
820
ajs274a4a42004-12-07 15:39:31 +00008212004-12-07 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
822
ajs8ddca702004-12-07 18:53:52 +0000823 * {smux.c,zclient.c}: Change level of debug messages to LOG_DEBUG.
824
8252004-12-07 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
826
ajs82146b82004-12-07 17:15:55 +0000827 * command.c: (config_write_host) Note that "log trap" is deprecated
828 when writing out the config.
829
8302004-12-07 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
831
ajs274a4a42004-12-07 15:39:31 +0000832 * log.h: Replace struct zlog flags and maskpri fields with maxlvl
833 array to support individual logging levels for each destination.
834 Remove the 2nd argument to openzlog since the default logging config
835 should be standardized inside the library. Replaced the
836 zlog_set_flag and zlog_reset_flag functions with zlog_set_level.
837 And zlog_set_file now requires an additional log_level argument.
838 Declare zlog_proto_names for use inside command.c in the
839 "show logging" command. Added defines useful for command
840 construction.
841 * log.c: (vzlog) Decide where to send the message based on the
842 individual logging levels configured for each destination.
843 Remove support for ZLOG_STDERR since it was never actually used.
844 Support record-priority for terminal monitors.
845 (zlog_signal,zlog_backtrace_sigsafe) Support destination-specific
846 logging levels. Remove stderr support (was never used). Added
847 support for terminal monitor logging.
848 (_zlog_assert_failed) Increase message severity to LOG_EMERG.
849 (openzlog) Remove 2nd argument since default config should be
850 standardized in library. By default, terminal monitoring
851 is set to debug, and all other logging is disabled.
852 (zlog_set_flag,zlog_reset_flag) Removed.
853 (zlog_set_level) New function to replace zlog_set_flag and
854 zlog_reset_flag. Supports destination-specific logging levels.
855 (zlog_set_file,zlog_reset_file) Support file-specific logging level.
856 (zlog_rotate) Log an error message if fopen fails, and support
857 new file-specific logging level.
858 * command.h: Change DEFUN_CMD_FUNC_DECL and DEFUN_CMD_FUNC_TEXT so that
859 command functions will be static instead of global. Remove
860 declarations for config_exit and config_help. Define new macros
861 DEFUNSH_ATTR, DEFUNSH_HIDDEN, and DEFUNSH_DEPRECATED so we can
862 have deprecated commands in vtysh. Similarly, for completeness,
863 define macros ALIAS_SH, ALIAS_SH_HIDDEN, and ALIAS_SH_DEPRECATED.
864 Also, fix bug in ALIAS_ATTR macro (didn't matter because it
865 was never used).
866 * command.c: Make many functions static instead of global.
867 (facility_name,facility_match,level_match) New functions
868 to support enhanced destination-specific logging levels.
869 (config_write_host) Support new destination-specific logging levels.
870 (config_logmsg) Added new "logmsg" command to help test logging
871 system.
872 (show_logging) Added "show logging" command to show the current
873 configuration of the logging system.
874 (config_log_stdout_level) Support explicit stdout logging level.
875 (no_config_log_stdout) Now takes optional LEVEL arg.
876 (config_log_monitor,config_log_monitor_level,no_config_log_monitor)
877 New commands creating new "log monitor" commands to set terminal
878 monitoring log level.
879 (config_log_file_level) Support explicit file logging level.
880 (config_log_syslog_level) Support explicit syslog logging level.
881 (config_log_facility,no_config_log_facility) Implement new
882 "log facility" command.
883 (cmd_init) Add hooks for new commands: "show logging", "logmsg",
884 "log stdout <level>", "log monitor", "log monitor <level>",
885 "no log monitor", "log file <filename> <level>",
886 "no log file <filename> <level>", "log syslog <level>",
887 "log facility", and "no log facility".
888 * vty.h: Added a "level" argument to vty_log so it can support
889 "log record-priority". Declare new function vty_log_fixed for
890 use in signal handlers.
891 * vty.c: (vty_log,vty_log_out) Added a "level" argument to support
892 "log record-priority" for vty terminal monitors.
893 (vty_down_level) Use config_exit_cmd.func instead of calling
894 config_exit directly (since command functions will now be static
895 instead of global).
896 (vty_log_fixed) New function to send terminal monitor messages
897 from inside a signal handler.
898
ajs887c44a2004-12-03 16:36:46 +00008992004-12-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
900
ajs5e764772004-12-03 19:03:33 +0000901 * log.h: Document appropriate use of syslog logging priorities
902 inside quagga.
903
9042004-12-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
905
ajs56f20692004-12-03 17:40:31 +0000906 * command.h: Remove fields log_stdout and log_syslog from struct host,
907 since they are just trying to duplicate information in the
908 zlog_default structure. Note that this fixes a bug since those
909 fields were not registering any logging that was established
910 in the initial call to openzlog (this affects only the zebra and
911 ospf6d daemons). It is probably a bug to turn on any logging by
912 default in the call to openzlog.
913 * command.c: (config_write_host) Get logging info from zlog_default
914 instead of now-removed fields host.log_stdout and host.log_syslog.
915 (config_log_stdout,no_config_log_stdout) Do not set now-removed field
916 host.log_stdout, since this info is recorded in zlog_default.
917 (config_log_file) Use XSTRDUP (instead of strdup) to set host.logfile.
918 (config_log_syslog,config_log_syslog_facility,no_config_log_syslog)
919 Do not set now-removed field host.log_syslog, since this info is
920 recorded in zlog_default.
921
9222004-12-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
923
ajs887c44a2004-12-03 16:36:46 +0000924 * version.h.in: Remove declaration for pid_output_lock, this function
925 is now static, not global.
926 * pid_output.c: (pid_output_lock) This function should be static, not
927 global. And remove "old umask" error message, since it was really
928 an unimportant debug message, not an error.
929 (pid_output) Need to declare static function pid_output_lock.
930
ajs7d149b82004-11-28 23:00:01 +00009312004-11-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
932
933 * log.h: Remove several unused fields from struct zlog. Add comments
934 for other fields, and add one new field syslog_options that is
935 used in the new syslog_sigsafe implementation.
936 * log.c: (syslog_sigsafe) New function to send syslog messages in
937 an async-signal safe way that can be used inside a signal handler.
938 (syslog_connect) New function to connect to syslog daemon inside a
939 signal handler. This function supports only systems where /dev/log
940 is a unix datagram socket (e.g. not Solaris).
941 (zlog_signal) Call syslog_sigsafe if syslog logging is enabled.
942 (zlog_backtrace_sigsafe) Call syslog_sigsafe if syslog logging is
943 enabled.
944 (openzlog) Save syslog_options for use in syslog_sigsafe.
945 (num_append) Fix bug: handle 0 properly.
946 (hex_append) New function to print a u_long in hex format.
947
hasso2557aed2004-11-28 21:16:20 +00009482004-11-28 Hasso Tepper <hasso at quagga.net>
949
950 * command.h: DEFUN_DEPRECATED passes attribute to DEFUN as well.
951
ajsd1c51d72004-11-26 14:14:30 +00009522004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
953
ajs48d6c692004-11-26 20:52:59 +0000954 * log.c, log.h, memory.c: Change function name from zlog_backtrace_safe
955 to the more self-explanatory zlog_backtrace_sigsafe.
956
9572004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
958
ajs5b85fac2004-11-26 19:36:42 +0000959 * debug.[ch]: Remove unused files.
960 * Makefile.am: Remove references to debug.c and debug.h
961
9622004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
963
ajs063ee522004-11-26 18:11:14 +0000964 * log.c: (zlog_backtrace) New function to log a backtrace.
965 (zlog_backtrace_safe) Log a backtrace in an async-signal-safe way.
966 Unfortunately, this function does not support syslog logging yet.
967 (zlog_signal) Move backtrace code into separate function
968 zlog_backtrace_safe.
969 (_zlog_assert_failed) Call zlog_backtrace before aborting.
970 * log.h: Declare new functions zlog_backtrace and zlog_backtrace_safe.
971 * memory.c: (zerror) Call zlog_backtrace before aborting.
972
9732004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
974
ajsd1c51d72004-11-26 14:14:30 +0000975 * Makefile.am: Need to add zassert.h to pkginclude_HEADERS.
976
ajse5879ca2004-11-25 16:07:53 +00009772004-11-25 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
978
ajs4cf0d0d2004-11-25 17:14:34 +0000979 * zebra.h: If not C99 and there's no va_copy macro and there is
980 a __va_copy macro, define va_copy as __va_copy.
981
9822004-11-25 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
983
ajse5879ca2004-11-25 16:07:53 +0000984 * pid_output.c: (pid_output_lock) Fix 2 bugs: when locking, should
985 set l_whence to SEEK_SET, not SEEK_END. And after writing new
986 pid to file, must ftruncate to eliminate any extraneous bytes left
987 over from the last time a pid was written.
988
ajscee3df12004-11-24 17:14:49 +00009892004-11-24 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
990
991 * zassert.h: New header file to declare a quagga-specific assert macro.
992 * log.c: (_zlog_assert_failed) New function called when assert fails
993 to log the error and abort.
994 * zebra.h: Include "zassert.h" instead of <assert.h>.
995 * regex.c: Include "zassert.h" instead of <assert.h>.
996
ajsd246bd92004-11-23 17:35:08 +00009972004-11-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
998
ajs59a06a92004-11-23 18:19:14 +0000999 * sigevent.c: (signal_init) Set up some default signal handlers
1000 so that processes will issue an error message before terminating
1001 or dumping core.
1002 (trap_default_signals) New function to set up signal handlers
1003 for various signals that may kill the process.
1004 (exit_handler) Call zlog_signal, then _exit.
1005 (core_handler) Call zlog_signal, then abort.
1006 * log.h: Declare new function zlog_signal.
1007 * log.c: (zlog_signal) New function to log information about
1008 a received signal before the process dies. Try to log a
1009 backtrace also.
1010 (quagga_signal_handler,signal_set) Should be static.
1011
10122004-11-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1013
ajsd246bd92004-11-23 17:35:08 +00001014 * log.c: (vzlog) Take a single va_list argument and use va_copy
1015 as necessary for multiple traversals.
1016 (zlog) Pass only one va_list to vzlog.
1017 (zlog_*,plog_*) Use a macro for boilerplate code; pass only one
1018 va_list to vzlog.
1019 (zlog_set_file) Remove unused 2nd argument (flags).
1020 (zlog_save_cwd,zlog_get_cwd,zlog_free_cwd) Remove unused functions.
1021 * log.h: Remove ZLOG_*_INDEX defines (no longer used).
1022 Remove unused 2nd argument from zlog_set_file prototype.
1023 Fix prototype for zlog_rotate.
1024 * command.c: (config_log_file) Remove unused 2nd arg to zlog_set_file.
1025 * vty.c: (vty_out) Fix stdarg usage to perform multiple traversals
1026 properly.
1027 (vty_log) Must use va_copy for multiple traversals of va_list arg.
1028
ajsca359762004-11-19 23:40:16 +000010292004-11-19 David Young <dyoung@pobox.com>
1030
1031 * log.c: (safe_strerror) New function: safe wrapper for strerror.
1032
ajsff29bb32004-11-19 18:29:22 +000010332004-11-19 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1034
1035 * sockopt.c: (setsockopt_so_recvbuf) Stop error message from being
1036 printed every time.
1037
ajsf858e492004-11-16 14:25:30 +000010382004-11-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1039
1040 * memory.h: Fix prototype for memory_init().
1041 * memory.c: Declare many functions and data structures static instead
1042 of global. Fix prototype for memory_init().
1043
gdt69e13252004-11-15 18:51:15 +000010442004-11-15 Greg Troxel <gdt@fnord.ir.bbn.com>
1045
1046 * sockopt.h: Avoid CMSG_ALIGN, and declare that sizes are without
1047 alignment (users should use CMSG_SPACE).
1048
1049 * zebra.h: Rationalize CMSG_SPACE compatibility defines. Warn if
1050 asumming 4-byte alignment, since this isn't safe.
1051
ajs7fa25ff2004-11-15 16:12:32 +000010522004-11-15 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1053
1054 * memory.c: (zerror) Use zlog_err instead of fprintf to stderr.
1055 Instead of exiting, log currenty memory usage and then abort.
1056 (log_memstats) New function to log memory statistics, called by
1057 zerror.
1058 (show_memory_all) Loop over new mlists array instead of calling
1059 show_memory_vty separately for each memory_list.
1060
paulb86718e2004-11-08 17:34:07 +000010612004-11-08 Paul Jakma <paul@dishone.st>
paulb35e5b42004-11-07 22:27:27 +00001062
paul2265d202004-11-08 15:43:21 +00001063 * buffer.c: Add missing include of log.h.
1064 (buffer_flush_available) written is compared against
1065 mostly against unsigned types, only for the writev do we need
1066 signed compare, so declare it as size_t and cast it to ssize_t
1067 just for the error compare when we've called writev.
1068 * buffer.h: Add comment that buffer data sizes really should be
1069 size_t.
1070
10712004-11-07 Paul Jakma <paul@dishone.st>
1072
1073 * version.h.in: add autoconf configure_input output var
paulb35e5b42004-11-07 22:27:27 +00001074
ajs49ff6d92004-11-04 19:26:16 +000010752004-11-04 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1076
ajs5a646652004-11-05 01:25:55 +00001077 * vty.h: Remove fields in struct vty that were related to VTY_CONTINUE
1078 capabilities (that were used only in bgpd/bgp_route.c and are now
1079 removed). Also remove some other fields that were not being
1080 used at all.
1081 * vty.c: (vty_execute) Do not test for obsolete status values VTY_START
1082 and VTY_CONTINUE.
1083 (vty_read) Remove calls to vty->output_func since that was part
1084 of the VTY_CONTINUE infrastructure that has been removed.
1085 (vty_flush) Remove code to support VTY_START and VTY_CONTINUE.
1086 (vty_close) Remove code to cancel vty->t_output thread, since that
1087 thread was never actually used.
1088
10892004-11-04 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1090
ajs49ff6d92004-11-04 19:26:16 +00001091 * vty.c: Vtysh connections to daemons should use buffering.
1092 (vty_out) Remove exception for vty_shell_serv, just use buffer_write.
1093 (vty_new) Increase output buffer size to 4096 rounded up to a
1094 multiple of pagesize.
1095 (vtysh_read) After command has been executed and all output buffered,
1096 call buffer_flush_available and schedule further writes if the
1097 buffers are not yet empty.
1098 (vtysh_write) New function to flush output to vtysh when the socket
1099 is writeable.
1100 (vty_event) Added new VTYSH_WRITE event for flushing buffers to vtysh
1101 clients. Also, should save read thread in vty->t_read so the
1102 thread can be cancelled in vty_close.
1103 * buffer.h: In struct buffer_data, remove unused "parent" field.
1104 Convert "unsigned char *data" to "unsigned char data[0]" to save
1105 a malloc. Declare new function buffer_flush_available that works
1106 with non-blocking sockets.
1107 * buffer.c: (buffer_data_new) Use a single malloc now that data is
1108 a variable-size array at end of structure.
1109 (buffer_data_free) Just a single free now that data is part of the
1110 structure.
1111 (buffer_write) Simplify the logic to make behavior more transparent.
1112 (buffer_flush) Decrease b->length as data is written out.
1113 (buffer_flush_vty_all) Decrease b->length as buffers are freed.
1114 (buffer_flush_vty) Decrease b->length as data is written out.
1115 (buffer_flush_available) New function to flush non-blocking sockets.
1116
paule064d6d2004-11-01 08:59:21 +000011172004-11-01 Paul Jakma <paul@dishone.st>
1118
1119 * sockopt.c: (setsockopt_pktinfo) remove, its unused.
1120
paul75e15fe2004-10-31 02:13:09 +000011212004-10-31 Paul Jakma <paul@dishone.st>
1122
1123 * vty.c: As per Andrew's suggestions..
1124 (vty_serv_un) remove flags.
1125 (vtysh_accept) close socket if we cant set NONBLOCK. Add flags.
paul66cbbce2004-10-31 16:15:33 +00001126 * keychain.c: Convert some more strtoul users to VTY_GET_INTEGER.
paul9d11a192004-10-31 16:19:24 +00001127 * memory.h: Add MTYPE_THREAD_FUNCNAME and MTYPE_THREAD_STATS
1128 * thread.c: Update stats and funcname alloc/free to use previous
paul039b9572004-10-31 16:43:17 +00001129 specific memory type defines. Use XCALLOC and sizeof the type,
1130 not the pointer.
paul70e149e2004-10-31 16:29:50 +00001131 * smux.c: fix int to size_t compile warnings
paul75e15fe2004-10-31 02:13:09 +00001132
pauldccfb192004-10-29 08:29:36 +000011332004-10-29 Paul Jakma <paul@dishone.st>
1134
1135 * vty.c: Move setting of sock to O_NONBLOCK from vty_serv_un
1136 to vtysh_accept, where sock is the actual fd we wanted to set to
1137 O_NONBLOCK, ie the /connected/ vtysh unix socket.
1138
hasso508ec912004-10-23 14:26:49 +000011392004-10-23 Hasso Tepper <hasso at quagga.net>
1140
1141 * zclient.c: Unbreak reading interface update message. Might fix
1142 blocker bugzilla #109.
1143
paul23b9c612004-10-22 11:51:57 +000011442004-10-22 Paul Jakma <paul@dishone.st>
paul7d9c6e52004-10-22 10:54:39 +00001145
1146 * sockopt.c: (getsockopt_ipv4_ifindex) no ifindex should be 0, not
paul23b9c612004-10-22 11:51:57 +00001147 -1.
1148 (setsockopt_pktinfo) unexported
1149 * sockopt.h: Cleanup SOCKOPT_CMSG defines a bit. Add a throwaway
1150 define for SOPT_SIZE_CMSG_IFINDEX_IPV4 for systems which have
paul4ccb2c42004-10-22 22:52:33 +00001151 neither IP_RECVIF nor IP_PKTINFO (eg openbsd), thanks to Rivo
1152 Nurges for highlighting problem and fix.
paul4927cf02004-10-22 16:55:10 +00001153 Fix elif that should be an else.
paul406d6712004-10-22 12:27:44 +00001154 * command.h: Cleanup the defines a bit, add helper defines and
1155 collapse all defines to use those. Add an attribute field to
1156 cmd_element to support, eg hidden or deprecated commands, add
1157 defun defines for such. All that's left to do is add logic
1158 to command.c to check these attributes... ;)
paulaf0d97e2004-10-22 23:24:43 +00001159 * zebra.h: reserve ZEBRA_ROUTE_HSLS
paul7d9c6e52004-10-22 10:54:39 +00001160
hasso6590f2c2004-10-19 20:40:08 +000011612004-10-19 Hasso Tepper <hasso at quagga.net>
1162
1163 * version.h.in: Define copyright string QUAGGA_COPYRIGHT.
1164 * print_version.c: Remove. print_version () function moved to
1165 command.[c|h].
1166 * command.c: Use QUAGGA_COPYRIGHT.
1167 * Makefile.am: Remove useless version.c and print_version.c files.
1168
hasso3fb9cd62004-10-19 19:44:43 +000011692004-10-19 Andrew J. Schorr <aschorr@telemetry-investments.com>
1170
1171 * zclient.c: (zebra_interface_address_read) If the destination address
1172 is encoded as all zeroes, load it as a NULL pointer.
1173 * if.h: Add comment describing struct connected destination field
1174 and indicating that it may be NULL. Define macros
1175 CONNECTED_DEST_HOST and CONNECTED_POINTOPOINT_HOST to help
1176 with PtP logic (distinguish between host and subnet addressing).
1177 * if.c: (if_lookup_address) Fix PtP logic to handle subnet addressing
1178 properly,
1179 (connected_lookup_address) ditto.
1180 (connected_add_by_prefix) Handle case where destination is NULL,
1181 * prefix.[c|h]: New functions ipv4_network_addr and
1182 ipv4_broadcast_addr.
1183
hassoddd85ed2004-10-13 08:18:07 +000011842004-10-13 Hasso Tepper <hasso at quagga.net>
1185
1186 * command.c: Make CMD_ERR_NOTHING_TODO nonfatal if reading
1187 configuration from file. Fixes critical bugzilla #113.
hassoc75105a2004-10-13 10:33:26 +00001188 * smux.c, smux.h: Remove all defaults to initialize smux connection to
1189 snmpd by default even if not configured to do so. "smux peer OID
1190 <password>" initializes now connection and "no smux peer" terminates
1191 it.
hassoddd85ed2004-10-13 08:18:07 +00001192
paul42d49862004-10-13 05:22:18 +000011932004-10-13 Paul Jakma <paul@dishone.st>
1194
1195 * (global) more const'ification.
1196 * sockunion.c: (sockunion_su2str) buffer should be sized
1197 SU_ADDRSTRLEN.
1198 (sockunion_log) do not return stack variables, strdup buf before
1199 return.
1200 * vty.h: Fix up the VTY_GET_INTEGER macros. Testing caller supplied
1201 values against ULONG_MAX is daft, when caller probably has passed
1202 a type that can not hold ULONG_MAX. use a temporary long instead.
1203 Add VTY_GET_LONG, make VTY_GET_INTEGER_RANGE use it, make
1204 VTY_GET_INTEGER a define for VTY_GET_INTEGER_RANGE.
1205
hassoa1494112004-10-11 12:53:17 +000012062004-10-11 Hasso Tepper <hasso at quagga.net>
1207
1208 * command.h: Sync DEFUNSH with other macros.
1209 * sockunion.c, sockunion.h: More const strings.
1210
paul9076fbd2004-10-11 09:40:58 +000012112004-10-11 Paul Jakma <paul@dishone.st>
1212
1213 * thread.c: (funcname_thread_add_timer)
1214 (funcname_thread_add_timer_msec) Fix mistakes from last change.
1215 Pointed out by Liu Xin in [quagga-dev 1609].
paulc9eca012004-10-11 11:28:44 +00001216 * if.h: mtu's should be unsigned.
1217 * routemap.{c,h}: const char updates
1218 * smux.{c,h}: ditto
paul9076fbd2004-10-11 09:40:58 +00001219
paul9035efa2004-10-10 11:56:56 +000012202004-10-10 Paul Jakma <paul@dishone.st>
paul47ca2952004-10-10 08:03:18 +00001221
1222 * version.h.in: (pid_output*) add const qualifier.
paul9035efa2004-10-10 11:56:56 +00001223 * command.h: Change DEFUN func to take const char *[] rather
1224 than char **, to begin process of fixing compile warnings in lib/.
1225 Nearly all other changes in this commit follow from this change.
1226 * buffer.{c,h}: (buffer_write) pointer-arithmetic is gccism, take
1227 const void * and cast an automatic const char *p to it.
1228 (buffer_putstr) add const
1229 * command.c: (zencrypt) const qualifier
1230 (cmd_execute_command_real) ditto
1231 (cmd_execute_command_strict) ditto
1232 (config_log_file) ditto.
1233 Fix leak of getcwd() returned string.
1234 * memory.{c,h}: Add MTYPE_DISTRIBUTE_IFNAME for struct dist ifname.
1235 * distribute.{c,h}: Update with const qualifier.
1236 (distribute_free) use MTYPE_DISTRIBUTE_IFNAME
1237 (distribute_lookup) Cast to char *, note that it's ok.
1238 (distribute_hash_alloc) use MTYPE_DISTRIBUTE_IFNAME.
1239 (distribute_get) Cast to char *, note that it's ok.
1240 * filter.c: Update with const qualifier.
1241 * if.{c,h}: ditto.
1242 * if_rmap.{c,h}: ditto.
1243 (if_rmap_lookup) Cast to char *, note that it's ok.
1244 (if_rmap_get) ditto.
1245 * log.{c,h}: Update with const qualifier.
1246 * plist.{c,h}: ditto.
1247 * routemap.{c,h}: ditto.
1248 * smux.{c,h}: ditto. Fix some signed/unsigned comparisons.
1249 * sockopt.c: (getsockopt_cmsg_data) add return for error case.
1250 * vty.c: Update with const qualifier.
1251
hasso27a43a82004-10-08 06:29:12 +000012522004-10-08 Hasso Tepper <hasso at quagga.net>
1253
1254 * routemap.c, routemap.h: Make some string arguments const.
1255
paul5973ee72004-10-08 01:36:54 +000012562004-10-05 Paul Jakma <paul@dishone.st>
1257
1258 * version.h.in: print_version declaration is here, not in automake
1259 generated version.h.
1260
hassoea8e9d92004-10-07 21:32:14 +000012612004-10-08 Hasso Tepper <hasso at quagga.net>
1262
1263 * command.c, command.h: Make argument of cmd_make_strvec function
1264 const.
1265 * command.c: Make hostname commands usable in vtysh again.
1266
hasso6ad96ea2004-10-07 19:33:46 +000012672004-10-07 Hasso Tepper <hasso at quagga.net>
1268
1269 * command.c, pid_output.c, print_version.c, vty.c, vty.h: Make more
1270 strings const.
1271
hasso8c328f12004-10-05 21:01:23 +000012722004-10-05 Hasso Tepper <hasso at quagga.net>
1273
1274 * *.[c|h]: Make many strings cons and a lot of int -> unsigned int
1275 changes to fix warnings.
1276
paul96e27c92004-10-05 14:33:43 +000012772004-10-05 Paul Jakma <paul@dishone.st>
1278
1279 * sockopt.{c,h}: add sockopt_iphdrincl_swab_{htosys,systoh},
1280 functions to change byte order between system IP_HDRINCL order
1281 and host order.
paul98c91ac2004-10-05 14:57:50 +00001282 * thread.c: (funcname_thread_add_timer_timeval) new function, add
1283 timer at specified timeval.
1284 (funcname_thread_add_timer) use funcname_thread_add_timer_timeval.
1285 (funcname_thread_add_timer_msec) ditto
paul96e27c92004-10-05 14:33:43 +00001286
hassob04c6992004-10-04 19:10:31 +000012872004-10-04 Hasso Tepper <hasso at quagga.net>
1288
1289 * memory.c, memory.h: Make char * argument of strdup functions const.
1290 * prefix.c, prefix.h: Make many arguments const. Reorder stuff in
1291 header.
1292 * log.h: Make log message const in struct message.
1293 * log.c: Fix some indenting.
1294 * network.c, network.h: Make second argument of writen() const.
1295
hassoe7168df2004-10-03 20:11:32 +000012962004-10-03 Hasso Tepper <hasso at quagga.net>
1297
1298 * command.h: Introduce SERVICE_NODE for "service <...>" commands.
1299 * command.c: Don't initialize commands that don't make sense if vtysh
1300 is used.
1301 * vty.c: Make VTY_NODE appear in vtysh.
1302
hasso18a6dce2004-10-03 18:18:34 +000013032004-10-03 James R. Leu <jleu at mindspring.com>
1304
1305 * zclient.c, zclient.h: zclient functions for router id handling.
1306 * zebra.h: New message types for router id handling.
1307
paul9172ee02004-09-27 12:46:37 +000013082004-09-27 Paul Jakma <paul@dishone.st>
1309
1310 * zebra.h: Add WANT_OSPF_WRITE_FRAGMENT for ospfd
1311 to try to fragment oversized packets. Enabled only for Linux.
1312 Add HAVE_IP_HDRINCL_BSD_ORDER to define struct ip byte order,
1313 to consolidate various ad-hoc platform defines for same thing.
1314
hassoe473b032004-09-26 16:08:11 +000013152004-09-26 Hasso Tepper <hasso at quagga.net>
1316
1317 * vty.c, sockopt.c: Fix compiler warnings.
1318
hasso52dc7ee2004-09-23 19:18:23 +000013192004-09-23 Hasso Tepper <hasso at quagga.net>
1320
1321 * linklist.h: Remove list and listnode typedefs.
1322 * *.[c|h]: list -> struct list *, listnode -> struct listnode *.
1323
paul0b3acf42004-09-17 08:39:08 +000013242004-09-17 Paul Jakma <paul@dishone.st>
1325
paulb89e60c2004-09-21 15:43:13 +00001326 * sockopt.c: Add missing bracket
1327
13282004-09-17 Paul Jakma <paul@dishone.st>
1329
paul0b3acf42004-09-17 08:39:08 +00001330 * sockopt.{c,h}: Add setsockopt_so_recvbuf, for ripd and ripngd.
1331
paul33394762004-09-13 11:27:57 +000013322004-09-13 Paul Jakma <paul@dishone.st>
1333
1334 * command.c: Update the copyright string in the default motd.
1335
gdt630e4802004-08-31 17:28:41 +000013362004-08-31 David Wiggins <dwiggins@bbn.com>
1337
1338 * hash.c (hash_iterate): Save next pointer before calling
1339 procedure, so that iteration works even if the called procedure
1340 deletes the hash backet.
1341
1342 * linklist.h (listtail): new macro, not yet used.
1343
hasso34553cc2004-08-27 13:56:39 +000013442004-08-27 Hasso Tepper <hasso at quagga.net>
1345
1346 * command.c: Install "terminal length" commands only if vty is used.
1347 Vtysh will handle it itself.
1348
gdtafa43b22004-08-26 13:12:41 +000013492004-08-26 Greg Troxel <gdt@fnord.ir.bbn.com>
1350
1351 * sockopt.h: Define method-independent macro for callers of
1352 get_ifindex to use for cmsg length.
1353
paule6822762004-08-19 04:13:29 +000013542004-08-19 Paul Jakma <paul@dishone.st>
1355
paulefba6ce2004-08-25 13:47:16 +00001356 * zebra.h: add MAX and MIN defines (eg for ospf6d)
1357
13582004-08-19 Paul Jakma <paul@dishone.st>
1359
paule6822762004-08-19 04:13:29 +00001360 * sockopt.c: include sockopt.h
1361 rename some of the _pktinfo_ functions to _ifindex, where that is
1362 their purpose.
1363 (getsockopt_ipv6_pktinfo_ifindex) renamed to
1364 getsockopt_ipv6_ifindex.
1365 (setsockopt_ipv4_pktinfo) renamed to setsockopt_ipv4_ifindex
1366 (setsockopt_pktinfo) update with previous and add comment re
1367 AF_INET portability.
1368 (setsockopt_ifindex) generic ifindex function ala
1369 setsockopt_pktinfo.
1370 (getsockopt_ipv4_pktinfo_ifindex) renamed to
1371 getsockopt_ipv4_ifindex.
1372 (getsockopt_ipv4_ifindex) rejiggling to reduce repeated
1373 ifdef/elses. pktinfo case forgot to set ifindex.
1374 (getsockopt_pktinfo_ifindex) renamed to
1375 getsockopt_ifindex. update some calls to renamed functions.
1376 * sockopt.h: Update renamed exported functions
1377 Rename the CMSG_SIZE macros to IFINDEX.
1378 Guard IPv4 PKTINFO in a conditional define.
1379
paulc0618de2004-08-18 21:52:58 +000013802004-08-18 Paul Jakma <paul@dishone.st>
1381
1382 * vty.c: (vty_serv_un) set unix vty socket to nonblocking
1383 to prevent inadvertent blocking of daemons by use of
1384 vtysh. TODO: disentangle manual paging from the buffer_write
1385 path so that unix vty can use this path too and be reliable.
1386
gdt33f92322004-07-23 16:14:32 +000013872004-07-23 Greg Troxel <gdt@poblano.ir.bbn.com>
1388
1389 * sockopt.c (getsockopt_ipv4_pktinfo_ifindex): Make this compile
1390 on NetBSD, and add comments to make it less confusing. Change the
1391 sense of the SUNOS_5 test to make parallel structure between the
1392 variables and the code.
1393
paul4f7baa02004-07-23 15:11:07 +000013942004-07-23 Paul Jakma <paul@dishone.st>
1395
1396 * sockopt.h: Add SOPT_SIZE_CMSG_PKTINFO{_IPV{4,6}} define, for
1397 sizeof pktinfo as appropriate, to be used when allocating msg
1398 buffers. export setsockopt_pktinfo() and
1399 getsockopt_pktinfo_ifindex()
1400 * sockopt.c: (setsockopt_pktinfo_ifindex) new function to portably
1401 set received ifindex sock option.
1402 (getsockopt_pktinfo_ifindex) portably retrieve ifindex.
1403 (getsockopt_cmsg_data) retrieve indicated control info from
1404 message header.
1405 (getsockopt_ipv6_pktinfo_ifindex) ipv6 version of above.
1406 (setsockopt_ipv4_pktinfo) v4 version
1407 (setsockopt_pktinfo) the exported version
1408 (getsockopt_ipv4_pktinfo_ifindex) v4 specific version
1409 (getsockopt_pktinfo_ifindex) the exported version
1410
paul05c447d2004-07-22 19:14:27 +000014112004-07-14 Paul Jakma <paul@dishone.st>
1412
1413 * sigevent.c: (quagga_signal_handler) add a global caught flag, set
1414 the flags to a constant rather increment to be kinder.
1415 (quagga_sigevent_process) new function, to do core of what
1416 quagga_signal_timer did. dont block signals at all as sig->caught
1417 is volatile sig_atomic_t and should be safe to access from signal
1418 and normal contexts. The signal blocking is unneeded paranoia, but
1419 is left intact under an ifdef, should some platform require it.
1420 Check global caught flag before iterating through array.
1421 (quagga_signal_timer) nearly everything moved to
1422 quagga_sigevent_process. Left in under ifdef, in case some
1423 platform could use a regular timer check for signals.
1424 * sigevent.h: quagga_sigevent_process declaration.
1425 * thread.c: (thread_fetch) check for signals at beginning of
1426 scheduler loop, check for signals if select returns EINTR.
1427
gdtb7797132004-07-13 13:47:25 +000014282004-07-13 Greg Troxel <gdt@poblano.ir.bbn.com>
1429
1430 * sigevent.c: Don't block SIGTRAP and SIGKILL. Blocking SIGTRAP
1431 confuses gdb, at least on NetBSD 2.0_BETA, where the block
1432 succeeds.
1433
paul5510e832004-07-09 14:00:01 +000014342004-07-09 Paul Jakma <paul@dishone.st>
1435
1436 * Merge Kunihiro's 'show route-map' change and add
1437 compatibility aliases for route-map continue
paulb9790b32004-07-09 14:05:47 +00001438 * jhash.{c,h}: New files. Bob Jenkins' public domain hashing
1439 function, as implemented in linux kernel by David Miller.
paul5510e832004-07-09 14:00:01 +00001440
paulb06c14f2004-07-09 12:24:42 +000014412004-07-09 Juris Kalnins <juris@mt.lv>
1442
1443 * if.c: (if_cmp_func) fix for interface names where name is same,
1444 but one has no number, eg "devtyp" and "devtyp0".
1445
gdt87efd642004-06-30 17:36:11 +000014462004-06-30 Greg Troxel <gdt@poblano.ir.bbn.com>
1447
1448 * Makefile.am: Make libzebra shared.
1449
paul138ce752004-06-21 10:35:59 +000014502004-06-21 Paul Jakma <paul@dishone.st>
1451
1452 * ChangeLog: fix my last update config.h -> zebra.h ;)
1453 * zebra.h: Fix gcc check.
1454
paul02ff83c2004-06-11 11:27:03 +000014552004-06-11 Sowmini Varadhan <sowmini.varadhan@sun.com>
1456
1457 * filter.c: (access_list_remark_cmd) buffer_putstr doesnt need cast
1458 to u_char. (ipv6_access_list_remark_cmd) ditto.
1459 if.c: ditto
1460 * network.c: (readn/writen) pointer arg should be type u_char.
1461 * plist.c: needs to include stream.h, not declare stream functions
1462 internally.
1463 (various) Add static qualifier to internal functions.
1464 (prefix_list_type_str) extraneous breaks in switch statement.
1465 (ip_prefix_list_description_cmd) buffer_putstr doesnt need cast
1466 * stream.h: depends on plist.h and export stream_put_prefix
1467 * vty.c: (vty_<telnet option build functions>) should use
1468 unsigned char, telnet options are 0 -> 255.
1469 * zclient.c: various u_char<->char type cleanups.
1470 * zebra.h: Having to define CMSG_* can apply to more than just
1471 BSDI_NRL.
1472
paul51a87982004-06-09 10:36:05 +000014732004-06-09 Paul Jakma <paul@dishone.st>
1474
paul138ce752004-06-21 10:35:59 +00001475 * zebra.h: __attribute__ is a gcc'ism
paul51a87982004-06-09 10:36:05 +00001476
paul5228ad22004-06-04 17:58:18 +000014772004-06-04 Paul Jakma <paul@dishone.st>
1478
1479 * type mismatch fixes
1480
hasso6708fa32004-05-18 18:46:54 +000014812004-05-18 Hasso Tepper <hasso@estpak.ee>
1482
1483 * pqueue.[c|h]: Added as part of ospf6d merge from Zebra repository.
1484
paul0a589352004-05-08 11:48:26 +000014852004-05-08 Paul Jakma <paul@dishone.st>
1486
1487 * zclient.c (zapi_ipv4_route) Follow Sowmini's lead and describe
1488 message format.
1489
14902004-05-08 Sowmini Varadhan <sowmini.varadhan@sun.com>
1491
1492 * zclient.c: (zapi_ipv4_add) collapsed into zapi_ipv4_route
1493 (zapi_ipv4_delete) ditto.
1494 (zapi_ipv4_route) add/delete a route by way of cmd arg.
1495 (zapi_ipv6_add) collapsed into zapi_ipv6_route.
1496 (zapi_ipv6_delete) ditto.
1497 (zapi_ipv6_route) add/delete a route by way of cmd arg.
1498 (zebra_interface_address_delete_read) collapsed into
1499 zebra_interface_address_read.
1500 (zebra_interface_address_delete_read) ditto.
1501 (zebra_interface_address_read) read address add/delete messages
1502 by way of type argument. Describe command message format.
1503 (zebra_interface_add_read) Unconditionally read new ifmtu6 field.
1504 Describe command message format.
1505 (zebra_interface_state_read) Unconditionally read new ifmtu6 field.
1506 (zclient_redistribute_set) Collapsed into zclient_redistribute
1507 (zclient_redistribute_unset) ditto
1508 (zclient_redistribute) set/unset redistribution.
1509 (zclient_redistribute_default_set) Collapsed into
1510 zclient_redistribute_default.
1511 (zclient_redistribute_default_unset) ditto.
1512 (zclient_redistribute_default) Redistribute default set/unset.
1513 * zclient.h: delete zapi_ipv{4,6}_add, zapi_ipv{4,6}_delete. Add
1514 zapi_ipv{4,6}_route. delete zclient_redistribute_set/unset. Add
1515 zclient_redistribute. Ditto for
1516 zclient_redistribute_default_{set/unset}.
1517
paul4a7aac12004-05-08 05:00:31 +000015182004-05-08 Sowmini Varadhan <sowmini.varadhan@sun.com>
1519
1520 * if.h: Add mtu6 field to struct interface, IPv6 MTU may differ
1521 from IPv4, and Solaris treats the MTU's differently.
1522 Add connected_add_by_prefix, for use by later patch.
1523 * if.c: (connected_add_by_prefix) Add prefix to connected list.
1524 (if_flag_dump) Solaris: Dump IFF_IPv4/6 flag
1525 (if_dump) Dump mtu6 flag, for HAVE_IPV6.
paul22528292004-05-08 05:10:38 +00001526 * command.c: (sockunion_getsockname) use socklen_t for len.
1527 (sockunion_getpeername) ditto.
paul0a589352004-05-08 11:48:26 +00001528
paul31fcdd32004-04-21 11:00:43 +000015292004-04-21 Boris Kovalenko <boris@tagnet.ru>
1530
1531 * daemon.c: (daemon) fix check for error return from setsid
1532
paulc49b3062004-01-19 21:23:37 +000015332004-01-19 Paul Jakma <paul@dishone.st>
1534
1535 * sigevent.{c,h}: New files, implement event handled signals.
1536 see signal_init() in sigevent.h.
1537
jardinc32e1b52003-12-23 09:06:51 +000015382003-12-23 Vincent Jardin <jardin@6wind.com>
1539
1540 * {command.c, memory.c, vty.c, zebra.h}: Add isisd support
1541
gdt3dbf9962003-12-22 20:18:18 +000015422003-12-22 Greg Troxel <gdt@fnord.ir.bbn.com>
1543
1544 * vty.c (vty_use_backup_config): Don't free filenames before using
1545 them for unlink.
1546
paul54aba542003-08-21 20:28:24 +000015472003-08-20 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
1548
1549 * command.c: Fix <cr> display problem for command line
1550 description
1551
paule9af5c72003-05-24 11:54:31 +000015522003-05-24 Anil Madhavapeddy
1553
1554 * (sockunion.c): Incorrect bounds specified in sockunion_log()
1555
paul445f1432003-05-16 19:00:31 +000015562003-05-08 Sergiy Vyshnevetskiy <serg @ vostok.net>
1557
1558 * vty.c: -A option
1559
15602003-04-19 Hasso Tepper <hasso@estpak.ee>
1561
1562 * rip_routemap.c: sync daemon's route-map commands to have same
1563 syntax
1564
paul718e3742002-12-13 20:15:29 +000015652002-09-28 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
1566
1567 * vty.c (vty_flush): One line more on vty.
1568
15692002-09-27 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1570
1571 * vector.c (vector_lookup): Add new function.
1572
15732002-08-19 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1574
1575 * thread.c (timeval_adjust): Fix unconditional crush due to
1576 FreeBSD's select() system call timeval value check.
1577
15782002-07-07 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1579
1580 * zebra-0.93 released.
1581
15822002-06-21 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1583
1584 * if.c (ifc_pointopoint): Add ifc_pointopoint() accoding to Frank
1585 van Maarseveen's suggestion.
1586
15872002-06-18 Kunihiro Ishiguro <kunihiro@zebra.org>
1588
1589 * command.c: Change bcopy() to memcpy().
1590
15912001-12-12 Kunihiro Ishiguro <kunihiro@zebra.org>
1592
1593 * command.c (config_password): Fix host.password clear bug.
1594 Reported by Wang Jian <lark@linux.net.cn>.
1595
15962001-08-29 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1597
1598 * thread.c (thread_should_yield): New function to check thread
1599 should yeild it's execution to other thread. Suggested by: Rick
1600 Payne <rickp@ayrnetworks.com>
1601
16022001-08-20 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1603
1604 * thread.c (thread_timer_cmp): Rewrite function.
1605
1606 * hash.c: Add hash_get(). Change hash_pull() to hash_release().
1607
16082001-08-19 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1609
1610 * zebra-0.92a released.
1611
16122001-08-15 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1613
1614 * zebra-0.92 released.
1615
16162001-08-12 Akihiro Mizutani <mizutani@dml.com>
1617
1618 * prefix.c (netmask_str2prefix_str): Convert "1.1.0.0 255.255.0.0"
1619 string to "1.1.0.0/16".
1620
16212001-08-10 Kunihiro Ishiguro <kunihiro@zebra.org>
1622
1623 * filter.c (access_list_lookup): access_list_lookup's first
1624 argument is changed from address family to AFI.
1625
1626 * plist.c: (prefix_list_lookup): Likewise.
1627
16282001-07-27 Akihiro Mizutani <mizutani@dml.com>
1629
1630 * plist.c: ge and le display order is changed. Old compatible
1631 rule (len <= ge-value <= le-value) is removed.
1632
16332001-07-08 Kunihiro Ishiguro <kunihiro@zebra.org>
1634
1635 * prefix.h: Temporary fix for alignment of prefix problem.
1636
16372001-06-21 Kunihiro Ishiguro <kunihiro@zebra.org>
1638
1639 * prefix.h (struct prefix): Remove safi and padding field.
1640 (struct prefix_ipv4): Likewise.
1641 (struct prefix_ipv6): Likewise.
1642 (struct prefix_ls): Likewise.
1643 (struct prefix_rd): Likewise.
1644
1645 * command.h (enum node_type): Preparation for BGP new config.
1646
1647 * vty.c (vty_end_config): Likewise.
1648
16492001-06-17 Kunihiro Ishiguro <kunihiro@zebra.org>
1650
1651 * routemap.c (route_map_rule_delete): Call func_free when
1652 route-map rule is deleted.
1653
16542001-06-14 "Akihiro Mizutani" <mizutani@dml.com>
1655
1656 * routemap.c (route_map_index_lookup): Prevent to use deny and
1657 permit for same route-map sequence.
1658
16592001-04-12 Kunihiro Ishiguro <kunihiro@zebra.org>
1660
1661 * vty.c (vty_read_config): Fix warning.
1662
16632001-03-08 Kunihiro Ishiguro <kunihiro@zebra.org>
1664
1665 * command.c (IPV6_PREFIX_STR): Add '.' and '%' for IPv6 address
1666 strings.
1667
16682001-03-07 Kunihiro Ishiguro <kunihiro@zebra.org>
1669
1670 * zebra.h (_XPG4_2): Define _XPG4_2 and __EXTENSIONS__ for
1671 CMSG_FIRSTHDR.
1672
16732001-03-07 Michael Rozhavsky <mrozhavsky@opticalaccess.com>
1674
1675 * zebra.h (struct in_pktinfo): structure in_pktinfo declaration.
1676
16772001-02-19 Kunihiro Ishiguro <kunihiro@zebra.org>
1678
1679 * memory.c (memory_list_lib): Add MTYPE_NEXTHOP for "show memory
1680 lib" member.
1681
16822001-02-13 Matthew Grant <grantma@anathoth.gen.nz>
1683
1684 * vty.c (vty_read_config): Revert check of integrate_default when
1685 VTYSH is defined.
1686
16872001-02-13 Kunihiro Ishiguro <kunihiro@zebra.org>
1688
1689 * vty.c (vty_read_config): Do not check integrate_default. That
1690 should be used only by vtysh.
1691
16922001-02-08 Matthew Grant <grantma@anathoth.gen.nz>
1693
1694 * vty.c (vty_serv_un): Set umask 0077.
1695 (vty_read_config): Stat for vtysh Zebra.conf, if found startup and
1696 wait for boot configuration.
1697
1698 * if.c (if_lookup_address): Make it smart implementation.
1699
1700 * sockopt.c (setsockopt_multicast_ipv4): Set up a multicast socket
1701 options for IPv4 This is here so that people only have to do their
1702 OS multicast mess in one place rather than all through zebra,
1703 ospfd, and ripd .
1704
17052001-02-04 Akihiro Mizutani <mizutani@dml.com>
1706
1707 * plist.c (vty_prefix_list_install): Even when argument is
1708 invalid, new memory is allocated. Now memory allocation is done
1709 after argument check.
1710
17112001-02-01 Kunihiro Ishiguro <kunihiro@zebra.org>
1712
1713 * zebra-0.91 is released.
1714
17152001-01-31 Akihiro Mizutani <mizutani@dml.com>
1716
1717 * vty.c (vty_login): Add vty login command.
1718
17192001-01-31 Kunihiro Ishiguro <kunihiro@zebra.org>
1720
1721 * vty.c (vty_reset): Close accept socket.
1722
17232001-01-30 Kunihiro Ishiguro <kunihiro@zebra.org>
1724
1725 * memory.h (enum): MTYPE_ATTR_TRANSIT is added for unknown transit
1726 attribute.
1727
17282001-01-22 Kunihiro Ishiguro <kunihiro@zebra.org>
1729
1730 * zclient.c (zebra_interface_address_add_read): Fetch interface
1731 address flag.
1732 (zebra_interface_address_delete_read): Likewise.
1733
17342001-01-16 Kunihiro Ishiguro <kunihiro@zebra.org>
1735
1736 * table.c (route_node_match_ipv4): Utility function for IPv4
1737 address lookup.
1738 (route_node_match_ipv6): Utility function for IPv4 address lookup.
1739
17402001-01-15 Kunihiro Ishiguro <kunihiro@zebra.org>
1741
1742 * if.c: Delete RIP_API part until new implementation comes out.
1743
17442001-01-13 Kunihiro Ishiguro <kunihiro@zebra.org>
1745
1746 * hash.h (struct Hash): Rename alloc to count. Change type to
1747 unsigned long.
1748
1749 * stream.c (stream_getc_from): New function.
1750 (stream_getw_from): Likewise.
1751
1752 * zebra.h (ZEBRA_FLAG_STATIC): Add new flag for persistent route.
1753
17542001-01-11 Kunihiro Ishiguro <kunihiro@zebra.org>
1755
1756 * flap.c: File is removed.
1757
1758 * flap.c: Likewise.
1759
1760 * roken.h: Likewise.
1761
1762 * buffer.c (buffer_new): Remove type option to buffer_new().
1763
17642001-01-10 Kunihiro Ishiguro <kunihiro@zebra.org>
1765
1766 * zclient.c (zapi_ipv4_delete): Remove OLD_RIB part.
1767
17682001-01-09 Kunihiro Ishiguro <kunihiro@zebra.org>
1769
1770 * zebra-0.90 is released.
1771
1772 * command.c: Update Copyright year.
1773
17742001-01-09 Matthew Grant <grantma@anathoth.gen.nz>
1775
1776 * if.c (if_create): Register connected_free() function for
1777 deletion.
1778 (if_delete): Free connected information when the interface is
1779 deleted.
1780 (if_lookup_by_index): Fix argument type from int to unsigned int.
1781 (connected_add): Keep list in order if old info found, essential
1782 for repeatable operation in some daemons.
1783
17842001-01-09 endo@suri.co.jp (Masahiko Endo)
1785
1786 * vty.c (vty_flush): When vty->statis is VTY_CLOSE do not add vty
1787 read thread.
1788
17892001-01-08 Kunihiro Ishiguro <kunihiro@zebra.org>
1790
1791 * filter.c (access_list_delete): Access-list name is not freed.
1792
1793 * plist.c (prefix_list_delete): Prefix-list name is not freed.
1794
17952000-12-29 Kunihiro Ishiguro <kunihiro@zebra.org>
1796
1797 * zclient.c (zclient_start): Change to use UNIX domain
1798 socket for zebra communication.
1799
1800 * vector.c (vector_init): vector_alloc and vector_data_alloc is
1801 removed. All memory allocation count should be maintained by
1802 XMALLOC and XFREE macros.
1803
18042000-12-28 Kunihiro Ishiguro <kunihiro@zebra.org>
1805
1806 * zebra.h (ZEBRA_NEXTHOP_IFINDEX): Define ZEBRA_NEXTHOP_* values.
1807
18082000-12-27 Kunihiro Ishiguro <kunihiro@zebra.org>
1809
1810 * zebra.h (ZEBRA_ERR_RTEXIST): Make zebra error code to negative
1811 value.
1812
18132000-12-25 "Wataru Uno" <wataru@po.ntts.co.jp>
1814
1815 * vty.c (vtysh_read): Don't allocate new buffer because buffer is
1816 allocated in vty_new ().
1817
18182000-12-14 Kunihiro Ishiguro <kunihiro@zebra.org>
1819
1820 * memory.h (enum): Add MTYPE_AS_FILTER_STR.
1821
1822 * command.c (config_write_terminal): Display "end" at the end of
1823 configuration.
1824
1825 * plist.c (vty_prefix_list_install): Use AF_INET to determine
1826 lenum length.
1827
18282000-12-13 "Wataru Uno" <wataru@po.ntts.co.jp>
1829
1830 * buffer.c (buffer_flush_vty): If IOV_MAX defined in the System,
1831 then all lines write by IOV_MAX.
1832
18332000-12-12 Michael Rozhavsky <mrozhavsky@opticalaccess.com>
1834
1835 * command.c (config_write_file): Robust method for writing
1836 configuration file and recover from backing up config file.
1837
18382000-11-29 Kunihiro Ishiguro <kunihiro@zebra.org>
1839
1840 * smux.c (smux_connect): More fail check.
1841 (smux_trap): When SMUX connection is not established, do nothing.
1842
18432000-11-28 Gleb Natapov <gleb@nbase.co.il>
1844
1845 * thread.c (thread_fetch): Execut event list first. Old event
1846 list is renamed to ready list. With this change, event thread is
1847 executed before any other thread.
1848
1849 * thread.h (struct thread_master): Add ready list.
1850
18512000-11-28 Kunihiro Ishiguro <kunihiro@zebra.org>
1852
1853 * linklist.c (listnode_add_after): Add node right after the
1854 listnode pointer.
1855
18562000-11-27 Kunihiro Ishiguro <kunihiro@zebra.org>
1857
1858 * smux.h: Pass struct variable to WriteMethod.
1859
18602000-11-25 Frank van Maarseveen <F.vanMaarseveen@inter.NL.net>
1861
1862 * if.c (if_lookup_address): When looking up interface with IP
1863 address, Sometimes multiple interfaces will match. Now PtP
1864 interfaces prevail in such a case which seem the right thing to
1865 do: There will probably also be host routes which usually prevail
1866 over network routes.
1867
18682000-11-25 Kunihiro Ishiguro <kunihiro@zebra.org>
1869
1870 * smux.c (smux_trap): SMUX trap implementation.
1871
18722000-11-19 Akihiro Mizutani <mizutani@dml.com>
1873
1874 * plist.c: Add automatic conversion function of an old rule.
1875 ex.) 10.0.0.0/8 ge 8 -> 10.0.0.0/8 le 32
1876
18772000-11-16 Yon Uriarte <ukl2@rz.uni-karlsruhe.de>
1878
1879 * zclient.c (zebra_interface_add_read): Read hardware address when
1880 hw_addr_len is greater than 0.
1881
18822000-11-15 Akihiro Mizutani <mizutani@dml.com>
1883
1884 * plist.c: The rule of "len <= ge-value <= le-value"
1885 was changed to "len < ge-value <= le-value".
1886
18872000-11-09 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
1888
1889 * memory.[ch]: Added #define and functions for ospf6d.
1890
1891 * log.[ch]: some platform says that the data of used va_list
1892 is undefined. Changed to hold list of va_list for each
1893 vsnprintf.
1894
18952000-11-07 Rick Payne <rickp@rossfell.co.uk>
1896
1897 * memory.h (enum): Add MTYPE_COMMUNITY_REGEXP.
1898
18992000-11-06 Kunihiro Ishiguro <kunihiro@zebra.org>
1900
1901 * command.c (config_exit): Fix bug of missing break after case
1902 BGP_VPNV4_NODE.
1903
19042000-10-30 Kunihiro Ishiguro <kunihiro@zebra.org>
1905
1906 * vector.c (vector_unset): Check i is not nevative.
1907
19082000-10-24 Arkadiusz Miskiewicz <misiek@pld.org.pl>
1909
1910 * smux.c (smux_sock): Set terminating '\0'. Check address family.
1911
1912 * vty.c (vty_serv_sock_addrinfo): Set terminating '\0'. Use
1913 gai_strerror. Check address family.
1914
19152000-10-23 Jochen Friedrich <jochen@scram.de>
1916
1917 * smux.c: Use linklist rather than vector.
1918 (smux_getnext): A SMUX subagent has to behave as if it manages the
1919 whole SNMP MIB tree itself. It's the duty of the master agent to
1920 collect the best answer and return it to the manager. See RFC 1227
1921 chapter 3.1.6 for the glory details :-). ucd-snmp really behaves
1922 bad here as it actually might ask multiple times for the same
1923 GETNEXT request as it throws away the answer when it expects it in
1924 a different subtree and might come back later with the very same
1925 request.
1926
19272000-10-23 Kunihiro Ishiguro <kunihiro@zebra.org>
1928
1929 * command.c (cmd_init): Log related command are only installed for
1930 terminal mode.
1931
19322000-10-21 Kunihiro Ishiguro <kunihiro@zebra.org>
1933
1934 * Makefile.am (libzebra_a_SOURCES): Remove duplicated buffer.c.
1935
1936 * zebra.h: Remove #warn directive.
1937
19382000-10-20 Kunihiro Ishiguro <kunihiro@zebra.org>
1939
1940 * keychain.c (keychain_init): Register "key chain" command to
1941 KEYCHAIN_NODE and KEYCHAIN_KEY_NODE.
1942
1943 * vty.c (vty_end_config): Fix missing vty_cinfig_unlock for other
1944 CONFIG_NODE.
1945
1946 * command.c (config_end): Likewise.
1947
1948 * keychain.c (keychain_get): Key is sorted by it's identifier
1949 value.
1950
19512000-10-19 Kunihiro Ishiguro <kunihiro@zebra.org>
1952
1953 * linklist.c (list_delete_all_node): Call delete function if it is
1954 defined.
1955
1956 * command.c (cmd_execute_command_strict): Add modification for
1957 vtysh.
1958 (cmd_execute_command_strict): Remove first argument cmdvec because
1959 it is global varibale in command.c.
1960
19612000-10-18 Kunihiro Ishiguro <kunihiro@zebra.org>
1962
1963 * command.c (cmd_init): Install
1964 copy_runningconfig_startupconfig_cmd only in terminal mode.
1965
1966 * linklist.c (list_delete_node): Simplify the function.
1967 (listnode_lookup): Renamed from list_lookup_node.
1968
19692000-10-17 Kunihiro Ishiguro <kunihiro@zebra.org>
1970
1971 * stream.h: Undef stream_read and stream_write without
1972 parenthesis.
1973
1974 * newlist.c: File removed.
1975
1976 * newlist.h: Likewise.
1977
1978 * linklist.c (list_new): Remove list_init(). To allocate new
1979 linked list, please use list_new().
1980 (listnode_add): Remove list_add_node(). To add new node to linked
1981 list, please use listnode_add().
1982 (list_delete_by_val): Revemove fucntion.
1983
19842000-10-16 Nobuaki Tanaka <nobby@po.ntts.co.jp>
1985
1986 * table.c (route_table_free): Reimplement route_table_free().
1987
19882000-10-11 Kunihiro Ishiguro <kunihiro@zebra.org>
1989
1990 * keychain.c (keychain_get): Register key_delete_func to key
1991 list's delete function. Use linklist.c instead of newlist.c.
1992
19932000-10-04 Akihiro Mizutani <mizutani@dml.com>
1994
1995 * filter.c (access_list_remark): Add access-list's remark command.
1996 (no_access_list): "no access-list 100 permit any" error message
1997 bug is fixed.
1998
19992000-10-03 Kunihiro Ishiguro <kunihiro@zebra.org>
2000
2001 * memory.h (enum): Add MTYPE_SOCKUNION.
2002
20032000-10-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2004
2005 * zebra-0.89 is released.
2006
20072000-10-01 Kunihiro Ishiguro <kunihiro@zebra.org>
2008
2009 * linklist.c (list_add_node_head): Delete unused function.
2010 (list_add_node_tail): Likewise.
2011
20122000-09-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2013
2014 * stream.c (stream_read_unblock): Add new function for unblocking
2015 read.
2016
20172000-09-26 Jochen Friedrich <jochen@nwe.de>
2018
2019 * smux.c (smux_register): Fix bug of can't register more than one
2020 MIB with SMUX.
2021
20222000-09-26 Makoto Otsuka <otsuka@inl.ntts.co.jp>
2023
2024 * vty.c (vty_close): Fix memory leak of sb_buffer.
2025 (vty_new): Likewise.
2026
20272000-09-21 steve@Watt.COM (Steve Watt)
2028
2029 * log.h: Do not declare zlog_priority[0] variable.
2030
20312000-09-12 Kunihiro Ishiguro <kunihiro@zebra.org>
2032
2033 * linklist.h (struct _list ): Add member cmp for compare function.
2034 (struct _list ): Member up is deleted
2035
20362000-09-12 David Lipovkov <dlipovkov@OpticalAccess.com>
2037
2038 * if.c: Include RIP_API header when RIP API is enabled.
2039
20402000-09-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2041
2042 * prefix.c (prefix_free): Siplify prefix_free().
2043
2044 * keychain.c (key_match_for_accept): strncmp check bug is fixed.
2045
20462000-09-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2047
2048 * zebra.h: Merge roken.h into zebra.h.
2049
20502000-09-05 Akihiro Mizutani <mizutani@dml.com>
2051
2052 * routemap.c (route_map_init_vty): Install route-map command to
2053 RMAP_NODE.
2054
20552000-08-22 Kunihiro Ishiguro <kunihiro@zebra.org>
2056
2057 * thread.c (thread_get_id): Remove pthread related garbage.
2058
2059 * command.h (struct host): Likewise.
2060
2061 * zebra.h: Likewise.
2062
20632000-08-20 Kunihiro Ishiguro <kunihiro@zebra.org>
2064
2065 * command.h (node_type ): Add AAA node for authentication.
2066
2067 * vty.c (vty_close): Do not close stdout.
2068
20692000-08-18 Kunihiro Ishiguro <kunihiro@zebra.org>
2070
2071 * vty.c (vty_init_vtysh): Added for vtysh.
2072
2073 * distribute.c (districute_list_prefix_all): Interface independent
2074 filter can be set.
2075 (distribute_list_all): Likewise.
2076 (config_show_distribute): Display current distribute-list status
2077 for "show ip protocols".
2078
20792000-08-18 Akihiro Mizutani <mizutani@dml.com>
2080
2081 * command.c (config_terminal_no_length): no terminal monitor ->
2082 terminal no monitor
2083 (cmd_init): Do not install service_terminal_length_cmd into
2084 ENABLE_NODE.
2085
2086 * vty.c (terminal_no_monitor): no terminal length -> terminal no
2087 length.
2088
20892000-08-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2090
2091 * zebra-0.88 is released.
2092
20932000-08-17 Magnus Ahltorp <ahltorp@nada.kth.se>
2094
2095 * vty.h (struct vty ): Add iac_sb_in_progress and sb_buffer for
2096 better IAC handling.
2097
2098 * vty.c (vty_telnet_option): Change telnet option handling.
2099
21002000-08-15 Gleb Natapov <gleb@nbase.co.il>
2101
2102 * zclient.c (zclient_redistribute_unset): New function added.
2103
21042000-08-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2105
2106 * zclient.c (zebra_interface_add_read): Change ifindex restore
2107 size from two octet to four.
2108 (zebra_interface_state_read): Likewise.
2109 (zebra_interface_address_add_read): Likewise.
2110
21112000-08-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2112
2113 * vty.c (vty_event): Use vector_set_index() instead of
2114 vector_set().
2115
21162000-08-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2117
2118 * zebra.h (ZEBRA_XXX_DISTANCE_DEFAULT): Define Default
2119 Administrative Distance of each protocol.
2120
21212000-08-07 Matthew Grant <grantma@anathoth.gen.nz>
2122
2123 * if.h (struct interface ): Add new member bandwidth to struct
2124 interface.
2125
2126 * zclient.c (zebra_interface_add_read): Fetch bandwidth value.
2127 (zebra_interface_state_read): Likewise.
2128
21292000-08-07 Gleb Natapov <gleb@nbase.co.il>
2130
2131 * routemap.c (route_map_event_hook): New hook route_map_event_hook
2132 is added. This hook is called when route-map is changed. The
2133 parameters passed to the hook are 'event' and 'route-map name'
2134
2135 * routemap.h: Add prototype for route_map_event_hook().
2136
21372000-08-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2138
2139 * zclient.c (zebra_ipv4_route): zebra_ipv4_route(),
2140 zebra_ipv4_add(), zebra_ipv4_delete() are removed.
2141
2142 * routemap.c (route_map_empty): Add new function.
2143 (route_map_delete): Use route_map_index_delete() instead of
2144 route_map_index_free().
2145 (route_map_index_free): Function removed.
2146
21472000-08-06 Gleb Natapov <gleb@nbase.co.il>
2148
2149 * routemap.c (route_map_index_delete): Add check for route-map is
2150 empty or not.
2151
21522000-08-03 Kunihiro Ishiguro <kunihiro@zebra.org>
2153
2154 * zclient.c (zebra_ipv4_add): Change socket arguemnt with struct
2155 zclient.
2156
21572000-08-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2158
2159 * zclient.h (struct zebra): Add obuf for output buffer.
2160
2161 * if.c: Remove #ifdef NRL enclosing if_nametoindex() and
2162 if_indextoname().
2163
21642000-08-02 David Lipovkov <davidl@nbase.co.il>
2165
2166 * if.h (IF_PSEUDO_UNSET): IF_PSEUDO related macro added.
2167 (IF_UNKNOWN_SET): IF_UNKNOWN related macro deleted.
2168
2169 * if.c (interface_pseudo): Add "pseudo" command to interface node.
2170 (no_interface_pseudo): Add "no pseudo" command to interface node.
2171
2172 * zclient.c (zebra_interface_add_read): Set pseudo flag when it is
2173 send from zebra.
2174
21752000-08-01 Kunihiro Ishiguro <kunihiro@zebra.org>
2176
2177 * zebra.h (ZEBRA_IPV4_NEXTHOP_LOOKUP): Add new message.
2178 (ZEBRA_IPV6_NEXTHOP_LOOKUP): Likewise.
2179
2180 * vty.c (vty_serv_un): Use AF_UNIX for backward compatibility.
2181
21822000-07-31 Kunihiro Ishiguro <kunihiro@zebra.org>
2183
2184 * vty.c: Use vector for VTY server thread listing instead of
2185 single value.
2186
21872000-07-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2188
2189 * keychain.c (no_key_chain): "no key chain WORD" command is added.
2190
21912000-07-29 Kunihiro Ishiguro <kunihiro@zebra.org>
2192
2193 * command.c (config_from_file): If command fail in
2194 KEYCHAIN_KEY_NODE, down to KEYCHAIN_NODE.
2195
2196 * vty.h (struct vty ): Add index_sub member.
2197
21982000-07-27 Akihiro Mizutani <mizutani@dml.com>
2199
2200 * if.c: Help strings updates.
2201
22022000-07-11 Akihiro Mizutani <mizutani@dml.com>
2203
2204 * command.c (no_config_enable_password): Add "no enable password"
2205 command.
2206 (config_write_host): Display password string.
2207
2208 * routemap.c (route_map_delete_match): Add support for delete
2209 match without argument.
2210 (route_map_delete_set): Likewise.
2211
22122000-07-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2213
2214 * command.h (node_type ): Change KEYCHAIN_NODE and
2215 KEYCHAIN_KEY_NODE place just before INTERFACE_NODE.
2216
22172000-07-09 Jochen Friedrich <jochen@scram.de>
2218
2219 * smux.c (config_write_smux): Fixes the option to override OID and
2220 password for SMUX.
2221
22222000-07-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2223
2224 * command.h (node_type ): Add SMUX_NODE for SMUX configuration.
2225
22262000-07-09 Toshiaki Takada <takada@zebra.org>
2227
2228 * command.c: Sort descvec command's help.
2229
2230 * vty.c (vty_describe_command): Display '<cr>' at the end of
2231 descriptions.
2232
22332000-07-05 Toshiaki Takada <takada@zebra.org>
2234
2235 * command.c (cmd_ipv6_match), (cmd_ipv6_prefix_match): Fix bug
2236 treatment of double colon.
2237
22382000-07-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2239
2240 * zclient.h: Add zclient_redistribute_default_{set,unset}().
2241
2242 * keychain.c: New file for authentication key management.
2243 * keychain.h: Likewise.
2244
2245 * tcpfilter.c: New file for TCP/UDP base filtering using ipfw or
2246 ipchains.
2247 * tcpfilter.h: Likewise.
2248
2249 * flap.h: New file for route flap dampening.
2250 * flap.c: Likewise.
2251
22522000-07-04 Toshiaki Takada <takada@zebra.org>
2253
2254 * filter.c (struct filter): Add exact flag.
2255 (access_list): Add exact-match command.
2256 (ipv6_access_list): Add exact-match command.
2257
22582000-07-03 Kunihiro Ishiguro <kunihiro@zebra.org>
2259
2260 * zebra.h (ZEBRA_REDISTRIBUTE_DEFAULT_ADD): New message for
2261 request default route.
2262
22632000-07-01 Hideaki YOSHIFUJI ($B5HF#1QL@(B) <yoshfuji@ecei.tohoku.ac.jp>
2264
2265 * smux.c: Add IPv6 smux connection code.
2266
22672000-06-15 Kunihiro Ishiguro <kunihiro@zebra.org>
2268
2269 * vty.c (vty_complete_command): To cooperate readline library,
2270 returned string is newly allocated. So some match function case
2271 need, free of memory.
2272
22732000-06-12 Akihiro Mizutani <mizutani@dml.com>
2274
2275 * distribute.c: Fix help strings.
2276
22772000-06-11 Kunihiro Ishiguro <kunihiro@zebra.org>
2278
2279 * command.c (cmd_complete_command): Add check for vector_slot
2280 (vline, index) is not NULL when calculating lcd.
2281 (cmd_entry_function): First check variable arguemnt to prevent it
2282 from completion.
2283
22842000-06-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2285
2286 * vty.h (struct vty ): Add output_count member for displaying
2287 output route count. Remove arugment arg from output_func because
2288 the value is passed by vty argument. Change output to output_rn.
2289 Add output_clean function pointer member. Add output_type member.
2290
22912000-06-10 Toshiaki Takada <takada@zebra.org>
2292
2293 * command.c (show_startup_config): Add "show startup-config"
2294 command.
2295
22962000-06-06 Akihiro Mizutani <mizutani@dml.com>
2297
2298 * filter.c: Fix help strings.
2299
23002000-06-05 Kunihiro Ishiguro <kunihiro@zebra.org>
2301
2302 * prefix.h (struct prefix_rd): New prefix structure for routing
2303 distinguisher.
2304 (struct prefix): Add padding to every prefix structure.
2305
2306
2307 * routemap.c (route_map_add_match): When completely same match
2308 statement exists, don't duplicate it.
2309
23102000-06-05 Akihiro Mizutani <mizutani@dml.com>
2311
2312 * routemap.c: Change NAME to WORD.
2313
2314 * plist.c: Fix help strings.
2315
23162000-06-02 Akihiro Mizutani <mizutani@dml.com>
2317
2318 * routemap.c: Fix route-map help strings.
2319
23202000-06-01 Kunihiro Ishiguro <kunihiro@zebra.org>
2321
2322 * command.c (cmd_filter_by_completion): Fix CMD_VARARG treatment
2323 to filter other non vararg commands.
2324
2325 * routemap.c (route_map_init_vty): Use install_default() for
2326 install common commands into route-map node..
2327
23282000-06-01 Akihiro Mizutani <mizutani@dml.com>
2329
2330 * command.h (OSPF_STR): Macro added.
2331
23322000-05-31 Kunihiro Ishiguro <kunihiro@zebra.org>
2333
2334 * command.c (cmd_complete_command): LCD completion must not modify
2335 installed command string.
2336
2337 * plist.c (ipv6_prefix_list): Fix wrong syntax definition. Change
2338 X:X::X:X to X:X::X:X/M.
2339
23402000-05-31 Toshiaki Takada <takada@zebra.org>
2341
2342 * vty.c (show_history): New defun added.
2343
23442000-05-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2345
2346 * command.h (CMD_COMPLETE_LIST_MATCH): New define for completion
2347 list. CMD_COMPLETE_MATCH is used for LCD completion.
2348
2349 * vty.c (vty_complete_command): Matched string's LCD is completed.
2350
2351 * command.c (cmd_lcd): New function for calculate LCD of matched
2352 strings.
2353
23542000-05-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2355
2356 * command.c (install_default): config_write_terminal_cmd,
2357 config_write_file_cmd, config_write_memory_cmd are added to
2358 default node.
2359
2360 * memory.c (memory_init): Divide show memory command into each
2361 sort.
2362
2363 * command.c (cmd_init): config_write_terminal_cmd,
2364 config_write_file_cmd, config_write_memory_cmd are added to
2365 CONFIG_NODE.
2366
2367 * routemap.c (route_map_index_free): New function.
2368 (no_route_map_all): New DEFUN for "no route-map NAME".
2369
2370 * filter.c (no_access_list_all): New DEFUN for delete access-list
2371 with NAME.
2372 (no_ipv6_access_list_all): Likewise.
2373
23742000-05-23 Kunihiro Ishiguro <kunihiro@zebra.org>
2375
2376 * plist.c: Change IPV6_PREFIX to X:X::X:X. When "any" is
2377 specified, user can not use "ge" and "le" statement.
2378
23792000-05-22 Thomas Molkenbur <tmo@datus.datus.com>
2380
2381 * routemap.c (route_map_add_set): Fix bug of next pointer missing.
2382
2383 * table.c (route_table_free): Like wise.
2384
23852000-05-22 Toshiaki Takada <takada@zebra.org>
2386
2387 * vty.c (vty_stop_input): Set history pointer to the latest one.
2388
2389 * vty.c (vty_hist_add): Do not add command line history when input
2390 is as same as previous one.
2391
23922000-05-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2393
2394 * memory.h (enum): Add MTYPE_ECOMMUNITY and MTYPE_ECOMMUNITY_VAL.
2395
23962000-05-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2397
2398 * command.h (node_type ): Add BGP_VPNV4_NODE.
2399
24002000-05-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2401
2402 * vty.c (vtysh_accept): Add cast of struct sockaddr * to bind
2403 argument. Reported by: Vesselin Mladenov <mladenov@netbg.com>.
2404
2405 * filter.c (ipv6_access_list): Add IPv6 prefix example instead of
2406 IPv4 example. Reported by: Love <lha@s3.kth.se>.
2407
2408 * command.c (cmd_complete_command): Make it sure last element of
2409 matchvec is NULL. This fix problem which cause crush in
2410 vty_complete_command(). Reported by: JINMEI Tatuya
2411 <jinmei@isl.rdc.toshiba.co.jp>.
2412
24132000-04-28 Love <lha@s3.kth.se>
2414
2415 * prefix.h (struct prefix): Add padding.
2416
24172000-04-28 Kunihiro Ishiguro <kunihiro@zebra.org>
2418
2419 * command.c (show_version): Update copyright year.
2420
24212000-04-27 Kunihiro Ishiguro <kunihiro@zebra.org>
2422
2423 * routemap.c (route_map_apply): When map is NULL, return deny.
2424
24252000-04-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2426
2427 * filter.c (access_list_apply): When access is NULL, return deny.
2428
2429 * plist.c (prefix_list_apply): When plist is NULL, return deny.
2430
24312000-04-23 Kunihiro Ishiguro <kunihiro@zebra.org>
2432
2433 * command.h (node_type ): Change RDISC_NODE to IRDP_NODE.
2434
24352000-04-18 Toshiaki Takada <takada@zebra.org>
2436
2437 * filter.[ch] (access_list_add_hook), (access_list_delete_hook):
2438 Add argument for hook function to give struct access_list *.
2439
24402000-04-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2441
2442 * plist.c (prefix_list_entry_match): In case of le nor ge is
2443 specified, exact match is performed.
2444 (prefix_list_entry_match): Add any entry matching check.
2445
24462000-04-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2447
2448 * vty.c (exec_timeout): Separate timeout setting to minutes and
2449 seconds.
2450 (no_exec_timeout): Add "no exec-timeout" command.
2451
2452 * vty.h (VTY_TIMEOUT_DEFAULT): Change default value from 300 to
2453 600.
2454
24552000-03-31 Jochen Friedrich <jochen@scram.de>
2456
2457 * smux.h (SMUX_CLOSE): The SMUX_CLOSE PDU is implicit integer, so
2458 it is a primitive encoding and not constructed.
2459
24602000-03-28 Toshiaki Takada <takada@zebra.org>
2461
2462 * memory.[ch] (enum): Add MTYPE_OSPF_EXTERNAL_INFO.
2463
24642000-03-26 Love <lha@s3.kth.se>
2465
2466 * zclient.c (zclient_read): Add nbytes size check for
2467 ZEBRA_HEADER_SIZE. Check return value of steam_read ().
2468
24692000-03-26 Rick Payne <rickp@rossfell.co.uk>
2470
2471 * routemap.c: Add flexible route-map commands such as on-match
2472 next, on-match goto N.
2473
2474 * routemap.h: Likewise
2475
24762000-03-23 Adrian Bool <aid@u.net.uk>
2477
2478 * command.c (config_log_trap): Add new command "log trap
2479 PRIORITY".
2480
24812000-03-14 Toshiaki Takada <takada@zebra.org>
2482
2483 * memory.c (struct memory_list): Add Link List and Link Node
2484 to view.
2485
2486 * memory.h (enum): Remove MTYPE_OSPF_EXTERNAL_ROUTE.
2487
24882000-01-20 Hideto Yamakawa <hideto.yamakawa@soliton.co.jp>
2489
2490 * str.c (snprintf): Fix bug of calling sprintf instead of
2491 vsprintf.
2492
24932000-01-16 Kunihiro Ishiguro <kunihiro@zebra.org>
2494
2495 * memory.h (enum): Add MTYPE_RIP_PEER.
2496
24972000-01-15 Toshiaki Takada <takada@zebra.org>
2498
2499 * memory.h (enum): Add MTYPE_OSPF_CRYPT_KEY.
2500
25012000-01-15 Kunihiro Ishiguro <kunihiro@zebra.org>
2502
2503 * command.h (node_type ): Add MASC_NODE for masc.
2504
25052000-01-09 Wang Jianliang <wangjl@soim.net>
2506
2507 * routemap.c (route_map_index_add): When route_map_index is not
2508 empty and insert new item at the head, it can cause core dump.
2509 Fix "if (index == map->head)" to "if (point == map->head).
2510 (route_map_add_set): If there is an old set command, override old
2511 set command with new one.
2512 (route_map_index_delete): Use while() instead of for for() for
2513 logical correctness.
2514
25151999-12-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2516
2517 * memory.h (enum): Add MTYPE_BGP_STATIC.
2518
25191999-12-23 Alex Zinin <zinin@amt.ru>
2520 * zebra.h, zclient.*: dynamic int up/down message
2521 support
2522
25231999-12-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2524
2525 * thread.c (thread_cancel_event): Add a function for clean up
2526 events.
2527
25281999-12-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2529
2530 * dropline.c: Delete file.
2531 dropline.h: Linewise.
2532
25331999-12-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2534
2535 * filter.c (access_list_filter_delete): Wrong pointer
2536 access->master was pointed out after access is freed. I store
2537 master value at the beginning of the function.
2538
25391999-12-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2540
2541 * vty.c (exec_timeout): Change of VTY timeout affect to current
2542 VTY connection.
2543 (vty_accept): Instead of immediate exit() return -1.
2544
25451999-12-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2546
2547 * vty.c (vty_configure_lock): Configuration lock function added.
2548 Only one VTY can use CONFI_NODE at the same time.
2549
2550 * log.c: Delete zvlog_* functions. Now zlog_* does the same
2551 thing.
2552
2553 * log.c (log_init): Function removed.
2554 (log_close): Likewise.
2555 (log_flush): Likewise.
2556 (log_open): Likewise.
2557
2558 * vty.c (terminal_monitor): Add new command.
2559 (no_terminal_monitor): Likewise.
2560
2561 * log.c (old_log): Function removed.
2562 (old_log2): Likewise.
2563 (old_log_warn): Likewise.
2564
25651999-12-04 Toshiaki Takada <takada@zebra.org>
2566
2567 * command.c (cmd_ipv6_match): New function added.
2568 (cmd_ipv6_prefix_match): Likewise.
2569
25701999-12-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2571
2572 * command.c (cmd_ipv6_match):
2573
2574 * table.c: Delete #ifdef HAVE_MBGPV4.
2575
2576 * prefix.h (struct prefix): Add safi member.
2577 (struct prefix_ipv4): Likewise.
2578 (struct prefix_ipv6): Likewise.
2579
25801999-12-04 Rumen Svobodnikov <rumen@linux.tu-varna.acad.bg>
2581
2582 * memory.c (struct mstat): Revert to support MEMORY_LOG.
2583
25841999-11-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2585
2586 * version.h: Bump up to 0.81c for testing new kernel codes.
2587
25881999-11-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2589
2590 * thread.h (struct thread): Pthread support is disabled all
2591 platform.
2592
25931999-11-21 Michael Handler <handler@sub-rosa.com>
2594
2595 * Include <limits.h> and <strings.h> under SUNOS_5.
2596
25971999-11-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2598
2599 * sockunion.c (in6addr_cmp): Enclosed by #define HAVE_IPV6
26001999-11-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2601
2602 * command.h (node_type ): Add BGP_IPV4_NODE and BGP_IPV6_NODE.
2603
26041999-11-12 Kunihiro Ishiguro <kunihiro@zebra.org>
2605
2606 * command.c (disable): Add `disable' command.
2607
26081999-11-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2609
2610 * plist.c (vty_prefix_list_install): Add any check.
2611
26121999-11-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2613
2614 * command.h (node_type ): Add DUMP_NODE.
2615
26161999-11-03 Kunihiro Ishiguro <kunihiro@zebra.org>
2617
2618 * smux.c: Change default SMUX oid to compatible with gated.
2619
26201999-10-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2621
2622 * if_rmap.c: New file added.
2623
2624 * if_rmap.h: New file added.
2625
26261999-10-29 Alex Zinin <zinin@amt.ru>
2627
2628 * hash.c: add hash_free() function
2629
26301999-10-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2631
2632 * hash.c (hash_clean): Add clean function.
2633
2634 * plist.c (prefix_list_reset): Add reset function.
2635
2636 * filter.c (access_list_reset): Add reset function.
2637
26381999-10-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2639
2640 * client.c: Merged with zclient.c.
2641 * client.h: Merged with zclient.h.
2642
26431999-10-15 Jordan Mendelson <jordy@wserv.com>
2644
2645 * md5.c: Imported from GNU C Library.
2646 * md5-gnu.h: Likewise.
2647
26481999-10-15 Jochen Friedrich <jochen@scram.de>
2649
2650 * smux.c (smux_getresp_send): SMUX_GETRSP codes improvement.
2651
26521999-10-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2653
2654 * smux.h: New file added.
2655
2656 * snmp.c: Rename to smux.c.
2657
26581999-10-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2659
2660 * command.c (cmd_execute_command_strict): Filter ambious commands.
2661 (cmd_filter_by_string): Change to return enum match_type.
2662
26631999-10-01 Toshiaki Takada <takada@zebra.org>
2664
2665 * vty.c (vty_describe_fold): New function which does VTY
2666 description line fold.
2667 * vty.c (vty_describe_command): Set description column.
2668
26691999-09-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2670
2671 * plist.c (prefix_list_init_ipv4): VTY user interface is improved.
2672
26731999-09-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2674
2675 * command.c (cmd_filter_by_string): Fix bug of CMD_IPV4 and
2676 CMD_IPV4_PREFIX check. Both return type must be exact_match.
2677
26781999-09-24 Toshiaki Takada <takada@zebra.org>
2679
2680 * command.c (cmd_filter_by_completion),
2681 (is_cmd_ambiguous): Check IPv4 address, IPv4 prefix and range
2682 parameter matches range.
2683
26841999-09-22 Kunihiro Ishiguro <kunihiro@zebra.org>
2685
2686 * routemap.c (route_map_apply): Returm RM_DENYMATCH when no match
2687 is performed.
2688
26891999-09-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2690
2691 * vty.c (vty_read): Control-C stop VTY_MORE mode.
2692
26931999-09-20 Kunihiro Ishiguro <kunihiro@zebra.org>
2694
2695 * command.h (node_type ): Add ACCESS_IPV6_NODE and
2696 PREFIX_IPV6_NODE.
2697
2698 * distribute.h: New file added.
2699
2700 * command.h (node_type ): Delete DISTRIBUTE_NODE.
2701
27021999-09-18 Kunihiro Ishiguro <kunihiro@zebra.org>
2703
2704 * vty.c (vty_terminate_all): New function added for reload
2705 support.
2706
27071999-09-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2708
2709 * memory.h (enum): Add new type MTYPE_OSPF_EXTERNAL_ROUTE.
2710
27111999-08-31 Janos Farkas <chexum@shadow.banki.hu>
2712
2713 * vty.c (vty_read): Handle also 0x7f (alt-backspace), just like
2714 esc-ctrl-h (delete word backwards).
2715
27161999-08-24 Kunihiro Ishiguro <kunihiro@zebra.org>
2717
2718 * if.h: Add if_nametoindex for NRL.
2719
27201999-08-23 Kunihiro Ishiguro <kunihiro@zebra.org>
2721
2722 * if.c (if_create): New function.
2723
27241999-08-22 Kunihiro Ishiguro <kunihiro@zebra.org>
2725
2726 * snmp.c: New file.
2727
27281999-08-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2729
2730 * stream.c (stream_put): stream_memcpy () is changed to stream_put
2731 (). stream_get () is added.
2732
27331999-08-18 Toshiaki Takada <takada@zebra.org>
2734
2735 * memory.h (enum): Add MTYPE_OSPF_LSA_DATA.
2736
27371999-08-18 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2738
2739 * table.c (route_table_finish): add function frees table.
2740
27411999-08-12 Kunihiro Ishiguro <kunihiro@zebra.org>
2742
2743 * memory.h (enum): Add MTYPE_RTADV_PREFIX.
2744
27451999-08-11 Kunihiro Ishiguro <kunihiro@zebra.org>
2746
2747 * if.h (struct interface ): hw_address, hw_address_len added.
2748
27491999-08-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2750
2751 * if.h (struct interface ): Change structure member if_data to
2752 info, index to ifindex.
2753
27541999-08-08 Rick Payne <rickp@rossfell.co.uk>
2755
2756 * routemap.c: Multi protocol route-map modification.
2757
2758 * routemap.c (route_map_apply): Route match process bug is fixed.
2759
27601999-08-05 Kunihiro Ishiguro <kunihiro@zebra.org>
2761
2762 * thread.c (thread_fetch): When signal comes, goto retry point.
2763
27641999-08-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2765
2766 * Makefile.am: Add sockopt.c and sockopt.h
2767 * sockopt.c: New file.
2768 * sockopt.h: New file.
2769
27701999-08-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2771
2772 * version.h (ZEBRA_VERSION): Release zebra-0.75
2773
27741999-08-01 Kunihiro Ishiguro <kunihiro@zebra.org>
2775
2776 * memory.h (enum): Add MTYPE_RIPNG_AGGREGATE.
2777
27781999-07-31 Kunihiro Ishiguro <kunihiro@zebra.org>
2779
2780 * sockunion.h: Add sockunion_getpeername ().
2781
27821999-07-27 Kunihiro Ishiguro <kunihiro@zebra.org>
2783
2784 * version.h: Release zebra-0.74
2785
27861999-07-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2787
2788 * command.h (struct host): Delete lines from struct host. Add
2789 lines to struct vty.
2790
2791 * command.c: Delete `lines LINES'. Terminal display line settings
2792 should be done by `terminal length' command.
2793
27941999-07-24 Kunihiro Ishiguro <kunihiro@zebra.org>
2795
2796 * memory.h (enum): MTYPE_OSPF_PATH are added.
2797
27981999-07-22 Toshiaki Takada <takada@zebra.org>
2799
2800 * memory.h (enum): MTYPE_OSPF_NEXTHOP is added.
2801
28021999-07-21 Toshiaki Takada <takada@zebra.org>
2803
2804 * linklist.c (list_add_node_prev), (list_add_node_next),
2805 (list_add_list): New function added.
2806
2807 * table.c (route_table_free): New function added.
2808
28091999-07-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2810
2811 * plist.c (config_write_prefix): Set write flag when configuration
2812 is written.
2813
28141999-07-15 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2815
2816 * prefix.c : prefix_cmp() added. change apply_mask() to
2817 apply_mask_ipv4(), and new apply_mask() added.
2818
28191999-07-14 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2820
2821 * prefix.c (prefix2str): append prefixlen.
2822
28231999-07-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2824
2825 * command.c (config_terminal): Change "config terminal" to
2826 "configure terminal". Reported by Georg Hitsch
2827 <georg@atnet.at>.
2828 (config_terminal_length): `terminal length <0-512>' is added. At
2829 this moment this command is only usef for vty interface.
2830 Suggested by Georg Hitsch <georg@atnet.at>.
2831
28321999-07-12 Kunihiro Ishiguro <kunihiro@zebra.org>
2833
2834 * routemap.c (rulecmp): Add wrapper function of strcmp.
2835
28361999-07-08 Rick Payne <rickp@rossfell.co.uk>
2837
2838 * sockunion.c (inet_aton): Fix bug of inet_aton.
2839
28401999-07-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2841
2842 * version.h (ZEBRA_VERSION): Start zebra-0.73
2843
28441999-07-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2845
2846 * version.h: Bump up to 0.72.
2847
28481999-07-05 Kunihiro Ishiguro <kunihiro@zebra.org>
2849
2850 * command.c (install_default): New function for install default
2851 commands to the node.
2852
2853 * memory.h (enum): MTYPE_NEXTHOP is added.
2854
28551999-07-01 <kunihiro@zebra.org>
2856
2857 * command.c (no_banner_motd): `no banner motd' command added.
2858
28591999-06-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2860
2861 * regex.c: Update to glibc-2.1.1's posix/regex.c
2862
2863 * regex-gnu.h: Update to glibc-2.1.1's posix/regex.h
2864
2865 * prefix.h (IPV4_ADDR_SAME): Macro added.
2866 (IPV6_ADDR_SAME): Likewise.
2867
28681999-06-29 Kunihiro Ishiguro <kunihiro@zebra.org>
2869
2870 * memory.h (enum): Add MTYPE_OSPF_VERTEX
2871
2872 * version.h: Bump up to 0.71.
2873
2874 * vty.c (vty_serv_sock_addrinfo): Use addrinfo function to bind
2875 VTY socket when IPv6 is enabled.
2876
28771999-06-28 Kunihiro Ishiguro <kunihiro@zebra.org>
2878
2879 * vty.c (vty_serv_sock): Change vty_serv_sock determine which
2880 address family to bind.
2881
2882 * command.c: Add quit command.
2883
28841999-06-26 NOGUCHI kay <kay@dti.ad.jp>
2885
2886 * vty.c (vty_read_config): Fix bug of configuration file path
2887 detection.
2888
28891999-06-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2890
2891 * version.h: Bump up to 0.70.
2892
28931999-06-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2894
2895 * buffer.h (GETL): Remove GETL macro.
2896
2897 * version.h: Bump up to 0.69.
2898
28991999-06-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2900
2901 * if.c (connected_add): Commented out connected_log.
2902
29031999-06-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2904
2905 * command.h (struct cmd_element ): strvec and descvec is combined
2906 into newstrvec.
2907
2908 * command.c (desc_make): Function removed.
2909 (desc_next): Function removed.
2910
2911 * command.h (struct cmd_element ): docvec is removed from struct
2912 cmd_element.
2913
29141999-06-12 Kunihiro Ishiguro <kunihiro@zebra.org>
2915
2916 * command.c (cmd_execute_command): Remove command NULL check.
2917
2918 * command.h (struct cmd_element ): Add newstrvec entry to struct
2919 cmd_element.
2920 (DEFUN2): DEFUN2 macro is removed. DEFUN is extended to support
2921 (a|b|c) statement.
2922 (DESC): DESC macro is removed.
2923
2924 * vty.c (vty_complete_command): When return value is
2925 CMD_ERR_NO_MATCH, don't display error message.
2926
29271999-06-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2928
2929 * table.c (route_next_until): New function.
2930
2931 * version.h: Bump up to 0.68.
2932
29331999-06-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2934
2935 * vty.c (vty_close): Free vty->buf when vty is closed.
2936
2937 * memory.h (enum): Add MTYPE_COMMUNITY_ENTRY and
2938 MTYPE_COMMUNITY_LIST.
2939
2940 * vty.h (struct vty ): Change buf from static length buffer to
2941 variable length buffer.
2942
2943 * vty.c (vty_ensure): New function added.
2944
29451999-06-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2946
2947 * command.h (node_type ): Add COMMUNITY_LIST_NODE.
2948
2949 * command.c (config_enable_password): Freeing host.enable bug is
2950 fixed.
2951 (config_enable_password): Add argc count check.
2952
29531999-05-31 Kunihiro Ishiguro <kunihiro@zebra.org>
2954
2955 * version.h: Bump up to 0.67.
2956
29571999-05-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2958
2959 * command.c (zencrypt): New function for encrypt password.
2960
2961 * command.h (struct host): Add password_encrypt and
2962 enable_encrypt.
2963
29641999-05-30 Jochen Friedrich <jochen@scram.de>
2965
2966 * command.h (struct host): New member encrypt is added for
2967 encrypted password.
2968
29691999-05-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2970
2971 * vty.c: Remove all_digit_check function. Instead use all_digit.
2972
2973 * prefix.c (all_digit): New function for checking string is made
2974 from digit character.
2975
29761999-05-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2977
2978 * Makefile.am (libzebra_a_SOURCES): Add zclient.c.
2979 (noinst_HEADERS): Add zclient.h
2980
2981 * zclient.[ch]: New file for zebra client routine.
2982
2983 * memory.h (enum): Add MTYPE_ZEBRA.
2984
29851999-05-19 Kunihiro Ishiguro <kunihiro@zebra.org>
2986
2987 * version.h (ZEBRA_VERSION): Update to 0.66.
2988
29891999-05-15 Kunihiro Ishiguro <kunihiro@zebra.org>
2990
2991 * buffer.h (GETC,GETW): Macro deleted.
2992
29931999-05-15 Carlos Alberto Barcenilla <barce@frlp.utn.edu.ar>
2994
2995 * prefix.h (IPV4_NET0, IPV4_NET127): Macro added.
2996
29971999-05-15 Kunihiro Ishiguro <kunihiro@zebra.org>
2998
2999 * vty.c (service_advanced_vty): New command added.
3000 (no_service_advanced_vty): Likewise.
3001
30021999-05-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3003
3004 * vty.c (vty_auth): If advanced flag is set and enable password is
3005 not set, directly login to the ENABLE_NODE. This feature is
3006 originally designed and implemented by Stephen R. van den Berg
3007 <srb@cuci.nl>.
3008
3009 * command.h (host): Add advanced flag to struct host for advanced
3010 vty terminal interface.
3011
3012 * version.h (ZEBRA_VERSION): Update to 0.65 for next beta release.
3013
30141999-05-14 Stephen R. van den Berg <srb@cuci.nl>
3015
3016 * command.h (node_type ): Add TABLE_NODE.
3017
3018 * vty.c (vty_telnet_option): Check host.lines value.
3019
3020 * command.c (config_lines): DEFUN for 'lines LINES' command.
3021
3022 * zebra.h: Include <sys/utsname.h> for uname().
3023 (RT_TABLE_MAIN): Defined as 0 if OS does not support multiple
3024 routing table.
3025
3026 * vty.c (vty_auth): Directly login to the ENABLE_NODE when enable
3027 password is not set.
3028 (vty_prompt): Get machine's hostname when hostname is not set.
3029
30301999-05-11 James Willard <james@whispering.org>
3031
3032 * command.c (config_exit): Close connection when `exit' command is
3033 executed at ENABLE_NODE.
3034
30351999-05-10 Kunihiro Ishiguro <kunihiro@zebra.org>
3036
3037 * vty.c (vty_stop_input): `C-c' key change node to ENABLE_NODE.
3038
3039 * command.c (cmd_execute_command_strict): Matched command size
3040 check added.
3041 (cmd_make_desc_line): New function for DEFUN2.
3042
3043 * command.h (struct cmd_element ): Add descsize.
3044
30451999-05-09 Kunihiro Ishiguro <kunihiro@zebra.org>
3046
3047 * command.h (struct cmd_element ): Remame descvec to docvec.
3048 (struct cmd_element ): Add descvec for new description system.
3049
3050 * command.c (desc_make): Check cmd->descvec.
3051
30521999-05-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3053
3054 * memory.h (enum): Add MTYPE_CLUSTER, MTYPE_CLUSTER_VAL.
3055
30561999-05-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3057
3058 * version.h (ZEBRA_VERSION): Bump up to 0.64 for next beta
3059 release.
3060
30611999-05-04 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
3062
3063 * linklist.c (list_delete_all_node): bug fix.
3064 previous code loses current position when node
3065 is deleted.
3066
30671999-05-03 Kunihiro Ishiguro <kunihiro@zebra.org>
3068
3069 * command.h (DESC): Macro added.
3070 (struct cmd_element2): Delete struct cmd_element2.
3071
3072 * plist.c (prefix_list): Sequential number option check is added.
3073
30741999-05-02 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
3075
3076 * log.c (zvlog_{debug,info,notice,warn,err}): have been
3077 added. now we can log both console and file, but still
3078 need some fix about config write.
3079
30801999-05-02 Kunihiro Ishiguro <kunihiro@zebra.org>
3081
3082 * log.c (zvlog_debug): Fix yasu's change.
3083
30841999-05-01 Kunihiro Ishiguro <kunihiro@zebra.org>
3085
3086 * plist.c (prefix_list): Fix typo.
3087
30881999-04-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3089
3090 * Set version to 0.63 for first beta package.
3091
30921999-04-27 Carlos Barcenilla <barce@frlp.utn.edu.ar>
3093
3094 * prefix.c (str2prefix_ipv4): Fix prefix length check.
3095 (str2prefix_ipv6): Likewise.
3096
30971999-04-25 Kunihiro Ishiguro <kunihiro@zebra.org>
3098
3099 * memory.h (enum): Add MTPYE_PREFIX_LIST and
3100 MTYPE_PREFIX_LIST_ENTRY.
3101
3102 * command.h (node_type ): Add PREFIX_NODE.
3103
31041999-04-25 Carlos Barcenilla <barce@frlp.utn.edu.ar>
3105
3106 * command.c: ALIAS (config_write_memory_cmd) and ALIAS
3107 (copy_runningconfig_startupconfig_cmd) is added.
3108
3109 * table.c (route_node_lookup): Unused match variable deletion.
3110
31111999-04-24 Kunihiro Ishiguro <kunihiro@zebra.org>
3112
3113 * Makefile.am (libzebra_a_SOURCES): plist.c added.
3114 (noinst_HEADERS): plist.h added.
3115
3116 * plist.c, plist.h: New file added.
3117
3118 * memory.h (enum): Rename MTYPE_AS_PASN to MTYPE_AS_STR.
3119 * memory.c: Likewise.
3120
31211999-04-19 Carlos Alberto Barcenilla <barce@frlp.utn.edu.ar>
3122
3123 * command.c (show_version): `show version' command added.
3124
31251999-04-19 Kunihiro Ishiguro <kunihiro@zebra.org>
3126
3127 * prefix.c (str2prefix_ipv6): Prefix length overflow check.
3128
31291999-04-19 Carlos Alberto Barcenilla <barce@frlp.utn.edu.ar>
3130
3131 * prefix.c (str2prefix_ipv4): Prefix length overflow check.
3132
31331999-04-19 Alex Bligh <amb@gxn.net>
3134
3135 * prefix.c (sockunion2hostprefix): Function added.
3136 (sockunion2prefix): Address family was not set. Now it is set.
3137
3138 * vty.c: VTY access-class command is added.
3139
31401999-04-18 Kunihiro Ishiguro <kunihiro@zebra.org>
3141
3142 * memory.c: Change xmalloc to zmalloc. xcalloc, xrealloc, xfree,
3143 xstrdup are likewise.
3144
31451999-04-18 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
3146
3147 * thread.c: Add thread_execute for other routing daemon.
3148 OSPF tasks need to be generated by "sheduled" and "executed".
3149
31501999-04-13 Kunihiro Ishiguro <kunihiro@zebra.org>
3151
3152 * buffer.c: Rewrite buffer_write and buffer_flush related
3153 functions for fixing bugs. Reason of the problem and fix is
3154 suggested by Alex Bligh <amb@gxn.net>.
3155
31561999-04-12 Alex Bligh <amb@gxn.net>
3157
3158 * command.c (cmd_entry_function_descr): Added for variable
3159 argument help display.
3160
31611999-04-07 Kunihiro Ishiguro <kunihiro@zebra.org>
3162
3163 * regex.c, regex-gnu.h: Imported from GNU sed-3.02 distribution.
3164
31651999-03-24 Kunihiro Ishiguro <kunihiro@zebra.org>
3166
3167 * stream.c: stream_fifo_free bug is fixed.
3168
31691999-03-19 Toshiaki Takada <takada@zebra.org>
3170
3171 * stream.c (stream_strncpy): Added for getting any length bytes
3172 from stream.
3173
31741999-03-16 Kunihiro Ishiguro <kunihiro@zebra.org>
3175
3176 * version.h (ZEBRA_BUG_ADDRESS): New macro added.
3177
31781999-03-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3179
3180 * buffer.c (buffer_flush_window): If ep is same as buffer's size
3181 length and lp is overrun one octet.
3182
31831999-03-13 Kunihiro Ishiguro <kunihiro@zebra.org>
3184
3185 * vty.h: add VTY's timeout function.
3186
31871999-03-05 <kunihiro@zebra.org>
3188
3189 * command.h (node_type ): Add OSPF6_node.
3190
31911999-03-04 Kunihiro Ishiguro <kunihiro@zebra.org>
3192
3193 * zebra.h: Check HAVE_SYS_SELECT_H when include <sys/select.h>
3194
31951999-03-03 Jeroen Ruigrok/Asmodai <asmodai@wxs.nl>
3196
3197 * zebra.h: Include <net/if_var.h> if it exists.
3198
31991999-03-02 Kunihiro Ishiguro <kunihiro@zebra.org>
3200
3201 * getopt.[ch],getopt1.c: Sync with glibc-2.1.
3202
3203 * log.c (zlog): Tempolary ZLOG_STDOUT feature added.
3204
3205 * command.h: Include vector.h and vty.h
3206
32071999-02-25 Kunihiro Ishiguro <kunihiro@zebra.org>
3208
3209 * routemap.h (struct route_map_rule_cmd): Add prefix arguemnt.
3210
3211 * routemap.c (route_map_apply_index): Add prefix argument.
3212 (route_map_apply): Likewise.
3213
3214 * memory.h (enum): Add MTYPE_ROUTE_MAP_COMPILED.
3215
3216 * stream.c: Add stream_fifo related functions.
3217
32181999-02-24 Kunihiro Ishiguro <kunihiro@zebra.org>
3219
3220 * daemon.c: Return integer value. File descriptor close is added.
3221
3222 * memory.h (enum): add MTYPE_OSPF_LSA.
3223
32241999-02-23 Kunihiro Ishiguro <kunihiro@zebra.org>
3225
3226 * rsh.c: Remove empty file.
3227
32281999-02-22 <kunihiro@zebra.org>
3229
3230 * routemap.c: Add add/delete hook to route_map_master.
3231
32321999-02-19 Peter Galbavy <Peter.Galbavy@knowledge.com>
3233
3234 * str.[ch] added to supply wrappers for snprintf(), strlcat() and
3235 strlcpy on system without these.
3236
32371999-02-18 Peter Galbavy <Peter.Galbavy@knowledge.com>
3238
3239 * syslog support added
3240
32411999-02-02 Kunihiro Ishiguro <kunihiro@zebra.org>
3242
3243 * filter.c (access_list_add_hook): added for hook function management.
3244 * filter.c (access_list_delete_hook): Likewise.
3245
32461999-01-19 Kunihiro Ishiguro <kunihiro@zebra.org>
3247
3248 * stream.c: New file.
3249 * stream.h: New file.
3250 * Divide stream related fucntions from buffer.[ch] into stream.[ch].
3251
32521999-01-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3253
3254 * memory.h (enum): add MTYPE_STREAM, MTYPE_STREAM_DATA
3255
3256 * buffer.c (stream_new): Set MTYPE_STREAM to XMALLOC argument.
3257
32581998-12-23 Kunihiro Ishiguro <kunihiro@zebra.org>
3259
3260 * routemap.c: route_map_index_delete() added.
3261
32621998-12-22 Kunihiro Ishiguro <kunihiro@zebra.org>
3263
3264 * buffer.c (buffer_empty): check cp instead of sp.
3265
32661998-12-17 Kunihiro Ishiguro <kunihiro@zebra.org>
3267
3268 * radix.[ch]: Deleted.
3269
32701998-12-15 Magnus Ahltorp <map@stacken.kth.se>
3271
3272 * buffer.c: Prototype fixes.
3273 * prefix.c: Likewise.
3274 * sockunion.c: Likewise.
3275 * sockunion.h: Likewise.
3276
32771998-12-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3278
3279 * vty.c (vty_read): DELETE key works as vty_delete_char.
3280
32811998-12-13 Kunihiro Ishiguro <kunihiro@zebra.org>
3282
3283 * log.c (time_print): chane %y to %Y.
3284
32851998-12-10 Kunihiro Ishiguro <kunihiro@zebra.org>
3286
3287 * distribute.c: new file.
3288
32891998-12-09 Kunihiro Ishiguro <kunihiro@zebra.org>
3290
3291 * filter.c: Remove all of struct prefix_{ipv4,ipv6} and add
3292 complete support of IPv6 access list.
3293
3294 * command.c (config_write_element): function delete.
3295 (config_write_host): function add. password and enable password
3296 isn't printed to vty interface.
3297
32981998-12-08 Kunihiro Ishiguro <kunihiro@zebra.org>
3299
3300 * filter.c: Change prefix_ipv4 to prefix and add support of
3301 prefix_ipv6 filtering.
3302
33031998-12-07 Kunihiro Ishiguro <kunihiro@zebra.org>
3304
3305 * Makefile.am (INCLUDES): add @INCLUDES@ for Linux IPv6 inet6-apps
3306 header includes.
3307
33081998-12-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3309
3310 * log.c (log_flush): fix function name typo.
3311
33121998-12-04 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
3313
3314 * memory.h: OSPF memory type is added.
3315
33161998-11-15 Kunihiro Ishiguro <kunihiro@zebra.org>
3317
3318 * command.c (sort_node): add sort_node() for pretty printing of
3319 command on vty interface.
3320 (config_password): delete the restriction of charaster of password
3321 string.
3322
33231998-09-05 Kunihiro Ishiguro <kunihiro@debian.zebra.org>
3324
3325 * prefix.c (prefix_ipv4_any): add prefix_ipv4_any().
3326
33271998-08-25 Kunihiro Ishiguro <kunihiro@zebra.org>
3328
3329 * network.h: New file.
3330
33311998-08-24 Kunihiro Ishiguro <kunihiro@zebra.org>
3332
3333 * vty.c (vty_will_echo): function name change from vty_off_echo.
3334
33351998-08-18 Kunihiro Ishiguro <kunihiro@zebra.org>
3336
3337 * buffer.h: add PUTC,PUTW,PUTL macros.
3338
33391998-07-22 Kunihiro Ishiguro <kunihiro@zebra.org>
3340
3341 * route.[ch]: renamed to prefix.[ch]
3342
33431998-06-09 Kunihiro Ishiguro <kunihiro@zebra.org>
3344
3345 * prefix_in, prefix_in6 is replaced by prefix_ipv4, prefix_ipv6.
3346
3347 * Makefile.am: @INCLUDES@ is deleted from INCLUDES.
3348
33491998-06-07 Kunihiro Ishiguro <kunihiro@zebra.org>
3350
3351 * host.[ch]: merged with command.[ch]
3352
33531998-05-08 Kunihiro Ishiguro <kunihiro@zebra.org>
3354
3355 * Makefile.am (libzebra_a_SOURCES): add route.c to libzebra_a_SOURCES.
3356
33571998-05-07 Kunihiro Ishiguro <kunihiro@zebra.org>
3358
3359 * route.c (str2prefix): str2prefix () is gone.
3360
33611998-05-03 Kunihiro Ishiguro <kunihiro@zebra.org>
3362
3363 * vty.c (vty_read_config): change CONDIR to SYSCONFDIR.
3364
3365 * .cvsignore: add file.
3366
3367 * memory.c (xerror): add arguent `type' and `size'.
3368
3369 * socket.c: deleted.
3370
33711998-05-02 Kunihiro Ishiguro <kunihiro@zebra.org>
3372
3373 * vector.c: malloc,free,realloc -> XMALLOC,XFREE,XREALLOC.
3374 * linklist.c: same as above.
3375
33761998-04-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3377
3378 * filter.[ch]: added.
3379
33801998-04-01 Kunihiro Ishiguro <kunihiro@zebra.org>
3381
3382 * vty.c (config_who): return CMD_SUCCESS
3383
33841998-04-01 Jochen Friedrich <jochen@scram.de>
3385
3386 * table.c (route_dump_node): route_dump_node is IPv6 specific
3387 function so move #ifdef to the end of route_dump_node ().
3388
33891998-03-05 "Hannes R. Boehm" <hannes@boehm.org>
3390
3391 * if.c: DEFUN(interface_desc) added.
3392
33931998-03-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3394
3395 * if.c: separated from ripd/rip_interface.c
3396
33971998-03-04 Kunihiro Ishiguro <kunihiro@zebra.org>
3398
3399 * thread.[ch] : added.
3400
34011998-02-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3402
3403 * vty.c (vty_delete_char): fix size bug.
3404 (vty_backward_pure_word): function added.
3405 (vty_read): ESC + 'f' perform vty_forward_word.
3406 (vty_read): ESC + 'b' perform vty_backward_word.
3407
34081998-02-11 Kunihiro Ishiguro <kunihiro@zebra.org>
3409
3410 * radix.c (radix_lookup_rt): add mask check.
3411 (radix_delete_duproute): add mask check.
3412
34131998-02-10 Kunihiro Ishiguro <kunihiro@zebra.org>
3414
3415 * command.c (config_write_file): fix vty -> file_vty.
3416
34171998-02-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3418
3419 * command.c (cmd_filter_ambiguous): add complex type treatment.
3420
34211998-02-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3422
3423 * vty.c (vty_time_print): function added.
3424 (vty_complete_command): now [...] element isn't shown by completion.
3425
34261998-01-26 Kunihiro Ishiguro <kunihiro@zebra.org>
3427
3428 * command.c : change from cmd_install_node() to install_node().
3429
34301998-01-16 Kunihiro Ishiguro <kunihiro@zebra.org>
3431
3432 * route.[ch]: struct rt{} is replaced by struct prefix{}.
3433
34341998-01-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3435
3436 * command.c (cmd_execute_command): check command length.
3437
3438 * timer.c (zebra_timer_set): add zebra_timer_set.
3439
34401998-01-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3441
3442 * command.h (node_type ): add ZEBRA_NODE.
3443
3444 * command.c (config_exit): add RIP_NODE.
3445 (config_write_file): add RIP_NODE.
3446
34471998-01-04 Kunihiro Ishiguro <kunihiro@zebra.org>
3448
3449 * print_version.c (print_version): Now Copyright is 1996-1998.
3450
3451 * sockunion.c (sockunion_log): moved from ../zebra/route.c
3452
34531997-12-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3454
3455 * host.c (config_logfile): change 'log PATH' to 'logfile PATH'.
3456
3457 * sockunion.c (sockunion_sameprefix): add same prefix for
3458 sockunion.
3459
34601997-12-29 Kunihiro Ishiguro <kunihiro@zebra.org>
3461
3462 * radix.[ch] : are moved from ../zebra directroy.
3463
3464 * command.c (config_from_file): if command execution failed down
3465 level to CONFIG_NODE.
3466
3467 * host.c: config_log function which enable 'log FILENAME' command.
3468
34691997-12-23 Kunihiro Ishiguro <kunihiro@zebra.org>
3470
3471 * vty.c: add vty_transpose_chars (). Now you can use '^T' to
3472 transpose character.
3473
3474 * command.c: cmd_cmdsize add, this is useful to check incomplete
3475 command.
3476
34771997-12-07 Kunihiro Ishiguro <kunihiro@zebra.org>
3478
3479 * fd.h: add family for address family
3480
34811997-12-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3482
3483 * command.o
3484 * vty.o
3485 * host.o is moved from ../zebra
3486
34871997-08-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3488
3489 * make library directory.
3490