blob: 26cb68628919df8330a0ef59ea7a85fcd03a23c1 [file] [log] [blame]
ajs9fc7ebf2005-02-23 15:12:34 +000012005-02-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
2
ajscdb6ee92005-02-23 15:48:32 +00003 * {vty.h,vty.c}: Remove vty_finish (duplicate of vty_reset).
4
52005-02-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
6
ajs9fc7ebf2005-02-23 15:12:34 +00007 * buffer.h: Make the struct buffer and struct buffer_data structures
8 private by moving them inside buffer.c. Add comments for all
9 functions. Rename buffer_write as buffer_put (to be more consistent
10 with the buffer_putc and buffer_putstr functions). Declare a new
11 buffer_write function that is used to write data to a file descriptor
12 and/or add it to the buffer queue. Remove unused function
13 buffer_flush_vty_all. Create a new enum typedef buffer_status_t
14 to be used as the return code for all buffer_flush* functions
15 and buffer_write.
16 * buffer.c: The struct buffer and struct buffer_data declarations
17 are now private to this file. In conjunction with that, remove
18 some unnecessary fields: struct buffer (alloc, unused_head,
19 unused_tail, length), struct buffer_data (prev).
20 (buffer_data_new) Removed: functionality incorporated into buffer_add.
21 (buffer_data_free) Removed: use a macro BUFFER_DATA_FREE instead.
22 (buffer_new) Use calloc instead of malloc + memset(zero).
23 Supply an appropriate default size if the specified size is 0.
24 (buffer_free) Eliminate code duplication by calling buffer_reset to
25 free the contents of the buffer (and remove unused code related
26 to unused_head).
27 (buffer_empty,buffer_putc,buffer_putstr) Aesthetic change (make more
28 compact).
29 (buffer_reset) Use macro BUFFER_DATA_FREE. No need to set
30 alloc and length to 0 (these fields have been removed).
31 (buffer_add) Fix scope to be static. Call XMALLOC directly instead
32 of calling removed buffer_data_new function. Simplify the logic
33 (since it's now a singly-linked list instead of doubly-linked).
34 (buffer_write) Renamed to buffer_put. Change to void, since return
35 code of 1 was meaningless. No need to adjust length field, since
36 it has been removed.
37 (buffer_putw,buffer_flush,buffer_flush_vty_all,buffer_flush_vty)
38 Remove unused functions.
39 (buffer_flush_all) Rewrite using buffer_flush_available to eliminate
40 a possible failure mode if IOV_MAX is less than the number of buffers
41 on the queue.
42 (buffer_flush_window) Incorporate logic from buffer_flush_vty.
43 Log an error message if there is a writev error.
44 (buffer_flush_available) Be more paranoid: check for case where
45 buffer is already empty. Use new ERRNO_IO_RETRY macro, and use
46 new enum for return codes. Simplify deletion logic (since it's
47 now a singly-linked list).
48 (buffer_write) New function for use with non-blocking I/O.
49 * vty.h: Replace the struct vty sb_buffer field with a fixed-size
50 (5-character) sb_buf field and an sb_len field, since using
51 a struct buffer was inappropriate for this task. Add some useful
52 comments about telnet window size negotiation.
53 * vty.c: Include <arpa/telnet.h> (no longer included by zebra.h).
54 Remove VTY_OBUF_SIZE (instead use buffer_new default size).
55 Make telnet_backward_char and telnet_space_char static const.
56 (vty_out) Replace buffer_write with buffer_put.
57 (vty_log_out) Check for I/O errors. If fatal, close the vty session.
58 Consolidate 3 separate writes into a single write call.
59 (vty_will_echo,vty_command,vty_next_line,vty_previous_line,
60 vty_end_config,vty_describe_fold,vty_clear_buf,vty_serv_sock_addrinfo,
61 vty_serv_sock_family,vty_serv_un,vty_use_backup_config,exec_timeout,
62 vty_config_write,vty_save_cwd) Fix scope to static.
63 (vty_new) Let buffer_new use its default buffer size.
64 (vty_write) Fix signature: 2nd arg should be const char *.
65 Replaced buffer_write with buffer_put.
66 (vty_telnet_option) Fix minor bug (window height or width greater than
67 255 was broken). Use sb_buf and sb_len instead of removed sb_buffer
68 (which was being used improperly).
69 (vty_read) On error, use ERRNO_IO_RETRY to decide whether it's fatal.
70 If the error is fatal, call buffer_reset so vty_close does not attempt
71 to flush the data. Use new sb_buf and sb_len instead of sb_buffer
72 to store the SB negotiation string.
73 (vty_flush) When vty->lines is 0, call buffer_flush_available instead
74 of buffer_flush_window. Look at the return code from buffer_flush
75 to detect I/O errors (and in that case, log an error message and
76 close the vty).
77 (vty_create) Fix scope to static. Initialize sb_len to 0 instead
78 of creating sb_buffer.
79 (vty_accept) Set socket nonblocking.
80 (vtysh_accept) Use new set_nonblocking function instead of calling
81 fcntl directly.
82 (vtysh_flush) New function called from vtysh_read (after command
83 execution) and from vtysh_write. This flushes the buffer
84 and reacts appropriately to the return code (by closing the vty
85 or scheduling further flushes).
86 (vtysh_read) Check whether error is fatal using ERRNO_IO_RETRY.
87 If not, just try again later. Otherwise, call buffer_reset before
88 calling vty_close (to avoid trying to flush the buffer in vty_close).
89 Fix logic to allow case where a command does not arrive atomically
90 in a single read call by checking for the terminating NUL char.
91 (vtysh_write) Use new vtysh_flush helper function.
92 (vty_close) No need to call buffer_empty, just call buffer_flush_all
93 in any case (it will check whether the buffer is empty).
94 Do not free sb_buffer (since it has been removed).
95 (vty_log_fixed) Use writev instead of write.
96 * zebra.h: Do not include <arpa/telnet.h>, since this is used only
97 by lib/vty.c.
98
hassoc3c07f22005-02-21 18:17:52 +0000992005-02-21 Vincenzo Eramo <eramo at infocom.ing.uniroma1.it>
100
101 * pqueue.[ch]: Introduce "update" function to meet ospf spf needs. It
102 will allow to update node when:
103 i) a node is inserted into the priority queue;
104 ii) a node position is modified in the priority queue;
105 * pqueue.h: Export trickle_down() function.
106
paul109ac962005-02-19 01:17:07 +00001072005-02-19 Paul Jakma <paul.jakma@sun.com>
108
109 * stream.c: (stream_new) fix dumb mistake.
110
ajsd7e2a812005-02-17 20:02:49 +00001112005-02-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
112
ajs53270112005-02-17 20:07:22 +0000113 * stream.c: (stream_read_try) Use new ERRNO_IO_RETRY macro.
114
1152005-02-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
116
ajsd7e2a812005-02-17 20:02:49 +0000117 * network.h: Define a new ERRNO_IO_RETRY macro to test whether an I/O
118 operation should be retried. This eliminates the need to duplicate
119 the same logic testing for EAGAIN or EINTR in multiple places.
120
ajs42218e72005-02-16 16:25:39 +00001212005-02-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
122
ajs262feb12005-02-16 20:35:47 +0000123 * stream.h: Declare new function stream_read_try suitable for use
124 with non-blocking file descriptors. Indicate that stream_read
125 and stream_read_unblock are deprecated.
126 * stream.c: (stream_read_try) New function for use with non-blocking
127 I/O.
128 (stream_recvmsg) Should return -1 if the stream is too small to
129 contain the data.
130
1312005-02-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
132
ajs42218e72005-02-16 16:25:39 +0000133 * network.c: (set_nonblocking) Should check return code from
134 fcntl(F_GETFL).
135
ajsa269d612005-02-16 00:45:37 +00001362005-02-15 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
137
138 * network.h: Declare new function set_nonblocking. Indicate that
139 readn and writen are deprecated.
140 * network.c: (set_nonblocking) New function to make a file descriptor
141 non-blocking, since it seems silly to have fcntl calls sprinkled
142 throughout the code.
143
paul1dd13d42005-02-14 23:49:09 +00001442005-02-14 Paul Jakma <paul.jakma@sun.com>
paulf2e6c422005-02-12 14:35:49 +0000145
146 * stream.h: Unsigned long updated to size_t
147 * stream.c: ditto
paul050c0132005-02-14 23:47:47 +0000148 * stream.h: Add stream_copy, stream_dup, stream_recvmsg.
149 Add comment describing struct stream abstraction, and various
150 other comments.
151 Deprecate several unsafe/ambigious macros.
152 Add STREAM_WRITEABLE and STREAM_READABLE.
153 Add (stream_getl_from) for symmetry.
154 Update stream_forward_{endp,getp} to use size_t offset.
155 Make stream data a 0 length array, rather than a seperate malloc.
156 * stream.c: Add consistency checks. Update to follow stream.h
157 changes.
158 (stream_new) Alloc stream+data in one go.
159 (stream_copy) new function, copy a stream.
160 (stream_dup) new function, dup a stream.
161 (stream_recvmsg) new function, recvmsg data into a stream.
162 (stream_empty) no need to check getp == 0.
paulf2e6c422005-02-12 14:35:49 +0000163
paul9985f832005-02-09 15:51:56 +00001642005-02-09 Paul Jakma <paul.jakma@sun.com>
165
166 * stream.h: Remove putp. Update reference to putp with endp.
167 Add stream_forward_endp, which daemons were doing manually.
168 Rename stream_forward to stream_forward_getp.
169 stream.c: Remove/update references to putp.
170 introduce stream_forward_endp.
171
ajs548e6f72005-02-08 15:57:25 +00001722005-02-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
173
174 * zebra.h: Change macro definitions SET_FLAG and UNSET_FLAG
175 to use compound assignment operators (aesthetic change).
176
ajs1e221352005-02-03 16:42:40 +00001772005-02-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
178
ajsc4c7d0c2005-02-03 19:22:05 +0000179 * log.c: (zlog_signal,zlog_backtrace_sigsafe) Eliminate use of fileno()
180 since it is not async-signal-safe.
181 (_zlog_assert_failed) Rewrite crashlog logic more compactly.
182 (zlog_set_file,zlog_reset_file,zlog_rotate) Update logfile_fd
183 for use in signal handler.
184
1852005-02-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
186
ajs1e221352005-02-03 16:42:40 +0000187 * log.c: (syslog_sigsafe) Reduce scope of syslog_fd: it is accessed
188 inside this function only.
189 (open_crashlog) New function to open /var/tmp/quagga.<daemon>.crashlog
190 with flags O_WRONLY|O_CREAT|O_EXCL to save some crash info.
191 (zlog_signal,_zlog_assert_failed) Increase logging priority from
192 LOG_ERR to LOG_CRIT. If no file logging is configured, try to use
193 open_crashlog to create a crash logfile.
194 (zlog_backtrace_sigsafe) If a crashlog file descriptor is open,
195 dump a backtrace to that file.
196
ajs847947f2005-02-02 18:38:48 +00001972005-02-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
198
199 * if.h: Declare if_flag_dump.
200
ajs6a52d0d2005-01-30 18:49:28 +00002012005-01-30 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
202
203 * daemon.c: (daemon) Replace perror with zlog_err.
204 * vty.c: (vty_serv_un) Replace perror with zlog_err.
205
ajs3b8b1852005-01-29 18:19:13 +00002062005-01-29 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
207
208 * buffer.h: Fix comment on buffer_getstr to reflect that it now
209 uses XMALLOC.
210 * buffer.c: (buffer_getstr) Use XMALLOC(MTYPE_TMP) instead of malloc.
211 * filter.c: (access_list_remark,ipv6_access_list_remark) Use
212 argv_concat instead of buffer_getstr.
213 * if.c: (interface_desc) Use argv_concat instead of buffer_getstr.
214 * plist.c: (ip_prefix_list_description,ipv6_prefix_list_description)
215 Use argv_concat instead of buffer_getstr.
216
ajsf6834d42005-01-28 20:28:35 +00002172005-01-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
218
ajsafb8b602005-01-28 20:41:07 +0000219 * lib/buffer.h: Document behavior of buffer_getstr function.
220 * lib/buffer.c: (buffer_getstr) Fix bug: must handle case where
221 the string extends beyond the head struct buffer_data.
222
2232005-01-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
224
ajsf6834d42005-01-28 20:28:35 +0000225 * lib/command.h: Document behavior of argv_concat function.
226 * lib/command.c: (argv_concat) Calculate total string length first so
227 we can call malloc just once (instead of realloc'ing to add each
228 string element).
229 (do_echo,config_logmsg) Allow for possible NULL return value from
230 argv_concat.
231
hasso13bfca72005-01-23 21:42:25 +00002322005-01-23 Hasso Tepper <hasso at quagga.net>
233
234 * lib/command.[ch]: Make node_parent() function nonstatic. vtyh.c will
235 use it as well.
236
ajs31364272005-01-18 22:18:59 +00002372005-01-18 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
238
239 * log.h: Test for SA_SIGINFO to see whether zlog_signal takes final
240 two args (siginfo and program_counter).
241 * log.c: (hex_append) Include this function only if SA_SIGINFO or
242 HAVE_GLIBC_BACKTRACE is defined.
243 (zlog_signal) Final two args (siginfo and program_counter) now
244 depend on whether SA_SIGINFO is defined on this platform.
245 * sigevent.c: (program_counter) Do not include this function if
246 SA_SIGINFO is not defined on this platform.
247 (exit_handler,core_handler) Test for SA_SIGINFO to decide whether
248 2nd & 3rd arguments are present and to decide how to invoke
249 zlog_signal.
250 (trap_default_signals) Test for SA_SIGINFO and invoke sigaction
251 appropriately.
252
ajs239c26f2005-01-17 15:22:28 +00002532005-01-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
254
255 * log.h: Change prototype for zlog_backtrace_sigsafe to take additional
256 program_counter argument.
257 * log.c: (zlog_backtrace_sigsafe) Add additional program_counter
258 argument. If it is non-NULL, use backtrace_symbols_fd to resolve
259 the address.
260 (zlog_signal) Call zlog_backtrace_sigsafe with additional
261 program_counter argument.
262
hasso87d683b2005-01-16 23:31:54 +00002632005-01-17 Hasso Tepper <hasso at quagga.net>
264
265 * command.[ch], vty.c: cmd_execute_command() function must not attempt
266 to walk up in the node tree if called from vtysh. Different daemons
267 might have commands with same syntax in different nodes (for example
268 "router-id x.x.x.x" commands in zebra/ospfd/ospf6d daemons).
269
ajscb585b62005-01-14 17:09:38 +00002702005-01-14 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
271
272 * command.c (print_version): Do not bother even to examine host.name,
273 since it is always NULL when this function is called from main.
274
gdtf867d322005-01-14 15:47:33 +00002752005-01-14 Greg Troxel <gdt@fnord.ir.bbn.com>
276
277 * command.c (print_version): Don't print host.name if it is NULL.
278 Fixes segfault on Solaris reported by Goetz von Escher <goetz@open.ch>
279
ajse22f5512005-01-12 16:18:17 +00002802005-01-12 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
281
ajs40abf232005-01-12 17:27:27 +0000282 * sigevent.c: (trap_default_signals) Use the SA_SIGINFO flag to
283 pass additional siginfo_t and ucontext_t arguments to core_handler
284 and exit_handler.
285 (core_handler,exit_handler) Now invoked with 3 arguments (using
286 SA_SIGINFO). Pass additional info to zlog_signal.
287 (program_counter) New function to find program counter in ucontext_t,
288 needs to be enhanced to support more platforms (currently works only
289 on Linux/x86).
290 * log.h: Change the zlog_signal prototype to add new arguments
291 siginfo_t * and program_counter.
292 * log.c: (zlog_signal) Add new arguments siginfo and program_counter.
293 Include si_addr and program counter (if non-NULL) in message.
294 And remove #ifdef HAVE_GLIBC_BACKTRACE around hex_append, since
295 that is now used to render the si_addr and PC pointers.
296
2972005-01-12 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
298
ajse22f5512005-01-12 16:18:17 +0000299 * zebra.h: If not C99 and no va_copy macro available, fall back to
300 memcpy (solves a build problem on FreeBSD 4.x).
301
ajsb99760a2005-01-04 16:24:43 +00003022005-01-04 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
303
304 * zebra.h: Define ZCMSG_FIRSTHDR appropriately based on whether
305 config.h indicates HAVE_BROKEN_CMSG_FIRSTHDR (as determined
306 by the configure test program).
307 * sockopt.c: (getsockopt_cmsg_data) Use ZCMSG_FIRSTHDR instead
308 of CMSG_FIRSTHDR.
309
hassocba8a602005-01-02 18:51:01 +00003102005-01-02 Hasso Tepper <hasso at quagga.net>
311
312 * command.c: Revert int -> unsigned int fixes in
313 cmd_describe_command_real() and cmd_complete_command_real(). index can
314 be actually negative and it caused crash with "do<TAB>" in vty.
315
gdt1d69fdf2004-12-29 18:53:30 +00003162004-12-29 Greg Troxel <gdt@poblano.ir.bbn.com>
317
gdtd44debe2004-12-29 20:06:23 +0000318 * sockopt.c (getsockopt_ipv4_ifindex): Document calling
319 convention. Beef up comments. Handle the case where the cmsghdr
320 has a zero controllen, or more specifically when the wanted option
321 is not present. This is needed for Solaris 8, and in general for
322 any platform for which configure finds a method and it can fail.
323 Mark some changes with XXX to be cleaned up post 0.98.
324
ajsaf04bd72004-12-28 17:00:12 +00003252004-12-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
326
ajs1d75c8c2004-12-28 21:43:17 +0000327 * sockopt.c: (setsockopt_ipv4_ifindex) Improve error message.
328 When neither IP_PKTINFO nor IP_RECVIF is defined, make return value
329 deterministic (-1).
330
3312004-12-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
332
ajsaf04bd72004-12-28 17:00:12 +0000333 * thread.c: (funcname_thread_add_timer_msec) Reduce overflow risk.
334
paul4ba9b922004-12-21 22:34:58 +00003352004-12-21 Paul Jakma <paul.jakma@sun.com>
336
337 * if.h: Add more 'non-generic' IFF_ flags.
338 * if.c: IFF_NOXMIT/IFF_VIRTUAL interfaces are 'loopback like'
paul0e43a2b2004-12-22 00:15:34 +0000339 * stream.c: Dont allocate streams with 0 sized data buffers
paul4ba9b922004-12-21 22:34:58 +0000340
ajs202d08c2004-12-17 20:50:00 +00003412004-12-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
ajs2885f722004-12-17 23:16:33 +0000342
343 * command.c: (do_echo) Added new "echo" command, useful for
344 watchdog pinging to make sure the daemon is responsive.
345
3462004-12-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
ajs202d08c2004-12-17 20:50:00 +0000347
348 * pid_output.c: (pid_output_lock) Eliminate static function, and just
349 use the #ifdef to decide which version of the function to include.
350 This eliminates a compilation problem with gcc4. And fix the
351 non-fcntl version so that it actually compiles. Exit with
352 status 1 instead of -1 on error.
353
ajs81fc57c2004-12-15 17:41:14 +00003542004-12-15 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
355
356 * sigevent.c: (trap_default_signals) Ignore SIGPIPE instead of exiting.
357
ajs3378d202004-12-10 22:43:17 +00003582004-12-10 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
359
360 * log.c: (zlog_signal,_zlog_assert_failed) Change logging level back to
361 LOG_ERR instead of LOG_EMERG.
362
ajsc3324c62004-12-09 17:26:31 +00003632004-12-09 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
364
365 * log.c: (hex_append) No need to include this function if
366 HAVE_GLIBC_BACKTRACE is not defined.
367
ajsb9e70282004-12-08 17:14:45 +00003682004-12-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
369
370 * prefix.c: (prefix_copy) Error message before abort should
371 have severity LOG_ERR, not LOG_INFO.
372 * memory.c: (mtype_log) Log level should be LOG_DEBUG, not LOG_INFO.
373
ajs274a4a42004-12-07 15:39:31 +00003742004-12-07 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
375
ajs8ddca702004-12-07 18:53:52 +0000376 * {smux.c,zclient.c}: Change level of debug messages to LOG_DEBUG.
377
3782004-12-07 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
379
ajs82146b82004-12-07 17:15:55 +0000380 * command.c: (config_write_host) Note that "log trap" is deprecated
381 when writing out the config.
382
3832004-12-07 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
384
ajs274a4a42004-12-07 15:39:31 +0000385 * log.h: Replace struct zlog flags and maskpri fields with maxlvl
386 array to support individual logging levels for each destination.
387 Remove the 2nd argument to openzlog since the default logging config
388 should be standardized inside the library. Replaced the
389 zlog_set_flag and zlog_reset_flag functions with zlog_set_level.
390 And zlog_set_file now requires an additional log_level argument.
391 Declare zlog_proto_names for use inside command.c in the
392 "show logging" command. Added defines useful for command
393 construction.
394 * log.c: (vzlog) Decide where to send the message based on the
395 individual logging levels configured for each destination.
396 Remove support for ZLOG_STDERR since it was never actually used.
397 Support record-priority for terminal monitors.
398 (zlog_signal,zlog_backtrace_sigsafe) Support destination-specific
399 logging levels. Remove stderr support (was never used). Added
400 support for terminal monitor logging.
401 (_zlog_assert_failed) Increase message severity to LOG_EMERG.
402 (openzlog) Remove 2nd argument since default config should be
403 standardized in library. By default, terminal monitoring
404 is set to debug, and all other logging is disabled.
405 (zlog_set_flag,zlog_reset_flag) Removed.
406 (zlog_set_level) New function to replace zlog_set_flag and
407 zlog_reset_flag. Supports destination-specific logging levels.
408 (zlog_set_file,zlog_reset_file) Support file-specific logging level.
409 (zlog_rotate) Log an error message if fopen fails, and support
410 new file-specific logging level.
411 * command.h: Change DEFUN_CMD_FUNC_DECL and DEFUN_CMD_FUNC_TEXT so that
412 command functions will be static instead of global. Remove
413 declarations for config_exit and config_help. Define new macros
414 DEFUNSH_ATTR, DEFUNSH_HIDDEN, and DEFUNSH_DEPRECATED so we can
415 have deprecated commands in vtysh. Similarly, for completeness,
416 define macros ALIAS_SH, ALIAS_SH_HIDDEN, and ALIAS_SH_DEPRECATED.
417 Also, fix bug in ALIAS_ATTR macro (didn't matter because it
418 was never used).
419 * command.c: Make many functions static instead of global.
420 (facility_name,facility_match,level_match) New functions
421 to support enhanced destination-specific logging levels.
422 (config_write_host) Support new destination-specific logging levels.
423 (config_logmsg) Added new "logmsg" command to help test logging
424 system.
425 (show_logging) Added "show logging" command to show the current
426 configuration of the logging system.
427 (config_log_stdout_level) Support explicit stdout logging level.
428 (no_config_log_stdout) Now takes optional LEVEL arg.
429 (config_log_monitor,config_log_monitor_level,no_config_log_monitor)
430 New commands creating new "log monitor" commands to set terminal
431 monitoring log level.
432 (config_log_file_level) Support explicit file logging level.
433 (config_log_syslog_level) Support explicit syslog logging level.
434 (config_log_facility,no_config_log_facility) Implement new
435 "log facility" command.
436 (cmd_init) Add hooks for new commands: "show logging", "logmsg",
437 "log stdout <level>", "log monitor", "log monitor <level>",
438 "no log monitor", "log file <filename> <level>",
439 "no log file <filename> <level>", "log syslog <level>",
440 "log facility", and "no log facility".
441 * vty.h: Added a "level" argument to vty_log so it can support
442 "log record-priority". Declare new function vty_log_fixed for
443 use in signal handlers.
444 * vty.c: (vty_log,vty_log_out) Added a "level" argument to support
445 "log record-priority" for vty terminal monitors.
446 (vty_down_level) Use config_exit_cmd.func instead of calling
447 config_exit directly (since command functions will now be static
448 instead of global).
449 (vty_log_fixed) New function to send terminal monitor messages
450 from inside a signal handler.
451
ajs887c44a2004-12-03 16:36:46 +00004522004-12-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
453
ajs5e764772004-12-03 19:03:33 +0000454 * log.h: Document appropriate use of syslog logging priorities
455 inside quagga.
456
4572004-12-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
458
ajs56f20692004-12-03 17:40:31 +0000459 * command.h: Remove fields log_stdout and log_syslog from struct host,
460 since they are just trying to duplicate information in the
461 zlog_default structure. Note that this fixes a bug since those
462 fields were not registering any logging that was established
463 in the initial call to openzlog (this affects only the zebra and
464 ospf6d daemons). It is probably a bug to turn on any logging by
465 default in the call to openzlog.
466 * command.c: (config_write_host) Get logging info from zlog_default
467 instead of now-removed fields host.log_stdout and host.log_syslog.
468 (config_log_stdout,no_config_log_stdout) Do not set now-removed field
469 host.log_stdout, since this info is recorded in zlog_default.
470 (config_log_file) Use XSTRDUP (instead of strdup) to set host.logfile.
471 (config_log_syslog,config_log_syslog_facility,no_config_log_syslog)
472 Do not set now-removed field host.log_syslog, since this info is
473 recorded in zlog_default.
474
4752004-12-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
476
ajs887c44a2004-12-03 16:36:46 +0000477 * version.h.in: Remove declaration for pid_output_lock, this function
478 is now static, not global.
479 * pid_output.c: (pid_output_lock) This function should be static, not
480 global. And remove "old umask" error message, since it was really
481 an unimportant debug message, not an error.
482 (pid_output) Need to declare static function pid_output_lock.
483
ajs7d149b82004-11-28 23:00:01 +00004842004-11-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
485
486 * log.h: Remove several unused fields from struct zlog. Add comments
487 for other fields, and add one new field syslog_options that is
488 used in the new syslog_sigsafe implementation.
489 * log.c: (syslog_sigsafe) New function to send syslog messages in
490 an async-signal safe way that can be used inside a signal handler.
491 (syslog_connect) New function to connect to syslog daemon inside a
492 signal handler. This function supports only systems where /dev/log
493 is a unix datagram socket (e.g. not Solaris).
494 (zlog_signal) Call syslog_sigsafe if syslog logging is enabled.
495 (zlog_backtrace_sigsafe) Call syslog_sigsafe if syslog logging is
496 enabled.
497 (openzlog) Save syslog_options for use in syslog_sigsafe.
498 (num_append) Fix bug: handle 0 properly.
499 (hex_append) New function to print a u_long in hex format.
500
hasso2557aed2004-11-28 21:16:20 +00005012004-11-28 Hasso Tepper <hasso at quagga.net>
502
503 * command.h: DEFUN_DEPRECATED passes attribute to DEFUN as well.
504
ajsd1c51d72004-11-26 14:14:30 +00005052004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
506
ajs48d6c692004-11-26 20:52:59 +0000507 * log.c, log.h, memory.c: Change function name from zlog_backtrace_safe
508 to the more self-explanatory zlog_backtrace_sigsafe.
509
5102004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
511
ajs5b85fac2004-11-26 19:36:42 +0000512 * debug.[ch]: Remove unused files.
513 * Makefile.am: Remove references to debug.c and debug.h
514
5152004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
516
ajs063ee522004-11-26 18:11:14 +0000517 * log.c: (zlog_backtrace) New function to log a backtrace.
518 (zlog_backtrace_safe) Log a backtrace in an async-signal-safe way.
519 Unfortunately, this function does not support syslog logging yet.
520 (zlog_signal) Move backtrace code into separate function
521 zlog_backtrace_safe.
522 (_zlog_assert_failed) Call zlog_backtrace before aborting.
523 * log.h: Declare new functions zlog_backtrace and zlog_backtrace_safe.
524 * memory.c: (zerror) Call zlog_backtrace before aborting.
525
5262004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
527
ajsd1c51d72004-11-26 14:14:30 +0000528 * Makefile.am: Need to add zassert.h to pkginclude_HEADERS.
529
ajse5879ca2004-11-25 16:07:53 +00005302004-11-25 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
531
ajs4cf0d0d2004-11-25 17:14:34 +0000532 * zebra.h: If not C99 and there's no va_copy macro and there is
533 a __va_copy macro, define va_copy as __va_copy.
534
5352004-11-25 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
536
ajse5879ca2004-11-25 16:07:53 +0000537 * pid_output.c: (pid_output_lock) Fix 2 bugs: when locking, should
538 set l_whence to SEEK_SET, not SEEK_END. And after writing new
539 pid to file, must ftruncate to eliminate any extraneous bytes left
540 over from the last time a pid was written.
541
ajscee3df12004-11-24 17:14:49 +00005422004-11-24 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
543
544 * zassert.h: New header file to declare a quagga-specific assert macro.
545 * log.c: (_zlog_assert_failed) New function called when assert fails
546 to log the error and abort.
547 * zebra.h: Include "zassert.h" instead of <assert.h>.
548 * regex.c: Include "zassert.h" instead of <assert.h>.
549
ajsd246bd92004-11-23 17:35:08 +00005502004-11-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
551
ajs59a06a92004-11-23 18:19:14 +0000552 * sigevent.c: (signal_init) Set up some default signal handlers
553 so that processes will issue an error message before terminating
554 or dumping core.
555 (trap_default_signals) New function to set up signal handlers
556 for various signals that may kill the process.
557 (exit_handler) Call zlog_signal, then _exit.
558 (core_handler) Call zlog_signal, then abort.
559 * log.h: Declare new function zlog_signal.
560 * log.c: (zlog_signal) New function to log information about
561 a received signal before the process dies. Try to log a
562 backtrace also.
563 (quagga_signal_handler,signal_set) Should be static.
564
5652004-11-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
566
ajsd246bd92004-11-23 17:35:08 +0000567 * log.c: (vzlog) Take a single va_list argument and use va_copy
568 as necessary for multiple traversals.
569 (zlog) Pass only one va_list to vzlog.
570 (zlog_*,plog_*) Use a macro for boilerplate code; pass only one
571 va_list to vzlog.
572 (zlog_set_file) Remove unused 2nd argument (flags).
573 (zlog_save_cwd,zlog_get_cwd,zlog_free_cwd) Remove unused functions.
574 * log.h: Remove ZLOG_*_INDEX defines (no longer used).
575 Remove unused 2nd argument from zlog_set_file prototype.
576 Fix prototype for zlog_rotate.
577 * command.c: (config_log_file) Remove unused 2nd arg to zlog_set_file.
578 * vty.c: (vty_out) Fix stdarg usage to perform multiple traversals
579 properly.
580 (vty_log) Must use va_copy for multiple traversals of va_list arg.
581
ajsca359762004-11-19 23:40:16 +00005822004-11-19 David Young <dyoung@pobox.com>
583
584 * log.c: (safe_strerror) New function: safe wrapper for strerror.
585
ajsff29bb32004-11-19 18:29:22 +00005862004-11-19 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
587
588 * sockopt.c: (setsockopt_so_recvbuf) Stop error message from being
589 printed every time.
590
ajsf858e492004-11-16 14:25:30 +00005912004-11-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
592
593 * memory.h: Fix prototype for memory_init().
594 * memory.c: Declare many functions and data structures static instead
595 of global. Fix prototype for memory_init().
596
gdt69e13252004-11-15 18:51:15 +00005972004-11-15 Greg Troxel <gdt@fnord.ir.bbn.com>
598
599 * sockopt.h: Avoid CMSG_ALIGN, and declare that sizes are without
600 alignment (users should use CMSG_SPACE).
601
602 * zebra.h: Rationalize CMSG_SPACE compatibility defines. Warn if
603 asumming 4-byte alignment, since this isn't safe.
604
ajs7fa25ff2004-11-15 16:12:32 +00006052004-11-15 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
606
607 * memory.c: (zerror) Use zlog_err instead of fprintf to stderr.
608 Instead of exiting, log currenty memory usage and then abort.
609 (log_memstats) New function to log memory statistics, called by
610 zerror.
611 (show_memory_all) Loop over new mlists array instead of calling
612 show_memory_vty separately for each memory_list.
613
paulb86718e2004-11-08 17:34:07 +00006142004-11-08 Paul Jakma <paul@dishone.st>
paulb35e5b42004-11-07 22:27:27 +0000615
paul2265d202004-11-08 15:43:21 +0000616 * buffer.c: Add missing include of log.h.
617 (buffer_flush_available) written is compared against
618 mostly against unsigned types, only for the writev do we need
619 signed compare, so declare it as size_t and cast it to ssize_t
620 just for the error compare when we've called writev.
621 * buffer.h: Add comment that buffer data sizes really should be
622 size_t.
623
6242004-11-07 Paul Jakma <paul@dishone.st>
625
626 * version.h.in: add autoconf configure_input output var
paulb35e5b42004-11-07 22:27:27 +0000627
ajs49ff6d92004-11-04 19:26:16 +00006282004-11-04 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
629
ajs5a646652004-11-05 01:25:55 +0000630 * vty.h: Remove fields in struct vty that were related to VTY_CONTINUE
631 capabilities (that were used only in bgpd/bgp_route.c and are now
632 removed). Also remove some other fields that were not being
633 used at all.
634 * vty.c: (vty_execute) Do not test for obsolete status values VTY_START
635 and VTY_CONTINUE.
636 (vty_read) Remove calls to vty->output_func since that was part
637 of the VTY_CONTINUE infrastructure that has been removed.
638 (vty_flush) Remove code to support VTY_START and VTY_CONTINUE.
639 (vty_close) Remove code to cancel vty->t_output thread, since that
640 thread was never actually used.
641
6422004-11-04 Andrew J. Schorr <ajschorr@alumni.princeton.edu>
643
ajs49ff6d92004-11-04 19:26:16 +0000644 * vty.c: Vtysh connections to daemons should use buffering.
645 (vty_out) Remove exception for vty_shell_serv, just use buffer_write.
646 (vty_new) Increase output buffer size to 4096 rounded up to a
647 multiple of pagesize.
648 (vtysh_read) After command has been executed and all output buffered,
649 call buffer_flush_available and schedule further writes if the
650 buffers are not yet empty.
651 (vtysh_write) New function to flush output to vtysh when the socket
652 is writeable.
653 (vty_event) Added new VTYSH_WRITE event for flushing buffers to vtysh
654 clients. Also, should save read thread in vty->t_read so the
655 thread can be cancelled in vty_close.
656 * buffer.h: In struct buffer_data, remove unused "parent" field.
657 Convert "unsigned char *data" to "unsigned char data[0]" to save
658 a malloc. Declare new function buffer_flush_available that works
659 with non-blocking sockets.
660 * buffer.c: (buffer_data_new) Use a single malloc now that data is
661 a variable-size array at end of structure.
662 (buffer_data_free) Just a single free now that data is part of the
663 structure.
664 (buffer_write) Simplify the logic to make behavior more transparent.
665 (buffer_flush) Decrease b->length as data is written out.
666 (buffer_flush_vty_all) Decrease b->length as buffers are freed.
667 (buffer_flush_vty) Decrease b->length as data is written out.
668 (buffer_flush_available) New function to flush non-blocking sockets.
669
paule064d6d2004-11-01 08:59:21 +00006702004-11-01 Paul Jakma <paul@dishone.st>
671
672 * sockopt.c: (setsockopt_pktinfo) remove, its unused.
673
paul75e15fe2004-10-31 02:13:09 +00006742004-10-31 Paul Jakma <paul@dishone.st>
675
676 * vty.c: As per Andrew's suggestions..
677 (vty_serv_un) remove flags.
678 (vtysh_accept) close socket if we cant set NONBLOCK. Add flags.
paul66cbbce2004-10-31 16:15:33 +0000679 * keychain.c: Convert some more strtoul users to VTY_GET_INTEGER.
paul9d11a192004-10-31 16:19:24 +0000680 * memory.h: Add MTYPE_THREAD_FUNCNAME and MTYPE_THREAD_STATS
681 * thread.c: Update stats and funcname alloc/free to use previous
paul039b9572004-10-31 16:43:17 +0000682 specific memory type defines. Use XCALLOC and sizeof the type,
683 not the pointer.
paul70e149e2004-10-31 16:29:50 +0000684 * smux.c: fix int to size_t compile warnings
paul75e15fe2004-10-31 02:13:09 +0000685
pauldccfb192004-10-29 08:29:36 +00006862004-10-29 Paul Jakma <paul@dishone.st>
687
688 * vty.c: Move setting of sock to O_NONBLOCK from vty_serv_un
689 to vtysh_accept, where sock is the actual fd we wanted to set to
690 O_NONBLOCK, ie the /connected/ vtysh unix socket.
691
hasso508ec912004-10-23 14:26:49 +00006922004-10-23 Hasso Tepper <hasso at quagga.net>
693
694 * zclient.c: Unbreak reading interface update message. Might fix
695 blocker bugzilla #109.
696
paul23b9c612004-10-22 11:51:57 +00006972004-10-22 Paul Jakma <paul@dishone.st>
paul7d9c6e52004-10-22 10:54:39 +0000698
699 * sockopt.c: (getsockopt_ipv4_ifindex) no ifindex should be 0, not
paul23b9c612004-10-22 11:51:57 +0000700 -1.
701 (setsockopt_pktinfo) unexported
702 * sockopt.h: Cleanup SOCKOPT_CMSG defines a bit. Add a throwaway
703 define for SOPT_SIZE_CMSG_IFINDEX_IPV4 for systems which have
paul4ccb2c42004-10-22 22:52:33 +0000704 neither IP_RECVIF nor IP_PKTINFO (eg openbsd), thanks to Rivo
705 Nurges for highlighting problem and fix.
paul4927cf02004-10-22 16:55:10 +0000706 Fix elif that should be an else.
paul406d6712004-10-22 12:27:44 +0000707 * command.h: Cleanup the defines a bit, add helper defines and
708 collapse all defines to use those. Add an attribute field to
709 cmd_element to support, eg hidden or deprecated commands, add
710 defun defines for such. All that's left to do is add logic
711 to command.c to check these attributes... ;)
paulaf0d97e2004-10-22 23:24:43 +0000712 * zebra.h: reserve ZEBRA_ROUTE_HSLS
paul7d9c6e52004-10-22 10:54:39 +0000713
hasso6590f2c2004-10-19 20:40:08 +00007142004-10-19 Hasso Tepper <hasso at quagga.net>
715
716 * version.h.in: Define copyright string QUAGGA_COPYRIGHT.
717 * print_version.c: Remove. print_version () function moved to
718 command.[c|h].
719 * command.c: Use QUAGGA_COPYRIGHT.
720 * Makefile.am: Remove useless version.c and print_version.c files.
721
hasso3fb9cd62004-10-19 19:44:43 +00007222004-10-19 Andrew J. Schorr <aschorr@telemetry-investments.com>
723
724 * zclient.c: (zebra_interface_address_read) If the destination address
725 is encoded as all zeroes, load it as a NULL pointer.
726 * if.h: Add comment describing struct connected destination field
727 and indicating that it may be NULL. Define macros
728 CONNECTED_DEST_HOST and CONNECTED_POINTOPOINT_HOST to help
729 with PtP logic (distinguish between host and subnet addressing).
730 * if.c: (if_lookup_address) Fix PtP logic to handle subnet addressing
731 properly,
732 (connected_lookup_address) ditto.
733 (connected_add_by_prefix) Handle case where destination is NULL,
734 * prefix.[c|h]: New functions ipv4_network_addr and
735 ipv4_broadcast_addr.
736
hassoddd85ed2004-10-13 08:18:07 +00007372004-10-13 Hasso Tepper <hasso at quagga.net>
738
739 * command.c: Make CMD_ERR_NOTHING_TODO nonfatal if reading
740 configuration from file. Fixes critical bugzilla #113.
hassoc75105a2004-10-13 10:33:26 +0000741 * smux.c, smux.h: Remove all defaults to initialize smux connection to
742 snmpd by default even if not configured to do so. "smux peer OID
743 <password>" initializes now connection and "no smux peer" terminates
744 it.
hassoddd85ed2004-10-13 08:18:07 +0000745
paul42d49862004-10-13 05:22:18 +00007462004-10-13 Paul Jakma <paul@dishone.st>
747
748 * (global) more const'ification.
749 * sockunion.c: (sockunion_su2str) buffer should be sized
750 SU_ADDRSTRLEN.
751 (sockunion_log) do not return stack variables, strdup buf before
752 return.
753 * vty.h: Fix up the VTY_GET_INTEGER macros. Testing caller supplied
754 values against ULONG_MAX is daft, when caller probably has passed
755 a type that can not hold ULONG_MAX. use a temporary long instead.
756 Add VTY_GET_LONG, make VTY_GET_INTEGER_RANGE use it, make
757 VTY_GET_INTEGER a define for VTY_GET_INTEGER_RANGE.
758
hassoa1494112004-10-11 12:53:17 +00007592004-10-11 Hasso Tepper <hasso at quagga.net>
760
761 * command.h: Sync DEFUNSH with other macros.
762 * sockunion.c, sockunion.h: More const strings.
763
paul9076fbd2004-10-11 09:40:58 +00007642004-10-11 Paul Jakma <paul@dishone.st>
765
766 * thread.c: (funcname_thread_add_timer)
767 (funcname_thread_add_timer_msec) Fix mistakes from last change.
768 Pointed out by Liu Xin in [quagga-dev 1609].
paulc9eca012004-10-11 11:28:44 +0000769 * if.h: mtu's should be unsigned.
770 * routemap.{c,h}: const char updates
771 * smux.{c,h}: ditto
paul9076fbd2004-10-11 09:40:58 +0000772
paul9035efa2004-10-10 11:56:56 +00007732004-10-10 Paul Jakma <paul@dishone.st>
paul47ca2952004-10-10 08:03:18 +0000774
775 * version.h.in: (pid_output*) add const qualifier.
paul9035efa2004-10-10 11:56:56 +0000776 * command.h: Change DEFUN func to take const char *[] rather
777 than char **, to begin process of fixing compile warnings in lib/.
778 Nearly all other changes in this commit follow from this change.
779 * buffer.{c,h}: (buffer_write) pointer-arithmetic is gccism, take
780 const void * and cast an automatic const char *p to it.
781 (buffer_putstr) add const
782 * command.c: (zencrypt) const qualifier
783 (cmd_execute_command_real) ditto
784 (cmd_execute_command_strict) ditto
785 (config_log_file) ditto.
786 Fix leak of getcwd() returned string.
787 * memory.{c,h}: Add MTYPE_DISTRIBUTE_IFNAME for struct dist ifname.
788 * distribute.{c,h}: Update with const qualifier.
789 (distribute_free) use MTYPE_DISTRIBUTE_IFNAME
790 (distribute_lookup) Cast to char *, note that it's ok.
791 (distribute_hash_alloc) use MTYPE_DISTRIBUTE_IFNAME.
792 (distribute_get) Cast to char *, note that it's ok.
793 * filter.c: Update with const qualifier.
794 * if.{c,h}: ditto.
795 * if_rmap.{c,h}: ditto.
796 (if_rmap_lookup) Cast to char *, note that it's ok.
797 (if_rmap_get) ditto.
798 * log.{c,h}: Update with const qualifier.
799 * plist.{c,h}: ditto.
800 * routemap.{c,h}: ditto.
801 * smux.{c,h}: ditto. Fix some signed/unsigned comparisons.
802 * sockopt.c: (getsockopt_cmsg_data) add return for error case.
803 * vty.c: Update with const qualifier.
804
hasso27a43a82004-10-08 06:29:12 +00008052004-10-08 Hasso Tepper <hasso at quagga.net>
806
807 * routemap.c, routemap.h: Make some string arguments const.
808
paul5973ee72004-10-08 01:36:54 +00008092004-10-05 Paul Jakma <paul@dishone.st>
810
811 * version.h.in: print_version declaration is here, not in automake
812 generated version.h.
813
hassoea8e9d92004-10-07 21:32:14 +00008142004-10-08 Hasso Tepper <hasso at quagga.net>
815
816 * command.c, command.h: Make argument of cmd_make_strvec function
817 const.
818 * command.c: Make hostname commands usable in vtysh again.
819
hasso6ad96ea2004-10-07 19:33:46 +00008202004-10-07 Hasso Tepper <hasso at quagga.net>
821
822 * command.c, pid_output.c, print_version.c, vty.c, vty.h: Make more
823 strings const.
824
hasso8c328f12004-10-05 21:01:23 +00008252004-10-05 Hasso Tepper <hasso at quagga.net>
826
827 * *.[c|h]: Make many strings cons and a lot of int -> unsigned int
828 changes to fix warnings.
829
paul96e27c92004-10-05 14:33:43 +00008302004-10-05 Paul Jakma <paul@dishone.st>
831
832 * sockopt.{c,h}: add sockopt_iphdrincl_swab_{htosys,systoh},
833 functions to change byte order between system IP_HDRINCL order
834 and host order.
paul98c91ac2004-10-05 14:57:50 +0000835 * thread.c: (funcname_thread_add_timer_timeval) new function, add
836 timer at specified timeval.
837 (funcname_thread_add_timer) use funcname_thread_add_timer_timeval.
838 (funcname_thread_add_timer_msec) ditto
paul96e27c92004-10-05 14:33:43 +0000839
hassob04c6992004-10-04 19:10:31 +00008402004-10-04 Hasso Tepper <hasso at quagga.net>
841
842 * memory.c, memory.h: Make char * argument of strdup functions const.
843 * prefix.c, prefix.h: Make many arguments const. Reorder stuff in
844 header.
845 * log.h: Make log message const in struct message.
846 * log.c: Fix some indenting.
847 * network.c, network.h: Make second argument of writen() const.
848
hassoe7168df2004-10-03 20:11:32 +00008492004-10-03 Hasso Tepper <hasso at quagga.net>
850
851 * command.h: Introduce SERVICE_NODE for "service <...>" commands.
852 * command.c: Don't initialize commands that don't make sense if vtysh
853 is used.
854 * vty.c: Make VTY_NODE appear in vtysh.
855
hasso18a6dce2004-10-03 18:18:34 +00008562004-10-03 James R. Leu <jleu at mindspring.com>
857
858 * zclient.c, zclient.h: zclient functions for router id handling.
859 * zebra.h: New message types for router id handling.
860
paul9172ee02004-09-27 12:46:37 +00008612004-09-27 Paul Jakma <paul@dishone.st>
862
863 * zebra.h: Add WANT_OSPF_WRITE_FRAGMENT for ospfd
864 to try to fragment oversized packets. Enabled only for Linux.
865 Add HAVE_IP_HDRINCL_BSD_ORDER to define struct ip byte order,
866 to consolidate various ad-hoc platform defines for same thing.
867
hassoe473b032004-09-26 16:08:11 +00008682004-09-26 Hasso Tepper <hasso at quagga.net>
869
870 * vty.c, sockopt.c: Fix compiler warnings.
871
hasso52dc7ee2004-09-23 19:18:23 +00008722004-09-23 Hasso Tepper <hasso at quagga.net>
873
874 * linklist.h: Remove list and listnode typedefs.
875 * *.[c|h]: list -> struct list *, listnode -> struct listnode *.
876
paul0b3acf42004-09-17 08:39:08 +00008772004-09-17 Paul Jakma <paul@dishone.st>
878
paulb89e60c2004-09-21 15:43:13 +0000879 * sockopt.c: Add missing bracket
880
8812004-09-17 Paul Jakma <paul@dishone.st>
882
paul0b3acf42004-09-17 08:39:08 +0000883 * sockopt.{c,h}: Add setsockopt_so_recvbuf, for ripd and ripngd.
884
paul33394762004-09-13 11:27:57 +00008852004-09-13 Paul Jakma <paul@dishone.st>
886
887 * command.c: Update the copyright string in the default motd.
888
gdt630e4802004-08-31 17:28:41 +00008892004-08-31 David Wiggins <dwiggins@bbn.com>
890
891 * hash.c (hash_iterate): Save next pointer before calling
892 procedure, so that iteration works even if the called procedure
893 deletes the hash backet.
894
895 * linklist.h (listtail): new macro, not yet used.
896
hasso34553cc2004-08-27 13:56:39 +00008972004-08-27 Hasso Tepper <hasso at quagga.net>
898
899 * command.c: Install "terminal length" commands only if vty is used.
900 Vtysh will handle it itself.
901
gdtafa43b22004-08-26 13:12:41 +00009022004-08-26 Greg Troxel <gdt@fnord.ir.bbn.com>
903
904 * sockopt.h: Define method-independent macro for callers of
905 get_ifindex to use for cmsg length.
906
paule6822762004-08-19 04:13:29 +00009072004-08-19 Paul Jakma <paul@dishone.st>
908
paulefba6ce2004-08-25 13:47:16 +0000909 * zebra.h: add MAX and MIN defines (eg for ospf6d)
910
9112004-08-19 Paul Jakma <paul@dishone.st>
912
paule6822762004-08-19 04:13:29 +0000913 * sockopt.c: include sockopt.h
914 rename some of the _pktinfo_ functions to _ifindex, where that is
915 their purpose.
916 (getsockopt_ipv6_pktinfo_ifindex) renamed to
917 getsockopt_ipv6_ifindex.
918 (setsockopt_ipv4_pktinfo) renamed to setsockopt_ipv4_ifindex
919 (setsockopt_pktinfo) update with previous and add comment re
920 AF_INET portability.
921 (setsockopt_ifindex) generic ifindex function ala
922 setsockopt_pktinfo.
923 (getsockopt_ipv4_pktinfo_ifindex) renamed to
924 getsockopt_ipv4_ifindex.
925 (getsockopt_ipv4_ifindex) rejiggling to reduce repeated
926 ifdef/elses. pktinfo case forgot to set ifindex.
927 (getsockopt_pktinfo_ifindex) renamed to
928 getsockopt_ifindex. update some calls to renamed functions.
929 * sockopt.h: Update renamed exported functions
930 Rename the CMSG_SIZE macros to IFINDEX.
931 Guard IPv4 PKTINFO in a conditional define.
932
paulc0618de2004-08-18 21:52:58 +00009332004-08-18 Paul Jakma <paul@dishone.st>
934
935 * vty.c: (vty_serv_un) set unix vty socket to nonblocking
936 to prevent inadvertent blocking of daemons by use of
937 vtysh. TODO: disentangle manual paging from the buffer_write
938 path so that unix vty can use this path too and be reliable.
939
gdt33f92322004-07-23 16:14:32 +00009402004-07-23 Greg Troxel <gdt@poblano.ir.bbn.com>
941
942 * sockopt.c (getsockopt_ipv4_pktinfo_ifindex): Make this compile
943 on NetBSD, and add comments to make it less confusing. Change the
944 sense of the SUNOS_5 test to make parallel structure between the
945 variables and the code.
946
paul4f7baa02004-07-23 15:11:07 +00009472004-07-23 Paul Jakma <paul@dishone.st>
948
949 * sockopt.h: Add SOPT_SIZE_CMSG_PKTINFO{_IPV{4,6}} define, for
950 sizeof pktinfo as appropriate, to be used when allocating msg
951 buffers. export setsockopt_pktinfo() and
952 getsockopt_pktinfo_ifindex()
953 * sockopt.c: (setsockopt_pktinfo_ifindex) new function to portably
954 set received ifindex sock option.
955 (getsockopt_pktinfo_ifindex) portably retrieve ifindex.
956 (getsockopt_cmsg_data) retrieve indicated control info from
957 message header.
958 (getsockopt_ipv6_pktinfo_ifindex) ipv6 version of above.
959 (setsockopt_ipv4_pktinfo) v4 version
960 (setsockopt_pktinfo) the exported version
961 (getsockopt_ipv4_pktinfo_ifindex) v4 specific version
962 (getsockopt_pktinfo_ifindex) the exported version
963
paul05c447d2004-07-22 19:14:27 +00009642004-07-14 Paul Jakma <paul@dishone.st>
965
966 * sigevent.c: (quagga_signal_handler) add a global caught flag, set
967 the flags to a constant rather increment to be kinder.
968 (quagga_sigevent_process) new function, to do core of what
969 quagga_signal_timer did. dont block signals at all as sig->caught
970 is volatile sig_atomic_t and should be safe to access from signal
971 and normal contexts. The signal blocking is unneeded paranoia, but
972 is left intact under an ifdef, should some platform require it.
973 Check global caught flag before iterating through array.
974 (quagga_signal_timer) nearly everything moved to
975 quagga_sigevent_process. Left in under ifdef, in case some
976 platform could use a regular timer check for signals.
977 * sigevent.h: quagga_sigevent_process declaration.
978 * thread.c: (thread_fetch) check for signals at beginning of
979 scheduler loop, check for signals if select returns EINTR.
980
gdtb7797132004-07-13 13:47:25 +00009812004-07-13 Greg Troxel <gdt@poblano.ir.bbn.com>
982
983 * sigevent.c: Don't block SIGTRAP and SIGKILL. Blocking SIGTRAP
984 confuses gdb, at least on NetBSD 2.0_BETA, where the block
985 succeeds.
986
paul5510e832004-07-09 14:00:01 +00009872004-07-09 Paul Jakma <paul@dishone.st>
988
989 * Merge Kunihiro's 'show route-map' change and add
990 compatibility aliases for route-map continue
paulb9790b32004-07-09 14:05:47 +0000991 * jhash.{c,h}: New files. Bob Jenkins' public domain hashing
992 function, as implemented in linux kernel by David Miller.
paul5510e832004-07-09 14:00:01 +0000993
paulb06c14f2004-07-09 12:24:42 +00009942004-07-09 Juris Kalnins <juris@mt.lv>
995
996 * if.c: (if_cmp_func) fix for interface names where name is same,
997 but one has no number, eg "devtyp" and "devtyp0".
998
gdt87efd642004-06-30 17:36:11 +00009992004-06-30 Greg Troxel <gdt@poblano.ir.bbn.com>
1000
1001 * Makefile.am: Make libzebra shared.
1002
paul138ce752004-06-21 10:35:59 +000010032004-06-21 Paul Jakma <paul@dishone.st>
1004
1005 * ChangeLog: fix my last update config.h -> zebra.h ;)
1006 * zebra.h: Fix gcc check.
1007
paul02ff83c2004-06-11 11:27:03 +000010082004-06-11 Sowmini Varadhan <sowmini.varadhan@sun.com>
1009
1010 * filter.c: (access_list_remark_cmd) buffer_putstr doesnt need cast
1011 to u_char. (ipv6_access_list_remark_cmd) ditto.
1012 if.c: ditto
1013 * network.c: (readn/writen) pointer arg should be type u_char.
1014 * plist.c: needs to include stream.h, not declare stream functions
1015 internally.
1016 (various) Add static qualifier to internal functions.
1017 (prefix_list_type_str) extraneous breaks in switch statement.
1018 (ip_prefix_list_description_cmd) buffer_putstr doesnt need cast
1019 * stream.h: depends on plist.h and export stream_put_prefix
1020 * vty.c: (vty_<telnet option build functions>) should use
1021 unsigned char, telnet options are 0 -> 255.
1022 * zclient.c: various u_char<->char type cleanups.
1023 * zebra.h: Having to define CMSG_* can apply to more than just
1024 BSDI_NRL.
1025
paul51a87982004-06-09 10:36:05 +000010262004-06-09 Paul Jakma <paul@dishone.st>
1027
paul138ce752004-06-21 10:35:59 +00001028 * zebra.h: __attribute__ is a gcc'ism
paul51a87982004-06-09 10:36:05 +00001029
paul5228ad22004-06-04 17:58:18 +000010302004-06-04 Paul Jakma <paul@dishone.st>
1031
1032 * type mismatch fixes
1033
hasso6708fa32004-05-18 18:46:54 +000010342004-05-18 Hasso Tepper <hasso@estpak.ee>
1035
1036 * pqueue.[c|h]: Added as part of ospf6d merge from Zebra repository.
1037
paul0a589352004-05-08 11:48:26 +000010382004-05-08 Paul Jakma <paul@dishone.st>
1039
1040 * zclient.c (zapi_ipv4_route) Follow Sowmini's lead and describe
1041 message format.
1042
10432004-05-08 Sowmini Varadhan <sowmini.varadhan@sun.com>
1044
1045 * zclient.c: (zapi_ipv4_add) collapsed into zapi_ipv4_route
1046 (zapi_ipv4_delete) ditto.
1047 (zapi_ipv4_route) add/delete a route by way of cmd arg.
1048 (zapi_ipv6_add) collapsed into zapi_ipv6_route.
1049 (zapi_ipv6_delete) ditto.
1050 (zapi_ipv6_route) add/delete a route by way of cmd arg.
1051 (zebra_interface_address_delete_read) collapsed into
1052 zebra_interface_address_read.
1053 (zebra_interface_address_delete_read) ditto.
1054 (zebra_interface_address_read) read address add/delete messages
1055 by way of type argument. Describe command message format.
1056 (zebra_interface_add_read) Unconditionally read new ifmtu6 field.
1057 Describe command message format.
1058 (zebra_interface_state_read) Unconditionally read new ifmtu6 field.
1059 (zclient_redistribute_set) Collapsed into zclient_redistribute
1060 (zclient_redistribute_unset) ditto
1061 (zclient_redistribute) set/unset redistribution.
1062 (zclient_redistribute_default_set) Collapsed into
1063 zclient_redistribute_default.
1064 (zclient_redistribute_default_unset) ditto.
1065 (zclient_redistribute_default) Redistribute default set/unset.
1066 * zclient.h: delete zapi_ipv{4,6}_add, zapi_ipv{4,6}_delete. Add
1067 zapi_ipv{4,6}_route. delete zclient_redistribute_set/unset. Add
1068 zclient_redistribute. Ditto for
1069 zclient_redistribute_default_{set/unset}.
1070
paul4a7aac12004-05-08 05:00:31 +000010712004-05-08 Sowmini Varadhan <sowmini.varadhan@sun.com>
1072
1073 * if.h: Add mtu6 field to struct interface, IPv6 MTU may differ
1074 from IPv4, and Solaris treats the MTU's differently.
1075 Add connected_add_by_prefix, for use by later patch.
1076 * if.c: (connected_add_by_prefix) Add prefix to connected list.
1077 (if_flag_dump) Solaris: Dump IFF_IPv4/6 flag
1078 (if_dump) Dump mtu6 flag, for HAVE_IPV6.
paul22528292004-05-08 05:10:38 +00001079 * command.c: (sockunion_getsockname) use socklen_t for len.
1080 (sockunion_getpeername) ditto.
paul0a589352004-05-08 11:48:26 +00001081
paul31fcdd32004-04-21 11:00:43 +000010822004-04-21 Boris Kovalenko <boris@tagnet.ru>
1083
1084 * daemon.c: (daemon) fix check for error return from setsid
1085
paulc49b3062004-01-19 21:23:37 +000010862004-01-19 Paul Jakma <paul@dishone.st>
1087
1088 * sigevent.{c,h}: New files, implement event handled signals.
1089 see signal_init() in sigevent.h.
1090
jardinc32e1b52003-12-23 09:06:51 +000010912003-12-23 Vincent Jardin <jardin@6wind.com>
1092
1093 * {command.c, memory.c, vty.c, zebra.h}: Add isisd support
1094
gdt3dbf9962003-12-22 20:18:18 +000010952003-12-22 Greg Troxel <gdt@fnord.ir.bbn.com>
1096
1097 * vty.c (vty_use_backup_config): Don't free filenames before using
1098 them for unlink.
1099
paul54aba542003-08-21 20:28:24 +000011002003-08-20 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
1101
1102 * command.c: Fix <cr> display problem for command line
1103 description
1104
paule9af5c72003-05-24 11:54:31 +000011052003-05-24 Anil Madhavapeddy
1106
1107 * (sockunion.c): Incorrect bounds specified in sockunion_log()
1108
paul445f1432003-05-16 19:00:31 +000011092003-05-08 Sergiy Vyshnevetskiy <serg @ vostok.net>
1110
1111 * vty.c: -A option
1112
11132003-04-19 Hasso Tepper <hasso@estpak.ee>
1114
1115 * rip_routemap.c: sync daemon's route-map commands to have same
1116 syntax
1117
paul718e3742002-12-13 20:15:29 +000011182002-09-28 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
1119
1120 * vty.c (vty_flush): One line more on vty.
1121
11222002-09-27 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1123
1124 * vector.c (vector_lookup): Add new function.
1125
11262002-08-19 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1127
1128 * thread.c (timeval_adjust): Fix unconditional crush due to
1129 FreeBSD's select() system call timeval value check.
1130
11312002-07-07 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1132
1133 * zebra-0.93 released.
1134
11352002-06-21 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1136
1137 * if.c (ifc_pointopoint): Add ifc_pointopoint() accoding to Frank
1138 van Maarseveen's suggestion.
1139
11402002-06-18 Kunihiro Ishiguro <kunihiro@zebra.org>
1141
1142 * command.c: Change bcopy() to memcpy().
1143
11442001-12-12 Kunihiro Ishiguro <kunihiro@zebra.org>
1145
1146 * command.c (config_password): Fix host.password clear bug.
1147 Reported by Wang Jian <lark@linux.net.cn>.
1148
11492001-08-29 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1150
1151 * thread.c (thread_should_yield): New function to check thread
1152 should yeild it's execution to other thread. Suggested by: Rick
1153 Payne <rickp@ayrnetworks.com>
1154
11552001-08-20 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1156
1157 * thread.c (thread_timer_cmp): Rewrite function.
1158
1159 * hash.c: Add hash_get(). Change hash_pull() to hash_release().
1160
11612001-08-19 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1162
1163 * zebra-0.92a released.
1164
11652001-08-15 Kunihiro Ishiguro <kunihiro@ipinfusion.com>
1166
1167 * zebra-0.92 released.
1168
11692001-08-12 Akihiro Mizutani <mizutani@dml.com>
1170
1171 * prefix.c (netmask_str2prefix_str): Convert "1.1.0.0 255.255.0.0"
1172 string to "1.1.0.0/16".
1173
11742001-08-10 Kunihiro Ishiguro <kunihiro@zebra.org>
1175
1176 * filter.c (access_list_lookup): access_list_lookup's first
1177 argument is changed from address family to AFI.
1178
1179 * plist.c: (prefix_list_lookup): Likewise.
1180
11812001-07-27 Akihiro Mizutani <mizutani@dml.com>
1182
1183 * plist.c: ge and le display order is changed. Old compatible
1184 rule (len <= ge-value <= le-value) is removed.
1185
11862001-07-08 Kunihiro Ishiguro <kunihiro@zebra.org>
1187
1188 * prefix.h: Temporary fix for alignment of prefix problem.
1189
11902001-06-21 Kunihiro Ishiguro <kunihiro@zebra.org>
1191
1192 * prefix.h (struct prefix): Remove safi and padding field.
1193 (struct prefix_ipv4): Likewise.
1194 (struct prefix_ipv6): Likewise.
1195 (struct prefix_ls): Likewise.
1196 (struct prefix_rd): Likewise.
1197
1198 * command.h (enum node_type): Preparation for BGP new config.
1199
1200 * vty.c (vty_end_config): Likewise.
1201
12022001-06-17 Kunihiro Ishiguro <kunihiro@zebra.org>
1203
1204 * routemap.c (route_map_rule_delete): Call func_free when
1205 route-map rule is deleted.
1206
12072001-06-14 "Akihiro Mizutani" <mizutani@dml.com>
1208
1209 * routemap.c (route_map_index_lookup): Prevent to use deny and
1210 permit for same route-map sequence.
1211
12122001-04-12 Kunihiro Ishiguro <kunihiro@zebra.org>
1213
1214 * vty.c (vty_read_config): Fix warning.
1215
12162001-03-08 Kunihiro Ishiguro <kunihiro@zebra.org>
1217
1218 * command.c (IPV6_PREFIX_STR): Add '.' and '%' for IPv6 address
1219 strings.
1220
12212001-03-07 Kunihiro Ishiguro <kunihiro@zebra.org>
1222
1223 * zebra.h (_XPG4_2): Define _XPG4_2 and __EXTENSIONS__ for
1224 CMSG_FIRSTHDR.
1225
12262001-03-07 Michael Rozhavsky <mrozhavsky@opticalaccess.com>
1227
1228 * zebra.h (struct in_pktinfo): structure in_pktinfo declaration.
1229
12302001-02-19 Kunihiro Ishiguro <kunihiro@zebra.org>
1231
1232 * memory.c (memory_list_lib): Add MTYPE_NEXTHOP for "show memory
1233 lib" member.
1234
12352001-02-13 Matthew Grant <grantma@anathoth.gen.nz>
1236
1237 * vty.c (vty_read_config): Revert check of integrate_default when
1238 VTYSH is defined.
1239
12402001-02-13 Kunihiro Ishiguro <kunihiro@zebra.org>
1241
1242 * vty.c (vty_read_config): Do not check integrate_default. That
1243 should be used only by vtysh.
1244
12452001-02-08 Matthew Grant <grantma@anathoth.gen.nz>
1246
1247 * vty.c (vty_serv_un): Set umask 0077.
1248 (vty_read_config): Stat for vtysh Zebra.conf, if found startup and
1249 wait for boot configuration.
1250
1251 * if.c (if_lookup_address): Make it smart implementation.
1252
1253 * sockopt.c (setsockopt_multicast_ipv4): Set up a multicast socket
1254 options for IPv4 This is here so that people only have to do their
1255 OS multicast mess in one place rather than all through zebra,
1256 ospfd, and ripd .
1257
12582001-02-04 Akihiro Mizutani <mizutani@dml.com>
1259
1260 * plist.c (vty_prefix_list_install): Even when argument is
1261 invalid, new memory is allocated. Now memory allocation is done
1262 after argument check.
1263
12642001-02-01 Kunihiro Ishiguro <kunihiro@zebra.org>
1265
1266 * zebra-0.91 is released.
1267
12682001-01-31 Akihiro Mizutani <mizutani@dml.com>
1269
1270 * vty.c (vty_login): Add vty login command.
1271
12722001-01-31 Kunihiro Ishiguro <kunihiro@zebra.org>
1273
1274 * vty.c (vty_reset): Close accept socket.
1275
12762001-01-30 Kunihiro Ishiguro <kunihiro@zebra.org>
1277
1278 * memory.h (enum): MTYPE_ATTR_TRANSIT is added for unknown transit
1279 attribute.
1280
12812001-01-22 Kunihiro Ishiguro <kunihiro@zebra.org>
1282
1283 * zclient.c (zebra_interface_address_add_read): Fetch interface
1284 address flag.
1285 (zebra_interface_address_delete_read): Likewise.
1286
12872001-01-16 Kunihiro Ishiguro <kunihiro@zebra.org>
1288
1289 * table.c (route_node_match_ipv4): Utility function for IPv4
1290 address lookup.
1291 (route_node_match_ipv6): Utility function for IPv4 address lookup.
1292
12932001-01-15 Kunihiro Ishiguro <kunihiro@zebra.org>
1294
1295 * if.c: Delete RIP_API part until new implementation comes out.
1296
12972001-01-13 Kunihiro Ishiguro <kunihiro@zebra.org>
1298
1299 * hash.h (struct Hash): Rename alloc to count. Change type to
1300 unsigned long.
1301
1302 * stream.c (stream_getc_from): New function.
1303 (stream_getw_from): Likewise.
1304
1305 * zebra.h (ZEBRA_FLAG_STATIC): Add new flag for persistent route.
1306
13072001-01-11 Kunihiro Ishiguro <kunihiro@zebra.org>
1308
1309 * flap.c: File is removed.
1310
1311 * flap.c: Likewise.
1312
1313 * roken.h: Likewise.
1314
1315 * buffer.c (buffer_new): Remove type option to buffer_new().
1316
13172001-01-10 Kunihiro Ishiguro <kunihiro@zebra.org>
1318
1319 * zclient.c (zapi_ipv4_delete): Remove OLD_RIB part.
1320
13212001-01-09 Kunihiro Ishiguro <kunihiro@zebra.org>
1322
1323 * zebra-0.90 is released.
1324
1325 * command.c: Update Copyright year.
1326
13272001-01-09 Matthew Grant <grantma@anathoth.gen.nz>
1328
1329 * if.c (if_create): Register connected_free() function for
1330 deletion.
1331 (if_delete): Free connected information when the interface is
1332 deleted.
1333 (if_lookup_by_index): Fix argument type from int to unsigned int.
1334 (connected_add): Keep list in order if old info found, essential
1335 for repeatable operation in some daemons.
1336
13372001-01-09 endo@suri.co.jp (Masahiko Endo)
1338
1339 * vty.c (vty_flush): When vty->statis is VTY_CLOSE do not add vty
1340 read thread.
1341
13422001-01-08 Kunihiro Ishiguro <kunihiro@zebra.org>
1343
1344 * filter.c (access_list_delete): Access-list name is not freed.
1345
1346 * plist.c (prefix_list_delete): Prefix-list name is not freed.
1347
13482000-12-29 Kunihiro Ishiguro <kunihiro@zebra.org>
1349
1350 * zclient.c (zclient_start): Change to use UNIX domain
1351 socket for zebra communication.
1352
1353 * vector.c (vector_init): vector_alloc and vector_data_alloc is
1354 removed. All memory allocation count should be maintained by
1355 XMALLOC and XFREE macros.
1356
13572000-12-28 Kunihiro Ishiguro <kunihiro@zebra.org>
1358
1359 * zebra.h (ZEBRA_NEXTHOP_IFINDEX): Define ZEBRA_NEXTHOP_* values.
1360
13612000-12-27 Kunihiro Ishiguro <kunihiro@zebra.org>
1362
1363 * zebra.h (ZEBRA_ERR_RTEXIST): Make zebra error code to negative
1364 value.
1365
13662000-12-25 "Wataru Uno" <wataru@po.ntts.co.jp>
1367
1368 * vty.c (vtysh_read): Don't allocate new buffer because buffer is
1369 allocated in vty_new ().
1370
13712000-12-14 Kunihiro Ishiguro <kunihiro@zebra.org>
1372
1373 * memory.h (enum): Add MTYPE_AS_FILTER_STR.
1374
1375 * command.c (config_write_terminal): Display "end" at the end of
1376 configuration.
1377
1378 * plist.c (vty_prefix_list_install): Use AF_INET to determine
1379 lenum length.
1380
13812000-12-13 "Wataru Uno" <wataru@po.ntts.co.jp>
1382
1383 * buffer.c (buffer_flush_vty): If IOV_MAX defined in the System,
1384 then all lines write by IOV_MAX.
1385
13862000-12-12 Michael Rozhavsky <mrozhavsky@opticalaccess.com>
1387
1388 * command.c (config_write_file): Robust method for writing
1389 configuration file and recover from backing up config file.
1390
13912000-11-29 Kunihiro Ishiguro <kunihiro@zebra.org>
1392
1393 * smux.c (smux_connect): More fail check.
1394 (smux_trap): When SMUX connection is not established, do nothing.
1395
13962000-11-28 Gleb Natapov <gleb@nbase.co.il>
1397
1398 * thread.c (thread_fetch): Execut event list first. Old event
1399 list is renamed to ready list. With this change, event thread is
1400 executed before any other thread.
1401
1402 * thread.h (struct thread_master): Add ready list.
1403
14042000-11-28 Kunihiro Ishiguro <kunihiro@zebra.org>
1405
1406 * linklist.c (listnode_add_after): Add node right after the
1407 listnode pointer.
1408
14092000-11-27 Kunihiro Ishiguro <kunihiro@zebra.org>
1410
1411 * smux.h: Pass struct variable to WriteMethod.
1412
14132000-11-25 Frank van Maarseveen <F.vanMaarseveen@inter.NL.net>
1414
1415 * if.c (if_lookup_address): When looking up interface with IP
1416 address, Sometimes multiple interfaces will match. Now PtP
1417 interfaces prevail in such a case which seem the right thing to
1418 do: There will probably also be host routes which usually prevail
1419 over network routes.
1420
14212000-11-25 Kunihiro Ishiguro <kunihiro@zebra.org>
1422
1423 * smux.c (smux_trap): SMUX trap implementation.
1424
14252000-11-19 Akihiro Mizutani <mizutani@dml.com>
1426
1427 * plist.c: Add automatic conversion function of an old rule.
1428 ex.) 10.0.0.0/8 ge 8 -> 10.0.0.0/8 le 32
1429
14302000-11-16 Yon Uriarte <ukl2@rz.uni-karlsruhe.de>
1431
1432 * zclient.c (zebra_interface_add_read): Read hardware address when
1433 hw_addr_len is greater than 0.
1434
14352000-11-15 Akihiro Mizutani <mizutani@dml.com>
1436
1437 * plist.c: The rule of "len <= ge-value <= le-value"
1438 was changed to "len < ge-value <= le-value".
1439
14402000-11-09 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
1441
1442 * memory.[ch]: Added #define and functions for ospf6d.
1443
1444 * log.[ch]: some platform says that the data of used va_list
1445 is undefined. Changed to hold list of va_list for each
1446 vsnprintf.
1447
14482000-11-07 Rick Payne <rickp@rossfell.co.uk>
1449
1450 * memory.h (enum): Add MTYPE_COMMUNITY_REGEXP.
1451
14522000-11-06 Kunihiro Ishiguro <kunihiro@zebra.org>
1453
1454 * command.c (config_exit): Fix bug of missing break after case
1455 BGP_VPNV4_NODE.
1456
14572000-10-30 Kunihiro Ishiguro <kunihiro@zebra.org>
1458
1459 * vector.c (vector_unset): Check i is not nevative.
1460
14612000-10-24 Arkadiusz Miskiewicz <misiek@pld.org.pl>
1462
1463 * smux.c (smux_sock): Set terminating '\0'. Check address family.
1464
1465 * vty.c (vty_serv_sock_addrinfo): Set terminating '\0'. Use
1466 gai_strerror. Check address family.
1467
14682000-10-23 Jochen Friedrich <jochen@scram.de>
1469
1470 * smux.c: Use linklist rather than vector.
1471 (smux_getnext): A SMUX subagent has to behave as if it manages the
1472 whole SNMP MIB tree itself. It's the duty of the master agent to
1473 collect the best answer and return it to the manager. See RFC 1227
1474 chapter 3.1.6 for the glory details :-). ucd-snmp really behaves
1475 bad here as it actually might ask multiple times for the same
1476 GETNEXT request as it throws away the answer when it expects it in
1477 a different subtree and might come back later with the very same
1478 request.
1479
14802000-10-23 Kunihiro Ishiguro <kunihiro@zebra.org>
1481
1482 * command.c (cmd_init): Log related command are only installed for
1483 terminal mode.
1484
14852000-10-21 Kunihiro Ishiguro <kunihiro@zebra.org>
1486
1487 * Makefile.am (libzebra_a_SOURCES): Remove duplicated buffer.c.
1488
1489 * zebra.h: Remove #warn directive.
1490
14912000-10-20 Kunihiro Ishiguro <kunihiro@zebra.org>
1492
1493 * keychain.c (keychain_init): Register "key chain" command to
1494 KEYCHAIN_NODE and KEYCHAIN_KEY_NODE.
1495
1496 * vty.c (vty_end_config): Fix missing vty_cinfig_unlock for other
1497 CONFIG_NODE.
1498
1499 * command.c (config_end): Likewise.
1500
1501 * keychain.c (keychain_get): Key is sorted by it's identifier
1502 value.
1503
15042000-10-19 Kunihiro Ishiguro <kunihiro@zebra.org>
1505
1506 * linklist.c (list_delete_all_node): Call delete function if it is
1507 defined.
1508
1509 * command.c (cmd_execute_command_strict): Add modification for
1510 vtysh.
1511 (cmd_execute_command_strict): Remove first argument cmdvec because
1512 it is global varibale in command.c.
1513
15142000-10-18 Kunihiro Ishiguro <kunihiro@zebra.org>
1515
1516 * command.c (cmd_init): Install
1517 copy_runningconfig_startupconfig_cmd only in terminal mode.
1518
1519 * linklist.c (list_delete_node): Simplify the function.
1520 (listnode_lookup): Renamed from list_lookup_node.
1521
15222000-10-17 Kunihiro Ishiguro <kunihiro@zebra.org>
1523
1524 * stream.h: Undef stream_read and stream_write without
1525 parenthesis.
1526
1527 * newlist.c: File removed.
1528
1529 * newlist.h: Likewise.
1530
1531 * linklist.c (list_new): Remove list_init(). To allocate new
1532 linked list, please use list_new().
1533 (listnode_add): Remove list_add_node(). To add new node to linked
1534 list, please use listnode_add().
1535 (list_delete_by_val): Revemove fucntion.
1536
15372000-10-16 Nobuaki Tanaka <nobby@po.ntts.co.jp>
1538
1539 * table.c (route_table_free): Reimplement route_table_free().
1540
15412000-10-11 Kunihiro Ishiguro <kunihiro@zebra.org>
1542
1543 * keychain.c (keychain_get): Register key_delete_func to key
1544 list's delete function. Use linklist.c instead of newlist.c.
1545
15462000-10-04 Akihiro Mizutani <mizutani@dml.com>
1547
1548 * filter.c (access_list_remark): Add access-list's remark command.
1549 (no_access_list): "no access-list 100 permit any" error message
1550 bug is fixed.
1551
15522000-10-03 Kunihiro Ishiguro <kunihiro@zebra.org>
1553
1554 * memory.h (enum): Add MTYPE_SOCKUNION.
1555
15562000-10-02 Kunihiro Ishiguro <kunihiro@zebra.org>
1557
1558 * zebra-0.89 is released.
1559
15602000-10-01 Kunihiro Ishiguro <kunihiro@zebra.org>
1561
1562 * linklist.c (list_add_node_head): Delete unused function.
1563 (list_add_node_tail): Likewise.
1564
15652000-09-26 Kunihiro Ishiguro <kunihiro@zebra.org>
1566
1567 * stream.c (stream_read_unblock): Add new function for unblocking
1568 read.
1569
15702000-09-26 Jochen Friedrich <jochen@nwe.de>
1571
1572 * smux.c (smux_register): Fix bug of can't register more than one
1573 MIB with SMUX.
1574
15752000-09-26 Makoto Otsuka <otsuka@inl.ntts.co.jp>
1576
1577 * vty.c (vty_close): Fix memory leak of sb_buffer.
1578 (vty_new): Likewise.
1579
15802000-09-21 steve@Watt.COM (Steve Watt)
1581
1582 * log.h: Do not declare zlog_priority[0] variable.
1583
15842000-09-12 Kunihiro Ishiguro <kunihiro@zebra.org>
1585
1586 * linklist.h (struct _list ): Add member cmp for compare function.
1587 (struct _list ): Member up is deleted
1588
15892000-09-12 David Lipovkov <dlipovkov@OpticalAccess.com>
1590
1591 * if.c: Include RIP_API header when RIP API is enabled.
1592
15932000-09-10 Kunihiro Ishiguro <kunihiro@zebra.org>
1594
1595 * prefix.c (prefix_free): Siplify prefix_free().
1596
1597 * keychain.c (key_match_for_accept): strncmp check bug is fixed.
1598
15992000-09-07 Kunihiro Ishiguro <kunihiro@zebra.org>
1600
1601 * zebra.h: Merge roken.h into zebra.h.
1602
16032000-09-05 Akihiro Mizutani <mizutani@dml.com>
1604
1605 * routemap.c (route_map_init_vty): Install route-map command to
1606 RMAP_NODE.
1607
16082000-08-22 Kunihiro Ishiguro <kunihiro@zebra.org>
1609
1610 * thread.c (thread_get_id): Remove pthread related garbage.
1611
1612 * command.h (struct host): Likewise.
1613
1614 * zebra.h: Likewise.
1615
16162000-08-20 Kunihiro Ishiguro <kunihiro@zebra.org>
1617
1618 * command.h (node_type ): Add AAA node for authentication.
1619
1620 * vty.c (vty_close): Do not close stdout.
1621
16222000-08-18 Kunihiro Ishiguro <kunihiro@zebra.org>
1623
1624 * vty.c (vty_init_vtysh): Added for vtysh.
1625
1626 * distribute.c (districute_list_prefix_all): Interface independent
1627 filter can be set.
1628 (distribute_list_all): Likewise.
1629 (config_show_distribute): Display current distribute-list status
1630 for "show ip protocols".
1631
16322000-08-18 Akihiro Mizutani <mizutani@dml.com>
1633
1634 * command.c (config_terminal_no_length): no terminal monitor ->
1635 terminal no monitor
1636 (cmd_init): Do not install service_terminal_length_cmd into
1637 ENABLE_NODE.
1638
1639 * vty.c (terminal_no_monitor): no terminal length -> terminal no
1640 length.
1641
16422000-08-17 Kunihiro Ishiguro <kunihiro@zebra.org>
1643
1644 * zebra-0.88 is released.
1645
16462000-08-17 Magnus Ahltorp <ahltorp@nada.kth.se>
1647
1648 * vty.h (struct vty ): Add iac_sb_in_progress and sb_buffer for
1649 better IAC handling.
1650
1651 * vty.c (vty_telnet_option): Change telnet option handling.
1652
16532000-08-15 Gleb Natapov <gleb@nbase.co.il>
1654
1655 * zclient.c (zclient_redistribute_unset): New function added.
1656
16572000-08-14 Kunihiro Ishiguro <kunihiro@zebra.org>
1658
1659 * zclient.c (zebra_interface_add_read): Change ifindex restore
1660 size from two octet to four.
1661 (zebra_interface_state_read): Likewise.
1662 (zebra_interface_address_add_read): Likewise.
1663
16642000-08-13 Kunihiro Ishiguro <kunihiro@zebra.org>
1665
1666 * vty.c (vty_event): Use vector_set_index() instead of
1667 vector_set().
1668
16692000-08-07 Kunihiro Ishiguro <kunihiro@zebra.org>
1670
1671 * zebra.h (ZEBRA_XXX_DISTANCE_DEFAULT): Define Default
1672 Administrative Distance of each protocol.
1673
16742000-08-07 Matthew Grant <grantma@anathoth.gen.nz>
1675
1676 * if.h (struct interface ): Add new member bandwidth to struct
1677 interface.
1678
1679 * zclient.c (zebra_interface_add_read): Fetch bandwidth value.
1680 (zebra_interface_state_read): Likewise.
1681
16822000-08-07 Gleb Natapov <gleb@nbase.co.il>
1683
1684 * routemap.c (route_map_event_hook): New hook route_map_event_hook
1685 is added. This hook is called when route-map is changed. The
1686 parameters passed to the hook are 'event' and 'route-map name'
1687
1688 * routemap.h: Add prototype for route_map_event_hook().
1689
16902000-08-06 Kunihiro Ishiguro <kunihiro@zebra.org>
1691
1692 * zclient.c (zebra_ipv4_route): zebra_ipv4_route(),
1693 zebra_ipv4_add(), zebra_ipv4_delete() are removed.
1694
1695 * routemap.c (route_map_empty): Add new function.
1696 (route_map_delete): Use route_map_index_delete() instead of
1697 route_map_index_free().
1698 (route_map_index_free): Function removed.
1699
17002000-08-06 Gleb Natapov <gleb@nbase.co.il>
1701
1702 * routemap.c (route_map_index_delete): Add check for route-map is
1703 empty or not.
1704
17052000-08-03 Kunihiro Ishiguro <kunihiro@zebra.org>
1706
1707 * zclient.c (zebra_ipv4_add): Change socket arguemnt with struct
1708 zclient.
1709
17102000-08-02 Kunihiro Ishiguro <kunihiro@zebra.org>
1711
1712 * zclient.h (struct zebra): Add obuf for output buffer.
1713
1714 * if.c: Remove #ifdef NRL enclosing if_nametoindex() and
1715 if_indextoname().
1716
17172000-08-02 David Lipovkov <davidl@nbase.co.il>
1718
1719 * if.h (IF_PSEUDO_UNSET): IF_PSEUDO related macro added.
1720 (IF_UNKNOWN_SET): IF_UNKNOWN related macro deleted.
1721
1722 * if.c (interface_pseudo): Add "pseudo" command to interface node.
1723 (no_interface_pseudo): Add "no pseudo" command to interface node.
1724
1725 * zclient.c (zebra_interface_add_read): Set pseudo flag when it is
1726 send from zebra.
1727
17282000-08-01 Kunihiro Ishiguro <kunihiro@zebra.org>
1729
1730 * zebra.h (ZEBRA_IPV4_NEXTHOP_LOOKUP): Add new message.
1731 (ZEBRA_IPV6_NEXTHOP_LOOKUP): Likewise.
1732
1733 * vty.c (vty_serv_un): Use AF_UNIX for backward compatibility.
1734
17352000-07-31 Kunihiro Ishiguro <kunihiro@zebra.org>
1736
1737 * vty.c: Use vector for VTY server thread listing instead of
1738 single value.
1739
17402000-07-30 Kunihiro Ishiguro <kunihiro@zebra.org>
1741
1742 * keychain.c (no_key_chain): "no key chain WORD" command is added.
1743
17442000-07-29 Kunihiro Ishiguro <kunihiro@zebra.org>
1745
1746 * command.c (config_from_file): If command fail in
1747 KEYCHAIN_KEY_NODE, down to KEYCHAIN_NODE.
1748
1749 * vty.h (struct vty ): Add index_sub member.
1750
17512000-07-27 Akihiro Mizutani <mizutani@dml.com>
1752
1753 * if.c: Help strings updates.
1754
17552000-07-11 Akihiro Mizutani <mizutani@dml.com>
1756
1757 * command.c (no_config_enable_password): Add "no enable password"
1758 command.
1759 (config_write_host): Display password string.
1760
1761 * routemap.c (route_map_delete_match): Add support for delete
1762 match without argument.
1763 (route_map_delete_set): Likewise.
1764
17652000-07-09 Kunihiro Ishiguro <kunihiro@zebra.org>
1766
1767 * command.h (node_type ): Change KEYCHAIN_NODE and
1768 KEYCHAIN_KEY_NODE place just before INTERFACE_NODE.
1769
17702000-07-09 Jochen Friedrich <jochen@scram.de>
1771
1772 * smux.c (config_write_smux): Fixes the option to override OID and
1773 password for SMUX.
1774
17752000-07-09 Kunihiro Ishiguro <kunihiro@zebra.org>
1776
1777 * command.h (node_type ): Add SMUX_NODE for SMUX configuration.
1778
17792000-07-09 Toshiaki Takada <takada@zebra.org>
1780
1781 * command.c: Sort descvec command's help.
1782
1783 * vty.c (vty_describe_command): Display '<cr>' at the end of
1784 descriptions.
1785
17862000-07-05 Toshiaki Takada <takada@zebra.org>
1787
1788 * command.c (cmd_ipv6_match), (cmd_ipv6_prefix_match): Fix bug
1789 treatment of double colon.
1790
17912000-07-04 Kunihiro Ishiguro <kunihiro@zebra.org>
1792
1793 * zclient.h: Add zclient_redistribute_default_{set,unset}().
1794
1795 * keychain.c: New file for authentication key management.
1796 * keychain.h: Likewise.
1797
1798 * tcpfilter.c: New file for TCP/UDP base filtering using ipfw or
1799 ipchains.
1800 * tcpfilter.h: Likewise.
1801
1802 * flap.h: New file for route flap dampening.
1803 * flap.c: Likewise.
1804
18052000-07-04 Toshiaki Takada <takada@zebra.org>
1806
1807 * filter.c (struct filter): Add exact flag.
1808 (access_list): Add exact-match command.
1809 (ipv6_access_list): Add exact-match command.
1810
18112000-07-03 Kunihiro Ishiguro <kunihiro@zebra.org>
1812
1813 * zebra.h (ZEBRA_REDISTRIBUTE_DEFAULT_ADD): New message for
1814 request default route.
1815
18162000-07-01 Hideaki YOSHIFUJI ($B5HF#1QL@(B) <yoshfuji@ecei.tohoku.ac.jp>
1817
1818 * smux.c: Add IPv6 smux connection code.
1819
18202000-06-15 Kunihiro Ishiguro <kunihiro@zebra.org>
1821
1822 * vty.c (vty_complete_command): To cooperate readline library,
1823 returned string is newly allocated. So some match function case
1824 need, free of memory.
1825
18262000-06-12 Akihiro Mizutani <mizutani@dml.com>
1827
1828 * distribute.c: Fix help strings.
1829
18302000-06-11 Kunihiro Ishiguro <kunihiro@zebra.org>
1831
1832 * command.c (cmd_complete_command): Add check for vector_slot
1833 (vline, index) is not NULL when calculating lcd.
1834 (cmd_entry_function): First check variable arguemnt to prevent it
1835 from completion.
1836
18372000-06-10 Kunihiro Ishiguro <kunihiro@zebra.org>
1838
1839 * vty.h (struct vty ): Add output_count member for displaying
1840 output route count. Remove arugment arg from output_func because
1841 the value is passed by vty argument. Change output to output_rn.
1842 Add output_clean function pointer member. Add output_type member.
1843
18442000-06-10 Toshiaki Takada <takada@zebra.org>
1845
1846 * command.c (show_startup_config): Add "show startup-config"
1847 command.
1848
18492000-06-06 Akihiro Mizutani <mizutani@dml.com>
1850
1851 * filter.c: Fix help strings.
1852
18532000-06-05 Kunihiro Ishiguro <kunihiro@zebra.org>
1854
1855 * prefix.h (struct prefix_rd): New prefix structure for routing
1856 distinguisher.
1857 (struct prefix): Add padding to every prefix structure.
1858
1859
1860 * routemap.c (route_map_add_match): When completely same match
1861 statement exists, don't duplicate it.
1862
18632000-06-05 Akihiro Mizutani <mizutani@dml.com>
1864
1865 * routemap.c: Change NAME to WORD.
1866
1867 * plist.c: Fix help strings.
1868
18692000-06-02 Akihiro Mizutani <mizutani@dml.com>
1870
1871 * routemap.c: Fix route-map help strings.
1872
18732000-06-01 Kunihiro Ishiguro <kunihiro@zebra.org>
1874
1875 * command.c (cmd_filter_by_completion): Fix CMD_VARARG treatment
1876 to filter other non vararg commands.
1877
1878 * routemap.c (route_map_init_vty): Use install_default() for
1879 install common commands into route-map node..
1880
18812000-06-01 Akihiro Mizutani <mizutani@dml.com>
1882
1883 * command.h (OSPF_STR): Macro added.
1884
18852000-05-31 Kunihiro Ishiguro <kunihiro@zebra.org>
1886
1887 * command.c (cmd_complete_command): LCD completion must not modify
1888 installed command string.
1889
1890 * plist.c (ipv6_prefix_list): Fix wrong syntax definition. Change
1891 X:X::X:X to X:X::X:X/M.
1892
18932000-05-31 Toshiaki Takada <takada@zebra.org>
1894
1895 * vty.c (show_history): New defun added.
1896
18972000-05-30 Kunihiro Ishiguro <kunihiro@zebra.org>
1898
1899 * command.h (CMD_COMPLETE_LIST_MATCH): New define for completion
1900 list. CMD_COMPLETE_MATCH is used for LCD completion.
1901
1902 * vty.c (vty_complete_command): Matched string's LCD is completed.
1903
1904 * command.c (cmd_lcd): New function for calculate LCD of matched
1905 strings.
1906
19072000-05-26 Kunihiro Ishiguro <kunihiro@zebra.org>
1908
1909 * command.c (install_default): config_write_terminal_cmd,
1910 config_write_file_cmd, config_write_memory_cmd are added to
1911 default node.
1912
1913 * memory.c (memory_init): Divide show memory command into each
1914 sort.
1915
1916 * command.c (cmd_init): config_write_terminal_cmd,
1917 config_write_file_cmd, config_write_memory_cmd are added to
1918 CONFIG_NODE.
1919
1920 * routemap.c (route_map_index_free): New function.
1921 (no_route_map_all): New DEFUN for "no route-map NAME".
1922
1923 * filter.c (no_access_list_all): New DEFUN for delete access-list
1924 with NAME.
1925 (no_ipv6_access_list_all): Likewise.
1926
19272000-05-23 Kunihiro Ishiguro <kunihiro@zebra.org>
1928
1929 * plist.c: Change IPV6_PREFIX to X:X::X:X. When "any" is
1930 specified, user can not use "ge" and "le" statement.
1931
19322000-05-22 Thomas Molkenbur <tmo@datus.datus.com>
1933
1934 * routemap.c (route_map_add_set): Fix bug of next pointer missing.
1935
1936 * table.c (route_table_free): Like wise.
1937
19382000-05-22 Toshiaki Takada <takada@zebra.org>
1939
1940 * vty.c (vty_stop_input): Set history pointer to the latest one.
1941
1942 * vty.c (vty_hist_add): Do not add command line history when input
1943 is as same as previous one.
1944
19452000-05-14 Kunihiro Ishiguro <kunihiro@zebra.org>
1946
1947 * memory.h (enum): Add MTYPE_ECOMMUNITY and MTYPE_ECOMMUNITY_VAL.
1948
19492000-05-13 Kunihiro Ishiguro <kunihiro@zebra.org>
1950
1951 * command.h (node_type ): Add BGP_VPNV4_NODE.
1952
19532000-05-08 Kunihiro Ishiguro <kunihiro@zebra.org>
1954
1955 * vty.c (vtysh_accept): Add cast of struct sockaddr * to bind
1956 argument. Reported by: Vesselin Mladenov <mladenov@netbg.com>.
1957
1958 * filter.c (ipv6_access_list): Add IPv6 prefix example instead of
1959 IPv4 example. Reported by: Love <lha@s3.kth.se>.
1960
1961 * command.c (cmd_complete_command): Make it sure last element of
1962 matchvec is NULL. This fix problem which cause crush in
1963 vty_complete_command(). Reported by: JINMEI Tatuya
1964 <jinmei@isl.rdc.toshiba.co.jp>.
1965
19662000-04-28 Love <lha@s3.kth.se>
1967
1968 * prefix.h (struct prefix): Add padding.
1969
19702000-04-28 Kunihiro Ishiguro <kunihiro@zebra.org>
1971
1972 * command.c (show_version): Update copyright year.
1973
19742000-04-27 Kunihiro Ishiguro <kunihiro@zebra.org>
1975
1976 * routemap.c (route_map_apply): When map is NULL, return deny.
1977
19782000-04-26 Kunihiro Ishiguro <kunihiro@zebra.org>
1979
1980 * filter.c (access_list_apply): When access is NULL, return deny.
1981
1982 * plist.c (prefix_list_apply): When plist is NULL, return deny.
1983
19842000-04-23 Kunihiro Ishiguro <kunihiro@zebra.org>
1985
1986 * command.h (node_type ): Change RDISC_NODE to IRDP_NODE.
1987
19882000-04-18 Toshiaki Takada <takada@zebra.org>
1989
1990 * filter.[ch] (access_list_add_hook), (access_list_delete_hook):
1991 Add argument for hook function to give struct access_list *.
1992
19932000-04-17 Kunihiro Ishiguro <kunihiro@zebra.org>
1994
1995 * plist.c (prefix_list_entry_match): In case of le nor ge is
1996 specified, exact match is performed.
1997 (prefix_list_entry_match): Add any entry matching check.
1998
19992000-04-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2000
2001 * vty.c (exec_timeout): Separate timeout setting to minutes and
2002 seconds.
2003 (no_exec_timeout): Add "no exec-timeout" command.
2004
2005 * vty.h (VTY_TIMEOUT_DEFAULT): Change default value from 300 to
2006 600.
2007
20082000-03-31 Jochen Friedrich <jochen@scram.de>
2009
2010 * smux.h (SMUX_CLOSE): The SMUX_CLOSE PDU is implicit integer, so
2011 it is a primitive encoding and not constructed.
2012
20132000-03-28 Toshiaki Takada <takada@zebra.org>
2014
2015 * memory.[ch] (enum): Add MTYPE_OSPF_EXTERNAL_INFO.
2016
20172000-03-26 Love <lha@s3.kth.se>
2018
2019 * zclient.c (zclient_read): Add nbytes size check for
2020 ZEBRA_HEADER_SIZE. Check return value of steam_read ().
2021
20222000-03-26 Rick Payne <rickp@rossfell.co.uk>
2023
2024 * routemap.c: Add flexible route-map commands such as on-match
2025 next, on-match goto N.
2026
2027 * routemap.h: Likewise
2028
20292000-03-23 Adrian Bool <aid@u.net.uk>
2030
2031 * command.c (config_log_trap): Add new command "log trap
2032 PRIORITY".
2033
20342000-03-14 Toshiaki Takada <takada@zebra.org>
2035
2036 * memory.c (struct memory_list): Add Link List and Link Node
2037 to view.
2038
2039 * memory.h (enum): Remove MTYPE_OSPF_EXTERNAL_ROUTE.
2040
20412000-01-20 Hideto Yamakawa <hideto.yamakawa@soliton.co.jp>
2042
2043 * str.c (snprintf): Fix bug of calling sprintf instead of
2044 vsprintf.
2045
20462000-01-16 Kunihiro Ishiguro <kunihiro@zebra.org>
2047
2048 * memory.h (enum): Add MTYPE_RIP_PEER.
2049
20502000-01-15 Toshiaki Takada <takada@zebra.org>
2051
2052 * memory.h (enum): Add MTYPE_OSPF_CRYPT_KEY.
2053
20542000-01-15 Kunihiro Ishiguro <kunihiro@zebra.org>
2055
2056 * command.h (node_type ): Add MASC_NODE for masc.
2057
20582000-01-09 Wang Jianliang <wangjl@soim.net>
2059
2060 * routemap.c (route_map_index_add): When route_map_index is not
2061 empty and insert new item at the head, it can cause core dump.
2062 Fix "if (index == map->head)" to "if (point == map->head).
2063 (route_map_add_set): If there is an old set command, override old
2064 set command with new one.
2065 (route_map_index_delete): Use while() instead of for for() for
2066 logical correctness.
2067
20681999-12-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2069
2070 * memory.h (enum): Add MTYPE_BGP_STATIC.
2071
20721999-12-23 Alex Zinin <zinin@amt.ru>
2073 * zebra.h, zclient.*: dynamic int up/down message
2074 support
2075
20761999-12-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2077
2078 * thread.c (thread_cancel_event): Add a function for clean up
2079 events.
2080
20811999-12-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2082
2083 * dropline.c: Delete file.
2084 dropline.h: Linewise.
2085
20861999-12-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2087
2088 * filter.c (access_list_filter_delete): Wrong pointer
2089 access->master was pointed out after access is freed. I store
2090 master value at the beginning of the function.
2091
20921999-12-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2093
2094 * vty.c (exec_timeout): Change of VTY timeout affect to current
2095 VTY connection.
2096 (vty_accept): Instead of immediate exit() return -1.
2097
20981999-12-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2099
2100 * vty.c (vty_configure_lock): Configuration lock function added.
2101 Only one VTY can use CONFI_NODE at the same time.
2102
2103 * log.c: Delete zvlog_* functions. Now zlog_* does the same
2104 thing.
2105
2106 * log.c (log_init): Function removed.
2107 (log_close): Likewise.
2108 (log_flush): Likewise.
2109 (log_open): Likewise.
2110
2111 * vty.c (terminal_monitor): Add new command.
2112 (no_terminal_monitor): Likewise.
2113
2114 * log.c (old_log): Function removed.
2115 (old_log2): Likewise.
2116 (old_log_warn): Likewise.
2117
21181999-12-04 Toshiaki Takada <takada@zebra.org>
2119
2120 * command.c (cmd_ipv6_match): New function added.
2121 (cmd_ipv6_prefix_match): Likewise.
2122
21231999-12-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2124
2125 * command.c (cmd_ipv6_match):
2126
2127 * table.c: Delete #ifdef HAVE_MBGPV4.
2128
2129 * prefix.h (struct prefix): Add safi member.
2130 (struct prefix_ipv4): Likewise.
2131 (struct prefix_ipv6): Likewise.
2132
21331999-12-04 Rumen Svobodnikov <rumen@linux.tu-varna.acad.bg>
2134
2135 * memory.c (struct mstat): Revert to support MEMORY_LOG.
2136
21371999-11-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2138
2139 * version.h: Bump up to 0.81c for testing new kernel codes.
2140
21411999-11-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2142
2143 * thread.h (struct thread): Pthread support is disabled all
2144 platform.
2145
21461999-11-21 Michael Handler <handler@sub-rosa.com>
2147
2148 * Include <limits.h> and <strings.h> under SUNOS_5.
2149
21501999-11-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2151
2152 * sockunion.c (in6addr_cmp): Enclosed by #define HAVE_IPV6
21531999-11-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2154
2155 * command.h (node_type ): Add BGP_IPV4_NODE and BGP_IPV6_NODE.
2156
21571999-11-12 Kunihiro Ishiguro <kunihiro@zebra.org>
2158
2159 * command.c (disable): Add `disable' command.
2160
21611999-11-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2162
2163 * plist.c (vty_prefix_list_install): Add any check.
2164
21651999-11-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2166
2167 * command.h (node_type ): Add DUMP_NODE.
2168
21691999-11-03 Kunihiro Ishiguro <kunihiro@zebra.org>
2170
2171 * smux.c: Change default SMUX oid to compatible with gated.
2172
21731999-10-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2174
2175 * if_rmap.c: New file added.
2176
2177 * if_rmap.h: New file added.
2178
21791999-10-29 Alex Zinin <zinin@amt.ru>
2180
2181 * hash.c: add hash_free() function
2182
21831999-10-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2184
2185 * hash.c (hash_clean): Add clean function.
2186
2187 * plist.c (prefix_list_reset): Add reset function.
2188
2189 * filter.c (access_list_reset): Add reset function.
2190
21911999-10-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2192
2193 * client.c: Merged with zclient.c.
2194 * client.h: Merged with zclient.h.
2195
21961999-10-15 Jordan Mendelson <jordy@wserv.com>
2197
2198 * md5.c: Imported from GNU C Library.
2199 * md5-gnu.h: Likewise.
2200
22011999-10-15 Jochen Friedrich <jochen@scram.de>
2202
2203 * smux.c (smux_getresp_send): SMUX_GETRSP codes improvement.
2204
22051999-10-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2206
2207 * smux.h: New file added.
2208
2209 * snmp.c: Rename to smux.c.
2210
22111999-10-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2212
2213 * command.c (cmd_execute_command_strict): Filter ambious commands.
2214 (cmd_filter_by_string): Change to return enum match_type.
2215
22161999-10-01 Toshiaki Takada <takada@zebra.org>
2217
2218 * vty.c (vty_describe_fold): New function which does VTY
2219 description line fold.
2220 * vty.c (vty_describe_command): Set description column.
2221
22221999-09-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2223
2224 * plist.c (prefix_list_init_ipv4): VTY user interface is improved.
2225
22261999-09-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2227
2228 * command.c (cmd_filter_by_string): Fix bug of CMD_IPV4 and
2229 CMD_IPV4_PREFIX check. Both return type must be exact_match.
2230
22311999-09-24 Toshiaki Takada <takada@zebra.org>
2232
2233 * command.c (cmd_filter_by_completion),
2234 (is_cmd_ambiguous): Check IPv4 address, IPv4 prefix and range
2235 parameter matches range.
2236
22371999-09-22 Kunihiro Ishiguro <kunihiro@zebra.org>
2238
2239 * routemap.c (route_map_apply): Returm RM_DENYMATCH when no match
2240 is performed.
2241
22421999-09-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2243
2244 * vty.c (vty_read): Control-C stop VTY_MORE mode.
2245
22461999-09-20 Kunihiro Ishiguro <kunihiro@zebra.org>
2247
2248 * command.h (node_type ): Add ACCESS_IPV6_NODE and
2249 PREFIX_IPV6_NODE.
2250
2251 * distribute.h: New file added.
2252
2253 * command.h (node_type ): Delete DISTRIBUTE_NODE.
2254
22551999-09-18 Kunihiro Ishiguro <kunihiro@zebra.org>
2256
2257 * vty.c (vty_terminate_all): New function added for reload
2258 support.
2259
22601999-09-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2261
2262 * memory.h (enum): Add new type MTYPE_OSPF_EXTERNAL_ROUTE.
2263
22641999-08-31 Janos Farkas <chexum@shadow.banki.hu>
2265
2266 * vty.c (vty_read): Handle also 0x7f (alt-backspace), just like
2267 esc-ctrl-h (delete word backwards).
2268
22691999-08-24 Kunihiro Ishiguro <kunihiro@zebra.org>
2270
2271 * if.h: Add if_nametoindex for NRL.
2272
22731999-08-23 Kunihiro Ishiguro <kunihiro@zebra.org>
2274
2275 * if.c (if_create): New function.
2276
22771999-08-22 Kunihiro Ishiguro <kunihiro@zebra.org>
2278
2279 * snmp.c: New file.
2280
22811999-08-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2282
2283 * stream.c (stream_put): stream_memcpy () is changed to stream_put
2284 (). stream_get () is added.
2285
22861999-08-18 Toshiaki Takada <takada@zebra.org>
2287
2288 * memory.h (enum): Add MTYPE_OSPF_LSA_DATA.
2289
22901999-08-18 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2291
2292 * table.c (route_table_finish): add function frees table.
2293
22941999-08-12 Kunihiro Ishiguro <kunihiro@zebra.org>
2295
2296 * memory.h (enum): Add MTYPE_RTADV_PREFIX.
2297
22981999-08-11 Kunihiro Ishiguro <kunihiro@zebra.org>
2299
2300 * if.h (struct interface ): hw_address, hw_address_len added.
2301
23021999-08-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2303
2304 * if.h (struct interface ): Change structure member if_data to
2305 info, index to ifindex.
2306
23071999-08-08 Rick Payne <rickp@rossfell.co.uk>
2308
2309 * routemap.c: Multi protocol route-map modification.
2310
2311 * routemap.c (route_map_apply): Route match process bug is fixed.
2312
23131999-08-05 Kunihiro Ishiguro <kunihiro@zebra.org>
2314
2315 * thread.c (thread_fetch): When signal comes, goto retry point.
2316
23171999-08-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2318
2319 * Makefile.am: Add sockopt.c and sockopt.h
2320 * sockopt.c: New file.
2321 * sockopt.h: New file.
2322
23231999-08-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2324
2325 * version.h (ZEBRA_VERSION): Release zebra-0.75
2326
23271999-08-01 Kunihiro Ishiguro <kunihiro@zebra.org>
2328
2329 * memory.h (enum): Add MTYPE_RIPNG_AGGREGATE.
2330
23311999-07-31 Kunihiro Ishiguro <kunihiro@zebra.org>
2332
2333 * sockunion.h: Add sockunion_getpeername ().
2334
23351999-07-27 Kunihiro Ishiguro <kunihiro@zebra.org>
2336
2337 * version.h: Release zebra-0.74
2338
23391999-07-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2340
2341 * command.h (struct host): Delete lines from struct host. Add
2342 lines to struct vty.
2343
2344 * command.c: Delete `lines LINES'. Terminal display line settings
2345 should be done by `terminal length' command.
2346
23471999-07-24 Kunihiro Ishiguro <kunihiro@zebra.org>
2348
2349 * memory.h (enum): MTYPE_OSPF_PATH are added.
2350
23511999-07-22 Toshiaki Takada <takada@zebra.org>
2352
2353 * memory.h (enum): MTYPE_OSPF_NEXTHOP is added.
2354
23551999-07-21 Toshiaki Takada <takada@zebra.org>
2356
2357 * linklist.c (list_add_node_prev), (list_add_node_next),
2358 (list_add_list): New function added.
2359
2360 * table.c (route_table_free): New function added.
2361
23621999-07-21 Kunihiro Ishiguro <kunihiro@zebra.org>
2363
2364 * plist.c (config_write_prefix): Set write flag when configuration
2365 is written.
2366
23671999-07-15 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2368
2369 * prefix.c : prefix_cmp() added. change apply_mask() to
2370 apply_mask_ipv4(), and new apply_mask() added.
2371
23721999-07-14 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2373
2374 * prefix.c (prefix2str): append prefixlen.
2375
23761999-07-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2377
2378 * command.c (config_terminal): Change "config terminal" to
2379 "configure terminal". Reported by Georg Hitsch
2380 <georg@atnet.at>.
2381 (config_terminal_length): `terminal length <0-512>' is added. At
2382 this moment this command is only usef for vty interface.
2383 Suggested by Georg Hitsch <georg@atnet.at>.
2384
23851999-07-12 Kunihiro Ishiguro <kunihiro@zebra.org>
2386
2387 * routemap.c (rulecmp): Add wrapper function of strcmp.
2388
23891999-07-08 Rick Payne <rickp@rossfell.co.uk>
2390
2391 * sockunion.c (inet_aton): Fix bug of inet_aton.
2392
23931999-07-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2394
2395 * version.h (ZEBRA_VERSION): Start zebra-0.73
2396
23971999-07-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2398
2399 * version.h: Bump up to 0.72.
2400
24011999-07-05 Kunihiro Ishiguro <kunihiro@zebra.org>
2402
2403 * command.c (install_default): New function for install default
2404 commands to the node.
2405
2406 * memory.h (enum): MTYPE_NEXTHOP is added.
2407
24081999-07-01 <kunihiro@zebra.org>
2409
2410 * command.c (no_banner_motd): `no banner motd' command added.
2411
24121999-06-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2413
2414 * regex.c: Update to glibc-2.1.1's posix/regex.c
2415
2416 * regex-gnu.h: Update to glibc-2.1.1's posix/regex.h
2417
2418 * prefix.h (IPV4_ADDR_SAME): Macro added.
2419 (IPV6_ADDR_SAME): Likewise.
2420
24211999-06-29 Kunihiro Ishiguro <kunihiro@zebra.org>
2422
2423 * memory.h (enum): Add MTYPE_OSPF_VERTEX
2424
2425 * version.h: Bump up to 0.71.
2426
2427 * vty.c (vty_serv_sock_addrinfo): Use addrinfo function to bind
2428 VTY socket when IPv6 is enabled.
2429
24301999-06-28 Kunihiro Ishiguro <kunihiro@zebra.org>
2431
2432 * vty.c (vty_serv_sock): Change vty_serv_sock determine which
2433 address family to bind.
2434
2435 * command.c: Add quit command.
2436
24371999-06-26 NOGUCHI kay <kay@dti.ad.jp>
2438
2439 * vty.c (vty_read_config): Fix bug of configuration file path
2440 detection.
2441
24421999-06-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2443
2444 * version.h: Bump up to 0.70.
2445
24461999-06-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2447
2448 * buffer.h (GETL): Remove GETL macro.
2449
2450 * version.h: Bump up to 0.69.
2451
24521999-06-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2453
2454 * if.c (connected_add): Commented out connected_log.
2455
24561999-06-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2457
2458 * command.h (struct cmd_element ): strvec and descvec is combined
2459 into newstrvec.
2460
2461 * command.c (desc_make): Function removed.
2462 (desc_next): Function removed.
2463
2464 * command.h (struct cmd_element ): docvec is removed from struct
2465 cmd_element.
2466
24671999-06-12 Kunihiro Ishiguro <kunihiro@zebra.org>
2468
2469 * command.c (cmd_execute_command): Remove command NULL check.
2470
2471 * command.h (struct cmd_element ): Add newstrvec entry to struct
2472 cmd_element.
2473 (DEFUN2): DEFUN2 macro is removed. DEFUN is extended to support
2474 (a|b|c) statement.
2475 (DESC): DESC macro is removed.
2476
2477 * vty.c (vty_complete_command): When return value is
2478 CMD_ERR_NO_MATCH, don't display error message.
2479
24801999-06-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2481
2482 * table.c (route_next_until): New function.
2483
2484 * version.h: Bump up to 0.68.
2485
24861999-06-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2487
2488 * vty.c (vty_close): Free vty->buf when vty is closed.
2489
2490 * memory.h (enum): Add MTYPE_COMMUNITY_ENTRY and
2491 MTYPE_COMMUNITY_LIST.
2492
2493 * vty.h (struct vty ): Change buf from static length buffer to
2494 variable length buffer.
2495
2496 * vty.c (vty_ensure): New function added.
2497
24981999-06-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2499
2500 * command.h (node_type ): Add COMMUNITY_LIST_NODE.
2501
2502 * command.c (config_enable_password): Freeing host.enable bug is
2503 fixed.
2504 (config_enable_password): Add argc count check.
2505
25061999-05-31 Kunihiro Ishiguro <kunihiro@zebra.org>
2507
2508 * version.h: Bump up to 0.67.
2509
25101999-05-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2511
2512 * command.c (zencrypt): New function for encrypt password.
2513
2514 * command.h (struct host): Add password_encrypt and
2515 enable_encrypt.
2516
25171999-05-30 Jochen Friedrich <jochen@scram.de>
2518
2519 * command.h (struct host): New member encrypt is added for
2520 encrypted password.
2521
25221999-05-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2523
2524 * vty.c: Remove all_digit_check function. Instead use all_digit.
2525
2526 * prefix.c (all_digit): New function for checking string is made
2527 from digit character.
2528
25291999-05-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2530
2531 * Makefile.am (libzebra_a_SOURCES): Add zclient.c.
2532 (noinst_HEADERS): Add zclient.h
2533
2534 * zclient.[ch]: New file for zebra client routine.
2535
2536 * memory.h (enum): Add MTYPE_ZEBRA.
2537
25381999-05-19 Kunihiro Ishiguro <kunihiro@zebra.org>
2539
2540 * version.h (ZEBRA_VERSION): Update to 0.66.
2541
25421999-05-15 Kunihiro Ishiguro <kunihiro@zebra.org>
2543
2544 * buffer.h (GETC,GETW): Macro deleted.
2545
25461999-05-15 Carlos Alberto Barcenilla <barce@frlp.utn.edu.ar>
2547
2548 * prefix.h (IPV4_NET0, IPV4_NET127): Macro added.
2549
25501999-05-15 Kunihiro Ishiguro <kunihiro@zebra.org>
2551
2552 * vty.c (service_advanced_vty): New command added.
2553 (no_service_advanced_vty): Likewise.
2554
25551999-05-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2556
2557 * vty.c (vty_auth): If advanced flag is set and enable password is
2558 not set, directly login to the ENABLE_NODE. This feature is
2559 originally designed and implemented by Stephen R. van den Berg
2560 <srb@cuci.nl>.
2561
2562 * command.h (host): Add advanced flag to struct host for advanced
2563 vty terminal interface.
2564
2565 * version.h (ZEBRA_VERSION): Update to 0.65 for next beta release.
2566
25671999-05-14 Stephen R. van den Berg <srb@cuci.nl>
2568
2569 * command.h (node_type ): Add TABLE_NODE.
2570
2571 * vty.c (vty_telnet_option): Check host.lines value.
2572
2573 * command.c (config_lines): DEFUN for 'lines LINES' command.
2574
2575 * zebra.h: Include <sys/utsname.h> for uname().
2576 (RT_TABLE_MAIN): Defined as 0 if OS does not support multiple
2577 routing table.
2578
2579 * vty.c (vty_auth): Directly login to the ENABLE_NODE when enable
2580 password is not set.
2581 (vty_prompt): Get machine's hostname when hostname is not set.
2582
25831999-05-11 James Willard <james@whispering.org>
2584
2585 * command.c (config_exit): Close connection when `exit' command is
2586 executed at ENABLE_NODE.
2587
25881999-05-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2589
2590 * vty.c (vty_stop_input): `C-c' key change node to ENABLE_NODE.
2591
2592 * command.c (cmd_execute_command_strict): Matched command size
2593 check added.
2594 (cmd_make_desc_line): New function for DEFUN2.
2595
2596 * command.h (struct cmd_element ): Add descsize.
2597
25981999-05-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2599
2600 * command.h (struct cmd_element ): Remame descvec to docvec.
2601 (struct cmd_element ): Add descvec for new description system.
2602
2603 * command.c (desc_make): Check cmd->descvec.
2604
26051999-05-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2606
2607 * memory.h (enum): Add MTYPE_CLUSTER, MTYPE_CLUSTER_VAL.
2608
26091999-05-05 Kunihiro Ishiguro <kunihiro@zebra.org>
2610
2611 * version.h (ZEBRA_VERSION): Bump up to 0.64 for next beta
2612 release.
2613
26141999-05-04 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2615
2616 * linklist.c (list_delete_all_node): bug fix.
2617 previous code loses current position when node
2618 is deleted.
2619
26201999-05-03 Kunihiro Ishiguro <kunihiro@zebra.org>
2621
2622 * command.h (DESC): Macro added.
2623 (struct cmd_element2): Delete struct cmd_element2.
2624
2625 * plist.c (prefix_list): Sequential number option check is added.
2626
26271999-05-02 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2628
2629 * log.c (zvlog_{debug,info,notice,warn,err}): have been
2630 added. now we can log both console and file, but still
2631 need some fix about config write.
2632
26331999-05-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2634
2635 * log.c (zvlog_debug): Fix yasu's change.
2636
26371999-05-01 Kunihiro Ishiguro <kunihiro@zebra.org>
2638
2639 * plist.c (prefix_list): Fix typo.
2640
26411999-04-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2642
2643 * Set version to 0.63 for first beta package.
2644
26451999-04-27 Carlos Barcenilla <barce@frlp.utn.edu.ar>
2646
2647 * prefix.c (str2prefix_ipv4): Fix prefix length check.
2648 (str2prefix_ipv6): Likewise.
2649
26501999-04-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2651
2652 * memory.h (enum): Add MTPYE_PREFIX_LIST and
2653 MTYPE_PREFIX_LIST_ENTRY.
2654
2655 * command.h (node_type ): Add PREFIX_NODE.
2656
26571999-04-25 Carlos Barcenilla <barce@frlp.utn.edu.ar>
2658
2659 * command.c: ALIAS (config_write_memory_cmd) and ALIAS
2660 (copy_runningconfig_startupconfig_cmd) is added.
2661
2662 * table.c (route_node_lookup): Unused match variable deletion.
2663
26641999-04-24 Kunihiro Ishiguro <kunihiro@zebra.org>
2665
2666 * Makefile.am (libzebra_a_SOURCES): plist.c added.
2667 (noinst_HEADERS): plist.h added.
2668
2669 * plist.c, plist.h: New file added.
2670
2671 * memory.h (enum): Rename MTYPE_AS_PASN to MTYPE_AS_STR.
2672 * memory.c: Likewise.
2673
26741999-04-19 Carlos Alberto Barcenilla <barce@frlp.utn.edu.ar>
2675
2676 * command.c (show_version): `show version' command added.
2677
26781999-04-19 Kunihiro Ishiguro <kunihiro@zebra.org>
2679
2680 * prefix.c (str2prefix_ipv6): Prefix length overflow check.
2681
26821999-04-19 Carlos Alberto Barcenilla <barce@frlp.utn.edu.ar>
2683
2684 * prefix.c (str2prefix_ipv4): Prefix length overflow check.
2685
26861999-04-19 Alex Bligh <amb@gxn.net>
2687
2688 * prefix.c (sockunion2hostprefix): Function added.
2689 (sockunion2prefix): Address family was not set. Now it is set.
2690
2691 * vty.c: VTY access-class command is added.
2692
26931999-04-18 Kunihiro Ishiguro <kunihiro@zebra.org>
2694
2695 * memory.c: Change xmalloc to zmalloc. xcalloc, xrealloc, xfree,
2696 xstrdup are likewise.
2697
26981999-04-18 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2699
2700 * thread.c: Add thread_execute for other routing daemon.
2701 OSPF tasks need to be generated by "sheduled" and "executed".
2702
27031999-04-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2704
2705 * buffer.c: Rewrite buffer_write and buffer_flush related
2706 functions for fixing bugs. Reason of the problem and fix is
2707 suggested by Alex Bligh <amb@gxn.net>.
2708
27091999-04-12 Alex Bligh <amb@gxn.net>
2710
2711 * command.c (cmd_entry_function_descr): Added for variable
2712 argument help display.
2713
27141999-04-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2715
2716 * regex.c, regex-gnu.h: Imported from GNU sed-3.02 distribution.
2717
27181999-03-24 Kunihiro Ishiguro <kunihiro@zebra.org>
2719
2720 * stream.c: stream_fifo_free bug is fixed.
2721
27221999-03-19 Toshiaki Takada <takada@zebra.org>
2723
2724 * stream.c (stream_strncpy): Added for getting any length bytes
2725 from stream.
2726
27271999-03-16 Kunihiro Ishiguro <kunihiro@zebra.org>
2728
2729 * version.h (ZEBRA_BUG_ADDRESS): New macro added.
2730
27311999-03-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2732
2733 * buffer.c (buffer_flush_window): If ep is same as buffer's size
2734 length and lp is overrun one octet.
2735
27361999-03-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2737
2738 * vty.h: add VTY's timeout function.
2739
27401999-03-05 <kunihiro@zebra.org>
2741
2742 * command.h (node_type ): Add OSPF6_node.
2743
27441999-03-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2745
2746 * zebra.h: Check HAVE_SYS_SELECT_H when include <sys/select.h>
2747
27481999-03-03 Jeroen Ruigrok/Asmodai <asmodai@wxs.nl>
2749
2750 * zebra.h: Include <net/if_var.h> if it exists.
2751
27521999-03-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2753
2754 * getopt.[ch],getopt1.c: Sync with glibc-2.1.
2755
2756 * log.c (zlog): Tempolary ZLOG_STDOUT feature added.
2757
2758 * command.h: Include vector.h and vty.h
2759
27601999-02-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2761
2762 * routemap.h (struct route_map_rule_cmd): Add prefix arguemnt.
2763
2764 * routemap.c (route_map_apply_index): Add prefix argument.
2765 (route_map_apply): Likewise.
2766
2767 * memory.h (enum): Add MTYPE_ROUTE_MAP_COMPILED.
2768
2769 * stream.c: Add stream_fifo related functions.
2770
27711999-02-24 Kunihiro Ishiguro <kunihiro@zebra.org>
2772
2773 * daemon.c: Return integer value. File descriptor close is added.
2774
2775 * memory.h (enum): add MTYPE_OSPF_LSA.
2776
27771999-02-23 Kunihiro Ishiguro <kunihiro@zebra.org>
2778
2779 * rsh.c: Remove empty file.
2780
27811999-02-22 <kunihiro@zebra.org>
2782
2783 * routemap.c: Add add/delete hook to route_map_master.
2784
27851999-02-19 Peter Galbavy <Peter.Galbavy@knowledge.com>
2786
2787 * str.[ch] added to supply wrappers for snprintf(), strlcat() and
2788 strlcpy on system without these.
2789
27901999-02-18 Peter Galbavy <Peter.Galbavy@knowledge.com>
2791
2792 * syslog support added
2793
27941999-02-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2795
2796 * filter.c (access_list_add_hook): added for hook function management.
2797 * filter.c (access_list_delete_hook): Likewise.
2798
27991999-01-19 Kunihiro Ishiguro <kunihiro@zebra.org>
2800
2801 * stream.c: New file.
2802 * stream.h: New file.
2803 * Divide stream related fucntions from buffer.[ch] into stream.[ch].
2804
28051999-01-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2806
2807 * memory.h (enum): add MTYPE_STREAM, MTYPE_STREAM_DATA
2808
2809 * buffer.c (stream_new): Set MTYPE_STREAM to XMALLOC argument.
2810
28111998-12-23 Kunihiro Ishiguro <kunihiro@zebra.org>
2812
2813 * routemap.c: route_map_index_delete() added.
2814
28151998-12-22 Kunihiro Ishiguro <kunihiro@zebra.org>
2816
2817 * buffer.c (buffer_empty): check cp instead of sp.
2818
28191998-12-17 Kunihiro Ishiguro <kunihiro@zebra.org>
2820
2821 * radix.[ch]: Deleted.
2822
28231998-12-15 Magnus Ahltorp <map@stacken.kth.se>
2824
2825 * buffer.c: Prototype fixes.
2826 * prefix.c: Likewise.
2827 * sockunion.c: Likewise.
2828 * sockunion.h: Likewise.
2829
28301998-12-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2831
2832 * vty.c (vty_read): DELETE key works as vty_delete_char.
2833
28341998-12-13 Kunihiro Ishiguro <kunihiro@zebra.org>
2835
2836 * log.c (time_print): chane %y to %Y.
2837
28381998-12-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2839
2840 * distribute.c: new file.
2841
28421998-12-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2843
2844 * filter.c: Remove all of struct prefix_{ipv4,ipv6} and add
2845 complete support of IPv6 access list.
2846
2847 * command.c (config_write_element): function delete.
2848 (config_write_host): function add. password and enable password
2849 isn't printed to vty interface.
2850
28511998-12-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2852
2853 * filter.c: Change prefix_ipv4 to prefix and add support of
2854 prefix_ipv6 filtering.
2855
28561998-12-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2857
2858 * Makefile.am (INCLUDES): add @INCLUDES@ for Linux IPv6 inet6-apps
2859 header includes.
2860
28611998-12-05 Kunihiro Ishiguro <kunihiro@zebra.org>
2862
2863 * log.c (log_flush): fix function name typo.
2864
28651998-12-04 Yasuhiro Ohara <yasu@sfc.wide.ad.jp>
2866
2867 * memory.h: OSPF memory type is added.
2868
28691998-11-15 Kunihiro Ishiguro <kunihiro@zebra.org>
2870
2871 * command.c (sort_node): add sort_node() for pretty printing of
2872 command on vty interface.
2873 (config_password): delete the restriction of charaster of password
2874 string.
2875
28761998-09-05 Kunihiro Ishiguro <kunihiro@debian.zebra.org>
2877
2878 * prefix.c (prefix_ipv4_any): add prefix_ipv4_any().
2879
28801998-08-25 Kunihiro Ishiguro <kunihiro@zebra.org>
2881
2882 * network.h: New file.
2883
28841998-08-24 Kunihiro Ishiguro <kunihiro@zebra.org>
2885
2886 * vty.c (vty_will_echo): function name change from vty_off_echo.
2887
28881998-08-18 Kunihiro Ishiguro <kunihiro@zebra.org>
2889
2890 * buffer.h: add PUTC,PUTW,PUTL macros.
2891
28921998-07-22 Kunihiro Ishiguro <kunihiro@zebra.org>
2893
2894 * route.[ch]: renamed to prefix.[ch]
2895
28961998-06-09 Kunihiro Ishiguro <kunihiro@zebra.org>
2897
2898 * prefix_in, prefix_in6 is replaced by prefix_ipv4, prefix_ipv6.
2899
2900 * Makefile.am: @INCLUDES@ is deleted from INCLUDES.
2901
29021998-06-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2903
2904 * host.[ch]: merged with command.[ch]
2905
29061998-05-08 Kunihiro Ishiguro <kunihiro@zebra.org>
2907
2908 * Makefile.am (libzebra_a_SOURCES): add route.c to libzebra_a_SOURCES.
2909
29101998-05-07 Kunihiro Ishiguro <kunihiro@zebra.org>
2911
2912 * route.c (str2prefix): str2prefix () is gone.
2913
29141998-05-03 Kunihiro Ishiguro <kunihiro@zebra.org>
2915
2916 * vty.c (vty_read_config): change CONDIR to SYSCONFDIR.
2917
2918 * .cvsignore: add file.
2919
2920 * memory.c (xerror): add arguent `type' and `size'.
2921
2922 * socket.c: deleted.
2923
29241998-05-02 Kunihiro Ishiguro <kunihiro@zebra.org>
2925
2926 * vector.c: malloc,free,realloc -> XMALLOC,XFREE,XREALLOC.
2927 * linklist.c: same as above.
2928
29291998-04-30 Kunihiro Ishiguro <kunihiro@zebra.org>
2930
2931 * filter.[ch]: added.
2932
29331998-04-01 Kunihiro Ishiguro <kunihiro@zebra.org>
2934
2935 * vty.c (config_who): return CMD_SUCCESS
2936
29371998-04-01 Jochen Friedrich <jochen@scram.de>
2938
2939 * table.c (route_dump_node): route_dump_node is IPv6 specific
2940 function so move #ifdef to the end of route_dump_node ().
2941
29421998-03-05 "Hannes R. Boehm" <hannes@boehm.org>
2943
2944 * if.c: DEFUN(interface_desc) added.
2945
29461998-03-05 Kunihiro Ishiguro <kunihiro@zebra.org>
2947
2948 * if.c: separated from ripd/rip_interface.c
2949
29501998-03-04 Kunihiro Ishiguro <kunihiro@zebra.org>
2951
2952 * thread.[ch] : added.
2953
29541998-02-14 Kunihiro Ishiguro <kunihiro@zebra.org>
2955
2956 * vty.c (vty_delete_char): fix size bug.
2957 (vty_backward_pure_word): function added.
2958 (vty_read): ESC + 'f' perform vty_forward_word.
2959 (vty_read): ESC + 'b' perform vty_backward_word.
2960
29611998-02-11 Kunihiro Ishiguro <kunihiro@zebra.org>
2962
2963 * radix.c (radix_lookup_rt): add mask check.
2964 (radix_delete_duproute): add mask check.
2965
29661998-02-10 Kunihiro Ishiguro <kunihiro@zebra.org>
2967
2968 * command.c (config_write_file): fix vty -> file_vty.
2969
29701998-02-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2971
2972 * command.c (cmd_filter_ambiguous): add complex type treatment.
2973
29741998-02-05 Kunihiro Ishiguro <kunihiro@zebra.org>
2975
2976 * vty.c (vty_time_print): function added.
2977 (vty_complete_command): now [...] element isn't shown by completion.
2978
29791998-01-26 Kunihiro Ishiguro <kunihiro@zebra.org>
2980
2981 * command.c : change from cmd_install_node() to install_node().
2982
29831998-01-16 Kunihiro Ishiguro <kunihiro@zebra.org>
2984
2985 * route.[ch]: struct rt{} is replaced by struct prefix{}.
2986
29871998-01-06 Kunihiro Ishiguro <kunihiro@zebra.org>
2988
2989 * command.c (cmd_execute_command): check command length.
2990
2991 * timer.c (zebra_timer_set): add zebra_timer_set.
2992
29931998-01-05 Kunihiro Ishiguro <kunihiro@zebra.org>
2994
2995 * command.h (node_type ): add ZEBRA_NODE.
2996
2997 * command.c (config_exit): add RIP_NODE.
2998 (config_write_file): add RIP_NODE.
2999
30001998-01-04 Kunihiro Ishiguro <kunihiro@zebra.org>
3001
3002 * print_version.c (print_version): Now Copyright is 1996-1998.
3003
3004 * sockunion.c (sockunion_log): moved from ../zebra/route.c
3005
30061997-12-30 Kunihiro Ishiguro <kunihiro@zebra.org>
3007
3008 * host.c (config_logfile): change 'log PATH' to 'logfile PATH'.
3009
3010 * sockunion.c (sockunion_sameprefix): add same prefix for
3011 sockunion.
3012
30131997-12-29 Kunihiro Ishiguro <kunihiro@zebra.org>
3014
3015 * radix.[ch] : are moved from ../zebra directroy.
3016
3017 * command.c (config_from_file): if command execution failed down
3018 level to CONFIG_NODE.
3019
3020 * host.c: config_log function which enable 'log FILENAME' command.
3021
30221997-12-23 Kunihiro Ishiguro <kunihiro@zebra.org>
3023
3024 * vty.c: add vty_transpose_chars (). Now you can use '^T' to
3025 transpose character.
3026
3027 * command.c: cmd_cmdsize add, this is useful to check incomplete
3028 command.
3029
30301997-12-07 Kunihiro Ishiguro <kunihiro@zebra.org>
3031
3032 * fd.h: add family for address family
3033
30341997-12-06 Kunihiro Ishiguro <kunihiro@zebra.org>
3035
3036 * command.o
3037 * vty.o
3038 * host.o is moved from ../zebra
3039
30401997-08-14 Kunihiro Ishiguro <kunihiro@zebra.org>
3041
3042 * make library directory.
3043