blob: 37c1324bdff297373678efb0b144ff16f59d217f [file] [log] [blame]
Paul Jakmae5cd7062006-06-15 12:25:55 +000012006-06-15 Paul Jakma <paul.jakma@sun.com>
2
3 * command.c: (cmd_describe_command_real) Fix leak, CID #38.
Paul Jakma8ce5cfd2006-06-15 12:41:02 +00004 * memory.h: Experimental, have XFREE macro NULL out the freed
5 pointer.
Paul Jakmac024fd02006-06-15 12:43:09 +00006 * linklist.c: (list_delete) call list_delete_all_node, don't
7 duplicate it.
Paul Jakma630c97c2006-06-15 12:48:17 +00008 * if.c: (if_flag_dump) remove the whitespace indentation, callers
9 should provide.
Paul Jakmae5cd7062006-06-15 12:25:55 +000010
Paul Jakma35cfc902006-05-28 08:08:24 +0000112006-05-28 Paul Jakma <paul.jakma@sun.com>
12
13 * zebra.h: Include inttypes.h rather than stdint.h, best practice
14 according to the autoconf manual.
15 Add UINT*_MAX defines for older platforms lacking these (FBSD 4)
Paul Jakmad09552d2006-05-28 08:15:46 +000016 * memory.c: malloc.h is deprecated in favour of stdlib.h, however
17 we still need it on GNU Libc for mallinfo().
Paul Jakmaa4b30302006-05-28 08:18:38 +000018 * vty.c: (vty_log/vty_log_fixed) dont crash if called when vty
19 hasn't been initiliased.
Paul Jakmafb66b292006-05-28 08:26:15 +000020 * log.c: (general) Add support for Sun libc printstack().
21 (hex_append) make the cpp conditional on general HAVE_STACK_TRACE
22 define.
23 (zlog_backtrace_sigsafe) Ditto. Add printstack() version of the
24 the DUMP macro in this function.
Paul Jakma35cfc902006-05-28 08:08:24 +000025
Andrew J. Schorr9c378512006-05-21 04:04:49 +0000262006-05-21 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
27
28 * if.h: (struct connected) Document the meaning of the
29 ZEBRA_IFC_REAL and ZEBRA_IFC_CONFIGURED flags.
30
Paul Jakma9c42a6e2006-06-27 07:52:03 +0000312006-05-23 Paul Jakma <paul.jakma@sun.com>
32
33 * route_types.txt: New file, table of ZEBRA_ROUTE definitions.
34 * route_types.awk: New script, to parse previous and generate
35 (for now) redistribute string defines.
36 * Makefile.am: build route_types.h using previous two, ala
37 memtypes.h, include the script and table file in EXTRA_DIST.
38 * command.h: pull in route_types.h, add a REDIST_STR define.
39
Paul Jakmad6d672a2006-05-15 16:56:51 +0000402006-05-15 Paul Jakma <paul.jakma@sun.com>
41
42 * log.c: (general) Generalise struct zebra_route_desc into
43 struct zebra_desc_table and, similar to route_types, add a
44 command_types table to describe Zserv protocol commands.
45 (route_types[]) use a macro to use designated initialisers
46 while avoiding tedious duplication.
47 (zserv_command_string) lookup string from zebra_desc_table,
48 similar to zebra_route_string
49 * zebra.h: Add declaration for zserv_command_string, adjust the
50 comments to reflect zebra_desc_table.
51
Paul Jakmad16e0432006-05-15 10:56:46 +0000522006-05-13 Paul Jakma <paul.jakma@sun.com>
53
54 * vty.c: (vty_describe_command) CID #39 fix was too hasty, just
55 cause it /can/ leak doesn't mean it always will have, check
56 first.
57
Paul Jakma9376c342006-05-12 23:17:38 +0000582006-05-12 Paul Jakma <paul.jakma@sun.com>
59
60 * plist.c: (vty_prefix_list_uninstall) Fix potential NULL deref
61 of prefix and typestr strings, Coverity CID #3.
Paul Jakmad2519962006-05-12 23:19:37 +000062 * command.c: (cmd_complete_command_real) Fix leak of cmd_vector
63 in error case, Coverity CID #37.
Paul Jakma5fc60512006-05-12 23:24:09 +000064 (cmd_describe_command_real) Fix return of freed pointer when
65 no-match, CID #55.
Paul Jakma2fe8aba2006-05-12 23:22:01 +000066 * vty.c: (vty_describe_command) fix leak of describe vector in
67 error path, CID #39.
Paul Jakma9376c342006-05-12 23:17:38 +000068
Paul Jakma6cf0cf02006-03-30 14:43:17 +0000692006-03-30 Paul Jakma <paul.jakma@sun.com>
70
71 * command.h: (DEFUN_CMD_FUNC_TEXT) Annotate arguments as
72 potentially being unused.
Paul Jakma213d8da2006-03-30 14:45:47 +000073 * workqueue.c: (work_queue_run) fix line length of comment
Paul Jakma6cf0cf02006-03-30 14:43:17 +000074
Paul Jakmad4ce4f62006-03-30 14:30:19 +0000752006-03-27 Paul Jakma <paul.jakma@sun.com>
76
77 * memtypes.awk: Fix gensub call, g should be a string..
78
Paul Jakma68784532006-03-30 14:25:24 +0000792006-03-25 Paul Jakma <paul.jakma@sun.com>
80
81 * workqueue.h: (struct work_queue) Remove status field and
82 state flag, no longer used.
83
Paul Jakmab51f1262006-03-30 14:09:38 +0000842006-03-19 Paul Jakma <paul.jakma@sun.com>
85
86 * memtypes.c: Add MTYPE_BGP_SYNCHRONISE.
87
Paul Jakmacec0c4f2006-03-30 13:58:05 +0000882006-03-16 Paul Jakma <paul.jakma@sun.com>
89
90 * Makefile.am: Fix -version-info argument.
91
Paul Jakma41be32b2006-03-30 13:53:59 +0000922006-03-15 Paul Jakma <paul.jakma@sun.com>
93
94 * memory.c: (mtype_memstr) new helper function to
95 return human friendly string for a byte count.
96 (mtype_stats_alloc) new function, for users to retrieve
97 number of objects allocated.
98 (show_memory_mallinfo) New function, show mallinfo statistics
99 if available.
100 (show_memory_all_cmd) Call show_memory_mallinfo, if mallinfo
101 is available.
102 * memory.h: Export mtype_memstr and mtype_stats_alloc.
103 Provide a define for a reasonable buffer size for
104 mtype_memstr.
105
Paul Jakma924f9d32006-03-30 13:25:52 +00001062006-03-14 Paul Jakma <paul.jakma@sun.com>
107
108 * privs.c: (zprivs_caps_init) Change user IDs before lowering
109 privileges, while this seems to work on Linux, on Solaris
110 it rightfully refuses due to PRIV_PROC_SETID having been
111 dropped.
Paul Jakma86228fd2006-03-30 15:00:30 +0000112 * command.h: Add the struct host global exported from command.c
Paul Jakma924f9d32006-03-30 13:25:52 +0000113
Paul Jakma478ccfd2006-03-06 18:18:37 +00001142006-03-06 Paul Jakma <paul.jakma@sun.com>
115
116 * if.h: export show_address_cmd, for anyone who wishes to use
117 it.
118
Paul Jakma5a54df92006-02-21 01:37:14 +00001192006-02-21 Paul Jakma <paul.jakma@sun.com>
120
121 * sockunion.c: (sockunion_{su2str,log}) Use XSTRDUP.
122 Particularly with _su2str, as that string gets XFREEd,
123 which can be annoying if run debug code in memory.c.
124
paul306d8892006-02-02 17:50:19 +00001252006-02-02 Paul Jakma <paul.jakma@sun.com>
126
127 * workqueue.h: (struct work_queue) Remove the delay field.
128 It served no purpose and just introduced bad behaviour.
129 Should be excised before its allowed to escape into 1.0.
130 This removes need for the 'flood' and runs_since_clear
131 fields.
132 * workqueue.c: (general) excise delay factor between queue
133 runs, hence the 'flood' crap too.. See above.
134
paul581a02a2006-01-19 20:22:16 +00001352006-01-19 Paul Jakma <paul.jakma@sun.com>
136
137 * stream.c: (stream_getq_from) should use POSIX uint64_t
138 not u_int64_t. Latter is neither a traditional BSD type, nor
139 a POSIX type.
140
vincenteac314c2006-01-17 23:39:04 +00001412006-01-17 Vincent Jardin <vincent.jardin@6wind.com>
142
143 * md5.c: Don't forget to keep const.
144 * regex.c: Cleanup code and remove warnings.
145
paul7d0b0c42006-01-17 17:40:45 +00001462006-01-17 Paul Jakma <paul.jakma@sun.com>
147
148 * md5.{c,h}: (md5_loop) Is better off taking a void * and doing
149 cast to byte wise type internally, avoids needs for casts
150 in users.
paul789f78a2006-01-17 17:42:03 +0000151 * vty.c: (no_terminal_monitor_cmd) New ALIAS for
152 terminal_no_monitor, in the more normal negating format,
153 to be kind to my fingers.
154 (vty_init) install new ALIAS.
pauld2110862006-01-17 17:43:18 +0000155 * zclient.{c,h}: (zclient_create_header) export this, seems others
156 could use it (in lieu of more complete zserv helpers).
paul7d0b0c42006-01-17 17:40:45 +0000157
paulc1b98002006-01-16 01:54:02 +00001582006-01-16 Paul Jakma <paul.jakma@sun.com>
159
160 * zclient.h: Update the Zserv protocol header with a version
161 field. Define the old command field to be a 'marker', to
162 allow old Zserv and updated Zserv to be differentiated.
163 Future updates will bump the version field obviously. New
164 command field is made wider. Try to stop using the
165 'zebra_size_t' typedef in the callbacks.
166 * zclient.c: Update to read/write new format header.
167
paulc77d4542006-01-11 01:59:04 +00001682006-01-11 Paul Jakma <paul.jakma@sun.com>
169
170 * if.h: (struct interface) expand flags to 8 bytes.
171 * zclient.c: (zebra_interface_{add,state}_read) stream read of
172 interface flags now need to use stream_getq.
173 (zebra_interface_if_set_value) ditto
174
paul4b201d42006-01-10 14:35:19 +00001752006-01-10 Paul Jakma <paul.jakma@sun.com>
176
177 * stream.c: (stream_new) Allocate stream data as seperate object.
178 (stream_free) free the data.
179 (stream_resize) new function, resize stream to new size.
180 (stream_{get,put}q*) new functions to get/put quad word size
181 types.
182 * stream.h: (struct stream) make data seperate from the stream.
183 Export new stream_resize and quad-word get/put functions.
184
gdtf80a0162005-12-29 16:03:32 +00001852005-12-29 Greg Troxel <gdt@fnord.ir.bbn.com>
186
187 * vty.c (vty_hello): add cast to quiet lint (from David Young)
188
paul00c290e2005-11-26 09:21:43 +00001892005-11-26 Paul Jakma <paul.jakma@sun.com>
190
191 * buffer.c: (struct buffer_data) change gcc zero array
192 declaration to C99 incomplete array.
193 * stream.h: (struct stream) same
194
paul6e0f1b92005-11-24 12:47:17 +00001952005-11-24 Paul Jakma <paul.jakma@sun.com>
196
197 * privs.c: (zcaps2sys/solaris) remove unused variable.
198 (zprivs_state_caps/solaris) Format string missing a
199 specifier.
paulb6026072005-11-24 12:51:24 +0000200 * zebra.h: s/u_int/unsigned int/, u_int is a BSD type, defining
201 __USE_BSD on Linux pulls in further things from netinet/ip.h
202 which dont preprocess for some reason. There is no C99
203 shorthand type directly equivalent to u_int afaict, so don't
204 use it.
paul6e0f1b92005-11-24 12:47:17 +0000205
paul190880d2005-11-14 12:07:47 +00002062005-11-14 Paul Jakma <paul.jakma@sun.com>
207
paul889e9312005-11-14 14:46:35 +0000208 * (general) pass struct work-queue to callback functions.
209 * workqueue.h: (struct work_queue) move the state flag
210 variables to end.
211 Add an opaque pointer to spec, for user-data global to the
212 queue.
213 Pass reference to work_queue to all callbacks.
214 * workqueue.c: (work_queue_item_remove) pass ref to workqueue
215 to user callbacks.
216 (work_queue_run) ditto.
217
2182005-11-14 Paul Jakma <paul.jakma@sun.com>
219
paul190880d2005-11-14 12:07:47 +0000220 * (general) Add state to detect queue floods. There's no sense
221 trying to be sparing of CPU resources, if the queue is
222 flooding and using ever more memory resources. we should just
223 get on with clearing the queue.
224 The sense of delay and hold were wrong way around, fix.
225 * workqueue.h: (struct work_queue) Add status bitfield. Add
226 'flood' integer to workqueue spec. Add runs_since_clear
227 counter to workqueue.
228 * workqueue.c: (work_queue_new) set defaults for delay, hold
229 and flood.
230 (work_queue_add) initial schedule should use delay, not hold.
231 (show_work_queues) Print flood field, conserve whitespace.
232 (work_queue_unplug) use delay, not hold.
233 (work_queue_run) consecutive runs should be seperated by hold
234 time, not delay.
235 Keep track of number of consecutive runs, go into 'overdrive'
236 if queue is being flooded, we can't avoid making heavy use of
237 resources, better to use CPU than ever more RAM.
paul76367ea2005-11-14 14:05:35 +0000238 * zebra.h: [bug #231] include stdint, if its there.
paul190880d2005-11-14 12:07:47 +0000239
2402005-11-05 Paul Jakma <paul.jakma@sun.com>
pauldb29ae52005-11-12 22:36:41 +0000241
242 * routemap.c: (vty_show_route_map_entry) call action is
243 seperate from exit action, latter should still be printed
244 regardless of whether a call is specified.
245
paul34204aa2005-11-03 09:00:23 +00002462005-11-03 Paul Jakma <paul.jakma@sun.com>
247
248 * zebra.h: BSD BYTE_ORDER define isn't available everywhere,
249 define if needs be.
250 * checksum.h: new file. checksum.c exports in_cksum, provide
251 a header for it.
252 * checksum.c: (in_cksum) callers shouldn't have to know it uses
253 a u_short internally, change to void *.
254 * Makefile.am: Add checksum.h
255 * command.h: remove bogus trailling slash.
256 * md5.c: (general) Update it for the twentieth century. ANSI
257 declarations are widely supported now.. Don't include system
258 headers, only include zebra.h. Use POSIX types (the
259 alternative is to define u_int64_t in a portable way - rest
260 of Quagga needs same cleanup).
261 Make endian-conditional code be compiler conditional rather
262 than preprocessor conditional, so that breakage gets noticed
263 quicker.
264 * md5.h: POSIX types. Get rid of the odd __P() non-ANSI capable
265 compiler compatibility hack.
paul9c4f1c62005-11-03 11:04:07 +0000266 * if.c: (connected_free) use MTYPE for connected label.
paula49ad232005-11-03 13:00:54 +0000267 * memtypes.c: Add MTYPE_CONNECTED_LABEL
268 * memtypes.h: Update auto-built file.
paul34204aa2005-11-03 09:00:23 +0000269
paul02416842005-10-26 05:05:16 +00002702005-10-26 Paul Jakma <paul.jakma@sun.com>
271
272 * (general) Cleanup a some calls to XFREE,strdup, etc. to use
273 the memory.h macros.
274 * memtypes.c: Add MTYPE_IF_RMAP_NAME, MTYPE_PQUEUE,
275 MTYPE_PQUEUE_DATA and MTYPE_HOST.
276 * memtypes.h: update auto-built file.
277 * if_rmap.c: Use MTYPE_IF_RMAP_NAME.
278 * pqueue.c: Use the two MTYPE_PQUEUE mtypes for allocations.
paul05865c92005-10-26 05:49:54 +0000279 * command.c: Use MTYPE_HOST, MTYPE_STRVEC. Some other fixups,
280 including fixing some likely leaks in config_write_file.
281 * vty.c: memory macro usage fixes.
282 (vty_read_config) fix leak where relative config file is
283 specified.
paul02416842005-10-26 05:05:16 +0000284
ajs24065a32005-10-20 22:28:14 +00002852005-10-20 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
286
ajsc188c372005-10-21 02:57:41 +0000287 * sockopt.c: (setsockopt_multicast_ipv4) If IP_ADD_MEMBERSHIP
288 fails with errno equal to EADDRINUSE, then issue an info
289 message and try IP_DROP_MEMBERSHIP followed by IP_ADD_MEMBERSHIP.
290
2912005-10-20 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
292
ajs24065a32005-10-20 22:28:14 +0000293 * memory.c: (show_memory_vty) Omit zero statistics. Print separators
294 only if some non-zero stats have been printed in between.
295 (show_separator) New function to print a separator.
296 (show_memory_all) Keep track of whether a separator is needed
297 between the different memory statistics groups.
298
ajs50123222005-10-18 20:19:13 +00002992005-10-18 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
300
301 * memtypes.h: Add MTYPE_OSPF_VERTEX_PARENT (to match memtypes.c).
302
pauleb3da6d2005-10-18 04:20:33 +00003032005-10-18 Paul Jakma <paul.jakma@sun.com>
304
305 * memtypes.c: (memory_list_ospf) Add MTYPE_OSPF_VERTEX_PARENT.
306
ajsf52d13c2005-10-01 17:38:06 +00003072005-10-01 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
308
309 * zebra.h: Declare new functions zebra_route_string() and
310 zebra_route_char().
311 * log.c: (zroute_lookup,zebra_route_string,zebra_route_char) New
312 functions to map zebra route numbers to strings.
313
vincent5e4914c2005-09-29 16:34:30 +00003142005-09-29 Alain Ritoux <alain.ritoux@6wind.com>
315
316 * smux.[ch]: allow to retreive global OID (identified by <0
317 namelen).
318
paulceacedb2005-09-29 14:39:32 +00003192005-09-29 Paul Jakma <paul.jakma@sun.com>
320
321 * zebra.h: Solaris capabilities requires priv.h to be included.
322 * privs.{c,h}: Add support for Solaris Least-Privileges.
323 privs.h: Reduce some of the abstract capabilities, which do
324 not have rough equivalents on both systems. Rename the net
325 related caps to _NET, as they should have been in first
326 place.
327 (zprivs_terminate) should take the zebra_privs_t as argument so
328 that it can update change pointer.
329 Add an additional privilege state, ZPRIVS_UNKNOWN.
330 * privs.c: (various capability functions) Add
331 Solaris privileges variants.
332 (zprivs_state) Use privs.c specific generic types to
333 represent various capability/privilege related types, so that
334 each can be typedef'd as appropriate on each platform.
335 (zprivs_null_state) static added, to hold the state the null
336 method should report (should be raised by default, and
337 LOWERED if zprivs_terminate has been called)
338 (zprivs_state_null) Report back the zprivs_null_state.
339 (cap_map) Make it able to map abstract capability to multiple
340 system capabilities.
341 (zcaps2sys) Map to abstract capabilities to multiple system
342 privileges/capabilities.
343 (zprivs_init) move capability related init to seperate
344 function, zprivs_caps_init.
345 (zprivs_terminate) ditto, moved to zprivs_caps_terminate.
346 Set the change_state callback to the NULL state, so the
347 user can continue to run and use the callbacks.
348
vincentfbf5d032005-09-29 11:25:50 +00003492005-09-29 Alain Ritoux <alain.ritoux@6wind.com>
350
351 * filer.c: show protocol name in filter_show()
352 * plist.c: show protocol name in vty_show_prefix_entry()
353 * routemap.c: show protocol name in vty_show_route_map_entry()
354 * vty.c: in vty_command(), show protocol name if command unknown
355
vincentc1a03d42005-09-28 15:47:44 +00003562005-09-28 Alain Ritoux <alain.ritoux@6wind.com>
357
358 * md5-gnu.h: removed
359 * md5.h: replaces md5-gnu.h
360 * Makefile.am: use correct md5.h
361 * md5.c: import from WIDE
362
paul75b2dd02005-09-21 14:06:35 +00003632005-09-21 Paul Jakma <paul.jakma@sun.com>
364
365 * memtypes.{c,h}: Add MTYPE_AS_SEG_DATA.
366
hassoe6a4feb2005-09-19 09:53:21 +00003672005-09-19 Hasso Tepper <hasso at quagga.net>
368
369 * str.[ch]: Add strndup() from glibc.
370
pauleb820af2005-09-05 11:54:13 +00003712005-09-05 Paul Jakma <paul.jakma@sun.com>
372
373 * command.c: (install_element) be more robust. Eg, cmd_init
374 need not have been called, some applications may use other
375 library subsystems, which call install_element, without the
376 application wanting commands and hence not calling cmd_init.
377
paul1e836592005-08-22 22:39:56 +00003782005-08-22 Hugo Santos <hsantos@av.it.pt>
379
380 * command.h: (enum node_type) Add BGP_IPV6M_NODE
381 * command.c: (node_parent) Handle BGP_IPV6M_NODE node
382 (config_exit, config_end) ditto
383 * vty.c: (vty_end_config) Handle BGP_IPV6M_NODE node
384
gdt0312f0c2005-08-10 13:20:03 +00003852005-08-10 Greg Troxel <gdt@fnord.ir.bbn.com>
386
387 * getopt.h: Don't declare getopt (rather than getopt_long), since
388 quagga doesn't need it.
389 * getopt.c (getopt): Don't define getopt.
390
ajs330009f2005-07-26 14:35:37 +00003912005-07-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
ajs7907c6c2005-07-26 19:55:31 +0000392 * prefix.c: (prefix_ipv4_new, prefix_ipv6_new): Call prefix_new
393 to allocate the memory to make sure that all struct prefix pointers
394 point to objects of the same length (avoids memory overruns
395 on struct prefix assignments).
396 (prefix_ipv4_free, prefix_ipv6_free): Simply call prefix_free.
397 It is interesting to note that these functions are never actually
398 called anywhere in the code. Instead prefix_free was already
399 being called directly, despite the previous MTYPE incompatibility.
400
4012005-07-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
ajs330009f2005-07-26 14:35:37 +0000402
403 * prefix.c: (ip_masklen) While loop should test that 'pnt' pointer is
404 in range before dereferencing it.
405
paul510e2092005-06-24 01:20:25 +00004062005-06-24 Pawel Worach <pawel.worach@gmail.com>
407
408 * getopt.h: add further tests for full getopt declaration on
409 various systems.
410
paul354f3b62005-06-18 16:55:20 +00004112005-06-18 Paul Jakma <paul.jakma@sun.com>
412
413 * memtypes.h: update autobuilt file to match memtypes.c changes
414
paul200df112005-06-01 11:17:05 +00004152005-06-01 Paul Jakma <paul.jakma@sun.com>
416
417 * memtypes.c: Add MTYPE_BGP_PROCESS_QUEUE and
418 MTYPE_BGP_CLEAR_NODE_QUEUE
419
paul8176c192005-05-24 09:33:52 +00004202005-05-24 Paul Jakma <paul@dishone.st>
421
422 * memtypes.h: update this auto-built file. (maybe we should just
423 remove it, is GNU awk a terrible dependency to have?)
424
pauld5c92532005-05-23 12:33:58 +00004252005-05-23 Paul Jakma <paul@dishone.st>
426
427 * memtypes.awk: use character classes, which work correctly in
428 all LC_COLLATE environments, unlike A-Z, which doesnt work in
429 eg estonian collate order. Reported by Hasso.
pauld4f09602005-05-23 12:43:34 +0000430 * routemap.c: (rmap_onmatch_goto) fix crash if 'continue' command
431 is used, which does not supply an argv[0].
432 this is a backport candidate /iff/ the trailing ; is removed
433 from VTY_GET_INTEGER_RANGE
434 * vty.h: fix the VTY_GET macros, do {..} while(0) so they have
435 correct function like syntax in usage.
paul269d74f2005-05-23 13:42:46 +0000436 * workqueue.h: Add a WQ_QUEUE_BLOCKED item_status return code,
437 to allow a queue function to indicate the queue is not
438 ready/blocked - rather than any problem with the item at hand.
439 Add a notion of being able to 'plug' and 'unplug' a queue.
440 Add helpers to plug/unplug a queue.
441 Add a completion callback, to be called when a queue is emptied.
442 * workqueue.c: (work_queue_new) remove useless list_free.
443 (work_queue_schedule) new internal helper function to schedule
444 queue, if appropriate.
445 (work_queue_add) use work_queue_schedule
446 (show_work_queues) Print 'P' if queue is plugged.
447 (work_queue_plug) new API function, plug a queue - ie prevent it
448 from 'drained' / processed / scheduled.
449 (work_queue_unplug) unplug a queue, allowing it to be drained
450 / scheduled / processed again.
451 (work_queue_run) Add support for WQ_QUEUE_BLOCKED.
452 Add comment for RETRY_NOW case.
453 Make hysteris more aggresive in ramping up granularity, improves
454 performance significantly.
455 Add support for calling completion callback when queue is emptied,
456 possibly useful for knowing when to unplug a queue.
pauld5c92532005-05-23 12:33:58 +0000457
pauldc818072005-05-19 01:30:53 +00004582005-05-19 Paul Jakma <paul@dishone.st>
459
460 * thread.c: (thread_cancel_event) the number of pending events
461 cancelled is potentially useful information, dont throw it away,
462 pass it back to the caller.
paul2ba9a372005-05-19 01:37:50 +0000463 * sockunion.c: (sockunion_getsockname) use MTYPE_SOCKUNION, not TMP
464 (sockunion_getpeername) ditto
paule387e662005-05-19 02:13:28 +0000465 * memtypes.c: (memory_list_bgp) add MTYPE_BGP_PEER_HOST
pauldc818072005-05-19 01:30:53 +0000466
paul024a7f02005-05-15 14:25:08 +00004672005-05-15 Paul Jakma <paul@dishone.st>
468
469 * getopt.h: It's not just __GNU_LIBRARY__ which defines
470 getopt, eg __EXTENSIONS__ does too on SunOS. It still seems
471 awfully fragile though.
472 * getopt.c: include zebra.h after config.h, before including
473 getopt.h so that things at least are consistent..
474 * getopt1.c: ditto
475
paul42c98192005-05-07 02:22:51 +00004762005-05-07 Yar Tikhiy <yar@comp.chem.msu.su>
477
478 * sockopt.c: Add support for BSD style ifindex in ip_mreq.
479
paul8cc41982005-05-06 21:25:49 +00004802005-05-06 Paul Jakma <paul@dishone.st>
481
482 * (general) extern and static'ification of functions in code and
483 header.
484 Cleanup any definitions with unspecified arguments.
485 Add casts for callback assignments where the callback is defined,
486 typically, as passing void *, but the function being assigned has
487 some other pointer type defined as its argument, as gcc complains
488 about casts from void * to X* via function arguments.
489 Fix some old K&R style function argument definitions.
490 Add noreturn gcc attribute to some functions, as appropriate.
491 Add unused gcc attribute to some functions (eg ones meant to help
492 while debugging)
493 Add guard defines to headers which were missing them.
494 * command.c: (install_node) add const qualifier, still doesnt shut
495 up the warning though, because of the double pointer.
496 (cmp_node) ditto
497 * keychain.c: (key_str2time) Add GET_LONG_RANGE() macro, derived
498 fromn vty.h ones to fix some of the (long) < 0 warnings.
499 * thread.c: (various) use thread_empty
500 (cpu_record_hash_key) should cast to uintptr_t, a stdint.h type
501 * vty.h: Add VTY_GET_IPV4_ADDRESS and VTY_GET_IPV4_PREFIX so they
502 removed from ospfd/ospf_vty.h
503 * zebra.h: Move definition of ZEBRA_PORT to here, to remove
504 dependence of lib on zebra/zserv.h
505
hassoe7fe8c82005-05-06 19:33:35 +00005062005-05-06 Hasso Tepper <hasso at quagga.net>
507
508 * sockunion.c: Fix warning message.
509
paul0dab9302005-05-03 09:07:56 +00005102005-05-03 Paul Jakma <paul@dishone.st>
511
512 * stream.h: Add comment about the special zero-ing ability of
513 stream_put.
514 (stream_recvmsg, stream_write) should return ssize_t and size_t
515 respectively. Should both be extern linkage.
516 (stream_recvfrom) Stream aware wrapper around recvfrom, in style
517 of stream_read_try.
518 * stream.c: (stream_recvfrom) new function, wrapper around recvfrom.
519 (stream_recvmsg, stream_write) ssize_t and size_t return values
520
ajs3df53782005-04-27 16:29:54 +00005212005-04-27 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
522
ajs8b70d0b2005-04-28 01:31:13 +0000523 Add wall-clock timing statistics to 'show thread cpu' output.
524 * thread.h: Define struct rusage_t to contain wall-clock time
525 and cpu time. Change GETRUSAGE macro to collect both pieces
526 of data. Make appropriate changes to struct cpu_thread_history
527 to track CPU time and real time. Change proto for
528 thread_consumed_time to return real and cpu time elapsed.
529 And declare a new global variable 'struct timeval recent_time'.
530 * thread.c (struct timeval recent_time): New global timestamp variable.
531 (timeval_adjust): If timeout is negative, set to 0 (not 10
532 microseconds). And remove upper bound of 1,000,000 seconds, since
533 this does not seem to make any sense (and it breaks
534 funcname_thread_add_timer_timeval).
535 (timeval_cmp): Should return long, not int.
536 (vty_out_cpu_thread_history): Show CPU time and real time.
537 (cpu_record_hash_print): Calculate totals for CPU and real time.
538 (cpu_record_print): Change 'show thread cpu' title to show CPU and
539 real time.
540 (thread_timer_remain_second): Put current time in global recent_time.
541 (funcname_thread_add_timer_timeval): Fix assert. Replace 2-case
542 switch assignment with a ternary expression. Use global recent_time
543 variable. Fix use of timeval_adjust (previously, the value was not
544 actually being adjusted).
545 (thread_cancel): Add missing "break" statement in case
546 THREAD_BACKGROUND.
547 (thread_timer_wait): Use global recent_time value instead of calling
548 gettimeofday. And there's no need to check for negative timeouts,
549 since timeval_subtract already sets these to zero.
550 (thread_timer_process): Timers are sorted, so bail out once we
551 encounter a timer that has not yet popped. And remove some
552 extraneous asserts.
553 (thread_fetch): Do not process foreground timers before calling
554 select. Instead, add them to the ready list just after the select.
555 Also, no need to maintain a count of the number of ready threads,
556 since we don't care how many there are, just whether there's
557 one at the head of the ready list (which is easily checked).
558 Stick current time in global variable recent_time to reduce
559 the number of calls to gettimeofday. Tighten logic for
560 calculating the select timeout.
561 (thread_consumed_time): Now returns real time and puts the elapsed
562 cpu time in an additional argument.
563 (thread_should_yield): Use real (wall-clock) time to decide whether
564 to yield.
565 (thread_call): Maintain CPU and real time statistics.
566 * vty.c (vty_command): For slow commands, show real and cpu time.
567
5682005-04-27 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
569
ajs3df53782005-04-27 16:29:54 +0000570 * workqueue.c (show_work_queues): Remove unused gettimeofday call.
571
paul84369682005-04-27 12:39:27 +00005722005-04-27 Paul Jakma <paul.jakma@sun.com>
573
574 * workqueue.h: (struct work_queue_item) change retry_count to ran,
575 its a count of number item has been run.
576 * workqueue.c: (show_work_queues) Fix formating of slightly
577 bugfix: fix SIGFPE if wq->runs is 0.
578 (work_queue_run) retry logic was slightly wrong.
579 cycles.best is 0 initialy, granularity is 1, so update best
580 if cycles >= granularity, not just >.
paula7bca0f2005-04-27 12:44:54 +0000581 * memory.h: memtypes is built source, default includes points to
582 top_builddir, so we should refer to lib/memtypes.h
583
ajs07334da2005-04-26 17:14:30 +00005842005-04-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
585
586 * buffer.c (buffer_write): Comment out call to buffer_flush_available.
587 This should speed up buffering at the expense of a possible increase
588 in latency in flushing the data if inside a long-running thread.
589
paulab59ae32005-04-25 13:52:26 +00005902005-04-25 Paul Jakma <paul.jakma@sun.com>
591
paul147aff02005-04-25 16:29:10 +0000592 * workqueue.{c,h}: Helper API for setting up and running queues via
593 background threads.
594 * command.c: install the 'show workqueues' command
595 * memtypes.c: Add work queue mtypes, and a rib-queue type for
596 a zebra rib work queue.
597 * memtypes.h: Updated to match memtypes.c
paulab59ae32005-04-25 13:52:26 +0000598 * Makefile.am: Refer to source files via srcdir variable, fix
599 out-of-tree build breakage.
paul147aff02005-04-25 16:29:10 +0000600 Add new workqueue files to build.
paul2c1de2a2005-04-25 14:02:44 +0000601 * memory.c: Make the string field much wider
602 * memtypes.c: Correct the prefix list str/entry strings
paul907873a2005-04-25 14:53:46 +0000603 * thread.c: Kill unused TIMER_NO_SORT bits
paulab59ae32005-04-25 13:52:26 +0000604
ajsfb9e46b2005-04-22 14:23:34 +00006052005-04-22 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
606
607 * thread.h: Fix type for struct thread_master add_type: should be
608 unsigned char. Also, add some documentation of thread_add_background
609 args. And remove extraneous declaration of
610 show_thread_work_queues_cmd.
611
paula48b4e62005-04-22 00:43:47 +00006122005-04-22 Paul Jakma <paul.jakma@sun.com>
613
paule1e53ed2005-04-22 13:44:17 +0000614 * memory.h: Move include of memtypes.h to after the definition of
615 struct memory_list, gcc 4.0 doesn't like arrays of incomplete
616 types.
paula48b4e62005-04-22 00:43:47 +0000617 * thread.h: Add background thread type and thread_add_background
618 macro and accompanying funcname_... function.
619 export thread_should_yield, background threads can use it.
620 Lower thread yield time to 10ms, 100ms is noticeable lag and
621 a thread would only be /starting/ to finish sometime afterward.
622 * thread.c: (general) Add background thread type and schedule
623 nearly all thread types through the ready list for fairness.
624 (timeval_adjust) static qualifier missing
625 (vty_out_cpu_thread_history) add support for printout of
626 background threads
627 (show_thread_cpu) ditto.
628 (thread_master_debug) add debug of background list
629 (thread_master_create) fixup long line
630 (thread_add_unuse) add asserts for required state.
631 (thread_master_free) free background thread list
632 (funcname_thread_add_timer_timeval) make generic, able to
633 support arbitrary timer-like thread types.
634 (funcname_thread_add_timer) pass thread type to .._add_timer_timeval
635 (funcname_thread_add_timer_msec) ditto
636 (funcname_thread_add_background) Add a background thread, with an
637 optional millisecond delay factor, using .._add_timer_timeval.
638 (thread_cancel) Add background thread type.
639 Move the thread_list_delete common to all cases to bottom of
640 function, after the switch statement..
641 (thread_cancel_event) indent
642 (thread_timer_wait) Static qualifier, and make it able to cope
643 with arbitrary timer-like thread lists, so its of use to
644 background threads too.
645 (thread_process_fd) static qualifier. Again, make it take a list
646 reference rather than thread_master. Fix indentation.
647 (thread_timer_process) Check for ready timer-like threads in the
648 given list and move them on to the ready list - code originally
649 embedded in thread_fetch.
650 (thread_fetch) Schedule all threads, other than events, through
651 the ready list, to ensure fairness. Timer readying code moved to
652 thread_timer_process so it can be reused for background threads.
653 Remove the unneeded quagga_sigevent_process, as pointed out by
654 John Lin <john.ch.lin@gmail.com>.
655 (thread_should_yield) make this available.
656
ajs924b9222005-04-16 17:11:24 +00006572005-04-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
658
659 * thread.h (thread_consumed_time): Declare new function to calculate
660 elapsed microseconds.
661 * thread.c (thread_consumed_time): Must be global not static so we
662 can call it from lib/vty.c:vty_command.
663 (thread_should_yield): Surround with `#if 0' to make clear that this
664 function is not currently being used anywhere.
665 (thread_call): If CONSUMED_TIME_CHECK is defined, print a CPU HOG
666 warning message if the thread takes more than CONSUMED_TIME_CHECK
667 microseconds.
668 * vty.c (vty_command): If CONSUMED_TIME_CHECK is defined, print a CPU
669 HOG warning message if the command takes more than CONSUMED_TIME_CHECK
670 microseconds.
671
pauldc830cb2005-04-16 15:51:05 +00006722005-04-16 Paul Jakma <paul@dishone.st>
673
674 * memtypes.c: the comment about use of comments in the comments
675 headers was causing comment within comment warnings from compiler
676 * memtypes.awk: Add extensive comments on the file format for
677 memtypes.c.
678 tighten the pattern for the MTYPE matching action (suggestion from
679 Andrew) and tighten which field we try the match on.
680
paul2fd2fd52005-04-15 11:47:15 +00006812005-04-15 Paul Jakma <paul@dishone.st>
682
683 * memtypes.c: The new, unified location for memory type definitions.
684 The memtype enum and declarations for memory_lists are built from
685 this automatically and put into memtypes.h.
686 * memtypes.awk: New script to generate memtypes.h from memtypes.c
687 * memory.h: Finally, the enum can banished!
688 * memory.c: Finally, the seperate mtype memory_list definitions can
689 be banished!
690 (log_memstats) Increase width of fields
691 (show_memory_zebra_cmd) display zebra specific memory types.
692 Increase width of fields.
693 * Makefile.am: Add memtypes.{c,h}, add BUILT_SOURCES for memtypes.h
694 Add a rule to build memtypes.h using memtypes.awk.
695 Add memtypes.awk to EXTRA_DIST.
pauld45f1f12005-04-15 22:18:37 +0000696 memtypes.awk is gawk dependent, use the GAWK automake var.
697 * memtypes.h: New file, auto-generated, checked in for convenience.
paul2fd2fd52005-04-15 11:47:15 +0000698
ajs634f9ea2005-04-11 15:51:40 +00006992005-04-11 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
700
701 * zclient.h (struct zclient): Add two fields to support non-blocking
702 I/O: struct buffer *wb, and struct thread *t_write.
703 (zclient_free): Remove function.
704 (zebra_redistribute_send): Change 2nd arg from socket fd to
705 struct zclient * (needed to support non-blocking I/O and buffering).
706 (zclient_send_message): New function to send an arbitrary
707 message with non-blocking I/O.
708 * zclient.c (zclient_new): Create write buffer.
709 (zclient_free): Remove unused function.
710 (zclient_stop): Must cancel new t_write thread. Also, reset
711 all buffers: ibuf, obuf, and wb.
712 (zclient_failed): New helper function for typical error handling.
713 (zclient_flush_data): New thread to flush queued data.
714 (zclient_send_message): New function to send the message in
715 zclient->obuf to zebra using non-blocking I/O and buffering.
716 (zebra_message_send, zapi_ipv4_route, zapi_ipv6_route): Use
717 new zclient_send_message function instead of calling writen.
718 (zclient_start): Set socket non-blocking. Also, change 2nd arg
719 to zebra_redistribute_send from zclient->sock to zclient.
720 (zebra_redistribute_send): Change 2nd arg to struct zclient *.
721 Can now use zclient->obuf to assemble the message instead of
722 allocating a temporary stream. And call zclient_send_message to
723 send the message instead of writen.
724 (zclient_read): Convert to support non-blocking I/O by using
725 stream_read_try instead of deprecated stream_read.
726 (zclient_redistribute): Change 2nd arg to zebra_redistribute_send
727 from zclient->sock to zclient.
728
hasso5bb4c192005-04-09 13:27:50 +00007292005-04-09 Jeroen Simonetti <jeroens@office.netland.nl>
730
731 * routemap.c: Show description in "show route-map" output.
732
ajsd66a7b52005-04-08 16:42:03 +00007332005-04-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
734
ajs67bf16c2005-04-08 19:02:04 +0000735 * sigevent.c: On GNU_LINUX, check whether __USE_GNU is already defined.
736
7372005-04-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
738
ajs926fe8f2005-04-08 18:50:40 +0000739 * vty.c: (vty_log_fixed) Use casts to (void *) to try to eliminate
740 compiler warnings when assigning a (const char *) value to
741 struct iovec iov_base.
742
7432005-04-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
744
ajsd66a7b52005-04-08 16:42:03 +0000745 * zebra.h: If GNU_LINUX is defined, then define _GNU_SOURCE. This
746 fixes a problem where we were not getting the declaration of strnlen
747 in <string.h>.
748
hasso3a2ce6a2005-04-08 01:30:51 +00007492005-04-08 Hasso Tepper <hasso at quagga.net>
750
hasso4a8164e2005-04-08 14:20:18 +0000751 * routemap.[ch]: Added "description ..." command.
752
7532005-04-08 Hasso Tepper <hasso at quagga.net>
754
hasso3a2ce6a2005-04-08 01:30:51 +0000755 * prefix.[hc]: Pass argument to the inet6_ntoa by value making it more
756 inet_ntoa alike.
757
paul1eb8ef22005-04-07 07:30:20 +00007582005-04-07 Paul Jakma <paul.jakma@sun.com>
759
760 * linklist.h: Add usage comments.
761 Rename getdata macro to listgetdata.
762 Rename nextnode to listnextnode and fix its odd behaviour to be
763 less dangerous.
764 Make listgetdata macro assert node is not null, NULL list entries
765 should be bug condition.
766 ALL_LIST_ELEMENTS, new macro, forward-referencing macro for use
767 with for loop, Suggested by Jim Carlson of Sun.
768 Add ALL_LIST_ELEMENTS_RO for cases which obviously do not need the
769 "safety" of previous macro.
770 LISTNODE_ADD and DELETE macros renamed to ATTACH, DETACH, to
771 distinguish from the similarly named functions, and reflect their
772 effect better.
773 Add a QUAGGA_NO_DEPRECATED_INTERFACES define guarded section
774 with the old defines which were modified above,
775 for backwards compatibility - guarded to prevent Quagga using it..
776 * linklist.c: fix up for linklist.h changes.
777 * *.c: fix up for new list loop macro, try audit other loop
778 usage at same time, to some degree.
779
hasso59209902005-04-05 14:36:49 +00007802004-04-05 Hasso Tepper <hasso at quagga.net>
781
782 * lib/prefix.[hc]: inet6_ntoa utility function copied from
783 ripngd/ripngd.c (inet6_ntop).
784
paul3d1dc852005-04-05 00:45:23 +00007852004-04-05 Paul Jakma <paul@dishone.st>
786
787 * vty.c: Improve logging of failures to open vty socket(s).
788 See bugid #163.
789
ajs3cb98de2005-04-02 16:01:05 +00007902005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
791
ajs08dbfb62005-04-03 03:40:52 +0000792 * if.h: Fix comments to reflect that if_lookup_by_name and
793 if_get_by_name now require the argument strings to be NUL-terminated.
794 * if.c: (if_lookup_by_name) Compare using strcmp.
795 (if_get_by_name) Pass strlen(ifname) as 2nd arg to if_create.
796
7972005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
798
ajs018546e2005-04-02 23:05:56 +0000799 * if.c: (if_nametoindex) The man page is rather vague, but it seems
800 like the argument to if_nametoindex has an implicit maximum length
801 of IFNAMSIZ characters.
802
8032005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
804
ajsa3491982005-04-02 22:50:38 +0000805 * if.h: (if_lookup_by_name_len, if_get_by_name_len) New functions.
806 * if.c: (if_lookup_by_name_len, if_get_by_name_len) New functions.
807 (if_get_by_name) Tighten up code.
808 (interface) Use new function if_get_by_name_len.
809 * zclient.c: (zebra_interface_add_read) Use new if_get_by_name_len
810 function.
811 (zebra_interface_state_read) Use new if_lookup_by_name_len function.
812
8132005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
814
ajs851adbd2005-04-02 18:48:39 +0000815 * str.c: Replace strlcpy and strlcat with actual working versions
816 copied from rsync-2.6.2/lib/compat.c.
817
8182005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
819
ajsd2fc8892005-04-02 18:38:43 +0000820 * if.h: Remove define for IFINDEX_INTERNBASE and add define
821 IFINDEX_INTERNAL 0, since all internal (i.e. non-kernel) pseudo-
822 interfaces should have ifindex set to 0.
823 (if_new) Remove function.
824 (if_delete_retain) New function to delete an interface without
825 removing from iflist and freeing the structure.
826 (ifname2ifindex) New function.
827 * if.c: (if_new) Remove function (absorb into if_create).
828 (if_create) Replace function if_new with call to calloc.
829 Set ifp->ifindex to IFINDEX_INTERNAL. Fix off-by-one error
830 in assert to check length of interface name. Add error message
831 if interface with this name already exists.
832 (if_delete_retain) New function to delete an interface without
833 removing from iflist and freeing the structure.
834 (if_delete) Implement with help of if_delete_retain.
835 (ifindex2ifname) Reimplement using if_lookup_by_index.
836 (ifname2ifindex) New function to complement ifindex2ifname.
837 (interface) The interface command should check the name length
838 and fail with a warning message if it is too long.
839 (no_interface) Fix spelling in warning message.
840 (if_nametoindex) Reimplement using if_lookup_by_name.
841 (if_indextoname, ifaddr_ipv4_lookup) Reimplement using
842 if_lookup_by_index.
843
8442005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
845
ajs3cb98de2005-04-02 16:01:05 +0000846 * zebra.h: Should include str.h to pick up missing functions.
847 * str.h: Declare strnlen if needed.
848 * str.c: Do not include str.h since zebra.h now includes it.
849 (strnlen) New function.
850
ajsdb8eaac2005-03-16 16:13:06 +00008512005-03-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
852
853 * zebra.h: Must check whether __attribute__ should be defined before
854 including zassert.h.
855
paulb8961472005-03-14 17:35:52 +00008562005-03-14 Paul Jakma <paul.jakma@sun.com>
857
858 * command.c: (sort_node) use vector_max instead of referencing
859 (struct vector *)->max directly. Test that vector_max is > 0
860 before using it to calculate an index.
861 Fixup vector loop to make main body conditional on vector slot
862 not being empty.
863 (cmd_cmdsize) Fixup vector loop to make main body conditional on
864 vector slot not being empty.
865 (cmd_filter_by_completion) ditto
866 (cmd_filter_by_string) ditto
867 (is_cmd_ambiguous) ditto
868 (cmd_describe_command_real) Change index integers to unsigned.
869 Test that vector_max is > 0 before using it to calculate an index.
870 Return immediately with CMD_ERR_NO_MATCH if vline has no
871 active slots.
872 Fixup vector loop to make main body conditional on vector slot
873 not being empty.
874 (cmd_complete_command_real) ditto.
875 (cmd_execute_command_strict) Fixup vector loop to be conditional
876 on non-null slot.
paul909a2152005-03-14 17:41:45 +0000877 (various) Fix indentation and other whitespace.
paul55468c82005-03-14 20:19:01 +0000878 vector.h: Rename to (struct vector).max to slightly less confusing
879 active, for the number of active slots, distinct from allocated
880 or active-and-not-empty. Rename vector_max to vector_active
881 for same reason.
paulb8961472005-03-14 17:35:52 +0000882
paul9e92eea2005-03-09 13:39:26 +00008832005-03-09 Paul Jakma <paul.jakma@sun.com>
884
885 * command.c: Undo commit of sign warning fix and hidden command
886 in list_cmd. Sign warning is more subtle. list_cmd on its own
887 will be committed after.
paul4275b1d2005-03-09 13:42:23 +0000888 * command.c: (config_list_cmd) Don't list hidden or deprecated
889 commands, hiding these from tab completion is still to be done.
paul9e92eea2005-03-09 13:39:26 +0000890
paulb45da6f2005-03-08 15:16:57 +00008912005-03-08 Paul Jakma <paul.jakma@sun.com>
892
paul9c5d8562005-03-08 15:56:42 +0000893 * command.c: (banner_motd_file_cmd) use XSTRDUP/XFREE.
paul22085182005-03-08 16:00:12 +0000894 (no_banner_motd_cmd) use XFREE.
paul9c5d8562005-03-08 15:56:42 +0000895 (cmd_describe_command_real) sign compile warning fix
896 (cmd_complete_command_real) ditto.
897 (config_list_cmd) Don't list hidden or deprecated commands,
898 hiding these from tab completion is still to be done.
899 * command.h: cmd attr enum should start at 1.
paulb45da6f2005-03-08 15:16:57 +0000900 * vty.c: (vty_hello) suggestions from Andrew, read by line and
901 stub out trailling non-printable characters on each line thus
902 allowing us to specify VTY_NEWLINE to vty_out.
903
paul3b0c5d92005-03-08 10:43:43 +00009042005-03-08 Jeroen Massar <jeroen@unfix.org>
905
906 * vty.c: (vty_hello) display motd file, if set
907 * command.h: add char *motdfile to struct host
908 * command.c: (config_write_host) write out motdfile config
909 (banner_motd_file_cmd) new command, allow motd to be read from
910 file.
911 (no_banner_motd_cmd) free motdfile string, if needs be.
912 (cmd_init) init (struct host).motdfile. Add new motd file
913 commands.
914
hasso12f6ea22005-03-07 08:35:39 +00009152005-03-07 Michael Sandee <voidptr@voidptr.sboost.org>
916
917 * command.c: host.name might be NULL.
918 * vty.c: Fix fd leak.
919
ajs81fb3242005-02-24 16:02:53 +00009202005-02-24 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
921
922 * stream.c: (stream_read_try) Log a warning message if a fatal
923 I/O error occurs.
924 (stream_fifo_new) Fix prototype.
925 * stream.h: Fix prototype for stream_fifo_new (need void arg).
926
ajs9fc7ebf2005-02-23 15:12:34 +00009272005-02-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
928
ajscdb6ee92005-02-23 15:48:32 +0000929 * {vty.h,vty.c}: Remove vty_finish (duplicate of vty_reset).
930
9312005-02-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
932
ajs9fc7ebf2005-02-23 15:12:34 +0000933 * buffer.h: Make the struct buffer and struct buffer_data structures
934 private by moving them inside buffer.c. Add comments for all
935 functions. Rename buffer_write as buffer_put (to be more consistent
936 with the buffer_putc and buffer_putstr functions). Declare a new
937 buffer_write function that is used to write data to a file descriptor
938 and/or add it to the buffer queue. Remove unused function
939 buffer_flush_vty_all. Create a new enum typedef buffer_status_t
940 to be used as the return code for all buffer_flush* functions
941 and buffer_write.
942 * buffer.c: The struct buffer and struct buffer_data declarations
943 are now private to this file. In conjunction with that, remove
944 some unnecessary fields: struct buffer (alloc, unused_head,
945 unused_tail, length), struct buffer_data (prev).
946 (buffer_data_new) Removed: functionality incorporated into buffer_add.
947 (buffer_data_free) Removed: use a macro BUFFER_DATA_FREE instead.
948 (buffer_new) Use calloc instead of malloc + memset(zero).
949 Supply an appropriate default size if the specified size is 0.
950 (buffer_free) Eliminate code duplication by calling buffer_reset to
951 free the contents of the buffer (and remove unused code related
952 to unused_head).
953 (buffer_empty,buffer_putc,buffer_putstr) Aesthetic change (make more
954 compact).
955 (buffer_reset) Use macro BUFFER_DATA_FREE. No need to set
956 alloc and length to 0 (these fields have been removed).
957 (buffer_add) Fix scope to be static. Call XMALLOC directly instead
958 of calling removed buffer_data_new function. Simplify the logic
959 (since it's now a singly-linked list instead of doubly-linked).
960 (buffer_write) Renamed to buffer_put. Change to void, since return
961 code of 1 was meaningless. No need to adjust length field, since
962 it has been removed.
963 (buffer_putw,buffer_flush,buffer_flush_vty_all,buffer_flush_vty)
964 Remove unused functions.
965 (buffer_flush_all) Rewrite using buffer_flush_available to eliminate
966 a possible failure mode if IOV_MAX is less than the number of buffers
967 on the queue.
968 (buffer_flush_window) Incorporate logic from buffer_flush_vty.
969 Log an error message if there is a writev error.
970 (buffer_flush_available) Be more paranoid: check for case where
971 buffer is already empty. Use new ERRNO_IO_RETRY macro, and use
972 new enum for return codes. Simplify deletion logic (since it's
973 now a singly-linked list).
974 (buffer_write) New function for use with non-blocking I/O.
975 * vty.h: Replace the struct vty sb_buffer field with a fixed-size
976 (5-character) sb_buf field and an sb_len field, since using
977 a struct buffer was inappropriate for this task. Add some useful
978 comments about telnet window size negotiation.
979 * vty.c: Include <arpa/telnet.h> (no longer included by zebra.h).
980 Remove VTY_OBUF_SIZE (instead use buffer_new default size).
981 Make telnet_backward_char and telnet_space_char static const.
982 (vty_out) Replace buffer_write with buffer_put.
983 (vty_log_out) Check for I/O errors. If fatal, close the vty session.
984 Consolidate 3 separate writes into a single write call.
985 (vty_will_echo,vty_command,vty_next_line,vty_previous_line,
986 vty_end_config,vty_describe_fold,vty_clear_buf,vty_serv_sock_addrinfo,
987 vty_serv_sock_family,vty_serv_un,vty_use_backup_config,exec_timeout,
988 vty_config_write,vty_save_cwd) Fix scope to static.
989 (vty_new) Let buffer_new use its default buffer size.
990 (vty_write) Fix signature: 2nd arg should be const char *.
991 Replaced buffer_write with buffer_put.
992 (vty_telnet_option) Fix minor bug (window height or width greater than
993 255 was broken). Use sb_buf and sb_len instead of removed sb_buffer
994 (which was being used improperly).
995 (vty_read) On error, use ERRNO_IO_RETRY to decide whether it's fatal.
996 If the error is fatal, call buffer_reset so vty_close does not attempt
997 to flush the data. Use new sb_buf and sb_len instead of sb_buffer
998 to store the SB negotiation string.
999 (vty_flush) When vty->lines is 0, call buffer_flush_available instead
1000 of buffer_flush_window. Look at the return code from buffer_flush
1001 to detect I/O errors (and in that case, log an error message and
1002 close the vty).
1003 (vty_create) Fix scope to static. Initialize sb_len to 0 instead
1004 of creating sb_buffer.
1005 (vty_accept) Set socket nonblocking.
1006 (vtysh_accept) Use new set_nonblocking function instead of calling
1007 fcntl directly.
1008 (vtysh_flush) New function called from vtysh_read (after command
1009 execution) and from vtysh_write. This flushes the buffer
1010 and reacts appropriately to the return code (by closing the vty
1011 or scheduling further flushes).
1012 (vtysh_read) Check whether error is fatal using ERRNO_IO_RETRY.
1013 If not, just try again later. Otherwise, call buffer_reset before
1014 calling vty_close (to avoid trying to flush the buffer in vty_close).
1015 Fix logic to allow case where a command does not arrive atomically
1016 in a single read call by checking for the terminating NUL char.
1017 (vtysh_write) Use new vtysh_flush helper function.
1018 (vty_close) No need to call buffer_empty, just call buffer_flush_all
1019 in any case (it will check whether the buffer is empty).
1020 Do not free sb_buffer (since it has been removed).
1021 (vty_log_fixed) Use writev instead of write.
1022 * zebra.h: Do not include <arpa/telnet.h>, since this is used only
1023 by lib/vty.c.
1024
hassoc3c07f22005-02-21 18:17:52 +000010252005-02-21 Vincenzo Eramo <eramo at infocom.ing.uniroma1.it>
1026
1027 * pqueue.[ch]: Introduce "update" function to meet ospf spf needs. It
1028 will allow to update node when:
1029 i) a node is inserted into the priority queue;
1030 ii) a node position is modified in the priority queue;
1031 * pqueue.h: Export trickle_down() function.
1032
paul109ac962005-02-19 01:17:07 +000010332005-02-19 Paul Jakma <paul.jakma@sun.com>
1034
1035 * stream.c: (stream_new) fix dumb mistake.
1036
ajsd7e2a812005-02-17 20:02:49 +000010372005-02-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1038
ajs53270112005-02-17 20:07:22 +00001039 * stream.c: (stream_read_try) Use new ERRNO_IO_RETRY macro.
1040
10412005-02-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1042
ajsd7e2a812005-02-17 20:02:49 +00001043 * network.h: Define a new ERRNO_IO_RETRY macro to test whether an I/O
1044 operation should be retried. This eliminates the need to duplicate
1045 the same logic testing for EAGAIN or EINTR in multiple places.
1046
ajs42218e72005-02-16 16:25:39 +000010472005-02-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1048
ajs262feb12005-02-16 20:35:47 +00001049 * stream.h: Declare new function stream_read_try suitable for use
1050 with non-blocking file descriptors. Indicate that stream_read
1051 and stream_read_unblock are deprecated.
1052 * stream.c: (stream_read_try) New function for use with non-blocking
1053 I/O.
1054 (stream_recvmsg) Should return -1 if the stream is too small to
1055 contain the data.
1056
10572005-02-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1058
ajs42218e72005-02-16 16:25:39 +00001059 * network.c: (set_nonblocking) Should check return code from
1060 fcntl(F_GETFL).
1061
ajsa269d612005-02-16 00:45:37 +000010622005-02-15 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1063
1064 * network.h: Declare new function set_nonblocking. Indicate that
1065 readn and writen are deprecated.
1066 * network.c: (set_nonblocking) New function to make a file descriptor
1067 non-blocking, since it seems silly to have fcntl calls sprinkled
1068 throughout the code.
1069
paul1dd13d42005-02-14 23:49:09 +000010702005-02-14 Paul Jakma <paul.jakma@sun.com>
paulf2e6c422005-02-12 14:35:49 +00001071
1072 * stream.h: Unsigned long updated to size_t
1073 * stream.c: ditto
paul050c0132005-02-14 23:47:47 +00001074 * stream.h: Add stream_copy, stream_dup, stream_recvmsg.
1075 Add comment describing struct stream abstraction, and various
1076 other comments.
1077 Deprecate several unsafe/ambigious macros.
1078 Add STREAM_WRITEABLE and STREAM_READABLE.
1079 Add (stream_getl_from) for symmetry.
1080 Update stream_forward_{endp,getp} to use size_t offset.
1081 Make stream data a 0 length array, rather than a seperate malloc.
1082 * stream.c: Add consistency checks. Update to follow stream.h
1083 changes.
1084 (stream_new) Alloc stream+data in one go.
1085 (stream_copy) new function, copy a stream.
1086 (stream_dup) new function, dup a stream.
1087 (stream_recvmsg) new function, recvmsg data into a stream.
1088 (stream_empty) no need to check getp == 0.
paulf2e6c422005-02-12 14:35:49 +00001089
paul9985f832005-02-09 15:51:56 +000010902005-02-09 Paul Jakma <paul.jakma@sun.com>
1091
1092 * stream.h: Remove putp. Update reference to putp with endp.
1093 Add stream_forward_endp, which daemons were doing manually.
1094 Rename stream_forward to stream_forward_getp.
1095 stream.c: Remove/update references to putp.
1096 introduce stream_forward_endp.
1097
ajs548e6f72005-02-08 15:57:25 +000010982005-02-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1099
1100 * zebra.h: Change macro definitions SET_FLAG and UNSET_FLAG
1101 to use compound assignment operators (aesthetic change).
1102
ajs1e221352005-02-03 16:42:40 +000011032005-02-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1104
ajsc4c7d0c2005-02-03 19:22:05 +00001105 * log.c: (zlog_signal,zlog_backtrace_sigsafe) Eliminate use of fileno()
1106 since it is not async-signal-safe.
1107 (_zlog_assert_failed) Rewrite crashlog logic more compactly.
1108 (zlog_set_file,zlog_reset_file,zlog_rotate) Update logfile_fd
1109 for use in signal handler.
1110
11112005-02-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1112
ajs1e221352005-02-03 16:42:40 +00001113 * log.c: (syslog_sigsafe) Reduce scope of syslog_fd: it is accessed
1114 inside this function only.
1115 (open_crashlog) New function to open /var/tmp/quagga.<daemon>.crashlog
1116 with flags O_WRONLY|O_CREAT|O_EXCL to save some crash info.
1117 (zlog_signal,_zlog_assert_failed) Increase logging priority from
1118 LOG_ERR to LOG_CRIT. If no file logging is configured, try to use
1119 open_crashlog to create a crash logfile.
1120 (zlog_backtrace_sigsafe) If a crashlog file descriptor is open,
1121 dump a backtrace to that file.
1122
ajs847947f2005-02-02 18:38:48 +000011232005-02-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1124
1125 * if.h: Declare if_flag_dump.
1126
ajs6a52d0d2005-01-30 18:49:28 +000011272005-01-30 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1128
1129 * daemon.c: (daemon) Replace perror with zlog_err.
1130 * vty.c: (vty_serv_un) Replace perror with zlog_err.
1131
ajs3b8b1852005-01-29 18:19:13 +000011322005-01-29 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1133
1134 * buffer.h: Fix comment on buffer_getstr to reflect that it now
1135 uses XMALLOC.
1136 * buffer.c: (buffer_getstr) Use XMALLOC(MTYPE_TMP) instead of malloc.
1137 * filter.c: (access_list_remark,ipv6_access_list_remark) Use
1138 argv_concat instead of buffer_getstr.
1139 * if.c: (interface_desc) Use argv_concat instead of buffer_getstr.
1140 * plist.c: (ip_prefix_list_description,ipv6_prefix_list_description)
1141 Use argv_concat instead of buffer_getstr.
1142
ajsf6834d42005-01-28 20:28:35 +000011432005-01-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1144
ajsafb8b602005-01-28 20:41:07 +00001145 * lib/buffer.h: Document behavior of buffer_getstr function.
1146 * lib/buffer.c: (buffer_getstr) Fix bug: must handle case where
1147 the string extends beyond the head struct buffer_data.
1148
11492005-01-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1150
ajsf6834d42005-01-28 20:28:35 +00001151 * lib/command.h: Document behavior of argv_concat function.
1152 * lib/command.c: (argv_concat) Calculate total string length first so
1153 we can call malloc just once (instead of realloc'ing to add each
1154 string element).
1155 (do_echo,config_logmsg) Allow for possible NULL return value from
1156 argv_concat.
1157
hasso13bfca72005-01-23 21:42:25 +000011582005-01-23 Hasso Tepper <hasso at quagga.net>
1159
1160 * lib/command.[ch]: Make node_parent() function nonstatic. vtyh.c will
1161 use it as well.
1162
ajs31364272005-01-18 22:18:59 +000011632005-01-18 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1164
1165 * log.h: Test for SA_SIGINFO to see whether zlog_signal takes final
1166 two args (siginfo and program_counter).
1167 * log.c: (hex_append) Include this function only if SA_SIGINFO or
1168 HAVE_GLIBC_BACKTRACE is defined.
1169 (zlog_signal) Final two args (siginfo and program_counter) now
1170 depend on whether SA_SIGINFO is defined on this platform.
1171 * sigevent.c: (program_counter) Do not include this function if
1172 SA_SIGINFO is not defined on this platform.
1173 (exit_handler,core_handler) Test for SA_SIGINFO to decide whether
1174 2nd & 3rd arguments are present and to decide how to invoke
1175 zlog_signal.
1176 (trap_default_signals) Test for SA_SIGINFO and invoke sigaction
1177 appropriately.
1178
ajs239c26f2005-01-17 15:22:28 +000011792005-01-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1180
1181 * log.h: Change prototype for zlog_backtrace_sigsafe to take additional
1182 program_counter argument.
1183 * log.c: (zlog_backtrace_sigsafe) Add additional program_counter
1184 argument. If it is non-NULL, use backtrace_symbols_fd to resolve
1185 the address.
1186 (zlog_signal) Call zlog_backtrace_sigsafe with additional
1187 program_counter argument.
1188
hasso87d683b2005-01-16 23:31:54 +000011892005-01-17 Hasso Tepper <hasso at quagga.net>
1190
1191 * command.[ch], vty.c: cmd_execute_command() function must not attempt
1192 to walk up in the node tree if called from vtysh. Different daemons
1193 might have commands with same syntax in different nodes (for example
1194 "router-id x.x.x.x" commands in zebra/ospfd/ospf6d daemons).
1195
ajscb585b62005-01-14 17:09:38 +000011962005-01-14 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1197
1198 * command.c (print_version): Do not bother even to examine host.name,
1199 since it is always NULL when this function is called from main.
1200
gdtf867d322005-01-14 15:47:33 +000012012005-01-14 Greg Troxel <gdt@fnord.ir.bbn.com>
1202
1203 * command.c (print_version): Don't print host.name if it is NULL.
1204 Fixes segfault on Solaris reported by Goetz von Escher <goetz@open.ch>
1205
ajse22f5512005-01-12 16:18:17 +000012062005-01-12 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1207
ajs40abf232005-01-12 17:27:27 +00001208 * sigevent.c: (trap_default_signals) Use the SA_SIGINFO flag to
1209 pass additional siginfo_t and ucontext_t arguments to core_handler
1210 and exit_handler.
1211 (core_handler,exit_handler) Now invoked with 3 arguments (using
1212 SA_SIGINFO). Pass additional info to zlog_signal.
1213 (program_counter) New function to find program counter in ucontext_t,
1214 needs to be enhanced to support more platforms (currently works only
1215 on Linux/x86).
1216 * log.h: Change the zlog_signal prototype to add new arguments
1217 siginfo_t * and program_counter.
1218 * log.c: (zlog_signal) Add new arguments siginfo and program_counter.
1219 Include si_addr and program counter (if non-NULL) in message.
1220 And remove #ifdef HAVE_GLIBC_BACKTRACE around hex_append, since
1221 that is now used to render the si_addr and PC pointers.
1222
12232005-01-12 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1224
ajse22f5512005-01-12 16:18:17 +00001225 * zebra.h: If not C99 and no va_copy macro available, fall back to
1226 memcpy (solves a build problem on FreeBSD 4.x).
1227
ajsb99760a2005-01-04 16:24:43 +000012282005-01-04 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1229
1230 * zebra.h: Define ZCMSG_FIRSTHDR appropriately based on whether
1231 config.h indicates HAVE_BROKEN_CMSG_FIRSTHDR (as determined
1232 by the configure test program).
1233 * sockopt.c: (getsockopt_cmsg_data) Use ZCMSG_FIRSTHDR instead
1234 of CMSG_FIRSTHDR.
1235
hassocba8a602005-01-02 18:51:01 +000012362005-01-02 Hasso Tepper <hasso at quagga.net>
1237
1238 * command.c: Revert int -> unsigned int fixes in
1239 cmd_describe_command_real() and cmd_complete_command_real(). index can
1240 be actually negative and it caused crash with "do<TAB>" in vty.
1241
gdt1d69fdf2004-12-29 18:53:30 +000012422004-12-29 Greg Troxel <gdt@poblano.ir.bbn.com>
1243
gdtd44debe2004-12-29 20:06:23 +00001244 * sockopt.c (getsockopt_ipv4_ifindex): Document calling
1245 convention. Beef up comments. Handle the case where the cmsghdr
1246 has a zero controllen, or more specifically when the wanted option
1247 is not present. This is needed for Solaris 8, and in general for
1248 any platform for which configure finds a method and it can fail.
1249 Mark some changes with XXX to be cleaned up post 0.98.
1250
ajsaf04bd72004-12-28 17:00:12 +000012512004-12-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1252
ajs1d75c8c2004-12-28 21:43:17 +00001253 * sockopt.c: (setsockopt_ipv4_ifindex) Improve error message.
1254 When neither IP_PKTINFO nor IP_RECVIF is defined, make return value
1255 deterministic (-1).
1256
12572004-12-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1258
ajsaf04bd72004-12-28 17:00:12 +00001259 * thread.c: (funcname_thread_add_timer_msec) Reduce overflow risk.
1260
paul4ba9b922004-12-21 22:34:58 +000012612004-12-21 Paul Jakma <paul.jakma@sun.com>
1262
1263 * if.h: Add more 'non-generic' IFF_ flags.
1264 * if.c: IFF_NOXMIT/IFF_VIRTUAL interfaces are 'loopback like'
paul0e43a2b2004-12-22 00:15:34 +00001265 * stream.c: Dont allocate streams with 0 sized data buffers
paul4ba9b922004-12-21 22:34:58 +00001266
ajs202d08c2004-12-17 20:50:00 +000012672004-12-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
ajs2885f722004-12-17 23:16:33 +00001268
1269 * command.c: (do_echo) Added new "echo" command, useful for
1270 watchdog pinging to make sure the daemon is responsive.
1271
12722004-12-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
ajs202d08c2004-12-17 20:50:00 +00001273
1274 * pid_output.c: (pid_output_lock) Eliminate static function, and just
1275 use the #ifdef to decide which version of the function to include.
1276 This eliminates a compilation problem with gcc4. And fix the
1277 non-fcntl version so that it actually compiles. Exit with
1278 status 1 instead of -1 on error.
1279
ajs81fc57c2004-12-15 17:41:14 +000012802004-12-15 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1281
1282 * sigevent.c: (trap_default_signals) Ignore SIGPIPE instead of exiting.
1283
ajs3378d202004-12-10 22:43:17 +000012842004-12-10 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1285
1286 * log.c: (zlog_signal,_zlog_assert_failed) Change logging level back to
1287 LOG_ERR instead of LOG_EMERG.
1288
ajsc3324c62004-12-09 17:26:31 +000012892004-12-09 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1290
1291 * log.c: (hex_append) No need to include this function if
1292 HAVE_GLIBC_BACKTRACE is not defined.
1293
ajsb9e70282004-12-08 17:14:45 +000012942004-12-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1295
1296 * prefix.c: (prefix_copy) Error message before abort should
1297 have severity LOG_ERR, not LOG_INFO.
1298 * memory.c: (mtype_log) Log level should be LOG_DEBUG, not LOG_INFO.
1299
ajs274a4a42004-12-07 15:39:31 +000013002004-12-07 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1301
ajs8ddca702004-12-07 18:53:52 +00001302 * {smux.c,zclient.c}: Change level of debug messages to LOG_DEBUG.
1303
13042004-12-07 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1305
ajs82146b82004-12-07 17:15:55 +00001306 * command.c: (config_write_host) Note that "log trap" is deprecated
1307 when writing out the config.
1308
13092004-12-07 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1310
ajs274a4a42004-12-07 15:39:31 +00001311 * log.h: Replace struct zlog flags and maskpri fields with maxlvl
1312 array to support individual logging levels for each destination.
1313 Remove the 2nd argument to openzlog since the default logging config
1314 should be standardized inside the library. Replaced the
1315 zlog_set_flag and zlog_reset_flag functions with zlog_set_level.
1316 And zlog_set_file now requires an additional log_level argument.
1317 Declare zlog_proto_names for use inside command.c in the
1318 "show logging" command. Added defines useful for command
1319 construction.
1320 * log.c: (vzlog) Decide where to send the message based on the
1321 individual logging levels configured for each destination.
1322 Remove support for ZLOG_STDERR since it was never actually used.
1323 Support record-priority for terminal monitors.
1324 (zlog_signal,zlog_backtrace_sigsafe) Support destination-specific
1325 logging levels. Remove stderr support (was never used). Added
1326 support for terminal monitor logging.
1327 (_zlog_assert_failed) Increase message severity to LOG_EMERG.
1328 (openzlog) Remove 2nd argument since default config should be
1329 standardized in library. By default, terminal monitoring
1330 is set to debug, and all other logging is disabled.
1331 (zlog_set_flag,zlog_reset_flag) Removed.
1332 (zlog_set_level) New function to replace zlog_set_flag and
1333 zlog_reset_flag. Supports destination-specific logging levels.
1334 (zlog_set_file,zlog_reset_file) Support file-specific logging level.
1335 (zlog_rotate) Log an error message if fopen fails, and support
1336 new file-specific logging level.
1337 * command.h: Change DEFUN_CMD_FUNC_DECL and DEFUN_CMD_FUNC_TEXT so that
1338 command functions will be static instead of global. Remove
1339 declarations for config_exit and config_help. Define new macros
1340 DEFUNSH_ATTR, DEFUNSH_HIDDEN, and DEFUNSH_DEPRECATED so we can
1341 have deprecated commands in vtysh. Similarly, for completeness,
1342 define macros ALIAS_SH, ALIAS_SH_HIDDEN, and ALIAS_SH_DEPRECATED.
1343 Also, fix bug in ALIAS_ATTR macro (didn't matter because it
1344 was never used).
1345 * command.c: Make many functions static instead of global.
1346 (facility_name,facility_match,level_match) New functions
1347 to support enhanced destination-specific logging levels.
1348 (config_write_host) Support new destination-specific logging levels.
1349 (config_logmsg) Added new "logmsg" command to help test logging
1350 system.
1351 (show_logging) Added "show logging" command to show the current
1352 configuration of the logging system.
1353 (config_log_stdout_level) Support explicit stdout logging level.
1354 (no_config_log_stdout) Now takes optional LEVEL arg.
1355 (config_log_monitor,config_log_monitor_level,no_config_log_monitor)
1356 New commands creating new "log monitor" commands to set terminal
1357 monitoring log level.
1358 (config_log_file_level) Support explicit file logging level.
1359 (config_log_syslog_level) Support explicit syslog logging level.
1360 (config_log_facility,no_config_log_facility) Implement new
1361 "log facility" command.
1362 (cmd_init) Add hooks for new commands: "show logging", "logmsg",
1363 "log stdout <level>", "log monitor", "log monitor <level>",
1364 "no log monitor", "log file <filename> <level>",
1365 "no log file <filename> <level>", "log syslog <level>",
1366 "log facility", and "no log facility".
1367 * vty.h: Added a "level" argument to vty_log so it can support
1368 "log record-priority". Declare new function vty_log_fixed for
1369 use in signal handlers.
1370 * vty.c: (vty_log,vty_log_out) Added a "level" argument to support
1371 "log record-priority" for vty terminal monitors.
1372 (vty_down_level) Use config_exit_cmd.func instead of calling
1373 config_exit directly (since command functions will now be static
1374 instead of global).
1375 (vty_log_fixed) New function to send terminal monitor messages
1376 from inside a signal handler.
1377
ajs887c44a2004-12-03 16:36:46 +000013782004-12-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1379
ajs5e764772004-12-03 19:03:33 +00001380 * log.h: Document appropriate use of syslog logging priorities
1381 inside quagga.
1382
13832004-12-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1384
ajs56f20692004-12-03 17:40:31 +00001385 * command.h: Remove fields log_stdout and log_syslog from struct host,
1386 since they are just trying to duplicate information in the
1387 zlog_default structure. Note that this fixes a bug since those
1388 fields were not registering any logging that was established
1389 in the initial call to openzlog (this affects only the zebra and
1390 ospf6d daemons). It is probably a bug to turn on any logging by
1391 default in the call to openzlog.
1392 * command.c: (config_write_host) Get logging info from zlog_default
1393 instead of now-removed fields host.log_stdout and host.log_syslog.
1394 (config_log_stdout,no_config_log_stdout) Do not set now-removed field
1395 host.log_stdout, since this info is recorded in zlog_default.
1396 (config_log_file) Use XSTRDUP (instead of strdup) to set host.logfile.
1397 (config_log_syslog,config_log_syslog_facility,no_config_log_syslog)
1398 Do not set now-removed field host.log_syslog, since this info is
1399 recorded in zlog_default.
1400
14012004-12-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1402
ajs887c44a2004-12-03 16:36:46 +00001403 * version.h.in: Remove declaration for pid_output_lock, this function
1404 is now static, not global.
1405 * pid_output.c: (pid_output_lock) This function should be static, not
1406 global. And remove "old umask" error message, since it was really
1407 an unimportant debug message, not an error.
1408 (pid_output) Need to declare static function pid_output_lock.
1409
ajs7d149b82004-11-28 23:00:01 +000014102004-11-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1411
1412 * log.h: Remove several unused fields from struct zlog. Add comments
1413 for other fields, and add one new field syslog_options that is
1414 used in the new syslog_sigsafe implementation.
1415 * log.c: (syslog_sigsafe) New function to send syslog messages in
1416 an async-signal safe way that can be used inside a signal handler.
1417 (syslog_connect) New function to connect to syslog daemon inside a
1418 signal handler. This function supports only systems where /dev/log
1419 is a unix datagram socket (e.g. not Solaris).
1420 (zlog_signal) Call syslog_sigsafe if syslog logging is enabled.
1421 (zlog_backtrace_sigsafe) Call syslog_sigsafe if syslog logging is
1422 enabled.
1423 (openzlog) Save syslog_options for use in syslog_sigsafe.
1424 (num_append) Fix bug: handle 0 properly.
1425 (hex_append) New function to print a u_long in hex format.
1426
hasso2557aed2004-11-28 21:16:20 +000014272004-11-28 Hasso Tepper <hasso at quagga.net>
1428
1429 * command.h: DEFUN_DEPRECATED passes attribute to DEFUN as well.
1430
ajsd1c51d72004-11-26 14:14:30 +000014312004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1432
ajs48d6c692004-11-26 20:52:59 +00001433 * log.c, log.h, memory.c: Change function name from zlog_backtrace_safe
1434 to the more self-explanatory zlog_backtrace_sigsafe.
1435
14362004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1437
ajs5b85fac2004-11-26 19:36:42 +00001438 * debug.[ch]: Remove unused files.
1439 * Makefile.am: Remove references to debug.c and debug.h
1440
14412004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1442
ajs063ee522004-11-26 18:11:14 +00001443 * log.c: (zlog_backtrace) New function to log a backtrace.
1444 (zlog_backtrace_safe) Log a backtrace in an async-signal-safe way.
1445 Unfortunately, this function does not support syslog logging yet.
1446 (zlog_signal) Move backtrace code into separate function
1447 zlog_backtrace_safe.
1448 (_zlog_assert_failed) Call zlog_backtrace before aborting.
1449 * log.h: Declare new functions zlog_backtrace and zlog_backtrace_safe.
1450 * memory.c: (zerror) Call zlog_backtrace before aborting.
1451
14522004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1453
ajsd1c51d72004-11-26 14:14:30 +00001454 * Makefile.am: Need to add zassert.h to pkginclude_HEADERS.
1455
ajse5879ca2004-11-25 16:07:53 +000014562004-11-25 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1457
ajs4cf0d0d2004-11-25 17:14:34 +00001458 * zebra.h: If not C99 and there's no va_copy macro and there is
1459 a __va_copy macro, define va_copy as __va_copy.
1460
14612004-11-25 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1462
ajse5879ca2004-11-25 16:07:53 +00001463 * pid_output.c: (pid_output_lock) Fix 2 bugs: when locking, should
1464 set l_whence to SEEK_SET, not SEEK_END. And after writing new
1465 pid to file, must ftruncate to eliminate any extraneous bytes left
1466 over from the last time a pid was written.
1467
ajscee3df12004-11-24 17:14:49 +000014682004-11-24 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1469
1470 * zassert.h: New header file to declare a quagga-specific assert macro.
1471 * log.c: (_zlog_assert_failed) New function called when assert fails
1472 to log the error and abort.
1473 * zebra.h: Include "zassert.h" instead of <assert.h>.
1474 * regex.c: Include "zassert.h" instead of <assert.h>.
1475
ajsd246bd92004-11-23 17:35:08 +000014762004-11-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1477
ajs59a06a92004-11-23 18:19:14 +00001478 * sigevent.c: (signal_init) Set up some default signal handlers
1479 so that processes will issue an error message before terminating
1480 or dumping core.
1481 (trap_default_signals) New function to set up signal handlers
1482 for various signals that may kill the process.
1483 (exit_handler) Call zlog_signal, then _exit.
1484 (core_handler) Call zlog_signal, then abort.
1485 * log.h: Declare new function zlog_signal.
1486 * log.c: (zlog_signal) New function to log information about
1487 a received signal before the process dies. Try to log a
1488 backtrace also.
1489 (quagga_signal_handler,signal_set) Should be static.
1490
14912004-11-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1492
ajsd246bd92004-11-23 17:35:08 +00001493 * log.c: (vzlog) Take a single va_list argument and use va_copy
1494 as necessary for multiple traversals.
1495 (zlog) Pass only one va_list to vzlog.
1496 (zlog_*,plog_*) Use a macro for boilerplate code; pass only one
1497 va_list to vzlog.
1498 (zlog_set_file) Remove unused 2nd argument (flags).
1499 (zlog_save_cwd,zlog_get_cwd,zlog_free_cwd) Remove unused functions.
1500 * log.h: Remove ZLOG_*_INDEX defines (no longer used).
1501 Remove unused 2nd argument from zlog_set_file prototype.
1502 Fix prototype for zlog_rotate.
1503 * command.c: (config_log_file) Remove unused 2nd arg to zlog_set_file.
1504 * vty.c: (vty_out) Fix stdarg usage to perform multiple traversals
1505 properly.
1506 (vty_log) Must use va_copy for multiple traversals of va_list arg.
1507
ajsca359762004-11-19 23:40:16 +000015082004-11-19 David Young <dyoung@pobox.com>
1509
1510 * log.c: (safe_strerror) New function: safe wrapper for strerror.
1511
ajsff29bb32004-11-19 18:29:22 +000015122004-11-19 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1513
1514 * sockopt.c: (setsockopt_so_recvbuf) Stop error message from being
1515 printed every time.
1516
ajsf858e492004-11-16 14:25:30 +000015172004-11-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1518
1519 * memory.h: Fix prototype for memory_init().
1520 * memory.c: Declare many functions and data structures static instead
1521 of global. Fix prototype for memory_init().
1522
gdt69e13252004-11-15 18:51:15 +000015232004-11-15 Greg Troxel <gdt@fnord.ir.bbn.com>
1524
1525 * sockopt.h: Avoid CMSG_ALIGN, and declare that sizes are without
1526 alignment (users should use CMSG_SPACE).
1527
1528 * zebra.h: Rationalize CMSG_SPACE compatibility defines. Warn if
1529 asumming 4-byte alignment, since this isn't safe.
1530
ajs7fa25ff2004-11-15 16:12:32 +000015312004-11-15 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1532
1533 * memory.c: (zerror) Use zlog_err instead of fprintf to stderr.
1534 Instead of exiting, log currenty memory usage and then abort.
1535 (log_memstats) New function to log memory statistics, called by
1536 zerror.
1537 (show_memory_all) Loop over new mlists array instead of calling
1538 show_memory_vty separately for each memory_list.
1539
paulb86718e2004-11-08 17:34:07 +000015402004-11-08 Paul Jakma <paul@dishone.st>
paulb35e5b42004-11-07 22:27:27 +00001541
paul2265d202004-11-08 15:43:21 +00001542 * buffer.c: Add missing include of log.h.
1543 (buffer_flush_available) written is compared against
1544 mostly against unsigned types, only for the writev do we need
1545 signed compare, so declare it as size_t and cast it to ssize_t
1546 just for the error compare when we've called writev.
1547 * buffer.h: Add comment that buffer data sizes really should be
1548 size_t.
1549
15502004-11-07 Paul Jakma <paul@dishone.st>
1551
1552 * version.h.in: add autoconf configure_input output var
paulb35e5b42004-11-07 22:27:27 +00001553
ajs49ff6d92004-11-04 19:26:16 +000015542004-11-04 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1555
ajs5a646652004-11-05 01:25:55 +00001556 * vty.h: Remove fields in struct vty that were related to VTY_CONTINUE
1557 capabilities (that were used only in bgpd/bgp_route.c and are now
1558 removed). Also remove some other fields that were not being
1559 used at all.
1560 * vty.c: (vty_execute) Do not test for obsolete status values VTY_START
1561 and VTY_CONTINUE.
1562 (vty_read) Remove calls to vty->output_func since that was part
1563 of the VTY_CONTINUE infrastructure that has been removed.
1564 (vty_flush) Remove code to support VTY_START and VTY_CONTINUE.
1565 (vty_close) Remove code to cancel vty->t_output thread, since that
1566 thread was never actually used.
1567
15682004-11-04 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
1569
ajs49ff6d92004-11-04 19:26:16 +00001570 * vty.c: Vtysh connections to daemons should use buffering.
1571 (vty_out) Remove exception for vty_shell_serv, just use buffer_write.
1572 (vty_new) Increase output buffer size to 4096 rounded up to a
1573 multiple of pagesize.
1574 (vtysh_read) After command has been executed and all output buffered,
1575 call buffer_flush_available and schedule further writes if the
1576 buffers are not yet empty.
1577 (vtysh_write) New function to flush output to vtysh when the socket
1578 is writeable.
1579 (vty_event) Added new VTYSH_WRITE event for flushing buffers to vtysh
1580 clients. Also, should save read thread in vty->t_read so the
1581 thread can be cancelled in vty_close.
1582 * buffer.h: In struct buffer_data, remove unused "parent" field.
1583 Convert "unsigned char *data" to "unsigned char data[0]" to save
1584 a malloc. Declare new function buffer_flush_available that works
1585 with non-blocking sockets.
1586 * buffer.c: (buffer_data_new) Use a single malloc now that data is
1587 a variable-size array at end of structure.
1588 (buffer_data_free) Just a single free now that data is part of the
1589 structure.
1590 (buffer_write) Simplify the logic to make behavior more transparent.
1591 (buffer_flush) Decrease b->length as data is written out.
1592 (buffer_flush_vty_all) Decrease b->length as buffers are freed.
1593 (buffer_flush_vty) Decrease b->length as data is written out.
1594 (buffer_flush_available) New function to flush non-blocking sockets.
1595
paule064d6d2004-11-01 08:59:21 +000015962004-11-01 Paul Jakma <paul@dishone.st>
1597
1598 * sockopt.c: (setsockopt_pktinfo) remove, its unused.
1599
paul75e15fe2004-10-31 02:13:09 +000016002004-10-31 Paul Jakma <paul@dishone.st>
1601
1602 * vty.c: As per Andrew's suggestions..
1603 (vty_serv_un) remove flags.
1604 (vtysh_accept) close socket if we cant set NONBLOCK. Add flags.
paul66cbbce2004-10-31 16:15:33 +00001605 * keychain.c: Convert some more strtoul users to VTY_GET_INTEGER.
paul9d11a192004-10-31 16:19:24 +00001606 * memory.h: Add MTYPE_THREAD_FUNCNAME and MTYPE_THREAD_STATS
1607 * thread.c: Update stats and funcname alloc/free to use previous
paul039b9572004-10-31 16:43:17 +00001608 specific memory type defines. Use XCALLOC and sizeof the type,
1609 not the pointer.
paul70e149e2004-10-31 16:29:50 +00001610 * smux.c: fix int to size_t compile warnings
paul75e15fe2004-10-31 02:13:09 +00001611
pauldccfb192004-10-29 08:29:36 +000016122004-10-29 Paul Jakma <paul@dishone.st>
1613
1614 * vty.c: Move setting of sock to O_NONBLOCK from vty_serv_un
1615 to vtysh_accept, where sock is the actual fd we wanted to set to
1616 O_NONBLOCK, ie the /connected/ vtysh unix socket.
1617
hasso508ec912004-10-23 14:26:49 +000016182004-10-23 Hasso Tepper <hasso at quagga.net>
1619
1620 * zclient.c: Unbreak reading interface update message. Might fix
1621 blocker bugzilla #109.
1622
paul23b9c612004-10-22 11:51:57 +000016232004-10-22 Paul Jakma <paul@dishone.st>
paul7d9c6e52004-10-22 10:54:39 +00001624
1625 * sockopt.c: (getsockopt_ipv4_ifindex) no ifindex should be 0, not
paul23b9c612004-10-22 11:51:57 +00001626 -1.
1627 (setsockopt_pktinfo) unexported
1628 * sockopt.h: Cleanup SOCKOPT_CMSG defines a bit. Add a throwaway
1629 define for SOPT_SIZE_CMSG_IFINDEX_IPV4 for systems which have
paul4ccb2c42004-10-22 22:52:33 +00001630 neither IP_RECVIF nor IP_PKTINFO (eg openbsd), thanks to Rivo
1631 Nurges for highlighting problem and fix.
paul4927cf02004-10-22 16:55:10 +00001632 Fix elif that should be an else.
paul406d6712004-10-22 12:27:44 +00001633 * command.h: Cleanup the defines a bit, add helper defines and
1634 collapse all defines to use those. Add an attribute field to
1635 cmd_element to support, eg hidden or deprecated commands, add
1636 defun defines for such. All that's left to do is add logic
1637 to command.c to check these attributes... ;)
paulaf0d97e2004-10-22 23:24:43 +00001638 * zebra.h: reserve ZEBRA_ROUTE_HSLS
paul7d9c6e52004-10-22 10:54:39 +00001639
hasso6590f2c2004-10-19 20:40:08 +000016402004-10-19 Hasso Tepper <hasso at quagga.net>
1641
1642 * version.h.in: Define copyright string QUAGGA_COPYRIGHT.
1643 * print_version.c: Remove. print_version () function moved to
1644 command.[c|h].
1645 * command.c: Use QUAGGA_COPYRIGHT.
1646 * Makefile.am: Remove useless version.c and print_version.c files.
1647
hasso3fb9cd62004-10-19 19:44:43 +000016482004-10-19 Andrew J. Schorr <aschorr@telemetry-investments.com>
1649
1650 * zclient.c: (zebra_interface_address_read) If the destination address
1651 is encoded as all zeroes, load it as a NULL pointer.
1652 * if.h: Add comment describing struct connected destination field
1653 and indicating that it may be NULL. Define macros
1654 CONNECTED_DEST_HOST and CONNECTED_POINTOPOINT_HOST to help
1655 with PtP logic (distinguish between host and subnet addressing).
1656 * if.c: (if_lookup_address) Fix PtP logic to handle subnet addressing
1657 properly,
1658 (connected_lookup_address) ditto.
1659 (connected_add_by_prefix) Handle case where destination is NULL,
1660 * prefix.[c|h]: New functions ipv4_network_addr and
1661 ipv4_broadcast_addr.
1662
hassoddd85ed2004-10-13 08:18:07 +000016632004-10-13 Hasso Tepper <hasso at quagga.net>
1664
1665 * command.c: Make CMD_ERR_NOTHING_TODO nonfatal if reading
1666 configuration from file. Fixes critical bugzilla #113.
hassoc75105a2004-10-13 10:33:26 +00001667 * smux.c, smux.h: Remove all defaults to initialize smux connection to
1668 snmpd by default even if not configured to do so. "smux peer OID
1669 <password>" initializes now connection and "no smux peer" terminates
1670 it.
hassoddd85ed2004-10-13 08:18:07 +00001671
paul42d49862004-10-13 05:22:18 +000016722004-10-13 Paul Jakma <paul@dishone.st>
1673
1674 * (global) more const'ification.
1675 * sockunion.c: (sockunion_su2str) buffer should be sized
1676 SU_ADDRSTRLEN.
1677 (sockunion_log) do not return stack variables, strdup buf before
1678 return.
1679 * vty.h: Fix up the VTY_GET_INTEGER macros. Testing caller supplied
1680 values against ULONG_MAX is daft, when caller probably has passed
1681 a type that can not hold ULONG_MAX. use a temporary long instead.
1682 Add VTY_GET_LONG, make VTY_GET_INTEGER_RANGE use it, make
1683 VTY_GET_INTEGER a define for VTY_GET_INTEGER_RANGE.
1684
hassoa1494112004-10-11 12:53:17 +000016852004-10-11 Hasso Tepper <hasso at quagga.net>
1686
1687 * command.h: Sync DEFUNSH with other macros.
1688 * sockunion.c, sockunion.h: More const strings.
1689
paul9076fbd2004-10-11 09:40:58 +000016902004-10-11 Paul Jakma <paul@dishone.st>
1691
1692 * thread.c: (funcname_thread_add_timer)
1693 (funcname_thread_add_timer_msec) Fix mistakes from last change.
1694 Pointed out by Liu Xin in [quagga-dev 1609].
paulc9eca012004-10-11 11:28:44 +00001695 * if.h: mtu's should be unsigned.
1696 * routemap.{c,h}: const char updates
1697 * smux.{c,h}: ditto
paul9076fbd2004-10-11 09:40:58 +00001698
paul9035efa2004-10-10 11:56:56 +000016992004-10-10 Paul Jakma <paul@dishone.st>
paul47ca2952004-10-10 08:03:18 +00001700
1701 * version.h.in: (pid_output*) add const qualifier.
paul9035efa2004-10-10 11:56:56 +00001702 * command.h: Change DEFUN func to take const char *[] rather
1703 than char **, to begin process of fixing compile warnings in lib/.
1704 Nearly all other changes in this commit follow from this change.
1705 * buffer.{c,h}: (buffer_write) pointer-arithmetic is gccism, take
1706 const void * and cast an automatic const char *p to it.
1707 (buffer_putstr) add const
1708 * command.c: (zencrypt) const qualifier
1709 (cmd_execute_command_real) ditto
1710 (cmd_execute_command_strict) ditto
1711 (config_log_file) ditto.
1712 Fix leak of getcwd() returned string.
1713 * memory.{c,h}: Add MTYPE_DISTRIBUTE_IFNAME for struct dist ifname.
1714 * distribute.{c,h}: Update with const qualifier.
1715 (distribute_free) use MTYPE_DISTRIBUTE_IFNAME
1716 (distribute_lookup) Cast to char *, note that it's ok.
1717 (distribute_hash_alloc) use MTYPE_DISTRIBUTE_IFNAME.
1718 (distribute_get) Cast to char *, note that it's ok.
1719 * filter.c: Update with const qualifier.
1720 * if.{c,h}: ditto.
1721 * if_rmap.{c,h}: ditto.
1722 (if_rmap_lookup) Cast to char *, note that it's ok.
1723 (if_rmap_get) ditto.
1724 * log.{c,h}: Update with const qualifier.
1725 * plist.{c,h}: ditto.
1726 * routemap.{c,h}: ditto.
1727 * smux.{c,h}: ditto. Fix some signed/unsigned comparisons.
1728 * sockopt.c: (getsockopt_cmsg_data) add return for error case.
1729 * vty.c: Update with const qualifier.
1730
hasso27a43a82004-10-08 06:29:12 +000017312004-10-08 Hasso Tepper <hasso at quagga.net>
1732
1733 * routemap.c, routemap.h: Make some string arguments const.
1734
paul5973ee72004-10-08 01:36:54 +000017352004-10-05 Paul Jakma <paul@dishone.st>
1736
1737 * version.h.in: print_version declaration is here, not in automake
1738 generated version.h.
1739
hassoea8e9d92004-10-07 21:32:14 +000017402004-10-08 Hasso Tepper <hasso at quagga.net>
1741
1742 * command.c, command.h: Make argument of cmd_make_strvec function
1743 const.
1744 * command.c: Make hostname commands usable in vtysh again.
1745
hasso6ad96ea2004-10-07 19:33:46 +000017462004-10-07 Hasso Tepper <hasso at quagga.net>
1747
1748 * command.c, pid_output.c, print_version.c, vty.c, vty.h: Make more
1749 strings const.
1750
hasso8c328f12004-10-05 21:01:23 +000017512004-10-05 Hasso Tepper <hasso at quagga.net>
1752
1753 * *.[c|h]: Make many strings cons and a lot of int -> unsigned int
1754 changes to fix warnings.
1755
paul96e27c92004-10-05 14:33:43 +000017562004-10-05 Paul Jakma <paul@dishone.st>
1757
1758 * sockopt.{c,h}: add sockopt_iphdrincl_swab_{htosys,systoh},
1759 functions to change byte order between system IP_HDRINCL order
1760 and host order.
paul98c91ac2004-10-05 14:57:50 +00001761 * thread.c: (funcname_thread_add_timer_timeval) new function, add
1762 timer at specified timeval.
1763 (funcname_thread_add_timer) use funcname_thread_add_timer_timeval.
1764 (funcname_thread_add_timer_msec) ditto
paul96e27c92004-10-05 14:33:43 +00001765
hassob04c6992004-10-04 19:10:31 +000017662004-10-04 Hasso Tepper <hasso at quagga.net>
1767
1768 * memory.c, memory.h: Make char * argument of strdup functions const.
1769 * prefix.c, prefix.h: Make many arguments const. Reorder stuff in
1770 header.
1771 * log.h: Make log message const in struct message.
1772 * log.c: Fix some indenting.
1773 * network.c, network.h: Make second argument of writen() const.
1774
hassoe7168df2004-10-03 20:11:32 +000017752004-10-03 Hasso Tepper <hasso at quagga.net>
1776
1777 * command.h: Introduce SERVICE_NODE for "service <...>" commands.
1778 * command.c: Don't initialize commands that don't make sense if vtysh
1779 is used.
1780 * vty.c: Make VTY_NODE appear in vtysh.
1781
hasso18a6dce2004-10-03 18:18:34 +000017822004-10-03 James R. Leu <jleu at mindspring.com>
1783
1784 * zclient.c, zclient.h: zclient functions for router id handling.
1785 * zebra.h: New message types for router id handling.
1786
paul9172ee02004-09-27 12:46:37 +000017872004-09-27 Paul Jakma <paul@dishone.st>
1788
1789 * zebra.h: Add WANT_OSPF_WRITE_FRAGMENT for ospfd
1790 to try to fragment oversized packets. Enabled only for Linux.
1791 Add HAVE_IP_HDRINCL_BSD_ORDER to define struct ip byte order,
1792 to consolidate various ad-hoc platform defines for same thing.
1793
hassoe473b032004-09-26 16:08:11 +000017942004-09-26 Hasso Tepper <hasso at quagga.net>
1795
1796 * vty.c, sockopt.c: Fix compiler warnings.
1797
hasso52dc7ee2004-09-23 19:18:23 +000017982004-09-23 Hasso Tepper <hasso at quagga.net>
1799
1800 * linklist.h: Remove list and listnode typedefs.
1801 * *.[c|h]: list -> struct list *, listnode -> struct listnode *.
1802
paul0b3acf42004-09-17 08:39:08 +000018032004-09-17 Paul Jakma <paul@dishone.st>
1804
paulb89e60c2004-09-21 15:43:13 +00001805 * sockopt.c: Add missing bracket
1806
18072004-09-17 Paul Jakma <paul@dishone.st>
1808
paul0b3acf42004-09-17 08:39:08 +00001809 * sockopt.{c,h}: Add setsockopt_so_recvbuf, for ripd and ripngd.
1810
paul33394762004-09-13 11:27:57 +000018112004-09-13 Paul Jakma <paul@dishone.st>
1812
1813 * command.c: Update the copyright string in the default motd.
1814
gdt630e4802004-08-31 17:28:41 +000018152004-08-31 David Wiggins <dwiggins@bbn.com>
1816
1817 * hash.c (hash_iterate): Save next pointer before calling
1818 procedure, so that iteration works even if the called procedure
1819 deletes the hash backet.
1820
1821 * linklist.h (listtail): new macro, not yet used.
1822
hasso34553cc2004-08-27 13:56:39 +000018232004-08-27 Hasso Tepper <hasso at quagga.net>
1824
1825 * command.c: Install "terminal length" commands only if vty is used.
1826 Vtysh will handle it itself.
1827
gdtafa43b22004-08-26 13:12:41 +000018282004-08-26 Greg Troxel <gdt@fnord.ir.bbn.com>
1829
1830 * sockopt.h: Define method-independent macro for callers of
1831 get_ifindex to use for cmsg length.
1832
paule6822762004-08-19 04:13:29 +000018332004-08-19 Paul Jakma <paul@dishone.st>
1834
paulefba6ce2004-08-25 13:47:16 +00001835 * zebra.h: add MAX and MIN defines (eg for ospf6d)
1836
18372004-08-19 Paul Jakma <paul@dishone.st>
1838
paule6822762004-08-19 04:13:29 +00001839 * sockopt.c: include sockopt.h
1840 rename some of the _pktinfo_ functions to _ifindex, where that is
1841 their purpose.
1842 (getsockopt_ipv6_pktinfo_ifindex) renamed to
1843 getsockopt_ipv6_ifindex.
1844 (setsockopt_ipv4_pktinfo) renamed to setsockopt_ipv4_ifindex
1845 (setsockopt_pktinfo) update with previous and add comment re
1846 AF_INET portability.
1847 (setsockopt_ifindex) generic ifindex function ala
1848 setsockopt_pktinfo.
1849 (getsockopt_ipv4_pktinfo_ifindex) renamed to
1850 getsockopt_ipv4_ifindex.
1851 (getsockopt_ipv4_ifindex) rejiggling to reduce repeated
1852 ifdef/elses. pktinfo case forgot to set ifindex.
1853 (getsockopt_pktinfo_ifindex) renamed to
1854 getsockopt_ifindex. update some calls to renamed functions.
1855 * sockopt.h: Update renamed exported functions
1856 Rename the CMSG_SIZE macros to IFINDEX.
1857 Guard IPv4 PKTINFO in a conditional define.
1858
paulc0618de2004-08-18 21:52:58 +000018592004-08-18 Paul Jakma <paul@dishone.st>
1860
1861 * vty.c: (vty_serv_un) set unix vty socket to nonblocking
1862 to prevent inadvertent blocking of daemons by use of
1863 vtysh. TODO: disentangle manual paging from the buffer_write
1864 path so that unix vty can use this path too and be reliable.
1865
gdt33f92322004-07-23 16:14:32 +000018662004-07-23 Greg Troxel <gdt@poblano.ir.bbn.com>
1867
1868 * sockopt.c (getsockopt_ipv4_pktinfo_ifindex): Make this compile
1869 on NetBSD, and add comments to make it less confusing. Change the
1870 sense of the SUNOS_5 test to make parallel structure between the
1871 variables and the code.
1872
paul4f7baa02004-07-23 15:11:07 +000018732004-07-23 Paul Jakma <paul@dishone.st>
1874
1875 * sockopt.h: Add SOPT_SIZE_CMSG_PKTINFO{_IPV{4,6}} define, for
1876 sizeof pktinfo as appropriate, to be used when allocating msg
1877 buffers. export setsockopt_pktinfo() and
1878 getsockopt_pktinfo_ifindex()
1879 * sockopt.c: (setsockopt_pktinfo_ifindex) new function to portably
1880 set received ifindex sock option.
1881 (getsockopt_pktinfo_ifindex) portably retrieve ifindex.
1882 (getsockopt_cmsg_data) retrieve indicated control info from
1883 message header.
1884 (getsockopt_ipv6_pktinfo_ifindex) ipv6 version of above.
1885 (setsockopt_ipv4_pktinfo) v4 version
1886 (setsockopt_pktinfo) the exported version
1887 (getsockopt_ipv4_pktinfo_ifindex) v4 specific version
1888 (getsockopt_pktinfo_ifindex) the exported version
1889
paul05c447d2004-07-22 19:14:27 +000018902004-07-14 Paul Jakma <paul@dishone.st>
1891
1892 * sigevent.c: (quagga_signal_handler) add a global caught flag, set
1893 the flags to a constant rather increment to be kinder.
1894 (quagga_sigevent_process) new function, to do core of what
1895 quagga_signal_timer did. dont block signals at all as sig->caught
1896 is volatile sig_atomic_t and should be safe to access from signal
1897 and normal contexts. The signal blocking is unneeded paranoia, but
1898 is left intact under an ifdef, should some platform require it.
1899 Check global caught flag before iterating through array.
1900 (quagga_signal_timer) nearly everything moved to
1901 quagga_sigevent_process. Left in under ifdef, in case some
1902 platform could use a regular timer check for signals.
1903 * sigevent.h: quagga_sigevent_process declaration.
1904 * thread.c: (thread_fetch) check for signals at beginning of
1905 scheduler loop, check for signals if select returns EINTR.
1906
gdtb7797132004-07-13 13:47:25 +000019072004-07-13 Greg Troxel <gdt@poblano.ir.bbn.com>
1908
1909 * sigevent.c: Don't block SIGTRAP and SIGKILL. Blocking SIGTRAP
1910 confuses gdb, at least on NetBSD 2.0_BETA, where the block
1911 succeeds.
1912
paul5510e832004-07-09 14:00:01 +000019132004-07-09 Paul Jakma <paul@dishone.st>
1914
1915 * Merge Kunihiro's 'show route-map' change and add
1916 compatibility aliases for route-map continue
paulb9790b32004-07-09 14:05:47 +00001917 * jhash.{c,h}: New files. Bob Jenkins' public domain hashing
1918 function, as implemented in linux kernel by David Miller.
paul5510e832004-07-09 14:00:01 +00001919
paulb06c14f2004-07-09 12:24:42 +000019202004-07-09 Juris Kalnins <juris@mt.lv>
1921
1922 * if.c: (if_cmp_func) fix for interface names where name is same,
1923 but one has no number, eg "devtyp" and "devtyp0".
1924
gdt87efd642004-06-30 17:36:11 +000019252004-06-30 Greg Troxel <gdt@poblano.ir.bbn.com>
1926
1927 * Makefile.am: Make libzebra shared.
1928
paul138ce752004-06-21 10:35:59 +000019292004-06-21 Paul Jakma <paul@dishone.st>
1930
1931 * ChangeLog: fix my last update config.h -> zebra.h ;)
1932 * zebra.h: Fix gcc check.
1933
paul02ff83c2004-06-11 11:27:03 +000019342004-06-11 Sowmini Varadhan <sowmini.varadhan@sun.com>
1935
1936 * filter.c: (access_list_remark_cmd) buffer_putstr doesnt need cast
1937 to u_char. (ipv6_access_list_remark_cmd) ditto.
1938 if.c: ditto
1939 * network.c: (readn/writen) pointer arg should be type u_char.
1940 * plist.c: needs to include stream.h, not declare stream functions
1941 internally.
1942 (various) Add static qualifier to internal functions.
1943 (prefix_list_type_str) extraneous breaks in switch statement.
1944 (ip_prefix_list_description_cmd) buffer_putstr doesnt need cast
1945 * stream.h: depends on plist.h and export stream_put_prefix
1946 * vty.c: (vty_<telnet option build functions>) should use
1947 unsigned char, telnet options are 0 -> 255.
1948 * zclient.c: various u_char<->char type cleanups.
1949 * zebra.h: Having to define CMSG_* can apply to more than just
1950 BSDI_NRL.
1951
paul51a87982004-06-09 10:36:05 +000019522004-06-09 Paul Jakma <paul@dishone.st>
1953
paul138ce752004-06-21 10:35:59 +00001954 * zebra.h: __attribute__ is a gcc'ism
paul51a87982004-06-09 10:36:05 +00001955
paul5228ad22004-06-04 17:58:18 +000019562004-06-04 Paul Jakma <paul@dishone.st>
1957
1958 * type mismatch fixes
1959
hasso6708fa32004-05-18 18:46:54 +000019602004-05-18 Hasso Tepper <hasso@estpak.ee>
1961
1962 * pqueue.[c|h]: Added as part of ospf6d merge from Zebra repository.
1963
paul0a589352004-05-08 11:48:26 +000019642004-05-08 Paul Jakma <paul@dishone.st>
1965
1966 * zclient.c (zapi_ipv4_route) Follow Sowmini's lead and describe
1967 message format.
1968
19692004-05-08 Sowmini Varadhan <sowmini.varadhan@sun.com>
1970
1971 * zclient.c: (zapi_ipv4_add) collapsed into zapi_ipv4_route
1972 (zapi_ipv4_delete) ditto.
1973 (zapi_ipv4_route) add/delete a route by way of cmd arg.
1974 (zapi_ipv6_add) collapsed into zapi_ipv6_route.
1975 (zapi_ipv6_delete) ditto.
1976 (zapi_ipv6_route) add/delete a route by way of cmd arg.
1977 (zebra_interface_address_delete_read) collapsed into
1978 zebra_interface_address_read.
1979 (zebra_interface_address_delete_read) ditto.
1980 (zebra_interface_address_read) read address add/delete messages
1981 by way of type argument. Describe command message format.
1982 (zebra_interface_add_read) Unconditionally read new ifmtu6 field.
1983 Describe command message format.
1984 (zebra_interface_state_read) Unconditionally read new ifmtu6 field.
1985 (zclient_redistribute_set) Collapsed into zclient_redistribute
1986 (zclient_redistribute_unset) ditto
1987 (zclient_redistribute) set/unset redistribution.
1988 (zclient_redistribute_default_set) Collapsed into
1989 zclient_redistribute_default.
1990 (zclient_redistribute_default_unset) ditto.
1991 (zclient_redistribute_default) Redistribute default set/unset.
1992 * zclient.h: delete zapi_ipv{4,6}_add, zapi_ipv{4,6}_delete. Add
1993 zapi_ipv{4,6}_route. delete zclient_redistribute_set/unset. Add
1994 zclient_redistribute. Ditto for
1995 zclient_redistribute_default_{set/unset}.
1996
paul4a7aac12004-05-08 05:00:31 +000019972004-05-08 Sowmini Varadhan <sowmini.varadhan@sun.com>
1998
1999 * if.h: Add mtu6 field to struct interface, IPv6 MTU may differ
2000 from IPv4, and Solaris treats the MTU's differently.
2001 Add connected_add_by_prefix, for use by later patch.
2002 * if.c: (connected_add_by_prefix) Add prefix to connected list.
2003 (if_flag_dump) Solaris: Dump IFF_IPv4/6 flag
2004 (if_dump) Dump mtu6 flag, for HAVE_IPV6.
paul22528292004-05-08 05:10:38 +00002005 * command.c: (sockunion_getsockname) use socklen_t for len.
2006 (sockunion_getpeername) ditto.
paul0a589352004-05-08 11:48:26 +00002007
paul31fcdd32004-04-21 11:00:43 +000020082004-04-21 Boris Kovalenko <boris@tagnet.ru>
2009
2010 * daemon.c: (daemon) fix check for error return from setsid
2011
paulc49b3062004-01-19 21:23:37 +000020122004-01-19 Paul Jakma <paul@dishone.st>
2013
2014 * sigevent.{c,h}: New files, implement event handled signals.
2015 see signal_init() in sigevent.h.
2016
jardinc32e1b52003-12-23 09:06:51 +000020172003-12-23 Vincent Jardin <jardin@6wind.com>
2018
2019 * {command.c, memory.c, vty.c, zebra.h}: Add isisd support
2020
gdt3dbf9962003-12-22 20:18:18 +000020212003-12-22 Greg Troxel <gdt@fnord.ir.bbn.com>
2022
2023 * vty.c (vty_use_backup_config): Don't free filenames before using
2024 them for unlink.
2025
paul54aba542003-08-21 20:28:24 +000020262003-08-20 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2027
2028 * command.c: Fix <cr> display problem for command line
2029 description
2030
paule9af5c72003-05-24 11:54:31 +000020312003-05-24 Anil Madhavapeddy
2032
2033 * (sockunion.c): Incorrect bounds specified in sockunion_log()
2034
paul445f1432003-05-16 19:00:31 +000020352003-05-08 Sergiy Vyshnevetskiy <serg @ vostok.net>
2036
2037 * vty.c: -A option
2038
20392003-04-19 Hasso Tepper <hasso@estpak.ee>
2040
2041 * rip_routemap.c: sync daemon's route-map commands to have same
2042 syntax
2043
paul718e3742002-12-13 20:15:29 +000020442002-09-28 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2045
2046 * vty.c (vty_flush): One line more on vty.
2047
20482002-09-27 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
2049
2050 * vector.c (vector_lookup): Add new function.
2051
20522002-08-19 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
2053
2054 * thread.c (timeval_adjust): Fix unconditional crush due to
2055 FreeBSD's select() system call timeval value check.
2056
20572002-07-07 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
2058
2059 * zebra-0.93 released.
2060
20612002-06-21 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
2062
2063 * if.c (ifc_pointopoint): Add ifc_pointopoint() accoding to Frank
2064 van Maarseveen's suggestion.
2065
20662002-06-18 Kunihiro Ishiguro <kunihiro@zebra.org>
2067
2068 * command.c: Change bcopy() to memcpy().
2069
20702001-12-12 Kunihiro Ishiguro <kunihiro@zebra.org>
2071
2072 * command.c (config_password): Fix host.password clear bug.
2073 Reported by Wang Jian <lark@linux.net.cn>.
2074
20752001-08-29 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
2076
2077 * thread.c (thread_should_yield): New function to check thread
2078 should yeild it's execution to other thread. Suggested by: Rick
2079 Payne <rickp@ayrnetworks.com>
2080
20812001-08-20 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
2082
2083 * thread.c (thread_timer_cmp): Rewrite function.
2084
2085 * hash.c: Add hash_get(). Change hash_pull() to hash_release().
2086
20872001-08-19 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
2088
2089 * zebra-0.92a released.
2090
20912001-08-15 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
2092
2093 * zebra-0.92 released.
2094
20952001-08-12 Akihiro Mizutani <mizutani@dml.com>
2096
2097 * prefix.c (netmask_str2prefix_str): Convert "1.1.0.0 255.255.0.0"
2098 string to "1.1.0.0/16".
2099
21002001-08-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2101
2102 * filter.c (access_list_lookup): access_list_lookup's first
2103 argument is changed from address family to AFI.
2104
2105 * plist.c: (prefix_list_lookup): Likewise.
2106
21072001-07-27 Akihiro Mizutani <mizutani@dml.com>
2108
2109 * plist.c: ge and le display order is changed. Old compatible
2110 rule (len <= ge-value <= le-value) is removed.
2111
21122001-07-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2113
2114 * prefix.h: Temporary fix for alignment of prefix problem.
2115
21162001-06-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2117
2118 * prefix.h (struct prefix): Remove safi and padding field.
2119 (struct prefix_ipv4): Likewise.
2120 (struct prefix_ipv6): Likewise.
2121 (struct prefix_ls): Likewise.
2122 (struct prefix_rd): Likewise.
2123
2124 * command.h (enum node_type): Preparation for BGP new config.
2125
2126 * vty.c (vty_end_config): Likewise.
2127
21282001-06-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2129
2130 * routemap.c (route_map_rule_delete): Call func_free when
2131 route-map rule is deleted.
2132
21332001-06-14 "Akihiro Mizutani" <mizutani@dml.com>
2134
2135 * routemap.c (route_map_index_lookup): Prevent to use deny and
2136 permit for same route-map sequence.
2137
21382001-04-12 Kunihiro Ishiguro <kunihiro@zebra.org>
2139
2140 * vty.c (vty_read_config): Fix warning.
2141
21422001-03-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2143
2144 * command.c (IPV6_PREFIX_STR): Add '.' and '%' for IPv6 address
2145 strings.
2146
21472001-03-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2148
2149 * zebra.h (_XPG4_2): Define _XPG4_2 and __EXTENSIONS__ for
2150 CMSG_FIRSTHDR.
2151
21522001-03-07 Michael Rozhavsky <mrozhavsky@opticalaccess.com>
2153
2154 * zebra.h (struct in_pktinfo): structure in_pktinfo declaration.
2155
21562001-02-19 Kunihiro Ishiguro <kunihiro@zebra.org>
2157
2158 * memory.c (memory_list_lib): Add MTYPE_NEXTHOP for "show memory
2159 lib" member.
2160
21612001-02-13 Matthew Grant <grantma@anathoth.gen.nz>
2162
2163 * vty.c (vty_read_config): Revert check of integrate_default when
2164 VTYSH is defined.
2165
21662001-02-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2167
2168 * vty.c (vty_read_config): Do not check integrate_default. That
2169 should be used only by vtysh.
2170
21712001-02-08 Matthew Grant <grantma@anathoth.gen.nz>
2172
2173 * vty.c (vty_serv_un): Set umask 0077.
2174 (vty_read_config): Stat for vtysh Zebra.conf, if found startup and
2175 wait for boot configuration.
2176
2177 * if.c (if_lookup_address): Make it smart implementation.
2178
2179 * sockopt.c (setsockopt_multicast_ipv4): Set up a multicast socket
2180 options for IPv4 This is here so that people only have to do their
2181 OS multicast mess in one place rather than all through zebra,
2182 ospfd, and ripd .
2183
21842001-02-04 Akihiro Mizutani <mizutani@dml.com>
2185
2186 * plist.c (vty_prefix_list_install): Even when argument is
2187 invalid, new memory is allocated. Now memory allocation is done
2188 after argument check.
2189
21902001-02-01 Kunihiro Ishiguro <kunihiro@zebra.org>
2191
2192 * zebra-0.91 is released.
2193
21942001-01-31 Akihiro Mizutani <mizutani@dml.com>
2195
2196 * vty.c (vty_login): Add vty login command.
2197
21982001-01-31 Kunihiro Ishiguro <kunihiro@zebra.org>
2199
2200 * vty.c (vty_reset): Close accept socket.
2201
22022001-01-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2203
2204 * memory.h (enum): MTYPE_ATTR_TRANSIT is added for unknown transit
2205 attribute.
2206
22072001-01-22 Kunihiro Ishiguro <kunihiro@zebra.org>
2208
2209 * zclient.c (zebra_interface_address_add_read): Fetch interface
2210 address flag.
2211 (zebra_interface_address_delete_read): Likewise.
2212
22132001-01-16 Kunihiro Ishiguro <kunihiro@zebra.org>
2214
2215 * table.c (route_node_match_ipv4): Utility function for IPv4
2216 address lookup.
2217 (route_node_match_ipv6): Utility function for IPv4 address lookup.
2218
22192001-01-15 Kunihiro Ishiguro <kunihiro@zebra.org>
2220
2221 * if.c: Delete RIP_API part until new implementation comes out.
2222
22232001-01-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2224
2225 * hash.h (struct Hash): Rename alloc to count. Change type to
2226 unsigned long.
2227
2228 * stream.c (stream_getc_from): New function.
2229 (stream_getw_from): Likewise.
2230
2231 * zebra.h (ZEBRA_FLAG_STATIC): Add new flag for persistent route.
2232
22332001-01-11 Kunihiro Ishiguro <kunihiro@zebra.org>
2234
2235 * flap.c: File is removed.
2236
2237 * flap.c: Likewise.
2238
2239 * roken.h: Likewise.
2240
2241 * buffer.c (buffer_new): Remove type option to buffer_new().
2242
22432001-01-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2244
2245 * zclient.c (zapi_ipv4_delete): Remove OLD_RIB part.
2246
22472001-01-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2248
2249 * zebra-0.90 is released.
2250
2251 * command.c: Update Copyright year.
2252
22532001-01-09 Matthew Grant <grantma@anathoth.gen.nz>
2254
2255 * if.c (if_create): Register connected_free() function for
2256 deletion.
2257 (if_delete): Free connected information when the interface is
2258 deleted.
2259 (if_lookup_by_index): Fix argument type from int to unsigned int.
2260 (connected_add): Keep list in order if old info found, essential
2261 for repeatable operation in some daemons.
2262
22632001-01-09 endo@suri.co.jp (Masahiko Endo)
2264
2265 * vty.c (vty_flush): When vty->statis is VTY_CLOSE do not add vty
2266 read thread.
2267
22682001-01-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2269
2270 * filter.c (access_list_delete): Access-list name is not freed.
2271
2272 * plist.c (prefix_list_delete): Prefix-list name is not freed.
2273
22742000-12-29 Kunihiro Ishiguro <kunihiro@zebra.org>
2275
2276 * zclient.c (zclient_start): Change to use UNIX domain
2277 socket for zebra communication.
2278
2279 * vector.c (vector_init): vector_alloc and vector_data_alloc is
2280 removed. All memory allocation count should be maintained by
2281 XMALLOC and XFREE macros.
2282
22832000-12-28 Kunihiro Ishiguro <kunihiro@zebra.org>
2284
2285 * zebra.h (ZEBRA_NEXTHOP_IFINDEX): Define ZEBRA_NEXTHOP_* values.
2286
22872000-12-27 Kunihiro Ishiguro <kunihiro@zebra.org>
2288
2289 * zebra.h (ZEBRA_ERR_RTEXIST): Make zebra error code to negative
2290 value.
2291
22922000-12-25 "Wataru Uno" <wataru@po.ntts.co.jp>
2293
2294 * vty.c (vtysh_read): Don't allocate new buffer because buffer is
2295 allocated in vty_new ().
2296
22972000-12-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2298
2299 * memory.h (enum): Add MTYPE_AS_FILTER_STR.
2300
2301 * command.c (config_write_terminal): Display "end" at the end of
2302 configuration.
2303
2304 * plist.c (vty_prefix_list_install): Use AF_INET to determine
2305 lenum length.
2306
23072000-12-13 "Wataru Uno" <wataru@po.ntts.co.jp>
2308
2309 * buffer.c (buffer_flush_vty): If IOV_MAX defined in the System,
2310 then all lines write by IOV_MAX.
2311
23122000-12-12 Michael Rozhavsky <mrozhavsky@opticalaccess.com>
2313
2314 * command.c (config_write_file): Robust method for writing
2315 configuration file and recover from backing up config file.
2316
23172000-11-29 Kunihiro Ishiguro <kunihiro@zebra.org>
2318
2319 * smux.c (smux_connect): More fail check.
2320 (smux_trap): When SMUX connection is not established, do nothing.
2321
23222000-11-28 Gleb Natapov <gleb@nbase.co.il>
2323
2324 * thread.c (thread_fetch): Execut event list first. Old event
2325 list is renamed to ready list. With this change, event thread is
2326 executed before any other thread.
2327
2328 * thread.h (struct thread_master): Add ready list.
2329
23302000-11-28 Kunihiro Ishiguro <kunihiro@zebra.org>
2331
2332 * linklist.c (listnode_add_after): Add node right after the
2333 listnode pointer.
2334
23352000-11-27 Kunihiro Ishiguro <kunihiro@zebra.org>
2336
2337 * smux.h: Pass struct variable to WriteMethod.
2338
23392000-11-25 Frank van Maarseveen <F.vanMaarseveen@inter.NL.net>
2340
2341 * if.c (if_lookup_address): When looking up interface with IP
2342 address, Sometimes multiple interfaces will match. Now PtP
2343 interfaces prevail in such a case which seem the right thing to
2344 do: There will probably also be host routes which usually prevail
2345 over network routes.
2346
23472000-11-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2348
2349 * smux.c (smux_trap): SMUX trap implementation.
2350
23512000-11-19 Akihiro Mizutani <mizutani@dml.com>
2352
2353 * plist.c: Add automatic conversion function of an old rule.
2354 ex.) 10.0.0.0/8 ge 8 -> 10.0.0.0/8 le 32
2355
23562000-11-16 Yon Uriarte <ukl2@rz.uni-karlsruhe.de>
2357
2358 * zclient.c (zebra_interface_add_read): Read hardware address when
2359 hw_addr_len is greater than 0.
2360
23612000-11-15 Akihiro Mizutani <mizutani@dml.com>
2362
2363 * plist.c: The rule of "len <= ge-value <= le-value"
2364 was changed to "len < ge-value <= le-value".
2365
23662000-11-09 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2367
2368 * memory.[ch]: Added #define and functions for ospf6d.
2369
2370 * log.[ch]: some platform says that the data of used va_list
2371 is undefined. Changed to hold list of va_list for each
2372 vsnprintf.
2373
23742000-11-07 Rick Payne <rickp@rossfell.co.uk>
2375
2376 * memory.h (enum): Add MTYPE_COMMUNITY_REGEXP.
2377
23782000-11-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2379
2380 * command.c (config_exit): Fix bug of missing break after case
2381 BGP_VPNV4_NODE.
2382
23832000-10-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2384
2385 * vector.c (vector_unset): Check i is not nevative.
2386
23872000-10-24 Arkadiusz Miskiewicz <misiek@pld.org.pl>
2388
2389 * smux.c (smux_sock): Set terminating '\0'. Check address family.
2390
2391 * vty.c (vty_serv_sock_addrinfo): Set terminating '\0'. Use
2392 gai_strerror. Check address family.
2393
23942000-10-23 Jochen Friedrich <jochen@scram.de>
2395
2396 * smux.c: Use linklist rather than vector.
2397 (smux_getnext): A SMUX subagent has to behave as if it manages the
2398 whole SNMP MIB tree itself. It's the duty of the master agent to
2399 collect the best answer and return it to the manager. See RFC 1227
2400 chapter 3.1.6 for the glory details :-). ucd-snmp really behaves
2401 bad here as it actually might ask multiple times for the same
2402 GETNEXT request as it throws away the answer when it expects it in
2403 a different subtree and might come back later with the very same
2404 request.
2405
24062000-10-23 Kunihiro Ishiguro <kunihiro@zebra.org>
2407
2408 * command.c (cmd_init): Log related command are only installed for
2409 terminal mode.
2410
24112000-10-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2412
2413 * Makefile.am (libzebra_a_SOURCES): Remove duplicated buffer.c.
2414
2415 * zebra.h: Remove #warn directive.
2416
24172000-10-20 Kunihiro Ishiguro <kunihiro@zebra.org>
2418
2419 * keychain.c (keychain_init): Register "key chain" command to
2420 KEYCHAIN_NODE and KEYCHAIN_KEY_NODE.
2421
2422 * vty.c (vty_end_config): Fix missing vty_cinfig_unlock for other
2423 CONFIG_NODE.
2424
2425 * command.c (config_end): Likewise.
2426
2427 * keychain.c (keychain_get): Key is sorted by it's identifier
2428 value.
2429
24302000-10-19 Kunihiro Ishiguro <kunihiro@zebra.org>
2431
2432 * linklist.c (list_delete_all_node): Call delete function if it is
2433 defined.
2434
2435 * command.c (cmd_execute_command_strict): Add modification for
2436 vtysh.
2437 (cmd_execute_command_strict): Remove first argument cmdvec because
2438 it is global varibale in command.c.
2439
24402000-10-18 Kunihiro Ishiguro <kunihiro@zebra.org>
2441
2442 * command.c (cmd_init): Install
2443 copy_runningconfig_startupconfig_cmd only in terminal mode.
2444
2445 * linklist.c (list_delete_node): Simplify the function.
2446 (listnode_lookup): Renamed from list_lookup_node.
2447
24482000-10-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2449
2450 * stream.h: Undef stream_read and stream_write without
2451 parenthesis.
2452
2453 * newlist.c: File removed.
2454
2455 * newlist.h: Likewise.
2456
2457 * linklist.c (list_new): Remove list_init(). To allocate new
2458 linked list, please use list_new().
2459 (listnode_add): Remove list_add_node(). To add new node to linked
2460 list, please use listnode_add().
2461 (list_delete_by_val): Revemove fucntion.
2462
24632000-10-16 Nobuaki Tanaka <nobby@po.ntts.co.jp>
2464
2465 * table.c (route_table_free): Reimplement route_table_free().
2466
24672000-10-11 Kunihiro Ishiguro <kunihiro@zebra.org>
2468
2469 * keychain.c (keychain_get): Register key_delete_func to key
2470 list's delete function. Use linklist.c instead of newlist.c.
2471
24722000-10-04 Akihiro Mizutani <mizutani@dml.com>
2473
2474 * filter.c (access_list_remark): Add access-list's remark command.
2475 (no_access_list): "no access-list 100 permit any" error message
2476 bug is fixed.
2477
24782000-10-03 Kunihiro Ishiguro <kunihiro@zebra.org>
2479
2480 * memory.h (enum): Add MTYPE_SOCKUNION.
2481
24822000-10-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2483
2484 * zebra-0.89 is released.
2485
24862000-10-01 Kunihiro Ishiguro <kunihiro@zebra.org>
2487
2488 * linklist.c (list_add_node_head): Delete unused function.
2489 (list_add_node_tail): Likewise.
2490
24912000-09-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2492
2493 * stream.c (stream_read_unblock): Add new function for unblocking
2494 read.
2495
24962000-09-26 Jochen Friedrich <jochen@nwe.de>
2497
2498 * smux.c (smux_register): Fix bug of can't register more than one
2499 MIB with SMUX.
2500
25012000-09-26 Makoto Otsuka <otsuka@inl.ntts.co.jp>
2502
2503 * vty.c (vty_close): Fix memory leak of sb_buffer.
2504 (vty_new): Likewise.
2505
25062000-09-21 steve@Watt.COM (Steve Watt)
2507
2508 * log.h: Do not declare zlog_priority[0] variable.
2509
25102000-09-12 Kunihiro Ishiguro <kunihiro@zebra.org>
2511
2512 * linklist.h (struct _list ): Add member cmp for compare function.
2513 (struct _list ): Member up is deleted
2514
25152000-09-12 David Lipovkov <dlipovkov@OpticalAccess.com>
2516
2517 * if.c: Include RIP_API header when RIP API is enabled.
2518
25192000-09-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2520
2521 * prefix.c (prefix_free): Siplify prefix_free().
2522
2523 * keychain.c (key_match_for_accept): strncmp check bug is fixed.
2524
25252000-09-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2526
2527 * zebra.h: Merge roken.h into zebra.h.
2528
25292000-09-05 Akihiro Mizutani <mizutani@dml.com>
2530
2531 * routemap.c (route_map_init_vty): Install route-map command to
2532 RMAP_NODE.
2533
25342000-08-22 Kunihiro Ishiguro <kunihiro@zebra.org>
2535
2536 * thread.c (thread_get_id): Remove pthread related garbage.
2537
2538 * command.h (struct host): Likewise.
2539
2540 * zebra.h: Likewise.
2541
25422000-08-20 Kunihiro Ishiguro <kunihiro@zebra.org>
2543
2544 * command.h (node_type ): Add AAA node for authentication.
2545
2546 * vty.c (vty_close): Do not close stdout.
2547
25482000-08-18 Kunihiro Ishiguro <kunihiro@zebra.org>
2549
2550 * vty.c (vty_init_vtysh): Added for vtysh.
2551
2552 * distribute.c (districute_list_prefix_all): Interface independent
2553 filter can be set.
2554 (distribute_list_all): Likewise.
2555 (config_show_distribute): Display current distribute-list status
2556 for "show ip protocols".
2557
25582000-08-18 Akihiro Mizutani <mizutani@dml.com>
2559
2560 * command.c (config_terminal_no_length): no terminal monitor ->
2561 terminal no monitor
2562 (cmd_init): Do not install service_terminal_length_cmd into
2563 ENABLE_NODE.
2564
2565 * vty.c (terminal_no_monitor): no terminal length -> terminal no
2566 length.
2567
25682000-08-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2569
2570 * zebra-0.88 is released.
2571
25722000-08-17 Magnus Ahltorp <ahltorp@nada.kth.se>
2573
2574 * vty.h (struct vty ): Add iac_sb_in_progress and sb_buffer for
2575 better IAC handling.
2576
2577 * vty.c (vty_telnet_option): Change telnet option handling.
2578
25792000-08-15 Gleb Natapov <gleb@nbase.co.il>
2580
2581 * zclient.c (zclient_redistribute_unset): New function added.
2582
25832000-08-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2584
2585 * zclient.c (zebra_interface_add_read): Change ifindex restore
2586 size from two octet to four.
2587 (zebra_interface_state_read): Likewise.
2588 (zebra_interface_address_add_read): Likewise.
2589
25902000-08-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2591
2592 * vty.c (vty_event): Use vector_set_index() instead of
2593 vector_set().
2594
25952000-08-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2596
2597 * zebra.h (ZEBRA_XXX_DISTANCE_DEFAULT): Define Default
2598 Administrative Distance of each protocol.
2599
26002000-08-07 Matthew Grant <grantma@anathoth.gen.nz>
2601
2602 * if.h (struct interface ): Add new member bandwidth to struct
2603 interface.
2604
2605 * zclient.c (zebra_interface_add_read): Fetch bandwidth value.
2606 (zebra_interface_state_read): Likewise.
2607
26082000-08-07 Gleb Natapov <gleb@nbase.co.il>
2609
2610 * routemap.c (route_map_event_hook): New hook route_map_event_hook
2611 is added. This hook is called when route-map is changed. The
2612 parameters passed to the hook are 'event' and 'route-map name'
2613
2614 * routemap.h: Add prototype for route_map_event_hook().
2615
26162000-08-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2617
2618 * zclient.c (zebra_ipv4_route): zebra_ipv4_route(),
2619 zebra_ipv4_add(), zebra_ipv4_delete() are removed.
2620
2621 * routemap.c (route_map_empty): Add new function.
2622 (route_map_delete): Use route_map_index_delete() instead of
2623 route_map_index_free().
2624 (route_map_index_free): Function removed.
2625
26262000-08-06 Gleb Natapov <gleb@nbase.co.il>
2627
2628 * routemap.c (route_map_index_delete): Add check for route-map is
2629 empty or not.
2630
26312000-08-03 Kunihiro Ishiguro <kunihiro@zebra.org>
2632
2633 * zclient.c (zebra_ipv4_add): Change socket arguemnt with struct
2634 zclient.
2635
26362000-08-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2637
2638 * zclient.h (struct zebra): Add obuf for output buffer.
2639
2640 * if.c: Remove #ifdef NRL enclosing if_nametoindex() and
2641 if_indextoname().
2642
26432000-08-02 David Lipovkov <davidl@nbase.co.il>
2644
2645 * if.h (IF_PSEUDO_UNSET): IF_PSEUDO related macro added.
2646 (IF_UNKNOWN_SET): IF_UNKNOWN related macro deleted.
2647
2648 * if.c (interface_pseudo): Add "pseudo" command to interface node.
2649 (no_interface_pseudo): Add "no pseudo" command to interface node.
2650
2651 * zclient.c (zebra_interface_add_read): Set pseudo flag when it is
2652 send from zebra.
2653
26542000-08-01 Kunihiro Ishiguro <kunihiro@zebra.org>
2655
2656 * zebra.h (ZEBRA_IPV4_NEXTHOP_LOOKUP): Add new message.
2657 (ZEBRA_IPV6_NEXTHOP_LOOKUP): Likewise.
2658
2659 * vty.c (vty_serv_un): Use AF_UNIX for backward compatibility.
2660
26612000-07-31 Kunihiro Ishiguro <kunihiro@zebra.org>
2662
2663 * vty.c: Use vector for VTY server thread listing instead of
2664 single value.
2665
26662000-07-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2667
2668 * keychain.c (no_key_chain): "no key chain WORD" command is added.
2669
26702000-07-29 Kunihiro Ishiguro <kunihiro@zebra.org>
2671
2672 * command.c (config_from_file): If command fail in
2673 KEYCHAIN_KEY_NODE, down to KEYCHAIN_NODE.
2674
2675 * vty.h (struct vty ): Add index_sub member.
2676
26772000-07-27 Akihiro Mizutani <mizutani@dml.com>
2678
2679 * if.c: Help strings updates.
2680
26812000-07-11 Akihiro Mizutani <mizutani@dml.com>
2682
2683 * command.c (no_config_enable_password): Add "no enable password"
2684 command.
2685 (config_write_host): Display password string.
2686
2687 * routemap.c (route_map_delete_match): Add support for delete
2688 match without argument.
2689 (route_map_delete_set): Likewise.
2690
26912000-07-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2692
2693 * command.h (node_type ): Change KEYCHAIN_NODE and
2694 KEYCHAIN_KEY_NODE place just before INTERFACE_NODE.
2695
26962000-07-09 Jochen Friedrich <jochen@scram.de>
2697
2698 * smux.c (config_write_smux): Fixes the option to override OID and
2699 password for SMUX.
2700
27012000-07-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2702
2703 * command.h (node_type ): Add SMUX_NODE for SMUX configuration.
2704
27052000-07-09 Toshiaki Takada <takada@zebra.org>
2706
2707 * command.c: Sort descvec command's help.
2708
2709 * vty.c (vty_describe_command): Display '<cr>' at the end of
2710 descriptions.
2711
27122000-07-05 Toshiaki Takada <takada@zebra.org>
2713
2714 * command.c (cmd_ipv6_match), (cmd_ipv6_prefix_match): Fix bug
2715 treatment of double colon.
2716
27172000-07-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2718
2719 * zclient.h: Add zclient_redistribute_default_{set,unset}().
2720
2721 * keychain.c: New file for authentication key management.
2722 * keychain.h: Likewise.
2723
2724 * tcpfilter.c: New file for TCP/UDP base filtering using ipfw or
2725 ipchains.
2726 * tcpfilter.h: Likewise.
2727
2728 * flap.h: New file for route flap dampening.
2729 * flap.c: Likewise.
2730
27312000-07-04 Toshiaki Takada <takada@zebra.org>
2732
2733 * filter.c (struct filter): Add exact flag.
2734 (access_list): Add exact-match command.
2735 (ipv6_access_list): Add exact-match command.
2736
27372000-07-03 Kunihiro Ishiguro <kunihiro@zebra.org>
2738
2739 * zebra.h (ZEBRA_REDISTRIBUTE_DEFAULT_ADD): New message for
2740 request default route.
2741
27422000-07-01 Hideaki YOSHIFUJI ($B5HF#1QL@(B) <yoshfuji@ecei.tohoku.ac.jp>
2743
2744 * smux.c: Add IPv6 smux connection code.
2745
27462000-06-15 Kunihiro Ishiguro <kunihiro@zebra.org>
2747
2748 * vty.c (vty_complete_command): To cooperate readline library,
2749 returned string is newly allocated. So some match function case
2750 need, free of memory.
2751
27522000-06-12 Akihiro Mizutani <mizutani@dml.com>
2753
2754 * distribute.c: Fix help strings.
2755
27562000-06-11 Kunihiro Ishiguro <kunihiro@zebra.org>
2757
2758 * command.c (cmd_complete_command): Add check for vector_slot
2759 (vline, index) is not NULL when calculating lcd.
2760 (cmd_entry_function): First check variable arguemnt to prevent it
2761 from completion.
2762
27632000-06-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2764
2765 * vty.h (struct vty ): Add output_count member for displaying
2766 output route count. Remove arugment arg from output_func because
2767 the value is passed by vty argument. Change output to output_rn.
2768 Add output_clean function pointer member. Add output_type member.
2769
27702000-06-10 Toshiaki Takada <takada@zebra.org>
2771
2772 * command.c (show_startup_config): Add "show startup-config"
2773 command.
2774
27752000-06-06 Akihiro Mizutani <mizutani@dml.com>
2776
2777 * filter.c: Fix help strings.
2778
27792000-06-05 Kunihiro Ishiguro <kunihiro@zebra.org>
2780
2781 * prefix.h (struct prefix_rd): New prefix structure for routing
2782 distinguisher.
2783 (struct prefix): Add padding to every prefix structure.
2784
2785
2786 * routemap.c (route_map_add_match): When completely same match
2787 statement exists, don't duplicate it.
2788
27892000-06-05 Akihiro Mizutani <mizutani@dml.com>
2790
2791 * routemap.c: Change NAME to WORD.
2792
2793 * plist.c: Fix help strings.
2794
27952000-06-02 Akihiro Mizutani <mizutani@dml.com>
2796
2797 * routemap.c: Fix route-map help strings.
2798
27992000-06-01 Kunihiro Ishiguro <kunihiro@zebra.org>
2800
2801 * command.c (cmd_filter_by_completion): Fix CMD_VARARG treatment
2802 to filter other non vararg commands.
2803
2804 * routemap.c (route_map_init_vty): Use install_default() for
2805 install common commands into route-map node..
2806
28072000-06-01 Akihiro Mizutani <mizutani@dml.com>
2808
2809 * command.h (OSPF_STR): Macro added.
2810
28112000-05-31 Kunihiro Ishiguro <kunihiro@zebra.org>
2812
2813 * command.c (cmd_complete_command): LCD completion must not modify
2814 installed command string.
2815
2816 * plist.c (ipv6_prefix_list): Fix wrong syntax definition. Change
2817 X:X::X:X to X:X::X:X/M.
2818
28192000-05-31 Toshiaki Takada <takada@zebra.org>
2820
2821 * vty.c (show_history): New defun added.
2822
28232000-05-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2824
2825 * command.h (CMD_COMPLETE_LIST_MATCH): New define for completion
2826 list. CMD_COMPLETE_MATCH is used for LCD completion.
2827
2828 * vty.c (vty_complete_command): Matched string's LCD is completed.
2829
2830 * command.c (cmd_lcd): New function for calculate LCD of matched
2831 strings.
2832
28332000-05-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2834
2835 * command.c (install_default): config_write_terminal_cmd,
2836 config_write_file_cmd, config_write_memory_cmd are added to
2837 default node.
2838
2839 * memory.c (memory_init): Divide show memory command into each
2840 sort.
2841
2842 * command.c (cmd_init): config_write_terminal_cmd,
2843 config_write_file_cmd, config_write_memory_cmd are added to
2844 CONFIG_NODE.
2845
2846 * routemap.c (route_map_index_free): New function.
2847 (no_route_map_all): New DEFUN for "no route-map NAME".
2848
2849 * filter.c (no_access_list_all): New DEFUN for delete access-list
2850 with NAME.
2851 (no_ipv6_access_list_all): Likewise.
2852
28532000-05-23 Kunihiro Ishiguro <kunihiro@zebra.org>
2854
2855 * plist.c: Change IPV6_PREFIX to X:X::X:X. When "any" is
2856 specified, user can not use "ge" and "le" statement.
2857
28582000-05-22 Thomas Molkenbur <tmo@datus.datus.com>
2859
2860 * routemap.c (route_map_add_set): Fix bug of next pointer missing.
2861
2862 * table.c (route_table_free): Like wise.
2863
28642000-05-22 Toshiaki Takada <takada@zebra.org>
2865
2866 * vty.c (vty_stop_input): Set history pointer to the latest one.
2867
2868 * vty.c (vty_hist_add): Do not add command line history when input
2869 is as same as previous one.
2870
28712000-05-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2872
2873 * memory.h (enum): Add MTYPE_ECOMMUNITY and MTYPE_ECOMMUNITY_VAL.
2874
28752000-05-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2876
2877 * command.h (node_type ): Add BGP_VPNV4_NODE.
2878
28792000-05-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2880
2881 * vty.c (vtysh_accept): Add cast of struct sockaddr * to bind
2882 argument. Reported by: Vesselin Mladenov <mladenov@netbg.com>.
2883
2884 * filter.c (ipv6_access_list): Add IPv6 prefix example instead of
2885 IPv4 example. Reported by: Love <lha@s3.kth.se>.
2886
2887 * command.c (cmd_complete_command): Make it sure last element of
2888 matchvec is NULL. This fix problem which cause crush in
2889 vty_complete_command(). Reported by: JINMEI Tatuya
2890 <jinmei@isl.rdc.toshiba.co.jp>.
2891
28922000-04-28 Love <lha@s3.kth.se>
2893
2894 * prefix.h (struct prefix): Add padding.
2895
28962000-04-28 Kunihiro Ishiguro <kunihiro@zebra.org>
2897
2898 * command.c (show_version): Update copyright year.
2899
29002000-04-27 Kunihiro Ishiguro <kunihiro@zebra.org>
2901
2902 * routemap.c (route_map_apply): When map is NULL, return deny.
2903
29042000-04-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2905
2906 * filter.c (access_list_apply): When access is NULL, return deny.
2907
2908 * plist.c (prefix_list_apply): When plist is NULL, return deny.
2909
29102000-04-23 Kunihiro Ishiguro <kunihiro@zebra.org>
2911
2912 * command.h (node_type ): Change RDISC_NODE to IRDP_NODE.
2913
29142000-04-18 Toshiaki Takada <takada@zebra.org>
2915
2916 * filter.[ch] (access_list_add_hook), (access_list_delete_hook):
2917 Add argument for hook function to give struct access_list *.
2918
29192000-04-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2920
2921 * plist.c (prefix_list_entry_match): In case of le nor ge is
2922 specified, exact match is performed.
2923 (prefix_list_entry_match): Add any entry matching check.
2924
29252000-04-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2926
2927 * vty.c (exec_timeout): Separate timeout setting to minutes and
2928 seconds.
2929 (no_exec_timeout): Add "no exec-timeout" command.
2930
2931 * vty.h (VTY_TIMEOUT_DEFAULT): Change default value from 300 to
2932 600.
2933
29342000-03-31 Jochen Friedrich <jochen@scram.de>
2935
2936 * smux.h (SMUX_CLOSE): The SMUX_CLOSE PDU is implicit integer, so
2937 it is a primitive encoding and not constructed.
2938
29392000-03-28 Toshiaki Takada <takada@zebra.org>
2940
2941 * memory.[ch] (enum): Add MTYPE_OSPF_EXTERNAL_INFO.
2942
29432000-03-26 Love <lha@s3.kth.se>
2944
2945 * zclient.c (zclient_read): Add nbytes size check for
2946 ZEBRA_HEADER_SIZE. Check return value of steam_read ().
2947
29482000-03-26 Rick Payne <rickp@rossfell.co.uk>
2949
2950 * routemap.c: Add flexible route-map commands such as on-match
2951 next, on-match goto N.
2952
2953 * routemap.h: Likewise
2954
29552000-03-23 Adrian Bool <aid@u.net.uk>
2956
2957 * command.c (config_log_trap): Add new command "log trap
2958 PRIORITY".
2959
29602000-03-14 Toshiaki Takada <takada@zebra.org>
2961
2962 * memory.c (struct memory_list): Add Link List and Link Node
2963 to view.
2964
2965 * memory.h (enum): Remove MTYPE_OSPF_EXTERNAL_ROUTE.
2966
29672000-01-20 Hideto Yamakawa <hideto.yamakawa@soliton.co.jp>
2968
2969 * str.c (snprintf): Fix bug of calling sprintf instead of
2970 vsprintf.
2971
29722000-01-16 Kunihiro Ishiguro <kunihiro@zebra.org>
2973
2974 * memory.h (enum): Add MTYPE_RIP_PEER.
2975
29762000-01-15 Toshiaki Takada <takada@zebra.org>
2977
2978 * memory.h (enum): Add MTYPE_OSPF_CRYPT_KEY.
2979
29802000-01-15 Kunihiro Ishiguro <kunihiro@zebra.org>
2981
2982 * command.h (node_type ): Add MASC_NODE for masc.
2983
29842000-01-09 Wang Jianliang <wangjl@soim.net>
2985
2986 * routemap.c (route_map_index_add): When route_map_index is not
2987 empty and insert new item at the head, it can cause core dump.
2988 Fix "if (index == map->head)" to "if (point == map->head).
2989 (route_map_add_set): If there is an old set command, override old
2990 set command with new one.
2991 (route_map_index_delete): Use while() instead of for for() for
2992 logical correctness.
2993
29941999-12-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2995
2996 * memory.h (enum): Add MTYPE_BGP_STATIC.
2997
29981999-12-23 Alex Zinin <zinin@amt.ru>
2999 * zebra.h, zclient.*: dynamic int up/down message
3000 support
3001
30021999-12-10 Kunihiro Ishiguro <kunihiro@zebra.org>
3003
3004 * thread.c (thread_cancel_event): Add a function for clean up
3005 events.
3006
30071999-12-09 Kunihiro Ishiguro <kunihiro@zebra.org>
3008
3009 * dropline.c: Delete file.
3010 dropline.h: Linewise.
3011
30121999-12-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3013
3014 * filter.c (access_list_filter_delete): Wrong pointer
3015 access->master was pointed out after access is freed. I store
3016 master value at the beginning of the function.
3017
30181999-12-08 Kunihiro Ishiguro <kunihiro@zebra.org>
3019
3020 * vty.c (exec_timeout): Change of VTY timeout affect to current
3021 VTY connection.
3022 (vty_accept): Instead of immediate exit() return -1.
3023
30241999-12-07 Kunihiro Ishiguro <kunihiro@zebra.org>
3025
3026 * vty.c (vty_configure_lock): Configuration lock function added.
3027 Only one VTY can use CONFI_NODE at the same time.
3028
3029 * log.c: Delete zvlog_* functions. Now zlog_* does the same
3030 thing.
3031
3032 * log.c (log_init): Function removed.
3033 (log_close): Likewise.
3034 (log_flush): Likewise.
3035 (log_open): Likewise.
3036
3037 * vty.c (terminal_monitor): Add new command.
3038 (no_terminal_monitor): Likewise.
3039
3040 * log.c (old_log): Function removed.
3041 (old_log2): Likewise.
3042 (old_log_warn): Likewise.
3043
30441999-12-04 Toshiaki Takada <takada@zebra.org>
3045
3046 * command.c (cmd_ipv6_match): New function added.
3047 (cmd_ipv6_prefix_match): Likewise.
3048
30491999-12-04 Kunihiro Ishiguro <kunihiro@zebra.org>
3050
3051 * command.c (cmd_ipv6_match):
3052
3053 * table.c: Delete #ifdef HAVE_MBGPV4.
3054
3055 * prefix.h (struct prefix): Add safi member.
3056 (struct prefix_ipv4): Likewise.
3057 (struct prefix_ipv6): Likewise.
3058
30591999-12-04 Rumen Svobodnikov <rumen@linux.tu-varna.acad.bg>
3060
3061 * memory.c (struct mstat): Revert to support MEMORY_LOG.
3062
30631999-11-25 Kunihiro Ishiguro <kunihiro@zebra.org>
3064
3065 * version.h: Bump up to 0.81c for testing new kernel codes.
3066
30671999-11-21 Kunihiro Ishiguro <kunihiro@zebra.org>
3068
3069 * thread.h (struct thread): Pthread support is disabled all
3070 platform.
3071
30721999-11-21 Michael Handler <handler@sub-rosa.com>
3073
3074 * Include <limits.h> and <strings.h> under SUNOS_5.
3075
30761999-11-21 Kunihiro Ishiguro <kunihiro@zebra.org>
3077
3078 * sockunion.c (in6addr_cmp): Enclosed by #define HAVE_IPV6
30791999-11-13 Kunihiro Ishiguro <kunihiro@zebra.org>
3080
3081 * command.h (node_type ): Add BGP_IPV4_NODE and BGP_IPV6_NODE.
3082
30831999-11-12 Kunihiro Ishiguro <kunihiro@zebra.org>
3084
3085 * command.c (disable): Add `disable' command.
3086
30871999-11-09 Kunihiro Ishiguro <kunihiro@zebra.org>
3088
3089 * plist.c (vty_prefix_list_install): Add any check.
3090
30911999-11-04 Kunihiro Ishiguro <kunihiro@zebra.org>
3092
3093 * command.h (node_type ): Add DUMP_NODE.
3094
30951999-11-03 Kunihiro Ishiguro <kunihiro@zebra.org>
3096
3097 * smux.c: Change default SMUX oid to compatible with gated.
3098
30991999-10-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3100
3101 * if_rmap.c: New file added.
3102
3103 * if_rmap.h: New file added.
3104
31051999-10-29 Alex Zinin <zinin@amt.ru>
3106
3107 * hash.c: add hash_free() function
3108
31091999-10-25 Kunihiro Ishiguro <kunihiro@zebra.org>
3110
3111 * hash.c (hash_clean): Add clean function.
3112
3113 * plist.c (prefix_list_reset): Add reset function.
3114
3115 * filter.c (access_list_reset): Add reset function.
3116
31171999-10-17 Kunihiro Ishiguro <kunihiro@zebra.org>
3118
3119 * client.c: Merged with zclient.c.
3120 * client.h: Merged with zclient.h.
3121
31221999-10-15 Jordan Mendelson <jordy@wserv.com>
3123
3124 * md5.c: Imported from GNU C Library.
3125 * md5-gnu.h: Likewise.
3126
31271999-10-15 Jochen Friedrich <jochen@scram.de>
3128
3129 * smux.c (smux_getresp_send): SMUX_GETRSP codes improvement.
3130
31311999-10-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3132
3133 * smux.h: New file added.
3134
3135 * snmp.c: Rename to smux.c.
3136
31371999-10-02 Kunihiro Ishiguro <kunihiro@zebra.org>
3138
3139 * command.c (cmd_execute_command_strict): Filter ambious commands.
3140 (cmd_filter_by_string): Change to return enum match_type.
3141
31421999-10-01 Toshiaki Takada <takada@zebra.org>
3143
3144 * vty.c (vty_describe_fold): New function which does VTY
3145 description line fold.
3146 * vty.c (vty_describe_command): Set description column.
3147
31481999-09-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3149
3150 * plist.c (prefix_list_init_ipv4): VTY user interface is improved.
3151
31521999-09-26 Kunihiro Ishiguro <kunihiro@zebra.org>
3153
3154 * command.c (cmd_filter_by_string): Fix bug of CMD_IPV4 and
3155 CMD_IPV4_PREFIX check. Both return type must be exact_match.
3156
31571999-09-24 Toshiaki Takada <takada@zebra.org>
3158
3159 * command.c (cmd_filter_by_completion),
3160 (is_cmd_ambiguous): Check IPv4 address, IPv4 prefix and range
3161 parameter matches range.
3162
31631999-09-22 Kunihiro Ishiguro <kunihiro@zebra.org>
3164
3165 * routemap.c (route_map_apply): Returm RM_DENYMATCH when no match
3166 is performed.
3167
31681999-09-21 Kunihiro Ishiguro <kunihiro@zebra.org>
3169
3170 * vty.c (vty_read): Control-C stop VTY_MORE mode.
3171
31721999-09-20 Kunihiro Ishiguro <kunihiro@zebra.org>
3173
3174 * command.h (node_type ): Add ACCESS_IPV6_NODE and
3175 PREFIX_IPV6_NODE.
3176
3177 * distribute.h: New file added.
3178
3179 * command.h (node_type ): Delete DISTRIBUTE_NODE.
3180
31811999-09-18 Kunihiro Ishiguro <kunihiro@zebra.org>
3182
3183 * vty.c (vty_terminate_all): New function added for reload
3184 support.
3185
31861999-09-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3187
3188 * memory.h (enum): Add new type MTYPE_OSPF_EXTERNAL_ROUTE.
3189
31901999-08-31 Janos Farkas <chexum@shadow.banki.hu>
3191
3192 * vty.c (vty_read): Handle also 0x7f (alt-backspace), just like
3193 esc-ctrl-h (delete word backwards).
3194
31951999-08-24 Kunihiro Ishiguro <kunihiro@zebra.org>
3196
3197 * if.h: Add if_nametoindex for NRL.
3198
31991999-08-23 Kunihiro Ishiguro <kunihiro@zebra.org>
3200
3201 * if.c (if_create): New function.
3202
32031999-08-22 Kunihiro Ishiguro <kunihiro@zebra.org>
3204
3205 * snmp.c: New file.
3206
32071999-08-21 Kunihiro Ishiguro <kunihiro@zebra.org>
3208
3209 * stream.c (stream_put): stream_memcpy () is changed to stream_put
3210 (). stream_get () is added.
3211
32121999-08-18 Toshiaki Takada <takada@zebra.org>
3213
3214 * memory.h (enum): Add MTYPE_OSPF_LSA_DATA.
3215
32161999-08-18 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
3217
3218 * table.c (route_table_finish): add function frees table.
3219
32201999-08-12 Kunihiro Ishiguro <kunihiro@zebra.org>
3221
3222 * memory.h (enum): Add MTYPE_RTADV_PREFIX.
3223
32241999-08-11 Kunihiro Ishiguro <kunihiro@zebra.org>
3225
3226 * if.h (struct interface ): hw_address, hw_address_len added.
3227
32281999-08-10 Kunihiro Ishiguro <kunihiro@zebra.org>
3229
3230 * if.h (struct interface ): Change structure member if_data to
3231 info, index to ifindex.
3232
32331999-08-08 Rick Payne <rickp@rossfell.co.uk>
3234
3235 * routemap.c: Multi protocol route-map modification.
3236
3237 * routemap.c (route_map_apply): Route match process bug is fixed.
3238
32391999-08-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3240
3241 * thread.c (thread_fetch): When signal comes, goto retry point.
3242
32431999-08-04 Kunihiro Ishiguro <kunihiro@zebra.org>
3244
3245 * Makefile.am: Add sockopt.c and sockopt.h
3246 * sockopt.c: New file.
3247 * sockopt.h: New file.
3248
32491999-08-02 Kunihiro Ishiguro <kunihiro@zebra.org>
3250
3251 * version.h (ZEBRA_VERSION): Release zebra-0.75
3252
32531999-08-01 Kunihiro Ishiguro <kunihiro@zebra.org>
3254
3255 * memory.h (enum): Add MTYPE_RIPNG_AGGREGATE.
3256
32571999-07-31 Kunihiro Ishiguro <kunihiro@zebra.org>
3258
3259 * sockunion.h: Add sockunion_getpeername ().
3260
32611999-07-27 Kunihiro Ishiguro <kunihiro@zebra.org>
3262
3263 * version.h: Release zebra-0.74
3264
32651999-07-26 Kunihiro Ishiguro <kunihiro@zebra.org>
3266
3267 * command.h (struct host): Delete lines from struct host. Add
3268 lines to struct vty.
3269
3270 * command.c: Delete `lines LINES'. Terminal display line settings
3271 should be done by `terminal length' command.
3272
32731999-07-24 Kunihiro Ishiguro <kunihiro@zebra.org>
3274
3275 * memory.h (enum): MTYPE_OSPF_PATH are added.
3276
32771999-07-22 Toshiaki Takada <takada@zebra.org>
3278
3279 * memory.h (enum): MTYPE_OSPF_NEXTHOP is added.
3280
32811999-07-21 Toshiaki Takada <takada@zebra.org>
3282
3283 * linklist.c (list_add_node_prev), (list_add_node_next),
3284 (list_add_list): New function added.
3285
3286 * table.c (route_table_free): New function added.
3287
32881999-07-21 Kunihiro Ishiguro <kunihiro@zebra.org>
3289
3290 * plist.c (config_write_prefix): Set write flag when configuration
3291 is written.
3292
32931999-07-15 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
3294
3295 * prefix.c : prefix_cmp() added. change apply_mask() to
3296 apply_mask_ipv4(), and new apply_mask() added.
3297
32981999-07-14 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
3299
3300 * prefix.c (prefix2str): append prefixlen.
3301
33021999-07-13 Kunihiro Ishiguro <kunihiro@zebra.org>
3303
3304 * command.c (config_terminal): Change "config terminal" to
3305 "configure terminal". Reported by Georg Hitsch
3306 <georg@atnet.at>.
3307 (config_terminal_length): `terminal length <0-512>' is added. At
3308 this moment this command is only usef for vty interface.
3309 Suggested by Georg Hitsch <georg@atnet.at>.
3310
33111999-07-12 Kunihiro Ishiguro <kunihiro@zebra.org>
3312
3313 * routemap.c (rulecmp): Add wrapper function of strcmp.
3314
33151999-07-08 Rick Payne <rickp@rossfell.co.uk>
3316
3317 * sockunion.c (inet_aton): Fix bug of inet_aton.
3318
33191999-07-08 Kunihiro Ishiguro <kunihiro@zebra.org>
3320
3321 * version.h (ZEBRA_VERSION): Start zebra-0.73
3322
33231999-07-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3324
3325 * version.h: Bump up to 0.72.
3326
33271999-07-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3328
3329 * command.c (install_default): New function for install default
3330 commands to the node.
3331
3332 * memory.h (enum): MTYPE_NEXTHOP is added.
3333
33341999-07-01 <kunihiro@zebra.org>
3335
3336 * command.c (no_banner_motd): `no banner motd' command added.
3337
33381999-06-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3339
3340 * regex.c: Update to glibc-2.1.1's posix/regex.c
3341
3342 * regex-gnu.h: Update to glibc-2.1.1's posix/regex.h
3343
3344 * prefix.h (IPV4_ADDR_SAME): Macro added.
3345 (IPV6_ADDR_SAME): Likewise.
3346
33471999-06-29 Kunihiro Ishiguro <kunihiro@zebra.org>
3348
3349 * memory.h (enum): Add MTYPE_OSPF_VERTEX
3350
3351 * version.h: Bump up to 0.71.
3352
3353 * vty.c (vty_serv_sock_addrinfo): Use addrinfo function to bind
3354 VTY socket when IPv6 is enabled.
3355
33561999-06-28 Kunihiro Ishiguro <kunihiro@zebra.org>
3357
3358 * vty.c (vty_serv_sock): Change vty_serv_sock determine which
3359 address family to bind.
3360
3361 * command.c: Add quit command.
3362
33631999-06-26 NOGUCHI kay <kay@dti.ad.jp>
3364
3365 * vty.c (vty_read_config): Fix bug of configuration file path
3366 detection.
3367
33681999-06-25 Kunihiro Ishiguro <kunihiro@zebra.org>
3369
3370 * version.h: Bump up to 0.70.
3371
33721999-06-17 Kunihiro Ishiguro <kunihiro@zebra.org>
3373
3374 * buffer.h (GETL): Remove GETL macro.
3375
3376 * version.h: Bump up to 0.69.
3377
33781999-06-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3379
3380 * if.c (connected_add): Commented out connected_log.
3381
33821999-06-13 Kunihiro Ishiguro <kunihiro@zebra.org>
3383
3384 * command.h (struct cmd_element ): strvec and descvec is combined
3385 into newstrvec.
3386
3387 * command.c (desc_make): Function removed.
3388 (desc_next): Function removed.
3389
3390 * command.h (struct cmd_element ): docvec is removed from struct
3391 cmd_element.
3392
33931999-06-12 Kunihiro Ishiguro <kunihiro@zebra.org>
3394
3395 * command.c (cmd_execute_command): Remove command NULL check.
3396
3397 * command.h (struct cmd_element ): Add newstrvec entry to struct
3398 cmd_element.
3399 (DEFUN2): DEFUN2 macro is removed. DEFUN is extended to support
3400 (a|b|c) statement.
3401 (DESC): DESC macro is removed.
3402
3403 * vty.c (vty_complete_command): When return value is
3404 CMD_ERR_NO_MATCH, don't display error message.
3405
34061999-06-08 Kunihiro Ishiguro <kunihiro@zebra.org>
3407
3408 * table.c (route_next_until): New function.
3409
3410 * version.h: Bump up to 0.68.
3411
34121999-06-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3413
3414 * vty.c (vty_close): Free vty->buf when vty is closed.
3415
3416 * memory.h (enum): Add MTYPE_COMMUNITY_ENTRY and
3417 MTYPE_COMMUNITY_LIST.
3418
3419 * vty.h (struct vty ): Change buf from static length buffer to
3420 variable length buffer.
3421
3422 * vty.c (vty_ensure): New function added.
3423
34241999-06-04 Kunihiro Ishiguro <kunihiro@zebra.org>
3425
3426 * command.h (node_type ): Add COMMUNITY_LIST_NODE.
3427
3428 * command.c (config_enable_password): Freeing host.enable bug is
3429 fixed.
3430 (config_enable_password): Add argc count check.
3431
34321999-05-31 Kunihiro Ishiguro <kunihiro@zebra.org>
3433
3434 * version.h: Bump up to 0.67.
3435
34361999-05-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3437
3438 * command.c (zencrypt): New function for encrypt password.
3439
3440 * command.h (struct host): Add password_encrypt and
3441 enable_encrypt.
3442
34431999-05-30 Jochen Friedrich <jochen@scram.de>
3444
3445 * command.h (struct host): New member encrypt is added for
3446 encrypted password.
3447
34481999-05-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3449
3450 * vty.c: Remove all_digit_check function. Instead use all_digit.
3451
3452 * prefix.c (all_digit): New function for checking string is made
3453 from digit character.
3454
34551999-05-25 Kunihiro Ishiguro <kunihiro@zebra.org>
3456
3457 * Makefile.am (libzebra_a_SOURCES): Add zclient.c.
3458 (noinst_HEADERS): Add zclient.h
3459
3460 * zclient.[ch]: New file for zebra client routine.
3461
3462 * memory.h (enum): Add MTYPE_ZEBRA.
3463
34641999-05-19 Kunihiro Ishiguro <kunihiro@zebra.org>
3465
3466 * version.h (ZEBRA_VERSION): Update to 0.66.
3467
34681999-05-15 Kunihiro Ishiguro <kunihiro@zebra.org>
3469
3470 * buffer.h (GETC,GETW): Macro deleted.
3471
34721999-05-15 Carlos Alberto Barcenilla <barce@frlp.utn.edu.ar>
3473
3474 * prefix.h (IPV4_NET0, IPV4_NET127): Macro added.
3475
34761999-05-15 Kunihiro Ishiguro <kunihiro@zebra.org>
3477
3478 * vty.c (service_advanced_vty): New command added.
3479 (no_service_advanced_vty): Likewise.
3480
34811999-05-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3482
3483 * vty.c (vty_auth): If advanced flag is set and enable password is
3484 not set, directly login to the ENABLE_NODE. This feature is
3485 originally designed and implemented by Stephen R. van den Berg
3486 <srb@cuci.nl>.
3487
3488 * command.h (host): Add advanced flag to struct host for advanced
3489 vty terminal interface.
3490
3491 * version.h (ZEBRA_VERSION): Update to 0.65 for next beta release.
3492
34931999-05-14 Stephen R. van den Berg <srb@cuci.nl>
3494
3495 * command.h (node_type ): Add TABLE_NODE.
3496
3497 * vty.c (vty_telnet_option): Check host.lines value.
3498
3499 * command.c (config_lines): DEFUN for 'lines LINES' command.
3500
3501 * zebra.h: Include <sys/utsname.h> for uname().
3502 (RT_TABLE_MAIN): Defined as 0 if OS does not support multiple
3503 routing table.
3504
3505 * vty.c (vty_auth): Directly login to the ENABLE_NODE when enable
3506 password is not set.
3507 (vty_prompt): Get machine's hostname when hostname is not set.
3508
35091999-05-11 James Willard <james@whispering.org>
3510
3511 * command.c (config_exit): Close connection when `exit' command is
3512 executed at ENABLE_NODE.
3513
35141999-05-10 Kunihiro Ishiguro <kunihiro@zebra.org>
3515
3516 * vty.c (vty_stop_input): `C-c' key change node to ENABLE_NODE.
3517
3518 * command.c (cmd_execute_command_strict): Matched command size
3519 check added.
3520 (cmd_make_desc_line): New function for DEFUN2.
3521
3522 * command.h (struct cmd_element ): Add descsize.
3523
35241999-05-09 Kunihiro Ishiguro <kunihiro@zebra.org>
3525
3526 * command.h (struct cmd_element ): Remame descvec to docvec.
3527 (struct cmd_element ): Add descvec for new description system.
3528
3529 * command.c (desc_make): Check cmd->descvec.
3530
35311999-05-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3532
3533 * memory.h (enum): Add MTYPE_CLUSTER, MTYPE_CLUSTER_VAL.
3534
35351999-05-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3536
3537 * version.h (ZEBRA_VERSION): Bump up to 0.64 for next beta
3538 release.
3539
35401999-05-04 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
3541
3542 * linklist.c (list_delete_all_node): bug fix.
3543 previous code loses current position when node
3544 is deleted.
3545
35461999-05-03 Kunihiro Ishiguro <kunihiro@zebra.org>
3547
3548 * command.h (DESC): Macro added.
3549 (struct cmd_element2): Delete struct cmd_element2.
3550
3551 * plist.c (prefix_list): Sequential number option check is added.
3552
35531999-05-02 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
3554
3555 * log.c (zvlog_{debug,info,notice,warn,err}): have been
3556 added. now we can log both console and file, but still
3557 need some fix about config write.
3558
35591999-05-02 Kunihiro Ishiguro <kunihiro@zebra.org>
3560
3561 * log.c (zvlog_debug): Fix yasu's change.
3562
35631999-05-01 Kunihiro Ishiguro <kunihiro@zebra.org>
3564
3565 * plist.c (prefix_list): Fix typo.
3566
35671999-04-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3568
3569 * Set version to 0.63 for first beta package.
3570
35711999-04-27 Carlos Barcenilla <barce@frlp.utn.edu.ar>
3572
3573 * prefix.c (str2prefix_ipv4): Fix prefix length check.
3574 (str2prefix_ipv6): Likewise.
3575
35761999-04-25 Kunihiro Ishiguro <kunihiro@zebra.org>
3577
3578 * memory.h (enum): Add MTPYE_PREFIX_LIST and
3579 MTYPE_PREFIX_LIST_ENTRY.
3580
3581 * command.h (node_type ): Add PREFIX_NODE.
3582
35831999-04-25 Carlos Barcenilla <barce@frlp.utn.edu.ar>
3584
3585 * command.c: ALIAS (config_write_memory_cmd) and ALIAS
3586 (copy_runningconfig_startupconfig_cmd) is added.
3587
3588 * table.c (route_node_lookup): Unused match variable deletion.
3589
35901999-04-24 Kunihiro Ishiguro <kunihiro@zebra.org>
3591
3592 * Makefile.am (libzebra_a_SOURCES): plist.c added.
3593 (noinst_HEADERS): plist.h added.
3594
3595 * plist.c, plist.h: New file added.
3596
3597 * memory.h (enum): Rename MTYPE_AS_PASN to MTYPE_AS_STR.
3598 * memory.c: Likewise.
3599
36001999-04-19 Carlos Alberto Barcenilla <barce@frlp.utn.edu.ar>
3601
3602 * command.c (show_version): `show version' command added.
3603
36041999-04-19 Kunihiro Ishiguro <kunihiro@zebra.org>
3605
3606 * prefix.c (str2prefix_ipv6): Prefix length overflow check.
3607
36081999-04-19 Carlos Alberto Barcenilla <barce@frlp.utn.edu.ar>
3609
3610 * prefix.c (str2prefix_ipv4): Prefix length overflow check.
3611
36121999-04-19 Alex Bligh <amb@gxn.net>
3613
3614 * prefix.c (sockunion2hostprefix): Function added.
3615 (sockunion2prefix): Address family was not set. Now it is set.
3616
3617 * vty.c: VTY access-class command is added.
3618
36191999-04-18 Kunihiro Ishiguro <kunihiro@zebra.org>
3620
3621 * memory.c: Change xmalloc to zmalloc. xcalloc, xrealloc, xfree,
3622 xstrdup are likewise.
3623
36241999-04-18 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
3625
3626 * thread.c: Add thread_execute for other routing daemon.
3627 OSPF tasks need to be generated by "sheduled" and "executed".
3628
36291999-04-13 Kunihiro Ishiguro <kunihiro@zebra.org>
3630
3631 * buffer.c: Rewrite buffer_write and buffer_flush related
3632 functions for fixing bugs. Reason of the problem and fix is
3633 suggested by Alex Bligh <amb@gxn.net>.
3634
36351999-04-12 Alex Bligh <amb@gxn.net>
3636
3637 * command.c (cmd_entry_function_descr): Added for variable
3638 argument help display.
3639
36401999-04-07 Kunihiro Ishiguro <kunihiro@zebra.org>
3641
3642 * regex.c, regex-gnu.h: Imported from GNU sed-3.02 distribution.
3643
36441999-03-24 Kunihiro Ishiguro <kunihiro@zebra.org>
3645
3646 * stream.c: stream_fifo_free bug is fixed.
3647
36481999-03-19 Toshiaki Takada <takada@zebra.org>
3649
3650 * stream.c (stream_strncpy): Added for getting any length bytes
3651 from stream.
3652
36531999-03-16 Kunihiro Ishiguro <kunihiro@zebra.org>
3654
3655 * version.h (ZEBRA_BUG_ADDRESS): New macro added.
3656
36571999-03-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3658
3659 * buffer.c (buffer_flush_window): If ep is same as buffer's size
3660 length and lp is overrun one octet.
3661
36621999-03-13 Kunihiro Ishiguro <kunihiro@zebra.org>
3663
3664 * vty.h: add VTY's timeout function.
3665
36661999-03-05 <kunihiro@zebra.org>
3667
3668 * command.h (node_type ): Add OSPF6_node.
3669
36701999-03-04 Kunihiro Ishiguro <kunihiro@zebra.org>
3671
3672 * zebra.h: Check HAVE_SYS_SELECT_H when include <sys/select.h>
3673
36741999-03-03 Jeroen Ruigrok/Asmodai <asmodai@wxs.nl>
3675
3676 * zebra.h: Include <net/if_var.h> if it exists.
3677
36781999-03-02 Kunihiro Ishiguro <kunihiro@zebra.org>
3679
3680 * getopt.[ch],getopt1.c: Sync with glibc-2.1.
3681
3682 * log.c (zlog): Tempolary ZLOG_STDOUT feature added.
3683
3684 * command.h: Include vector.h and vty.h
3685
36861999-02-25 Kunihiro Ishiguro <kunihiro@zebra.org>
3687
3688 * routemap.h (struct route_map_rule_cmd): Add prefix arguemnt.
3689
3690 * routemap.c (route_map_apply_index): Add prefix argument.
3691 (route_map_apply): Likewise.
3692
3693 * memory.h (enum): Add MTYPE_ROUTE_MAP_COMPILED.
3694
3695 * stream.c: Add stream_fifo related functions.
3696
36971999-02-24 Kunihiro Ishiguro <kunihiro@zebra.org>
3698
3699 * daemon.c: Return integer value. File descriptor close is added.
3700
3701 * memory.h (enum): add MTYPE_OSPF_LSA.
3702
37031999-02-23 Kunihiro Ishiguro <kunihiro@zebra.org>
3704
3705 * rsh.c: Remove empty file.
3706
37071999-02-22 <kunihiro@zebra.org>
3708
3709 * routemap.c: Add add/delete hook to route_map_master.
3710
37111999-02-19 Peter Galbavy <Peter.Galbavy@knowledge.com>
3712
3713 * str.[ch] added to supply wrappers for snprintf(), strlcat() and
3714 strlcpy on system without these.
3715
37161999-02-18 Peter Galbavy <Peter.Galbavy@knowledge.com>
3717
3718 * syslog support added
3719
37201999-02-02 Kunihiro Ishiguro <kunihiro@zebra.org>
3721
3722 * filter.c (access_list_add_hook): added for hook function management.
3723 * filter.c (access_list_delete_hook): Likewise.
3724
37251999-01-19 Kunihiro Ishiguro <kunihiro@zebra.org>
3726
3727 * stream.c: New file.
3728 * stream.h: New file.
3729 * Divide stream related fucntions from buffer.[ch] into stream.[ch].
3730
37311999-01-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3732
3733 * memory.h (enum): add MTYPE_STREAM, MTYPE_STREAM_DATA
3734
3735 * buffer.c (stream_new): Set MTYPE_STREAM to XMALLOC argument.
3736
37371998-12-23 Kunihiro Ishiguro <kunihiro@zebra.org>
3738
3739 * routemap.c: route_map_index_delete() added.
3740
37411998-12-22 Kunihiro Ishiguro <kunihiro@zebra.org>
3742
3743 * buffer.c (buffer_empty): check cp instead of sp.
3744
37451998-12-17 Kunihiro Ishiguro <kunihiro@zebra.org>
3746
3747 * radix.[ch]: Deleted.
3748
37491998-12-15 Magnus Ahltorp <map@stacken.kth.se>
3750
3751 * buffer.c: Prototype fixes.
3752 * prefix.c: Likewise.
3753 * sockunion.c: Likewise.
3754 * sockunion.h: Likewise.
3755
37561998-12-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3757
3758 * vty.c (vty_read): DELETE key works as vty_delete_char.
3759
37601998-12-13 Kunihiro Ishiguro <kunihiro@zebra.org>
3761
3762 * log.c (time_print): chane %y to %Y.
3763
37641998-12-10 Kunihiro Ishiguro <kunihiro@zebra.org>
3765
3766 * distribute.c: new file.
3767
37681998-12-09 Kunihiro Ishiguro <kunihiro@zebra.org>
3769
3770 * filter.c: Remove all of struct prefix_{ipv4,ipv6} and add
3771 complete support of IPv6 access list.
3772
3773 * command.c (config_write_element): function delete.
3774 (config_write_host): function add. password and enable password
3775 isn't printed to vty interface.
3776
37771998-12-08 Kunihiro Ishiguro <kunihiro@zebra.org>
3778
3779 * filter.c: Change prefix_ipv4 to prefix and add support of
3780 prefix_ipv6 filtering.
3781
37821998-12-07 Kunihiro Ishiguro <kunihiro@zebra.org>
3783
3784 * Makefile.am (INCLUDES): add @INCLUDES@ for Linux IPv6 inet6-apps
3785 header includes.
3786
37871998-12-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3788
3789 * log.c (log_flush): fix function name typo.
3790
37911998-12-04 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
3792
3793 * memory.h: OSPF memory type is added.
3794
37951998-11-15 Kunihiro Ishiguro <kunihiro@zebra.org>
3796
3797 * command.c (sort_node): add sort_node() for pretty printing of
3798 command on vty interface.
3799 (config_password): delete the restriction of charaster of password
3800 string.
3801
38021998-09-05 Kunihiro Ishiguro <kunihiro@debian.zebra.org>
3803
3804 * prefix.c (prefix_ipv4_any): add prefix_ipv4_any().
3805
38061998-08-25 Kunihiro Ishiguro <kunihiro@zebra.org>
3807
3808 * network.h: New file.
3809
38101998-08-24 Kunihiro Ishiguro <kunihiro@zebra.org>
3811
3812 * vty.c (vty_will_echo): function name change from vty_off_echo.
3813
38141998-08-18 Kunihiro Ishiguro <kunihiro@zebra.org>
3815
3816 * buffer.h: add PUTC,PUTW,PUTL macros.
3817
38181998-07-22 Kunihiro Ishiguro <kunihiro@zebra.org>
3819
3820 * route.[ch]: renamed to prefix.[ch]
3821
38221998-06-09 Kunihiro Ishiguro <kunihiro@zebra.org>
3823
3824 * prefix_in, prefix_in6 is replaced by prefix_ipv4, prefix_ipv6.
3825
3826 * Makefile.am: @INCLUDES@ is deleted from INCLUDES.
3827
38281998-06-07 Kunihiro Ishiguro <kunihiro@zebra.org>
3829
3830 * host.[ch]: merged with command.[ch]
3831
38321998-05-08 Kunihiro Ishiguro <kunihiro@zebra.org>
3833
3834 * Makefile.am (libzebra_a_SOURCES): add route.c to libzebra_a_SOURCES.
3835
38361998-05-07 Kunihiro Ishiguro <kunihiro@zebra.org>
3837
3838 * route.c (str2prefix): str2prefix () is gone.
3839
38401998-05-03 Kunihiro Ishiguro <kunihiro@zebra.org>
3841
3842 * vty.c (vty_read_config): change CONDIR to SYSCONFDIR.
3843
3844 * .cvsignore: add file.
3845
3846 * memory.c (xerror): add arguent `type' and `size'.
3847
3848 * socket.c: deleted.
3849
38501998-05-02 Kunihiro Ishiguro <kunihiro@zebra.org>
3851
3852 * vector.c: malloc,free,realloc -> XMALLOC,XFREE,XREALLOC.
3853 * linklist.c: same as above.
3854
38551998-04-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3856
3857 * filter.[ch]: added.
3858
38591998-04-01 Kunihiro Ishiguro <kunihiro@zebra.org>
3860
3861 * vty.c (config_who): return CMD_SUCCESS
3862
38631998-04-01 Jochen Friedrich <jochen@scram.de>
3864
3865 * table.c (route_dump_node): route_dump_node is IPv6 specific
3866 function so move #ifdef to the end of route_dump_node ().
3867
38681998-03-05 "Hannes R. Boehm" <hannes@boehm.org>
3869
3870 * if.c: DEFUN(interface_desc) added.
3871
38721998-03-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3873
3874 * if.c: separated from ripd/rip_interface.c
3875
38761998-03-04 Kunihiro Ishiguro <kunihiro@zebra.org>
3877
3878 * thread.[ch] : added.
3879
38801998-02-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3881
3882 * vty.c (vty_delete_char): fix size bug.
3883 (vty_backward_pure_word): function added.
3884 (vty_read): ESC + 'f' perform vty_forward_word.
3885 (vty_read): ESC + 'b' perform vty_backward_word.
3886
38871998-02-11 Kunihiro Ishiguro <kunihiro@zebra.org>
3888
3889 * radix.c (radix_lookup_rt): add mask check.
3890 (radix_delete_duproute): add mask check.
3891
38921998-02-10 Kunihiro Ishiguro <kunihiro@zebra.org>
3893
3894 * command.c (config_write_file): fix vty -> file_vty.
3895
38961998-02-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3897
3898 * command.c (cmd_filter_ambiguous): add complex type treatment.
3899
39001998-02-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3901
3902 * vty.c (vty_time_print): function added.
3903 (vty_complete_command): now [...] element isn't shown by completion.
3904
39051998-01-26 Kunihiro Ishiguro <kunihiro@zebra.org>
3906
3907 * command.c : change from cmd_install_node() to install_node().
3908
39091998-01-16 Kunihiro Ishiguro <kunihiro@zebra.org>
3910
3911 * route.[ch]: struct rt{} is replaced by struct prefix{}.
3912
39131998-01-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3914
3915 * command.c (cmd_execute_command): check command length.
3916
3917 * timer.c (zebra_timer_set): add zebra_timer_set.
3918
39191998-01-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3920
3921 * command.h (node_type ): add ZEBRA_NODE.
3922
3923 * command.c (config_exit): add RIP_NODE.
3924 (config_write_file): add RIP_NODE.
3925
39261998-01-04 Kunihiro Ishiguro <kunihiro@zebra.org>
3927
3928 * print_version.c (print_version): Now Copyright is 1996-1998.
3929
3930 * sockunion.c (sockunion_log): moved from ../zebra/route.c
3931
39321997-12-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3933
3934 * host.c (config_logfile): change 'log PATH' to 'logfile PATH'.
3935
3936 * sockunion.c (sockunion_sameprefix): add same prefix for
3937 sockunion.
3938
39391997-12-29 Kunihiro Ishiguro <kunihiro@zebra.org>
3940
3941 * radix.[ch] : are moved from ../zebra directroy.
3942
3943 * command.c (config_from_file): if command execution failed down
3944 level to CONFIG_NODE.
3945
3946 * host.c: config_log function which enable 'log FILENAME' command.
3947
39481997-12-23 Kunihiro Ishiguro <kunihiro@zebra.org>
3949
3950 * vty.c: add vty_transpose_chars (). Now you can use '^T' to
3951 transpose character.
3952
3953 * command.c: cmd_cmdsize add, this is useful to check incomplete
3954 command.
3955
39561997-12-07 Kunihiro Ishiguro <kunihiro@zebra.org>
3957
3958 * fd.h: add family for address family
3959
39601997-12-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3961
3962 * command.o
3963 * vty.o
3964 * host.o is moved from ../zebra
3965
39661997-08-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3967
3968 * make library directory.
3969