blob: b5a5e486cbd2692127af5a264355b7781fdd9e48 [file] [log] [blame]
Paul Jakmab51f1262006-03-30 14:09:38 +000012006-03-19 Paul Jakma <paul.jakma@sun.com>
2
3 * memtypes.c: Add MTYPE_BGP_SYNCHRONISE.
4
Paul Jakmacec0c4f2006-03-30 13:58:05 +000052006-03-16 Paul Jakma <paul.jakma@sun.com>
6
7 * Makefile.am: Fix -version-info argument.
8
Paul Jakma41be32b2006-03-30 13:53:59 +000092006-03-15 Paul Jakma <paul.jakma@sun.com>
10
11 * memory.c: (mtype_memstr) new helper function to
12 return human friendly string for a byte count.
13 (mtype_stats_alloc) new function, for users to retrieve
14 number of objects allocated.
15 (show_memory_mallinfo) New function, show mallinfo statistics
16 if available.
17 (show_memory_all_cmd) Call show_memory_mallinfo, if mallinfo
18 is available.
19 * memory.h: Export mtype_memstr and mtype_stats_alloc.
20 Provide a define for a reasonable buffer size for
21 mtype_memstr.
22
Paul Jakma924f9d32006-03-30 13:25:52 +0000232006-03-14 Paul Jakma <paul.jakma@sun.com>
24
25 * privs.c: (zprivs_caps_init) Change user IDs before lowering
26 privileges, while this seems to work on Linux, on Solaris
27 it rightfully refuses due to PRIV_PROC_SETID having been
28 dropped.
29
Paul Jakma478ccfd2006-03-06 18:18:37 +0000302006-03-06 Paul Jakma <paul.jakma@sun.com>
31
32 * if.h: export show_address_cmd, for anyone who wishes to use
33 it.
34
Paul Jakma5a54df92006-02-21 01:37:14 +0000352006-02-21 Paul Jakma <paul.jakma@sun.com>
36
37 * sockunion.c: (sockunion_{su2str,log}) Use XSTRDUP.
38 Particularly with _su2str, as that string gets XFREEd,
39 which can be annoying if run debug code in memory.c.
40
paul306d8892006-02-02 17:50:19 +0000412006-02-02 Paul Jakma <paul.jakma@sun.com>
42
43 * workqueue.h: (struct work_queue) Remove the delay field.
44 It served no purpose and just introduced bad behaviour.
45 Should be excised before its allowed to escape into 1.0.
46 This removes need for the 'flood' and runs_since_clear
47 fields.
48 * workqueue.c: (general) excise delay factor between queue
49 runs, hence the 'flood' crap too.. See above.
50
paul581a02a2006-01-19 20:22:16 +0000512006-01-19 Paul Jakma <paul.jakma@sun.com>
52
53 * stream.c: (stream_getq_from) should use POSIX uint64_t
54 not u_int64_t. Latter is neither a traditional BSD type, nor
55 a POSIX type.
56
vincenteac314c2006-01-17 23:39:04 +0000572006-01-17 Vincent Jardin <vincent.jardin@6wind.com>
58
59 * md5.c: Don't forget to keep const.
60 * regex.c: Cleanup code and remove warnings.
61
paul7d0b0c42006-01-17 17:40:45 +0000622006-01-17 Paul Jakma <paul.jakma@sun.com>
63
64 * md5.{c,h}: (md5_loop) Is better off taking a void * and doing
65 cast to byte wise type internally, avoids needs for casts
66 in users.
paul789f78a2006-01-17 17:42:03 +000067 * vty.c: (no_terminal_monitor_cmd) New ALIAS for
68 terminal_no_monitor, in the more normal negating format,
69 to be kind to my fingers.
70 (vty_init) install new ALIAS.
pauld2110862006-01-17 17:43:18 +000071 * zclient.{c,h}: (zclient_create_header) export this, seems others
72 could use it (in lieu of more complete zserv helpers).
paul7d0b0c42006-01-17 17:40:45 +000073
paulc1b98002006-01-16 01:54:02 +0000742006-01-16 Paul Jakma <paul.jakma@sun.com>
75
76 * zclient.h: Update the Zserv protocol header with a version
77 field. Define the old command field to be a 'marker', to
78 allow old Zserv and updated Zserv to be differentiated.
79 Future updates will bump the version field obviously. New
80 command field is made wider. Try to stop using the
81 'zebra_size_t' typedef in the callbacks.
82 * zclient.c: Update to read/write new format header.
83
paulc77d4542006-01-11 01:59:04 +0000842006-01-11 Paul Jakma <paul.jakma@sun.com>
85
86 * if.h: (struct interface) expand flags to 8 bytes.
87 * zclient.c: (zebra_interface_{add,state}_read) stream read of
88 interface flags now need to use stream_getq.
89 (zebra_interface_if_set_value) ditto
90
paul4b201d42006-01-10 14:35:19 +0000912006-01-10 Paul Jakma <paul.jakma@sun.com>
92
93 * stream.c: (stream_new) Allocate stream data as seperate object.
94 (stream_free) free the data.
95 (stream_resize) new function, resize stream to new size.
96 (stream_{get,put}q*) new functions to get/put quad word size
97 types.
98 * stream.h: (struct stream) make data seperate from the stream.
99 Export new stream_resize and quad-word get/put functions.
100
gdtf80a0162005-12-29 16:03:32 +00001012005-12-29 Greg Troxel <gdt@fnord.ir.bbn.com>
102
103 * vty.c (vty_hello): add cast to quiet lint (from David Young)
104
paul00c290e2005-11-26 09:21:43 +00001052005-11-26 Paul Jakma <paul.jakma@sun.com>
106
107 * buffer.c: (struct buffer_data) change gcc zero array
108 declaration to C99 incomplete array.
109 * stream.h: (struct stream) same
110
paul6e0f1b92005-11-24 12:47:17 +00001112005-11-24 Paul Jakma <paul.jakma@sun.com>
112
113 * privs.c: (zcaps2sys/solaris) remove unused variable.
114 (zprivs_state_caps/solaris) Format string missing a
115 specifier.
paulb6026072005-11-24 12:51:24 +0000116 * zebra.h: s/u_int/unsigned int/, u_int is a BSD type, defining
117 __USE_BSD on Linux pulls in further things from netinet/ip.h
118 which dont preprocess for some reason. There is no C99
119 shorthand type directly equivalent to u_int afaict, so don't
120 use it.
paul6e0f1b92005-11-24 12:47:17 +0000121
paul190880d2005-11-14 12:07:47 +00001222005-11-14 Paul Jakma <paul.jakma@sun.com>
123
paul889e9312005-11-14 14:46:35 +0000124 * (general) pass struct work-queue to callback functions.
125 * workqueue.h: (struct work_queue) move the state flag
126 variables to end.
127 Add an opaque pointer to spec, for user-data global to the
128 queue.
129 Pass reference to work_queue to all callbacks.
130 * workqueue.c: (work_queue_item_remove) pass ref to workqueue
131 to user callbacks.
132 (work_queue_run) ditto.
133
1342005-11-14 Paul Jakma <paul.jakma@sun.com>
135
paul190880d2005-11-14 12:07:47 +0000136 * (general) Add state to detect queue floods. There's no sense
137 trying to be sparing of CPU resources, if the queue is
138 flooding and using ever more memory resources. we should just
139 get on with clearing the queue.
140 The sense of delay and hold were wrong way around, fix.
141 * workqueue.h: (struct work_queue) Add status bitfield. Add
142 'flood' integer to workqueue spec. Add runs_since_clear
143 counter to workqueue.
144 * workqueue.c: (work_queue_new) set defaults for delay, hold
145 and flood.
146 (work_queue_add) initial schedule should use delay, not hold.
147 (show_work_queues) Print flood field, conserve whitespace.
148 (work_queue_unplug) use delay, not hold.
149 (work_queue_run) consecutive runs should be seperated by hold
150 time, not delay.
151 Keep track of number of consecutive runs, go into 'overdrive'
152 if queue is being flooded, we can't avoid making heavy use of
153 resources, better to use CPU than ever more RAM.
paul76367ea2005-11-14 14:05:35 +0000154 * zebra.h: [bug #231] include stdint, if its there.
paul190880d2005-11-14 12:07:47 +0000155
1562005-11-05 Paul Jakma <paul.jakma@sun.com>
pauldb29ae52005-11-12 22:36:41 +0000157
158 * routemap.c: (vty_show_route_map_entry) call action is
159 seperate from exit action, latter should still be printed
160 regardless of whether a call is specified.
161
paul34204aa2005-11-03 09:00:23 +00001622005-11-03 Paul Jakma <paul.jakma@sun.com>
163
164 * zebra.h: BSD BYTE_ORDER define isn't available everywhere,
165 define if needs be.
166 * checksum.h: new file. checksum.c exports in_cksum, provide
167 a header for it.
168 * checksum.c: (in_cksum) callers shouldn't have to know it uses
169 a u_short internally, change to void *.
170 * Makefile.am: Add checksum.h
171 * command.h: remove bogus trailling slash.
172 * md5.c: (general) Update it for the twentieth century. ANSI
173 declarations are widely supported now.. Don't include system
174 headers, only include zebra.h. Use POSIX types (the
175 alternative is to define u_int64_t in a portable way - rest
176 of Quagga needs same cleanup).
177 Make endian-conditional code be compiler conditional rather
178 than preprocessor conditional, so that breakage gets noticed
179 quicker.
180 * md5.h: POSIX types. Get rid of the odd __P() non-ANSI capable
181 compiler compatibility hack.
paul9c4f1c62005-11-03 11:04:07 +0000182 * if.c: (connected_free) use MTYPE for connected label.
paula49ad232005-11-03 13:00:54 +0000183 * memtypes.c: Add MTYPE_CONNECTED_LABEL
184 * memtypes.h: Update auto-built file.
paul34204aa2005-11-03 09:00:23 +0000185
paul02416842005-10-26 05:05:16 +00001862005-10-26 Paul Jakma <paul.jakma@sun.com>
187
188 * (general) Cleanup a some calls to XFREE,strdup, etc. to use
189 the memory.h macros.
190 * memtypes.c: Add MTYPE_IF_RMAP_NAME, MTYPE_PQUEUE,
191 MTYPE_PQUEUE_DATA and MTYPE_HOST.
192 * memtypes.h: update auto-built file.
193 * if_rmap.c: Use MTYPE_IF_RMAP_NAME.
194 * pqueue.c: Use the two MTYPE_PQUEUE mtypes for allocations.
paul05865c92005-10-26 05:49:54 +0000195 * command.c: Use MTYPE_HOST, MTYPE_STRVEC. Some other fixups,
196 including fixing some likely leaks in config_write_file.
197 * vty.c: memory macro usage fixes.
198 (vty_read_config) fix leak where relative config file is
199 specified.
paul02416842005-10-26 05:05:16 +0000200
ajs24065a32005-10-20 22:28:14 +00002012005-10-20 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
202
ajsc188c372005-10-21 02:57:41 +0000203 * sockopt.c: (setsockopt_multicast_ipv4) If IP_ADD_MEMBERSHIP
204 fails with errno equal to EADDRINUSE, then issue an info
205 message and try IP_DROP_MEMBERSHIP followed by IP_ADD_MEMBERSHIP.
206
2072005-10-20 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
208
ajs24065a32005-10-20 22:28:14 +0000209 * memory.c: (show_memory_vty) Omit zero statistics. Print separators
210 only if some non-zero stats have been printed in between.
211 (show_separator) New function to print a separator.
212 (show_memory_all) Keep track of whether a separator is needed
213 between the different memory statistics groups.
214
ajs50123222005-10-18 20:19:13 +00002152005-10-18 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
216
217 * memtypes.h: Add MTYPE_OSPF_VERTEX_PARENT (to match memtypes.c).
218
pauleb3da6d2005-10-18 04:20:33 +00002192005-10-18 Paul Jakma <paul.jakma@sun.com>
220
221 * memtypes.c: (memory_list_ospf) Add MTYPE_OSPF_VERTEX_PARENT.
222
ajsf52d13c2005-10-01 17:38:06 +00002232005-10-01 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
224
225 * zebra.h: Declare new functions zebra_route_string() and
226 zebra_route_char().
227 * log.c: (zroute_lookup,zebra_route_string,zebra_route_char) New
228 functions to map zebra route numbers to strings.
229
vincent5e4914c2005-09-29 16:34:30 +00002302005-09-29 Alain Ritoux <alain.ritoux@6wind.com>
231
232 * smux.[ch]: allow to retreive global OID (identified by <0
233 namelen).
234
paulceacedb2005-09-29 14:39:32 +00002352005-09-29 Paul Jakma <paul.jakma@sun.com>
236
237 * zebra.h: Solaris capabilities requires priv.h to be included.
238 * privs.{c,h}: Add support for Solaris Least-Privileges.
239 privs.h: Reduce some of the abstract capabilities, which do
240 not have rough equivalents on both systems. Rename the net
241 related caps to _NET, as they should have been in first
242 place.
243 (zprivs_terminate) should take the zebra_privs_t as argument so
244 that it can update change pointer.
245 Add an additional privilege state, ZPRIVS_UNKNOWN.
246 * privs.c: (various capability functions) Add
247 Solaris privileges variants.
248 (zprivs_state) Use privs.c specific generic types to
249 represent various capability/privilege related types, so that
250 each can be typedef'd as appropriate on each platform.
251 (zprivs_null_state) static added, to hold the state the null
252 method should report (should be raised by default, and
253 LOWERED if zprivs_terminate has been called)
254 (zprivs_state_null) Report back the zprivs_null_state.
255 (cap_map) Make it able to map abstract capability to multiple
256 system capabilities.
257 (zcaps2sys) Map to abstract capabilities to multiple system
258 privileges/capabilities.
259 (zprivs_init) move capability related init to seperate
260 function, zprivs_caps_init.
261 (zprivs_terminate) ditto, moved to zprivs_caps_terminate.
262 Set the change_state callback to the NULL state, so the
263 user can continue to run and use the callbacks.
264
vincentfbf5d032005-09-29 11:25:50 +00002652005-09-29 Alain Ritoux <alain.ritoux@6wind.com>
266
267 * filer.c: show protocol name in filter_show()
268 * plist.c: show protocol name in vty_show_prefix_entry()
269 * routemap.c: show protocol name in vty_show_route_map_entry()
270 * vty.c: in vty_command(), show protocol name if command unknown
271
vincentc1a03d42005-09-28 15:47:44 +00002722005-09-28 Alain Ritoux <alain.ritoux@6wind.com>
273
274 * md5-gnu.h: removed
275 * md5.h: replaces md5-gnu.h
276 * Makefile.am: use correct md5.h
277 * md5.c: import from WIDE
278
paul75b2dd02005-09-21 14:06:35 +00002792005-09-21 Paul Jakma <paul.jakma@sun.com>
280
281 * memtypes.{c,h}: Add MTYPE_AS_SEG_DATA.
282
hassoe6a4feb2005-09-19 09:53:21 +00002832005-09-19 Hasso Tepper <hasso at quagga.net>
284
285 * str.[ch]: Add strndup() from glibc.
286
pauleb820af2005-09-05 11:54:13 +00002872005-09-05 Paul Jakma <paul.jakma@sun.com>
288
289 * command.c: (install_element) be more robust. Eg, cmd_init
290 need not have been called, some applications may use other
291 library subsystems, which call install_element, without the
292 application wanting commands and hence not calling cmd_init.
293
paul1e836592005-08-22 22:39:56 +00002942005-08-22 Hugo Santos <hsantos@av.it.pt>
295
296 * command.h: (enum node_type) Add BGP_IPV6M_NODE
297 * command.c: (node_parent) Handle BGP_IPV6M_NODE node
298 (config_exit, config_end) ditto
299 * vty.c: (vty_end_config) Handle BGP_IPV6M_NODE node
300
gdt0312f0c2005-08-10 13:20:03 +00003012005-08-10 Greg Troxel <gdt@fnord.ir.bbn.com>
302
303 * getopt.h: Don't declare getopt (rather than getopt_long), since
304 quagga doesn't need it.
305 * getopt.c (getopt): Don't define getopt.
306
ajs330009f2005-07-26 14:35:37 +00003072005-07-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
ajs7907c6c2005-07-26 19:55:31 +0000308 * prefix.c: (prefix_ipv4_new, prefix_ipv6_new): Call prefix_new
309 to allocate the memory to make sure that all struct prefix pointers
310 point to objects of the same length (avoids memory overruns
311 on struct prefix assignments).
312 (prefix_ipv4_free, prefix_ipv6_free): Simply call prefix_free.
313 It is interesting to note that these functions are never actually
314 called anywhere in the code. Instead prefix_free was already
315 being called directly, despite the previous MTYPE incompatibility.
316
3172005-07-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
ajs330009f2005-07-26 14:35:37 +0000318
319 * prefix.c: (ip_masklen) While loop should test that 'pnt' pointer is
320 in range before dereferencing it.
321
paul510e2092005-06-24 01:20:25 +00003222005-06-24 Pawel Worach <pawel.worach@gmail.com>
323
324 * getopt.h: add further tests for full getopt declaration on
325 various systems.
326
paul354f3b62005-06-18 16:55:20 +00003272005-06-18 Paul Jakma <paul.jakma@sun.com>
328
329 * memtypes.h: update autobuilt file to match memtypes.c changes
330
paul200df112005-06-01 11:17:05 +00003312005-06-01 Paul Jakma <paul.jakma@sun.com>
332
333 * memtypes.c: Add MTYPE_BGP_PROCESS_QUEUE and
334 MTYPE_BGP_CLEAR_NODE_QUEUE
335
paul8176c192005-05-24 09:33:52 +00003362005-05-24 Paul Jakma <paul@dishone.st>
337
338 * memtypes.h: update this auto-built file. (maybe we should just
339 remove it, is GNU awk a terrible dependency to have?)
340
pauld5c92532005-05-23 12:33:58 +00003412005-05-23 Paul Jakma <paul@dishone.st>
342
343 * memtypes.awk: use character classes, which work correctly in
344 all LC_COLLATE environments, unlike A-Z, which doesnt work in
345 eg estonian collate order. Reported by Hasso.
pauld4f09602005-05-23 12:43:34 +0000346 * routemap.c: (rmap_onmatch_goto) fix crash if 'continue' command
347 is used, which does not supply an argv[0].
348 this is a backport candidate /iff/ the trailing ; is removed
349 from VTY_GET_INTEGER_RANGE
350 * vty.h: fix the VTY_GET macros, do {..} while(0) so they have
351 correct function like syntax in usage.
paul269d74f2005-05-23 13:42:46 +0000352 * workqueue.h: Add a WQ_QUEUE_BLOCKED item_status return code,
353 to allow a queue function to indicate the queue is not
354 ready/blocked - rather than any problem with the item at hand.
355 Add a notion of being able to 'plug' and 'unplug' a queue.
356 Add helpers to plug/unplug a queue.
357 Add a completion callback, to be called when a queue is emptied.
358 * workqueue.c: (work_queue_new) remove useless list_free.
359 (work_queue_schedule) new internal helper function to schedule
360 queue, if appropriate.
361 (work_queue_add) use work_queue_schedule
362 (show_work_queues) Print 'P' if queue is plugged.
363 (work_queue_plug) new API function, plug a queue - ie prevent it
364 from 'drained' / processed / scheduled.
365 (work_queue_unplug) unplug a queue, allowing it to be drained
366 / scheduled / processed again.
367 (work_queue_run) Add support for WQ_QUEUE_BLOCKED.
368 Add comment for RETRY_NOW case.
369 Make hysteris more aggresive in ramping up granularity, improves
370 performance significantly.
371 Add support for calling completion callback when queue is emptied,
372 possibly useful for knowing when to unplug a queue.
pauld5c92532005-05-23 12:33:58 +0000373
pauldc818072005-05-19 01:30:53 +00003742005-05-19 Paul Jakma <paul@dishone.st>
375
376 * thread.c: (thread_cancel_event) the number of pending events
377 cancelled is potentially useful information, dont throw it away,
378 pass it back to the caller.
paul2ba9a372005-05-19 01:37:50 +0000379 * sockunion.c: (sockunion_getsockname) use MTYPE_SOCKUNION, not TMP
380 (sockunion_getpeername) ditto
paule387e662005-05-19 02:13:28 +0000381 * memtypes.c: (memory_list_bgp) add MTYPE_BGP_PEER_HOST
pauldc818072005-05-19 01:30:53 +0000382
paul024a7f02005-05-15 14:25:08 +00003832005-05-15 Paul Jakma <paul@dishone.st>
384
385 * getopt.h: It's not just __GNU_LIBRARY__ which defines
386 getopt, eg __EXTENSIONS__ does too on SunOS. It still seems
387 awfully fragile though.
388 * getopt.c: include zebra.h after config.h, before including
389 getopt.h so that things at least are consistent..
390 * getopt1.c: ditto
391
paul42c98192005-05-07 02:22:51 +00003922005-05-07 Yar Tikhiy <yar@comp.chem.msu.su>
393
394 * sockopt.c: Add support for BSD style ifindex in ip_mreq.
395
paul8cc41982005-05-06 21:25:49 +00003962005-05-06 Paul Jakma <paul@dishone.st>
397
398 * (general) extern and static'ification of functions in code and
399 header.
400 Cleanup any definitions with unspecified arguments.
401 Add casts for callback assignments where the callback is defined,
402 typically, as passing void *, but the function being assigned has
403 some other pointer type defined as its argument, as gcc complains
404 about casts from void * to X* via function arguments.
405 Fix some old K&R style function argument definitions.
406 Add noreturn gcc attribute to some functions, as appropriate.
407 Add unused gcc attribute to some functions (eg ones meant to help
408 while debugging)
409 Add guard defines to headers which were missing them.
410 * command.c: (install_node) add const qualifier, still doesnt shut
411 up the warning though, because of the double pointer.
412 (cmp_node) ditto
413 * keychain.c: (key_str2time) Add GET_LONG_RANGE() macro, derived
414 fromn vty.h ones to fix some of the (long) < 0 warnings.
415 * thread.c: (various) use thread_empty
416 (cpu_record_hash_key) should cast to uintptr_t, a stdint.h type
417 * vty.h: Add VTY_GET_IPV4_ADDRESS and VTY_GET_IPV4_PREFIX so they
418 removed from ospfd/ospf_vty.h
419 * zebra.h: Move definition of ZEBRA_PORT to here, to remove
420 dependence of lib on zebra/zserv.h
421
hassoe7fe8c82005-05-06 19:33:35 +00004222005-05-06 Hasso Tepper <hasso at quagga.net>
423
424 * sockunion.c: Fix warning message.
425
paul0dab9302005-05-03 09:07:56 +00004262005-05-03 Paul Jakma <paul@dishone.st>
427
428 * stream.h: Add comment about the special zero-ing ability of
429 stream_put.
430 (stream_recvmsg, stream_write) should return ssize_t and size_t
431 respectively. Should both be extern linkage.
432 (stream_recvfrom) Stream aware wrapper around recvfrom, in style
433 of stream_read_try.
434 * stream.c: (stream_recvfrom) new function, wrapper around recvfrom.
435 (stream_recvmsg, stream_write) ssize_t and size_t return values
436
ajs3df53782005-04-27 16:29:54 +00004372005-04-27 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
438
ajs8b70d0b2005-04-28 01:31:13 +0000439 Add wall-clock timing statistics to 'show thread cpu' output.
440 * thread.h: Define struct rusage_t to contain wall-clock time
441 and cpu time. Change GETRUSAGE macro to collect both pieces
442 of data. Make appropriate changes to struct cpu_thread_history
443 to track CPU time and real time. Change proto for
444 thread_consumed_time to return real and cpu time elapsed.
445 And declare a new global variable 'struct timeval recent_time'.
446 * thread.c (struct timeval recent_time): New global timestamp variable.
447 (timeval_adjust): If timeout is negative, set to 0 (not 10
448 microseconds). And remove upper bound of 1,000,000 seconds, since
449 this does not seem to make any sense (and it breaks
450 funcname_thread_add_timer_timeval).
451 (timeval_cmp): Should return long, not int.
452 (vty_out_cpu_thread_history): Show CPU time and real time.
453 (cpu_record_hash_print): Calculate totals for CPU and real time.
454 (cpu_record_print): Change 'show thread cpu' title to show CPU and
455 real time.
456 (thread_timer_remain_second): Put current time in global recent_time.
457 (funcname_thread_add_timer_timeval): Fix assert. Replace 2-case
458 switch assignment with a ternary expression. Use global recent_time
459 variable. Fix use of timeval_adjust (previously, the value was not
460 actually being adjusted).
461 (thread_cancel): Add missing "break" statement in case
462 THREAD_BACKGROUND.
463 (thread_timer_wait): Use global recent_time value instead of calling
464 gettimeofday. And there's no need to check for negative timeouts,
465 since timeval_subtract already sets these to zero.
466 (thread_timer_process): Timers are sorted, so bail out once we
467 encounter a timer that has not yet popped. And remove some
468 extraneous asserts.
469 (thread_fetch): Do not process foreground timers before calling
470 select. Instead, add them to the ready list just after the select.
471 Also, no need to maintain a count of the number of ready threads,
472 since we don't care how many there are, just whether there's
473 one at the head of the ready list (which is easily checked).
474 Stick current time in global variable recent_time to reduce
475 the number of calls to gettimeofday. Tighten logic for
476 calculating the select timeout.
477 (thread_consumed_time): Now returns real time and puts the elapsed
478 cpu time in an additional argument.
479 (thread_should_yield): Use real (wall-clock) time to decide whether
480 to yield.
481 (thread_call): Maintain CPU and real time statistics.
482 * vty.c (vty_command): For slow commands, show real and cpu time.
483
4842005-04-27 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
485
ajs3df53782005-04-27 16:29:54 +0000486 * workqueue.c (show_work_queues): Remove unused gettimeofday call.
487
paul84369682005-04-27 12:39:27 +00004882005-04-27 Paul Jakma <paul.jakma@sun.com>
489
490 * workqueue.h: (struct work_queue_item) change retry_count to ran,
491 its a count of number item has been run.
492 * workqueue.c: (show_work_queues) Fix formating of slightly
493 bugfix: fix SIGFPE if wq->runs is 0.
494 (work_queue_run) retry logic was slightly wrong.
495 cycles.best is 0 initialy, granularity is 1, so update best
496 if cycles >= granularity, not just >.
paula7bca0f2005-04-27 12:44:54 +0000497 * memory.h: memtypes is built source, default includes points to
498 top_builddir, so we should refer to lib/memtypes.h
499
ajs07334da2005-04-26 17:14:30 +00005002005-04-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
501
502 * buffer.c (buffer_write): Comment out call to buffer_flush_available.
503 This should speed up buffering at the expense of a possible increase
504 in latency in flushing the data if inside a long-running thread.
505
paulab59ae32005-04-25 13:52:26 +00005062005-04-25 Paul Jakma <paul.jakma@sun.com>
507
paul147aff02005-04-25 16:29:10 +0000508 * workqueue.{c,h}: Helper API for setting up and running queues via
509 background threads.
510 * command.c: install the 'show workqueues' command
511 * memtypes.c: Add work queue mtypes, and a rib-queue type for
512 a zebra rib work queue.
513 * memtypes.h: Updated to match memtypes.c
paulab59ae32005-04-25 13:52:26 +0000514 * Makefile.am: Refer to source files via srcdir variable, fix
515 out-of-tree build breakage.
paul147aff02005-04-25 16:29:10 +0000516 Add new workqueue files to build.
paul2c1de2a2005-04-25 14:02:44 +0000517 * memory.c: Make the string field much wider
518 * memtypes.c: Correct the prefix list str/entry strings
paul907873a2005-04-25 14:53:46 +0000519 * thread.c: Kill unused TIMER_NO_SORT bits
paulab59ae32005-04-25 13:52:26 +0000520
ajsfb9e46b2005-04-22 14:23:34 +00005212005-04-22 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
522
523 * thread.h: Fix type for struct thread_master add_type: should be
524 unsigned char. Also, add some documentation of thread_add_background
525 args. And remove extraneous declaration of
526 show_thread_work_queues_cmd.
527
paula48b4e62005-04-22 00:43:47 +00005282005-04-22 Paul Jakma <paul.jakma@sun.com>
529
paule1e53ed2005-04-22 13:44:17 +0000530 * memory.h: Move include of memtypes.h to after the definition of
531 struct memory_list, gcc 4.0 doesn't like arrays of incomplete
532 types.
paula48b4e62005-04-22 00:43:47 +0000533 * thread.h: Add background thread type and thread_add_background
534 macro and accompanying funcname_... function.
535 export thread_should_yield, background threads can use it.
536 Lower thread yield time to 10ms, 100ms is noticeable lag and
537 a thread would only be /starting/ to finish sometime afterward.
538 * thread.c: (general) Add background thread type and schedule
539 nearly all thread types through the ready list for fairness.
540 (timeval_adjust) static qualifier missing
541 (vty_out_cpu_thread_history) add support for printout of
542 background threads
543 (show_thread_cpu) ditto.
544 (thread_master_debug) add debug of background list
545 (thread_master_create) fixup long line
546 (thread_add_unuse) add asserts for required state.
547 (thread_master_free) free background thread list
548 (funcname_thread_add_timer_timeval) make generic, able to
549 support arbitrary timer-like thread types.
550 (funcname_thread_add_timer) pass thread type to .._add_timer_timeval
551 (funcname_thread_add_timer_msec) ditto
552 (funcname_thread_add_background) Add a background thread, with an
553 optional millisecond delay factor, using .._add_timer_timeval.
554 (thread_cancel) Add background thread type.
555 Move the thread_list_delete common to all cases to bottom of
556 function, after the switch statement..
557 (thread_cancel_event) indent
558 (thread_timer_wait) Static qualifier, and make it able to cope
559 with arbitrary timer-like thread lists, so its of use to
560 background threads too.
561 (thread_process_fd) static qualifier. Again, make it take a list
562 reference rather than thread_master. Fix indentation.
563 (thread_timer_process) Check for ready timer-like threads in the
564 given list and move them on to the ready list - code originally
565 embedded in thread_fetch.
566 (thread_fetch) Schedule all threads, other than events, through
567 the ready list, to ensure fairness. Timer readying code moved to
568 thread_timer_process so it can be reused for background threads.
569 Remove the unneeded quagga_sigevent_process, as pointed out by
570 John Lin <john.ch.lin@gmail.com>.
571 (thread_should_yield) make this available.
572
ajs924b9222005-04-16 17:11:24 +00005732005-04-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
574
575 * thread.h (thread_consumed_time): Declare new function to calculate
576 elapsed microseconds.
577 * thread.c (thread_consumed_time): Must be global not static so we
578 can call it from lib/vty.c:vty_command.
579 (thread_should_yield): Surround with `#if 0' to make clear that this
580 function is not currently being used anywhere.
581 (thread_call): If CONSUMED_TIME_CHECK is defined, print a CPU HOG
582 warning message if the thread takes more than CONSUMED_TIME_CHECK
583 microseconds.
584 * vty.c (vty_command): If CONSUMED_TIME_CHECK is defined, print a CPU
585 HOG warning message if the command takes more than CONSUMED_TIME_CHECK
586 microseconds.
587
pauldc830cb2005-04-16 15:51:05 +00005882005-04-16 Paul Jakma <paul@dishone.st>
589
590 * memtypes.c: the comment about use of comments in the comments
591 headers was causing comment within comment warnings from compiler
592 * memtypes.awk: Add extensive comments on the file format for
593 memtypes.c.
594 tighten the pattern for the MTYPE matching action (suggestion from
595 Andrew) and tighten which field we try the match on.
596
paul2fd2fd52005-04-15 11:47:15 +00005972005-04-15 Paul Jakma <paul@dishone.st>
598
599 * memtypes.c: The new, unified location for memory type definitions.
600 The memtype enum and declarations for memory_lists are built from
601 this automatically and put into memtypes.h.
602 * memtypes.awk: New script to generate memtypes.h from memtypes.c
603 * memory.h: Finally, the enum can banished!
604 * memory.c: Finally, the seperate mtype memory_list definitions can
605 be banished!
606 (log_memstats) Increase width of fields
607 (show_memory_zebra_cmd) display zebra specific memory types.
608 Increase width of fields.
609 * Makefile.am: Add memtypes.{c,h}, add BUILT_SOURCES for memtypes.h
610 Add a rule to build memtypes.h using memtypes.awk.
611 Add memtypes.awk to EXTRA_DIST.
pauld45f1f12005-04-15 22:18:37 +0000612 memtypes.awk is gawk dependent, use the GAWK automake var.
613 * memtypes.h: New file, auto-generated, checked in for convenience.
paul2fd2fd52005-04-15 11:47:15 +0000614
ajs634f9ea2005-04-11 15:51:40 +00006152005-04-11 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
616
617 * zclient.h (struct zclient): Add two fields to support non-blocking
618 I/O: struct buffer *wb, and struct thread *t_write.
619 (zclient_free): Remove function.
620 (zebra_redistribute_send): Change 2nd arg from socket fd to
621 struct zclient * (needed to support non-blocking I/O and buffering).
622 (zclient_send_message): New function to send an arbitrary
623 message with non-blocking I/O.
624 * zclient.c (zclient_new): Create write buffer.
625 (zclient_free): Remove unused function.
626 (zclient_stop): Must cancel new t_write thread. Also, reset
627 all buffers: ibuf, obuf, and wb.
628 (zclient_failed): New helper function for typical error handling.
629 (zclient_flush_data): New thread to flush queued data.
630 (zclient_send_message): New function to send the message in
631 zclient->obuf to zebra using non-blocking I/O and buffering.
632 (zebra_message_send, zapi_ipv4_route, zapi_ipv6_route): Use
633 new zclient_send_message function instead of calling writen.
634 (zclient_start): Set socket non-blocking. Also, change 2nd arg
635 to zebra_redistribute_send from zclient->sock to zclient.
636 (zebra_redistribute_send): Change 2nd arg to struct zclient *.
637 Can now use zclient->obuf to assemble the message instead of
638 allocating a temporary stream. And call zclient_send_message to
639 send the message instead of writen.
640 (zclient_read): Convert to support non-blocking I/O by using
641 stream_read_try instead of deprecated stream_read.
642 (zclient_redistribute): Change 2nd arg to zebra_redistribute_send
643 from zclient->sock to zclient.
644
hasso5bb4c192005-04-09 13:27:50 +00006452005-04-09 Jeroen Simonetti <jeroens@office.netland.nl>
646
647 * routemap.c: Show description in "show route-map" output.
648
ajsd66a7b52005-04-08 16:42:03 +00006492005-04-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
650
ajs67bf16c2005-04-08 19:02:04 +0000651 * sigevent.c: On GNU_LINUX, check whether __USE_GNU is already defined.
652
6532005-04-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
654
ajs926fe8f2005-04-08 18:50:40 +0000655 * vty.c: (vty_log_fixed) Use casts to (void *) to try to eliminate
656 compiler warnings when assigning a (const char *) value to
657 struct iovec iov_base.
658
6592005-04-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
660
ajsd66a7b52005-04-08 16:42:03 +0000661 * zebra.h: If GNU_LINUX is defined, then define _GNU_SOURCE. This
662 fixes a problem where we were not getting the declaration of strnlen
663 in <string.h>.
664
hasso3a2ce6a2005-04-08 01:30:51 +00006652005-04-08 Hasso Tepper <hasso at quagga.net>
666
hasso4a8164e2005-04-08 14:20:18 +0000667 * routemap.[ch]: Added "description ..." command.
668
6692005-04-08 Hasso Tepper <hasso at quagga.net>
670
hasso3a2ce6a2005-04-08 01:30:51 +0000671 * prefix.[hc]: Pass argument to the inet6_ntoa by value making it more
672 inet_ntoa alike.
673
paul1eb8ef22005-04-07 07:30:20 +00006742005-04-07 Paul Jakma <paul.jakma@sun.com>
675
676 * linklist.h: Add usage comments.
677 Rename getdata macro to listgetdata.
678 Rename nextnode to listnextnode and fix its odd behaviour to be
679 less dangerous.
680 Make listgetdata macro assert node is not null, NULL list entries
681 should be bug condition.
682 ALL_LIST_ELEMENTS, new macro, forward-referencing macro for use
683 with for loop, Suggested by Jim Carlson of Sun.
684 Add ALL_LIST_ELEMENTS_RO for cases which obviously do not need the
685 "safety" of previous macro.
686 LISTNODE_ADD and DELETE macros renamed to ATTACH, DETACH, to
687 distinguish from the similarly named functions, and reflect their
688 effect better.
689 Add a QUAGGA_NO_DEPRECATED_INTERFACES define guarded section
690 with the old defines which were modified above,
691 for backwards compatibility - guarded to prevent Quagga using it..
692 * linklist.c: fix up for linklist.h changes.
693 * *.c: fix up for new list loop macro, try audit other loop
694 usage at same time, to some degree.
695
hasso59209902005-04-05 14:36:49 +00006962004-04-05 Hasso Tepper <hasso at quagga.net>
697
698 * lib/prefix.[hc]: inet6_ntoa utility function copied from
699 ripngd/ripngd.c (inet6_ntop).
700
paul3d1dc852005-04-05 00:45:23 +00007012004-04-05 Paul Jakma <paul@dishone.st>
702
703 * vty.c: Improve logging of failures to open vty socket(s).
704 See bugid #163.
705
ajs3cb98de2005-04-02 16:01:05 +00007062005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
707
ajs08dbfb62005-04-03 03:40:52 +0000708 * if.h: Fix comments to reflect that if_lookup_by_name and
709 if_get_by_name now require the argument strings to be NUL-terminated.
710 * if.c: (if_lookup_by_name) Compare using strcmp.
711 (if_get_by_name) Pass strlen(ifname) as 2nd arg to if_create.
712
7132005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
714
ajs018546e2005-04-02 23:05:56 +0000715 * if.c: (if_nametoindex) The man page is rather vague, but it seems
716 like the argument to if_nametoindex has an implicit maximum length
717 of IFNAMSIZ characters.
718
7192005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
720
ajsa3491982005-04-02 22:50:38 +0000721 * if.h: (if_lookup_by_name_len, if_get_by_name_len) New functions.
722 * if.c: (if_lookup_by_name_len, if_get_by_name_len) New functions.
723 (if_get_by_name) Tighten up code.
724 (interface) Use new function if_get_by_name_len.
725 * zclient.c: (zebra_interface_add_read) Use new if_get_by_name_len
726 function.
727 (zebra_interface_state_read) Use new if_lookup_by_name_len function.
728
7292005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
730
ajs851adbd2005-04-02 18:48:39 +0000731 * str.c: Replace strlcpy and strlcat with actual working versions
732 copied from rsync-2.6.2/lib/compat.c.
733
7342005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
735
ajsd2fc8892005-04-02 18:38:43 +0000736 * if.h: Remove define for IFINDEX_INTERNBASE and add define
737 IFINDEX_INTERNAL 0, since all internal (i.e. non-kernel) pseudo-
738 interfaces should have ifindex set to 0.
739 (if_new) Remove function.
740 (if_delete_retain) New function to delete an interface without
741 removing from iflist and freeing the structure.
742 (ifname2ifindex) New function.
743 * if.c: (if_new) Remove function (absorb into if_create).
744 (if_create) Replace function if_new with call to calloc.
745 Set ifp->ifindex to IFINDEX_INTERNAL. Fix off-by-one error
746 in assert to check length of interface name. Add error message
747 if interface with this name already exists.
748 (if_delete_retain) New function to delete an interface without
749 removing from iflist and freeing the structure.
750 (if_delete) Implement with help of if_delete_retain.
751 (ifindex2ifname) Reimplement using if_lookup_by_index.
752 (ifname2ifindex) New function to complement ifindex2ifname.
753 (interface) The interface command should check the name length
754 and fail with a warning message if it is too long.
755 (no_interface) Fix spelling in warning message.
756 (if_nametoindex) Reimplement using if_lookup_by_name.
757 (if_indextoname, ifaddr_ipv4_lookup) Reimplement using
758 if_lookup_by_index.
759
7602005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
761
ajs3cb98de2005-04-02 16:01:05 +0000762 * zebra.h: Should include str.h to pick up missing functions.
763 * str.h: Declare strnlen if needed.
764 * str.c: Do not include str.h since zebra.h now includes it.
765 (strnlen) New function.
766
ajsdb8eaac2005-03-16 16:13:06 +00007672005-03-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
768
769 * zebra.h: Must check whether __attribute__ should be defined before
770 including zassert.h.
771
paulb8961472005-03-14 17:35:52 +00007722005-03-14 Paul Jakma <paul.jakma@sun.com>
773
774 * command.c: (sort_node) use vector_max instead of referencing
775 (struct vector *)->max directly. Test that vector_max is > 0
776 before using it to calculate an index.
777 Fixup vector loop to make main body conditional on vector slot
778 not being empty.
779 (cmd_cmdsize) Fixup vector loop to make main body conditional on
780 vector slot not being empty.
781 (cmd_filter_by_completion) ditto
782 (cmd_filter_by_string) ditto
783 (is_cmd_ambiguous) ditto
784 (cmd_describe_command_real) Change index integers to unsigned.
785 Test that vector_max is > 0 before using it to calculate an index.
786 Return immediately with CMD_ERR_NO_MATCH if vline has no
787 active slots.
788 Fixup vector loop to make main body conditional on vector slot
789 not being empty.
790 (cmd_complete_command_real) ditto.
791 (cmd_execute_command_strict) Fixup vector loop to be conditional
792 on non-null slot.
paul909a2152005-03-14 17:41:45 +0000793 (various) Fix indentation and other whitespace.
paul55468c82005-03-14 20:19:01 +0000794 vector.h: Rename to (struct vector).max to slightly less confusing
795 active, for the number of active slots, distinct from allocated
796 or active-and-not-empty. Rename vector_max to vector_active
797 for same reason.
paulb8961472005-03-14 17:35:52 +0000798
paul9e92eea2005-03-09 13:39:26 +00007992005-03-09 Paul Jakma <paul.jakma@sun.com>
800
801 * command.c: Undo commit of sign warning fix and hidden command
802 in list_cmd. Sign warning is more subtle. list_cmd on its own
803 will be committed after.
paul4275b1d2005-03-09 13:42:23 +0000804 * command.c: (config_list_cmd) Don't list hidden or deprecated
805 commands, hiding these from tab completion is still to be done.
paul9e92eea2005-03-09 13:39:26 +0000806
paulb45da6f2005-03-08 15:16:57 +00008072005-03-08 Paul Jakma <paul.jakma@sun.com>
808
paul9c5d8562005-03-08 15:56:42 +0000809 * command.c: (banner_motd_file_cmd) use XSTRDUP/XFREE.
paul22085182005-03-08 16:00:12 +0000810 (no_banner_motd_cmd) use XFREE.
paul9c5d8562005-03-08 15:56:42 +0000811 (cmd_describe_command_real) sign compile warning fix
812 (cmd_complete_command_real) ditto.
813 (config_list_cmd) Don't list hidden or deprecated commands,
814 hiding these from tab completion is still to be done.
815 * command.h: cmd attr enum should start at 1.
paulb45da6f2005-03-08 15:16:57 +0000816 * vty.c: (vty_hello) suggestions from Andrew, read by line and
817 stub out trailling non-printable characters on each line thus
818 allowing us to specify VTY_NEWLINE to vty_out.
819
paul3b0c5d92005-03-08 10:43:43 +00008202005-03-08 Jeroen Massar <jeroen@unfix.org>
821
822 * vty.c: (vty_hello) display motd file, if set
823 * command.h: add char *motdfile to struct host
824 * command.c: (config_write_host) write out motdfile config
825 (banner_motd_file_cmd) new command, allow motd to be read from
826 file.
827 (no_banner_motd_cmd) free motdfile string, if needs be.
828 (cmd_init) init (struct host).motdfile. Add new motd file
829 commands.
830
hasso12f6ea22005-03-07 08:35:39 +00008312005-03-07 Michael Sandee <voidptr@voidptr.sboost.org>
832
833 * command.c: host.name might be NULL.
834 * vty.c: Fix fd leak.
835
ajs81fb3242005-02-24 16:02:53 +00008362005-02-24 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
837
838 * stream.c: (stream_read_try) Log a warning message if a fatal
839 I/O error occurs.
840 (stream_fifo_new) Fix prototype.
841 * stream.h: Fix prototype for stream_fifo_new (need void arg).
842
ajs9fc7ebf2005-02-23 15:12:34 +00008432005-02-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
844
ajscdb6ee92005-02-23 15:48:32 +0000845 * {vty.h,vty.c}: Remove vty_finish (duplicate of vty_reset).
846
8472005-02-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
848
ajs9fc7ebf2005-02-23 15:12:34 +0000849 * buffer.h: Make the struct buffer and struct buffer_data structures
850 private by moving them inside buffer.c. Add comments for all
851 functions. Rename buffer_write as buffer_put (to be more consistent
852 with the buffer_putc and buffer_putstr functions). Declare a new
853 buffer_write function that is used to write data to a file descriptor
854 and/or add it to the buffer queue. Remove unused function
855 buffer_flush_vty_all. Create a new enum typedef buffer_status_t
856 to be used as the return code for all buffer_flush* functions
857 and buffer_write.
858 * buffer.c: The struct buffer and struct buffer_data declarations
859 are now private to this file. In conjunction with that, remove
860 some unnecessary fields: struct buffer (alloc, unused_head,
861 unused_tail, length), struct buffer_data (prev).
862 (buffer_data_new) Removed: functionality incorporated into buffer_add.
863 (buffer_data_free) Removed: use a macro BUFFER_DATA_FREE instead.
864 (buffer_new) Use calloc instead of malloc + memset(zero).
865 Supply an appropriate default size if the specified size is 0.
866 (buffer_free) Eliminate code duplication by calling buffer_reset to
867 free the contents of the buffer (and remove unused code related
868 to unused_head).
869 (buffer_empty,buffer_putc,buffer_putstr) Aesthetic change (make more
870 compact).
871 (buffer_reset) Use macro BUFFER_DATA_FREE. No need to set
872 alloc and length to 0 (these fields have been removed).
873 (buffer_add) Fix scope to be static. Call XMALLOC directly instead
874 of calling removed buffer_data_new function. Simplify the logic
875 (since it's now a singly-linked list instead of doubly-linked).
876 (buffer_write) Renamed to buffer_put. Change to void, since return
877 code of 1 was meaningless. No need to adjust length field, since
878 it has been removed.
879 (buffer_putw,buffer_flush,buffer_flush_vty_all,buffer_flush_vty)
880 Remove unused functions.
881 (buffer_flush_all) Rewrite using buffer_flush_available to eliminate
882 a possible failure mode if IOV_MAX is less than the number of buffers
883 on the queue.
884 (buffer_flush_window) Incorporate logic from buffer_flush_vty.
885 Log an error message if there is a writev error.
886 (buffer_flush_available) Be more paranoid: check for case where
887 buffer is already empty. Use new ERRNO_IO_RETRY macro, and use
888 new enum for return codes. Simplify deletion logic (since it's
889 now a singly-linked list).
890 (buffer_write) New function for use with non-blocking I/O.
891 * vty.h: Replace the struct vty sb_buffer field with a fixed-size
892 (5-character) sb_buf field and an sb_len field, since using
893 a struct buffer was inappropriate for this task. Add some useful
894 comments about telnet window size negotiation.
895 * vty.c: Include <arpa/telnet.h> (no longer included by zebra.h).
896 Remove VTY_OBUF_SIZE (instead use buffer_new default size).
897 Make telnet_backward_char and telnet_space_char static const.
898 (vty_out) Replace buffer_write with buffer_put.
899 (vty_log_out) Check for I/O errors. If fatal, close the vty session.
900 Consolidate 3 separate writes into a single write call.
901 (vty_will_echo,vty_command,vty_next_line,vty_previous_line,
902 vty_end_config,vty_describe_fold,vty_clear_buf,vty_serv_sock_addrinfo,
903 vty_serv_sock_family,vty_serv_un,vty_use_backup_config,exec_timeout,
904 vty_config_write,vty_save_cwd) Fix scope to static.
905 (vty_new) Let buffer_new use its default buffer size.
906 (vty_write) Fix signature: 2nd arg should be const char *.
907 Replaced buffer_write with buffer_put.
908 (vty_telnet_option) Fix minor bug (window height or width greater than
909 255 was broken). Use sb_buf and sb_len instead of removed sb_buffer
910 (which was being used improperly).
911 (vty_read) On error, use ERRNO_IO_RETRY to decide whether it's fatal.
912 If the error is fatal, call buffer_reset so vty_close does not attempt
913 to flush the data. Use new sb_buf and sb_len instead of sb_buffer
914 to store the SB negotiation string.
915 (vty_flush) When vty->lines is 0, call buffer_flush_available instead
916 of buffer_flush_window. Look at the return code from buffer_flush
917 to detect I/O errors (and in that case, log an error message and
918 close the vty).
919 (vty_create) Fix scope to static. Initialize sb_len to 0 instead
920 of creating sb_buffer.
921 (vty_accept) Set socket nonblocking.
922 (vtysh_accept) Use new set_nonblocking function instead of calling
923 fcntl directly.
924 (vtysh_flush) New function called from vtysh_read (after command
925 execution) and from vtysh_write. This flushes the buffer
926 and reacts appropriately to the return code (by closing the vty
927 or scheduling further flushes).
928 (vtysh_read) Check whether error is fatal using ERRNO_IO_RETRY.
929 If not, just try again later. Otherwise, call buffer_reset before
930 calling vty_close (to avoid trying to flush the buffer in vty_close).
931 Fix logic to allow case where a command does not arrive atomically
932 in a single read call by checking for the terminating NUL char.
933 (vtysh_write) Use new vtysh_flush helper function.
934 (vty_close) No need to call buffer_empty, just call buffer_flush_all
935 in any case (it will check whether the buffer is empty).
936 Do not free sb_buffer (since it has been removed).
937 (vty_log_fixed) Use writev instead of write.
938 * zebra.h: Do not include <arpa/telnet.h>, since this is used only
939 by lib/vty.c.
940
hassoc3c07f22005-02-21 18:17:52 +00009412005-02-21 Vincenzo Eramo <eramo at infocom.ing.uniroma1.it>
942
943 * pqueue.[ch]: Introduce "update" function to meet ospf spf needs. It
944 will allow to update node when:
945 i) a node is inserted into the priority queue;
946 ii) a node position is modified in the priority queue;
947 * pqueue.h: Export trickle_down() function.
948
paul109ac962005-02-19 01:17:07 +00009492005-02-19 Paul Jakma <paul.jakma@sun.com>
950
951 * stream.c: (stream_new) fix dumb mistake.
952
ajsd7e2a812005-02-17 20:02:49 +00009532005-02-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
954
ajs53270112005-02-17 20:07:22 +0000955 * stream.c: (stream_read_try) Use new ERRNO_IO_RETRY macro.
956
9572005-02-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
958
ajsd7e2a812005-02-17 20:02:49 +0000959 * network.h: Define a new ERRNO_IO_RETRY macro to test whether an I/O
960 operation should be retried. This eliminates the need to duplicate
961 the same logic testing for EAGAIN or EINTR in multiple places.
962
ajs42218e72005-02-16 16:25:39 +00009632005-02-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
964
ajs262feb12005-02-16 20:35:47 +0000965 * stream.h: Declare new function stream_read_try suitable for use
966 with non-blocking file descriptors. Indicate that stream_read
967 and stream_read_unblock are deprecated.
968 * stream.c: (stream_read_try) New function for use with non-blocking
969 I/O.
970 (stream_recvmsg) Should return -1 if the stream is too small to
971 contain the data.
972
9732005-02-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
974
ajs42218e72005-02-16 16:25:39 +0000975 * network.c: (set_nonblocking) Should check return code from
976 fcntl(F_GETFL).
977
ajsa269d612005-02-16 00:45:37 +00009782005-02-15 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
979
980 * network.h: Declare new function set_nonblocking. Indicate that
981 readn and writen are deprecated.
982 * network.c: (set_nonblocking) New function to make a file descriptor
983 non-blocking, since it seems silly to have fcntl calls sprinkled
984 throughout the code.
985
paul1dd13d42005-02-14 23:49:09 +00009862005-02-14 Paul Jakma <paul.jakma@sun.com>
paulf2e6c422005-02-12 14:35:49 +0000987
988 * stream.h: Unsigned long updated to size_t
989 * stream.c: ditto
paul050c0132005-02-14 23:47:47 +0000990 * stream.h: Add stream_copy, stream_dup, stream_recvmsg.
991 Add comment describing struct stream abstraction, and various
992 other comments.
993 Deprecate several unsafe/ambigious macros.
994 Add STREAM_WRITEABLE and STREAM_READABLE.
995 Add (stream_getl_from) for symmetry.
996 Update stream_forward_{endp,getp} to use size_t offset.
997 Make stream data a 0 length array, rather than a seperate malloc.
998 * stream.c: Add consistency checks. Update to follow stream.h
999 changes.
1000 (stream_new) Alloc stream+data in one go.
1001 (stream_copy) new function, copy a stream.
1002 (stream_dup) new function, dup a stream.
1003 (stream_recvmsg) new function, recvmsg data into a stream.
1004 (stream_empty) no need to check getp == 0.
paulf2e6c422005-02-12 14:35:49 +00001005
paul9985f832005-02-09 15:51:56 +000010062005-02-09 Paul Jakma <paul.jakma@sun.com>
1007
1008 * stream.h: Remove putp. Update reference to putp with endp.
1009 Add stream_forward_endp, which daemons were doing manually.
1010 Rename stream_forward to stream_forward_getp.
1011 stream.c: Remove/update references to putp.
1012 introduce stream_forward_endp.
1013
ajs548e6f72005-02-08 15:57:25 +000010142005-02-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1015
1016 * zebra.h: Change macro definitions SET_FLAG and UNSET_FLAG
1017 to use compound assignment operators (aesthetic change).
1018
ajs1e221352005-02-03 16:42:40 +000010192005-02-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1020
ajsc4c7d0c2005-02-03 19:22:05 +00001021 * log.c: (zlog_signal,zlog_backtrace_sigsafe) Eliminate use of fileno()
1022 since it is not async-signal-safe.
1023 (_zlog_assert_failed) Rewrite crashlog logic more compactly.
1024 (zlog_set_file,zlog_reset_file,zlog_rotate) Update logfile_fd
1025 for use in signal handler.
1026
10272005-02-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1028
ajs1e221352005-02-03 16:42:40 +00001029 * log.c: (syslog_sigsafe) Reduce scope of syslog_fd: it is accessed
1030 inside this function only.
1031 (open_crashlog) New function to open /var/tmp/quagga.<daemon>.crashlog
1032 with flags O_WRONLY|O_CREAT|O_EXCL to save some crash info.
1033 (zlog_signal,_zlog_assert_failed) Increase logging priority from
1034 LOG_ERR to LOG_CRIT. If no file logging is configured, try to use
1035 open_crashlog to create a crash logfile.
1036 (zlog_backtrace_sigsafe) If a crashlog file descriptor is open,
1037 dump a backtrace to that file.
1038
ajs847947f2005-02-02 18:38:48 +000010392005-02-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1040
1041 * if.h: Declare if_flag_dump.
1042
ajs6a52d0d2005-01-30 18:49:28 +000010432005-01-30 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1044
1045 * daemon.c: (daemon) Replace perror with zlog_err.
1046 * vty.c: (vty_serv_un) Replace perror with zlog_err.
1047
ajs3b8b1852005-01-29 18:19:13 +000010482005-01-29 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1049
1050 * buffer.h: Fix comment on buffer_getstr to reflect that it now
1051 uses XMALLOC.
1052 * buffer.c: (buffer_getstr) Use XMALLOC(MTYPE_TMP) instead of malloc.
1053 * filter.c: (access_list_remark,ipv6_access_list_remark) Use
1054 argv_concat instead of buffer_getstr.
1055 * if.c: (interface_desc) Use argv_concat instead of buffer_getstr.
1056 * plist.c: (ip_prefix_list_description,ipv6_prefix_list_description)
1057 Use argv_concat instead of buffer_getstr.
1058
ajsf6834d42005-01-28 20:28:35 +000010592005-01-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1060
ajsafb8b602005-01-28 20:41:07 +00001061 * lib/buffer.h: Document behavior of buffer_getstr function.
1062 * lib/buffer.c: (buffer_getstr) Fix bug: must handle case where
1063 the string extends beyond the head struct buffer_data.
1064
10652005-01-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1066
ajsf6834d42005-01-28 20:28:35 +00001067 * lib/command.h: Document behavior of argv_concat function.
1068 * lib/command.c: (argv_concat) Calculate total string length first so
1069 we can call malloc just once (instead of realloc'ing to add each
1070 string element).
1071 (do_echo,config_logmsg) Allow for possible NULL return value from
1072 argv_concat.
1073
hasso13bfca72005-01-23 21:42:25 +000010742005-01-23 Hasso Tepper <hasso at quagga.net>
1075
1076 * lib/command.[ch]: Make node_parent() function nonstatic. vtyh.c will
1077 use it as well.
1078
ajs31364272005-01-18 22:18:59 +000010792005-01-18 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1080
1081 * log.h: Test for SA_SIGINFO to see whether zlog_signal takes final
1082 two args (siginfo and program_counter).
1083 * log.c: (hex_append) Include this function only if SA_SIGINFO or
1084 HAVE_GLIBC_BACKTRACE is defined.
1085 (zlog_signal) Final two args (siginfo and program_counter) now
1086 depend on whether SA_SIGINFO is defined on this platform.
1087 * sigevent.c: (program_counter) Do not include this function if
1088 SA_SIGINFO is not defined on this platform.
1089 (exit_handler,core_handler) Test for SA_SIGINFO to decide whether
1090 2nd & 3rd arguments are present and to decide how to invoke
1091 zlog_signal.
1092 (trap_default_signals) Test for SA_SIGINFO and invoke sigaction
1093 appropriately.
1094
ajs239c26f2005-01-17 15:22:28 +000010952005-01-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1096
1097 * log.h: Change prototype for zlog_backtrace_sigsafe to take additional
1098 program_counter argument.
1099 * log.c: (zlog_backtrace_sigsafe) Add additional program_counter
1100 argument. If it is non-NULL, use backtrace_symbols_fd to resolve
1101 the address.
1102 (zlog_signal) Call zlog_backtrace_sigsafe with additional
1103 program_counter argument.
1104
hasso87d683b2005-01-16 23:31:54 +000011052005-01-17 Hasso Tepper <hasso at quagga.net>
1106
1107 * command.[ch], vty.c: cmd_execute_command() function must not attempt
1108 to walk up in the node tree if called from vtysh. Different daemons
1109 might have commands with same syntax in different nodes (for example
1110 "router-id x.x.x.x" commands in zebra/ospfd/ospf6d daemons).
1111
ajscb585b62005-01-14 17:09:38 +000011122005-01-14 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1113
1114 * command.c (print_version): Do not bother even to examine host.name,
1115 since it is always NULL when this function is called from main.
1116
gdtf867d322005-01-14 15:47:33 +000011172005-01-14 Greg Troxel <gdt@fnord.ir.bbn.com>
1118
1119 * command.c (print_version): Don't print host.name if it is NULL.
1120 Fixes segfault on Solaris reported by Goetz von Escher <goetz@open.ch>
1121
ajse22f5512005-01-12 16:18:17 +000011222005-01-12 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1123
ajs40abf232005-01-12 17:27:27 +00001124 * sigevent.c: (trap_default_signals) Use the SA_SIGINFO flag to
1125 pass additional siginfo_t and ucontext_t arguments to core_handler
1126 and exit_handler.
1127 (core_handler,exit_handler) Now invoked with 3 arguments (using
1128 SA_SIGINFO). Pass additional info to zlog_signal.
1129 (program_counter) New function to find program counter in ucontext_t,
1130 needs to be enhanced to support more platforms (currently works only
1131 on Linux/x86).
1132 * log.h: Change the zlog_signal prototype to add new arguments
1133 siginfo_t * and program_counter.
1134 * log.c: (zlog_signal) Add new arguments siginfo and program_counter.
1135 Include si_addr and program counter (if non-NULL) in message.
1136 And remove #ifdef HAVE_GLIBC_BACKTRACE around hex_append, since
1137 that is now used to render the si_addr and PC pointers.
1138
11392005-01-12 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1140
ajse22f5512005-01-12 16:18:17 +00001141 * zebra.h: If not C99 and no va_copy macro available, fall back to
1142 memcpy (solves a build problem on FreeBSD 4.x).
1143
ajsb99760a2005-01-04 16:24:43 +000011442005-01-04 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1145
1146 * zebra.h: Define ZCMSG_FIRSTHDR appropriately based on whether
1147 config.h indicates HAVE_BROKEN_CMSG_FIRSTHDR (as determined
1148 by the configure test program).
1149 * sockopt.c: (getsockopt_cmsg_data) Use ZCMSG_FIRSTHDR instead
1150 of CMSG_FIRSTHDR.
1151
hassocba8a602005-01-02 18:51:01 +000011522005-01-02 Hasso Tepper <hasso at quagga.net>
1153
1154 * command.c: Revert int -> unsigned int fixes in
1155 cmd_describe_command_real() and cmd_complete_command_real(). index can
1156 be actually negative and it caused crash with "do<TAB>" in vty.
1157
gdt1d69fdf2004-12-29 18:53:30 +000011582004-12-29 Greg Troxel <gdt@poblano.ir.bbn.com>
1159
gdtd44debe2004-12-29 20:06:23 +00001160 * sockopt.c (getsockopt_ipv4_ifindex): Document calling
1161 convention. Beef up comments. Handle the case where the cmsghdr
1162 has a zero controllen, or more specifically when the wanted option
1163 is not present. This is needed for Solaris 8, and in general for
1164 any platform for which configure finds a method and it can fail.
1165 Mark some changes with XXX to be cleaned up post 0.98.
1166
ajsaf04bd72004-12-28 17:00:12 +000011672004-12-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1168
ajs1d75c8c2004-12-28 21:43:17 +00001169 * sockopt.c: (setsockopt_ipv4_ifindex) Improve error message.
1170 When neither IP_PKTINFO nor IP_RECVIF is defined, make return value
1171 deterministic (-1).
1172
11732004-12-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1174
ajsaf04bd72004-12-28 17:00:12 +00001175 * thread.c: (funcname_thread_add_timer_msec) Reduce overflow risk.
1176
paul4ba9b922004-12-21 22:34:58 +000011772004-12-21 Paul Jakma <paul.jakma@sun.com>
1178
1179 * if.h: Add more 'non-generic' IFF_ flags.
1180 * if.c: IFF_NOXMIT/IFF_VIRTUAL interfaces are 'loopback like'
paul0e43a2b2004-12-22 00:15:34 +00001181 * stream.c: Dont allocate streams with 0 sized data buffers
paul4ba9b922004-12-21 22:34:58 +00001182
ajs202d08c2004-12-17 20:50:00 +000011832004-12-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
ajs2885f722004-12-17 23:16:33 +00001184
1185 * command.c: (do_echo) Added new "echo" command, useful for
1186 watchdog pinging to make sure the daemon is responsive.
1187
11882004-12-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
ajs202d08c2004-12-17 20:50:00 +00001189
1190 * pid_output.c: (pid_output_lock) Eliminate static function, and just
1191 use the #ifdef to decide which version of the function to include.
1192 This eliminates a compilation problem with gcc4. And fix the
1193 non-fcntl version so that it actually compiles. Exit with
1194 status 1 instead of -1 on error.
1195
ajs81fc57c2004-12-15 17:41:14 +000011962004-12-15 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1197
1198 * sigevent.c: (trap_default_signals) Ignore SIGPIPE instead of exiting.
1199
ajs3378d202004-12-10 22:43:17 +000012002004-12-10 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1201
1202 * log.c: (zlog_signal,_zlog_assert_failed) Change logging level back to
1203 LOG_ERR instead of LOG_EMERG.
1204
ajsc3324c62004-12-09 17:26:31 +000012052004-12-09 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1206
1207 * log.c: (hex_append) No need to include this function if
1208 HAVE_GLIBC_BACKTRACE is not defined.
1209
ajsb9e70282004-12-08 17:14:45 +000012102004-12-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1211
1212 * prefix.c: (prefix_copy) Error message before abort should
1213 have severity LOG_ERR, not LOG_INFO.
1214 * memory.c: (mtype_log) Log level should be LOG_DEBUG, not LOG_INFO.
1215
ajs274a4a42004-12-07 15:39:31 +000012162004-12-07 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1217
ajs8ddca702004-12-07 18:53:52 +00001218 * {smux.c,zclient.c}: Change level of debug messages to LOG_DEBUG.
1219
12202004-12-07 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1221
ajs82146b82004-12-07 17:15:55 +00001222 * command.c: (config_write_host) Note that "log trap" is deprecated
1223 when writing out the config.
1224
12252004-12-07 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1226
ajs274a4a42004-12-07 15:39:31 +00001227 * log.h: Replace struct zlog flags and maskpri fields with maxlvl
1228 array to support individual logging levels for each destination.
1229 Remove the 2nd argument to openzlog since the default logging config
1230 should be standardized inside the library. Replaced the
1231 zlog_set_flag and zlog_reset_flag functions with zlog_set_level.
1232 And zlog_set_file now requires an additional log_level argument.
1233 Declare zlog_proto_names for use inside command.c in the
1234 "show logging" command. Added defines useful for command
1235 construction.
1236 * log.c: (vzlog) Decide where to send the message based on the
1237 individual logging levels configured for each destination.
1238 Remove support for ZLOG_STDERR since it was never actually used.
1239 Support record-priority for terminal monitors.
1240 (zlog_signal,zlog_backtrace_sigsafe) Support destination-specific
1241 logging levels. Remove stderr support (was never used). Added
1242 support for terminal monitor logging.
1243 (_zlog_assert_failed) Increase message severity to LOG_EMERG.
1244 (openzlog) Remove 2nd argument since default config should be
1245 standardized in library. By default, terminal monitoring
1246 is set to debug, and all other logging is disabled.
1247 (zlog_set_flag,zlog_reset_flag) Removed.
1248 (zlog_set_level) New function to replace zlog_set_flag and
1249 zlog_reset_flag. Supports destination-specific logging levels.
1250 (zlog_set_file,zlog_reset_file) Support file-specific logging level.
1251 (zlog_rotate) Log an error message if fopen fails, and support
1252 new file-specific logging level.
1253 * command.h: Change DEFUN_CMD_FUNC_DECL and DEFUN_CMD_FUNC_TEXT so that
1254 command functions will be static instead of global. Remove
1255 declarations for config_exit and config_help. Define new macros
1256 DEFUNSH_ATTR, DEFUNSH_HIDDEN, and DEFUNSH_DEPRECATED so we can
1257 have deprecated commands in vtysh. Similarly, for completeness,
1258 define macros ALIAS_SH, ALIAS_SH_HIDDEN, and ALIAS_SH_DEPRECATED.
1259 Also, fix bug in ALIAS_ATTR macro (didn't matter because it
1260 was never used).
1261 * command.c: Make many functions static instead of global.
1262 (facility_name,facility_match,level_match) New functions
1263 to support enhanced destination-specific logging levels.
1264 (config_write_host) Support new destination-specific logging levels.
1265 (config_logmsg) Added new "logmsg" command to help test logging
1266 system.
1267 (show_logging) Added "show logging" command to show the current
1268 configuration of the logging system.
1269 (config_log_stdout_level) Support explicit stdout logging level.
1270 (no_config_log_stdout) Now takes optional LEVEL arg.
1271 (config_log_monitor,config_log_monitor_level,no_config_log_monitor)
1272 New commands creating new "log monitor" commands to set terminal
1273 monitoring log level.
1274 (config_log_file_level) Support explicit file logging level.
1275 (config_log_syslog_level) Support explicit syslog logging level.
1276 (config_log_facility,no_config_log_facility) Implement new
1277 "log facility" command.
1278 (cmd_init) Add hooks for new commands: "show logging", "logmsg",
1279 "log stdout <level>", "log monitor", "log monitor <level>",
1280 "no log monitor", "log file <filename> <level>",
1281 "no log file <filename> <level>", "log syslog <level>",
1282 "log facility", and "no log facility".
1283 * vty.h: Added a "level" argument to vty_log so it can support
1284 "log record-priority". Declare new function vty_log_fixed for
1285 use in signal handlers.
1286 * vty.c: (vty_log,vty_log_out) Added a "level" argument to support
1287 "log record-priority" for vty terminal monitors.
1288 (vty_down_level) Use config_exit_cmd.func instead of calling
1289 config_exit directly (since command functions will now be static
1290 instead of global).
1291 (vty_log_fixed) New function to send terminal monitor messages
1292 from inside a signal handler.
1293
ajs887c44a2004-12-03 16:36:46 +000012942004-12-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1295
ajs5e764772004-12-03 19:03:33 +00001296 * log.h: Document appropriate use of syslog logging priorities
1297 inside quagga.
1298
12992004-12-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1300
ajs56f20692004-12-03 17:40:31 +00001301 * command.h: Remove fields log_stdout and log_syslog from struct host,
1302 since they are just trying to duplicate information in the
1303 zlog_default structure. Note that this fixes a bug since those
1304 fields were not registering any logging that was established
1305 in the initial call to openzlog (this affects only the zebra and
1306 ospf6d daemons). It is probably a bug to turn on any logging by
1307 default in the call to openzlog.
1308 * command.c: (config_write_host) Get logging info from zlog_default
1309 instead of now-removed fields host.log_stdout and host.log_syslog.
1310 (config_log_stdout,no_config_log_stdout) Do not set now-removed field
1311 host.log_stdout, since this info is recorded in zlog_default.
1312 (config_log_file) Use XSTRDUP (instead of strdup) to set host.logfile.
1313 (config_log_syslog,config_log_syslog_facility,no_config_log_syslog)
1314 Do not set now-removed field host.log_syslog, since this info is
1315 recorded in zlog_default.
1316
13172004-12-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1318
ajs887c44a2004-12-03 16:36:46 +00001319 * version.h.in: Remove declaration for pid_output_lock, this function
1320 is now static, not global.
1321 * pid_output.c: (pid_output_lock) This function should be static, not
1322 global. And remove "old umask" error message, since it was really
1323 an unimportant debug message, not an error.
1324 (pid_output) Need to declare static function pid_output_lock.
1325
ajs7d149b82004-11-28 23:00:01 +000013262004-11-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1327
1328 * log.h: Remove several unused fields from struct zlog. Add comments
1329 for other fields, and add one new field syslog_options that is
1330 used in the new syslog_sigsafe implementation.
1331 * log.c: (syslog_sigsafe) New function to send syslog messages in
1332 an async-signal safe way that can be used inside a signal handler.
1333 (syslog_connect) New function to connect to syslog daemon inside a
1334 signal handler. This function supports only systems where /dev/log
1335 is a unix datagram socket (e.g. not Solaris).
1336 (zlog_signal) Call syslog_sigsafe if syslog logging is enabled.
1337 (zlog_backtrace_sigsafe) Call syslog_sigsafe if syslog logging is
1338 enabled.
1339 (openzlog) Save syslog_options for use in syslog_sigsafe.
1340 (num_append) Fix bug: handle 0 properly.
1341 (hex_append) New function to print a u_long in hex format.
1342
hasso2557aed2004-11-28 21:16:20 +000013432004-11-28 Hasso Tepper <hasso at quagga.net>
1344
1345 * command.h: DEFUN_DEPRECATED passes attribute to DEFUN as well.
1346
ajsd1c51d72004-11-26 14:14:30 +000013472004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1348
ajs48d6c692004-11-26 20:52:59 +00001349 * log.c, log.h, memory.c: Change function name from zlog_backtrace_safe
1350 to the more self-explanatory zlog_backtrace_sigsafe.
1351
13522004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1353
ajs5b85fac2004-11-26 19:36:42 +00001354 * debug.[ch]: Remove unused files.
1355 * Makefile.am: Remove references to debug.c and debug.h
1356
13572004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1358
ajs063ee522004-11-26 18:11:14 +00001359 * log.c: (zlog_backtrace) New function to log a backtrace.
1360 (zlog_backtrace_safe) Log a backtrace in an async-signal-safe way.
1361 Unfortunately, this function does not support syslog logging yet.
1362 (zlog_signal) Move backtrace code into separate function
1363 zlog_backtrace_safe.
1364 (_zlog_assert_failed) Call zlog_backtrace before aborting.
1365 * log.h: Declare new functions zlog_backtrace and zlog_backtrace_safe.
1366 * memory.c: (zerror) Call zlog_backtrace before aborting.
1367
13682004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1369
ajsd1c51d72004-11-26 14:14:30 +00001370 * Makefile.am: Need to add zassert.h to pkginclude_HEADERS.
1371
ajse5879ca2004-11-25 16:07:53 +000013722004-11-25 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1373
ajs4cf0d0d2004-11-25 17:14:34 +00001374 * zebra.h: If not C99 and there's no va_copy macro and there is
1375 a __va_copy macro, define va_copy as __va_copy.
1376
13772004-11-25 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1378
ajse5879ca2004-11-25 16:07:53 +00001379 * pid_output.c: (pid_output_lock) Fix 2 bugs: when locking, should
1380 set l_whence to SEEK_SET, not SEEK_END. And after writing new
1381 pid to file, must ftruncate to eliminate any extraneous bytes left
1382 over from the last time a pid was written.
1383
ajscee3df12004-11-24 17:14:49 +000013842004-11-24 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1385
1386 * zassert.h: New header file to declare a quagga-specific assert macro.
1387 * log.c: (_zlog_assert_failed) New function called when assert fails
1388 to log the error and abort.
1389 * zebra.h: Include "zassert.h" instead of <assert.h>.
1390 * regex.c: Include "zassert.h" instead of <assert.h>.
1391
ajsd246bd92004-11-23 17:35:08 +000013922004-11-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1393
ajs59a06a92004-11-23 18:19:14 +00001394 * sigevent.c: (signal_init) Set up some default signal handlers
1395 so that processes will issue an error message before terminating
1396 or dumping core.
1397 (trap_default_signals) New function to set up signal handlers
1398 for various signals that may kill the process.
1399 (exit_handler) Call zlog_signal, then _exit.
1400 (core_handler) Call zlog_signal, then abort.
1401 * log.h: Declare new function zlog_signal.
1402 * log.c: (zlog_signal) New function to log information about
1403 a received signal before the process dies. Try to log a
1404 backtrace also.
1405 (quagga_signal_handler,signal_set) Should be static.
1406
14072004-11-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1408
ajsd246bd92004-11-23 17:35:08 +00001409 * log.c: (vzlog) Take a single va_list argument and use va_copy
1410 as necessary for multiple traversals.
1411 (zlog) Pass only one va_list to vzlog.
1412 (zlog_*,plog_*) Use a macro for boilerplate code; pass only one
1413 va_list to vzlog.
1414 (zlog_set_file) Remove unused 2nd argument (flags).
1415 (zlog_save_cwd,zlog_get_cwd,zlog_free_cwd) Remove unused functions.
1416 * log.h: Remove ZLOG_*_INDEX defines (no longer used).
1417 Remove unused 2nd argument from zlog_set_file prototype.
1418 Fix prototype for zlog_rotate.
1419 * command.c: (config_log_file) Remove unused 2nd arg to zlog_set_file.
1420 * vty.c: (vty_out) Fix stdarg usage to perform multiple traversals
1421 properly.
1422 (vty_log) Must use va_copy for multiple traversals of va_list arg.
1423
ajsca359762004-11-19 23:40:16 +000014242004-11-19 David Young <dyoung@pobox.com>
1425
1426 * log.c: (safe_strerror) New function: safe wrapper for strerror.
1427
ajsff29bb32004-11-19 18:29:22 +000014282004-11-19 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1429
1430 * sockopt.c: (setsockopt_so_recvbuf) Stop error message from being
1431 printed every time.
1432
ajsf858e492004-11-16 14:25:30 +000014332004-11-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1434
1435 * memory.h: Fix prototype for memory_init().
1436 * memory.c: Declare many functions and data structures static instead
1437 of global. Fix prototype for memory_init().
1438
gdt69e13252004-11-15 18:51:15 +000014392004-11-15 Greg Troxel <gdt@fnord.ir.bbn.com>
1440
1441 * sockopt.h: Avoid CMSG_ALIGN, and declare that sizes are without
1442 alignment (users should use CMSG_SPACE).
1443
1444 * zebra.h: Rationalize CMSG_SPACE compatibility defines. Warn if
1445 asumming 4-byte alignment, since this isn't safe.
1446
ajs7fa25ff2004-11-15 16:12:32 +000014472004-11-15 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1448
1449 * memory.c: (zerror) Use zlog_err instead of fprintf to stderr.
1450 Instead of exiting, log currenty memory usage and then abort.
1451 (log_memstats) New function to log memory statistics, called by
1452 zerror.
1453 (show_memory_all) Loop over new mlists array instead of calling
1454 show_memory_vty separately for each memory_list.
1455
paulb86718e2004-11-08 17:34:07 +000014562004-11-08 Paul Jakma <paul@dishone.st>
paulb35e5b42004-11-07 22:27:27 +00001457
paul2265d202004-11-08 15:43:21 +00001458 * buffer.c: Add missing include of log.h.
1459 (buffer_flush_available) written is compared against
1460 mostly against unsigned types, only for the writev do we need
1461 signed compare, so declare it as size_t and cast it to ssize_t
1462 just for the error compare when we've called writev.
1463 * buffer.h: Add comment that buffer data sizes really should be
1464 size_t.
1465
14662004-11-07 Paul Jakma <paul@dishone.st>
1467
1468 * version.h.in: add autoconf configure_input output var
paulb35e5b42004-11-07 22:27:27 +00001469
ajs49ff6d92004-11-04 19:26:16 +000014702004-11-04 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1471
ajs5a646652004-11-05 01:25:55 +00001472 * vty.h: Remove fields in struct vty that were related to VTY_CONTINUE
1473 capabilities (that were used only in bgpd/bgp_route.c and are now
1474 removed). Also remove some other fields that were not being
1475 used at all.
1476 * vty.c: (vty_execute) Do not test for obsolete status values VTY_START
1477 and VTY_CONTINUE.
1478 (vty_read) Remove calls to vty->output_func since that was part
1479 of the VTY_CONTINUE infrastructure that has been removed.
1480 (vty_flush) Remove code to support VTY_START and VTY_CONTINUE.
1481 (vty_close) Remove code to cancel vty->t_output thread, since that
1482 thread was never actually used.
1483
14842004-11-04 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1485
ajs49ff6d92004-11-04 19:26:16 +00001486 * vty.c: Vtysh connections to daemons should use buffering.
1487 (vty_out) Remove exception for vty_shell_serv, just use buffer_write.
1488 (vty_new) Increase output buffer size to 4096 rounded up to a
1489 multiple of pagesize.
1490 (vtysh_read) After command has been executed and all output buffered,
1491 call buffer_flush_available and schedule further writes if the
1492 buffers are not yet empty.
1493 (vtysh_write) New function to flush output to vtysh when the socket
1494 is writeable.
1495 (vty_event) Added new VTYSH_WRITE event for flushing buffers to vtysh
1496 clients. Also, should save read thread in vty->t_read so the
1497 thread can be cancelled in vty_close.
1498 * buffer.h: In struct buffer_data, remove unused "parent" field.
1499 Convert "unsigned char *data" to "unsigned char data[0]" to save
1500 a malloc. Declare new function buffer_flush_available that works
1501 with non-blocking sockets.
1502 * buffer.c: (buffer_data_new) Use a single malloc now that data is
1503 a variable-size array at end of structure.
1504 (buffer_data_free) Just a single free now that data is part of the
1505 structure.
1506 (buffer_write) Simplify the logic to make behavior more transparent.
1507 (buffer_flush) Decrease b->length as data is written out.
1508 (buffer_flush_vty_all) Decrease b->length as buffers are freed.
1509 (buffer_flush_vty) Decrease b->length as data is written out.
1510 (buffer_flush_available) New function to flush non-blocking sockets.
1511
paule064d6d2004-11-01 08:59:21 +000015122004-11-01 Paul Jakma <paul@dishone.st>
1513
1514 * sockopt.c: (setsockopt_pktinfo) remove, its unused.
1515
paul75e15fe2004-10-31 02:13:09 +000015162004-10-31 Paul Jakma <paul@dishone.st>
1517
1518 * vty.c: As per Andrew's suggestions..
1519 (vty_serv_un) remove flags.
1520 (vtysh_accept) close socket if we cant set NONBLOCK. Add flags.
paul66cbbce2004-10-31 16:15:33 +00001521 * keychain.c: Convert some more strtoul users to VTY_GET_INTEGER.
paul9d11a192004-10-31 16:19:24 +00001522 * memory.h: Add MTYPE_THREAD_FUNCNAME and MTYPE_THREAD_STATS
1523 * thread.c: Update stats and funcname alloc/free to use previous
paul039b9572004-10-31 16:43:17 +00001524 specific memory type defines. Use XCALLOC and sizeof the type,
1525 not the pointer.
paul70e149e2004-10-31 16:29:50 +00001526 * smux.c: fix int to size_t compile warnings
paul75e15fe2004-10-31 02:13:09 +00001527
pauldccfb192004-10-29 08:29:36 +000015282004-10-29 Paul Jakma <paul@dishone.st>
1529
1530 * vty.c: Move setting of sock to O_NONBLOCK from vty_serv_un
1531 to vtysh_accept, where sock is the actual fd we wanted to set to
1532 O_NONBLOCK, ie the /connected/ vtysh unix socket.
1533
hasso508ec912004-10-23 14:26:49 +000015342004-10-23 Hasso Tepper <hasso at quagga.net>
1535
1536 * zclient.c: Unbreak reading interface update message. Might fix
1537 blocker bugzilla #109.
1538
paul23b9c612004-10-22 11:51:57 +000015392004-10-22 Paul Jakma <paul@dishone.st>
paul7d9c6e52004-10-22 10:54:39 +00001540
1541 * sockopt.c: (getsockopt_ipv4_ifindex) no ifindex should be 0, not
paul23b9c612004-10-22 11:51:57 +00001542 -1.
1543 (setsockopt_pktinfo) unexported
1544 * sockopt.h: Cleanup SOCKOPT_CMSG defines a bit. Add a throwaway
1545 define for SOPT_SIZE_CMSG_IFINDEX_IPV4 for systems which have
paul4ccb2c42004-10-22 22:52:33 +00001546 neither IP_RECVIF nor IP_PKTINFO (eg openbsd), thanks to Rivo
1547 Nurges for highlighting problem and fix.
paul4927cf02004-10-22 16:55:10 +00001548 Fix elif that should be an else.
paul406d6712004-10-22 12:27:44 +00001549 * command.h: Cleanup the defines a bit, add helper defines and
1550 collapse all defines to use those. Add an attribute field to
1551 cmd_element to support, eg hidden or deprecated commands, add
1552 defun defines for such. All that's left to do is add logic
1553 to command.c to check these attributes... ;)
paulaf0d97e2004-10-22 23:24:43 +00001554 * zebra.h: reserve ZEBRA_ROUTE_HSLS
paul7d9c6e52004-10-22 10:54:39 +00001555
hasso6590f2c2004-10-19 20:40:08 +000015562004-10-19 Hasso Tepper <hasso at quagga.net>
1557
1558 * version.h.in: Define copyright string QUAGGA_COPYRIGHT.
1559 * print_version.c: Remove. print_version () function moved to
1560 command.[c|h].
1561 * command.c: Use QUAGGA_COPYRIGHT.
1562 * Makefile.am: Remove useless version.c and print_version.c files.
1563
hasso3fb9cd62004-10-19 19:44:43 +000015642004-10-19 Andrew J. Schorr <aschorr@telemetry-investments.com>
1565
1566 * zclient.c: (zebra_interface_address_read) If the destination address
1567 is encoded as all zeroes, load it as a NULL pointer.
1568 * if.h: Add comment describing struct connected destination field
1569 and indicating that it may be NULL. Define macros
1570 CONNECTED_DEST_HOST and CONNECTED_POINTOPOINT_HOST to help
1571 with PtP logic (distinguish between host and subnet addressing).
1572 * if.c: (if_lookup_address) Fix PtP logic to handle subnet addressing
1573 properly,
1574 (connected_lookup_address) ditto.
1575 (connected_add_by_prefix) Handle case where destination is NULL,
1576 * prefix.[c|h]: New functions ipv4_network_addr and
1577 ipv4_broadcast_addr.
1578
hassoddd85ed2004-10-13 08:18:07 +000015792004-10-13 Hasso Tepper <hasso at quagga.net>
1580
1581 * command.c: Make CMD_ERR_NOTHING_TODO nonfatal if reading
1582 configuration from file. Fixes critical bugzilla #113.
hassoc75105a2004-10-13 10:33:26 +00001583 * smux.c, smux.h: Remove all defaults to initialize smux connection to
1584 snmpd by default even if not configured to do so. "smux peer OID
1585 <password>" initializes now connection and "no smux peer" terminates
1586 it.
hassoddd85ed2004-10-13 08:18:07 +00001587
paul42d49862004-10-13 05:22:18 +000015882004-10-13 Paul Jakma <paul@dishone.st>
1589
1590 * (global) more const'ification.
1591 * sockunion.c: (sockunion_su2str) buffer should be sized
1592 SU_ADDRSTRLEN.
1593 (sockunion_log) do not return stack variables, strdup buf before
1594 return.
1595 * vty.h: Fix up the VTY_GET_INTEGER macros. Testing caller supplied
1596 values against ULONG_MAX is daft, when caller probably has passed
1597 a type that can not hold ULONG_MAX. use a temporary long instead.
1598 Add VTY_GET_LONG, make VTY_GET_INTEGER_RANGE use it, make
1599 VTY_GET_INTEGER a define for VTY_GET_INTEGER_RANGE.
1600
hassoa1494112004-10-11 12:53:17 +000016012004-10-11 Hasso Tepper <hasso at quagga.net>
1602
1603 * command.h: Sync DEFUNSH with other macros.
1604 * sockunion.c, sockunion.h: More const strings.
1605
paul9076fbd2004-10-11 09:40:58 +000016062004-10-11 Paul Jakma <paul@dishone.st>
1607
1608 * thread.c: (funcname_thread_add_timer)
1609 (funcname_thread_add_timer_msec) Fix mistakes from last change.
1610 Pointed out by Liu Xin in [quagga-dev 1609].
paulc9eca012004-10-11 11:28:44 +00001611 * if.h: mtu's should be unsigned.
1612 * routemap.{c,h}: const char updates
1613 * smux.{c,h}: ditto
paul9076fbd2004-10-11 09:40:58 +00001614
paul9035efa2004-10-10 11:56:56 +000016152004-10-10 Paul Jakma <paul@dishone.st>
paul47ca2952004-10-10 08:03:18 +00001616
1617 * version.h.in: (pid_output*) add const qualifier.
paul9035efa2004-10-10 11:56:56 +00001618 * command.h: Change DEFUN func to take const char *[] rather
1619 than char **, to begin process of fixing compile warnings in lib/.
1620 Nearly all other changes in this commit follow from this change.
1621 * buffer.{c,h}: (buffer_write) pointer-arithmetic is gccism, take
1622 const void * and cast an automatic const char *p to it.
1623 (buffer_putstr) add const
1624 * command.c: (zencrypt) const qualifier
1625 (cmd_execute_command_real) ditto
1626 (cmd_execute_command_strict) ditto
1627 (config_log_file) ditto.
1628 Fix leak of getcwd() returned string.
1629 * memory.{c,h}: Add MTYPE_DISTRIBUTE_IFNAME for struct dist ifname.
1630 * distribute.{c,h}: Update with const qualifier.
1631 (distribute_free) use MTYPE_DISTRIBUTE_IFNAME
1632 (distribute_lookup) Cast to char *, note that it's ok.
1633 (distribute_hash_alloc) use MTYPE_DISTRIBUTE_IFNAME.
1634 (distribute_get) Cast to char *, note that it's ok.
1635 * filter.c: Update with const qualifier.
1636 * if.{c,h}: ditto.
1637 * if_rmap.{c,h}: ditto.
1638 (if_rmap_lookup) Cast to char *, note that it's ok.
1639 (if_rmap_get) ditto.
1640 * log.{c,h}: Update with const qualifier.
1641 * plist.{c,h}: ditto.
1642 * routemap.{c,h}: ditto.
1643 * smux.{c,h}: ditto. Fix some signed/unsigned comparisons.
1644 * sockopt.c: (getsockopt_cmsg_data) add return for error case.
1645 * vty.c: Update with const qualifier.
1646
hasso27a43a82004-10-08 06:29:12 +000016472004-10-08 Hasso Tepper <hasso at quagga.net>
1648
1649 * routemap.c, routemap.h: Make some string arguments const.
1650
paul5973ee72004-10-08 01:36:54 +000016512004-10-05 Paul Jakma <paul@dishone.st>
1652
1653 * version.h.in: print_version declaration is here, not in automake
1654 generated version.h.
1655
hassoea8e9d92004-10-07 21:32:14 +000016562004-10-08 Hasso Tepper <hasso at quagga.net>
1657
1658 * command.c, command.h: Make argument of cmd_make_strvec function
1659 const.
1660 * command.c: Make hostname commands usable in vtysh again.
1661
hasso6ad96ea2004-10-07 19:33:46 +000016622004-10-07 Hasso Tepper <hasso at quagga.net>
1663
1664 * command.c, pid_output.c, print_version.c, vty.c, vty.h: Make more
1665 strings const.
1666
hasso8c328f12004-10-05 21:01:23 +000016672004-10-05 Hasso Tepper <hasso at quagga.net>
1668
1669 * *.[c|h]: Make many strings cons and a lot of int -> unsigned int
1670 changes to fix warnings.
1671
paul96e27c92004-10-05 14:33:43 +000016722004-10-05 Paul Jakma <paul@dishone.st>
1673
1674 * sockopt.{c,h}: add sockopt_iphdrincl_swab_{htosys,systoh},
1675 functions to change byte order between system IP_HDRINCL order
1676 and host order.
paul98c91ac2004-10-05 14:57:50 +00001677 * thread.c: (funcname_thread_add_timer_timeval) new function, add
1678 timer at specified timeval.
1679 (funcname_thread_add_timer) use funcname_thread_add_timer_timeval.
1680 (funcname_thread_add_timer_msec) ditto
paul96e27c92004-10-05 14:33:43 +00001681
hassob04c6992004-10-04 19:10:31 +000016822004-10-04 Hasso Tepper <hasso at quagga.net>
1683
1684 * memory.c, memory.h: Make char * argument of strdup functions const.
1685 * prefix.c, prefix.h: Make many arguments const. Reorder stuff in
1686 header.
1687 * log.h: Make log message const in struct message.
1688 * log.c: Fix some indenting.
1689 * network.c, network.h: Make second argument of writen() const.
1690
hassoe7168df2004-10-03 20:11:32 +000016912004-10-03 Hasso Tepper <hasso at quagga.net>
1692
1693 * command.h: Introduce SERVICE_NODE for "service <...>" commands.
1694 * command.c: Don't initialize commands that don't make sense if vtysh
1695 is used.
1696 * vty.c: Make VTY_NODE appear in vtysh.
1697
hasso18a6dce2004-10-03 18:18:34 +000016982004-10-03 James R. Leu <jleu at mindspring.com>
1699
1700 * zclient.c, zclient.h: zclient functions for router id handling.
1701 * zebra.h: New message types for router id handling.
1702
paul9172ee02004-09-27 12:46:37 +000017032004-09-27 Paul Jakma <paul@dishone.st>
1704
1705 * zebra.h: Add WANT_OSPF_WRITE_FRAGMENT for ospfd
1706 to try to fragment oversized packets. Enabled only for Linux.
1707 Add HAVE_IP_HDRINCL_BSD_ORDER to define struct ip byte order,
1708 to consolidate various ad-hoc platform defines for same thing.
1709
hassoe473b032004-09-26 16:08:11 +000017102004-09-26 Hasso Tepper <hasso at quagga.net>
1711
1712 * vty.c, sockopt.c: Fix compiler warnings.
1713
hasso52dc7ee2004-09-23 19:18:23 +000017142004-09-23 Hasso Tepper <hasso at quagga.net>
1715
1716 * linklist.h: Remove list and listnode typedefs.
1717 * *.[c|h]: list -> struct list *, listnode -> struct listnode *.
1718
paul0b3acf42004-09-17 08:39:08 +000017192004-09-17 Paul Jakma <paul@dishone.st>
1720
paulb89e60c2004-09-21 15:43:13 +00001721 * sockopt.c: Add missing bracket
1722
17232004-09-17 Paul Jakma <paul@dishone.st>
1724
paul0b3acf42004-09-17 08:39:08 +00001725 * sockopt.{c,h}: Add setsockopt_so_recvbuf, for ripd and ripngd.
1726
paul33394762004-09-13 11:27:57 +000017272004-09-13 Paul Jakma <paul@dishone.st>
1728
1729 * command.c: Update the copyright string in the default motd.
1730
gdt630e4802004-08-31 17:28:41 +000017312004-08-31 David Wiggins <dwiggins@bbn.com>
1732
1733 * hash.c (hash_iterate): Save next pointer before calling
1734 procedure, so that iteration works even if the called procedure
1735 deletes the hash backet.
1736
1737 * linklist.h (listtail): new macro, not yet used.
1738
hasso34553cc2004-08-27 13:56:39 +000017392004-08-27 Hasso Tepper <hasso at quagga.net>
1740
1741 * command.c: Install "terminal length" commands only if vty is used.
1742 Vtysh will handle it itself.
1743
gdtafa43b22004-08-26 13:12:41 +000017442004-08-26 Greg Troxel <gdt@fnord.ir.bbn.com>
1745
1746 * sockopt.h: Define method-independent macro for callers of
1747 get_ifindex to use for cmsg length.
1748
paule6822762004-08-19 04:13:29 +000017492004-08-19 Paul Jakma <paul@dishone.st>
1750
paulefba6ce2004-08-25 13:47:16 +00001751 * zebra.h: add MAX and MIN defines (eg for ospf6d)
1752
17532004-08-19 Paul Jakma <paul@dishone.st>
1754
paule6822762004-08-19 04:13:29 +00001755 * sockopt.c: include sockopt.h
1756 rename some of the _pktinfo_ functions to _ifindex, where that is
1757 their purpose.
1758 (getsockopt_ipv6_pktinfo_ifindex) renamed to
1759 getsockopt_ipv6_ifindex.
1760 (setsockopt_ipv4_pktinfo) renamed to setsockopt_ipv4_ifindex
1761 (setsockopt_pktinfo) update with previous and add comment re
1762 AF_INET portability.
1763 (setsockopt_ifindex) generic ifindex function ala
1764 setsockopt_pktinfo.
1765 (getsockopt_ipv4_pktinfo_ifindex) renamed to
1766 getsockopt_ipv4_ifindex.
1767 (getsockopt_ipv4_ifindex) rejiggling to reduce repeated
1768 ifdef/elses. pktinfo case forgot to set ifindex.
1769 (getsockopt_pktinfo_ifindex) renamed to
1770 getsockopt_ifindex. update some calls to renamed functions.
1771 * sockopt.h: Update renamed exported functions
1772 Rename the CMSG_SIZE macros to IFINDEX.
1773 Guard IPv4 PKTINFO in a conditional define.
1774
paulc0618de2004-08-18 21:52:58 +000017752004-08-18 Paul Jakma <paul@dishone.st>
1776
1777 * vty.c: (vty_serv_un) set unix vty socket to nonblocking
1778 to prevent inadvertent blocking of daemons by use of
1779 vtysh. TODO: disentangle manual paging from the buffer_write
1780 path so that unix vty can use this path too and be reliable.
1781
gdt33f92322004-07-23 16:14:32 +000017822004-07-23 Greg Troxel <gdt@poblano.ir.bbn.com>
1783
1784 * sockopt.c (getsockopt_ipv4_pktinfo_ifindex): Make this compile
1785 on NetBSD, and add comments to make it less confusing. Change the
1786 sense of the SUNOS_5 test to make parallel structure between the
1787 variables and the code.
1788
paul4f7baa02004-07-23 15:11:07 +000017892004-07-23 Paul Jakma <paul@dishone.st>
1790
1791 * sockopt.h: Add SOPT_SIZE_CMSG_PKTINFO{_IPV{4,6}} define, for
1792 sizeof pktinfo as appropriate, to be used when allocating msg
1793 buffers. export setsockopt_pktinfo() and
1794 getsockopt_pktinfo_ifindex()
1795 * sockopt.c: (setsockopt_pktinfo_ifindex) new function to portably
1796 set received ifindex sock option.
1797 (getsockopt_pktinfo_ifindex) portably retrieve ifindex.
1798 (getsockopt_cmsg_data) retrieve indicated control info from
1799 message header.
1800 (getsockopt_ipv6_pktinfo_ifindex) ipv6 version of above.
1801 (setsockopt_ipv4_pktinfo) v4 version
1802 (setsockopt_pktinfo) the exported version
1803 (getsockopt_ipv4_pktinfo_ifindex) v4 specific version
1804 (getsockopt_pktinfo_ifindex) the exported version
1805
paul05c447d2004-07-22 19:14:27 +000018062004-07-14 Paul Jakma <paul@dishone.st>
1807
1808 * sigevent.c: (quagga_signal_handler) add a global caught flag, set
1809 the flags to a constant rather increment to be kinder.
1810 (quagga_sigevent_process) new function, to do core of what
1811 quagga_signal_timer did. dont block signals at all as sig->caught
1812 is volatile sig_atomic_t and should be safe to access from signal
1813 and normal contexts. The signal blocking is unneeded paranoia, but
1814 is left intact under an ifdef, should some platform require it.
1815 Check global caught flag before iterating through array.
1816 (quagga_signal_timer) nearly everything moved to
1817 quagga_sigevent_process. Left in under ifdef, in case some
1818 platform could use a regular timer check for signals.
1819 * sigevent.h: quagga_sigevent_process declaration.
1820 * thread.c: (thread_fetch) check for signals at beginning of
1821 scheduler loop, check for signals if select returns EINTR.
1822
gdtb7797132004-07-13 13:47:25 +000018232004-07-13 Greg Troxel <gdt@poblano.ir.bbn.com>
1824
1825 * sigevent.c: Don't block SIGTRAP and SIGKILL. Blocking SIGTRAP
1826 confuses gdb, at least on NetBSD 2.0_BETA, where the block
1827 succeeds.
1828
paul5510e832004-07-09 14:00:01 +000018292004-07-09 Paul Jakma <paul@dishone.st>
1830
1831 * Merge Kunihiro's 'show route-map' change and add
1832 compatibility aliases for route-map continue
paulb9790b32004-07-09 14:05:47 +00001833 * jhash.{c,h}: New files. Bob Jenkins' public domain hashing
1834 function, as implemented in linux kernel by David Miller.
paul5510e832004-07-09 14:00:01 +00001835
paulb06c14f2004-07-09 12:24:42 +000018362004-07-09 Juris Kalnins <juris@mt.lv>
1837
1838 * if.c: (if_cmp_func) fix for interface names where name is same,
1839 but one has no number, eg "devtyp" and "devtyp0".
1840
gdt87efd642004-06-30 17:36:11 +000018412004-06-30 Greg Troxel <gdt@poblano.ir.bbn.com>
1842
1843 * Makefile.am: Make libzebra shared.
1844
paul138ce752004-06-21 10:35:59 +000018452004-06-21 Paul Jakma <paul@dishone.st>
1846
1847 * ChangeLog: fix my last update config.h -> zebra.h ;)
1848 * zebra.h: Fix gcc check.
1849
paul02ff83c2004-06-11 11:27:03 +000018502004-06-11 Sowmini Varadhan <sowmini.varadhan@sun.com>
1851
1852 * filter.c: (access_list_remark_cmd) buffer_putstr doesnt need cast
1853 to u_char. (ipv6_access_list_remark_cmd) ditto.
1854 if.c: ditto
1855 * network.c: (readn/writen) pointer arg should be type u_char.
1856 * plist.c: needs to include stream.h, not declare stream functions
1857 internally.
1858 (various) Add static qualifier to internal functions.
1859 (prefix_list_type_str) extraneous breaks in switch statement.
1860 (ip_prefix_list_description_cmd) buffer_putstr doesnt need cast
1861 * stream.h: depends on plist.h and export stream_put_prefix
1862 * vty.c: (vty_<telnet option build functions>) should use
1863 unsigned char, telnet options are 0 -> 255.
1864 * zclient.c: various u_char<->char type cleanups.
1865 * zebra.h: Having to define CMSG_* can apply to more than just
1866 BSDI_NRL.
1867
paul51a87982004-06-09 10:36:05 +000018682004-06-09 Paul Jakma <paul@dishone.st>
1869
paul138ce752004-06-21 10:35:59 +00001870 * zebra.h: __attribute__ is a gcc'ism
paul51a87982004-06-09 10:36:05 +00001871
paul5228ad22004-06-04 17:58:18 +000018722004-06-04 Paul Jakma <paul@dishone.st>
1873
1874 * type mismatch fixes
1875
hasso6708fa32004-05-18 18:46:54 +000018762004-05-18 Hasso Tepper <hasso@estpak.ee>
1877
1878 * pqueue.[c|h]: Added as part of ospf6d merge from Zebra repository.
1879
paul0a589352004-05-08 11:48:26 +000018802004-05-08 Paul Jakma <paul@dishone.st>
1881
1882 * zclient.c (zapi_ipv4_route) Follow Sowmini's lead and describe
1883 message format.
1884
18852004-05-08 Sowmini Varadhan <sowmini.varadhan@sun.com>
1886
1887 * zclient.c: (zapi_ipv4_add) collapsed into zapi_ipv4_route
1888 (zapi_ipv4_delete) ditto.
1889 (zapi_ipv4_route) add/delete a route by way of cmd arg.
1890 (zapi_ipv6_add) collapsed into zapi_ipv6_route.
1891 (zapi_ipv6_delete) ditto.
1892 (zapi_ipv6_route) add/delete a route by way of cmd arg.
1893 (zebra_interface_address_delete_read) collapsed into
1894 zebra_interface_address_read.
1895 (zebra_interface_address_delete_read) ditto.
1896 (zebra_interface_address_read) read address add/delete messages
1897 by way of type argument. Describe command message format.
1898 (zebra_interface_add_read) Unconditionally read new ifmtu6 field.
1899 Describe command message format.
1900 (zebra_interface_state_read) Unconditionally read new ifmtu6 field.
1901 (zclient_redistribute_set) Collapsed into zclient_redistribute
1902 (zclient_redistribute_unset) ditto
1903 (zclient_redistribute) set/unset redistribution.
1904 (zclient_redistribute_default_set) Collapsed into
1905 zclient_redistribute_default.
1906 (zclient_redistribute_default_unset) ditto.
1907 (zclient_redistribute_default) Redistribute default set/unset.
1908 * zclient.h: delete zapi_ipv{4,6}_add, zapi_ipv{4,6}_delete. Add
1909 zapi_ipv{4,6}_route. delete zclient_redistribute_set/unset. Add
1910 zclient_redistribute. Ditto for
1911 zclient_redistribute_default_{set/unset}.
1912
paul4a7aac12004-05-08 05:00:31 +000019132004-05-08 Sowmini Varadhan <sowmini.varadhan@sun.com>
1914
1915 * if.h: Add mtu6 field to struct interface, IPv6 MTU may differ
1916 from IPv4, and Solaris treats the MTU's differently.
1917 Add connected_add_by_prefix, for use by later patch.
1918 * if.c: (connected_add_by_prefix) Add prefix to connected list.
1919 (if_flag_dump) Solaris: Dump IFF_IPv4/6 flag
1920 (if_dump) Dump mtu6 flag, for HAVE_IPV6.
paul22528292004-05-08 05:10:38 +00001921 * command.c: (sockunion_getsockname) use socklen_t for len.
1922 (sockunion_getpeername) ditto.
paul0a589352004-05-08 11:48:26 +00001923
paul31fcdd32004-04-21 11:00:43 +000019242004-04-21 Boris Kovalenko <boris@tagnet.ru>
1925
1926 * daemon.c: (daemon) fix check for error return from setsid
1927
paulc49b3062004-01-19 21:23:37 +000019282004-01-19 Paul Jakma <paul@dishone.st>
1929
1930 * sigevent.{c,h}: New files, implement event handled signals.
1931 see signal_init() in sigevent.h.
1932
jardinc32e1b52003-12-23 09:06:51 +000019332003-12-23 Vincent Jardin <jardin@6wind.com>
1934
1935 * {command.c, memory.c, vty.c, zebra.h}: Add isisd support
1936
gdt3dbf9962003-12-22 20:18:18 +000019372003-12-22 Greg Troxel <gdt@fnord.ir.bbn.com>
1938
1939 * vty.c (vty_use_backup_config): Don't free filenames before using
1940 them for unlink.
1941
paul54aba542003-08-21 20:28:24 +000019422003-08-20 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
1943
1944 * command.c: Fix <cr> display problem for command line
1945 description
1946
paule9af5c72003-05-24 11:54:31 +000019472003-05-24 Anil Madhavapeddy
1948
1949 * (sockunion.c): Incorrect bounds specified in sockunion_log()
1950
paul445f1432003-05-16 19:00:31 +000019512003-05-08 Sergiy Vyshnevetskiy <serg @ vostok.net>
1952
1953 * vty.c: -A option
1954
19552003-04-19 Hasso Tepper <hasso@estpak.ee>
1956
1957 * rip_routemap.c: sync daemon's route-map commands to have same
1958 syntax
1959
paul718e3742002-12-13 20:15:29 +000019602002-09-28 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
1961
1962 * vty.c (vty_flush): One line more on vty.
1963
19642002-09-27 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1965
1966 * vector.c (vector_lookup): Add new function.
1967
19682002-08-19 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1969
1970 * thread.c (timeval_adjust): Fix unconditional crush due to
1971 FreeBSD's select() system call timeval value check.
1972
19732002-07-07 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1974
1975 * zebra-0.93 released.
1976
19772002-06-21 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1978
1979 * if.c (ifc_pointopoint): Add ifc_pointopoint() accoding to Frank
1980 van Maarseveen's suggestion.
1981
19822002-06-18 Kunihiro Ishiguro <kunihiro@zebra.org>
1983
1984 * command.c: Change bcopy() to memcpy().
1985
19862001-12-12 Kunihiro Ishiguro <kunihiro@zebra.org>
1987
1988 * command.c (config_password): Fix host.password clear bug.
1989 Reported by Wang Jian <lark@linux.net.cn>.
1990
19912001-08-29 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1992
1993 * thread.c (thread_should_yield): New function to check thread
1994 should yeild it's execution to other thread. Suggested by: Rick
1995 Payne <rickp@ayrnetworks.com>
1996
19972001-08-20 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1998
1999 * thread.c (thread_timer_cmp): Rewrite function.
2000
2001 * hash.c: Add hash_get(). Change hash_pull() to hash_release().
2002
20032001-08-19 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
2004
2005 * zebra-0.92a released.
2006
20072001-08-15 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
2008
2009 * zebra-0.92 released.
2010
20112001-08-12 Akihiro Mizutani <mizutani@dml.com>
2012
2013 * prefix.c (netmask_str2prefix_str): Convert "1.1.0.0 255.255.0.0"
2014 string to "1.1.0.0/16".
2015
20162001-08-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2017
2018 * filter.c (access_list_lookup): access_list_lookup's first
2019 argument is changed from address family to AFI.
2020
2021 * plist.c: (prefix_list_lookup): Likewise.
2022
20232001-07-27 Akihiro Mizutani <mizutani@dml.com>
2024
2025 * plist.c: ge and le display order is changed. Old compatible
2026 rule (len <= ge-value <= le-value) is removed.
2027
20282001-07-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2029
2030 * prefix.h: Temporary fix for alignment of prefix problem.
2031
20322001-06-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2033
2034 * prefix.h (struct prefix): Remove safi and padding field.
2035 (struct prefix_ipv4): Likewise.
2036 (struct prefix_ipv6): Likewise.
2037 (struct prefix_ls): Likewise.
2038 (struct prefix_rd): Likewise.
2039
2040 * command.h (enum node_type): Preparation for BGP new config.
2041
2042 * vty.c (vty_end_config): Likewise.
2043
20442001-06-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2045
2046 * routemap.c (route_map_rule_delete): Call func_free when
2047 route-map rule is deleted.
2048
20492001-06-14 "Akihiro Mizutani" <mizutani@dml.com>
2050
2051 * routemap.c (route_map_index_lookup): Prevent to use deny and
2052 permit for same route-map sequence.
2053
20542001-04-12 Kunihiro Ishiguro <kunihiro@zebra.org>
2055
2056 * vty.c (vty_read_config): Fix warning.
2057
20582001-03-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2059
2060 * command.c (IPV6_PREFIX_STR): Add '.' and '%' for IPv6 address
2061 strings.
2062
20632001-03-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2064
2065 * zebra.h (_XPG4_2): Define _XPG4_2 and __EXTENSIONS__ for
2066 CMSG_FIRSTHDR.
2067
20682001-03-07 Michael Rozhavsky <mrozhavsky@opticalaccess.com>
2069
2070 * zebra.h (struct in_pktinfo): structure in_pktinfo declaration.
2071
20722001-02-19 Kunihiro Ishiguro <kunihiro@zebra.org>
2073
2074 * memory.c (memory_list_lib): Add MTYPE_NEXTHOP for "show memory
2075 lib" member.
2076
20772001-02-13 Matthew Grant <grantma@anathoth.gen.nz>
2078
2079 * vty.c (vty_read_config): Revert check of integrate_default when
2080 VTYSH is defined.
2081
20822001-02-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2083
2084 * vty.c (vty_read_config): Do not check integrate_default. That
2085 should be used only by vtysh.
2086
20872001-02-08 Matthew Grant <grantma@anathoth.gen.nz>
2088
2089 * vty.c (vty_serv_un): Set umask 0077.
2090 (vty_read_config): Stat for vtysh Zebra.conf, if found startup and
2091 wait for boot configuration.
2092
2093 * if.c (if_lookup_address): Make it smart implementation.
2094
2095 * sockopt.c (setsockopt_multicast_ipv4): Set up a multicast socket
2096 options for IPv4 This is here so that people only have to do their
2097 OS multicast mess in one place rather than all through zebra,
2098 ospfd, and ripd .
2099
21002001-02-04 Akihiro Mizutani <mizutani@dml.com>
2101
2102 * plist.c (vty_prefix_list_install): Even when argument is
2103 invalid, new memory is allocated. Now memory allocation is done
2104 after argument check.
2105
21062001-02-01 Kunihiro Ishiguro <kunihiro@zebra.org>
2107
2108 * zebra-0.91 is released.
2109
21102001-01-31 Akihiro Mizutani <mizutani@dml.com>
2111
2112 * vty.c (vty_login): Add vty login command.
2113
21142001-01-31 Kunihiro Ishiguro <kunihiro@zebra.org>
2115
2116 * vty.c (vty_reset): Close accept socket.
2117
21182001-01-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2119
2120 * memory.h (enum): MTYPE_ATTR_TRANSIT is added for unknown transit
2121 attribute.
2122
21232001-01-22 Kunihiro Ishiguro <kunihiro@zebra.org>
2124
2125 * zclient.c (zebra_interface_address_add_read): Fetch interface
2126 address flag.
2127 (zebra_interface_address_delete_read): Likewise.
2128
21292001-01-16 Kunihiro Ishiguro <kunihiro@zebra.org>
2130
2131 * table.c (route_node_match_ipv4): Utility function for IPv4
2132 address lookup.
2133 (route_node_match_ipv6): Utility function for IPv4 address lookup.
2134
21352001-01-15 Kunihiro Ishiguro <kunihiro@zebra.org>
2136
2137 * if.c: Delete RIP_API part until new implementation comes out.
2138
21392001-01-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2140
2141 * hash.h (struct Hash): Rename alloc to count. Change type to
2142 unsigned long.
2143
2144 * stream.c (stream_getc_from): New function.
2145 (stream_getw_from): Likewise.
2146
2147 * zebra.h (ZEBRA_FLAG_STATIC): Add new flag for persistent route.
2148
21492001-01-11 Kunihiro Ishiguro <kunihiro@zebra.org>
2150
2151 * flap.c: File is removed.
2152
2153 * flap.c: Likewise.
2154
2155 * roken.h: Likewise.
2156
2157 * buffer.c (buffer_new): Remove type option to buffer_new().
2158
21592001-01-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2160
2161 * zclient.c (zapi_ipv4_delete): Remove OLD_RIB part.
2162
21632001-01-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2164
2165 * zebra-0.90 is released.
2166
2167 * command.c: Update Copyright year.
2168
21692001-01-09 Matthew Grant <grantma@anathoth.gen.nz>
2170
2171 * if.c (if_create): Register connected_free() function for
2172 deletion.
2173 (if_delete): Free connected information when the interface is
2174 deleted.
2175 (if_lookup_by_index): Fix argument type from int to unsigned int.
2176 (connected_add): Keep list in order if old info found, essential
2177 for repeatable operation in some daemons.
2178
21792001-01-09 endo@suri.co.jp (Masahiko Endo)
2180
2181 * vty.c (vty_flush): When vty->statis is VTY_CLOSE do not add vty
2182 read thread.
2183
21842001-01-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2185
2186 * filter.c (access_list_delete): Access-list name is not freed.
2187
2188 * plist.c (prefix_list_delete): Prefix-list name is not freed.
2189
21902000-12-29 Kunihiro Ishiguro <kunihiro@zebra.org>
2191
2192 * zclient.c (zclient_start): Change to use UNIX domain
2193 socket for zebra communication.
2194
2195 * vector.c (vector_init): vector_alloc and vector_data_alloc is
2196 removed. All memory allocation count should be maintained by
2197 XMALLOC and XFREE macros.
2198
21992000-12-28 Kunihiro Ishiguro <kunihiro@zebra.org>
2200
2201 * zebra.h (ZEBRA_NEXTHOP_IFINDEX): Define ZEBRA_NEXTHOP_* values.
2202
22032000-12-27 Kunihiro Ishiguro <kunihiro@zebra.org>
2204
2205 * zebra.h (ZEBRA_ERR_RTEXIST): Make zebra error code to negative
2206 value.
2207
22082000-12-25 "Wataru Uno" <wataru@po.ntts.co.jp>
2209
2210 * vty.c (vtysh_read): Don't allocate new buffer because buffer is
2211 allocated in vty_new ().
2212
22132000-12-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2214
2215 * memory.h (enum): Add MTYPE_AS_FILTER_STR.
2216
2217 * command.c (config_write_terminal): Display "end" at the end of
2218 configuration.
2219
2220 * plist.c (vty_prefix_list_install): Use AF_INET to determine
2221 lenum length.
2222
22232000-12-13 "Wataru Uno" <wataru@po.ntts.co.jp>
2224
2225 * buffer.c (buffer_flush_vty): If IOV_MAX defined in the System,
2226 then all lines write by IOV_MAX.
2227
22282000-12-12 Michael Rozhavsky <mrozhavsky@opticalaccess.com>
2229
2230 * command.c (config_write_file): Robust method for writing
2231 configuration file and recover from backing up config file.
2232
22332000-11-29 Kunihiro Ishiguro <kunihiro@zebra.org>
2234
2235 * smux.c (smux_connect): More fail check.
2236 (smux_trap): When SMUX connection is not established, do nothing.
2237
22382000-11-28 Gleb Natapov <gleb@nbase.co.il>
2239
2240 * thread.c (thread_fetch): Execut event list first. Old event
2241 list is renamed to ready list. With this change, event thread is
2242 executed before any other thread.
2243
2244 * thread.h (struct thread_master): Add ready list.
2245
22462000-11-28 Kunihiro Ishiguro <kunihiro@zebra.org>
2247
2248 * linklist.c (listnode_add_after): Add node right after the
2249 listnode pointer.
2250
22512000-11-27 Kunihiro Ishiguro <kunihiro@zebra.org>
2252
2253 * smux.h: Pass struct variable to WriteMethod.
2254
22552000-11-25 Frank van Maarseveen <F.vanMaarseveen@inter.NL.net>
2256
2257 * if.c (if_lookup_address): When looking up interface with IP
2258 address, Sometimes multiple interfaces will match. Now PtP
2259 interfaces prevail in such a case which seem the right thing to
2260 do: There will probably also be host routes which usually prevail
2261 over network routes.
2262
22632000-11-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2264
2265 * smux.c (smux_trap): SMUX trap implementation.
2266
22672000-11-19 Akihiro Mizutani <mizutani@dml.com>
2268
2269 * plist.c: Add automatic conversion function of an old rule.
2270 ex.) 10.0.0.0/8 ge 8 -> 10.0.0.0/8 le 32
2271
22722000-11-16 Yon Uriarte <ukl2@rz.uni-karlsruhe.de>
2273
2274 * zclient.c (zebra_interface_add_read): Read hardware address when
2275 hw_addr_len is greater than 0.
2276
22772000-11-15 Akihiro Mizutani <mizutani@dml.com>
2278
2279 * plist.c: The rule of "len <= ge-value <= le-value"
2280 was changed to "len < ge-value <= le-value".
2281
22822000-11-09 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2283
2284 * memory.[ch]: Added #define and functions for ospf6d.
2285
2286 * log.[ch]: some platform says that the data of used va_list
2287 is undefined. Changed to hold list of va_list for each
2288 vsnprintf.
2289
22902000-11-07 Rick Payne <rickp@rossfell.co.uk>
2291
2292 * memory.h (enum): Add MTYPE_COMMUNITY_REGEXP.
2293
22942000-11-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2295
2296 * command.c (config_exit): Fix bug of missing break after case
2297 BGP_VPNV4_NODE.
2298
22992000-10-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2300
2301 * vector.c (vector_unset): Check i is not nevative.
2302
23032000-10-24 Arkadiusz Miskiewicz <misiek@pld.org.pl>
2304
2305 * smux.c (smux_sock): Set terminating '\0'. Check address family.
2306
2307 * vty.c (vty_serv_sock_addrinfo): Set terminating '\0'. Use
2308 gai_strerror. Check address family.
2309
23102000-10-23 Jochen Friedrich <jochen@scram.de>
2311
2312 * smux.c: Use linklist rather than vector.
2313 (smux_getnext): A SMUX subagent has to behave as if it manages the
2314 whole SNMP MIB tree itself. It's the duty of the master agent to
2315 collect the best answer and return it to the manager. See RFC 1227
2316 chapter 3.1.6 for the glory details :-). ucd-snmp really behaves
2317 bad here as it actually might ask multiple times for the same
2318 GETNEXT request as it throws away the answer when it expects it in
2319 a different subtree and might come back later with the very same
2320 request.
2321
23222000-10-23 Kunihiro Ishiguro <kunihiro@zebra.org>
2323
2324 * command.c (cmd_init): Log related command are only installed for
2325 terminal mode.
2326
23272000-10-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2328
2329 * Makefile.am (libzebra_a_SOURCES): Remove duplicated buffer.c.
2330
2331 * zebra.h: Remove #warn directive.
2332
23332000-10-20 Kunihiro Ishiguro <kunihiro@zebra.org>
2334
2335 * keychain.c (keychain_init): Register "key chain" command to
2336 KEYCHAIN_NODE and KEYCHAIN_KEY_NODE.
2337
2338 * vty.c (vty_end_config): Fix missing vty_cinfig_unlock for other
2339 CONFIG_NODE.
2340
2341 * command.c (config_end): Likewise.
2342
2343 * keychain.c (keychain_get): Key is sorted by it's identifier
2344 value.
2345
23462000-10-19 Kunihiro Ishiguro <kunihiro@zebra.org>
2347
2348 * linklist.c (list_delete_all_node): Call delete function if it is
2349 defined.
2350
2351 * command.c (cmd_execute_command_strict): Add modification for
2352 vtysh.
2353 (cmd_execute_command_strict): Remove first argument cmdvec because
2354 it is global varibale in command.c.
2355
23562000-10-18 Kunihiro Ishiguro <kunihiro@zebra.org>
2357
2358 * command.c (cmd_init): Install
2359 copy_runningconfig_startupconfig_cmd only in terminal mode.
2360
2361 * linklist.c (list_delete_node): Simplify the function.
2362 (listnode_lookup): Renamed from list_lookup_node.
2363
23642000-10-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2365
2366 * stream.h: Undef stream_read and stream_write without
2367 parenthesis.
2368
2369 * newlist.c: File removed.
2370
2371 * newlist.h: Likewise.
2372
2373 * linklist.c (list_new): Remove list_init(). To allocate new
2374 linked list, please use list_new().
2375 (listnode_add): Remove list_add_node(). To add new node to linked
2376 list, please use listnode_add().
2377 (list_delete_by_val): Revemove fucntion.
2378
23792000-10-16 Nobuaki Tanaka <nobby@po.ntts.co.jp>
2380
2381 * table.c (route_table_free): Reimplement route_table_free().
2382
23832000-10-11 Kunihiro Ishiguro <kunihiro@zebra.org>
2384
2385 * keychain.c (keychain_get): Register key_delete_func to key
2386 list's delete function. Use linklist.c instead of newlist.c.
2387
23882000-10-04 Akihiro Mizutani <mizutani@dml.com>
2389
2390 * filter.c (access_list_remark): Add access-list's remark command.
2391 (no_access_list): "no access-list 100 permit any" error message
2392 bug is fixed.
2393
23942000-10-03 Kunihiro Ishiguro <kunihiro@zebra.org>
2395
2396 * memory.h (enum): Add MTYPE_SOCKUNION.
2397
23982000-10-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2399
2400 * zebra-0.89 is released.
2401
24022000-10-01 Kunihiro Ishiguro <kunihiro@zebra.org>
2403
2404 * linklist.c (list_add_node_head): Delete unused function.
2405 (list_add_node_tail): Likewise.
2406
24072000-09-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2408
2409 * stream.c (stream_read_unblock): Add new function for unblocking
2410 read.
2411
24122000-09-26 Jochen Friedrich <jochen@nwe.de>
2413
2414 * smux.c (smux_register): Fix bug of can't register more than one
2415 MIB with SMUX.
2416
24172000-09-26 Makoto Otsuka <otsuka@inl.ntts.co.jp>
2418
2419 * vty.c (vty_close): Fix memory leak of sb_buffer.
2420 (vty_new): Likewise.
2421
24222000-09-21 steve@Watt.COM (Steve Watt)
2423
2424 * log.h: Do not declare zlog_priority[0] variable.
2425
24262000-09-12 Kunihiro Ishiguro <kunihiro@zebra.org>
2427
2428 * linklist.h (struct _list ): Add member cmp for compare function.
2429 (struct _list ): Member up is deleted
2430
24312000-09-12 David Lipovkov <dlipovkov@OpticalAccess.com>
2432
2433 * if.c: Include RIP_API header when RIP API is enabled.
2434
24352000-09-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2436
2437 * prefix.c (prefix_free): Siplify prefix_free().
2438
2439 * keychain.c (key_match_for_accept): strncmp check bug is fixed.
2440
24412000-09-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2442
2443 * zebra.h: Merge roken.h into zebra.h.
2444
24452000-09-05 Akihiro Mizutani <mizutani@dml.com>
2446
2447 * routemap.c (route_map_init_vty): Install route-map command to
2448 RMAP_NODE.
2449
24502000-08-22 Kunihiro Ishiguro <kunihiro@zebra.org>
2451
2452 * thread.c (thread_get_id): Remove pthread related garbage.
2453
2454 * command.h (struct host): Likewise.
2455
2456 * zebra.h: Likewise.
2457
24582000-08-20 Kunihiro Ishiguro <kunihiro@zebra.org>
2459
2460 * command.h (node_type ): Add AAA node for authentication.
2461
2462 * vty.c (vty_close): Do not close stdout.
2463
24642000-08-18 Kunihiro Ishiguro <kunihiro@zebra.org>
2465
2466 * vty.c (vty_init_vtysh): Added for vtysh.
2467
2468 * distribute.c (districute_list_prefix_all): Interface independent
2469 filter can be set.
2470 (distribute_list_all): Likewise.
2471 (config_show_distribute): Display current distribute-list status
2472 for "show ip protocols".
2473
24742000-08-18 Akihiro Mizutani <mizutani@dml.com>
2475
2476 * command.c (config_terminal_no_length): no terminal monitor ->
2477 terminal no monitor
2478 (cmd_init): Do not install service_terminal_length_cmd into
2479 ENABLE_NODE.
2480
2481 * vty.c (terminal_no_monitor): no terminal length -> terminal no
2482 length.
2483
24842000-08-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2485
2486 * zebra-0.88 is released.
2487
24882000-08-17 Magnus Ahltorp <ahltorp@nada.kth.se>
2489
2490 * vty.h (struct vty ): Add iac_sb_in_progress and sb_buffer for
2491 better IAC handling.
2492
2493 * vty.c (vty_telnet_option): Change telnet option handling.
2494
24952000-08-15 Gleb Natapov <gleb@nbase.co.il>
2496
2497 * zclient.c (zclient_redistribute_unset): New function added.
2498
24992000-08-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2500
2501 * zclient.c (zebra_interface_add_read): Change ifindex restore
2502 size from two octet to four.
2503 (zebra_interface_state_read): Likewise.
2504 (zebra_interface_address_add_read): Likewise.
2505
25062000-08-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2507
2508 * vty.c (vty_event): Use vector_set_index() instead of
2509 vector_set().
2510
25112000-08-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2512
2513 * zebra.h (ZEBRA_XXX_DISTANCE_DEFAULT): Define Default
2514 Administrative Distance of each protocol.
2515
25162000-08-07 Matthew Grant <grantma@anathoth.gen.nz>
2517
2518 * if.h (struct interface ): Add new member bandwidth to struct
2519 interface.
2520
2521 * zclient.c (zebra_interface_add_read): Fetch bandwidth value.
2522 (zebra_interface_state_read): Likewise.
2523
25242000-08-07 Gleb Natapov <gleb@nbase.co.il>
2525
2526 * routemap.c (route_map_event_hook): New hook route_map_event_hook
2527 is added. This hook is called when route-map is changed. The
2528 parameters passed to the hook are 'event' and 'route-map name'
2529
2530 * routemap.h: Add prototype for route_map_event_hook().
2531
25322000-08-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2533
2534 * zclient.c (zebra_ipv4_route): zebra_ipv4_route(),
2535 zebra_ipv4_add(), zebra_ipv4_delete() are removed.
2536
2537 * routemap.c (route_map_empty): Add new function.
2538 (route_map_delete): Use route_map_index_delete() instead of
2539 route_map_index_free().
2540 (route_map_index_free): Function removed.
2541
25422000-08-06 Gleb Natapov <gleb@nbase.co.il>
2543
2544 * routemap.c (route_map_index_delete): Add check for route-map is
2545 empty or not.
2546
25472000-08-03 Kunihiro Ishiguro <kunihiro@zebra.org>
2548
2549 * zclient.c (zebra_ipv4_add): Change socket arguemnt with struct
2550 zclient.
2551
25522000-08-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2553
2554 * zclient.h (struct zebra): Add obuf for output buffer.
2555
2556 * if.c: Remove #ifdef NRL enclosing if_nametoindex() and
2557 if_indextoname().
2558
25592000-08-02 David Lipovkov <davidl@nbase.co.il>
2560
2561 * if.h (IF_PSEUDO_UNSET): IF_PSEUDO related macro added.
2562 (IF_UNKNOWN_SET): IF_UNKNOWN related macro deleted.
2563
2564 * if.c (interface_pseudo): Add "pseudo" command to interface node.
2565 (no_interface_pseudo): Add "no pseudo" command to interface node.
2566
2567 * zclient.c (zebra_interface_add_read): Set pseudo flag when it is
2568 send from zebra.
2569
25702000-08-01 Kunihiro Ishiguro <kunihiro@zebra.org>
2571
2572 * zebra.h (ZEBRA_IPV4_NEXTHOP_LOOKUP): Add new message.
2573 (ZEBRA_IPV6_NEXTHOP_LOOKUP): Likewise.
2574
2575 * vty.c (vty_serv_un): Use AF_UNIX for backward compatibility.
2576
25772000-07-31 Kunihiro Ishiguro <kunihiro@zebra.org>
2578
2579 * vty.c: Use vector for VTY server thread listing instead of
2580 single value.
2581
25822000-07-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2583
2584 * keychain.c (no_key_chain): "no key chain WORD" command is added.
2585
25862000-07-29 Kunihiro Ishiguro <kunihiro@zebra.org>
2587
2588 * command.c (config_from_file): If command fail in
2589 KEYCHAIN_KEY_NODE, down to KEYCHAIN_NODE.
2590
2591 * vty.h (struct vty ): Add index_sub member.
2592
25932000-07-27 Akihiro Mizutani <mizutani@dml.com>
2594
2595 * if.c: Help strings updates.
2596
25972000-07-11 Akihiro Mizutani <mizutani@dml.com>
2598
2599 * command.c (no_config_enable_password): Add "no enable password"
2600 command.
2601 (config_write_host): Display password string.
2602
2603 * routemap.c (route_map_delete_match): Add support for delete
2604 match without argument.
2605 (route_map_delete_set): Likewise.
2606
26072000-07-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2608
2609 * command.h (node_type ): Change KEYCHAIN_NODE and
2610 KEYCHAIN_KEY_NODE place just before INTERFACE_NODE.
2611
26122000-07-09 Jochen Friedrich <jochen@scram.de>
2613
2614 * smux.c (config_write_smux): Fixes the option to override OID and
2615 password for SMUX.
2616
26172000-07-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2618
2619 * command.h (node_type ): Add SMUX_NODE for SMUX configuration.
2620
26212000-07-09 Toshiaki Takada <takada@zebra.org>
2622
2623 * command.c: Sort descvec command's help.
2624
2625 * vty.c (vty_describe_command): Display '<cr>' at the end of
2626 descriptions.
2627
26282000-07-05 Toshiaki Takada <takada@zebra.org>
2629
2630 * command.c (cmd_ipv6_match), (cmd_ipv6_prefix_match): Fix bug
2631 treatment of double colon.
2632
26332000-07-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2634
2635 * zclient.h: Add zclient_redistribute_default_{set,unset}().
2636
2637 * keychain.c: New file for authentication key management.
2638 * keychain.h: Likewise.
2639
2640 * tcpfilter.c: New file for TCP/UDP base filtering using ipfw or
2641 ipchains.
2642 * tcpfilter.h: Likewise.
2643
2644 * flap.h: New file for route flap dampening.
2645 * flap.c: Likewise.
2646
26472000-07-04 Toshiaki Takada <takada@zebra.org>
2648
2649 * filter.c (struct filter): Add exact flag.
2650 (access_list): Add exact-match command.
2651 (ipv6_access_list): Add exact-match command.
2652
26532000-07-03 Kunihiro Ishiguro <kunihiro@zebra.org>
2654
2655 * zebra.h (ZEBRA_REDISTRIBUTE_DEFAULT_ADD): New message for
2656 request default route.
2657
26582000-07-01 Hideaki YOSHIFUJI ($B5HF#1QL@(B) <yoshfuji@ecei.tohoku.ac.jp>
2659
2660 * smux.c: Add IPv6 smux connection code.
2661
26622000-06-15 Kunihiro Ishiguro <kunihiro@zebra.org>
2663
2664 * vty.c (vty_complete_command): To cooperate readline library,
2665 returned string is newly allocated. So some match function case
2666 need, free of memory.
2667
26682000-06-12 Akihiro Mizutani <mizutani@dml.com>
2669
2670 * distribute.c: Fix help strings.
2671
26722000-06-11 Kunihiro Ishiguro <kunihiro@zebra.org>
2673
2674 * command.c (cmd_complete_command): Add check for vector_slot
2675 (vline, index) is not NULL when calculating lcd.
2676 (cmd_entry_function): First check variable arguemnt to prevent it
2677 from completion.
2678
26792000-06-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2680
2681 * vty.h (struct vty ): Add output_count member for displaying
2682 output route count. Remove arugment arg from output_func because
2683 the value is passed by vty argument. Change output to output_rn.
2684 Add output_clean function pointer member. Add output_type member.
2685
26862000-06-10 Toshiaki Takada <takada@zebra.org>
2687
2688 * command.c (show_startup_config): Add "show startup-config"
2689 command.
2690
26912000-06-06 Akihiro Mizutani <mizutani@dml.com>
2692
2693 * filter.c: Fix help strings.
2694
26952000-06-05 Kunihiro Ishiguro <kunihiro@zebra.org>
2696
2697 * prefix.h (struct prefix_rd): New prefix structure for routing
2698 distinguisher.
2699 (struct prefix): Add padding to every prefix structure.
2700
2701
2702 * routemap.c (route_map_add_match): When completely same match
2703 statement exists, don't duplicate it.
2704
27052000-06-05 Akihiro Mizutani <mizutani@dml.com>
2706
2707 * routemap.c: Change NAME to WORD.
2708
2709 * plist.c: Fix help strings.
2710
27112000-06-02 Akihiro Mizutani <mizutani@dml.com>
2712
2713 * routemap.c: Fix route-map help strings.
2714
27152000-06-01 Kunihiro Ishiguro <kunihiro@zebra.org>
2716
2717 * command.c (cmd_filter_by_completion): Fix CMD_VARARG treatment
2718 to filter other non vararg commands.
2719
2720 * routemap.c (route_map_init_vty): Use install_default() for
2721 install common commands into route-map node..
2722
27232000-06-01 Akihiro Mizutani <mizutani@dml.com>
2724
2725 * command.h (OSPF_STR): Macro added.
2726
27272000-05-31 Kunihiro Ishiguro <kunihiro@zebra.org>
2728
2729 * command.c (cmd_complete_command): LCD completion must not modify
2730 installed command string.
2731
2732 * plist.c (ipv6_prefix_list): Fix wrong syntax definition. Change
2733 X:X::X:X to X:X::X:X/M.
2734
27352000-05-31 Toshiaki Takada <takada@zebra.org>
2736
2737 * vty.c (show_history): New defun added.
2738
27392000-05-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2740
2741 * command.h (CMD_COMPLETE_LIST_MATCH): New define for completion
2742 list. CMD_COMPLETE_MATCH is used for LCD completion.
2743
2744 * vty.c (vty_complete_command): Matched string's LCD is completed.
2745
2746 * command.c (cmd_lcd): New function for calculate LCD of matched
2747 strings.
2748
27492000-05-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2750
2751 * command.c (install_default): config_write_terminal_cmd,
2752 config_write_file_cmd, config_write_memory_cmd are added to
2753 default node.
2754
2755 * memory.c (memory_init): Divide show memory command into each
2756 sort.
2757
2758 * command.c (cmd_init): config_write_terminal_cmd,
2759 config_write_file_cmd, config_write_memory_cmd are added to
2760 CONFIG_NODE.
2761
2762 * routemap.c (route_map_index_free): New function.
2763 (no_route_map_all): New DEFUN for "no route-map NAME".
2764
2765 * filter.c (no_access_list_all): New DEFUN for delete access-list
2766 with NAME.
2767 (no_ipv6_access_list_all): Likewise.
2768
27692000-05-23 Kunihiro Ishiguro <kunihiro@zebra.org>
2770
2771 * plist.c: Change IPV6_PREFIX to X:X::X:X. When "any" is
2772 specified, user can not use "ge" and "le" statement.
2773
27742000-05-22 Thomas Molkenbur <tmo@datus.datus.com>
2775
2776 * routemap.c (route_map_add_set): Fix bug of next pointer missing.
2777
2778 * table.c (route_table_free): Like wise.
2779
27802000-05-22 Toshiaki Takada <takada@zebra.org>
2781
2782 * vty.c (vty_stop_input): Set history pointer to the latest one.
2783
2784 * vty.c (vty_hist_add): Do not add command line history when input
2785 is as same as previous one.
2786
27872000-05-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2788
2789 * memory.h (enum): Add MTYPE_ECOMMUNITY and MTYPE_ECOMMUNITY_VAL.
2790
27912000-05-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2792
2793 * command.h (node_type ): Add BGP_VPNV4_NODE.
2794
27952000-05-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2796
2797 * vty.c (vtysh_accept): Add cast of struct sockaddr * to bind
2798 argument. Reported by: Vesselin Mladenov <mladenov@netbg.com>.
2799
2800 * filter.c (ipv6_access_list): Add IPv6 prefix example instead of
2801 IPv4 example. Reported by: Love <lha@s3.kth.se>.
2802
2803 * command.c (cmd_complete_command): Make it sure last element of
2804 matchvec is NULL. This fix problem which cause crush in
2805 vty_complete_command(). Reported by: JINMEI Tatuya
2806 <jinmei@isl.rdc.toshiba.co.jp>.
2807
28082000-04-28 Love <lha@s3.kth.se>
2809
2810 * prefix.h (struct prefix): Add padding.
2811
28122000-04-28 Kunihiro Ishiguro <kunihiro@zebra.org>
2813
2814 * command.c (show_version): Update copyright year.
2815
28162000-04-27 Kunihiro Ishiguro <kunihiro@zebra.org>
2817
2818 * routemap.c (route_map_apply): When map is NULL, return deny.
2819
28202000-04-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2821
2822 * filter.c (access_list_apply): When access is NULL, return deny.
2823
2824 * plist.c (prefix_list_apply): When plist is NULL, return deny.
2825
28262000-04-23 Kunihiro Ishiguro <kunihiro@zebra.org>
2827
2828 * command.h (node_type ): Change RDISC_NODE to IRDP_NODE.
2829
28302000-04-18 Toshiaki Takada <takada@zebra.org>
2831
2832 * filter.[ch] (access_list_add_hook), (access_list_delete_hook):
2833 Add argument for hook function to give struct access_list *.
2834
28352000-04-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2836
2837 * plist.c (prefix_list_entry_match): In case of le nor ge is
2838 specified, exact match is performed.
2839 (prefix_list_entry_match): Add any entry matching check.
2840
28412000-04-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2842
2843 * vty.c (exec_timeout): Separate timeout setting to minutes and
2844 seconds.
2845 (no_exec_timeout): Add "no exec-timeout" command.
2846
2847 * vty.h (VTY_TIMEOUT_DEFAULT): Change default value from 300 to
2848 600.
2849
28502000-03-31 Jochen Friedrich <jochen@scram.de>
2851
2852 * smux.h (SMUX_CLOSE): The SMUX_CLOSE PDU is implicit integer, so
2853 it is a primitive encoding and not constructed.
2854
28552000-03-28 Toshiaki Takada <takada@zebra.org>
2856
2857 * memory.[ch] (enum): Add MTYPE_OSPF_EXTERNAL_INFO.
2858
28592000-03-26 Love <lha@s3.kth.se>
2860
2861 * zclient.c (zclient_read): Add nbytes size check for
2862 ZEBRA_HEADER_SIZE. Check return value of steam_read ().
2863
28642000-03-26 Rick Payne <rickp@rossfell.co.uk>
2865
2866 * routemap.c: Add flexible route-map commands such as on-match
2867 next, on-match goto N.
2868
2869 * routemap.h: Likewise
2870
28712000-03-23 Adrian Bool <aid@u.net.uk>
2872
2873 * command.c (config_log_trap): Add new command "log trap
2874 PRIORITY".
2875
28762000-03-14 Toshiaki Takada <takada@zebra.org>
2877
2878 * memory.c (struct memory_list): Add Link List and Link Node
2879 to view.
2880
2881 * memory.h (enum): Remove MTYPE_OSPF_EXTERNAL_ROUTE.
2882
28832000-01-20 Hideto Yamakawa <hideto.yamakawa@soliton.co.jp>
2884
2885 * str.c (snprintf): Fix bug of calling sprintf instead of
2886 vsprintf.
2887
28882000-01-16 Kunihiro Ishiguro <kunihiro@zebra.org>
2889
2890 * memory.h (enum): Add MTYPE_RIP_PEER.
2891
28922000-01-15 Toshiaki Takada <takada@zebra.org>
2893
2894 * memory.h (enum): Add MTYPE_OSPF_CRYPT_KEY.
2895
28962000-01-15 Kunihiro Ishiguro <kunihiro@zebra.org>
2897
2898 * command.h (node_type ): Add MASC_NODE for masc.
2899
29002000-01-09 Wang Jianliang <wangjl@soim.net>
2901
2902 * routemap.c (route_map_index_add): When route_map_index is not
2903 empty and insert new item at the head, it can cause core dump.
2904 Fix "if (index == map->head)" to "if (point == map->head).
2905 (route_map_add_set): If there is an old set command, override old
2906 set command with new one.
2907 (route_map_index_delete): Use while() instead of for for() for
2908 logical correctness.
2909
29101999-12-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2911
2912 * memory.h (enum): Add MTYPE_BGP_STATIC.
2913
29141999-12-23 Alex Zinin <zinin@amt.ru>
2915 * zebra.h, zclient.*: dynamic int up/down message
2916 support
2917
29181999-12-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2919
2920 * thread.c (thread_cancel_event): Add a function for clean up
2921 events.
2922
29231999-12-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2924
2925 * dropline.c: Delete file.
2926 dropline.h: Linewise.
2927
29281999-12-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2929
2930 * filter.c (access_list_filter_delete): Wrong pointer
2931 access->master was pointed out after access is freed. I store
2932 master value at the beginning of the function.
2933
29341999-12-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2935
2936 * vty.c (exec_timeout): Change of VTY timeout affect to current
2937 VTY connection.
2938 (vty_accept): Instead of immediate exit() return -1.
2939
29401999-12-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2941
2942 * vty.c (vty_configure_lock): Configuration lock function added.
2943 Only one VTY can use CONFI_NODE at the same time.
2944
2945 * log.c: Delete zvlog_* functions. Now zlog_* does the same
2946 thing.
2947
2948 * log.c (log_init): Function removed.
2949 (log_close): Likewise.
2950 (log_flush): Likewise.
2951 (log_open): Likewise.
2952
2953 * vty.c (terminal_monitor): Add new command.
2954 (no_terminal_monitor): Likewise.
2955
2956 * log.c (old_log): Function removed.
2957 (old_log2): Likewise.
2958 (old_log_warn): Likewise.
2959
29601999-12-04 Toshiaki Takada <takada@zebra.org>
2961
2962 * command.c (cmd_ipv6_match): New function added.
2963 (cmd_ipv6_prefix_match): Likewise.
2964
29651999-12-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2966
2967 * command.c (cmd_ipv6_match):
2968
2969 * table.c: Delete #ifdef HAVE_MBGPV4.
2970
2971 * prefix.h (struct prefix): Add safi member.
2972 (struct prefix_ipv4): Likewise.
2973 (struct prefix_ipv6): Likewise.
2974
29751999-12-04 Rumen Svobodnikov <rumen@linux.tu-varna.acad.bg>
2976
2977 * memory.c (struct mstat): Revert to support MEMORY_LOG.
2978
29791999-11-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2980
2981 * version.h: Bump up to 0.81c for testing new kernel codes.
2982
29831999-11-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2984
2985 * thread.h (struct thread): Pthread support is disabled all
2986 platform.
2987
29881999-11-21 Michael Handler <handler@sub-rosa.com>
2989
2990 * Include <limits.h> and <strings.h> under SUNOS_5.
2991
29921999-11-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2993
2994 * sockunion.c (in6addr_cmp): Enclosed by #define HAVE_IPV6
29951999-11-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2996
2997 * command.h (node_type ): Add BGP_IPV4_NODE and BGP_IPV6_NODE.
2998
29991999-11-12 Kunihiro Ishiguro <kunihiro@zebra.org>
3000
3001 * command.c (disable): Add `disable' command.
3002
30031999-11-09 Kunihiro Ishiguro <kunihiro@zebra.org>
3004
3005 * plist.c (vty_prefix_list_install): Add any check.
3006
30071999-11-04 Kunihiro Ishiguro <kunihiro@zebra.org>
3008
3009 * command.h (node_type ): Add DUMP_NODE.
3010
30111999-11-03 Kunihiro Ishiguro <kunihiro@zebra.org>
3012
3013 * smux.c: Change default SMUX oid to compatible with gated.
3014
30151999-10-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3016
3017 * if_rmap.c: New file added.
3018
3019 * if_rmap.h: New file added.
3020
30211999-10-29 Alex Zinin <zinin@amt.ru>
3022
3023 * hash.c: add hash_free() function
3024
30251999-10-25 Kunihiro Ishiguro <kunihiro@zebra.org>
3026
3027 * hash.c (hash_clean): Add clean function.
3028
3029 * plist.c (prefix_list_reset): Add reset function.
3030
3031 * filter.c (access_list_reset): Add reset function.
3032
30331999-10-17 Kunihiro Ishiguro <kunihiro@zebra.org>
3034
3035 * client.c: Merged with zclient.c.
3036 * client.h: Merged with zclient.h.
3037
30381999-10-15 Jordan Mendelson <jordy@wserv.com>
3039
3040 * md5.c: Imported from GNU C Library.
3041 * md5-gnu.h: Likewise.
3042
30431999-10-15 Jochen Friedrich <jochen@scram.de>
3044
3045 * smux.c (smux_getresp_send): SMUX_GETRSP codes improvement.
3046
30471999-10-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3048
3049 * smux.h: New file added.
3050
3051 * snmp.c: Rename to smux.c.
3052
30531999-10-02 Kunihiro Ishiguro <kunihiro@zebra.org>
3054
3055 * command.c (cmd_execute_command_strict): Filter ambious commands.
3056 (cmd_filter_by_string): Change to return enum match_type.
3057
30581999-10-01 Toshiaki Takada <takada@zebra.org>
3059
3060 * vty.c (vty_describe_fold): New function which does VTY
3061 description line fold.
3062 * vty.c (vty_describe_command): Set description column.
3063
30641999-09-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3065
3066 * plist.c (prefix_list_init_ipv4): VTY user interface is improved.
3067
30681999-09-26 Kunihiro Ishiguro <kunihiro@zebra.org>
3069
3070 * command.c (cmd_filter_by_string): Fix bug of CMD_IPV4 and
3071 CMD_IPV4_PREFIX check. Both return type must be exact_match.
3072
30731999-09-24 Toshiaki Takada <takada@zebra.org>
3074
3075 * command.c (cmd_filter_by_completion),
3076 (is_cmd_ambiguous): Check IPv4 address, IPv4 prefix and range
3077 parameter matches range.
3078
30791999-09-22 Kunihiro Ishiguro <kunihiro@zebra.org>
3080
3081 * routemap.c (route_map_apply): Returm RM_DENYMATCH when no match
3082 is performed.
3083
30841999-09-21 Kunihiro Ishiguro <kunihiro@zebra.org>
3085
3086 * vty.c (vty_read): Control-C stop VTY_MORE mode.
3087
30881999-09-20 Kunihiro Ishiguro <kunihiro@zebra.org>
3089
3090 * command.h (node_type ): Add ACCESS_IPV6_NODE and
3091 PREFIX_IPV6_NODE.
3092
3093 * distribute.h: New file added.
3094
3095 * command.h (node_type ): Delete DISTRIBUTE_NODE.
3096
30971999-09-18 Kunihiro Ishiguro <kunihiro@zebra.org>
3098
3099 * vty.c (vty_terminate_all): New function added for reload
3100 support.
3101
31021999-09-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3103
3104 * memory.h (enum): Add new type MTYPE_OSPF_EXTERNAL_ROUTE.
3105
31061999-08-31 Janos Farkas <chexum@shadow.banki.hu>
3107
3108 * vty.c (vty_read): Handle also 0x7f (alt-backspace), just like
3109 esc-ctrl-h (delete word backwards).
3110
31111999-08-24 Kunihiro Ishiguro <kunihiro@zebra.org>
3112
3113 * if.h: Add if_nametoindex for NRL.
3114
31151999-08-23 Kunihiro Ishiguro <kunihiro@zebra.org>
3116
3117 * if.c (if_create): New function.
3118
31191999-08-22 Kunihiro Ishiguro <kunihiro@zebra.org>
3120
3121 * snmp.c: New file.
3122
31231999-08-21 Kunihiro Ishiguro <kunihiro@zebra.org>
3124
3125 * stream.c (stream_put): stream_memcpy () is changed to stream_put
3126 (). stream_get () is added.
3127
31281999-08-18 Toshiaki Takada <takada@zebra.org>
3129
3130 * memory.h (enum): Add MTYPE_OSPF_LSA_DATA.
3131
31321999-08-18 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
3133
3134 * table.c (route_table_finish): add function frees table.
3135
31361999-08-12 Kunihiro Ishiguro <kunihiro@zebra.org>
3137
3138 * memory.h (enum): Add MTYPE_RTADV_PREFIX.
3139
31401999-08-11 Kunihiro Ishiguro <kunihiro@zebra.org>
3141
3142 * if.h (struct interface ): hw_address, hw_address_len added.
3143
31441999-08-10 Kunihiro Ishiguro <kunihiro@zebra.org>
3145
3146 * if.h (struct interface ): Change structure member if_data to
3147 info, index to ifindex.
3148
31491999-08-08 Rick Payne <rickp@rossfell.co.uk>
3150
3151 * routemap.c: Multi protocol route-map modification.
3152
3153 * routemap.c (route_map_apply): Route match process bug is fixed.
3154
31551999-08-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3156
3157 * thread.c (thread_fetch): When signal comes, goto retry point.
3158
31591999-08-04 Kunihiro Ishiguro <kunihiro@zebra.org>
3160
3161 * Makefile.am: Add sockopt.c and sockopt.h
3162 * sockopt.c: New file.
3163 * sockopt.h: New file.
3164
31651999-08-02 Kunihiro Ishiguro <kunihiro@zebra.org>
3166
3167 * version.h (ZEBRA_VERSION): Release zebra-0.75
3168
31691999-08-01 Kunihiro Ishiguro <kunihiro@zebra.org>
3170
3171 * memory.h (enum): Add MTYPE_RIPNG_AGGREGATE.
3172
31731999-07-31 Kunihiro Ishiguro <kunihiro@zebra.org>
3174
3175 * sockunion.h: Add sockunion_getpeername ().
3176
31771999-07-27 Kunihiro Ishiguro <kunihiro@zebra.org>
3178
3179 * version.h: Release zebra-0.74
3180
31811999-07-26 Kunihiro Ishiguro <kunihiro@zebra.org>
3182
3183 * command.h (struct host): Delete lines from struct host. Add
3184 lines to struct vty.
3185
3186 * command.c: Delete `lines LINES'. Terminal display line settings
3187 should be done by `terminal length' command.
3188
31891999-07-24 Kunihiro Ishiguro <kunihiro@zebra.org>
3190
3191 * memory.h (enum): MTYPE_OSPF_PATH are added.
3192
31931999-07-22 Toshiaki Takada <takada@zebra.org>
3194
3195 * memory.h (enum): MTYPE_OSPF_NEXTHOP is added.
3196
31971999-07-21 Toshiaki Takada <takada@zebra.org>
3198
3199 * linklist.c (list_add_node_prev), (list_add_node_next),
3200 (list_add_list): New function added.
3201
3202 * table.c (route_table_free): New function added.
3203
32041999-07-21 Kunihiro Ishiguro <kunihiro@zebra.org>
3205
3206 * plist.c (config_write_prefix): Set write flag when configuration
3207 is written.
3208
32091999-07-15 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
3210
3211 * prefix.c : prefix_cmp() added. change apply_mask() to
3212 apply_mask_ipv4(), and new apply_mask() added.
3213
32141999-07-14 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
3215
3216 * prefix.c (prefix2str): append prefixlen.
3217
32181999-07-13 Kunihiro Ishiguro <kunihiro@zebra.org>
3219
3220 * command.c (config_terminal): Change "config terminal" to
3221 "configure terminal". Reported by Georg Hitsch
3222 <georg@atnet.at>.
3223 (config_terminal_length): `terminal length <0-512>' is added. At
3224 this moment this command is only usef for vty interface.
3225 Suggested by Georg Hitsch <georg@atnet.at>.
3226
32271999-07-12 Kunihiro Ishiguro <kunihiro@zebra.org>
3228
3229 * routemap.c (rulecmp): Add wrapper function of strcmp.
3230
32311999-07-08 Rick Payne <rickp@rossfell.co.uk>
3232
3233 * sockunion.c (inet_aton): Fix bug of inet_aton.
3234
32351999-07-08 Kunihiro Ishiguro <kunihiro@zebra.org>
3236
3237 * version.h (ZEBRA_VERSION): Start zebra-0.73
3238
32391999-07-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3240
3241 * version.h: Bump up to 0.72.
3242
32431999-07-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3244
3245 * command.c (install_default): New function for install default
3246 commands to the node.
3247
3248 * memory.h (enum): MTYPE_NEXTHOP is added.
3249
32501999-07-01 <kunihiro@zebra.org>
3251
3252 * command.c (no_banner_motd): `no banner motd' command added.
3253
32541999-06-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3255
3256 * regex.c: Update to glibc-2.1.1's posix/regex.c
3257
3258 * regex-gnu.h: Update to glibc-2.1.1's posix/regex.h
3259
3260 * prefix.h (IPV4_ADDR_SAME): Macro added.
3261 (IPV6_ADDR_SAME): Likewise.
3262
32631999-06-29 Kunihiro Ishiguro <kunihiro@zebra.org>
3264
3265 * memory.h (enum): Add MTYPE_OSPF_VERTEX
3266
3267 * version.h: Bump up to 0.71.
3268
3269 * vty.c (vty_serv_sock_addrinfo): Use addrinfo function to bind
3270 VTY socket when IPv6 is enabled.
3271
32721999-06-28 Kunihiro Ishiguro <kunihiro@zebra.org>
3273
3274 * vty.c (vty_serv_sock): Change vty_serv_sock determine which
3275 address family to bind.
3276
3277 * command.c: Add quit command.
3278
32791999-06-26 NOGUCHI kay <kay@dti.ad.jp>
3280
3281 * vty.c (vty_read_config): Fix bug of configuration file path
3282 detection.
3283
32841999-06-25 Kunihiro Ishiguro <kunihiro@zebra.org>
3285
3286 * version.h: Bump up to 0.70.
3287
32881999-06-17 Kunihiro Ishiguro <kunihiro@zebra.org>
3289
3290 * buffer.h (GETL): Remove GETL macro.
3291
3292 * version.h: Bump up to 0.69.
3293
32941999-06-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3295
3296 * if.c (connected_add): Commented out connected_log.
3297
32981999-06-13 Kunihiro Ishiguro <kunihiro@zebra.org>
3299
3300 * command.h (struct cmd_element ): strvec and descvec is combined
3301 into newstrvec.
3302
3303 * command.c (desc_make): Function removed.
3304 (desc_next): Function removed.
3305
3306 * command.h (struct cmd_element ): docvec is removed from struct
3307 cmd_element.
3308
33091999-06-12 Kunihiro Ishiguro <kunihiro@zebra.org>
3310
3311 * command.c (cmd_execute_command): Remove command NULL check.
3312
3313 * command.h (struct cmd_element ): Add newstrvec entry to struct
3314 cmd_element.
3315 (DEFUN2): DEFUN2 macro is removed. DEFUN is extended to support
3316 (a|b|c) statement.
3317 (DESC): DESC macro is removed.
3318
3319 * vty.c (vty_complete_command): When return value is
3320 CMD_ERR_NO_MATCH, don't display error message.
3321
33221999-06-08 Kunihiro Ishiguro <kunihiro@zebra.org>
3323
3324 * table.c (route_next_until): New function.
3325
3326 * version.h: Bump up to 0.68.
3327
33281999-06-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3329
3330 * vty.c (vty_close): Free vty->buf when vty is closed.
3331
3332 * memory.h (enum): Add MTYPE_COMMUNITY_ENTRY and
3333 MTYPE_COMMUNITY_LIST.
3334
3335 * vty.h (struct vty ): Change buf from static length buffer to
3336 variable length buffer.
3337
3338 * vty.c (vty_ensure): New function added.
3339
33401999-06-04 Kunihiro Ishiguro <kunihiro@zebra.org>
3341
3342 * command.h (node_type ): Add COMMUNITY_LIST_NODE.
3343
3344 * command.c (config_enable_password): Freeing host.enable bug is
3345 fixed.
3346 (config_enable_password): Add argc count check.
3347
33481999-05-31 Kunihiro Ishiguro <kunihiro@zebra.org>
3349
3350 * version.h: Bump up to 0.67.
3351
33521999-05-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3353
3354 * command.c (zencrypt): New function for encrypt password.
3355
3356 * command.h (struct host): Add password_encrypt and
3357 enable_encrypt.
3358
33591999-05-30 Jochen Friedrich <jochen@scram.de>
3360
3361 * command.h (struct host): New member encrypt is added for
3362 encrypted password.
3363
33641999-05-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3365
3366 * vty.c: Remove all_digit_check function. Instead use all_digit.
3367
3368 * prefix.c (all_digit): New function for checking string is made
3369 from digit character.
3370
33711999-05-25 Kunihiro Ishiguro <kunihiro@zebra.org>
3372
3373 * Makefile.am (libzebra_a_SOURCES): Add zclient.c.
3374 (noinst_HEADERS): Add zclient.h
3375
3376 * zclient.[ch]: New file for zebra client routine.
3377
3378 * memory.h (enum): Add MTYPE_ZEBRA.
3379
33801999-05-19 Kunihiro Ishiguro <kunihiro@zebra.org>
3381
3382 * version.h (ZEBRA_VERSION): Update to 0.66.
3383
33841999-05-15 Kunihiro Ishiguro <kunihiro@zebra.org>
3385
3386 * buffer.h (GETC,GETW): Macro deleted.
3387
33881999-05-15 Carlos Alberto Barcenilla <barce@frlp.utn.edu.ar>
3389
3390 * prefix.h (IPV4_NET0, IPV4_NET127): Macro added.
3391
33921999-05-15 Kunihiro Ishiguro <kunihiro@zebra.org>
3393
3394 * vty.c (service_advanced_vty): New command added.
3395 (no_service_advanced_vty): Likewise.
3396
33971999-05-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3398
3399 * vty.c (vty_auth): If advanced flag is set and enable password is
3400 not set, directly login to the ENABLE_NODE. This feature is
3401 originally designed and implemented by Stephen R. van den Berg
3402 <srb@cuci.nl>.
3403
3404 * command.h (host): Add advanced flag to struct host for advanced
3405 vty terminal interface.
3406
3407 * version.h (ZEBRA_VERSION): Update to 0.65 for next beta release.
3408
34091999-05-14 Stephen R. van den Berg <srb@cuci.nl>
3410
3411 * command.h (node_type ): Add TABLE_NODE.
3412
3413 * vty.c (vty_telnet_option): Check host.lines value.
3414
3415 * command.c (config_lines): DEFUN for 'lines LINES' command.
3416
3417 * zebra.h: Include <sys/utsname.h> for uname().
3418 (RT_TABLE_MAIN): Defined as 0 if OS does not support multiple
3419 routing table.
3420
3421 * vty.c (vty_auth): Directly login to the ENABLE_NODE when enable
3422 password is not set.
3423 (vty_prompt): Get machine's hostname when hostname is not set.
3424
34251999-05-11 James Willard <james@whispering.org>
3426
3427 * command.c (config_exit): Close connection when `exit' command is
3428 executed at ENABLE_NODE.
3429
34301999-05-10 Kunihiro Ishiguro <kunihiro@zebra.org>
3431
3432 * vty.c (vty_stop_input): `C-c' key change node to ENABLE_NODE.
3433
3434 * command.c (cmd_execute_command_strict): Matched command size
3435 check added.
3436 (cmd_make_desc_line): New function for DEFUN2.
3437
3438 * command.h (struct cmd_element ): Add descsize.
3439
34401999-05-09 Kunihiro Ishiguro <kunihiro@zebra.org>
3441
3442 * command.h (struct cmd_element ): Remame descvec to docvec.
3443 (struct cmd_element ): Add descvec for new description system.
3444
3445 * command.c (desc_make): Check cmd->descvec.
3446
34471999-05-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3448
3449 * memory.h (enum): Add MTYPE_CLUSTER, MTYPE_CLUSTER_VAL.
3450
34511999-05-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3452
3453 * version.h (ZEBRA_VERSION): Bump up to 0.64 for next beta
3454 release.
3455
34561999-05-04 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
3457
3458 * linklist.c (list_delete_all_node): bug fix.
3459 previous code loses current position when node
3460 is deleted.
3461
34621999-05-03 Kunihiro Ishiguro <kunihiro@zebra.org>
3463
3464 * command.h (DESC): Macro added.
3465 (struct cmd_element2): Delete struct cmd_element2.
3466
3467 * plist.c (prefix_list): Sequential number option check is added.
3468
34691999-05-02 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
3470
3471 * log.c (zvlog_{debug,info,notice,warn,err}): have been
3472 added. now we can log both console and file, but still
3473 need some fix about config write.
3474
34751999-05-02 Kunihiro Ishiguro <kunihiro@zebra.org>
3476
3477 * log.c (zvlog_debug): Fix yasu's change.
3478
34791999-05-01 Kunihiro Ishiguro <kunihiro@zebra.org>
3480
3481 * plist.c (prefix_list): Fix typo.
3482
34831999-04-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3484
3485 * Set version to 0.63 for first beta package.
3486
34871999-04-27 Carlos Barcenilla <barce@frlp.utn.edu.ar>
3488
3489 * prefix.c (str2prefix_ipv4): Fix prefix length check.
3490 (str2prefix_ipv6): Likewise.
3491
34921999-04-25 Kunihiro Ishiguro <kunihiro@zebra.org>
3493
3494 * memory.h (enum): Add MTPYE_PREFIX_LIST and
3495 MTYPE_PREFIX_LIST_ENTRY.
3496
3497 * command.h (node_type ): Add PREFIX_NODE.
3498
34991999-04-25 Carlos Barcenilla <barce@frlp.utn.edu.ar>
3500
3501 * command.c: ALIAS (config_write_memory_cmd) and ALIAS
3502 (copy_runningconfig_startupconfig_cmd) is added.
3503
3504 * table.c (route_node_lookup): Unused match variable deletion.
3505
35061999-04-24 Kunihiro Ishiguro <kunihiro@zebra.org>
3507
3508 * Makefile.am (libzebra_a_SOURCES): plist.c added.
3509 (noinst_HEADERS): plist.h added.
3510
3511 * plist.c, plist.h: New file added.
3512
3513 * memory.h (enum): Rename MTYPE_AS_PASN to MTYPE_AS_STR.
3514 * memory.c: Likewise.
3515
35161999-04-19 Carlos Alberto Barcenilla <barce@frlp.utn.edu.ar>
3517
3518 * command.c (show_version): `show version' command added.
3519
35201999-04-19 Kunihiro Ishiguro <kunihiro@zebra.org>
3521
3522 * prefix.c (str2prefix_ipv6): Prefix length overflow check.
3523
35241999-04-19 Carlos Alberto Barcenilla <barce@frlp.utn.edu.ar>
3525
3526 * prefix.c (str2prefix_ipv4): Prefix length overflow check.
3527
35281999-04-19 Alex Bligh <amb@gxn.net>
3529
3530 * prefix.c (sockunion2hostprefix): Function added.
3531 (sockunion2prefix): Address family was not set. Now it is set.
3532
3533 * vty.c: VTY access-class command is added.
3534
35351999-04-18 Kunihiro Ishiguro <kunihiro@zebra.org>
3536
3537 * memory.c: Change xmalloc to zmalloc. xcalloc, xrealloc, xfree,
3538 xstrdup are likewise.
3539
35401999-04-18 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
3541
3542 * thread.c: Add thread_execute for other routing daemon.
3543 OSPF tasks need to be generated by "sheduled" and "executed".
3544
35451999-04-13 Kunihiro Ishiguro <kunihiro@zebra.org>
3546
3547 * buffer.c: Rewrite buffer_write and buffer_flush related
3548 functions for fixing bugs. Reason of the problem and fix is
3549 suggested by Alex Bligh <amb@gxn.net>.
3550
35511999-04-12 Alex Bligh <amb@gxn.net>
3552
3553 * command.c (cmd_entry_function_descr): Added for variable
3554 argument help display.
3555
35561999-04-07 Kunihiro Ishiguro <kunihiro@zebra.org>
3557
3558 * regex.c, regex-gnu.h: Imported from GNU sed-3.02 distribution.
3559
35601999-03-24 Kunihiro Ishiguro <kunihiro@zebra.org>
3561
3562 * stream.c: stream_fifo_free bug is fixed.
3563
35641999-03-19 Toshiaki Takada <takada@zebra.org>
3565
3566 * stream.c (stream_strncpy): Added for getting any length bytes
3567 from stream.
3568
35691999-03-16 Kunihiro Ishiguro <kunihiro@zebra.org>
3570
3571 * version.h (ZEBRA_BUG_ADDRESS): New macro added.
3572
35731999-03-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3574
3575 * buffer.c (buffer_flush_window): If ep is same as buffer's size
3576 length and lp is overrun one octet.
3577
35781999-03-13 Kunihiro Ishiguro <kunihiro@zebra.org>
3579
3580 * vty.h: add VTY's timeout function.
3581
35821999-03-05 <kunihiro@zebra.org>
3583
3584 * command.h (node_type ): Add OSPF6_node.
3585
35861999-03-04 Kunihiro Ishiguro <kunihiro@zebra.org>
3587
3588 * zebra.h: Check HAVE_SYS_SELECT_H when include <sys/select.h>
3589
35901999-03-03 Jeroen Ruigrok/Asmodai <asmodai@wxs.nl>
3591
3592 * zebra.h: Include <net/if_var.h> if it exists.
3593
35941999-03-02 Kunihiro Ishiguro <kunihiro@zebra.org>
3595
3596 * getopt.[ch],getopt1.c: Sync with glibc-2.1.
3597
3598 * log.c (zlog): Tempolary ZLOG_STDOUT feature added.
3599
3600 * command.h: Include vector.h and vty.h
3601
36021999-02-25 Kunihiro Ishiguro <kunihiro@zebra.org>
3603
3604 * routemap.h (struct route_map_rule_cmd): Add prefix arguemnt.
3605
3606 * routemap.c (route_map_apply_index): Add prefix argument.
3607 (route_map_apply): Likewise.
3608
3609 * memory.h (enum): Add MTYPE_ROUTE_MAP_COMPILED.
3610
3611 * stream.c: Add stream_fifo related functions.
3612
36131999-02-24 Kunihiro Ishiguro <kunihiro@zebra.org>
3614
3615 * daemon.c: Return integer value. File descriptor close is added.
3616
3617 * memory.h (enum): add MTYPE_OSPF_LSA.
3618
36191999-02-23 Kunihiro Ishiguro <kunihiro@zebra.org>
3620
3621 * rsh.c: Remove empty file.
3622
36231999-02-22 <kunihiro@zebra.org>
3624
3625 * routemap.c: Add add/delete hook to route_map_master.
3626
36271999-02-19 Peter Galbavy <Peter.Galbavy@knowledge.com>
3628
3629 * str.[ch] added to supply wrappers for snprintf(), strlcat() and
3630 strlcpy on system without these.
3631
36321999-02-18 Peter Galbavy <Peter.Galbavy@knowledge.com>
3633
3634 * syslog support added
3635
36361999-02-02 Kunihiro Ishiguro <kunihiro@zebra.org>
3637
3638 * filter.c (access_list_add_hook): added for hook function management.
3639 * filter.c (access_list_delete_hook): Likewise.
3640
36411999-01-19 Kunihiro Ishiguro <kunihiro@zebra.org>
3642
3643 * stream.c: New file.
3644 * stream.h: New file.
3645 * Divide stream related fucntions from buffer.[ch] into stream.[ch].
3646
36471999-01-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3648
3649 * memory.h (enum): add MTYPE_STREAM, MTYPE_STREAM_DATA
3650
3651 * buffer.c (stream_new): Set MTYPE_STREAM to XMALLOC argument.
3652
36531998-12-23 Kunihiro Ishiguro <kunihiro@zebra.org>
3654
3655 * routemap.c: route_map_index_delete() added.
3656
36571998-12-22 Kunihiro Ishiguro <kunihiro@zebra.org>
3658
3659 * buffer.c (buffer_empty): check cp instead of sp.
3660
36611998-12-17 Kunihiro Ishiguro <kunihiro@zebra.org>
3662
3663 * radix.[ch]: Deleted.
3664
36651998-12-15 Magnus Ahltorp <map@stacken.kth.se>
3666
3667 * buffer.c: Prototype fixes.
3668 * prefix.c: Likewise.
3669 * sockunion.c: Likewise.
3670 * sockunion.h: Likewise.
3671
36721998-12-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3673
3674 * vty.c (vty_read): DELETE key works as vty_delete_char.
3675
36761998-12-13 Kunihiro Ishiguro <kunihiro@zebra.org>
3677
3678 * log.c (time_print): chane %y to %Y.
3679
36801998-12-10 Kunihiro Ishiguro <kunihiro@zebra.org>
3681
3682 * distribute.c: new file.
3683
36841998-12-09 Kunihiro Ishiguro <kunihiro@zebra.org>
3685
3686 * filter.c: Remove all of struct prefix_{ipv4,ipv6} and add
3687 complete support of IPv6 access list.
3688
3689 * command.c (config_write_element): function delete.
3690 (config_write_host): function add. password and enable password
3691 isn't printed to vty interface.
3692
36931998-12-08 Kunihiro Ishiguro <kunihiro@zebra.org>
3694
3695 * filter.c: Change prefix_ipv4 to prefix and add support of
3696 prefix_ipv6 filtering.
3697
36981998-12-07 Kunihiro Ishiguro <kunihiro@zebra.org>
3699
3700 * Makefile.am (INCLUDES): add @INCLUDES@ for Linux IPv6 inet6-apps
3701 header includes.
3702
37031998-12-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3704
3705 * log.c (log_flush): fix function name typo.
3706
37071998-12-04 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
3708
3709 * memory.h: OSPF memory type is added.
3710
37111998-11-15 Kunihiro Ishiguro <kunihiro@zebra.org>
3712
3713 * command.c (sort_node): add sort_node() for pretty printing of
3714 command on vty interface.
3715 (config_password): delete the restriction of charaster of password
3716 string.
3717
37181998-09-05 Kunihiro Ishiguro <kunihiro@debian.zebra.org>
3719
3720 * prefix.c (prefix_ipv4_any): add prefix_ipv4_any().
3721
37221998-08-25 Kunihiro Ishiguro <kunihiro@zebra.org>
3723
3724 * network.h: New file.
3725
37261998-08-24 Kunihiro Ishiguro <kunihiro@zebra.org>
3727
3728 * vty.c (vty_will_echo): function name change from vty_off_echo.
3729
37301998-08-18 Kunihiro Ishiguro <kunihiro@zebra.org>
3731
3732 * buffer.h: add PUTC,PUTW,PUTL macros.
3733
37341998-07-22 Kunihiro Ishiguro <kunihiro@zebra.org>
3735
3736 * route.[ch]: renamed to prefix.[ch]
3737
37381998-06-09 Kunihiro Ishiguro <kunihiro@zebra.org>
3739
3740 * prefix_in, prefix_in6 is replaced by prefix_ipv4, prefix_ipv6.
3741
3742 * Makefile.am: @INCLUDES@ is deleted from INCLUDES.
3743
37441998-06-07 Kunihiro Ishiguro <kunihiro@zebra.org>
3745
3746 * host.[ch]: merged with command.[ch]
3747
37481998-05-08 Kunihiro Ishiguro <kunihiro@zebra.org>
3749
3750 * Makefile.am (libzebra_a_SOURCES): add route.c to libzebra_a_SOURCES.
3751
37521998-05-07 Kunihiro Ishiguro <kunihiro@zebra.org>
3753
3754 * route.c (str2prefix): str2prefix () is gone.
3755
37561998-05-03 Kunihiro Ishiguro <kunihiro@zebra.org>
3757
3758 * vty.c (vty_read_config): change CONDIR to SYSCONFDIR.
3759
3760 * .cvsignore: add file.
3761
3762 * memory.c (xerror): add arguent `type' and `size'.
3763
3764 * socket.c: deleted.
3765
37661998-05-02 Kunihiro Ishiguro <kunihiro@zebra.org>
3767
3768 * vector.c: malloc,free,realloc -> XMALLOC,XFREE,XREALLOC.
3769 * linklist.c: same as above.
3770
37711998-04-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3772
3773 * filter.[ch]: added.
3774
37751998-04-01 Kunihiro Ishiguro <kunihiro@zebra.org>
3776
3777 * vty.c (config_who): return CMD_SUCCESS
3778
37791998-04-01 Jochen Friedrich <jochen@scram.de>
3780
3781 * table.c (route_dump_node): route_dump_node is IPv6 specific
3782 function so move #ifdef to the end of route_dump_node ().
3783
37841998-03-05 "Hannes R. Boehm" <hannes@boehm.org>
3785
3786 * if.c: DEFUN(interface_desc) added.
3787
37881998-03-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3789
3790 * if.c: separated from ripd/rip_interface.c
3791
37921998-03-04 Kunihiro Ishiguro <kunihiro@zebra.org>
3793
3794 * thread.[ch] : added.
3795
37961998-02-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3797
3798 * vty.c (vty_delete_char): fix size bug.
3799 (vty_backward_pure_word): function added.
3800 (vty_read): ESC + 'f' perform vty_forward_word.
3801 (vty_read): ESC + 'b' perform vty_backward_word.
3802
38031998-02-11 Kunihiro Ishiguro <kunihiro@zebra.org>
3804
3805 * radix.c (radix_lookup_rt): add mask check.
3806 (radix_delete_duproute): add mask check.
3807
38081998-02-10 Kunihiro Ishiguro <kunihiro@zebra.org>
3809
3810 * command.c (config_write_file): fix vty -> file_vty.
3811
38121998-02-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3813
3814 * command.c (cmd_filter_ambiguous): add complex type treatment.
3815
38161998-02-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3817
3818 * vty.c (vty_time_print): function added.
3819 (vty_complete_command): now [...] element isn't shown by completion.
3820
38211998-01-26 Kunihiro Ishiguro <kunihiro@zebra.org>
3822
3823 * command.c : change from cmd_install_node() to install_node().
3824
38251998-01-16 Kunihiro Ishiguro <kunihiro@zebra.org>
3826
3827 * route.[ch]: struct rt{} is replaced by struct prefix{}.
3828
38291998-01-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3830
3831 * command.c (cmd_execute_command): check command length.
3832
3833 * timer.c (zebra_timer_set): add zebra_timer_set.
3834
38351998-01-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3836
3837 * command.h (node_type ): add ZEBRA_NODE.
3838
3839 * command.c (config_exit): add RIP_NODE.
3840 (config_write_file): add RIP_NODE.
3841
38421998-01-04 Kunihiro Ishiguro <kunihiro@zebra.org>
3843
3844 * print_version.c (print_version): Now Copyright is 1996-1998.
3845
3846 * sockunion.c (sockunion_log): moved from ../zebra/route.c
3847
38481997-12-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3849
3850 * host.c (config_logfile): change 'log PATH' to 'logfile PATH'.
3851
3852 * sockunion.c (sockunion_sameprefix): add same prefix for
3853 sockunion.
3854
38551997-12-29 Kunihiro Ishiguro <kunihiro@zebra.org>
3856
3857 * radix.[ch] : are moved from ../zebra directroy.
3858
3859 * command.c (config_from_file): if command execution failed down
3860 level to CONFIG_NODE.
3861
3862 * host.c: config_log function which enable 'log FILENAME' command.
3863
38641997-12-23 Kunihiro Ishiguro <kunihiro@zebra.org>
3865
3866 * vty.c: add vty_transpose_chars (). Now you can use '^T' to
3867 transpose character.
3868
3869 * command.c: cmd_cmdsize add, this is useful to check incomplete
3870 command.
3871
38721997-12-07 Kunihiro Ishiguro <kunihiro@zebra.org>
3873
3874 * fd.h: add family for address family
3875
38761997-12-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3877
3878 * command.o
3879 * vty.o
3880 * host.o is moved from ../zebra
3881
38821997-08-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3883
3884 * make library directory.
3885