blob: ca5d4c3c8a7963ab80b74a5681706568362104ef [file] [log] [blame]
paulb45da6f2005-03-08 15:16:57 +000012005-03-08 Paul Jakma <paul.jakma@sun.com>
2
3 * command.c: (banner_motd_file_cmd) use XSTRDUP/XFREE
4 * vty.c: (vty_hello) suggestions from Andrew, read by line and
5 stub out trailling non-printable characters on each line thus
6 allowing us to specify VTY_NEWLINE to vty_out.
7
paul3b0c5d92005-03-08 10:43:43 +000082005-03-08 Jeroen Massar <jeroen@unfix.org>
9
10 * vty.c: (vty_hello) display motd file, if set
11 * command.h: add char *motdfile to struct host
12 * command.c: (config_write_host) write out motdfile config
13 (banner_motd_file_cmd) new command, allow motd to be read from
14 file.
15 (no_banner_motd_cmd) free motdfile string, if needs be.
16 (cmd_init) init (struct host).motdfile. Add new motd file
17 commands.
18
hasso12f6ea22005-03-07 08:35:39 +0000192005-03-07 Michael Sandee <voidptr@voidptr.sboost.org>
20
21 * command.c: host.name might be NULL.
22 * vty.c: Fix fd leak.
23
ajs81fb3242005-02-24 16:02:53 +0000242005-02-24 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
25
26 * stream.c: (stream_read_try) Log a warning message if a fatal
27 I/O error occurs.
28 (stream_fifo_new) Fix prototype.
29 * stream.h: Fix prototype for stream_fifo_new (need void arg).
30
ajs9fc7ebf2005-02-23 15:12:34 +0000312005-02-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
32
ajscdb6ee92005-02-23 15:48:32 +000033 * {vty.h,vty.c}: Remove vty_finish (duplicate of vty_reset).
34
352005-02-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
36
ajs9fc7ebf2005-02-23 15:12:34 +000037 * buffer.h: Make the struct buffer and struct buffer_data structures
38 private by moving them inside buffer.c. Add comments for all
39 functions. Rename buffer_write as buffer_put (to be more consistent
40 with the buffer_putc and buffer_putstr functions). Declare a new
41 buffer_write function that is used to write data to a file descriptor
42 and/or add it to the buffer queue. Remove unused function
43 buffer_flush_vty_all. Create a new enum typedef buffer_status_t
44 to be used as the return code for all buffer_flush* functions
45 and buffer_write.
46 * buffer.c: The struct buffer and struct buffer_data declarations
47 are now private to this file. In conjunction with that, remove
48 some unnecessary fields: struct buffer (alloc, unused_head,
49 unused_tail, length), struct buffer_data (prev).
50 (buffer_data_new) Removed: functionality incorporated into buffer_add.
51 (buffer_data_free) Removed: use a macro BUFFER_DATA_FREE instead.
52 (buffer_new) Use calloc instead of malloc + memset(zero).
53 Supply an appropriate default size if the specified size is 0.
54 (buffer_free) Eliminate code duplication by calling buffer_reset to
55 free the contents of the buffer (and remove unused code related
56 to unused_head).
57 (buffer_empty,buffer_putc,buffer_putstr) Aesthetic change (make more
58 compact).
59 (buffer_reset) Use macro BUFFER_DATA_FREE. No need to set
60 alloc and length to 0 (these fields have been removed).
61 (buffer_add) Fix scope to be static. Call XMALLOC directly instead
62 of calling removed buffer_data_new function. Simplify the logic
63 (since it's now a singly-linked list instead of doubly-linked).
64 (buffer_write) Renamed to buffer_put. Change to void, since return
65 code of 1 was meaningless. No need to adjust length field, since
66 it has been removed.
67 (buffer_putw,buffer_flush,buffer_flush_vty_all,buffer_flush_vty)
68 Remove unused functions.
69 (buffer_flush_all) Rewrite using buffer_flush_available to eliminate
70 a possible failure mode if IOV_MAX is less than the number of buffers
71 on the queue.
72 (buffer_flush_window) Incorporate logic from buffer_flush_vty.
73 Log an error message if there is a writev error.
74 (buffer_flush_available) Be more paranoid: check for case where
75 buffer is already empty. Use new ERRNO_IO_RETRY macro, and use
76 new enum for return codes. Simplify deletion logic (since it's
77 now a singly-linked list).
78 (buffer_write) New function for use with non-blocking I/O.
79 * vty.h: Replace the struct vty sb_buffer field with a fixed-size
80 (5-character) sb_buf field and an sb_len field, since using
81 a struct buffer was inappropriate for this task. Add some useful
82 comments about telnet window size negotiation.
83 * vty.c: Include <arpa/telnet.h> (no longer included by zebra.h).
84 Remove VTY_OBUF_SIZE (instead use buffer_new default size).
85 Make telnet_backward_char and telnet_space_char static const.
86 (vty_out) Replace buffer_write with buffer_put.
87 (vty_log_out) Check for I/O errors. If fatal, close the vty session.
88 Consolidate 3 separate writes into a single write call.
89 (vty_will_echo,vty_command,vty_next_line,vty_previous_line,
90 vty_end_config,vty_describe_fold,vty_clear_buf,vty_serv_sock_addrinfo,
91 vty_serv_sock_family,vty_serv_un,vty_use_backup_config,exec_timeout,
92 vty_config_write,vty_save_cwd) Fix scope to static.
93 (vty_new) Let buffer_new use its default buffer size.
94 (vty_write) Fix signature: 2nd arg should be const char *.
95 Replaced buffer_write with buffer_put.
96 (vty_telnet_option) Fix minor bug (window height or width greater than
97 255 was broken). Use sb_buf and sb_len instead of removed sb_buffer
98 (which was being used improperly).
99 (vty_read) On error, use ERRNO_IO_RETRY to decide whether it's fatal.
100 If the error is fatal, call buffer_reset so vty_close does not attempt
101 to flush the data. Use new sb_buf and sb_len instead of sb_buffer
102 to store the SB negotiation string.
103 (vty_flush) When vty->lines is 0, call buffer_flush_available instead
104 of buffer_flush_window. Look at the return code from buffer_flush
105 to detect I/O errors (and in that case, log an error message and
106 close the vty).
107 (vty_create) Fix scope to static. Initialize sb_len to 0 instead
108 of creating sb_buffer.
109 (vty_accept) Set socket nonblocking.
110 (vtysh_accept) Use new set_nonblocking function instead of calling
111 fcntl directly.
112 (vtysh_flush) New function called from vtysh_read (after command
113 execution) and from vtysh_write. This flushes the buffer
114 and reacts appropriately to the return code (by closing the vty
115 or scheduling further flushes).
116 (vtysh_read) Check whether error is fatal using ERRNO_IO_RETRY.
117 If not, just try again later. Otherwise, call buffer_reset before
118 calling vty_close (to avoid trying to flush the buffer in vty_close).
119 Fix logic to allow case where a command does not arrive atomically
120 in a single read call by checking for the terminating NUL char.
121 (vtysh_write) Use new vtysh_flush helper function.
122 (vty_close) No need to call buffer_empty, just call buffer_flush_all
123 in any case (it will check whether the buffer is empty).
124 Do not free sb_buffer (since it has been removed).
125 (vty_log_fixed) Use writev instead of write.
126 * zebra.h: Do not include <arpa/telnet.h>, since this is used only
127 by lib/vty.c.
128
hassoc3c07f22005-02-21 18:17:52 +00001292005-02-21 Vincenzo Eramo <eramo at infocom.ing.uniroma1.it>
130
131 * pqueue.[ch]: Introduce "update" function to meet ospf spf needs. It
132 will allow to update node when:
133 i) a node is inserted into the priority queue;
134 ii) a node position is modified in the priority queue;
135 * pqueue.h: Export trickle_down() function.
136
paul109ac962005-02-19 01:17:07 +00001372005-02-19 Paul Jakma <paul.jakma@sun.com>
138
139 * stream.c: (stream_new) fix dumb mistake.
140
ajsd7e2a812005-02-17 20:02:49 +00001412005-02-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
142
ajs53270112005-02-17 20:07:22 +0000143 * stream.c: (stream_read_try) Use new ERRNO_IO_RETRY macro.
144
1452005-02-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
146
ajsd7e2a812005-02-17 20:02:49 +0000147 * network.h: Define a new ERRNO_IO_RETRY macro to test whether an I/O
148 operation should be retried. This eliminates the need to duplicate
149 the same logic testing for EAGAIN or EINTR in multiple places.
150
ajs42218e72005-02-16 16:25:39 +00001512005-02-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
152
ajs262feb12005-02-16 20:35:47 +0000153 * stream.h: Declare new function stream_read_try suitable for use
154 with non-blocking file descriptors. Indicate that stream_read
155 and stream_read_unblock are deprecated.
156 * stream.c: (stream_read_try) New function for use with non-blocking
157 I/O.
158 (stream_recvmsg) Should return -1 if the stream is too small to
159 contain the data.
160
1612005-02-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
162
ajs42218e72005-02-16 16:25:39 +0000163 * network.c: (set_nonblocking) Should check return code from
164 fcntl(F_GETFL).
165
ajsa269d612005-02-16 00:45:37 +00001662005-02-15 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
167
168 * network.h: Declare new function set_nonblocking. Indicate that
169 readn and writen are deprecated.
170 * network.c: (set_nonblocking) New function to make a file descriptor
171 non-blocking, since it seems silly to have fcntl calls sprinkled
172 throughout the code.
173
paul1dd13d42005-02-14 23:49:09 +00001742005-02-14 Paul Jakma <paul.jakma@sun.com>
paulf2e6c422005-02-12 14:35:49 +0000175
176 * stream.h: Unsigned long updated to size_t
177 * stream.c: ditto
paul050c0132005-02-14 23:47:47 +0000178 * stream.h: Add stream_copy, stream_dup, stream_recvmsg.
179 Add comment describing struct stream abstraction, and various
180 other comments.
181 Deprecate several unsafe/ambigious macros.
182 Add STREAM_WRITEABLE and STREAM_READABLE.
183 Add (stream_getl_from) for symmetry.
184 Update stream_forward_{endp,getp} to use size_t offset.
185 Make stream data a 0 length array, rather than a seperate malloc.
186 * stream.c: Add consistency checks. Update to follow stream.h
187 changes.
188 (stream_new) Alloc stream+data in one go.
189 (stream_copy) new function, copy a stream.
190 (stream_dup) new function, dup a stream.
191 (stream_recvmsg) new function, recvmsg data into a stream.
192 (stream_empty) no need to check getp == 0.
paulf2e6c422005-02-12 14:35:49 +0000193
paul9985f832005-02-09 15:51:56 +00001942005-02-09 Paul Jakma <paul.jakma@sun.com>
195
196 * stream.h: Remove putp. Update reference to putp with endp.
197 Add stream_forward_endp, which daemons were doing manually.
198 Rename stream_forward to stream_forward_getp.
199 stream.c: Remove/update references to putp.
200 introduce stream_forward_endp.
201
ajs548e6f72005-02-08 15:57:25 +00002022005-02-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
203
204 * zebra.h: Change macro definitions SET_FLAG and UNSET_FLAG
205 to use compound assignment operators (aesthetic change).
206
ajs1e221352005-02-03 16:42:40 +00002072005-02-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
208
ajsc4c7d0c2005-02-03 19:22:05 +0000209 * log.c: (zlog_signal,zlog_backtrace_sigsafe) Eliminate use of fileno()
210 since it is not async-signal-safe.
211 (_zlog_assert_failed) Rewrite crashlog logic more compactly.
212 (zlog_set_file,zlog_reset_file,zlog_rotate) Update logfile_fd
213 for use in signal handler.
214
2152005-02-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
216
ajs1e221352005-02-03 16:42:40 +0000217 * log.c: (syslog_sigsafe) Reduce scope of syslog_fd: it is accessed
218 inside this function only.
219 (open_crashlog) New function to open /var/tmp/quagga.<daemon>.crashlog
220 with flags O_WRONLY|O_CREAT|O_EXCL to save some crash info.
221 (zlog_signal,_zlog_assert_failed) Increase logging priority from
222 LOG_ERR to LOG_CRIT. If no file logging is configured, try to use
223 open_crashlog to create a crash logfile.
224 (zlog_backtrace_sigsafe) If a crashlog file descriptor is open,
225 dump a backtrace to that file.
226
ajs847947f2005-02-02 18:38:48 +00002272005-02-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
228
229 * if.h: Declare if_flag_dump.
230
ajs6a52d0d2005-01-30 18:49:28 +00002312005-01-30 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
232
233 * daemon.c: (daemon) Replace perror with zlog_err.
234 * vty.c: (vty_serv_un) Replace perror with zlog_err.
235
ajs3b8b1852005-01-29 18:19:13 +00002362005-01-29 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
237
238 * buffer.h: Fix comment on buffer_getstr to reflect that it now
239 uses XMALLOC.
240 * buffer.c: (buffer_getstr) Use XMALLOC(MTYPE_TMP) instead of malloc.
241 * filter.c: (access_list_remark,ipv6_access_list_remark) Use
242 argv_concat instead of buffer_getstr.
243 * if.c: (interface_desc) Use argv_concat instead of buffer_getstr.
244 * plist.c: (ip_prefix_list_description,ipv6_prefix_list_description)
245 Use argv_concat instead of buffer_getstr.
246
ajsf6834d42005-01-28 20:28:35 +00002472005-01-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
248
ajsafb8b602005-01-28 20:41:07 +0000249 * lib/buffer.h: Document behavior of buffer_getstr function.
250 * lib/buffer.c: (buffer_getstr) Fix bug: must handle case where
251 the string extends beyond the head struct buffer_data.
252
2532005-01-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
254
ajsf6834d42005-01-28 20:28:35 +0000255 * lib/command.h: Document behavior of argv_concat function.
256 * lib/command.c: (argv_concat) Calculate total string length first so
257 we can call malloc just once (instead of realloc'ing to add each
258 string element).
259 (do_echo,config_logmsg) Allow for possible NULL return value from
260 argv_concat.
261
hasso13bfca72005-01-23 21:42:25 +00002622005-01-23 Hasso Tepper <hasso at quagga.net>
263
264 * lib/command.[ch]: Make node_parent() function nonstatic. vtyh.c will
265 use it as well.
266
ajs31364272005-01-18 22:18:59 +00002672005-01-18 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
268
269 * log.h: Test for SA_SIGINFO to see whether zlog_signal takes final
270 two args (siginfo and program_counter).
271 * log.c: (hex_append) Include this function only if SA_SIGINFO or
272 HAVE_GLIBC_BACKTRACE is defined.
273 (zlog_signal) Final two args (siginfo and program_counter) now
274 depend on whether SA_SIGINFO is defined on this platform.
275 * sigevent.c: (program_counter) Do not include this function if
276 SA_SIGINFO is not defined on this platform.
277 (exit_handler,core_handler) Test for SA_SIGINFO to decide whether
278 2nd & 3rd arguments are present and to decide how to invoke
279 zlog_signal.
280 (trap_default_signals) Test for SA_SIGINFO and invoke sigaction
281 appropriately.
282
ajs239c26f2005-01-17 15:22:28 +00002832005-01-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
284
285 * log.h: Change prototype for zlog_backtrace_sigsafe to take additional
286 program_counter argument.
287 * log.c: (zlog_backtrace_sigsafe) Add additional program_counter
288 argument. If it is non-NULL, use backtrace_symbols_fd to resolve
289 the address.
290 (zlog_signal) Call zlog_backtrace_sigsafe with additional
291 program_counter argument.
292
hasso87d683b2005-01-16 23:31:54 +00002932005-01-17 Hasso Tepper <hasso at quagga.net>
294
295 * command.[ch], vty.c: cmd_execute_command() function must not attempt
296 to walk up in the node tree if called from vtysh. Different daemons
297 might have commands with same syntax in different nodes (for example
298 "router-id x.x.x.x" commands in zebra/ospfd/ospf6d daemons).
299
ajscb585b62005-01-14 17:09:38 +00003002005-01-14 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
301
302 * command.c (print_version): Do not bother even to examine host.name,
303 since it is always NULL when this function is called from main.
304
gdtf867d322005-01-14 15:47:33 +00003052005-01-14 Greg Troxel <gdt@fnord.ir.bbn.com>
306
307 * command.c (print_version): Don't print host.name if it is NULL.
308 Fixes segfault on Solaris reported by Goetz von Escher <goetz@open.ch>
309
ajse22f5512005-01-12 16:18:17 +00003102005-01-12 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
311
ajs40abf232005-01-12 17:27:27 +0000312 * sigevent.c: (trap_default_signals) Use the SA_SIGINFO flag to
313 pass additional siginfo_t and ucontext_t arguments to core_handler
314 and exit_handler.
315 (core_handler,exit_handler) Now invoked with 3 arguments (using
316 SA_SIGINFO). Pass additional info to zlog_signal.
317 (program_counter) New function to find program counter in ucontext_t,
318 needs to be enhanced to support more platforms (currently works only
319 on Linux/x86).
320 * log.h: Change the zlog_signal prototype to add new arguments
321 siginfo_t * and program_counter.
322 * log.c: (zlog_signal) Add new arguments siginfo and program_counter.
323 Include si_addr and program counter (if non-NULL) in message.
324 And remove #ifdef HAVE_GLIBC_BACKTRACE around hex_append, since
325 that is now used to render the si_addr and PC pointers.
326
3272005-01-12 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
328
ajse22f5512005-01-12 16:18:17 +0000329 * zebra.h: If not C99 and no va_copy macro available, fall back to
330 memcpy (solves a build problem on FreeBSD 4.x).
331
ajsb99760a2005-01-04 16:24:43 +00003322005-01-04 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
333
334 * zebra.h: Define ZCMSG_FIRSTHDR appropriately based on whether
335 config.h indicates HAVE_BROKEN_CMSG_FIRSTHDR (as determined
336 by the configure test program).
337 * sockopt.c: (getsockopt_cmsg_data) Use ZCMSG_FIRSTHDR instead
338 of CMSG_FIRSTHDR.
339
hassocba8a602005-01-02 18:51:01 +00003402005-01-02 Hasso Tepper <hasso at quagga.net>
341
342 * command.c: Revert int -> unsigned int fixes in
343 cmd_describe_command_real() and cmd_complete_command_real(). index can
344 be actually negative and it caused crash with "do<TAB>" in vty.
345
gdt1d69fdf2004-12-29 18:53:30 +00003462004-12-29 Greg Troxel <gdt@poblano.ir.bbn.com>
347
gdtd44debe2004-12-29 20:06:23 +0000348 * sockopt.c (getsockopt_ipv4_ifindex): Document calling
349 convention. Beef up comments. Handle the case where the cmsghdr
350 has a zero controllen, or more specifically when the wanted option
351 is not present. This is needed for Solaris 8, and in general for
352 any platform for which configure finds a method and it can fail.
353 Mark some changes with XXX to be cleaned up post 0.98.
354
ajsaf04bd72004-12-28 17:00:12 +00003552004-12-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
356
ajs1d75c8c2004-12-28 21:43:17 +0000357 * sockopt.c: (setsockopt_ipv4_ifindex) Improve error message.
358 When neither IP_PKTINFO nor IP_RECVIF is defined, make return value
359 deterministic (-1).
360
3612004-12-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
362
ajsaf04bd72004-12-28 17:00:12 +0000363 * thread.c: (funcname_thread_add_timer_msec) Reduce overflow risk.
364
paul4ba9b922004-12-21 22:34:58 +00003652004-12-21 Paul Jakma <paul.jakma@sun.com>
366
367 * if.h: Add more 'non-generic' IFF_ flags.
368 * if.c: IFF_NOXMIT/IFF_VIRTUAL interfaces are 'loopback like'
paul0e43a2b2004-12-22 00:15:34 +0000369 * stream.c: Dont allocate streams with 0 sized data buffers
paul4ba9b922004-12-21 22:34:58 +0000370
ajs202d08c2004-12-17 20:50:00 +00003712004-12-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
ajs2885f722004-12-17 23:16:33 +0000372
373 * command.c: (do_echo) Added new "echo" command, useful for
374 watchdog pinging to make sure the daemon is responsive.
375
3762004-12-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
ajs202d08c2004-12-17 20:50:00 +0000377
378 * pid_output.c: (pid_output_lock) Eliminate static function, and just
379 use the #ifdef to decide which version of the function to include.
380 This eliminates a compilation problem with gcc4. And fix the
381 non-fcntl version so that it actually compiles. Exit with
382 status 1 instead of -1 on error.
383
ajs81fc57c2004-12-15 17:41:14 +00003842004-12-15 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
385
386 * sigevent.c: (trap_default_signals) Ignore SIGPIPE instead of exiting.
387
ajs3378d202004-12-10 22:43:17 +00003882004-12-10 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
389
390 * log.c: (zlog_signal,_zlog_assert_failed) Change logging level back to
391 LOG_ERR instead of LOG_EMERG.
392
ajsc3324c62004-12-09 17:26:31 +00003932004-12-09 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
394
395 * log.c: (hex_append) No need to include this function if
396 HAVE_GLIBC_BACKTRACE is not defined.
397
ajsb9e70282004-12-08 17:14:45 +00003982004-12-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
399
400 * prefix.c: (prefix_copy) Error message before abort should
401 have severity LOG_ERR, not LOG_INFO.
402 * memory.c: (mtype_log) Log level should be LOG_DEBUG, not LOG_INFO.
403
ajs274a4a42004-12-07 15:39:31 +00004042004-12-07 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
405
ajs8ddca702004-12-07 18:53:52 +0000406 * {smux.c,zclient.c}: Change level of debug messages to LOG_DEBUG.
407
4082004-12-07 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
409
ajs82146b82004-12-07 17:15:55 +0000410 * command.c: (config_write_host) Note that "log trap" is deprecated
411 when writing out the config.
412
4132004-12-07 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
414
ajs274a4a42004-12-07 15:39:31 +0000415 * log.h: Replace struct zlog flags and maskpri fields with maxlvl
416 array to support individual logging levels for each destination.
417 Remove the 2nd argument to openzlog since the default logging config
418 should be standardized inside the library. Replaced the
419 zlog_set_flag and zlog_reset_flag functions with zlog_set_level.
420 And zlog_set_file now requires an additional log_level argument.
421 Declare zlog_proto_names for use inside command.c in the
422 "show logging" command. Added defines useful for command
423 construction.
424 * log.c: (vzlog) Decide where to send the message based on the
425 individual logging levels configured for each destination.
426 Remove support for ZLOG_STDERR since it was never actually used.
427 Support record-priority for terminal monitors.
428 (zlog_signal,zlog_backtrace_sigsafe) Support destination-specific
429 logging levels. Remove stderr support (was never used). Added
430 support for terminal monitor logging.
431 (_zlog_assert_failed) Increase message severity to LOG_EMERG.
432 (openzlog) Remove 2nd argument since default config should be
433 standardized in library. By default, terminal monitoring
434 is set to debug, and all other logging is disabled.
435 (zlog_set_flag,zlog_reset_flag) Removed.
436 (zlog_set_level) New function to replace zlog_set_flag and
437 zlog_reset_flag. Supports destination-specific logging levels.
438 (zlog_set_file,zlog_reset_file) Support file-specific logging level.
439 (zlog_rotate) Log an error message if fopen fails, and support
440 new file-specific logging level.
441 * command.h: Change DEFUN_CMD_FUNC_DECL and DEFUN_CMD_FUNC_TEXT so that
442 command functions will be static instead of global. Remove
443 declarations for config_exit and config_help. Define new macros
444 DEFUNSH_ATTR, DEFUNSH_HIDDEN, and DEFUNSH_DEPRECATED so we can
445 have deprecated commands in vtysh. Similarly, for completeness,
446 define macros ALIAS_SH, ALIAS_SH_HIDDEN, and ALIAS_SH_DEPRECATED.
447 Also, fix bug in ALIAS_ATTR macro (didn't matter because it
448 was never used).
449 * command.c: Make many functions static instead of global.
450 (facility_name,facility_match,level_match) New functions
451 to support enhanced destination-specific logging levels.
452 (config_write_host) Support new destination-specific logging levels.
453 (config_logmsg) Added new "logmsg" command to help test logging
454 system.
455 (show_logging) Added "show logging" command to show the current
456 configuration of the logging system.
457 (config_log_stdout_level) Support explicit stdout logging level.
458 (no_config_log_stdout) Now takes optional LEVEL arg.
459 (config_log_monitor,config_log_monitor_level,no_config_log_monitor)
460 New commands creating new "log monitor" commands to set terminal
461 monitoring log level.
462 (config_log_file_level) Support explicit file logging level.
463 (config_log_syslog_level) Support explicit syslog logging level.
464 (config_log_facility,no_config_log_facility) Implement new
465 "log facility" command.
466 (cmd_init) Add hooks for new commands: "show logging", "logmsg",
467 "log stdout <level>", "log monitor", "log monitor <level>",
468 "no log monitor", "log file <filename> <level>",
469 "no log file <filename> <level>", "log syslog <level>",
470 "log facility", and "no log facility".
471 * vty.h: Added a "level" argument to vty_log so it can support
472 "log record-priority". Declare new function vty_log_fixed for
473 use in signal handlers.
474 * vty.c: (vty_log,vty_log_out) Added a "level" argument to support
475 "log record-priority" for vty terminal monitors.
476 (vty_down_level) Use config_exit_cmd.func instead of calling
477 config_exit directly (since command functions will now be static
478 instead of global).
479 (vty_log_fixed) New function to send terminal monitor messages
480 from inside a signal handler.
481
ajs887c44a2004-12-03 16:36:46 +00004822004-12-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
483
ajs5e764772004-12-03 19:03:33 +0000484 * log.h: Document appropriate use of syslog logging priorities
485 inside quagga.
486
4872004-12-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
488
ajs56f20692004-12-03 17:40:31 +0000489 * command.h: Remove fields log_stdout and log_syslog from struct host,
490 since they are just trying to duplicate information in the
491 zlog_default structure. Note that this fixes a bug since those
492 fields were not registering any logging that was established
493 in the initial call to openzlog (this affects only the zebra and
494 ospf6d daemons). It is probably a bug to turn on any logging by
495 default in the call to openzlog.
496 * command.c: (config_write_host) Get logging info from zlog_default
497 instead of now-removed fields host.log_stdout and host.log_syslog.
498 (config_log_stdout,no_config_log_stdout) Do not set now-removed field
499 host.log_stdout, since this info is recorded in zlog_default.
500 (config_log_file) Use XSTRDUP (instead of strdup) to set host.logfile.
501 (config_log_syslog,config_log_syslog_facility,no_config_log_syslog)
502 Do not set now-removed field host.log_syslog, since this info is
503 recorded in zlog_default.
504
5052004-12-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
506
ajs887c44a2004-12-03 16:36:46 +0000507 * version.h.in: Remove declaration for pid_output_lock, this function
508 is now static, not global.
509 * pid_output.c: (pid_output_lock) This function should be static, not
510 global. And remove "old umask" error message, since it was really
511 an unimportant debug message, not an error.
512 (pid_output) Need to declare static function pid_output_lock.
513
ajs7d149b82004-11-28 23:00:01 +00005142004-11-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
515
516 * log.h: Remove several unused fields from struct zlog. Add comments
517 for other fields, and add one new field syslog_options that is
518 used in the new syslog_sigsafe implementation.
519 * log.c: (syslog_sigsafe) New function to send syslog messages in
520 an async-signal safe way that can be used inside a signal handler.
521 (syslog_connect) New function to connect to syslog daemon inside a
522 signal handler. This function supports only systems where /dev/log
523 is a unix datagram socket (e.g. not Solaris).
524 (zlog_signal) Call syslog_sigsafe if syslog logging is enabled.
525 (zlog_backtrace_sigsafe) Call syslog_sigsafe if syslog logging is
526 enabled.
527 (openzlog) Save syslog_options for use in syslog_sigsafe.
528 (num_append) Fix bug: handle 0 properly.
529 (hex_append) New function to print a u_long in hex format.
530
hasso2557aed2004-11-28 21:16:20 +00005312004-11-28 Hasso Tepper <hasso at quagga.net>
532
533 * command.h: DEFUN_DEPRECATED passes attribute to DEFUN as well.
534
ajsd1c51d72004-11-26 14:14:30 +00005352004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
536
ajs48d6c692004-11-26 20:52:59 +0000537 * log.c, log.h, memory.c: Change function name from zlog_backtrace_safe
538 to the more self-explanatory zlog_backtrace_sigsafe.
539
5402004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
541
ajs5b85fac2004-11-26 19:36:42 +0000542 * debug.[ch]: Remove unused files.
543 * Makefile.am: Remove references to debug.c and debug.h
544
5452004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
546
ajs063ee522004-11-26 18:11:14 +0000547 * log.c: (zlog_backtrace) New function to log a backtrace.
548 (zlog_backtrace_safe) Log a backtrace in an async-signal-safe way.
549 Unfortunately, this function does not support syslog logging yet.
550 (zlog_signal) Move backtrace code into separate function
551 zlog_backtrace_safe.
552 (_zlog_assert_failed) Call zlog_backtrace before aborting.
553 * log.h: Declare new functions zlog_backtrace and zlog_backtrace_safe.
554 * memory.c: (zerror) Call zlog_backtrace before aborting.
555
5562004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
557
ajsd1c51d72004-11-26 14:14:30 +0000558 * Makefile.am: Need to add zassert.h to pkginclude_HEADERS.
559
ajse5879ca2004-11-25 16:07:53 +00005602004-11-25 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
561
ajs4cf0d0d2004-11-25 17:14:34 +0000562 * zebra.h: If not C99 and there's no va_copy macro and there is
563 a __va_copy macro, define va_copy as __va_copy.
564
5652004-11-25 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
566
ajse5879ca2004-11-25 16:07:53 +0000567 * pid_output.c: (pid_output_lock) Fix 2 bugs: when locking, should
568 set l_whence to SEEK_SET, not SEEK_END. And after writing new
569 pid to file, must ftruncate to eliminate any extraneous bytes left
570 over from the last time a pid was written.
571
ajscee3df12004-11-24 17:14:49 +00005722004-11-24 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
573
574 * zassert.h: New header file to declare a quagga-specific assert macro.
575 * log.c: (_zlog_assert_failed) New function called when assert fails
576 to log the error and abort.
577 * zebra.h: Include "zassert.h" instead of <assert.h>.
578 * regex.c: Include "zassert.h" instead of <assert.h>.
579
ajsd246bd92004-11-23 17:35:08 +00005802004-11-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
581
ajs59a06a92004-11-23 18:19:14 +0000582 * sigevent.c: (signal_init) Set up some default signal handlers
583 so that processes will issue an error message before terminating
584 or dumping core.
585 (trap_default_signals) New function to set up signal handlers
586 for various signals that may kill the process.
587 (exit_handler) Call zlog_signal, then _exit.
588 (core_handler) Call zlog_signal, then abort.
589 * log.h: Declare new function zlog_signal.
590 * log.c: (zlog_signal) New function to log information about
591 a received signal before the process dies. Try to log a
592 backtrace also.
593 (quagga_signal_handler,signal_set) Should be static.
594
5952004-11-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
596
ajsd246bd92004-11-23 17:35:08 +0000597 * log.c: (vzlog) Take a single va_list argument and use va_copy
598 as necessary for multiple traversals.
599 (zlog) Pass only one va_list to vzlog.
600 (zlog_*,plog_*) Use a macro for boilerplate code; pass only one
601 va_list to vzlog.
602 (zlog_set_file) Remove unused 2nd argument (flags).
603 (zlog_save_cwd,zlog_get_cwd,zlog_free_cwd) Remove unused functions.
604 * log.h: Remove ZLOG_*_INDEX defines (no longer used).
605 Remove unused 2nd argument from zlog_set_file prototype.
606 Fix prototype for zlog_rotate.
607 * command.c: (config_log_file) Remove unused 2nd arg to zlog_set_file.
608 * vty.c: (vty_out) Fix stdarg usage to perform multiple traversals
609 properly.
610 (vty_log) Must use va_copy for multiple traversals of va_list arg.
611
ajsca359762004-11-19 23:40:16 +00006122004-11-19 David Young <dyoung@pobox.com>
613
614 * log.c: (safe_strerror) New function: safe wrapper for strerror.
615
ajsff29bb32004-11-19 18:29:22 +00006162004-11-19 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
617
618 * sockopt.c: (setsockopt_so_recvbuf) Stop error message from being
619 printed every time.
620
ajsf858e492004-11-16 14:25:30 +00006212004-11-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
622
623 * memory.h: Fix prototype for memory_init().
624 * memory.c: Declare many functions and data structures static instead
625 of global. Fix prototype for memory_init().
626
gdt69e13252004-11-15 18:51:15 +00006272004-11-15 Greg Troxel <gdt@fnord.ir.bbn.com>
628
629 * sockopt.h: Avoid CMSG_ALIGN, and declare that sizes are without
630 alignment (users should use CMSG_SPACE).
631
632 * zebra.h: Rationalize CMSG_SPACE compatibility defines. Warn if
633 asumming 4-byte alignment, since this isn't safe.
634
ajs7fa25ff2004-11-15 16:12:32 +00006352004-11-15 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
636
637 * memory.c: (zerror) Use zlog_err instead of fprintf to stderr.
638 Instead of exiting, log currenty memory usage and then abort.
639 (log_memstats) New function to log memory statistics, called by
640 zerror.
641 (show_memory_all) Loop over new mlists array instead of calling
642 show_memory_vty separately for each memory_list.
643
paulb86718e2004-11-08 17:34:07 +00006442004-11-08 Paul Jakma <paul@dishone.st>
paulb35e5b42004-11-07 22:27:27 +0000645
paul2265d202004-11-08 15:43:21 +0000646 * buffer.c: Add missing include of log.h.
647 (buffer_flush_available) written is compared against
648 mostly against unsigned types, only for the writev do we need
649 signed compare, so declare it as size_t and cast it to ssize_t
650 just for the error compare when we've called writev.
651 * buffer.h: Add comment that buffer data sizes really should be
652 size_t.
653
6542004-11-07 Paul Jakma <paul@dishone.st>
655
656 * version.h.in: add autoconf configure_input output var
paulb35e5b42004-11-07 22:27:27 +0000657
ajs49ff6d92004-11-04 19:26:16 +00006582004-11-04 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
659
ajs5a646652004-11-05 01:25:55 +0000660 * vty.h: Remove fields in struct vty that were related to VTY_CONTINUE
661 capabilities (that were used only in bgpd/bgp_route.c and are now
662 removed). Also remove some other fields that were not being
663 used at all.
664 * vty.c: (vty_execute) Do not test for obsolete status values VTY_START
665 and VTY_CONTINUE.
666 (vty_read) Remove calls to vty->output_func since that was part
667 of the VTY_CONTINUE infrastructure that has been removed.
668 (vty_flush) Remove code to support VTY_START and VTY_CONTINUE.
669 (vty_close) Remove code to cancel vty->t_output thread, since that
670 thread was never actually used.
671
6722004-11-04 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
673
ajs49ff6d92004-11-04 19:26:16 +0000674 * vty.c: Vtysh connections to daemons should use buffering.
675 (vty_out) Remove exception for vty_shell_serv, just use buffer_write.
676 (vty_new) Increase output buffer size to 4096 rounded up to a
677 multiple of pagesize.
678 (vtysh_read) After command has been executed and all output buffered,
679 call buffer_flush_available and schedule further writes if the
680 buffers are not yet empty.
681 (vtysh_write) New function to flush output to vtysh when the socket
682 is writeable.
683 (vty_event) Added new VTYSH_WRITE event for flushing buffers to vtysh
684 clients. Also, should save read thread in vty->t_read so the
685 thread can be cancelled in vty_close.
686 * buffer.h: In struct buffer_data, remove unused "parent" field.
687 Convert "unsigned char *data" to "unsigned char data[0]" to save
688 a malloc. Declare new function buffer_flush_available that works
689 with non-blocking sockets.
690 * buffer.c: (buffer_data_new) Use a single malloc now that data is
691 a variable-size array at end of structure.
692 (buffer_data_free) Just a single free now that data is part of the
693 structure.
694 (buffer_write) Simplify the logic to make behavior more transparent.
695 (buffer_flush) Decrease b->length as data is written out.
696 (buffer_flush_vty_all) Decrease b->length as buffers are freed.
697 (buffer_flush_vty) Decrease b->length as data is written out.
698 (buffer_flush_available) New function to flush non-blocking sockets.
699
paule064d6d2004-11-01 08:59:21 +00007002004-11-01 Paul Jakma <paul@dishone.st>
701
702 * sockopt.c: (setsockopt_pktinfo) remove, its unused.
703
paul75e15fe2004-10-31 02:13:09 +00007042004-10-31 Paul Jakma <paul@dishone.st>
705
706 * vty.c: As per Andrew's suggestions..
707 (vty_serv_un) remove flags.
708 (vtysh_accept) close socket if we cant set NONBLOCK. Add flags.
paul66cbbce2004-10-31 16:15:33 +0000709 * keychain.c: Convert some more strtoul users to VTY_GET_INTEGER.
paul9d11a192004-10-31 16:19:24 +0000710 * memory.h: Add MTYPE_THREAD_FUNCNAME and MTYPE_THREAD_STATS
711 * thread.c: Update stats and funcname alloc/free to use previous
paul039b9572004-10-31 16:43:17 +0000712 specific memory type defines. Use XCALLOC and sizeof the type,
713 not the pointer.
paul70e149e2004-10-31 16:29:50 +0000714 * smux.c: fix int to size_t compile warnings
paul75e15fe2004-10-31 02:13:09 +0000715
pauldccfb192004-10-29 08:29:36 +00007162004-10-29 Paul Jakma <paul@dishone.st>
717
718 * vty.c: Move setting of sock to O_NONBLOCK from vty_serv_un
719 to vtysh_accept, where sock is the actual fd we wanted to set to
720 O_NONBLOCK, ie the /connected/ vtysh unix socket.
721
hasso508ec912004-10-23 14:26:49 +00007222004-10-23 Hasso Tepper <hasso at quagga.net>
723
724 * zclient.c: Unbreak reading interface update message. Might fix
725 blocker bugzilla #109.
726
paul23b9c612004-10-22 11:51:57 +00007272004-10-22 Paul Jakma <paul@dishone.st>
paul7d9c6e52004-10-22 10:54:39 +0000728
729 * sockopt.c: (getsockopt_ipv4_ifindex) no ifindex should be 0, not
paul23b9c612004-10-22 11:51:57 +0000730 -1.
731 (setsockopt_pktinfo) unexported
732 * sockopt.h: Cleanup SOCKOPT_CMSG defines a bit. Add a throwaway
733 define for SOPT_SIZE_CMSG_IFINDEX_IPV4 for systems which have
paul4ccb2c42004-10-22 22:52:33 +0000734 neither IP_RECVIF nor IP_PKTINFO (eg openbsd), thanks to Rivo
735 Nurges for highlighting problem and fix.
paul4927cf02004-10-22 16:55:10 +0000736 Fix elif that should be an else.
paul406d6712004-10-22 12:27:44 +0000737 * command.h: Cleanup the defines a bit, add helper defines and
738 collapse all defines to use those. Add an attribute field to
739 cmd_element to support, eg hidden or deprecated commands, add
740 defun defines for such. All that's left to do is add logic
741 to command.c to check these attributes... ;)
paulaf0d97e2004-10-22 23:24:43 +0000742 * zebra.h: reserve ZEBRA_ROUTE_HSLS
paul7d9c6e52004-10-22 10:54:39 +0000743
hasso6590f2c2004-10-19 20:40:08 +00007442004-10-19 Hasso Tepper <hasso at quagga.net>
745
746 * version.h.in: Define copyright string QUAGGA_COPYRIGHT.
747 * print_version.c: Remove. print_version () function moved to
748 command.[c|h].
749 * command.c: Use QUAGGA_COPYRIGHT.
750 * Makefile.am: Remove useless version.c and print_version.c files.
751
hasso3fb9cd62004-10-19 19:44:43 +00007522004-10-19 Andrew J. Schorr <aschorr@telemetry-investments.com>
753
754 * zclient.c: (zebra_interface_address_read) If the destination address
755 is encoded as all zeroes, load it as a NULL pointer.
756 * if.h: Add comment describing struct connected destination field
757 and indicating that it may be NULL. Define macros
758 CONNECTED_DEST_HOST and CONNECTED_POINTOPOINT_HOST to help
759 with PtP logic (distinguish between host and subnet addressing).
760 * if.c: (if_lookup_address) Fix PtP logic to handle subnet addressing
761 properly,
762 (connected_lookup_address) ditto.
763 (connected_add_by_prefix) Handle case where destination is NULL,
764 * prefix.[c|h]: New functions ipv4_network_addr and
765 ipv4_broadcast_addr.
766
hassoddd85ed2004-10-13 08:18:07 +00007672004-10-13 Hasso Tepper <hasso at quagga.net>
768
769 * command.c: Make CMD_ERR_NOTHING_TODO nonfatal if reading
770 configuration from file. Fixes critical bugzilla #113.
hassoc75105a2004-10-13 10:33:26 +0000771 * smux.c, smux.h: Remove all defaults to initialize smux connection to
772 snmpd by default even if not configured to do so. "smux peer OID
773 <password>" initializes now connection and "no smux peer" terminates
774 it.
hassoddd85ed2004-10-13 08:18:07 +0000775
paul42d49862004-10-13 05:22:18 +00007762004-10-13 Paul Jakma <paul@dishone.st>
777
778 * (global) more const'ification.
779 * sockunion.c: (sockunion_su2str) buffer should be sized
780 SU_ADDRSTRLEN.
781 (sockunion_log) do not return stack variables, strdup buf before
782 return.
783 * vty.h: Fix up the VTY_GET_INTEGER macros. Testing caller supplied
784 values against ULONG_MAX is daft, when caller probably has passed
785 a type that can not hold ULONG_MAX. use a temporary long instead.
786 Add VTY_GET_LONG, make VTY_GET_INTEGER_RANGE use it, make
787 VTY_GET_INTEGER a define for VTY_GET_INTEGER_RANGE.
788
hassoa1494112004-10-11 12:53:17 +00007892004-10-11 Hasso Tepper <hasso at quagga.net>
790
791 * command.h: Sync DEFUNSH with other macros.
792 * sockunion.c, sockunion.h: More const strings.
793
paul9076fbd2004-10-11 09:40:58 +00007942004-10-11 Paul Jakma <paul@dishone.st>
795
796 * thread.c: (funcname_thread_add_timer)
797 (funcname_thread_add_timer_msec) Fix mistakes from last change.
798 Pointed out by Liu Xin in [quagga-dev 1609].
paulc9eca012004-10-11 11:28:44 +0000799 * if.h: mtu's should be unsigned.
800 * routemap.{c,h}: const char updates
801 * smux.{c,h}: ditto
paul9076fbd2004-10-11 09:40:58 +0000802
paul9035efa2004-10-10 11:56:56 +00008032004-10-10 Paul Jakma <paul@dishone.st>
paul47ca2952004-10-10 08:03:18 +0000804
805 * version.h.in: (pid_output*) add const qualifier.
paul9035efa2004-10-10 11:56:56 +0000806 * command.h: Change DEFUN func to take const char *[] rather
807 than char **, to begin process of fixing compile warnings in lib/.
808 Nearly all other changes in this commit follow from this change.
809 * buffer.{c,h}: (buffer_write) pointer-arithmetic is gccism, take
810 const void * and cast an automatic const char *p to it.
811 (buffer_putstr) add const
812 * command.c: (zencrypt) const qualifier
813 (cmd_execute_command_real) ditto
814 (cmd_execute_command_strict) ditto
815 (config_log_file) ditto.
816 Fix leak of getcwd() returned string.
817 * memory.{c,h}: Add MTYPE_DISTRIBUTE_IFNAME for struct dist ifname.
818 * distribute.{c,h}: Update with const qualifier.
819 (distribute_free) use MTYPE_DISTRIBUTE_IFNAME
820 (distribute_lookup) Cast to char *, note that it's ok.
821 (distribute_hash_alloc) use MTYPE_DISTRIBUTE_IFNAME.
822 (distribute_get) Cast to char *, note that it's ok.
823 * filter.c: Update with const qualifier.
824 * if.{c,h}: ditto.
825 * if_rmap.{c,h}: ditto.
826 (if_rmap_lookup) Cast to char *, note that it's ok.
827 (if_rmap_get) ditto.
828 * log.{c,h}: Update with const qualifier.
829 * plist.{c,h}: ditto.
830 * routemap.{c,h}: ditto.
831 * smux.{c,h}: ditto. Fix some signed/unsigned comparisons.
832 * sockopt.c: (getsockopt_cmsg_data) add return for error case.
833 * vty.c: Update with const qualifier.
834
hasso27a43a82004-10-08 06:29:12 +00008352004-10-08 Hasso Tepper <hasso at quagga.net>
836
837 * routemap.c, routemap.h: Make some string arguments const.
838
paul5973ee72004-10-08 01:36:54 +00008392004-10-05 Paul Jakma <paul@dishone.st>
840
841 * version.h.in: print_version declaration is here, not in automake
842 generated version.h.
843
hassoea8e9d92004-10-07 21:32:14 +00008442004-10-08 Hasso Tepper <hasso at quagga.net>
845
846 * command.c, command.h: Make argument of cmd_make_strvec function
847 const.
848 * command.c: Make hostname commands usable in vtysh again.
849
hasso6ad96ea2004-10-07 19:33:46 +00008502004-10-07 Hasso Tepper <hasso at quagga.net>
851
852 * command.c, pid_output.c, print_version.c, vty.c, vty.h: Make more
853 strings const.
854
hasso8c328f12004-10-05 21:01:23 +00008552004-10-05 Hasso Tepper <hasso at quagga.net>
856
857 * *.[c|h]: Make many strings cons and a lot of int -> unsigned int
858 changes to fix warnings.
859
paul96e27c92004-10-05 14:33:43 +00008602004-10-05 Paul Jakma <paul@dishone.st>
861
862 * sockopt.{c,h}: add sockopt_iphdrincl_swab_{htosys,systoh},
863 functions to change byte order between system IP_HDRINCL order
864 and host order.
paul98c91ac2004-10-05 14:57:50 +0000865 * thread.c: (funcname_thread_add_timer_timeval) new function, add
866 timer at specified timeval.
867 (funcname_thread_add_timer) use funcname_thread_add_timer_timeval.
868 (funcname_thread_add_timer_msec) ditto
paul96e27c92004-10-05 14:33:43 +0000869
hassob04c6992004-10-04 19:10:31 +00008702004-10-04 Hasso Tepper <hasso at quagga.net>
871
872 * memory.c, memory.h: Make char * argument of strdup functions const.
873 * prefix.c, prefix.h: Make many arguments const. Reorder stuff in
874 header.
875 * log.h: Make log message const in struct message.
876 * log.c: Fix some indenting.
877 * network.c, network.h: Make second argument of writen() const.
878
hassoe7168df2004-10-03 20:11:32 +00008792004-10-03 Hasso Tepper <hasso at quagga.net>
880
881 * command.h: Introduce SERVICE_NODE for "service <...>" commands.
882 * command.c: Don't initialize commands that don't make sense if vtysh
883 is used.
884 * vty.c: Make VTY_NODE appear in vtysh.
885
hasso18a6dce2004-10-03 18:18:34 +00008862004-10-03 James R. Leu <jleu at mindspring.com>
887
888 * zclient.c, zclient.h: zclient functions for router id handling.
889 * zebra.h: New message types for router id handling.
890
paul9172ee02004-09-27 12:46:37 +00008912004-09-27 Paul Jakma <paul@dishone.st>
892
893 * zebra.h: Add WANT_OSPF_WRITE_FRAGMENT for ospfd
894 to try to fragment oversized packets. Enabled only for Linux.
895 Add HAVE_IP_HDRINCL_BSD_ORDER to define struct ip byte order,
896 to consolidate various ad-hoc platform defines for same thing.
897
hassoe473b032004-09-26 16:08:11 +00008982004-09-26 Hasso Tepper <hasso at quagga.net>
899
900 * vty.c, sockopt.c: Fix compiler warnings.
901
hasso52dc7ee2004-09-23 19:18:23 +00009022004-09-23 Hasso Tepper <hasso at quagga.net>
903
904 * linklist.h: Remove list and listnode typedefs.
905 * *.[c|h]: list -> struct list *, listnode -> struct listnode *.
906
paul0b3acf42004-09-17 08:39:08 +00009072004-09-17 Paul Jakma <paul@dishone.st>
908
paulb89e60c2004-09-21 15:43:13 +0000909 * sockopt.c: Add missing bracket
910
9112004-09-17 Paul Jakma <paul@dishone.st>
912
paul0b3acf42004-09-17 08:39:08 +0000913 * sockopt.{c,h}: Add setsockopt_so_recvbuf, for ripd and ripngd.
914
paul33394762004-09-13 11:27:57 +00009152004-09-13 Paul Jakma <paul@dishone.st>
916
917 * command.c: Update the copyright string in the default motd.
918
gdt630e4802004-08-31 17:28:41 +00009192004-08-31 David Wiggins <dwiggins@bbn.com>
920
921 * hash.c (hash_iterate): Save next pointer before calling
922 procedure, so that iteration works even if the called procedure
923 deletes the hash backet.
924
925 * linklist.h (listtail): new macro, not yet used.
926
hasso34553cc2004-08-27 13:56:39 +00009272004-08-27 Hasso Tepper <hasso at quagga.net>
928
929 * command.c: Install "terminal length" commands only if vty is used.
930 Vtysh will handle it itself.
931
gdtafa43b22004-08-26 13:12:41 +00009322004-08-26 Greg Troxel <gdt@fnord.ir.bbn.com>
933
934 * sockopt.h: Define method-independent macro for callers of
935 get_ifindex to use for cmsg length.
936
paule6822762004-08-19 04:13:29 +00009372004-08-19 Paul Jakma <paul@dishone.st>
938
paulefba6ce2004-08-25 13:47:16 +0000939 * zebra.h: add MAX and MIN defines (eg for ospf6d)
940
9412004-08-19 Paul Jakma <paul@dishone.st>
942
paule6822762004-08-19 04:13:29 +0000943 * sockopt.c: include sockopt.h
944 rename some of the _pktinfo_ functions to _ifindex, where that is
945 their purpose.
946 (getsockopt_ipv6_pktinfo_ifindex) renamed to
947 getsockopt_ipv6_ifindex.
948 (setsockopt_ipv4_pktinfo) renamed to setsockopt_ipv4_ifindex
949 (setsockopt_pktinfo) update with previous and add comment re
950 AF_INET portability.
951 (setsockopt_ifindex) generic ifindex function ala
952 setsockopt_pktinfo.
953 (getsockopt_ipv4_pktinfo_ifindex) renamed to
954 getsockopt_ipv4_ifindex.
955 (getsockopt_ipv4_ifindex) rejiggling to reduce repeated
956 ifdef/elses. pktinfo case forgot to set ifindex.
957 (getsockopt_pktinfo_ifindex) renamed to
958 getsockopt_ifindex. update some calls to renamed functions.
959 * sockopt.h: Update renamed exported functions
960 Rename the CMSG_SIZE macros to IFINDEX.
961 Guard IPv4 PKTINFO in a conditional define.
962
paulc0618de2004-08-18 21:52:58 +00009632004-08-18 Paul Jakma <paul@dishone.st>
964
965 * vty.c: (vty_serv_un) set unix vty socket to nonblocking
966 to prevent inadvertent blocking of daemons by use of
967 vtysh. TODO: disentangle manual paging from the buffer_write
968 path so that unix vty can use this path too and be reliable.
969
gdt33f92322004-07-23 16:14:32 +00009702004-07-23 Greg Troxel <gdt@poblano.ir.bbn.com>
971
972 * sockopt.c (getsockopt_ipv4_pktinfo_ifindex): Make this compile
973 on NetBSD, and add comments to make it less confusing. Change the
974 sense of the SUNOS_5 test to make parallel structure between the
975 variables and the code.
976
paul4f7baa02004-07-23 15:11:07 +00009772004-07-23 Paul Jakma <paul@dishone.st>
978
979 * sockopt.h: Add SOPT_SIZE_CMSG_PKTINFO{_IPV{4,6}} define, for
980 sizeof pktinfo as appropriate, to be used when allocating msg
981 buffers. export setsockopt_pktinfo() and
982 getsockopt_pktinfo_ifindex()
983 * sockopt.c: (setsockopt_pktinfo_ifindex) new function to portably
984 set received ifindex sock option.
985 (getsockopt_pktinfo_ifindex) portably retrieve ifindex.
986 (getsockopt_cmsg_data) retrieve indicated control info from
987 message header.
988 (getsockopt_ipv6_pktinfo_ifindex) ipv6 version of above.
989 (setsockopt_ipv4_pktinfo) v4 version
990 (setsockopt_pktinfo) the exported version
991 (getsockopt_ipv4_pktinfo_ifindex) v4 specific version
992 (getsockopt_pktinfo_ifindex) the exported version
993
paul05c447d2004-07-22 19:14:27 +00009942004-07-14 Paul Jakma <paul@dishone.st>
995
996 * sigevent.c: (quagga_signal_handler) add a global caught flag, set
997 the flags to a constant rather increment to be kinder.
998 (quagga_sigevent_process) new function, to do core of what
999 quagga_signal_timer did. dont block signals at all as sig->caught
1000 is volatile sig_atomic_t and should be safe to access from signal
1001 and normal contexts. The signal blocking is unneeded paranoia, but
1002 is left intact under an ifdef, should some platform require it.
1003 Check global caught flag before iterating through array.
1004 (quagga_signal_timer) nearly everything moved to
1005 quagga_sigevent_process. Left in under ifdef, in case some
1006 platform could use a regular timer check for signals.
1007 * sigevent.h: quagga_sigevent_process declaration.
1008 * thread.c: (thread_fetch) check for signals at beginning of
1009 scheduler loop, check for signals if select returns EINTR.
1010
gdtb7797132004-07-13 13:47:25 +000010112004-07-13 Greg Troxel <gdt@poblano.ir.bbn.com>
1012
1013 * sigevent.c: Don't block SIGTRAP and SIGKILL. Blocking SIGTRAP
1014 confuses gdb, at least on NetBSD 2.0_BETA, where the block
1015 succeeds.
1016
paul5510e832004-07-09 14:00:01 +000010172004-07-09 Paul Jakma <paul@dishone.st>
1018
1019 * Merge Kunihiro's 'show route-map' change and add
1020 compatibility aliases for route-map continue
paulb9790b32004-07-09 14:05:47 +00001021 * jhash.{c,h}: New files. Bob Jenkins' public domain hashing
1022 function, as implemented in linux kernel by David Miller.
paul5510e832004-07-09 14:00:01 +00001023
paulb06c14f2004-07-09 12:24:42 +000010242004-07-09 Juris Kalnins <juris@mt.lv>
1025
1026 * if.c: (if_cmp_func) fix for interface names where name is same,
1027 but one has no number, eg "devtyp" and "devtyp0".
1028
gdt87efd642004-06-30 17:36:11 +000010292004-06-30 Greg Troxel <gdt@poblano.ir.bbn.com>
1030
1031 * Makefile.am: Make libzebra shared.
1032
paul138ce752004-06-21 10:35:59 +000010332004-06-21 Paul Jakma <paul@dishone.st>
1034
1035 * ChangeLog: fix my last update config.h -> zebra.h ;)
1036 * zebra.h: Fix gcc check.
1037
paul02ff83c2004-06-11 11:27:03 +000010382004-06-11 Sowmini Varadhan <sowmini.varadhan@sun.com>
1039
1040 * filter.c: (access_list_remark_cmd) buffer_putstr doesnt need cast
1041 to u_char. (ipv6_access_list_remark_cmd) ditto.
1042 if.c: ditto
1043 * network.c: (readn/writen) pointer arg should be type u_char.
1044 * plist.c: needs to include stream.h, not declare stream functions
1045 internally.
1046 (various) Add static qualifier to internal functions.
1047 (prefix_list_type_str) extraneous breaks in switch statement.
1048 (ip_prefix_list_description_cmd) buffer_putstr doesnt need cast
1049 * stream.h: depends on plist.h and export stream_put_prefix
1050 * vty.c: (vty_<telnet option build functions>) should use
1051 unsigned char, telnet options are 0 -> 255.
1052 * zclient.c: various u_char<->char type cleanups.
1053 * zebra.h: Having to define CMSG_* can apply to more than just
1054 BSDI_NRL.
1055
paul51a87982004-06-09 10:36:05 +000010562004-06-09 Paul Jakma <paul@dishone.st>
1057
paul138ce752004-06-21 10:35:59 +00001058 * zebra.h: __attribute__ is a gcc'ism
paul51a87982004-06-09 10:36:05 +00001059
paul5228ad22004-06-04 17:58:18 +000010602004-06-04 Paul Jakma <paul@dishone.st>
1061
1062 * type mismatch fixes
1063
hasso6708fa32004-05-18 18:46:54 +000010642004-05-18 Hasso Tepper <hasso@estpak.ee>
1065
1066 * pqueue.[c|h]: Added as part of ospf6d merge from Zebra repository.
1067
paul0a589352004-05-08 11:48:26 +000010682004-05-08 Paul Jakma <paul@dishone.st>
1069
1070 * zclient.c (zapi_ipv4_route) Follow Sowmini's lead and describe
1071 message format.
1072
10732004-05-08 Sowmini Varadhan <sowmini.varadhan@sun.com>
1074
1075 * zclient.c: (zapi_ipv4_add) collapsed into zapi_ipv4_route
1076 (zapi_ipv4_delete) ditto.
1077 (zapi_ipv4_route) add/delete a route by way of cmd arg.
1078 (zapi_ipv6_add) collapsed into zapi_ipv6_route.
1079 (zapi_ipv6_delete) ditto.
1080 (zapi_ipv6_route) add/delete a route by way of cmd arg.
1081 (zebra_interface_address_delete_read) collapsed into
1082 zebra_interface_address_read.
1083 (zebra_interface_address_delete_read) ditto.
1084 (zebra_interface_address_read) read address add/delete messages
1085 by way of type argument. Describe command message format.
1086 (zebra_interface_add_read) Unconditionally read new ifmtu6 field.
1087 Describe command message format.
1088 (zebra_interface_state_read) Unconditionally read new ifmtu6 field.
1089 (zclient_redistribute_set) Collapsed into zclient_redistribute
1090 (zclient_redistribute_unset) ditto
1091 (zclient_redistribute) set/unset redistribution.
1092 (zclient_redistribute_default_set) Collapsed into
1093 zclient_redistribute_default.
1094 (zclient_redistribute_default_unset) ditto.
1095 (zclient_redistribute_default) Redistribute default set/unset.
1096 * zclient.h: delete zapi_ipv{4,6}_add, zapi_ipv{4,6}_delete. Add
1097 zapi_ipv{4,6}_route. delete zclient_redistribute_set/unset. Add
1098 zclient_redistribute. Ditto for
1099 zclient_redistribute_default_{set/unset}.
1100
paul4a7aac12004-05-08 05:00:31 +000011012004-05-08 Sowmini Varadhan <sowmini.varadhan@sun.com>
1102
1103 * if.h: Add mtu6 field to struct interface, IPv6 MTU may differ
1104 from IPv4, and Solaris treats the MTU's differently.
1105 Add connected_add_by_prefix, for use by later patch.
1106 * if.c: (connected_add_by_prefix) Add prefix to connected list.
1107 (if_flag_dump) Solaris: Dump IFF_IPv4/6 flag
1108 (if_dump) Dump mtu6 flag, for HAVE_IPV6.
paul22528292004-05-08 05:10:38 +00001109 * command.c: (sockunion_getsockname) use socklen_t for len.
1110 (sockunion_getpeername) ditto.
paul0a589352004-05-08 11:48:26 +00001111
paul31fcdd32004-04-21 11:00:43 +000011122004-04-21 Boris Kovalenko <boris@tagnet.ru>
1113
1114 * daemon.c: (daemon) fix check for error return from setsid
1115
paulc49b3062004-01-19 21:23:37 +000011162004-01-19 Paul Jakma <paul@dishone.st>
1117
1118 * sigevent.{c,h}: New files, implement event handled signals.
1119 see signal_init() in sigevent.h.
1120
jardinc32e1b52003-12-23 09:06:51 +000011212003-12-23 Vincent Jardin <jardin@6wind.com>
1122
1123 * {command.c, memory.c, vty.c, zebra.h}: Add isisd support
1124
gdt3dbf9962003-12-22 20:18:18 +000011252003-12-22 Greg Troxel <gdt@fnord.ir.bbn.com>
1126
1127 * vty.c (vty_use_backup_config): Don't free filenames before using
1128 them for unlink.
1129
paul54aba542003-08-21 20:28:24 +000011302003-08-20 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
1131
1132 * command.c: Fix <cr> display problem for command line
1133 description
1134
paule9af5c72003-05-24 11:54:31 +000011352003-05-24 Anil Madhavapeddy
1136
1137 * (sockunion.c): Incorrect bounds specified in sockunion_log()
1138
paul445f1432003-05-16 19:00:31 +000011392003-05-08 Sergiy Vyshnevetskiy <serg @ vostok.net>
1140
1141 * vty.c: -A option
1142
11432003-04-19 Hasso Tepper <hasso@estpak.ee>
1144
1145 * rip_routemap.c: sync daemon's route-map commands to have same
1146 syntax
1147
paul718e3742002-12-13 20:15:29 +000011482002-09-28 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
1149
1150 * vty.c (vty_flush): One line more on vty.
1151
11522002-09-27 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1153
1154 * vector.c (vector_lookup): Add new function.
1155
11562002-08-19 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1157
1158 * thread.c (timeval_adjust): Fix unconditional crush due to
1159 FreeBSD's select() system call timeval value check.
1160
11612002-07-07 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1162
1163 * zebra-0.93 released.
1164
11652002-06-21 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1166
1167 * if.c (ifc_pointopoint): Add ifc_pointopoint() accoding to Frank
1168 van Maarseveen's suggestion.
1169
11702002-06-18 Kunihiro Ishiguro <kunihiro@zebra.org>
1171
1172 * command.c: Change bcopy() to memcpy().
1173
11742001-12-12 Kunihiro Ishiguro <kunihiro@zebra.org>
1175
1176 * command.c (config_password): Fix host.password clear bug.
1177 Reported by Wang Jian <lark@linux.net.cn>.
1178
11792001-08-29 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1180
1181 * thread.c (thread_should_yield): New function to check thread
1182 should yeild it's execution to other thread. Suggested by: Rick
1183 Payne <rickp@ayrnetworks.com>
1184
11852001-08-20 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1186
1187 * thread.c (thread_timer_cmp): Rewrite function.
1188
1189 * hash.c: Add hash_get(). Change hash_pull() to hash_release().
1190
11912001-08-19 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1192
1193 * zebra-0.92a released.
1194
11952001-08-15 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1196
1197 * zebra-0.92 released.
1198
11992001-08-12 Akihiro Mizutani <mizutani@dml.com>
1200
1201 * prefix.c (netmask_str2prefix_str): Convert "1.1.0.0 255.255.0.0"
1202 string to "1.1.0.0/16".
1203
12042001-08-10 Kunihiro Ishiguro <kunihiro@zebra.org>
1205
1206 * filter.c (access_list_lookup): access_list_lookup's first
1207 argument is changed from address family to AFI.
1208
1209 * plist.c: (prefix_list_lookup): Likewise.
1210
12112001-07-27 Akihiro Mizutani <mizutani@dml.com>
1212
1213 * plist.c: ge and le display order is changed. Old compatible
1214 rule (len <= ge-value <= le-value) is removed.
1215
12162001-07-08 Kunihiro Ishiguro <kunihiro@zebra.org>
1217
1218 * prefix.h: Temporary fix for alignment of prefix problem.
1219
12202001-06-21 Kunihiro Ishiguro <kunihiro@zebra.org>
1221
1222 * prefix.h (struct prefix): Remove safi and padding field.
1223 (struct prefix_ipv4): Likewise.
1224 (struct prefix_ipv6): Likewise.
1225 (struct prefix_ls): Likewise.
1226 (struct prefix_rd): Likewise.
1227
1228 * command.h (enum node_type): Preparation for BGP new config.
1229
1230 * vty.c (vty_end_config): Likewise.
1231
12322001-06-17 Kunihiro Ishiguro <kunihiro@zebra.org>
1233
1234 * routemap.c (route_map_rule_delete): Call func_free when
1235 route-map rule is deleted.
1236
12372001-06-14 "Akihiro Mizutani" <mizutani@dml.com>
1238
1239 * routemap.c (route_map_index_lookup): Prevent to use deny and
1240 permit for same route-map sequence.
1241
12422001-04-12 Kunihiro Ishiguro <kunihiro@zebra.org>
1243
1244 * vty.c (vty_read_config): Fix warning.
1245
12462001-03-08 Kunihiro Ishiguro <kunihiro@zebra.org>
1247
1248 * command.c (IPV6_PREFIX_STR): Add '.' and '%' for IPv6 address
1249 strings.
1250
12512001-03-07 Kunihiro Ishiguro <kunihiro@zebra.org>
1252
1253 * zebra.h (_XPG4_2): Define _XPG4_2 and __EXTENSIONS__ for
1254 CMSG_FIRSTHDR.
1255
12562001-03-07 Michael Rozhavsky <mrozhavsky@opticalaccess.com>
1257
1258 * zebra.h (struct in_pktinfo): structure in_pktinfo declaration.
1259
12602001-02-19 Kunihiro Ishiguro <kunihiro@zebra.org>
1261
1262 * memory.c (memory_list_lib): Add MTYPE_NEXTHOP for "show memory
1263 lib" member.
1264
12652001-02-13 Matthew Grant <grantma@anathoth.gen.nz>
1266
1267 * vty.c (vty_read_config): Revert check of integrate_default when
1268 VTYSH is defined.
1269
12702001-02-13 Kunihiro Ishiguro <kunihiro@zebra.org>
1271
1272 * vty.c (vty_read_config): Do not check integrate_default. That
1273 should be used only by vtysh.
1274
12752001-02-08 Matthew Grant <grantma@anathoth.gen.nz>
1276
1277 * vty.c (vty_serv_un): Set umask 0077.
1278 (vty_read_config): Stat for vtysh Zebra.conf, if found startup and
1279 wait for boot configuration.
1280
1281 * if.c (if_lookup_address): Make it smart implementation.
1282
1283 * sockopt.c (setsockopt_multicast_ipv4): Set up a multicast socket
1284 options for IPv4 This is here so that people only have to do their
1285 OS multicast mess in one place rather than all through zebra,
1286 ospfd, and ripd .
1287
12882001-02-04 Akihiro Mizutani <mizutani@dml.com>
1289
1290 * plist.c (vty_prefix_list_install): Even when argument is
1291 invalid, new memory is allocated. Now memory allocation is done
1292 after argument check.
1293
12942001-02-01 Kunihiro Ishiguro <kunihiro@zebra.org>
1295
1296 * zebra-0.91 is released.
1297
12982001-01-31 Akihiro Mizutani <mizutani@dml.com>
1299
1300 * vty.c (vty_login): Add vty login command.
1301
13022001-01-31 Kunihiro Ishiguro <kunihiro@zebra.org>
1303
1304 * vty.c (vty_reset): Close accept socket.
1305
13062001-01-30 Kunihiro Ishiguro <kunihiro@zebra.org>
1307
1308 * memory.h (enum): MTYPE_ATTR_TRANSIT is added for unknown transit
1309 attribute.
1310
13112001-01-22 Kunihiro Ishiguro <kunihiro@zebra.org>
1312
1313 * zclient.c (zebra_interface_address_add_read): Fetch interface
1314 address flag.
1315 (zebra_interface_address_delete_read): Likewise.
1316
13172001-01-16 Kunihiro Ishiguro <kunihiro@zebra.org>
1318
1319 * table.c (route_node_match_ipv4): Utility function for IPv4
1320 address lookup.
1321 (route_node_match_ipv6): Utility function for IPv4 address lookup.
1322
13232001-01-15 Kunihiro Ishiguro <kunihiro@zebra.org>
1324
1325 * if.c: Delete RIP_API part until new implementation comes out.
1326
13272001-01-13 Kunihiro Ishiguro <kunihiro@zebra.org>
1328
1329 * hash.h (struct Hash): Rename alloc to count. Change type to
1330 unsigned long.
1331
1332 * stream.c (stream_getc_from): New function.
1333 (stream_getw_from): Likewise.
1334
1335 * zebra.h (ZEBRA_FLAG_STATIC): Add new flag for persistent route.
1336
13372001-01-11 Kunihiro Ishiguro <kunihiro@zebra.org>
1338
1339 * flap.c: File is removed.
1340
1341 * flap.c: Likewise.
1342
1343 * roken.h: Likewise.
1344
1345 * buffer.c (buffer_new): Remove type option to buffer_new().
1346
13472001-01-10 Kunihiro Ishiguro <kunihiro@zebra.org>
1348
1349 * zclient.c (zapi_ipv4_delete): Remove OLD_RIB part.
1350
13512001-01-09 Kunihiro Ishiguro <kunihiro@zebra.org>
1352
1353 * zebra-0.90 is released.
1354
1355 * command.c: Update Copyright year.
1356
13572001-01-09 Matthew Grant <grantma@anathoth.gen.nz>
1358
1359 * if.c (if_create): Register connected_free() function for
1360 deletion.
1361 (if_delete): Free connected information when the interface is
1362 deleted.
1363 (if_lookup_by_index): Fix argument type from int to unsigned int.
1364 (connected_add): Keep list in order if old info found, essential
1365 for repeatable operation in some daemons.
1366
13672001-01-09 endo@suri.co.jp (Masahiko Endo)
1368
1369 * vty.c (vty_flush): When vty->statis is VTY_CLOSE do not add vty
1370 read thread.
1371
13722001-01-08 Kunihiro Ishiguro <kunihiro@zebra.org>
1373
1374 * filter.c (access_list_delete): Access-list name is not freed.
1375
1376 * plist.c (prefix_list_delete): Prefix-list name is not freed.
1377
13782000-12-29 Kunihiro Ishiguro <kunihiro@zebra.org>
1379
1380 * zclient.c (zclient_start): Change to use UNIX domain
1381 socket for zebra communication.
1382
1383 * vector.c (vector_init): vector_alloc and vector_data_alloc is
1384 removed. All memory allocation count should be maintained by
1385 XMALLOC and XFREE macros.
1386
13872000-12-28 Kunihiro Ishiguro <kunihiro@zebra.org>
1388
1389 * zebra.h (ZEBRA_NEXTHOP_IFINDEX): Define ZEBRA_NEXTHOP_* values.
1390
13912000-12-27 Kunihiro Ishiguro <kunihiro@zebra.org>
1392
1393 * zebra.h (ZEBRA_ERR_RTEXIST): Make zebra error code to negative
1394 value.
1395
13962000-12-25 "Wataru Uno" <wataru@po.ntts.co.jp>
1397
1398 * vty.c (vtysh_read): Don't allocate new buffer because buffer is
1399 allocated in vty_new ().
1400
14012000-12-14 Kunihiro Ishiguro <kunihiro@zebra.org>
1402
1403 * memory.h (enum): Add MTYPE_AS_FILTER_STR.
1404
1405 * command.c (config_write_terminal): Display "end" at the end of
1406 configuration.
1407
1408 * plist.c (vty_prefix_list_install): Use AF_INET to determine
1409 lenum length.
1410
14112000-12-13 "Wataru Uno" <wataru@po.ntts.co.jp>
1412
1413 * buffer.c (buffer_flush_vty): If IOV_MAX defined in the System,
1414 then all lines write by IOV_MAX.
1415
14162000-12-12 Michael Rozhavsky <mrozhavsky@opticalaccess.com>
1417
1418 * command.c (config_write_file): Robust method for writing
1419 configuration file and recover from backing up config file.
1420
14212000-11-29 Kunihiro Ishiguro <kunihiro@zebra.org>
1422
1423 * smux.c (smux_connect): More fail check.
1424 (smux_trap): When SMUX connection is not established, do nothing.
1425
14262000-11-28 Gleb Natapov <gleb@nbase.co.il>
1427
1428 * thread.c (thread_fetch): Execut event list first. Old event
1429 list is renamed to ready list. With this change, event thread is
1430 executed before any other thread.
1431
1432 * thread.h (struct thread_master): Add ready list.
1433
14342000-11-28 Kunihiro Ishiguro <kunihiro@zebra.org>
1435
1436 * linklist.c (listnode_add_after): Add node right after the
1437 listnode pointer.
1438
14392000-11-27 Kunihiro Ishiguro <kunihiro@zebra.org>
1440
1441 * smux.h: Pass struct variable to WriteMethod.
1442
14432000-11-25 Frank van Maarseveen <F.vanMaarseveen@inter.NL.net>
1444
1445 * if.c (if_lookup_address): When looking up interface with IP
1446 address, Sometimes multiple interfaces will match. Now PtP
1447 interfaces prevail in such a case which seem the right thing to
1448 do: There will probably also be host routes which usually prevail
1449 over network routes.
1450
14512000-11-25 Kunihiro Ishiguro <kunihiro@zebra.org>
1452
1453 * smux.c (smux_trap): SMUX trap implementation.
1454
14552000-11-19 Akihiro Mizutani <mizutani@dml.com>
1456
1457 * plist.c: Add automatic conversion function of an old rule.
1458 ex.) 10.0.0.0/8 ge 8 -> 10.0.0.0/8 le 32
1459
14602000-11-16 Yon Uriarte <ukl2@rz.uni-karlsruhe.de>
1461
1462 * zclient.c (zebra_interface_add_read): Read hardware address when
1463 hw_addr_len is greater than 0.
1464
14652000-11-15 Akihiro Mizutani <mizutani@dml.com>
1466
1467 * plist.c: The rule of "len <= ge-value <= le-value"
1468 was changed to "len < ge-value <= le-value".
1469
14702000-11-09 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
1471
1472 * memory.[ch]: Added #define and functions for ospf6d.
1473
1474 * log.[ch]: some platform says that the data of used va_list
1475 is undefined. Changed to hold list of va_list for each
1476 vsnprintf.
1477
14782000-11-07 Rick Payne <rickp@rossfell.co.uk>
1479
1480 * memory.h (enum): Add MTYPE_COMMUNITY_REGEXP.
1481
14822000-11-06 Kunihiro Ishiguro <kunihiro@zebra.org>
1483
1484 * command.c (config_exit): Fix bug of missing break after case
1485 BGP_VPNV4_NODE.
1486
14872000-10-30 Kunihiro Ishiguro <kunihiro@zebra.org>
1488
1489 * vector.c (vector_unset): Check i is not nevative.
1490
14912000-10-24 Arkadiusz Miskiewicz <misiek@pld.org.pl>
1492
1493 * smux.c (smux_sock): Set terminating '\0'. Check address family.
1494
1495 * vty.c (vty_serv_sock_addrinfo): Set terminating '\0'. Use
1496 gai_strerror. Check address family.
1497
14982000-10-23 Jochen Friedrich <jochen@scram.de>
1499
1500 * smux.c: Use linklist rather than vector.
1501 (smux_getnext): A SMUX subagent has to behave as if it manages the
1502 whole SNMP MIB tree itself. It's the duty of the master agent to
1503 collect the best answer and return it to the manager. See RFC 1227
1504 chapter 3.1.6 for the glory details :-). ucd-snmp really behaves
1505 bad here as it actually might ask multiple times for the same
1506 GETNEXT request as it throws away the answer when it expects it in
1507 a different subtree and might come back later with the very same
1508 request.
1509
15102000-10-23 Kunihiro Ishiguro <kunihiro@zebra.org>
1511
1512 * command.c (cmd_init): Log related command are only installed for
1513 terminal mode.
1514
15152000-10-21 Kunihiro Ishiguro <kunihiro@zebra.org>
1516
1517 * Makefile.am (libzebra_a_SOURCES): Remove duplicated buffer.c.
1518
1519 * zebra.h: Remove #warn directive.
1520
15212000-10-20 Kunihiro Ishiguro <kunihiro@zebra.org>
1522
1523 * keychain.c (keychain_init): Register "key chain" command to
1524 KEYCHAIN_NODE and KEYCHAIN_KEY_NODE.
1525
1526 * vty.c (vty_end_config): Fix missing vty_cinfig_unlock for other
1527 CONFIG_NODE.
1528
1529 * command.c (config_end): Likewise.
1530
1531 * keychain.c (keychain_get): Key is sorted by it's identifier
1532 value.
1533
15342000-10-19 Kunihiro Ishiguro <kunihiro@zebra.org>
1535
1536 * linklist.c (list_delete_all_node): Call delete function if it is
1537 defined.
1538
1539 * command.c (cmd_execute_command_strict): Add modification for
1540 vtysh.
1541 (cmd_execute_command_strict): Remove first argument cmdvec because
1542 it is global varibale in command.c.
1543
15442000-10-18 Kunihiro Ishiguro <kunihiro@zebra.org>
1545
1546 * command.c (cmd_init): Install
1547 copy_runningconfig_startupconfig_cmd only in terminal mode.
1548
1549 * linklist.c (list_delete_node): Simplify the function.
1550 (listnode_lookup): Renamed from list_lookup_node.
1551
15522000-10-17 Kunihiro Ishiguro <kunihiro@zebra.org>
1553
1554 * stream.h: Undef stream_read and stream_write without
1555 parenthesis.
1556
1557 * newlist.c: File removed.
1558
1559 * newlist.h: Likewise.
1560
1561 * linklist.c (list_new): Remove list_init(). To allocate new
1562 linked list, please use list_new().
1563 (listnode_add): Remove list_add_node(). To add new node to linked
1564 list, please use listnode_add().
1565 (list_delete_by_val): Revemove fucntion.
1566
15672000-10-16 Nobuaki Tanaka <nobby@po.ntts.co.jp>
1568
1569 * table.c (route_table_free): Reimplement route_table_free().
1570
15712000-10-11 Kunihiro Ishiguro <kunihiro@zebra.org>
1572
1573 * keychain.c (keychain_get): Register key_delete_func to key
1574 list's delete function. Use linklist.c instead of newlist.c.
1575
15762000-10-04 Akihiro Mizutani <mizutani@dml.com>
1577
1578 * filter.c (access_list_remark): Add access-list's remark command.
1579 (no_access_list): "no access-list 100 permit any" error message
1580 bug is fixed.
1581
15822000-10-03 Kunihiro Ishiguro <kunihiro@zebra.org>
1583
1584 * memory.h (enum): Add MTYPE_SOCKUNION.
1585
15862000-10-02 Kunihiro Ishiguro <kunihiro@zebra.org>
1587
1588 * zebra-0.89 is released.
1589
15902000-10-01 Kunihiro Ishiguro <kunihiro@zebra.org>
1591
1592 * linklist.c (list_add_node_head): Delete unused function.
1593 (list_add_node_tail): Likewise.
1594
15952000-09-26 Kunihiro Ishiguro <kunihiro@zebra.org>
1596
1597 * stream.c (stream_read_unblock): Add new function for unblocking
1598 read.
1599
16002000-09-26 Jochen Friedrich <jochen@nwe.de>
1601
1602 * smux.c (smux_register): Fix bug of can't register more than one
1603 MIB with SMUX.
1604
16052000-09-26 Makoto Otsuka <otsuka@inl.ntts.co.jp>
1606
1607 * vty.c (vty_close): Fix memory leak of sb_buffer.
1608 (vty_new): Likewise.
1609
16102000-09-21 steve@Watt.COM (Steve Watt)
1611
1612 * log.h: Do not declare zlog_priority[0] variable.
1613
16142000-09-12 Kunihiro Ishiguro <kunihiro@zebra.org>
1615
1616 * linklist.h (struct _list ): Add member cmp for compare function.
1617 (struct _list ): Member up is deleted
1618
16192000-09-12 David Lipovkov <dlipovkov@OpticalAccess.com>
1620
1621 * if.c: Include RIP_API header when RIP API is enabled.
1622
16232000-09-10 Kunihiro Ishiguro <kunihiro@zebra.org>
1624
1625 * prefix.c (prefix_free): Siplify prefix_free().
1626
1627 * keychain.c (key_match_for_accept): strncmp check bug is fixed.
1628
16292000-09-07 Kunihiro Ishiguro <kunihiro@zebra.org>
1630
1631 * zebra.h: Merge roken.h into zebra.h.
1632
16332000-09-05 Akihiro Mizutani <mizutani@dml.com>
1634
1635 * routemap.c (route_map_init_vty): Install route-map command to
1636 RMAP_NODE.
1637
16382000-08-22 Kunihiro Ishiguro <kunihiro@zebra.org>
1639
1640 * thread.c (thread_get_id): Remove pthread related garbage.
1641
1642 * command.h (struct host): Likewise.
1643
1644 * zebra.h: Likewise.
1645
16462000-08-20 Kunihiro Ishiguro <kunihiro@zebra.org>
1647
1648 * command.h (node_type ): Add AAA node for authentication.
1649
1650 * vty.c (vty_close): Do not close stdout.
1651
16522000-08-18 Kunihiro Ishiguro <kunihiro@zebra.org>
1653
1654 * vty.c (vty_init_vtysh): Added for vtysh.
1655
1656 * distribute.c (districute_list_prefix_all): Interface independent
1657 filter can be set.
1658 (distribute_list_all): Likewise.
1659 (config_show_distribute): Display current distribute-list status
1660 for "show ip protocols".
1661
16622000-08-18 Akihiro Mizutani <mizutani@dml.com>
1663
1664 * command.c (config_terminal_no_length): no terminal monitor ->
1665 terminal no monitor
1666 (cmd_init): Do not install service_terminal_length_cmd into
1667 ENABLE_NODE.
1668
1669 * vty.c (terminal_no_monitor): no terminal length -> terminal no
1670 length.
1671
16722000-08-17 Kunihiro Ishiguro <kunihiro@zebra.org>
1673
1674 * zebra-0.88 is released.
1675
16762000-08-17 Magnus Ahltorp <ahltorp@nada.kth.se>
1677
1678 * vty.h (struct vty ): Add iac_sb_in_progress and sb_buffer for
1679 better IAC handling.
1680
1681 * vty.c (vty_telnet_option): Change telnet option handling.
1682
16832000-08-15 Gleb Natapov <gleb@nbase.co.il>
1684
1685 * zclient.c (zclient_redistribute_unset): New function added.
1686
16872000-08-14 Kunihiro Ishiguro <kunihiro@zebra.org>
1688
1689 * zclient.c (zebra_interface_add_read): Change ifindex restore
1690 size from two octet to four.
1691 (zebra_interface_state_read): Likewise.
1692 (zebra_interface_address_add_read): Likewise.
1693
16942000-08-13 Kunihiro Ishiguro <kunihiro@zebra.org>
1695
1696 * vty.c (vty_event): Use vector_set_index() instead of
1697 vector_set().
1698
16992000-08-07 Kunihiro Ishiguro <kunihiro@zebra.org>
1700
1701 * zebra.h (ZEBRA_XXX_DISTANCE_DEFAULT): Define Default
1702 Administrative Distance of each protocol.
1703
17042000-08-07 Matthew Grant <grantma@anathoth.gen.nz>
1705
1706 * if.h (struct interface ): Add new member bandwidth to struct
1707 interface.
1708
1709 * zclient.c (zebra_interface_add_read): Fetch bandwidth value.
1710 (zebra_interface_state_read): Likewise.
1711
17122000-08-07 Gleb Natapov <gleb@nbase.co.il>
1713
1714 * routemap.c (route_map_event_hook): New hook route_map_event_hook
1715 is added. This hook is called when route-map is changed. The
1716 parameters passed to the hook are 'event' and 'route-map name'
1717
1718 * routemap.h: Add prototype for route_map_event_hook().
1719
17202000-08-06 Kunihiro Ishiguro <kunihiro@zebra.org>
1721
1722 * zclient.c (zebra_ipv4_route): zebra_ipv4_route(),
1723 zebra_ipv4_add(), zebra_ipv4_delete() are removed.
1724
1725 * routemap.c (route_map_empty): Add new function.
1726 (route_map_delete): Use route_map_index_delete() instead of
1727 route_map_index_free().
1728 (route_map_index_free): Function removed.
1729
17302000-08-06 Gleb Natapov <gleb@nbase.co.il>
1731
1732 * routemap.c (route_map_index_delete): Add check for route-map is
1733 empty or not.
1734
17352000-08-03 Kunihiro Ishiguro <kunihiro@zebra.org>
1736
1737 * zclient.c (zebra_ipv4_add): Change socket arguemnt with struct
1738 zclient.
1739
17402000-08-02 Kunihiro Ishiguro <kunihiro@zebra.org>
1741
1742 * zclient.h (struct zebra): Add obuf for output buffer.
1743
1744 * if.c: Remove #ifdef NRL enclosing if_nametoindex() and
1745 if_indextoname().
1746
17472000-08-02 David Lipovkov <davidl@nbase.co.il>
1748
1749 * if.h (IF_PSEUDO_UNSET): IF_PSEUDO related macro added.
1750 (IF_UNKNOWN_SET): IF_UNKNOWN related macro deleted.
1751
1752 * if.c (interface_pseudo): Add "pseudo" command to interface node.
1753 (no_interface_pseudo): Add "no pseudo" command to interface node.
1754
1755 * zclient.c (zebra_interface_add_read): Set pseudo flag when it is
1756 send from zebra.
1757
17582000-08-01 Kunihiro Ishiguro <kunihiro@zebra.org>
1759
1760 * zebra.h (ZEBRA_IPV4_NEXTHOP_LOOKUP): Add new message.
1761 (ZEBRA_IPV6_NEXTHOP_LOOKUP): Likewise.
1762
1763 * vty.c (vty_serv_un): Use AF_UNIX for backward compatibility.
1764
17652000-07-31 Kunihiro Ishiguro <kunihiro@zebra.org>
1766
1767 * vty.c: Use vector for VTY server thread listing instead of
1768 single value.
1769
17702000-07-30 Kunihiro Ishiguro <kunihiro@zebra.org>
1771
1772 * keychain.c (no_key_chain): "no key chain WORD" command is added.
1773
17742000-07-29 Kunihiro Ishiguro <kunihiro@zebra.org>
1775
1776 * command.c (config_from_file): If command fail in
1777 KEYCHAIN_KEY_NODE, down to KEYCHAIN_NODE.
1778
1779 * vty.h (struct vty ): Add index_sub member.
1780
17812000-07-27 Akihiro Mizutani <mizutani@dml.com>
1782
1783 * if.c: Help strings updates.
1784
17852000-07-11 Akihiro Mizutani <mizutani@dml.com>
1786
1787 * command.c (no_config_enable_password): Add "no enable password"
1788 command.
1789 (config_write_host): Display password string.
1790
1791 * routemap.c (route_map_delete_match): Add support for delete
1792 match without argument.
1793 (route_map_delete_set): Likewise.
1794
17952000-07-09 Kunihiro Ishiguro <kunihiro@zebra.org>
1796
1797 * command.h (node_type ): Change KEYCHAIN_NODE and
1798 KEYCHAIN_KEY_NODE place just before INTERFACE_NODE.
1799
18002000-07-09 Jochen Friedrich <jochen@scram.de>
1801
1802 * smux.c (config_write_smux): Fixes the option to override OID and
1803 password for SMUX.
1804
18052000-07-09 Kunihiro Ishiguro <kunihiro@zebra.org>
1806
1807 * command.h (node_type ): Add SMUX_NODE for SMUX configuration.
1808
18092000-07-09 Toshiaki Takada <takada@zebra.org>
1810
1811 * command.c: Sort descvec command's help.
1812
1813 * vty.c (vty_describe_command): Display '<cr>' at the end of
1814 descriptions.
1815
18162000-07-05 Toshiaki Takada <takada@zebra.org>
1817
1818 * command.c (cmd_ipv6_match), (cmd_ipv6_prefix_match): Fix bug
1819 treatment of double colon.
1820
18212000-07-04 Kunihiro Ishiguro <kunihiro@zebra.org>
1822
1823 * zclient.h: Add zclient_redistribute_default_{set,unset}().
1824
1825 * keychain.c: New file for authentication key management.
1826 * keychain.h: Likewise.
1827
1828 * tcpfilter.c: New file for TCP/UDP base filtering using ipfw or
1829 ipchains.
1830 * tcpfilter.h: Likewise.
1831
1832 * flap.h: New file for route flap dampening.
1833 * flap.c: Likewise.
1834
18352000-07-04 Toshiaki Takada <takada@zebra.org>
1836
1837 * filter.c (struct filter): Add exact flag.
1838 (access_list): Add exact-match command.
1839 (ipv6_access_list): Add exact-match command.
1840
18412000-07-03 Kunihiro Ishiguro <kunihiro@zebra.org>
1842
1843 * zebra.h (ZEBRA_REDISTRIBUTE_DEFAULT_ADD): New message for
1844 request default route.
1845
18462000-07-01 Hideaki YOSHIFUJI ($B5HF#1QL@(B) <yoshfuji@ecei.tohoku.ac.jp>
1847
1848 * smux.c: Add IPv6 smux connection code.
1849
18502000-06-15 Kunihiro Ishiguro <kunihiro@zebra.org>
1851
1852 * vty.c (vty_complete_command): To cooperate readline library,
1853 returned string is newly allocated. So some match function case
1854 need, free of memory.
1855
18562000-06-12 Akihiro Mizutani <mizutani@dml.com>
1857
1858 * distribute.c: Fix help strings.
1859
18602000-06-11 Kunihiro Ishiguro <kunihiro@zebra.org>
1861
1862 * command.c (cmd_complete_command): Add check for vector_slot
1863 (vline, index) is not NULL when calculating lcd.
1864 (cmd_entry_function): First check variable arguemnt to prevent it
1865 from completion.
1866
18672000-06-10 Kunihiro Ishiguro <kunihiro@zebra.org>
1868
1869 * vty.h (struct vty ): Add output_count member for displaying
1870 output route count. Remove arugment arg from output_func because
1871 the value is passed by vty argument. Change output to output_rn.
1872 Add output_clean function pointer member. Add output_type member.
1873
18742000-06-10 Toshiaki Takada <takada@zebra.org>
1875
1876 * command.c (show_startup_config): Add "show startup-config"
1877 command.
1878
18792000-06-06 Akihiro Mizutani <mizutani@dml.com>
1880
1881 * filter.c: Fix help strings.
1882
18832000-06-05 Kunihiro Ishiguro <kunihiro@zebra.org>
1884
1885 * prefix.h (struct prefix_rd): New prefix structure for routing
1886 distinguisher.
1887 (struct prefix): Add padding to every prefix structure.
1888
1889
1890 * routemap.c (route_map_add_match): When completely same match
1891 statement exists, don't duplicate it.
1892
18932000-06-05 Akihiro Mizutani <mizutani@dml.com>
1894
1895 * routemap.c: Change NAME to WORD.
1896
1897 * plist.c: Fix help strings.
1898
18992000-06-02 Akihiro Mizutani <mizutani@dml.com>
1900
1901 * routemap.c: Fix route-map help strings.
1902
19032000-06-01 Kunihiro Ishiguro <kunihiro@zebra.org>
1904
1905 * command.c (cmd_filter_by_completion): Fix CMD_VARARG treatment
1906 to filter other non vararg commands.
1907
1908 * routemap.c (route_map_init_vty): Use install_default() for
1909 install common commands into route-map node..
1910
19112000-06-01 Akihiro Mizutani <mizutani@dml.com>
1912
1913 * command.h (OSPF_STR): Macro added.
1914
19152000-05-31 Kunihiro Ishiguro <kunihiro@zebra.org>
1916
1917 * command.c (cmd_complete_command): LCD completion must not modify
1918 installed command string.
1919
1920 * plist.c (ipv6_prefix_list): Fix wrong syntax definition. Change
1921 X:X::X:X to X:X::X:X/M.
1922
19232000-05-31 Toshiaki Takada <takada@zebra.org>
1924
1925 * vty.c (show_history): New defun added.
1926
19272000-05-30 Kunihiro Ishiguro <kunihiro@zebra.org>
1928
1929 * command.h (CMD_COMPLETE_LIST_MATCH): New define for completion
1930 list. CMD_COMPLETE_MATCH is used for LCD completion.
1931
1932 * vty.c (vty_complete_command): Matched string's LCD is completed.
1933
1934 * command.c (cmd_lcd): New function for calculate LCD of matched
1935 strings.
1936
19372000-05-26 Kunihiro Ishiguro <kunihiro@zebra.org>
1938
1939 * command.c (install_default): config_write_terminal_cmd,
1940 config_write_file_cmd, config_write_memory_cmd are added to
1941 default node.
1942
1943 * memory.c (memory_init): Divide show memory command into each
1944 sort.
1945
1946 * command.c (cmd_init): config_write_terminal_cmd,
1947 config_write_file_cmd, config_write_memory_cmd are added to
1948 CONFIG_NODE.
1949
1950 * routemap.c (route_map_index_free): New function.
1951 (no_route_map_all): New DEFUN for "no route-map NAME".
1952
1953 * filter.c (no_access_list_all): New DEFUN for delete access-list
1954 with NAME.
1955 (no_ipv6_access_list_all): Likewise.
1956
19572000-05-23 Kunihiro Ishiguro <kunihiro@zebra.org>
1958
1959 * plist.c: Change IPV6_PREFIX to X:X::X:X. When "any" is
1960 specified, user can not use "ge" and "le" statement.
1961
19622000-05-22 Thomas Molkenbur <tmo@datus.datus.com>
1963
1964 * routemap.c (route_map_add_set): Fix bug of next pointer missing.
1965
1966 * table.c (route_table_free): Like wise.
1967
19682000-05-22 Toshiaki Takada <takada@zebra.org>
1969
1970 * vty.c (vty_stop_input): Set history pointer to the latest one.
1971
1972 * vty.c (vty_hist_add): Do not add command line history when input
1973 is as same as previous one.
1974
19752000-05-14 Kunihiro Ishiguro <kunihiro@zebra.org>
1976
1977 * memory.h (enum): Add MTYPE_ECOMMUNITY and MTYPE_ECOMMUNITY_VAL.
1978
19792000-05-13 Kunihiro Ishiguro <kunihiro@zebra.org>
1980
1981 * command.h (node_type ): Add BGP_VPNV4_NODE.
1982
19832000-05-08 Kunihiro Ishiguro <kunihiro@zebra.org>
1984
1985 * vty.c (vtysh_accept): Add cast of struct sockaddr * to bind
1986 argument. Reported by: Vesselin Mladenov <mladenov@netbg.com>.
1987
1988 * filter.c (ipv6_access_list): Add IPv6 prefix example instead of
1989 IPv4 example. Reported by: Love <lha@s3.kth.se>.
1990
1991 * command.c (cmd_complete_command): Make it sure last element of
1992 matchvec is NULL. This fix problem which cause crush in
1993 vty_complete_command(). Reported by: JINMEI Tatuya
1994 <jinmei@isl.rdc.toshiba.co.jp>.
1995
19962000-04-28 Love <lha@s3.kth.se>
1997
1998 * prefix.h (struct prefix): Add padding.
1999
20002000-04-28 Kunihiro Ishiguro <kunihiro@zebra.org>
2001
2002 * command.c (show_version): Update copyright year.
2003
20042000-04-27 Kunihiro Ishiguro <kunihiro@zebra.org>
2005
2006 * routemap.c (route_map_apply): When map is NULL, return deny.
2007
20082000-04-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2009
2010 * filter.c (access_list_apply): When access is NULL, return deny.
2011
2012 * plist.c (prefix_list_apply): When plist is NULL, return deny.
2013
20142000-04-23 Kunihiro Ishiguro <kunihiro@zebra.org>
2015
2016 * command.h (node_type ): Change RDISC_NODE to IRDP_NODE.
2017
20182000-04-18 Toshiaki Takada <takada@zebra.org>
2019
2020 * filter.[ch] (access_list_add_hook), (access_list_delete_hook):
2021 Add argument for hook function to give struct access_list *.
2022
20232000-04-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2024
2025 * plist.c (prefix_list_entry_match): In case of le nor ge is
2026 specified, exact match is performed.
2027 (prefix_list_entry_match): Add any entry matching check.
2028
20292000-04-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2030
2031 * vty.c (exec_timeout): Separate timeout setting to minutes and
2032 seconds.
2033 (no_exec_timeout): Add "no exec-timeout" command.
2034
2035 * vty.h (VTY_TIMEOUT_DEFAULT): Change default value from 300 to
2036 600.
2037
20382000-03-31 Jochen Friedrich <jochen@scram.de>
2039
2040 * smux.h (SMUX_CLOSE): The SMUX_CLOSE PDU is implicit integer, so
2041 it is a primitive encoding and not constructed.
2042
20432000-03-28 Toshiaki Takada <takada@zebra.org>
2044
2045 * memory.[ch] (enum): Add MTYPE_OSPF_EXTERNAL_INFO.
2046
20472000-03-26 Love <lha@s3.kth.se>
2048
2049 * zclient.c (zclient_read): Add nbytes size check for
2050 ZEBRA_HEADER_SIZE. Check return value of steam_read ().
2051
20522000-03-26 Rick Payne <rickp@rossfell.co.uk>
2053
2054 * routemap.c: Add flexible route-map commands such as on-match
2055 next, on-match goto N.
2056
2057 * routemap.h: Likewise
2058
20592000-03-23 Adrian Bool <aid@u.net.uk>
2060
2061 * command.c (config_log_trap): Add new command "log trap
2062 PRIORITY".
2063
20642000-03-14 Toshiaki Takada <takada@zebra.org>
2065
2066 * memory.c (struct memory_list): Add Link List and Link Node
2067 to view.
2068
2069 * memory.h (enum): Remove MTYPE_OSPF_EXTERNAL_ROUTE.
2070
20712000-01-20 Hideto Yamakawa <hideto.yamakawa@soliton.co.jp>
2072
2073 * str.c (snprintf): Fix bug of calling sprintf instead of
2074 vsprintf.
2075
20762000-01-16 Kunihiro Ishiguro <kunihiro@zebra.org>
2077
2078 * memory.h (enum): Add MTYPE_RIP_PEER.
2079
20802000-01-15 Toshiaki Takada <takada@zebra.org>
2081
2082 * memory.h (enum): Add MTYPE_OSPF_CRYPT_KEY.
2083
20842000-01-15 Kunihiro Ishiguro <kunihiro@zebra.org>
2085
2086 * command.h (node_type ): Add MASC_NODE for masc.
2087
20882000-01-09 Wang Jianliang <wangjl@soim.net>
2089
2090 * routemap.c (route_map_index_add): When route_map_index is not
2091 empty and insert new item at the head, it can cause core dump.
2092 Fix "if (index == map->head)" to "if (point == map->head).
2093 (route_map_add_set): If there is an old set command, override old
2094 set command with new one.
2095 (route_map_index_delete): Use while() instead of for for() for
2096 logical correctness.
2097
20981999-12-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2099
2100 * memory.h (enum): Add MTYPE_BGP_STATIC.
2101
21021999-12-23 Alex Zinin <zinin@amt.ru>
2103 * zebra.h, zclient.*: dynamic int up/down message
2104 support
2105
21061999-12-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2107
2108 * thread.c (thread_cancel_event): Add a function for clean up
2109 events.
2110
21111999-12-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2112
2113 * dropline.c: Delete file.
2114 dropline.h: Linewise.
2115
21161999-12-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2117
2118 * filter.c (access_list_filter_delete): Wrong pointer
2119 access->master was pointed out after access is freed. I store
2120 master value at the beginning of the function.
2121
21221999-12-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2123
2124 * vty.c (exec_timeout): Change of VTY timeout affect to current
2125 VTY connection.
2126 (vty_accept): Instead of immediate exit() return -1.
2127
21281999-12-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2129
2130 * vty.c (vty_configure_lock): Configuration lock function added.
2131 Only one VTY can use CONFI_NODE at the same time.
2132
2133 * log.c: Delete zvlog_* functions. Now zlog_* does the same
2134 thing.
2135
2136 * log.c (log_init): Function removed.
2137 (log_close): Likewise.
2138 (log_flush): Likewise.
2139 (log_open): Likewise.
2140
2141 * vty.c (terminal_monitor): Add new command.
2142 (no_terminal_monitor): Likewise.
2143
2144 * log.c (old_log): Function removed.
2145 (old_log2): Likewise.
2146 (old_log_warn): Likewise.
2147
21481999-12-04 Toshiaki Takada <takada@zebra.org>
2149
2150 * command.c (cmd_ipv6_match): New function added.
2151 (cmd_ipv6_prefix_match): Likewise.
2152
21531999-12-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2154
2155 * command.c (cmd_ipv6_match):
2156
2157 * table.c: Delete #ifdef HAVE_MBGPV4.
2158
2159 * prefix.h (struct prefix): Add safi member.
2160 (struct prefix_ipv4): Likewise.
2161 (struct prefix_ipv6): Likewise.
2162
21631999-12-04 Rumen Svobodnikov <rumen@linux.tu-varna.acad.bg>
2164
2165 * memory.c (struct mstat): Revert to support MEMORY_LOG.
2166
21671999-11-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2168
2169 * version.h: Bump up to 0.81c for testing new kernel codes.
2170
21711999-11-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2172
2173 * thread.h (struct thread): Pthread support is disabled all
2174 platform.
2175
21761999-11-21 Michael Handler <handler@sub-rosa.com>
2177
2178 * Include <limits.h> and <strings.h> under SUNOS_5.
2179
21801999-11-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2181
2182 * sockunion.c (in6addr_cmp): Enclosed by #define HAVE_IPV6
21831999-11-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2184
2185 * command.h (node_type ): Add BGP_IPV4_NODE and BGP_IPV6_NODE.
2186
21871999-11-12 Kunihiro Ishiguro <kunihiro@zebra.org>
2188
2189 * command.c (disable): Add `disable' command.
2190
21911999-11-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2192
2193 * plist.c (vty_prefix_list_install): Add any check.
2194
21951999-11-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2196
2197 * command.h (node_type ): Add DUMP_NODE.
2198
21991999-11-03 Kunihiro Ishiguro <kunihiro@zebra.org>
2200
2201 * smux.c: Change default SMUX oid to compatible with gated.
2202
22031999-10-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2204
2205 * if_rmap.c: New file added.
2206
2207 * if_rmap.h: New file added.
2208
22091999-10-29 Alex Zinin <zinin@amt.ru>
2210
2211 * hash.c: add hash_free() function
2212
22131999-10-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2214
2215 * hash.c (hash_clean): Add clean function.
2216
2217 * plist.c (prefix_list_reset): Add reset function.
2218
2219 * filter.c (access_list_reset): Add reset function.
2220
22211999-10-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2222
2223 * client.c: Merged with zclient.c.
2224 * client.h: Merged with zclient.h.
2225
22261999-10-15 Jordan Mendelson <jordy@wserv.com>
2227
2228 * md5.c: Imported from GNU C Library.
2229 * md5-gnu.h: Likewise.
2230
22311999-10-15 Jochen Friedrich <jochen@scram.de>
2232
2233 * smux.c (smux_getresp_send): SMUX_GETRSP codes improvement.
2234
22351999-10-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2236
2237 * smux.h: New file added.
2238
2239 * snmp.c: Rename to smux.c.
2240
22411999-10-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2242
2243 * command.c (cmd_execute_command_strict): Filter ambious commands.
2244 (cmd_filter_by_string): Change to return enum match_type.
2245
22461999-10-01 Toshiaki Takada <takada@zebra.org>
2247
2248 * vty.c (vty_describe_fold): New function which does VTY
2249 description line fold.
2250 * vty.c (vty_describe_command): Set description column.
2251
22521999-09-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2253
2254 * plist.c (prefix_list_init_ipv4): VTY user interface is improved.
2255
22561999-09-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2257
2258 * command.c (cmd_filter_by_string): Fix bug of CMD_IPV4 and
2259 CMD_IPV4_PREFIX check. Both return type must be exact_match.
2260
22611999-09-24 Toshiaki Takada <takada@zebra.org>
2262
2263 * command.c (cmd_filter_by_completion),
2264 (is_cmd_ambiguous): Check IPv4 address, IPv4 prefix and range
2265 parameter matches range.
2266
22671999-09-22 Kunihiro Ishiguro <kunihiro@zebra.org>
2268
2269 * routemap.c (route_map_apply): Returm RM_DENYMATCH when no match
2270 is performed.
2271
22721999-09-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2273
2274 * vty.c (vty_read): Control-C stop VTY_MORE mode.
2275
22761999-09-20 Kunihiro Ishiguro <kunihiro@zebra.org>
2277
2278 * command.h (node_type ): Add ACCESS_IPV6_NODE and
2279 PREFIX_IPV6_NODE.
2280
2281 * distribute.h: New file added.
2282
2283 * command.h (node_type ): Delete DISTRIBUTE_NODE.
2284
22851999-09-18 Kunihiro Ishiguro <kunihiro@zebra.org>
2286
2287 * vty.c (vty_terminate_all): New function added for reload
2288 support.
2289
22901999-09-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2291
2292 * memory.h (enum): Add new type MTYPE_OSPF_EXTERNAL_ROUTE.
2293
22941999-08-31 Janos Farkas <chexum@shadow.banki.hu>
2295
2296 * vty.c (vty_read): Handle also 0x7f (alt-backspace), just like
2297 esc-ctrl-h (delete word backwards).
2298
22991999-08-24 Kunihiro Ishiguro <kunihiro@zebra.org>
2300
2301 * if.h: Add if_nametoindex for NRL.
2302
23031999-08-23 Kunihiro Ishiguro <kunihiro@zebra.org>
2304
2305 * if.c (if_create): New function.
2306
23071999-08-22 Kunihiro Ishiguro <kunihiro@zebra.org>
2308
2309 * snmp.c: New file.
2310
23111999-08-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2312
2313 * stream.c (stream_put): stream_memcpy () is changed to stream_put
2314 (). stream_get () is added.
2315
23161999-08-18 Toshiaki Takada <takada@zebra.org>
2317
2318 * memory.h (enum): Add MTYPE_OSPF_LSA_DATA.
2319
23201999-08-18 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2321
2322 * table.c (route_table_finish): add function frees table.
2323
23241999-08-12 Kunihiro Ishiguro <kunihiro@zebra.org>
2325
2326 * memory.h (enum): Add MTYPE_RTADV_PREFIX.
2327
23281999-08-11 Kunihiro Ishiguro <kunihiro@zebra.org>
2329
2330 * if.h (struct interface ): hw_address, hw_address_len added.
2331
23321999-08-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2333
2334 * if.h (struct interface ): Change structure member if_data to
2335 info, index to ifindex.
2336
23371999-08-08 Rick Payne <rickp@rossfell.co.uk>
2338
2339 * routemap.c: Multi protocol route-map modification.
2340
2341 * routemap.c (route_map_apply): Route match process bug is fixed.
2342
23431999-08-05 Kunihiro Ishiguro <kunihiro@zebra.org>
2344
2345 * thread.c (thread_fetch): When signal comes, goto retry point.
2346
23471999-08-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2348
2349 * Makefile.am: Add sockopt.c and sockopt.h
2350 * sockopt.c: New file.
2351 * sockopt.h: New file.
2352
23531999-08-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2354
2355 * version.h (ZEBRA_VERSION): Release zebra-0.75
2356
23571999-08-01 Kunihiro Ishiguro <kunihiro@zebra.org>
2358
2359 * memory.h (enum): Add MTYPE_RIPNG_AGGREGATE.
2360
23611999-07-31 Kunihiro Ishiguro <kunihiro@zebra.org>
2362
2363 * sockunion.h: Add sockunion_getpeername ().
2364
23651999-07-27 Kunihiro Ishiguro <kunihiro@zebra.org>
2366
2367 * version.h: Release zebra-0.74
2368
23691999-07-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2370
2371 * command.h (struct host): Delete lines from struct host. Add
2372 lines to struct vty.
2373
2374 * command.c: Delete `lines LINES'. Terminal display line settings
2375 should be done by `terminal length' command.
2376
23771999-07-24 Kunihiro Ishiguro <kunihiro@zebra.org>
2378
2379 * memory.h (enum): MTYPE_OSPF_PATH are added.
2380
23811999-07-22 Toshiaki Takada <takada@zebra.org>
2382
2383 * memory.h (enum): MTYPE_OSPF_NEXTHOP is added.
2384
23851999-07-21 Toshiaki Takada <takada@zebra.org>
2386
2387 * linklist.c (list_add_node_prev), (list_add_node_next),
2388 (list_add_list): New function added.
2389
2390 * table.c (route_table_free): New function added.
2391
23921999-07-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2393
2394 * plist.c (config_write_prefix): Set write flag when configuration
2395 is written.
2396
23971999-07-15 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2398
2399 * prefix.c : prefix_cmp() added. change apply_mask() to
2400 apply_mask_ipv4(), and new apply_mask() added.
2401
24021999-07-14 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2403
2404 * prefix.c (prefix2str): append prefixlen.
2405
24061999-07-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2407
2408 * command.c (config_terminal): Change "config terminal" to
2409 "configure terminal". Reported by Georg Hitsch
2410 <georg@atnet.at>.
2411 (config_terminal_length): `terminal length <0-512>' is added. At
2412 this moment this command is only usef for vty interface.
2413 Suggested by Georg Hitsch <georg@atnet.at>.
2414
24151999-07-12 Kunihiro Ishiguro <kunihiro@zebra.org>
2416
2417 * routemap.c (rulecmp): Add wrapper function of strcmp.
2418
24191999-07-08 Rick Payne <rickp@rossfell.co.uk>
2420
2421 * sockunion.c (inet_aton): Fix bug of inet_aton.
2422
24231999-07-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2424
2425 * version.h (ZEBRA_VERSION): Start zebra-0.73
2426
24271999-07-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2428
2429 * version.h: Bump up to 0.72.
2430
24311999-07-05 Kunihiro Ishiguro <kunihiro@zebra.org>
2432
2433 * command.c (install_default): New function for install default
2434 commands to the node.
2435
2436 * memory.h (enum): MTYPE_NEXTHOP is added.
2437
24381999-07-01 <kunihiro@zebra.org>
2439
2440 * command.c (no_banner_motd): `no banner motd' command added.
2441
24421999-06-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2443
2444 * regex.c: Update to glibc-2.1.1's posix/regex.c
2445
2446 * regex-gnu.h: Update to glibc-2.1.1's posix/regex.h
2447
2448 * prefix.h (IPV4_ADDR_SAME): Macro added.
2449 (IPV6_ADDR_SAME): Likewise.
2450
24511999-06-29 Kunihiro Ishiguro <kunihiro@zebra.org>
2452
2453 * memory.h (enum): Add MTYPE_OSPF_VERTEX
2454
2455 * version.h: Bump up to 0.71.
2456
2457 * vty.c (vty_serv_sock_addrinfo): Use addrinfo function to bind
2458 VTY socket when IPv6 is enabled.
2459
24601999-06-28 Kunihiro Ishiguro <kunihiro@zebra.org>
2461
2462 * vty.c (vty_serv_sock): Change vty_serv_sock determine which
2463 address family to bind.
2464
2465 * command.c: Add quit command.
2466
24671999-06-26 NOGUCHI kay <kay@dti.ad.jp>
2468
2469 * vty.c (vty_read_config): Fix bug of configuration file path
2470 detection.
2471
24721999-06-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2473
2474 * version.h: Bump up to 0.70.
2475
24761999-06-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2477
2478 * buffer.h (GETL): Remove GETL macro.
2479
2480 * version.h: Bump up to 0.69.
2481
24821999-06-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2483
2484 * if.c (connected_add): Commented out connected_log.
2485
24861999-06-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2487
2488 * command.h (struct cmd_element ): strvec and descvec is combined
2489 into newstrvec.
2490
2491 * command.c (desc_make): Function removed.
2492 (desc_next): Function removed.
2493
2494 * command.h (struct cmd_element ): docvec is removed from struct
2495 cmd_element.
2496
24971999-06-12 Kunihiro Ishiguro <kunihiro@zebra.org>
2498
2499 * command.c (cmd_execute_command): Remove command NULL check.
2500
2501 * command.h (struct cmd_element ): Add newstrvec entry to struct
2502 cmd_element.
2503 (DEFUN2): DEFUN2 macro is removed. DEFUN is extended to support
2504 (a|b|c) statement.
2505 (DESC): DESC macro is removed.
2506
2507 * vty.c (vty_complete_command): When return value is
2508 CMD_ERR_NO_MATCH, don't display error message.
2509
25101999-06-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2511
2512 * table.c (route_next_until): New function.
2513
2514 * version.h: Bump up to 0.68.
2515
25161999-06-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2517
2518 * vty.c (vty_close): Free vty->buf when vty is closed.
2519
2520 * memory.h (enum): Add MTYPE_COMMUNITY_ENTRY and
2521 MTYPE_COMMUNITY_LIST.
2522
2523 * vty.h (struct vty ): Change buf from static length buffer to
2524 variable length buffer.
2525
2526 * vty.c (vty_ensure): New function added.
2527
25281999-06-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2529
2530 * command.h (node_type ): Add COMMUNITY_LIST_NODE.
2531
2532 * command.c (config_enable_password): Freeing host.enable bug is
2533 fixed.
2534 (config_enable_password): Add argc count check.
2535
25361999-05-31 Kunihiro Ishiguro <kunihiro@zebra.org>
2537
2538 * version.h: Bump up to 0.67.
2539
25401999-05-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2541
2542 * command.c (zencrypt): New function for encrypt password.
2543
2544 * command.h (struct host): Add password_encrypt and
2545 enable_encrypt.
2546
25471999-05-30 Jochen Friedrich <jochen@scram.de>
2548
2549 * command.h (struct host): New member encrypt is added for
2550 encrypted password.
2551
25521999-05-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2553
2554 * vty.c: Remove all_digit_check function. Instead use all_digit.
2555
2556 * prefix.c (all_digit): New function for checking string is made
2557 from digit character.
2558
25591999-05-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2560
2561 * Makefile.am (libzebra_a_SOURCES): Add zclient.c.
2562 (noinst_HEADERS): Add zclient.h
2563
2564 * zclient.[ch]: New file for zebra client routine.
2565
2566 * memory.h (enum): Add MTYPE_ZEBRA.
2567
25681999-05-19 Kunihiro Ishiguro <kunihiro@zebra.org>
2569
2570 * version.h (ZEBRA_VERSION): Update to 0.66.
2571
25721999-05-15 Kunihiro Ishiguro <kunihiro@zebra.org>
2573
2574 * buffer.h (GETC,GETW): Macro deleted.
2575
25761999-05-15 Carlos Alberto Barcenilla <barce@frlp.utn.edu.ar>
2577
2578 * prefix.h (IPV4_NET0, IPV4_NET127): Macro added.
2579
25801999-05-15 Kunihiro Ishiguro <kunihiro@zebra.org>
2581
2582 * vty.c (service_advanced_vty): New command added.
2583 (no_service_advanced_vty): Likewise.
2584
25851999-05-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2586
2587 * vty.c (vty_auth): If advanced flag is set and enable password is
2588 not set, directly login to the ENABLE_NODE. This feature is
2589 originally designed and implemented by Stephen R. van den Berg
2590 <srb@cuci.nl>.
2591
2592 * command.h (host): Add advanced flag to struct host for advanced
2593 vty terminal interface.
2594
2595 * version.h (ZEBRA_VERSION): Update to 0.65 for next beta release.
2596
25971999-05-14 Stephen R. van den Berg <srb@cuci.nl>
2598
2599 * command.h (node_type ): Add TABLE_NODE.
2600
2601 * vty.c (vty_telnet_option): Check host.lines value.
2602
2603 * command.c (config_lines): DEFUN for 'lines LINES' command.
2604
2605 * zebra.h: Include <sys/utsname.h> for uname().
2606 (RT_TABLE_MAIN): Defined as 0 if OS does not support multiple
2607 routing table.
2608
2609 * vty.c (vty_auth): Directly login to the ENABLE_NODE when enable
2610 password is not set.
2611 (vty_prompt): Get machine's hostname when hostname is not set.
2612
26131999-05-11 James Willard <james@whispering.org>
2614
2615 * command.c (config_exit): Close connection when `exit' command is
2616 executed at ENABLE_NODE.
2617
26181999-05-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2619
2620 * vty.c (vty_stop_input): `C-c' key change node to ENABLE_NODE.
2621
2622 * command.c (cmd_execute_command_strict): Matched command size
2623 check added.
2624 (cmd_make_desc_line): New function for DEFUN2.
2625
2626 * command.h (struct cmd_element ): Add descsize.
2627
26281999-05-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2629
2630 * command.h (struct cmd_element ): Remame descvec to docvec.
2631 (struct cmd_element ): Add descvec for new description system.
2632
2633 * command.c (desc_make): Check cmd->descvec.
2634
26351999-05-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2636
2637 * memory.h (enum): Add MTYPE_CLUSTER, MTYPE_CLUSTER_VAL.
2638
26391999-05-05 Kunihiro Ishiguro <kunihiro@zebra.org>
2640
2641 * version.h (ZEBRA_VERSION): Bump up to 0.64 for next beta
2642 release.
2643
26441999-05-04 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2645
2646 * linklist.c (list_delete_all_node): bug fix.
2647 previous code loses current position when node
2648 is deleted.
2649
26501999-05-03 Kunihiro Ishiguro <kunihiro@zebra.org>
2651
2652 * command.h (DESC): Macro added.
2653 (struct cmd_element2): Delete struct cmd_element2.
2654
2655 * plist.c (prefix_list): Sequential number option check is added.
2656
26571999-05-02 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2658
2659 * log.c (zvlog_{debug,info,notice,warn,err}): have been
2660 added. now we can log both console and file, but still
2661 need some fix about config write.
2662
26631999-05-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2664
2665 * log.c (zvlog_debug): Fix yasu's change.
2666
26671999-05-01 Kunihiro Ishiguro <kunihiro@zebra.org>
2668
2669 * plist.c (prefix_list): Fix typo.
2670
26711999-04-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2672
2673 * Set version to 0.63 for first beta package.
2674
26751999-04-27 Carlos Barcenilla <barce@frlp.utn.edu.ar>
2676
2677 * prefix.c (str2prefix_ipv4): Fix prefix length check.
2678 (str2prefix_ipv6): Likewise.
2679
26801999-04-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2681
2682 * memory.h (enum): Add MTPYE_PREFIX_LIST and
2683 MTYPE_PREFIX_LIST_ENTRY.
2684
2685 * command.h (node_type ): Add PREFIX_NODE.
2686
26871999-04-25 Carlos Barcenilla <barce@frlp.utn.edu.ar>
2688
2689 * command.c: ALIAS (config_write_memory_cmd) and ALIAS
2690 (copy_runningconfig_startupconfig_cmd) is added.
2691
2692 * table.c (route_node_lookup): Unused match variable deletion.
2693
26941999-04-24 Kunihiro Ishiguro <kunihiro@zebra.org>
2695
2696 * Makefile.am (libzebra_a_SOURCES): plist.c added.
2697 (noinst_HEADERS): plist.h added.
2698
2699 * plist.c, plist.h: New file added.
2700
2701 * memory.h (enum): Rename MTYPE_AS_PASN to MTYPE_AS_STR.
2702 * memory.c: Likewise.
2703
27041999-04-19 Carlos Alberto Barcenilla <barce@frlp.utn.edu.ar>
2705
2706 * command.c (show_version): `show version' command added.
2707
27081999-04-19 Kunihiro Ishiguro <kunihiro@zebra.org>
2709
2710 * prefix.c (str2prefix_ipv6): Prefix length overflow check.
2711
27121999-04-19 Carlos Alberto Barcenilla <barce@frlp.utn.edu.ar>
2713
2714 * prefix.c (str2prefix_ipv4): Prefix length overflow check.
2715
27161999-04-19 Alex Bligh <amb@gxn.net>
2717
2718 * prefix.c (sockunion2hostprefix): Function added.
2719 (sockunion2prefix): Address family was not set. Now it is set.
2720
2721 * vty.c: VTY access-class command is added.
2722
27231999-04-18 Kunihiro Ishiguro <kunihiro@zebra.org>
2724
2725 * memory.c: Change xmalloc to zmalloc. xcalloc, xrealloc, xfree,
2726 xstrdup are likewise.
2727
27281999-04-18 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2729
2730 * thread.c: Add thread_execute for other routing daemon.
2731 OSPF tasks need to be generated by "sheduled" and "executed".
2732
27331999-04-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2734
2735 * buffer.c: Rewrite buffer_write and buffer_flush related
2736 functions for fixing bugs. Reason of the problem and fix is
2737 suggested by Alex Bligh <amb@gxn.net>.
2738
27391999-04-12 Alex Bligh <amb@gxn.net>
2740
2741 * command.c (cmd_entry_function_descr): Added for variable
2742 argument help display.
2743
27441999-04-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2745
2746 * regex.c, regex-gnu.h: Imported from GNU sed-3.02 distribution.
2747
27481999-03-24 Kunihiro Ishiguro <kunihiro@zebra.org>
2749
2750 * stream.c: stream_fifo_free bug is fixed.
2751
27521999-03-19 Toshiaki Takada <takada@zebra.org>
2753
2754 * stream.c (stream_strncpy): Added for getting any length bytes
2755 from stream.
2756
27571999-03-16 Kunihiro Ishiguro <kunihiro@zebra.org>
2758
2759 * version.h (ZEBRA_BUG_ADDRESS): New macro added.
2760
27611999-03-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2762
2763 * buffer.c (buffer_flush_window): If ep is same as buffer's size
2764 length and lp is overrun one octet.
2765
27661999-03-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2767
2768 * vty.h: add VTY's timeout function.
2769
27701999-03-05 <kunihiro@zebra.org>
2771
2772 * command.h (node_type ): Add OSPF6_node.
2773
27741999-03-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2775
2776 * zebra.h: Check HAVE_SYS_SELECT_H when include <sys/select.h>
2777
27781999-03-03 Jeroen Ruigrok/Asmodai <asmodai@wxs.nl>
2779
2780 * zebra.h: Include <net/if_var.h> if it exists.
2781
27821999-03-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2783
2784 * getopt.[ch],getopt1.c: Sync with glibc-2.1.
2785
2786 * log.c (zlog): Tempolary ZLOG_STDOUT feature added.
2787
2788 * command.h: Include vector.h and vty.h
2789
27901999-02-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2791
2792 * routemap.h (struct route_map_rule_cmd): Add prefix arguemnt.
2793
2794 * routemap.c (route_map_apply_index): Add prefix argument.
2795 (route_map_apply): Likewise.
2796
2797 * memory.h (enum): Add MTYPE_ROUTE_MAP_COMPILED.
2798
2799 * stream.c: Add stream_fifo related functions.
2800
28011999-02-24 Kunihiro Ishiguro <kunihiro@zebra.org>
2802
2803 * daemon.c: Return integer value. File descriptor close is added.
2804
2805 * memory.h (enum): add MTYPE_OSPF_LSA.
2806
28071999-02-23 Kunihiro Ishiguro <kunihiro@zebra.org>
2808
2809 * rsh.c: Remove empty file.
2810
28111999-02-22 <kunihiro@zebra.org>
2812
2813 * routemap.c: Add add/delete hook to route_map_master.
2814
28151999-02-19 Peter Galbavy <Peter.Galbavy@knowledge.com>
2816
2817 * str.[ch] added to supply wrappers for snprintf(), strlcat() and
2818 strlcpy on system without these.
2819
28201999-02-18 Peter Galbavy <Peter.Galbavy@knowledge.com>
2821
2822 * syslog support added
2823
28241999-02-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2825
2826 * filter.c (access_list_add_hook): added for hook function management.
2827 * filter.c (access_list_delete_hook): Likewise.
2828
28291999-01-19 Kunihiro Ishiguro <kunihiro@zebra.org>
2830
2831 * stream.c: New file.
2832 * stream.h: New file.
2833 * Divide stream related fucntions from buffer.[ch] into stream.[ch].
2834
28351999-01-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2836
2837 * memory.h (enum): add MTYPE_STREAM, MTYPE_STREAM_DATA
2838
2839 * buffer.c (stream_new): Set MTYPE_STREAM to XMALLOC argument.
2840
28411998-12-23 Kunihiro Ishiguro <kunihiro@zebra.org>
2842
2843 * routemap.c: route_map_index_delete() added.
2844
28451998-12-22 Kunihiro Ishiguro <kunihiro@zebra.org>
2846
2847 * buffer.c (buffer_empty): check cp instead of sp.
2848
28491998-12-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2850
2851 * radix.[ch]: Deleted.
2852
28531998-12-15 Magnus Ahltorp <map@stacken.kth.se>
2854
2855 * buffer.c: Prototype fixes.
2856 * prefix.c: Likewise.
2857 * sockunion.c: Likewise.
2858 * sockunion.h: Likewise.
2859
28601998-12-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2861
2862 * vty.c (vty_read): DELETE key works as vty_delete_char.
2863
28641998-12-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2865
2866 * log.c (time_print): chane %y to %Y.
2867
28681998-12-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2869
2870 * distribute.c: new file.
2871
28721998-12-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2873
2874 * filter.c: Remove all of struct prefix_{ipv4,ipv6} and add
2875 complete support of IPv6 access list.
2876
2877 * command.c (config_write_element): function delete.
2878 (config_write_host): function add. password and enable password
2879 isn't printed to vty interface.
2880
28811998-12-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2882
2883 * filter.c: Change prefix_ipv4 to prefix and add support of
2884 prefix_ipv6 filtering.
2885
28861998-12-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2887
2888 * Makefile.am (INCLUDES): add @INCLUDES@ for Linux IPv6 inet6-apps
2889 header includes.
2890
28911998-12-05 Kunihiro Ishiguro <kunihiro@zebra.org>
2892
2893 * log.c (log_flush): fix function name typo.
2894
28951998-12-04 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2896
2897 * memory.h: OSPF memory type is added.
2898
28991998-11-15 Kunihiro Ishiguro <kunihiro@zebra.org>
2900
2901 * command.c (sort_node): add sort_node() for pretty printing of
2902 command on vty interface.
2903 (config_password): delete the restriction of charaster of password
2904 string.
2905
29061998-09-05 Kunihiro Ishiguro <kunihiro@debian.zebra.org>
2907
2908 * prefix.c (prefix_ipv4_any): add prefix_ipv4_any().
2909
29101998-08-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2911
2912 * network.h: New file.
2913
29141998-08-24 Kunihiro Ishiguro <kunihiro@zebra.org>
2915
2916 * vty.c (vty_will_echo): function name change from vty_off_echo.
2917
29181998-08-18 Kunihiro Ishiguro <kunihiro@zebra.org>
2919
2920 * buffer.h: add PUTC,PUTW,PUTL macros.
2921
29221998-07-22 Kunihiro Ishiguro <kunihiro@zebra.org>
2923
2924 * route.[ch]: renamed to prefix.[ch]
2925
29261998-06-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2927
2928 * prefix_in, prefix_in6 is replaced by prefix_ipv4, prefix_ipv6.
2929
2930 * Makefile.am: @INCLUDES@ is deleted from INCLUDES.
2931
29321998-06-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2933
2934 * host.[ch]: merged with command.[ch]
2935
29361998-05-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2937
2938 * Makefile.am (libzebra_a_SOURCES): add route.c to libzebra_a_SOURCES.
2939
29401998-05-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2941
2942 * route.c (str2prefix): str2prefix () is gone.
2943
29441998-05-03 Kunihiro Ishiguro <kunihiro@zebra.org>
2945
2946 * vty.c (vty_read_config): change CONDIR to SYSCONFDIR.
2947
2948 * .cvsignore: add file.
2949
2950 * memory.c (xerror): add arguent `type' and `size'.
2951
2952 * socket.c: deleted.
2953
29541998-05-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2955
2956 * vector.c: malloc,free,realloc -> XMALLOC,XFREE,XREALLOC.
2957 * linklist.c: same as above.
2958
29591998-04-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2960
2961 * filter.[ch]: added.
2962
29631998-04-01 Kunihiro Ishiguro <kunihiro@zebra.org>
2964
2965 * vty.c (config_who): return CMD_SUCCESS
2966
29671998-04-01 Jochen Friedrich <jochen@scram.de>
2968
2969 * table.c (route_dump_node): route_dump_node is IPv6 specific
2970 function so move #ifdef to the end of route_dump_node ().
2971
29721998-03-05 "Hannes R. Boehm" <hannes@boehm.org>
2973
2974 * if.c: DEFUN(interface_desc) added.
2975
29761998-03-05 Kunihiro Ishiguro <kunihiro@zebra.org>
2977
2978 * if.c: separated from ripd/rip_interface.c
2979
29801998-03-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2981
2982 * thread.[ch] : added.
2983
29841998-02-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2985
2986 * vty.c (vty_delete_char): fix size bug.
2987 (vty_backward_pure_word): function added.
2988 (vty_read): ESC + 'f' perform vty_forward_word.
2989 (vty_read): ESC + 'b' perform vty_backward_word.
2990
29911998-02-11 Kunihiro Ishiguro <kunihiro@zebra.org>
2992
2993 * radix.c (radix_lookup_rt): add mask check.
2994 (radix_delete_duproute): add mask check.
2995
29961998-02-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2997
2998 * command.c (config_write_file): fix vty -> file_vty.
2999
30001998-02-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3001
3002 * command.c (cmd_filter_ambiguous): add complex type treatment.
3003
30041998-02-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3005
3006 * vty.c (vty_time_print): function added.
3007 (vty_complete_command): now [...] element isn't shown by completion.
3008
30091998-01-26 Kunihiro Ishiguro <kunihiro@zebra.org>
3010
3011 * command.c : change from cmd_install_node() to install_node().
3012
30131998-01-16 Kunihiro Ishiguro <kunihiro@zebra.org>
3014
3015 * route.[ch]: struct rt{} is replaced by struct prefix{}.
3016
30171998-01-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3018
3019 * command.c (cmd_execute_command): check command length.
3020
3021 * timer.c (zebra_timer_set): add zebra_timer_set.
3022
30231998-01-05 Kunihiro Ishiguro <kunihiro@zebra.org>
3024
3025 * command.h (node_type ): add ZEBRA_NODE.
3026
3027 * command.c (config_exit): add RIP_NODE.
3028 (config_write_file): add RIP_NODE.
3029
30301998-01-04 Kunihiro Ishiguro <kunihiro@zebra.org>
3031
3032 * print_version.c (print_version): Now Copyright is 1996-1998.
3033
3034 * sockunion.c (sockunion_log): moved from ../zebra/route.c
3035
30361997-12-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3037
3038 * host.c (config_logfile): change 'log PATH' to 'logfile PATH'.
3039
3040 * sockunion.c (sockunion_sameprefix): add same prefix for
3041 sockunion.
3042
30431997-12-29 Kunihiro Ishiguro <kunihiro@zebra.org>
3044
3045 * radix.[ch] : are moved from ../zebra directroy.
3046
3047 * command.c (config_from_file): if command execution failed down
3048 level to CONFIG_NODE.
3049
3050 * host.c: config_log function which enable 'log FILENAME' command.
3051
30521997-12-23 Kunihiro Ishiguro <kunihiro@zebra.org>
3053
3054 * vty.c: add vty_transpose_chars (). Now you can use '^T' to
3055 transpose character.
3056
3057 * command.c: cmd_cmdsize add, this is useful to check incomplete
3058 command.
3059
30601997-12-07 Kunihiro Ishiguro <kunihiro@zebra.org>
3061
3062 * fd.h: add family for address family
3063
30641997-12-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3065
3066 * command.o
3067 * vty.o
3068 * host.o is moved from ../zebra
3069
30701997-08-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3071
3072 * make library directory.
3073