]>
Commit | Line | Data |
---|---|---|
6cf0cf0c PJ |
1 | 2006-03-30 Paul Jakma <paul.jakma@sun.com> |
2 | ||
3 | * command.h: (DEFUN_CMD_FUNC_TEXT) Annotate arguments as | |
4 | potentially being unused. | |
213d8dad | 5 | * workqueue.c: (work_queue_run) fix line length of comment |
6cf0cf0c | 6 | |
d4ce4f68 PJ |
7 | 2006-03-27 Paul Jakma <paul.jakma@sun.com> |
8 | ||
9 | * memtypes.awk: Fix gensub call, g should be a string.. | |
10 | ||
68784535 PJ |
11 | 2006-03-25 Paul Jakma <paul.jakma@sun.com> |
12 | ||
13 | * workqueue.h: (struct work_queue) Remove status field and | |
14 | state flag, no longer used. | |
15 | ||
b51f126e PJ |
16 | 2006-03-19 Paul Jakma <paul.jakma@sun.com> |
17 | ||
18 | * memtypes.c: Add MTYPE_BGP_SYNCHRONISE. | |
19 | ||
cec0c4fb PJ |
20 | 2006-03-16 Paul Jakma <paul.jakma@sun.com> |
21 | ||
22 | * Makefile.am: Fix -version-info argument. | |
23 | ||
41be32bf PJ |
24 | 2006-03-15 Paul Jakma <paul.jakma@sun.com> |
25 | ||
26 | * memory.c: (mtype_memstr) new helper function to | |
27 | return human friendly string for a byte count. | |
28 | (mtype_stats_alloc) new function, for users to retrieve | |
29 | number of objects allocated. | |
30 | (show_memory_mallinfo) New function, show mallinfo statistics | |
31 | if available. | |
32 | (show_memory_all_cmd) Call show_memory_mallinfo, if mallinfo | |
33 | is available. | |
34 | * memory.h: Export mtype_memstr and mtype_stats_alloc. | |
35 | Provide a define for a reasonable buffer size for | |
36 | mtype_memstr. | |
37 | ||
924f9d32 PJ |
38 | 2006-03-14 Paul Jakma <paul.jakma@sun.com> |
39 | ||
40 | * privs.c: (zprivs_caps_init) Change user IDs before lowering | |
41 | privileges, while this seems to work on Linux, on Solaris | |
42 | it rightfully refuses due to PRIV_PROC_SETID having been | |
43 | dropped. | |
86228fde | 44 | * command.h: Add the struct host global exported from command.c |
924f9d32 | 45 | |
478ccfd6 PJ |
46 | 2006-03-06 Paul Jakma <paul.jakma@sun.com> |
47 | ||
48 | * if.h: export show_address_cmd, for anyone who wishes to use | |
49 | it. | |
50 | ||
5a54df97 PJ |
51 | 2006-02-21 Paul Jakma <paul.jakma@sun.com> |
52 | ||
53 | * sockunion.c: (sockunion_{su2str,log}) Use XSTRDUP. | |
54 | Particularly with _su2str, as that string gets XFREEd, | |
55 | which can be annoying if run debug code in memory.c. | |
56 | ||
306d8890 | 57 | 2006-02-02 Paul Jakma <paul.jakma@sun.com> |
58 | ||
59 | * workqueue.h: (struct work_queue) Remove the delay field. | |
60 | It served no purpose and just introduced bad behaviour. | |
61 | Should be excised before its allowed to escape into 1.0. | |
62 | This removes need for the 'flood' and runs_since_clear | |
63 | fields. | |
64 | * workqueue.c: (general) excise delay factor between queue | |
65 | runs, hence the 'flood' crap too.. See above. | |
66 | ||
581a02a9 | 67 | 2006-01-19 Paul Jakma <paul.jakma@sun.com> |
68 | ||
69 | * stream.c: (stream_getq_from) should use POSIX uint64_t | |
70 | not u_int64_t. Latter is neither a traditional BSD type, nor | |
71 | a POSIX type. | |
72 | ||
eac314c7 | 73 | 2006-01-17 Vincent Jardin <vincent.jardin@6wind.com> |
74 | ||
75 | * md5.c: Don't forget to keep const. | |
76 | * regex.c: Cleanup code and remove warnings. | |
77 | ||
7d0b0c4b | 78 | 2006-01-17 Paul Jakma <paul.jakma@sun.com> |
79 | ||
80 | * md5.{c,h}: (md5_loop) Is better off taking a void * and doing | |
81 | cast to byte wise type internally, avoids needs for casts | |
82 | in users. | |
789f78ac | 83 | * vty.c: (no_terminal_monitor_cmd) New ALIAS for |
84 | terminal_no_monitor, in the more normal negating format, | |
85 | to be kind to my fingers. | |
86 | (vty_init) install new ALIAS. | |
d211086a | 87 | * zclient.{c,h}: (zclient_create_header) export this, seems others |
88 | could use it (in lieu of more complete zserv helpers). | |
7d0b0c4b | 89 | |
c1b9800a | 90 | 2006-01-16 Paul Jakma <paul.jakma@sun.com> |
91 | ||
92 | * zclient.h: Update the Zserv protocol header with a version | |
93 | field. Define the old command field to be a 'marker', to | |
94 | allow old Zserv and updated Zserv to be differentiated. | |
95 | Future updates will bump the version field obviously. New | |
96 | command field is made wider. Try to stop using the | |
97 | 'zebra_size_t' typedef in the callbacks. | |
98 | * zclient.c: Update to read/write new format header. | |
99 | ||
c77d4546 | 100 | 2006-01-11 Paul Jakma <paul.jakma@sun.com> |
101 | ||
102 | * if.h: (struct interface) expand flags to 8 bytes. | |
103 | * zclient.c: (zebra_interface_{add,state}_read) stream read of | |
104 | interface flags now need to use stream_getq. | |
105 | (zebra_interface_if_set_value) ditto | |
106 | ||
4b201d46 | 107 | 2006-01-10 Paul Jakma <paul.jakma@sun.com> |
108 | ||
109 | * stream.c: (stream_new) Allocate stream data as seperate object. | |
110 | (stream_free) free the data. | |
111 | (stream_resize) new function, resize stream to new size. | |
112 | (stream_{get,put}q*) new functions to get/put quad word size | |
113 | types. | |
114 | * stream.h: (struct stream) make data seperate from the stream. | |
115 | Export new stream_resize and quad-word get/put functions. | |
116 | ||
f80a016f | 117 | 2005-12-29 Greg Troxel <gdt@fnord.ir.bbn.com> |
118 | ||
119 | * vty.c (vty_hello): add cast to quiet lint (from David Young) | |
120 | ||
00c290e0 | 121 | 2005-11-26 Paul Jakma <paul.jakma@sun.com> |
122 | ||
123 | * buffer.c: (struct buffer_data) change gcc zero array | |
124 | declaration to C99 incomplete array. | |
125 | * stream.h: (struct stream) same | |
126 | ||
6e0f1b94 | 127 | 2005-11-24 Paul Jakma <paul.jakma@sun.com> |
128 | ||
129 | * privs.c: (zcaps2sys/solaris) remove unused variable. | |
130 | (zprivs_state_caps/solaris) Format string missing a | |
131 | specifier. | |
b6026073 | 132 | * zebra.h: s/u_int/unsigned int/, u_int is a BSD type, defining |
133 | __USE_BSD on Linux pulls in further things from netinet/ip.h | |
134 | which dont preprocess for some reason. There is no C99 | |
135 | shorthand type directly equivalent to u_int afaict, so don't | |
136 | use it. | |
6e0f1b94 | 137 | |
889e9311 | 138 | 2005-11-14 Paul Jakma <paul.jakma@sun.com> |
139 | ||
140 | * (general) pass struct work-queue to callback functions. | |
141 | * workqueue.h: (struct work_queue) move the state flag | |
142 | variables to end. | |
143 | Add an opaque pointer to spec, for user-data global to the | |
144 | queue. | |
145 | Pass reference to work_queue to all callbacks. | |
146 | * workqueue.c: (work_queue_item_remove) pass ref to workqueue | |
147 | to user callbacks. | |
148 | (work_queue_run) ditto. | |
149 | ||
190880dc | 150 | 2005-11-14 Paul Jakma <paul.jakma@sun.com> |
151 | ||
152 | * (general) Add state to detect queue floods. There's no sense | |
153 | trying to be sparing of CPU resources, if the queue is | |
154 | flooding and using ever more memory resources. we should just | |
155 | get on with clearing the queue. | |
156 | The sense of delay and hold were wrong way around, fix. | |
157 | * workqueue.h: (struct work_queue) Add status bitfield. Add | |
158 | 'flood' integer to workqueue spec. Add runs_since_clear | |
159 | counter to workqueue. | |
160 | * workqueue.c: (work_queue_new) set defaults for delay, hold | |
161 | and flood. | |
162 | (work_queue_add) initial schedule should use delay, not hold. | |
163 | (show_work_queues) Print flood field, conserve whitespace. | |
164 | (work_queue_unplug) use delay, not hold. | |
165 | (work_queue_run) consecutive runs should be seperated by hold | |
166 | time, not delay. | |
167 | Keep track of number of consecutive runs, go into 'overdrive' | |
168 | if queue is being flooded, we can't avoid making heavy use of | |
169 | resources, better to use CPU than ever more RAM. | |
76367ea9 | 170 | * zebra.h: [bug #231] include stdint, if its there. |
190880dc | 171 | |
172 | 2005-11-05 Paul Jakma <paul.jakma@sun.com> | |
db29ae5f | 173 | |
174 | * routemap.c: (vty_show_route_map_entry) call action is | |
175 | seperate from exit action, latter should still be printed | |
176 | regardless of whether a call is specified. | |
177 | ||
34204aac | 178 | 2005-11-03 Paul Jakma <paul.jakma@sun.com> |
179 | ||
180 | * zebra.h: BSD BYTE_ORDER define isn't available everywhere, | |
181 | define if needs be. | |
182 | * checksum.h: new file. checksum.c exports in_cksum, provide | |
183 | a header for it. | |
184 | * checksum.c: (in_cksum) callers shouldn't have to know it uses | |
185 | a u_short internally, change to void *. | |
186 | * Makefile.am: Add checksum.h | |
187 | * command.h: remove bogus trailling slash. | |
188 | * md5.c: (general) Update it for the twentieth century. ANSI | |
189 | declarations are widely supported now.. Don't include system | |
190 | headers, only include zebra.h. Use POSIX types (the | |
191 | alternative is to define u_int64_t in a portable way - rest | |
192 | of Quagga needs same cleanup). | |
193 | Make endian-conditional code be compiler conditional rather | |
194 | than preprocessor conditional, so that breakage gets noticed | |
195 | quicker. | |
196 | * md5.h: POSIX types. Get rid of the odd __P() non-ANSI capable | |
197 | compiler compatibility hack. | |
9c4f1c6f | 198 | * if.c: (connected_free) use MTYPE for connected label. |
a49ad236 | 199 | * memtypes.c: Add MTYPE_CONNECTED_LABEL |
200 | * memtypes.h: Update auto-built file. | |
34204aac | 201 | |
0241684e | 202 | 2005-10-26 Paul Jakma <paul.jakma@sun.com> |
203 | ||
204 | * (general) Cleanup a some calls to XFREE,strdup, etc. to use | |
205 | the memory.h macros. | |
206 | * memtypes.c: Add MTYPE_IF_RMAP_NAME, MTYPE_PQUEUE, | |
207 | MTYPE_PQUEUE_DATA and MTYPE_HOST. | |
208 | * memtypes.h: update auto-built file. | |
209 | * if_rmap.c: Use MTYPE_IF_RMAP_NAME. | |
210 | * pqueue.c: Use the two MTYPE_PQUEUE mtypes for allocations. | |
05865c90 | 211 | * command.c: Use MTYPE_HOST, MTYPE_STRVEC. Some other fixups, |
212 | including fixing some likely leaks in config_write_file. | |
213 | * vty.c: memory macro usage fixes. | |
214 | (vty_read_config) fix leak where relative config file is | |
215 | specified. | |
0241684e | 216 | |
c188c37c | 217 | 2005-10-20 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
218 | ||
219 | * sockopt.c: (setsockopt_multicast_ipv4) If IP_ADD_MEMBERSHIP | |
220 | fails with errno equal to EADDRINUSE, then issue an info | |
221 | message and try IP_DROP_MEMBERSHIP followed by IP_ADD_MEMBERSHIP. | |
222 | ||
24065a3d | 223 | 2005-10-20 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
224 | ||
225 | * memory.c: (show_memory_vty) Omit zero statistics. Print separators | |
226 | only if some non-zero stats have been printed in between. | |
227 | (show_separator) New function to print a separator. | |
228 | (show_memory_all) Keep track of whether a separator is needed | |
229 | between the different memory statistics groups. | |
230 | ||
5012322d | 231 | 2005-10-18 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
232 | ||
233 | * memtypes.h: Add MTYPE_OSPF_VERTEX_PARENT (to match memtypes.c). | |
234 | ||
eb3da6df | 235 | 2005-10-18 Paul Jakma <paul.jakma@sun.com> |
236 | ||
237 | * memtypes.c: (memory_list_ospf) Add MTYPE_OSPF_VERTEX_PARENT. | |
238 | ||
f52d13cb | 239 | 2005-10-01 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
240 | ||
241 | * zebra.h: Declare new functions zebra_route_string() and | |
242 | zebra_route_char(). | |
243 | * log.c: (zroute_lookup,zebra_route_string,zebra_route_char) New | |
244 | functions to map zebra route numbers to strings. | |
245 | ||
5e4914c3 | 246 | 2005-09-29 Alain Ritoux <alain.ritoux@6wind.com> |
247 | ||
248 | * smux.[ch]: allow to retreive global OID (identified by <0 | |
249 | namelen). | |
250 | ||
ceacedba | 251 | 2005-09-29 Paul Jakma <paul.jakma@sun.com> |
252 | ||
253 | * zebra.h: Solaris capabilities requires priv.h to be included. | |
254 | * privs.{c,h}: Add support for Solaris Least-Privileges. | |
255 | privs.h: Reduce some of the abstract capabilities, which do | |
256 | not have rough equivalents on both systems. Rename the net | |
257 | related caps to _NET, as they should have been in first | |
258 | place. | |
259 | (zprivs_terminate) should take the zebra_privs_t as argument so | |
260 | that it can update change pointer. | |
261 | Add an additional privilege state, ZPRIVS_UNKNOWN. | |
262 | * privs.c: (various capability functions) Add | |
263 | Solaris privileges variants. | |
264 | (zprivs_state) Use privs.c specific generic types to | |
265 | represent various capability/privilege related types, so that | |
266 | each can be typedef'd as appropriate on each platform. | |
267 | (zprivs_null_state) static added, to hold the state the null | |
268 | method should report (should be raised by default, and | |
269 | LOWERED if zprivs_terminate has been called) | |
270 | (zprivs_state_null) Report back the zprivs_null_state. | |
271 | (cap_map) Make it able to map abstract capability to multiple | |
272 | system capabilities. | |
273 | (zcaps2sys) Map to abstract capabilities to multiple system | |
274 | privileges/capabilities. | |
275 | (zprivs_init) move capability related init to seperate | |
276 | function, zprivs_caps_init. | |
277 | (zprivs_terminate) ditto, moved to zprivs_caps_terminate. | |
278 | Set the change_state callback to the NULL state, so the | |
279 | user can continue to run and use the callbacks. | |
280 | ||
fbf5d033 | 281 | 2005-09-29 Alain Ritoux <alain.ritoux@6wind.com> |
282 | ||
283 | * filer.c: show protocol name in filter_show() | |
284 | * plist.c: show protocol name in vty_show_prefix_entry() | |
285 | * routemap.c: show protocol name in vty_show_route_map_entry() | |
286 | * vty.c: in vty_command(), show protocol name if command unknown | |
287 | ||
c1a03d47 | 288 | 2005-09-28 Alain Ritoux <alain.ritoux@6wind.com> |
289 | ||
290 | * md5-gnu.h: removed | |
291 | * md5.h: replaces md5-gnu.h | |
292 | * Makefile.am: use correct md5.h | |
293 | * md5.c: import from WIDE | |
294 | ||
75b2dd02 | 295 | 2005-09-21 Paul Jakma <paul.jakma@sun.com> |
296 | ||
297 | * memtypes.{c,h}: Add MTYPE_AS_SEG_DATA. | |
298 | ||
e6a4feb7 | 299 | 2005-09-19 Hasso Tepper <hasso at quagga.net> |
300 | ||
301 | * str.[ch]: Add strndup() from glibc. | |
302 | ||
eb820afe | 303 | 2005-09-05 Paul Jakma <paul.jakma@sun.com> |
304 | ||
305 | * command.c: (install_element) be more robust. Eg, cmd_init | |
306 | need not have been called, some applications may use other | |
307 | library subsystems, which call install_element, without the | |
308 | application wanting commands and hence not calling cmd_init. | |
309 | ||
1e836590 | 310 | 2005-08-22 Hugo Santos <hsantos@av.it.pt> |
311 | ||
312 | * command.h: (enum node_type) Add BGP_IPV6M_NODE | |
313 | * command.c: (node_parent) Handle BGP_IPV6M_NODE node | |
314 | (config_exit, config_end) ditto | |
315 | * vty.c: (vty_end_config) Handle BGP_IPV6M_NODE node | |
316 | ||
0312f0cd | 317 | 2005-08-10 Greg Troxel <gdt@fnord.ir.bbn.com> |
318 | ||
319 | * getopt.h: Don't declare getopt (rather than getopt_long), since | |
320 | quagga doesn't need it. | |
321 | * getopt.c (getopt): Don't define getopt. | |
322 | ||
7907c6c9 | 323 | 2005-07-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
324 | * prefix.c: (prefix_ipv4_new, prefix_ipv6_new): Call prefix_new | |
325 | to allocate the memory to make sure that all struct prefix pointers | |
326 | point to objects of the same length (avoids memory overruns | |
327 | on struct prefix assignments). | |
328 | (prefix_ipv4_free, prefix_ipv6_free): Simply call prefix_free. | |
329 | It is interesting to note that these functions are never actually | |
330 | called anywhere in the code. Instead prefix_free was already | |
331 | being called directly, despite the previous MTYPE incompatibility. | |
332 | ||
330009f7 | 333 | 2005-07-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
334 | ||
335 | * prefix.c: (ip_masklen) While loop should test that 'pnt' pointer is | |
336 | in range before dereferencing it. | |
337 | ||
510e209d | 338 | 2005-06-24 Pawel Worach <pawel.worach@gmail.com> |
339 | ||
340 | * getopt.h: add further tests for full getopt declaration on | |
341 | various systems. | |
342 | ||
354f3b66 | 343 | 2005-06-18 Paul Jakma <paul.jakma@sun.com> |
344 | ||
345 | * memtypes.h: update autobuilt file to match memtypes.c changes | |
346 | ||
200df115 | 347 | 2005-06-01 Paul Jakma <paul.jakma@sun.com> |
348 | ||
349 | * memtypes.c: Add MTYPE_BGP_PROCESS_QUEUE and | |
350 | MTYPE_BGP_CLEAR_NODE_QUEUE | |
351 | ||
8176c19f | 352 | 2005-05-24 Paul Jakma <paul@dishone.st> |
353 | ||
354 | * memtypes.h: update this auto-built file. (maybe we should just | |
355 | remove it, is GNU awk a terrible dependency to have?) | |
356 | ||
d5c92539 | 357 | 2005-05-23 Paul Jakma <paul@dishone.st> |
358 | ||
359 | * memtypes.awk: use character classes, which work correctly in | |
360 | all LC_COLLATE environments, unlike A-Z, which doesnt work in | |
361 | eg estonian collate order. Reported by Hasso. | |
d4f0960c | 362 | * routemap.c: (rmap_onmatch_goto) fix crash if 'continue' command |
363 | is used, which does not supply an argv[0]. | |
364 | this is a backport candidate /iff/ the trailing ; is removed | |
365 | from VTY_GET_INTEGER_RANGE | |
366 | * vty.h: fix the VTY_GET macros, do {..} while(0) so they have | |
367 | correct function like syntax in usage. | |
269d74fd | 368 | * workqueue.h: Add a WQ_QUEUE_BLOCKED item_status return code, |
369 | to allow a queue function to indicate the queue is not | |
370 | ready/blocked - rather than any problem with the item at hand. | |
371 | Add a notion of being able to 'plug' and 'unplug' a queue. | |
372 | Add helpers to plug/unplug a queue. | |
373 | Add a completion callback, to be called when a queue is emptied. | |
374 | * workqueue.c: (work_queue_new) remove useless list_free. | |
375 | (work_queue_schedule) new internal helper function to schedule | |
376 | queue, if appropriate. | |
377 | (work_queue_add) use work_queue_schedule | |
378 | (show_work_queues) Print 'P' if queue is plugged. | |
379 | (work_queue_plug) new API function, plug a queue - ie prevent it | |
380 | from 'drained' / processed / scheduled. | |
381 | (work_queue_unplug) unplug a queue, allowing it to be drained | |
382 | / scheduled / processed again. | |
383 | (work_queue_run) Add support for WQ_QUEUE_BLOCKED. | |
384 | Add comment for RETRY_NOW case. | |
385 | Make hysteris more aggresive in ramping up granularity, improves | |
386 | performance significantly. | |
387 | Add support for calling completion callback when queue is emptied, | |
388 | possibly useful for knowing when to unplug a queue. | |
d5c92539 | 389 | |
dc81807a | 390 | 2005-05-19 Paul Jakma <paul@dishone.st> |
391 | ||
392 | * thread.c: (thread_cancel_event) the number of pending events | |
393 | cancelled is potentially useful information, dont throw it away, | |
394 | pass it back to the caller. | |
2ba9a37a | 395 | * sockunion.c: (sockunion_getsockname) use MTYPE_SOCKUNION, not TMP |
396 | (sockunion_getpeername) ditto | |
e387e665 | 397 | * memtypes.c: (memory_list_bgp) add MTYPE_BGP_PEER_HOST |
dc81807a | 398 | |
024a7f06 | 399 | 2005-05-15 Paul Jakma <paul@dishone.st> |
400 | ||
401 | * getopt.h: It's not just __GNU_LIBRARY__ which defines | |
402 | getopt, eg __EXTENSIONS__ does too on SunOS. It still seems | |
403 | awfully fragile though. | |
404 | * getopt.c: include zebra.h after config.h, before including | |
405 | getopt.h so that things at least are consistent.. | |
406 | * getopt1.c: ditto | |
407 | ||
42c98199 | 408 | 2005-05-07 Yar Tikhiy <yar@comp.chem.msu.su> |
409 | ||
410 | * sockopt.c: Add support for BSD style ifindex in ip_mreq. | |
411 | ||
8cc4198f | 412 | 2005-05-06 Paul Jakma <paul@dishone.st> |
413 | ||
414 | * (general) extern and static'ification of functions in code and | |
415 | header. | |
416 | Cleanup any definitions with unspecified arguments. | |
417 | Add casts for callback assignments where the callback is defined, | |
418 | typically, as passing void *, but the function being assigned has | |
419 | some other pointer type defined as its argument, as gcc complains | |
420 | about casts from void * to X* via function arguments. | |
421 | Fix some old K&R style function argument definitions. | |
422 | Add noreturn gcc attribute to some functions, as appropriate. | |
423 | Add unused gcc attribute to some functions (eg ones meant to help | |
424 | while debugging) | |
425 | Add guard defines to headers which were missing them. | |
426 | * command.c: (install_node) add const qualifier, still doesnt shut | |
427 | up the warning though, because of the double pointer. | |
428 | (cmp_node) ditto | |
429 | * keychain.c: (key_str2time) Add GET_LONG_RANGE() macro, derived | |
430 | fromn vty.h ones to fix some of the (long) < 0 warnings. | |
431 | * thread.c: (various) use thread_empty | |
432 | (cpu_record_hash_key) should cast to uintptr_t, a stdint.h type | |
433 | * vty.h: Add VTY_GET_IPV4_ADDRESS and VTY_GET_IPV4_PREFIX so they | |
434 | removed from ospfd/ospf_vty.h | |
435 | * zebra.h: Move definition of ZEBRA_PORT to here, to remove | |
436 | dependence of lib on zebra/zserv.h | |
437 | ||
e7fe8c88 | 438 | 2005-05-06 Hasso Tepper <hasso at quagga.net> |
439 | ||
440 | * sockunion.c: Fix warning message. | |
441 | ||
0dab9303 | 442 | 2005-05-03 Paul Jakma <paul@dishone.st> |
443 | ||
444 | * stream.h: Add comment about the special zero-ing ability of | |
445 | stream_put. | |
446 | (stream_recvmsg, stream_write) should return ssize_t and size_t | |
447 | respectively. Should both be extern linkage. | |
448 | (stream_recvfrom) Stream aware wrapper around recvfrom, in style | |
449 | of stream_read_try. | |
450 | * stream.c: (stream_recvfrom) new function, wrapper around recvfrom. | |
451 | (stream_recvmsg, stream_write) ssize_t and size_t return values | |
452 | ||
8b70d0b0 | 453 | 2005-04-27 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
454 | ||
455 | Add wall-clock timing statistics to 'show thread cpu' output. | |
456 | * thread.h: Define struct rusage_t to contain wall-clock time | |
457 | and cpu time. Change GETRUSAGE macro to collect both pieces | |
458 | of data. Make appropriate changes to struct cpu_thread_history | |
459 | to track CPU time and real time. Change proto for | |
460 | thread_consumed_time to return real and cpu time elapsed. | |
461 | And declare a new global variable 'struct timeval recent_time'. | |
462 | * thread.c (struct timeval recent_time): New global timestamp variable. | |
463 | (timeval_adjust): If timeout is negative, set to 0 (not 10 | |
464 | microseconds). And remove upper bound of 1,000,000 seconds, since | |
465 | this does not seem to make any sense (and it breaks | |
466 | funcname_thread_add_timer_timeval). | |
467 | (timeval_cmp): Should return long, not int. | |
468 | (vty_out_cpu_thread_history): Show CPU time and real time. | |
469 | (cpu_record_hash_print): Calculate totals for CPU and real time. | |
470 | (cpu_record_print): Change 'show thread cpu' title to show CPU and | |
471 | real time. | |
472 | (thread_timer_remain_second): Put current time in global recent_time. | |
473 | (funcname_thread_add_timer_timeval): Fix assert. Replace 2-case | |
474 | switch assignment with a ternary expression. Use global recent_time | |
475 | variable. Fix use of timeval_adjust (previously, the value was not | |
476 | actually being adjusted). | |
477 | (thread_cancel): Add missing "break" statement in case | |
478 | THREAD_BACKGROUND. | |
479 | (thread_timer_wait): Use global recent_time value instead of calling | |
480 | gettimeofday. And there's no need to check for negative timeouts, | |
481 | since timeval_subtract already sets these to zero. | |
482 | (thread_timer_process): Timers are sorted, so bail out once we | |
483 | encounter a timer that has not yet popped. And remove some | |
484 | extraneous asserts. | |
485 | (thread_fetch): Do not process foreground timers before calling | |
486 | select. Instead, add them to the ready list just after the select. | |
487 | Also, no need to maintain a count of the number of ready threads, | |
488 | since we don't care how many there are, just whether there's | |
489 | one at the head of the ready list (which is easily checked). | |
490 | Stick current time in global variable recent_time to reduce | |
491 | the number of calls to gettimeofday. Tighten logic for | |
492 | calculating the select timeout. | |
493 | (thread_consumed_time): Now returns real time and puts the elapsed | |
494 | cpu time in an additional argument. | |
495 | (thread_should_yield): Use real (wall-clock) time to decide whether | |
496 | to yield. | |
497 | (thread_call): Maintain CPU and real time statistics. | |
498 | * vty.c (vty_command): For slow commands, show real and cpu time. | |
499 | ||
3df53782 | 500 | 2005-04-27 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
501 | ||
502 | * workqueue.c (show_work_queues): Remove unused gettimeofday call. | |
503 | ||
84369684 | 504 | 2005-04-27 Paul Jakma <paul.jakma@sun.com> |
505 | ||
506 | * workqueue.h: (struct work_queue_item) change retry_count to ran, | |
507 | its a count of number item has been run. | |
508 | * workqueue.c: (show_work_queues) Fix formating of slightly | |
509 | bugfix: fix SIGFPE if wq->runs is 0. | |
510 | (work_queue_run) retry logic was slightly wrong. | |
511 | cycles.best is 0 initialy, granularity is 1, so update best | |
512 | if cycles >= granularity, not just >. | |
a7bca0f5 | 513 | * memory.h: memtypes is built source, default includes points to |
514 | top_builddir, so we should refer to lib/memtypes.h | |
515 | ||
07334da0 | 516 | 2005-04-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
517 | ||
518 | * buffer.c (buffer_write): Comment out call to buffer_flush_available. | |
519 | This should speed up buffering at the expense of a possible increase | |
520 | in latency in flushing the data if inside a long-running thread. | |
521 | ||
ab59ae35 | 522 | 2005-04-25 Paul Jakma <paul.jakma@sun.com> |
523 | ||
147aff0f | 524 | * workqueue.{c,h}: Helper API for setting up and running queues via |
525 | background threads. | |
526 | * command.c: install the 'show workqueues' command | |
527 | * memtypes.c: Add work queue mtypes, and a rib-queue type for | |
528 | a zebra rib work queue. | |
529 | * memtypes.h: Updated to match memtypes.c | |
ab59ae35 | 530 | * Makefile.am: Refer to source files via srcdir variable, fix |
531 | out-of-tree build breakage. | |
147aff0f | 532 | Add new workqueue files to build. |
2c1de2a8 | 533 | * memory.c: Make the string field much wider |
534 | * memtypes.c: Correct the prefix list str/entry strings | |
907873a0 | 535 | * thread.c: Kill unused TIMER_NO_SORT bits |
ab59ae35 | 536 | |
fb9e46bb | 537 | 2005-04-22 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
538 | ||
539 | * thread.h: Fix type for struct thread_master add_type: should be | |
540 | unsigned char. Also, add some documentation of thread_add_background | |
541 | args. And remove extraneous declaration of | |
542 | show_thread_work_queues_cmd. | |
543 | ||
a48b4e6d | 544 | 2005-04-22 Paul Jakma <paul.jakma@sun.com> |
545 | ||
e1e53ed5 | 546 | * memory.h: Move include of memtypes.h to after the definition of |
547 | struct memory_list, gcc 4.0 doesn't like arrays of incomplete | |
548 | types. | |
a48b4e6d | 549 | * thread.h: Add background thread type and thread_add_background |
550 | macro and accompanying funcname_... function. | |
551 | export thread_should_yield, background threads can use it. | |
552 | Lower thread yield time to 10ms, 100ms is noticeable lag and | |
553 | a thread would only be /starting/ to finish sometime afterward. | |
554 | * thread.c: (general) Add background thread type and schedule | |
555 | nearly all thread types through the ready list for fairness. | |
556 | (timeval_adjust) static qualifier missing | |
557 | (vty_out_cpu_thread_history) add support for printout of | |
558 | background threads | |
559 | (show_thread_cpu) ditto. | |
560 | (thread_master_debug) add debug of background list | |
561 | (thread_master_create) fixup long line | |
562 | (thread_add_unuse) add asserts for required state. | |
563 | (thread_master_free) free background thread list | |
564 | (funcname_thread_add_timer_timeval) make generic, able to | |
565 | support arbitrary timer-like thread types. | |
566 | (funcname_thread_add_timer) pass thread type to .._add_timer_timeval | |
567 | (funcname_thread_add_timer_msec) ditto | |
568 | (funcname_thread_add_background) Add a background thread, with an | |
569 | optional millisecond delay factor, using .._add_timer_timeval. | |
570 | (thread_cancel) Add background thread type. | |
571 | Move the thread_list_delete common to all cases to bottom of | |
572 | function, after the switch statement.. | |
573 | (thread_cancel_event) indent | |
574 | (thread_timer_wait) Static qualifier, and make it able to cope | |
575 | with arbitrary timer-like thread lists, so its of use to | |
576 | background threads too. | |
577 | (thread_process_fd) static qualifier. Again, make it take a list | |
578 | reference rather than thread_master. Fix indentation. | |
579 | (thread_timer_process) Check for ready timer-like threads in the | |
580 | given list and move them on to the ready list - code originally | |
581 | embedded in thread_fetch. | |
582 | (thread_fetch) Schedule all threads, other than events, through | |
583 | the ready list, to ensure fairness. Timer readying code moved to | |
584 | thread_timer_process so it can be reused for background threads. | |
585 | Remove the unneeded quagga_sigevent_process, as pointed out by | |
586 | John Lin <john.ch.lin@gmail.com>. | |
587 | (thread_should_yield) make this available. | |
588 | ||
924b9229 | 589 | 2005-04-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
590 | ||
591 | * thread.h (thread_consumed_time): Declare new function to calculate | |
592 | elapsed microseconds. | |
593 | * thread.c (thread_consumed_time): Must be global not static so we | |
594 | can call it from lib/vty.c:vty_command. | |
595 | (thread_should_yield): Surround with `#if 0' to make clear that this | |
596 | function is not currently being used anywhere. | |
597 | (thread_call): If CONSUMED_TIME_CHECK is defined, print a CPU HOG | |
598 | warning message if the thread takes more than CONSUMED_TIME_CHECK | |
599 | microseconds. | |
600 | * vty.c (vty_command): If CONSUMED_TIME_CHECK is defined, print a CPU | |
601 | HOG warning message if the command takes more than CONSUMED_TIME_CHECK | |
602 | microseconds. | |
603 | ||
dc830cbf | 604 | 2005-04-16 Paul Jakma <paul@dishone.st> |
605 | ||
606 | * memtypes.c: the comment about use of comments in the comments | |
607 | headers was causing comment within comment warnings from compiler | |
608 | * memtypes.awk: Add extensive comments on the file format for | |
609 | memtypes.c. | |
610 | tighten the pattern for the MTYPE matching action (suggestion from | |
611 | Andrew) and tighten which field we try the match on. | |
612 | ||
2fd2fd5d | 613 | 2005-04-15 Paul Jakma <paul@dishone.st> |
614 | ||
615 | * memtypes.c: The new, unified location for memory type definitions. | |
616 | The memtype enum and declarations for memory_lists are built from | |
617 | this automatically and put into memtypes.h. | |
618 | * memtypes.awk: New script to generate memtypes.h from memtypes.c | |
619 | * memory.h: Finally, the enum can banished! | |
620 | * memory.c: Finally, the seperate mtype memory_list definitions can | |
621 | be banished! | |
622 | (log_memstats) Increase width of fields | |
623 | (show_memory_zebra_cmd) display zebra specific memory types. | |
624 | Increase width of fields. | |
625 | * Makefile.am: Add memtypes.{c,h}, add BUILT_SOURCES for memtypes.h | |
626 | Add a rule to build memtypes.h using memtypes.awk. | |
627 | Add memtypes.awk to EXTRA_DIST. | |
d45f1f1c | 628 | memtypes.awk is gawk dependent, use the GAWK automake var. |
629 | * memtypes.h: New file, auto-generated, checked in for convenience. | |
2fd2fd5d | 630 | |
634f9ea2 | 631 | 2005-04-11 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
632 | ||
633 | * zclient.h (struct zclient): Add two fields to support non-blocking | |
634 | I/O: struct buffer *wb, and struct thread *t_write. | |
635 | (zclient_free): Remove function. | |
636 | (zebra_redistribute_send): Change 2nd arg from socket fd to | |
637 | struct zclient * (needed to support non-blocking I/O and buffering). | |
638 | (zclient_send_message): New function to send an arbitrary | |
639 | message with non-blocking I/O. | |
640 | * zclient.c (zclient_new): Create write buffer. | |
641 | (zclient_free): Remove unused function. | |
642 | (zclient_stop): Must cancel new t_write thread. Also, reset | |
643 | all buffers: ibuf, obuf, and wb. | |
644 | (zclient_failed): New helper function for typical error handling. | |
645 | (zclient_flush_data): New thread to flush queued data. | |
646 | (zclient_send_message): New function to send the message in | |
647 | zclient->obuf to zebra using non-blocking I/O and buffering. | |
648 | (zebra_message_send, zapi_ipv4_route, zapi_ipv6_route): Use | |
649 | new zclient_send_message function instead of calling writen. | |
650 | (zclient_start): Set socket non-blocking. Also, change 2nd arg | |
651 | to zebra_redistribute_send from zclient->sock to zclient. | |
652 | (zebra_redistribute_send): Change 2nd arg to struct zclient *. | |
653 | Can now use zclient->obuf to assemble the message instead of | |
654 | allocating a temporary stream. And call zclient_send_message to | |
655 | send the message instead of writen. | |
656 | (zclient_read): Convert to support non-blocking I/O by using | |
657 | stream_read_try instead of deprecated stream_read. | |
658 | (zclient_redistribute): Change 2nd arg to zebra_redistribute_send | |
659 | from zclient->sock to zclient. | |
660 | ||
5bb4c198 | 661 | 2005-04-09 Jeroen Simonetti <jeroens@office.netland.nl> |
662 | ||
663 | * routemap.c: Show description in "show route-map" output. | |
664 | ||
67bf16c0 | 665 | 2005-04-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
666 | ||
667 | * sigevent.c: On GNU_LINUX, check whether __USE_GNU is already defined. | |
668 | ||
926fe8f1 | 669 | 2005-04-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
670 | ||
671 | * vty.c: (vty_log_fixed) Use casts to (void *) to try to eliminate | |
672 | compiler warnings when assigning a (const char *) value to | |
673 | struct iovec iov_base. | |
674 | ||
d66a7b56 | 675 | 2005-04-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
676 | ||
677 | * zebra.h: If GNU_LINUX is defined, then define _GNU_SOURCE. This | |
678 | fixes a problem where we were not getting the declaration of strnlen | |
679 | in <string.h>. | |
680 | ||
4a8164e5 | 681 | 2005-04-08 Hasso Tepper <hasso at quagga.net> |
682 | ||
683 | * routemap.[ch]: Added "description ..." command. | |
684 | ||
3a2ce6a1 | 685 | 2005-04-08 Hasso Tepper <hasso at quagga.net> |
686 | ||
687 | * prefix.[hc]: Pass argument to the inet6_ntoa by value making it more | |
688 | inet_ntoa alike. | |
689 | ||
1eb8ef25 | 690 | 2005-04-07 Paul Jakma <paul.jakma@sun.com> |
691 | ||
692 | * linklist.h: Add usage comments. | |
693 | Rename getdata macro to listgetdata. | |
694 | Rename nextnode to listnextnode and fix its odd behaviour to be | |
695 | less dangerous. | |
696 | Make listgetdata macro assert node is not null, NULL list entries | |
697 | should be bug condition. | |
698 | ALL_LIST_ELEMENTS, new macro, forward-referencing macro for use | |
699 | with for loop, Suggested by Jim Carlson of Sun. | |
700 | Add ALL_LIST_ELEMENTS_RO for cases which obviously do not need the | |
701 | "safety" of previous macro. | |
702 | LISTNODE_ADD and DELETE macros renamed to ATTACH, DETACH, to | |
703 | distinguish from the similarly named functions, and reflect their | |
704 | effect better. | |
705 | Add a QUAGGA_NO_DEPRECATED_INTERFACES define guarded section | |
706 | with the old defines which were modified above, | |
707 | for backwards compatibility - guarded to prevent Quagga using it.. | |
708 | * linklist.c: fix up for linklist.h changes. | |
709 | * *.c: fix up for new list loop macro, try audit other loop | |
710 | usage at same time, to some degree. | |
711 | ||
5920990f | 712 | 2004-04-05 Hasso Tepper <hasso at quagga.net> |
713 | ||
714 | * lib/prefix.[hc]: inet6_ntoa utility function copied from | |
715 | ripngd/ripngd.c (inet6_ntop). | |
716 | ||
3d1dc857 | 717 | 2004-04-05 Paul Jakma <paul@dishone.st> |
718 | ||
719 | * vty.c: Improve logging of failures to open vty socket(s). | |
720 | See bugid #163. | |
721 | ||
08dbfb69 | 722 | 2005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
723 | ||
724 | * if.h: Fix comments to reflect that if_lookup_by_name and | |
725 | if_get_by_name now require the argument strings to be NUL-terminated. | |
726 | * if.c: (if_lookup_by_name) Compare using strcmp. | |
727 | (if_get_by_name) Pass strlen(ifname) as 2nd arg to if_create. | |
728 | ||
018546e9 | 729 | 2005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
730 | ||
731 | * if.c: (if_nametoindex) The man page is rather vague, but it seems | |
732 | like the argument to if_nametoindex has an implicit maximum length | |
733 | of IFNAMSIZ characters. | |
734 | ||
a349198f | 735 | 2005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
736 | ||
737 | * if.h: (if_lookup_by_name_len, if_get_by_name_len) New functions. | |
738 | * if.c: (if_lookup_by_name_len, if_get_by_name_len) New functions. | |
739 | (if_get_by_name) Tighten up code. | |
740 | (interface) Use new function if_get_by_name_len. | |
741 | * zclient.c: (zebra_interface_add_read) Use new if_get_by_name_len | |
742 | function. | |
743 | (zebra_interface_state_read) Use new if_lookup_by_name_len function. | |
744 | ||
851adbd9 | 745 | 2005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
746 | ||
747 | * str.c: Replace strlcpy and strlcat with actual working versions | |
748 | copied from rsync-2.6.2/lib/compat.c. | |
749 | ||
d2fc8896 | 750 | 2005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
751 | ||
752 | * if.h: Remove define for IFINDEX_INTERNBASE and add define | |
753 | IFINDEX_INTERNAL 0, since all internal (i.e. non-kernel) pseudo- | |
754 | interfaces should have ifindex set to 0. | |
755 | (if_new) Remove function. | |
756 | (if_delete_retain) New function to delete an interface without | |
757 | removing from iflist and freeing the structure. | |
758 | (ifname2ifindex) New function. | |
759 | * if.c: (if_new) Remove function (absorb into if_create). | |
760 | (if_create) Replace function if_new with call to calloc. | |
761 | Set ifp->ifindex to IFINDEX_INTERNAL. Fix off-by-one error | |
762 | in assert to check length of interface name. Add error message | |
763 | if interface with this name already exists. | |
764 | (if_delete_retain) New function to delete an interface without | |
765 | removing from iflist and freeing the structure. | |
766 | (if_delete) Implement with help of if_delete_retain. | |
767 | (ifindex2ifname) Reimplement using if_lookup_by_index. | |
768 | (ifname2ifindex) New function to complement ifindex2ifname. | |
769 | (interface) The interface command should check the name length | |
770 | and fail with a warning message if it is too long. | |
771 | (no_interface) Fix spelling in warning message. | |
772 | (if_nametoindex) Reimplement using if_lookup_by_name. | |
773 | (if_indextoname, ifaddr_ipv4_lookup) Reimplement using | |
774 | if_lookup_by_index. | |
775 | ||
3cb98dee | 776 | 2005-04-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
777 | ||
778 | * zebra.h: Should include str.h to pick up missing functions. | |
779 | * str.h: Declare strnlen if needed. | |
780 | * str.c: Do not include str.h since zebra.h now includes it. | |
781 | (strnlen) New function. | |
782 | ||
db8eaac6 | 783 | 2005-03-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
784 | ||
785 | * zebra.h: Must check whether __attribute__ should be defined before | |
786 | including zassert.h. | |
787 | ||
b8961476 | 788 | 2005-03-14 Paul Jakma <paul.jakma@sun.com> |
789 | ||
790 | * command.c: (sort_node) use vector_max instead of referencing | |
791 | (struct vector *)->max directly. Test that vector_max is > 0 | |
792 | before using it to calculate an index. | |
793 | Fixup vector loop to make main body conditional on vector slot | |
794 | not being empty. | |
795 | (cmd_cmdsize) Fixup vector loop to make main body conditional on | |
796 | vector slot not being empty. | |
797 | (cmd_filter_by_completion) ditto | |
798 | (cmd_filter_by_string) ditto | |
799 | (is_cmd_ambiguous) ditto | |
800 | (cmd_describe_command_real) Change index integers to unsigned. | |
801 | Test that vector_max is > 0 before using it to calculate an index. | |
802 | Return immediately with CMD_ERR_NO_MATCH if vline has no | |
803 | active slots. | |
804 | Fixup vector loop to make main body conditional on vector slot | |
805 | not being empty. | |
806 | (cmd_complete_command_real) ditto. | |
807 | (cmd_execute_command_strict) Fixup vector loop to be conditional | |
808 | on non-null slot. | |
909a2155 | 809 | (various) Fix indentation and other whitespace. |
55468c86 | 810 | vector.h: Rename to (struct vector).max to slightly less confusing |
811 | active, for the number of active slots, distinct from allocated | |
812 | or active-and-not-empty. Rename vector_max to vector_active | |
813 | for same reason. | |
b8961476 | 814 | |
9e92eeab | 815 | 2005-03-09 Paul Jakma <paul.jakma@sun.com> |
816 | ||
817 | * command.c: Undo commit of sign warning fix and hidden command | |
818 | in list_cmd. Sign warning is more subtle. list_cmd on its own | |
819 | will be committed after. | |
4275b1de | 820 | * command.c: (config_list_cmd) Don't list hidden or deprecated |
821 | commands, hiding these from tab completion is still to be done. | |
9e92eeab | 822 | |
b45da6f0 | 823 | 2005-03-08 Paul Jakma <paul.jakma@sun.com> |
824 | ||
9c5d8562 | 825 | * command.c: (banner_motd_file_cmd) use XSTRDUP/XFREE. |
22085181 | 826 | (no_banner_motd_cmd) use XFREE. |
9c5d8562 | 827 | (cmd_describe_command_real) sign compile warning fix |
828 | (cmd_complete_command_real) ditto. | |
829 | (config_list_cmd) Don't list hidden or deprecated commands, | |
830 | hiding these from tab completion is still to be done. | |
831 | * command.h: cmd attr enum should start at 1. | |
b45da6f0 | 832 | * vty.c: (vty_hello) suggestions from Andrew, read by line and |
833 | stub out trailling non-printable characters on each line thus | |
834 | allowing us to specify VTY_NEWLINE to vty_out. | |
835 | ||
3b0c5d9a | 836 | 2005-03-08 Jeroen Massar <jeroen@unfix.org> |
837 | ||
838 | * vty.c: (vty_hello) display motd file, if set | |
839 | * command.h: add char *motdfile to struct host | |
840 | * command.c: (config_write_host) write out motdfile config | |
841 | (banner_motd_file_cmd) new command, allow motd to be read from | |
842 | file. | |
843 | (no_banner_motd_cmd) free motdfile string, if needs be. | |
844 | (cmd_init) init (struct host).motdfile. Add new motd file | |
845 | commands. | |
846 | ||
12f6ea23 | 847 | 2005-03-07 Michael Sandee <voidptr@voidptr.sboost.org> |
848 | ||
849 | * command.c: host.name might be NULL. | |
850 | * vty.c: Fix fd leak. | |
851 | ||
81fb3240 | 852 | 2005-02-24 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
853 | ||
854 | * stream.c: (stream_read_try) Log a warning message if a fatal | |
855 | I/O error occurs. | |
856 | (stream_fifo_new) Fix prototype. | |
857 | * stream.h: Fix prototype for stream_fifo_new (need void arg). | |
858 | ||
cdb6ee94 | 859 | 2005-02-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
860 | ||
861 | * {vty.h,vty.c}: Remove vty_finish (duplicate of vty_reset). | |
862 | ||
9fc7ebf1 | 863 | 2005-02-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
864 | ||
865 | * buffer.h: Make the struct buffer and struct buffer_data structures | |
866 | private by moving them inside buffer.c. Add comments for all | |
867 | functions. Rename buffer_write as buffer_put (to be more consistent | |
868 | with the buffer_putc and buffer_putstr functions). Declare a new | |
869 | buffer_write function that is used to write data to a file descriptor | |
870 | and/or add it to the buffer queue. Remove unused function | |
871 | buffer_flush_vty_all. Create a new enum typedef buffer_status_t | |
872 | to be used as the return code for all buffer_flush* functions | |
873 | and buffer_write. | |
874 | * buffer.c: The struct buffer and struct buffer_data declarations | |
875 | are now private to this file. In conjunction with that, remove | |
876 | some unnecessary fields: struct buffer (alloc, unused_head, | |
877 | unused_tail, length), struct buffer_data (prev). | |
878 | (buffer_data_new) Removed: functionality incorporated into buffer_add. | |
879 | (buffer_data_free) Removed: use a macro BUFFER_DATA_FREE instead. | |
880 | (buffer_new) Use calloc instead of malloc + memset(zero). | |
881 | Supply an appropriate default size if the specified size is 0. | |
882 | (buffer_free) Eliminate code duplication by calling buffer_reset to | |
883 | free the contents of the buffer (and remove unused code related | |
884 | to unused_head). | |
885 | (buffer_empty,buffer_putc,buffer_putstr) Aesthetic change (make more | |
886 | compact). | |
887 | (buffer_reset) Use macro BUFFER_DATA_FREE. No need to set | |
888 | alloc and length to 0 (these fields have been removed). | |
889 | (buffer_add) Fix scope to be static. Call XMALLOC directly instead | |
890 | of calling removed buffer_data_new function. Simplify the logic | |
891 | (since it's now a singly-linked list instead of doubly-linked). | |
892 | (buffer_write) Renamed to buffer_put. Change to void, since return | |
893 | code of 1 was meaningless. No need to adjust length field, since | |
894 | it has been removed. | |
895 | (buffer_putw,buffer_flush,buffer_flush_vty_all,buffer_flush_vty) | |
896 | Remove unused functions. | |
897 | (buffer_flush_all) Rewrite using buffer_flush_available to eliminate | |
898 | a possible failure mode if IOV_MAX is less than the number of buffers | |
899 | on the queue. | |
900 | (buffer_flush_window) Incorporate logic from buffer_flush_vty. | |
901 | Log an error message if there is a writev error. | |
902 | (buffer_flush_available) Be more paranoid: check for case where | |
903 | buffer is already empty. Use new ERRNO_IO_RETRY macro, and use | |
904 | new enum for return codes. Simplify deletion logic (since it's | |
905 | now a singly-linked list). | |
906 | (buffer_write) New function for use with non-blocking I/O. | |
907 | * vty.h: Replace the struct vty sb_buffer field with a fixed-size | |
908 | (5-character) sb_buf field and an sb_len field, since using | |
909 | a struct buffer was inappropriate for this task. Add some useful | |
910 | comments about telnet window size negotiation. | |
911 | * vty.c: Include <arpa/telnet.h> (no longer included by zebra.h). | |
912 | Remove VTY_OBUF_SIZE (instead use buffer_new default size). | |
913 | Make telnet_backward_char and telnet_space_char static const. | |
914 | (vty_out) Replace buffer_write with buffer_put. | |
915 | (vty_log_out) Check for I/O errors. If fatal, close the vty session. | |
916 | Consolidate 3 separate writes into a single write call. | |
917 | (vty_will_echo,vty_command,vty_next_line,vty_previous_line, | |
918 | vty_end_config,vty_describe_fold,vty_clear_buf,vty_serv_sock_addrinfo, | |
919 | vty_serv_sock_family,vty_serv_un,vty_use_backup_config,exec_timeout, | |
920 | vty_config_write,vty_save_cwd) Fix scope to static. | |
921 | (vty_new) Let buffer_new use its default buffer size. | |
922 | (vty_write) Fix signature: 2nd arg should be const char *. | |
923 | Replaced buffer_write with buffer_put. | |
924 | (vty_telnet_option) Fix minor bug (window height or width greater than | |
925 | 255 was broken). Use sb_buf and sb_len instead of removed sb_buffer | |
926 | (which was being used improperly). | |
927 | (vty_read) On error, use ERRNO_IO_RETRY to decide whether it's fatal. | |
928 | If the error is fatal, call buffer_reset so vty_close does not attempt | |
929 | to flush the data. Use new sb_buf and sb_len instead of sb_buffer | |
930 | to store the SB negotiation string. | |
931 | (vty_flush) When vty->lines is 0, call buffer_flush_available instead | |
932 | of buffer_flush_window. Look at the return code from buffer_flush | |
933 | to detect I/O errors (and in that case, log an error message and | |
934 | close the vty). | |
935 | (vty_create) Fix scope to static. Initialize sb_len to 0 instead | |
936 | of creating sb_buffer. | |
937 | (vty_accept) Set socket nonblocking. | |
938 | (vtysh_accept) Use new set_nonblocking function instead of calling | |
939 | fcntl directly. | |
940 | (vtysh_flush) New function called from vtysh_read (after command | |
941 | execution) and from vtysh_write. This flushes the buffer | |
942 | and reacts appropriately to the return code (by closing the vty | |
943 | or scheduling further flushes). | |
944 | (vtysh_read) Check whether error is fatal using ERRNO_IO_RETRY. | |
945 | If not, just try again later. Otherwise, call buffer_reset before | |
946 | calling vty_close (to avoid trying to flush the buffer in vty_close). | |
947 | Fix logic to allow case where a command does not arrive atomically | |
948 | in a single read call by checking for the terminating NUL char. | |
949 | (vtysh_write) Use new vtysh_flush helper function. | |
950 | (vty_close) No need to call buffer_empty, just call buffer_flush_all | |
951 | in any case (it will check whether the buffer is empty). | |
952 | Do not free sb_buffer (since it has been removed). | |
953 | (vty_log_fixed) Use writev instead of write. | |
954 | * zebra.h: Do not include <arpa/telnet.h>, since this is used only | |
955 | by lib/vty.c. | |
956 | ||
c3c07f28 | 957 | 2005-02-21 Vincenzo Eramo <eramo at infocom.ing.uniroma1.it> |
958 | ||
959 | * pqueue.[ch]: Introduce "update" function to meet ospf spf needs. It | |
960 | will allow to update node when: | |
961 | i) a node is inserted into the priority queue; | |
962 | ii) a node position is modified in the priority queue; | |
963 | * pqueue.h: Export trickle_down() function. | |
964 | ||
109ac96f | 965 | 2005-02-19 Paul Jakma <paul.jakma@sun.com> |
966 | ||
967 | * stream.c: (stream_new) fix dumb mistake. | |
968 | ||
53270116 | 969 | 2005-02-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
970 | ||
971 | * stream.c: (stream_read_try) Use new ERRNO_IO_RETRY macro. | |
972 | ||
d7e2a818 | 973 | 2005-02-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
974 | ||
975 | * network.h: Define a new ERRNO_IO_RETRY macro to test whether an I/O | |
976 | operation should be retried. This eliminates the need to duplicate | |
977 | the same logic testing for EAGAIN or EINTR in multiple places. | |
978 | ||
262feb1a | 979 | 2005-02-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
980 | ||
981 | * stream.h: Declare new function stream_read_try suitable for use | |
982 | with non-blocking file descriptors. Indicate that stream_read | |
983 | and stream_read_unblock are deprecated. | |
984 | * stream.c: (stream_read_try) New function for use with non-blocking | |
985 | I/O. | |
986 | (stream_recvmsg) Should return -1 if the stream is too small to | |
987 | contain the data. | |
988 | ||
42218e71 | 989 | 2005-02-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
990 | ||
991 | * network.c: (set_nonblocking) Should check return code from | |
992 | fcntl(F_GETFL). | |
993 | ||
a269d613 | 994 | 2005-02-15 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
995 | ||
996 | * network.h: Declare new function set_nonblocking. Indicate that | |
997 | readn and writen are deprecated. | |
998 | * network.c: (set_nonblocking) New function to make a file descriptor | |
999 | non-blocking, since it seems silly to have fcntl calls sprinkled | |
1000 | throughout the code. | |
1001 | ||
1dd13d41 | 1002 | 2005-02-14 Paul Jakma <paul.jakma@sun.com> |
f2e6c429 | 1003 | |
1004 | * stream.h: Unsigned long updated to size_t | |
1005 | * stream.c: ditto | |
050c013a | 1006 | * stream.h: Add stream_copy, stream_dup, stream_recvmsg. |
1007 | Add comment describing struct stream abstraction, and various | |
1008 | other comments. | |
1009 | Deprecate several unsafe/ambigious macros. | |
1010 | Add STREAM_WRITEABLE and STREAM_READABLE. | |
1011 | Add (stream_getl_from) for symmetry. | |
1012 | Update stream_forward_{endp,getp} to use size_t offset. | |
1013 | Make stream data a 0 length array, rather than a seperate malloc. | |
1014 | * stream.c: Add consistency checks. Update to follow stream.h | |
1015 | changes. | |
1016 | (stream_new) Alloc stream+data in one go. | |
1017 | (stream_copy) new function, copy a stream. | |
1018 | (stream_dup) new function, dup a stream. | |
1019 | (stream_recvmsg) new function, recvmsg data into a stream. | |
1020 | (stream_empty) no need to check getp == 0. | |
f2e6c429 | 1021 | |
9985f83c | 1022 | 2005-02-09 Paul Jakma <paul.jakma@sun.com> |
1023 | ||
1024 | * stream.h: Remove putp. Update reference to putp with endp. | |
1025 | Add stream_forward_endp, which daemons were doing manually. | |
1026 | Rename stream_forward to stream_forward_getp. | |
1027 | stream.c: Remove/update references to putp. | |
1028 | introduce stream_forward_endp. | |
1029 | ||
548e6f7d | 1030 | 2005-02-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1031 | ||
1032 | * zebra.h: Change macro definitions SET_FLAG and UNSET_FLAG | |
1033 | to use compound assignment operators (aesthetic change). | |
1034 | ||
c4c7d0c4 | 1035 | 2005-02-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1036 | ||
1037 | * log.c: (zlog_signal,zlog_backtrace_sigsafe) Eliminate use of fileno() | |
1038 | since it is not async-signal-safe. | |
1039 | (_zlog_assert_failed) Rewrite crashlog logic more compactly. | |
1040 | (zlog_set_file,zlog_reset_file,zlog_rotate) Update logfile_fd | |
1041 | for use in signal handler. | |
1042 | ||
1e221354 | 1043 | 2005-02-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1044 | ||
1045 | * log.c: (syslog_sigsafe) Reduce scope of syslog_fd: it is accessed | |
1046 | inside this function only. | |
1047 | (open_crashlog) New function to open /var/tmp/quagga.<daemon>.crashlog | |
1048 | with flags O_WRONLY|O_CREAT|O_EXCL to save some crash info. | |
1049 | (zlog_signal,_zlog_assert_failed) Increase logging priority from | |
1050 | LOG_ERR to LOG_CRIT. If no file logging is configured, try to use | |
1051 | open_crashlog to create a crash logfile. | |
1052 | (zlog_backtrace_sigsafe) If a crashlog file descriptor is open, | |
1053 | dump a backtrace to that file. | |
1054 | ||
847947f2 | 1055 | 2005-02-02 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1056 | ||
1057 | * if.h: Declare if_flag_dump. | |
1058 | ||
6a52d0d1 | 1059 | 2005-01-30 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1060 | ||
1061 | * daemon.c: (daemon) Replace perror with zlog_err. | |
1062 | * vty.c: (vty_serv_un) Replace perror with zlog_err. | |
1063 | ||
3b8b1855 | 1064 | 2005-01-29 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1065 | ||
1066 | * buffer.h: Fix comment on buffer_getstr to reflect that it now | |
1067 | uses XMALLOC. | |
1068 | * buffer.c: (buffer_getstr) Use XMALLOC(MTYPE_TMP) instead of malloc. | |
1069 | * filter.c: (access_list_remark,ipv6_access_list_remark) Use | |
1070 | argv_concat instead of buffer_getstr. | |
1071 | * if.c: (interface_desc) Use argv_concat instead of buffer_getstr. | |
1072 | * plist.c: (ip_prefix_list_description,ipv6_prefix_list_description) | |
1073 | Use argv_concat instead of buffer_getstr. | |
1074 | ||
afb8b605 | 1075 | 2005-01-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1076 | ||
1077 | * lib/buffer.h: Document behavior of buffer_getstr function. | |
1078 | * lib/buffer.c: (buffer_getstr) Fix bug: must handle case where | |
1079 | the string extends beyond the head struct buffer_data. | |
1080 | ||
f6834d4c | 1081 | 2005-01-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1082 | ||
1083 | * lib/command.h: Document behavior of argv_concat function. | |
1084 | * lib/command.c: (argv_concat) Calculate total string length first so | |
1085 | we can call malloc just once (instead of realloc'ing to add each | |
1086 | string element). | |
1087 | (do_echo,config_logmsg) Allow for possible NULL return value from | |
1088 | argv_concat. | |
1089 | ||
13bfca7a | 1090 | 2005-01-23 Hasso Tepper <hasso at quagga.net> |
1091 | ||
1092 | * lib/command.[ch]: Make node_parent() function nonstatic. vtyh.c will | |
1093 | use it as well. | |
1094 | ||
31364274 | 1095 | 2005-01-18 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1096 | ||
1097 | * log.h: Test for SA_SIGINFO to see whether zlog_signal takes final | |
1098 | two args (siginfo and program_counter). | |
1099 | * log.c: (hex_append) Include this function only if SA_SIGINFO or | |
1100 | HAVE_GLIBC_BACKTRACE is defined. | |
1101 | (zlog_signal) Final two args (siginfo and program_counter) now | |
1102 | depend on whether SA_SIGINFO is defined on this platform. | |
1103 | * sigevent.c: (program_counter) Do not include this function if | |
1104 | SA_SIGINFO is not defined on this platform. | |
1105 | (exit_handler,core_handler) Test for SA_SIGINFO to decide whether | |
1106 | 2nd & 3rd arguments are present and to decide how to invoke | |
1107 | zlog_signal. | |
1108 | (trap_default_signals) Test for SA_SIGINFO and invoke sigaction | |
1109 | appropriately. | |
1110 | ||
239c26fd | 1111 | 2005-01-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1112 | ||
1113 | * log.h: Change prototype for zlog_backtrace_sigsafe to take additional | |
1114 | program_counter argument. | |
1115 | * log.c: (zlog_backtrace_sigsafe) Add additional program_counter | |
1116 | argument. If it is non-NULL, use backtrace_symbols_fd to resolve | |
1117 | the address. | |
1118 | (zlog_signal) Call zlog_backtrace_sigsafe with additional | |
1119 | program_counter argument. | |
1120 | ||
87d683b0 | 1121 | 2005-01-17 Hasso Tepper <hasso at quagga.net> |
1122 | ||
1123 | * command.[ch], vty.c: cmd_execute_command() function must not attempt | |
1124 | to walk up in the node tree if called from vtysh. Different daemons | |
1125 | might have commands with same syntax in different nodes (for example | |
1126 | "router-id x.x.x.x" commands in zebra/ospfd/ospf6d daemons). | |
1127 | ||
cb585b65 | 1128 | 2005-01-14 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1129 | ||
1130 | * command.c (print_version): Do not bother even to examine host.name, | |
1131 | since it is always NULL when this function is called from main. | |
1132 | ||
f867d32c | 1133 | 2005-01-14 Greg Troxel <gdt@fnord.ir.bbn.com> |
1134 | ||
1135 | * command.c (print_version): Don't print host.name if it is NULL. | |
1136 | Fixes segfault on Solaris reported by Goetz von Escher <goetz@open.ch> | |
1137 | ||
40abf239 | 1138 | 2005-01-12 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1139 | ||
1140 | * sigevent.c: (trap_default_signals) Use the SA_SIGINFO flag to | |
1141 | pass additional siginfo_t and ucontext_t arguments to core_handler | |
1142 | and exit_handler. | |
1143 | (core_handler,exit_handler) Now invoked with 3 arguments (using | |
1144 | SA_SIGINFO). Pass additional info to zlog_signal. | |
1145 | (program_counter) New function to find program counter in ucontext_t, | |
1146 | needs to be enhanced to support more platforms (currently works only | |
1147 | on Linux/x86). | |
1148 | * log.h: Change the zlog_signal prototype to add new arguments | |
1149 | siginfo_t * and program_counter. | |
1150 | * log.c: (zlog_signal) Add new arguments siginfo and program_counter. | |
1151 | Include si_addr and program counter (if non-NULL) in message. | |
1152 | And remove #ifdef HAVE_GLIBC_BACKTRACE around hex_append, since | |
1153 | that is now used to render the si_addr and PC pointers. | |
1154 | ||
e22f5516 | 1155 | 2005-01-12 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1156 | ||
1157 | * zebra.h: If not C99 and no va_copy macro available, fall back to | |
1158 | memcpy (solves a build problem on FreeBSD 4.x). | |
1159 | ||
b99760ab | 1160 | 2005-01-04 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1161 | ||
1162 | * zebra.h: Define ZCMSG_FIRSTHDR appropriately based on whether | |
1163 | config.h indicates HAVE_BROKEN_CMSG_FIRSTHDR (as determined | |
1164 | by the configure test program). | |
1165 | * sockopt.c: (getsockopt_cmsg_data) Use ZCMSG_FIRSTHDR instead | |
1166 | of CMSG_FIRSTHDR. | |
1167 | ||
cba8a606 | 1168 | 2005-01-02 Hasso Tepper <hasso at quagga.net> |
1169 | ||
1170 | * command.c: Revert int -> unsigned int fixes in | |
1171 | cmd_describe_command_real() and cmd_complete_command_real(). index can | |
1172 | be actually negative and it caused crash with "do<TAB>" in vty. | |
1173 | ||
1d69fdf6 | 1174 | 2004-12-29 Greg Troxel <gdt@poblano.ir.bbn.com> |
1175 | ||
d44debed | 1176 | * sockopt.c (getsockopt_ipv4_ifindex): Document calling |
1177 | convention. Beef up comments. Handle the case where the cmsghdr | |
1178 | has a zero controllen, or more specifically when the wanted option | |
1179 | is not present. This is needed for Solaris 8, and in general for | |
1180 | any platform for which configure finds a method and it can fail. | |
1181 | Mark some changes with XXX to be cleaned up post 0.98. | |
1182 | ||
1d75c8c3 | 1183 | 2004-12-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1184 | ||
1185 | * sockopt.c: (setsockopt_ipv4_ifindex) Improve error message. | |
1186 | When neither IP_PKTINFO nor IP_RECVIF is defined, make return value | |
1187 | deterministic (-1). | |
1188 | ||
af04bd7c | 1189 | 2004-12-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1190 | ||
1191 | * thread.c: (funcname_thread_add_timer_msec) Reduce overflow risk. | |
1192 | ||
4ba9b924 | 1193 | 2004-12-21 Paul Jakma <paul.jakma@sun.com> |
1194 | ||
1195 | * if.h: Add more 'non-generic' IFF_ flags. | |
1196 | * if.c: IFF_NOXMIT/IFF_VIRTUAL interfaces are 'loopback like' | |
0e43a2bc | 1197 | * stream.c: Dont allocate streams with 0 sized data buffers |
4ba9b924 | 1198 | |
2885f72d | 1199 | 2004-12-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1200 | ||
1201 | * command.c: (do_echo) Added new "echo" command, useful for | |
1202 | watchdog pinging to make sure the daemon is responsive. | |
1203 | ||
202d08ca | 1204 | 2004-12-17 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1205 | ||
1206 | * pid_output.c: (pid_output_lock) Eliminate static function, and just | |
1207 | use the #ifdef to decide which version of the function to include. | |
1208 | This eliminates a compilation problem with gcc4. And fix the | |
1209 | non-fcntl version so that it actually compiles. Exit with | |
1210 | status 1 instead of -1 on error. | |
1211 | ||
81fc57ca | 1212 | 2004-12-15 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1213 | ||
1214 | * sigevent.c: (trap_default_signals) Ignore SIGPIPE instead of exiting. | |
1215 | ||
3378d209 | 1216 | 2004-12-10 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1217 | ||
1218 | * log.c: (zlog_signal,_zlog_assert_failed) Change logging level back to | |
1219 | LOG_ERR instead of LOG_EMERG. | |
1220 | ||
c3324c63 | 1221 | 2004-12-09 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1222 | ||
1223 | * log.c: (hex_append) No need to include this function if | |
1224 | HAVE_GLIBC_BACKTRACE is not defined. | |
1225 | ||
b9e7028f | 1226 | 2004-12-08 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1227 | ||
1228 | * prefix.c: (prefix_copy) Error message before abort should | |
1229 | have severity LOG_ERR, not LOG_INFO. | |
1230 | * memory.c: (mtype_log) Log level should be LOG_DEBUG, not LOG_INFO. | |
1231 | ||
8ddca704 | 1232 | 2004-12-07 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1233 | ||
1234 | * {smux.c,zclient.c}: Change level of debug messages to LOG_DEBUG. | |
1235 | ||
82146b88 | 1236 | 2004-12-07 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1237 | ||
1238 | * command.c: (config_write_host) Note that "log trap" is deprecated | |
1239 | when writing out the config. | |
1240 | ||
274a4a44 | 1241 | 2004-12-07 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1242 | ||
1243 | * log.h: Replace struct zlog flags and maskpri fields with maxlvl | |
1244 | array to support individual logging levels for each destination. | |
1245 | Remove the 2nd argument to openzlog since the default logging config | |
1246 | should be standardized inside the library. Replaced the | |
1247 | zlog_set_flag and zlog_reset_flag functions with zlog_set_level. | |
1248 | And zlog_set_file now requires an additional log_level argument. | |
1249 | Declare zlog_proto_names for use inside command.c in the | |
1250 | "show logging" command. Added defines useful for command | |
1251 | construction. | |
1252 | * log.c: (vzlog) Decide where to send the message based on the | |
1253 | individual logging levels configured for each destination. | |
1254 | Remove support for ZLOG_STDERR since it was never actually used. | |
1255 | Support record-priority for terminal monitors. | |
1256 | (zlog_signal,zlog_backtrace_sigsafe) Support destination-specific | |
1257 | logging levels. Remove stderr support (was never used). Added | |
1258 | support for terminal monitor logging. | |
1259 | (_zlog_assert_failed) Increase message severity to LOG_EMERG. | |
1260 | (openzlog) Remove 2nd argument since default config should be | |
1261 | standardized in library. By default, terminal monitoring | |
1262 | is set to debug, and all other logging is disabled. | |
1263 | (zlog_set_flag,zlog_reset_flag) Removed. | |
1264 | (zlog_set_level) New function to replace zlog_set_flag and | |
1265 | zlog_reset_flag. Supports destination-specific logging levels. | |
1266 | (zlog_set_file,zlog_reset_file) Support file-specific logging level. | |
1267 | (zlog_rotate) Log an error message if fopen fails, and support | |
1268 | new file-specific logging level. | |
1269 | * command.h: Change DEFUN_CMD_FUNC_DECL and DEFUN_CMD_FUNC_TEXT so that | |
1270 | command functions will be static instead of global. Remove | |
1271 | declarations for config_exit and config_help. Define new macros | |
1272 | DEFUNSH_ATTR, DEFUNSH_HIDDEN, and DEFUNSH_DEPRECATED so we can | |
1273 | have deprecated commands in vtysh. Similarly, for completeness, | |
1274 | define macros ALIAS_SH, ALIAS_SH_HIDDEN, and ALIAS_SH_DEPRECATED. | |
1275 | Also, fix bug in ALIAS_ATTR macro (didn't matter because it | |
1276 | was never used). | |
1277 | * command.c: Make many functions static instead of global. | |
1278 | (facility_name,facility_match,level_match) New functions | |
1279 | to support enhanced destination-specific logging levels. | |
1280 | (config_write_host) Support new destination-specific logging levels. | |
1281 | (config_logmsg) Added new "logmsg" command to help test logging | |
1282 | system. | |
1283 | (show_logging) Added "show logging" command to show the current | |
1284 | configuration of the logging system. | |
1285 | (config_log_stdout_level) Support explicit stdout logging level. | |
1286 | (no_config_log_stdout) Now takes optional LEVEL arg. | |
1287 | (config_log_monitor,config_log_monitor_level,no_config_log_monitor) | |
1288 | New commands creating new "log monitor" commands to set terminal | |
1289 | monitoring log level. | |
1290 | (config_log_file_level) Support explicit file logging level. | |
1291 | (config_log_syslog_level) Support explicit syslog logging level. | |
1292 | (config_log_facility,no_config_log_facility) Implement new | |
1293 | "log facility" command. | |
1294 | (cmd_init) Add hooks for new commands: "show logging", "logmsg", | |
1295 | "log stdout <level>", "log monitor", "log monitor <level>", | |
1296 | "no log monitor", "log file <filename> <level>", | |
1297 | "no log file <filename> <level>", "log syslog <level>", | |
1298 | "log facility", and "no log facility". | |
1299 | * vty.h: Added a "level" argument to vty_log so it can support | |
1300 | "log record-priority". Declare new function vty_log_fixed for | |
1301 | use in signal handlers. | |
1302 | * vty.c: (vty_log,vty_log_out) Added a "level" argument to support | |
1303 | "log record-priority" for vty terminal monitors. | |
1304 | (vty_down_level) Use config_exit_cmd.func instead of calling | |
1305 | config_exit directly (since command functions will now be static | |
1306 | instead of global). | |
1307 | (vty_log_fixed) New function to send terminal monitor messages | |
1308 | from inside a signal handler. | |
1309 | ||
5e764774 | 1310 | 2004-12-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1311 | ||
1312 | * log.h: Document appropriate use of syslog logging priorities | |
1313 | inside quagga. | |
1314 | ||
56f2069a | 1315 | 2004-12-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1316 | ||
1317 | * command.h: Remove fields log_stdout and log_syslog from struct host, | |
1318 | since they are just trying to duplicate information in the | |
1319 | zlog_default structure. Note that this fixes a bug since those | |
1320 | fields were not registering any logging that was established | |
1321 | in the initial call to openzlog (this affects only the zebra and | |
1322 | ospf6d daemons). It is probably a bug to turn on any logging by | |
1323 | default in the call to openzlog. | |
1324 | * command.c: (config_write_host) Get logging info from zlog_default | |
1325 | instead of now-removed fields host.log_stdout and host.log_syslog. | |
1326 | (config_log_stdout,no_config_log_stdout) Do not set now-removed field | |
1327 | host.log_stdout, since this info is recorded in zlog_default. | |
1328 | (config_log_file) Use XSTRDUP (instead of strdup) to set host.logfile. | |
1329 | (config_log_syslog,config_log_syslog_facility,no_config_log_syslog) | |
1330 | Do not set now-removed field host.log_syslog, since this info is | |
1331 | recorded in zlog_default. | |
1332 | ||
887c44a4 | 1333 | 2004-12-03 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1334 | ||
1335 | * version.h.in: Remove declaration for pid_output_lock, this function | |
1336 | is now static, not global. | |
1337 | * pid_output.c: (pid_output_lock) This function should be static, not | |
1338 | global. And remove "old umask" error message, since it was really | |
1339 | an unimportant debug message, not an error. | |
1340 | (pid_output) Need to declare static function pid_output_lock. | |
1341 | ||
7d149b8e | 1342 | 2004-11-28 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1343 | ||
1344 | * log.h: Remove several unused fields from struct zlog. Add comments | |
1345 | for other fields, and add one new field syslog_options that is | |
1346 | used in the new syslog_sigsafe implementation. | |
1347 | * log.c: (syslog_sigsafe) New function to send syslog messages in | |
1348 | an async-signal safe way that can be used inside a signal handler. | |
1349 | (syslog_connect) New function to connect to syslog daemon inside a | |
1350 | signal handler. This function supports only systems where /dev/log | |
1351 | is a unix datagram socket (e.g. not Solaris). | |
1352 | (zlog_signal) Call syslog_sigsafe if syslog logging is enabled. | |
1353 | (zlog_backtrace_sigsafe) Call syslog_sigsafe if syslog logging is | |
1354 | enabled. | |
1355 | (openzlog) Save syslog_options for use in syslog_sigsafe. | |
1356 | (num_append) Fix bug: handle 0 properly. | |
1357 | (hex_append) New function to print a u_long in hex format. | |
1358 | ||
2557aed1 | 1359 | 2004-11-28 Hasso Tepper <hasso at quagga.net> |
1360 | ||
1361 | * command.h: DEFUN_DEPRECATED passes attribute to DEFUN as well. | |
1362 | ||
48d6c69b | 1363 | 2004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1364 | ||
1365 | * log.c, log.h, memory.c: Change function name from zlog_backtrace_safe | |
1366 | to the more self-explanatory zlog_backtrace_sigsafe. | |
1367 | ||
5b85facc | 1368 | 2004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1369 | ||
1370 | * debug.[ch]: Remove unused files. | |
1371 | * Makefile.am: Remove references to debug.c and debug.h | |
1372 | ||
063ee52a | 1373 | 2004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1374 | ||
1375 | * log.c: (zlog_backtrace) New function to log a backtrace. | |
1376 | (zlog_backtrace_safe) Log a backtrace in an async-signal-safe way. | |
1377 | Unfortunately, this function does not support syslog logging yet. | |
1378 | (zlog_signal) Move backtrace code into separate function | |
1379 | zlog_backtrace_safe. | |
1380 | (_zlog_assert_failed) Call zlog_backtrace before aborting. | |
1381 | * log.h: Declare new functions zlog_backtrace and zlog_backtrace_safe. | |
1382 | * memory.c: (zerror) Call zlog_backtrace before aborting. | |
1383 | ||
d1c51d7c | 1384 | 2004-11-26 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1385 | ||
1386 | * Makefile.am: Need to add zassert.h to pkginclude_HEADERS. | |
1387 | ||
4cf0d0df | 1388 | 2004-11-25 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1389 | ||
1390 | * zebra.h: If not C99 and there's no va_copy macro and there is | |
1391 | a __va_copy macro, define va_copy as __va_copy. | |
1392 | ||
e5879ca1 | 1393 | 2004-11-25 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1394 | ||
1395 | * pid_output.c: (pid_output_lock) Fix 2 bugs: when locking, should | |
1396 | set l_whence to SEEK_SET, not SEEK_END. And after writing new | |
1397 | pid to file, must ftruncate to eliminate any extraneous bytes left | |
1398 | over from the last time a pid was written. | |
1399 | ||
cee3df1e | 1400 | 2004-11-24 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1401 | ||
1402 | * zassert.h: New header file to declare a quagga-specific assert macro. | |
1403 | * log.c: (_zlog_assert_failed) New function called when assert fails | |
1404 | to log the error and abort. | |
1405 | * zebra.h: Include "zassert.h" instead of <assert.h>. | |
1406 | * regex.c: Include "zassert.h" instead of <assert.h>. | |
1407 | ||
59a06a91 | 1408 | 2004-11-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1409 | ||
1410 | * sigevent.c: (signal_init) Set up some default signal handlers | |
1411 | so that processes will issue an error message before terminating | |
1412 | or dumping core. | |
1413 | (trap_default_signals) New function to set up signal handlers | |
1414 | for various signals that may kill the process. | |
1415 | (exit_handler) Call zlog_signal, then _exit. | |
1416 | (core_handler) Call zlog_signal, then abort. | |
1417 | * log.h: Declare new function zlog_signal. | |
1418 | * log.c: (zlog_signal) New function to log information about | |
1419 | a received signal before the process dies. Try to log a | |
1420 | backtrace also. | |
1421 | (quagga_signal_handler,signal_set) Should be static. | |
1422 | ||
d246bd96 | 1423 | 2004-11-23 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1424 | ||
1425 | * log.c: (vzlog) Take a single va_list argument and use va_copy | |
1426 | as necessary for multiple traversals. | |
1427 | (zlog) Pass only one va_list to vzlog. | |
1428 | (zlog_*,plog_*) Use a macro for boilerplate code; pass only one | |
1429 | va_list to vzlog. | |
1430 | (zlog_set_file) Remove unused 2nd argument (flags). | |
1431 | (zlog_save_cwd,zlog_get_cwd,zlog_free_cwd) Remove unused functions. | |
1432 | * log.h: Remove ZLOG_*_INDEX defines (no longer used). | |
1433 | Remove unused 2nd argument from zlog_set_file prototype. | |
1434 | Fix prototype for zlog_rotate. | |
1435 | * command.c: (config_log_file) Remove unused 2nd arg to zlog_set_file. | |
1436 | * vty.c: (vty_out) Fix stdarg usage to perform multiple traversals | |
1437 | properly. | |
1438 | (vty_log) Must use va_copy for multiple traversals of va_list arg. | |
1439 | ||
ca359769 | 1440 | 2004-11-19 David Young <dyoung@pobox.com> |
1441 | ||
1442 | * log.c: (safe_strerror) New function: safe wrapper for strerror. | |
1443 | ||
ff29bb31 | 1444 | 2004-11-19 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1445 | ||
1446 | * sockopt.c: (setsockopt_so_recvbuf) Stop error message from being | |
1447 | printed every time. | |
1448 | ||
f858e49b | 1449 | 2004-11-16 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1450 | ||
1451 | * memory.h: Fix prototype for memory_init(). | |
1452 | * memory.c: Declare many functions and data structures static instead | |
1453 | of global. Fix prototype for memory_init(). | |
1454 | ||
69e1325f | 1455 | 2004-11-15 Greg Troxel <gdt@fnord.ir.bbn.com> |
1456 | ||
1457 | * sockopt.h: Avoid CMSG_ALIGN, and declare that sizes are without | |
1458 | alignment (users should use CMSG_SPACE). | |
1459 | ||
1460 | * zebra.h: Rationalize CMSG_SPACE compatibility defines. Warn if | |
1461 | asumming 4-byte alignment, since this isn't safe. | |
1462 | ||
7fa25ff6 | 1463 | 2004-11-15 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1464 | ||
1465 | * memory.c: (zerror) Use zlog_err instead of fprintf to stderr. | |
1466 | Instead of exiting, log currenty memory usage and then abort. | |
1467 | (log_memstats) New function to log memory statistics, called by | |
1468 | zerror. | |
1469 | (show_memory_all) Loop over new mlists array instead of calling | |
1470 | show_memory_vty separately for each memory_list. | |
1471 | ||
b86718ea | 1472 | 2004-11-08 Paul Jakma <paul@dishone.st> |
b35e5b4e | 1473 | |
2265d20c | 1474 | * buffer.c: Add missing include of log.h. |
1475 | (buffer_flush_available) written is compared against | |
1476 | mostly against unsigned types, only for the writev do we need | |
1477 | signed compare, so declare it as size_t and cast it to ssize_t | |
1478 | just for the error compare when we've called writev. | |
1479 | * buffer.h: Add comment that buffer data sizes really should be | |
1480 | size_t. | |
1481 | ||
1482 | 2004-11-07 Paul Jakma <paul@dishone.st> | |
1483 | ||
1484 | * version.h.in: add autoconf configure_input output var | |
b35e5b4e | 1485 | |
5a646650 | 1486 | 2004-11-04 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1487 | ||
1488 | * vty.h: Remove fields in struct vty that were related to VTY_CONTINUE | |
1489 | capabilities (that were used only in bgpd/bgp_route.c and are now | |
1490 | removed). Also remove some other fields that were not being | |
1491 | used at all. | |
1492 | * vty.c: (vty_execute) Do not test for obsolete status values VTY_START | |
1493 | and VTY_CONTINUE. | |
1494 | (vty_read) Remove calls to vty->output_func since that was part | |
1495 | of the VTY_CONTINUE infrastructure that has been removed. | |
1496 | (vty_flush) Remove code to support VTY_START and VTY_CONTINUE. | |
1497 | (vty_close) Remove code to cancel vty->t_output thread, since that | |
1498 | thread was never actually used. | |
1499 | ||
49ff6d9d | 1500 | 2004-11-04 Andrew J. Schorr <ajschorr@alumni.princeton.edu> |
1501 | ||
1502 | * vty.c: Vtysh connections to daemons should use buffering. | |
1503 | (vty_out) Remove exception for vty_shell_serv, just use buffer_write. | |
1504 | (vty_new) Increase output buffer size to 4096 rounded up to a | |
1505 | multiple of pagesize. | |
1506 | (vtysh_read) After command has been executed and all output buffered, | |
1507 | call buffer_flush_available and schedule further writes if the | |
1508 | buffers are not yet empty. | |
1509 | (vtysh_write) New function to flush output to vtysh when the socket | |
1510 | is writeable. | |
1511 | (vty_event) Added new VTYSH_WRITE event for flushing buffers to vtysh | |
1512 | clients. Also, should save read thread in vty->t_read so the | |
1513 | thread can be cancelled in vty_close. | |
1514 | * buffer.h: In struct buffer_data, remove unused "parent" field. | |
1515 | Convert "unsigned char *data" to "unsigned char data[0]" to save | |
1516 | a malloc. Declare new function buffer_flush_available that works | |
1517 | with non-blocking sockets. | |
1518 | * buffer.c: (buffer_data_new) Use a single malloc now that data is | |
1519 | a variable-size array at end of structure. | |
1520 | (buffer_data_free) Just a single free now that data is part of the | |
1521 | structure. | |
1522 | (buffer_write) Simplify the logic to make behavior more transparent. | |
1523 | (buffer_flush) Decrease b->length as data is written out. | |
1524 | (buffer_flush_vty_all) Decrease b->length as buffers are freed. | |
1525 | (buffer_flush_vty) Decrease b->length as data is written out. | |
1526 | (buffer_flush_available) New function to flush non-blocking sockets. | |
1527 | ||
e064d6d9 | 1528 | 2004-11-01 Paul Jakma <paul@dishone.st> |
1529 | ||
1530 | * sockopt.c: (setsockopt_pktinfo) remove, its unused. | |
1531 | ||
75e15fe4 | 1532 | 2004-10-31 Paul Jakma <paul@dishone.st> |
1533 | ||
1534 | * vty.c: As per Andrew's suggestions.. | |
1535 | (vty_serv_un) remove flags. | |
1536 | (vtysh_accept) close socket if we cant set NONBLOCK. Add flags. | |
66cbbceb | 1537 | * keychain.c: Convert some more strtoul users to VTY_GET_INTEGER. |
9d11a19e | 1538 | * memory.h: Add MTYPE_THREAD_FUNCNAME and MTYPE_THREAD_STATS |
1539 | * thread.c: Update stats and funcname alloc/free to use previous | |
039b9577 | 1540 | specific memory type defines. Use XCALLOC and sizeof the type, |
1541 | not the pointer. | |
70e149e0 | 1542 | * smux.c: fix int to size_t compile warnings |
75e15fe4 | 1543 | |
dccfb190 | 1544 | 2004-10-29 Paul Jakma <paul@dishone.st> |
1545 | ||
1546 | * vty.c: Move setting of sock to O_NONBLOCK from vty_serv_un | |
1547 | to vtysh_accept, where sock is the actual fd we wanted to set to | |
1548 | O_NONBLOCK, ie the /connected/ vtysh unix socket. | |
1549 | ||
508ec910 | 1550 | 2004-10-23 Hasso Tepper <hasso at quagga.net> |
1551 | ||
1552 | * zclient.c: Unbreak reading interface update message. Might fix | |
1553 | blocker bugzilla #109. | |
1554 | ||
23b9c61e | 1555 | 2004-10-22 Paul Jakma <paul@dishone.st> |
7d9c6e51 | 1556 | |
1557 | * sockopt.c: (getsockopt_ipv4_ifindex) no ifindex should be 0, not | |
23b9c61e | 1558 | -1. |
1559 | (setsockopt_pktinfo) unexported | |
1560 | * sockopt.h: Cleanup SOCKOPT_CMSG defines a bit. Add a throwaway | |
1561 | define for SOPT_SIZE_CMSG_IFINDEX_IPV4 for systems which have | |
4ccb2c46 | 1562 | neither IP_RECVIF nor IP_PKTINFO (eg openbsd), thanks to Rivo |
1563 | Nurges for highlighting problem and fix. | |
4927cf0b | 1564 | Fix elif that should be an else. |
406d6716 | 1565 | * command.h: Cleanup the defines a bit, add helper defines and |
1566 | collapse all defines to use those. Add an attribute field to | |
1567 | cmd_element to support, eg hidden or deprecated commands, add | |
1568 | defun defines for such. All that's left to do is add logic | |
1569 | to command.c to check these attributes... ;) | |
af0d97eb | 1570 | * zebra.h: reserve ZEBRA_ROUTE_HSLS |
7d9c6e51 | 1571 | |
6590f2c3 | 1572 | 2004-10-19 Hasso Tepper <hasso at quagga.net> |
1573 | ||
1574 | * version.h.in: Define copyright string QUAGGA_COPYRIGHT. | |
1575 | * print_version.c: Remove. print_version () function moved to | |
1576 | command.[c|h]. | |
1577 | * command.c: Use QUAGGA_COPYRIGHT. | |
1578 | * Makefile.am: Remove useless version.c and print_version.c files. | |
1579 | ||
3fb9cd6e | 1580 | 2004-10-19 Andrew J. Schorr <aschorr@telemetry-investments.com> |
1581 | ||
1582 | * zclient.c: (zebra_interface_address_read) If the destination address | |
1583 | is encoded as all zeroes, load it as a NULL pointer. | |
1584 | * if.h: Add comment describing struct connected destination field | |
1585 | and indicating that it may be NULL. Define macros | |
1586 | CONNECTED_DEST_HOST and CONNECTED_POINTOPOINT_HOST to help | |
1587 | with PtP logic (distinguish between host and subnet addressing). | |
1588 | * if.c: (if_lookup_address) Fix PtP logic to handle subnet addressing | |
1589 | properly, | |
1590 | (connected_lookup_address) ditto. | |
1591 | (connected_add_by_prefix) Handle case where destination is NULL, | |
1592 | * prefix.[c|h]: New functions ipv4_network_addr and | |
1593 | ipv4_broadcast_addr. | |
1594 | ||
ddd85ed1 | 1595 | 2004-10-13 Hasso Tepper <hasso at quagga.net> |
1596 | ||
1597 | * command.c: Make CMD_ERR_NOTHING_TODO nonfatal if reading | |
1598 | configuration from file. Fixes critical bugzilla #113. | |
c75105ab | 1599 | * smux.c, smux.h: Remove all defaults to initialize smux connection to |
1600 | snmpd by default even if not configured to do so. "smux peer OID | |
1601 | <password>" initializes now connection and "no smux peer" terminates | |
1602 | it. | |
ddd85ed1 | 1603 | |
42d49865 | 1604 | 2004-10-13 Paul Jakma <paul@dishone.st> |
1605 | ||
1606 | * (global) more const'ification. | |
1607 | * sockunion.c: (sockunion_su2str) buffer should be sized | |
1608 | SU_ADDRSTRLEN. | |
1609 | (sockunion_log) do not return stack variables, strdup buf before | |
1610 | return. | |
1611 | * vty.h: Fix up the VTY_GET_INTEGER macros. Testing caller supplied | |
1612 | values against ULONG_MAX is daft, when caller probably has passed | |
1613 | a type that can not hold ULONG_MAX. use a temporary long instead. | |
1614 | Add VTY_GET_LONG, make VTY_GET_INTEGER_RANGE use it, make | |
1615 | VTY_GET_INTEGER a define for VTY_GET_INTEGER_RANGE. | |
1616 | ||
a149411b | 1617 | 2004-10-11 Hasso Tepper <hasso at quagga.net> |
1618 | ||
1619 | * command.h: Sync DEFUNSH with other macros. | |
1620 | * sockunion.c, sockunion.h: More const strings. | |
1621 | ||
9076fbd3 | 1622 | 2004-10-11 Paul Jakma <paul@dishone.st> |
1623 | ||
1624 | * thread.c: (funcname_thread_add_timer) | |
1625 | (funcname_thread_add_timer_msec) Fix mistakes from last change. | |
1626 | Pointed out by Liu Xin in [quagga-dev 1609]. | |
c9eca01b | 1627 | * if.h: mtu's should be unsigned. |
1628 | * routemap.{c,h}: const char updates | |
1629 | * smux.{c,h}: ditto | |
9076fbd3 | 1630 | |
9035efaa | 1631 | 2004-10-10 Paul Jakma <paul@dishone.st> |
47ca2953 | 1632 | |
1633 | * version.h.in: (pid_output*) add const qualifier. | |
9035efaa | 1634 | * command.h: Change DEFUN func to take const char *[] rather |
1635 | than char **, to begin process of fixing compile warnings in lib/. | |
1636 | Nearly all other changes in this commit follow from this change. | |
1637 | * buffer.{c,h}: (buffer_write) pointer-arithmetic is gccism, take | |
1638 | const void * and cast an automatic const char *p to it. | |
1639 | (buffer_putstr) add const | |
1640 | * command.c: (zencrypt) const qualifier | |
1641 | (cmd_execute_command_real) ditto | |
1642 | (cmd_execute_command_strict) ditto | |
1643 | (config_log_file) ditto. | |
1644 | Fix leak of getcwd() returned string. | |
1645 | * memory.{c,h}: Add MTYPE_DISTRIBUTE_IFNAME for struct dist ifname. | |
1646 | * distribute.{c,h}: Update with const qualifier. | |
1647 | (distribute_free) use MTYPE_DISTRIBUTE_IFNAME | |
1648 | (distribute_lookup) Cast to char *, note that it's ok. | |
1649 | (distribute_hash_alloc) use MTYPE_DISTRIBUTE_IFNAME. | |
1650 | (distribute_get) Cast to char *, note that it's ok. | |
1651 | * filter.c: Update with const qualifier. | |
1652 | * if.{c,h}: ditto. | |
1653 | * if_rmap.{c,h}: ditto. | |
1654 | (if_rmap_lookup) Cast to char *, note that it's ok. | |
1655 | (if_rmap_get) ditto. | |
1656 | * log.{c,h}: Update with const qualifier. | |
1657 | * plist.{c,h}: ditto. | |
1658 | * routemap.{c,h}: ditto. | |
1659 | * smux.{c,h}: ditto. Fix some signed/unsigned comparisons. | |
1660 | * sockopt.c: (getsockopt_cmsg_data) add return for error case. | |
1661 | * vty.c: Update with const qualifier. | |
1662 | ||
27a43a81 | 1663 | 2004-10-08 Hasso Tepper <hasso at quagga.net> |
1664 | ||
1665 | * routemap.c, routemap.h: Make some string arguments const. | |
1666 | ||
5973ee73 | 1667 | 2004-10-05 Paul Jakma <paul@dishone.st> |
1668 | ||
1669 | * version.h.in: print_version declaration is here, not in automake | |
1670 | generated version.h. | |
1671 | ||
ea8e9d97 | 1672 | 2004-10-08 Hasso Tepper <hasso at quagga.net> |
1673 | ||
1674 | * command.c, command.h: Make argument of cmd_make_strvec function | |
1675 | const. | |
1676 | * command.c: Make hostname commands usable in vtysh again. | |
1677 | ||
6ad96ea1 | 1678 | 2004-10-07 Hasso Tepper <hasso at quagga.net> |
1679 | ||
1680 | * command.c, pid_output.c, print_version.c, vty.c, vty.h: Make more | |
1681 | strings const. | |
1682 | ||
8c328f11 | 1683 | 2004-10-05 Hasso Tepper <hasso at quagga.net> |
1684 | ||
1685 | * *.[c|h]: Make many strings cons and a lot of int -> unsigned int | |
1686 | changes to fix warnings. | |
1687 | ||
96e27c99 | 1688 | 2004-10-05 Paul Jakma <paul@dishone.st> |
1689 | ||
1690 | * sockopt.{c,h}: add sockopt_iphdrincl_swab_{htosys,systoh}, | |
1691 | functions to change byte order between system IP_HDRINCL order | |
1692 | and host order. | |
98c91ac6 | 1693 | * thread.c: (funcname_thread_add_timer_timeval) new function, add |
1694 | timer at specified timeval. | |
1695 | (funcname_thread_add_timer) use funcname_thread_add_timer_timeval. | |
1696 | (funcname_thread_add_timer_msec) ditto | |
96e27c99 | 1697 | |
b04c699e | 1698 | 2004-10-04 Hasso Tepper <hasso at quagga.net> |
1699 | ||
1700 | * memory.c, memory.h: Make char * argument of strdup functions const. | |
1701 | * prefix.c, prefix.h: Make many arguments const. Reorder stuff in | |
1702 | header. | |
1703 | * log.h: Make log message const in struct message. | |
1704 | * log.c: Fix some indenting. | |
1705 | * network.c, network.h: Make second argument of writen() const. | |
1706 | ||
e7168df4 | 1707 | 2004-10-03 Hasso Tepper <hasso at quagga.net> |
1708 | ||
1709 | * command.h: Introduce SERVICE_NODE for "service <...>" commands. | |
1710 | * command.c: Don't initialize commands that don't make sense if vtysh | |
1711 | is used. | |
1712 | * vty.c: Make VTY_NODE appear in vtysh. | |
1713 | ||
18a6dce6 | 1714 | 2004-10-03 James R. Leu <jleu at mindspring.com> |
1715 | ||
1716 | * zclient.c, zclient.h: zclient functions for router id handling. | |
1717 | * zebra.h: New message types for router id handling. | |
1718 | ||
9172ee0e | 1719 | 2004-09-27 Paul Jakma <paul@dishone.st> |
1720 | ||
1721 | * zebra.h: Add WANT_OSPF_WRITE_FRAGMENT for ospfd | |
1722 | to try to fragment oversized packets. Enabled only for Linux. | |
1723 | Add HAVE_IP_HDRINCL_BSD_ORDER to define struct ip byte order, | |
1724 | to consolidate various ad-hoc platform defines for same thing. | |
1725 | ||
e473b032 | 1726 | 2004-09-26 Hasso Tepper <hasso at quagga.net> |
1727 | ||
1728 | * vty.c, sockopt.c: Fix compiler warnings. | |
1729 | ||
52dc7ee6 | 1730 | 2004-09-23 Hasso Tepper <hasso at quagga.net> |
1731 | ||
1732 | * linklist.h: Remove list and listnode typedefs. | |
1733 | * *.[c|h]: list -> struct list *, listnode -> struct listnode *. | |
1734 | ||
b89e60c7 | 1735 | 2004-09-17 Paul Jakma <paul@dishone.st> |
1736 | ||
1737 | * sockopt.c: Add missing bracket | |
1738 | ||
0b3acf4f | 1739 | 2004-09-17 Paul Jakma <paul@dishone.st> |
1740 | ||
1741 | * sockopt.{c,h}: Add setsockopt_so_recvbuf, for ripd and ripngd. | |
1742 | ||
33394766 | 1743 | 2004-09-13 Paul Jakma <paul@dishone.st> |
1744 | ||
1745 | * command.c: Update the copyright string in the default motd. | |
1746 | ||
630e4807 | 1747 | 2004-08-31 David Wiggins <dwiggins@bbn.com> |
1748 | ||
1749 | * hash.c (hash_iterate): Save next pointer before calling | |
1750 | procedure, so that iteration works even if the called procedure | |
1751 | deletes the hash backet. | |
1752 | ||
1753 | * linklist.h (listtail): new macro, not yet used. | |
1754 | ||
34553cc3 | 1755 | 2004-08-27 Hasso Tepper <hasso at quagga.net> |
1756 | ||
1757 | * command.c: Install "terminal length" commands only if vty is used. | |
1758 | Vtysh will handle it itself. | |
1759 | ||
afa43b23 | 1760 | 2004-08-26 Greg Troxel <gdt@fnord.ir.bbn.com> |
1761 | ||
1762 | * sockopt.h: Define method-independent macro for callers of | |
1763 | get_ifindex to use for cmsg length. | |
1764 | ||
efba6ce9 | 1765 | 2004-08-19 Paul Jakma <paul@dishone.st> |
1766 | ||
1767 | * zebra.h: add MAX and MIN defines (eg for ospf6d) | |
1768 | ||
e6822768 | 1769 | 2004-08-19 Paul Jakma <paul@dishone.st> |
1770 | ||
1771 | * sockopt.c: include sockopt.h | |
1772 | rename some of the _pktinfo_ functions to _ifindex, where that is | |
1773 | their purpose. | |
1774 | (getsockopt_ipv6_pktinfo_ifindex) renamed to | |
1775 | getsockopt_ipv6_ifindex. | |
1776 | (setsockopt_ipv4_pktinfo) renamed to setsockopt_ipv4_ifindex | |
1777 | (setsockopt_pktinfo) update with previous and add comment re | |
1778 | AF_INET portability. | |
1779 | (setsockopt_ifindex) generic ifindex function ala | |
1780 | setsockopt_pktinfo. | |
1781 | (getsockopt_ipv4_pktinfo_ifindex) renamed to | |
1782 | getsockopt_ipv4_ifindex. | |
1783 | (getsockopt_ipv4_ifindex) rejiggling to reduce repeated | |
1784 | ifdef/elses. pktinfo case forgot to set ifindex. | |
1785 | (getsockopt_pktinfo_ifindex) renamed to | |
1786 | getsockopt_ifindex. update some calls to renamed functions. | |
1787 | * sockopt.h: Update renamed exported functions | |
1788 | Rename the CMSG_SIZE macros to IFINDEX. | |
1789 | Guard IPv4 PKTINFO in a conditional define. | |
1790 | ||
c0618de6 | 1791 | 2004-08-18 Paul Jakma <paul@dishone.st> |
1792 | ||
1793 | * vty.c: (vty_serv_un) set unix vty socket to nonblocking | |
1794 | to prevent inadvertent blocking of daemons by use of | |
1795 | vtysh. TODO: disentangle manual paging from the buffer_write | |
1796 | path so that unix vty can use this path too and be reliable. | |
1797 | ||
33f92320 | 1798 | 2004-07-23 Greg Troxel <gdt@poblano.ir.bbn.com> |
1799 | ||
1800 | * sockopt.c (getsockopt_ipv4_pktinfo_ifindex): Make this compile | |
1801 | on NetBSD, and add comments to make it less confusing. Change the | |
1802 | sense of the SUNOS_5 test to make parallel structure between the | |
1803 | variables and the code. | |
1804 | ||
4f7baa0e | 1805 | 2004-07-23 Paul Jakma <paul@dishone.st> |
1806 | ||
1807 | * sockopt.h: Add SOPT_SIZE_CMSG_PKTINFO{_IPV{4,6}} define, for | |
1808 | sizeof pktinfo as appropriate, to be used when allocating msg | |
1809 | buffers. export setsockopt_pktinfo() and | |
1810 | getsockopt_pktinfo_ifindex() | |
1811 | * sockopt.c: (setsockopt_pktinfo_ifindex) new function to portably | |
1812 | set received ifindex sock option. | |
1813 | (getsockopt_pktinfo_ifindex) portably retrieve ifindex. | |
1814 | (getsockopt_cmsg_data) retrieve indicated control info from | |
1815 | message header. | |
1816 | (getsockopt_ipv6_pktinfo_ifindex) ipv6 version of above. | |
1817 | (setsockopt_ipv4_pktinfo) v4 version | |
1818 | (setsockopt_pktinfo) the exported version | |
1819 | (getsockopt_ipv4_pktinfo_ifindex) v4 specific version | |
1820 | (getsockopt_pktinfo_ifindex) the exported version | |
1821 | ||
05c447dd | 1822 | 2004-07-14 Paul Jakma <paul@dishone.st> |
1823 | ||
1824 | * sigevent.c: (quagga_signal_handler) add a global caught flag, set | |
1825 | the flags to a constant rather increment to be kinder. | |
1826 | (quagga_sigevent_process) new function, to do core of what | |
1827 | quagga_signal_timer did. dont block signals at all as sig->caught | |
1828 | is volatile sig_atomic_t and should be safe to access from signal | |
1829 | and normal contexts. The signal blocking is unneeded paranoia, but | |
1830 | is left intact under an ifdef, should some platform require it. | |
1831 | Check global caught flag before iterating through array. | |
1832 | (quagga_signal_timer) nearly everything moved to | |
1833 | quagga_sigevent_process. Left in under ifdef, in case some | |
1834 | platform could use a regular timer check for signals. | |
1835 | * sigevent.h: quagga_sigevent_process declaration. | |
1836 | * thread.c: (thread_fetch) check for signals at beginning of | |
1837 | scheduler loop, check for signals if select returns EINTR. | |
1838 | ||
b7797131 | 1839 | 2004-07-13 Greg Troxel <gdt@poblano.ir.bbn.com> |
1840 | ||
1841 | * sigevent.c: Don't block SIGTRAP and SIGKILL. Blocking SIGTRAP | |
1842 | confuses gdb, at least on NetBSD 2.0_BETA, where the block | |
1843 | succeeds. | |
1844 | ||
5510e83b | 1845 | 2004-07-09 Paul Jakma <paul@dishone.st> |
1846 | ||
1847 | * Merge Kunihiro's 'show route-map' change and add | |
1848 | compatibility aliases for route-map continue | |
b9790b34 | 1849 | * jhash.{c,h}: New files. Bob Jenkins' public domain hashing |
1850 | function, as implemented in linux kernel by David Miller. | |
5510e83b | 1851 | |
b06c14f2 | 1852 | 2004-07-09 Juris Kalnins <juris@mt.lv> |
1853 | ||
1854 | * if.c: (if_cmp_func) fix for interface names where name is same, | |
1855 | but one has no number, eg "devtyp" and "devtyp0". | |
1856 | ||
87efd646 | 1857 | 2004-06-30 Greg Troxel <gdt@poblano.ir.bbn.com> |
1858 | ||
1859 | * Makefile.am: Make libzebra shared. | |
1860 | ||
138ce75f | 1861 | 2004-06-21 Paul Jakma <paul@dishone.st> |
1862 | ||
1863 | * ChangeLog: fix my last update config.h -> zebra.h ;) | |
1864 | * zebra.h: Fix gcc check. | |
1865 | ||
02ff83c5 | 1866 | 2004-06-11 Sowmini Varadhan <sowmini.varadhan@sun.com> |
1867 | ||
1868 | * filter.c: (access_list_remark_cmd) buffer_putstr doesnt need cast | |
1869 | to u_char. (ipv6_access_list_remark_cmd) ditto. | |
1870 | if.c: ditto | |
1871 | * network.c: (readn/writen) pointer arg should be type u_char. | |
1872 | * plist.c: needs to include stream.h, not declare stream functions | |
1873 | internally. | |
1874 | (various) Add static qualifier to internal functions. | |
1875 | (prefix_list_type_str) extraneous breaks in switch statement. | |
1876 | (ip_prefix_list_description_cmd) buffer_putstr doesnt need cast | |
1877 | * stream.h: depends on plist.h and export stream_put_prefix | |
1878 | * vty.c: (vty_<telnet option build functions>) should use | |
1879 | unsigned char, telnet options are 0 -> 255. | |
1880 | * zclient.c: various u_char<->char type cleanups. | |
1881 | * zebra.h: Having to define CMSG_* can apply to more than just | |
1882 | BSDI_NRL. | |
1883 | ||
51a8798e | 1884 | 2004-06-09 Paul Jakma <paul@dishone.st> |
1885 | ||
138ce75f | 1886 | * zebra.h: __attribute__ is a gcc'ism |
51a8798e | 1887 | |
5228ad27 | 1888 | 2004-06-04 Paul Jakma <paul@dishone.st> |
1889 | ||
1890 | * type mismatch fixes | |
1891 | ||
6708fa3c | 1892 | 2004-05-18 Hasso Tepper <hasso@estpak.ee> |
1893 | ||
1894 | * pqueue.[c|h]: Added as part of ospf6d merge from Zebra repository. | |
1895 | ||
0a589359 | 1896 | 2004-05-08 Paul Jakma <paul@dishone.st> |
1897 | ||
1898 | * zclient.c (zapi_ipv4_route) Follow Sowmini's lead and describe | |
1899 | message format. | |
1900 | ||
1901 | 2004-05-08 Sowmini Varadhan <sowmini.varadhan@sun.com> | |
1902 | ||
1903 | * zclient.c: (zapi_ipv4_add) collapsed into zapi_ipv4_route | |
1904 | (zapi_ipv4_delete) ditto. | |
1905 | (zapi_ipv4_route) add/delete a route by way of cmd arg. | |
1906 | (zapi_ipv6_add) collapsed into zapi_ipv6_route. | |
1907 | (zapi_ipv6_delete) ditto. | |
1908 | (zapi_ipv6_route) add/delete a route by way of cmd arg. | |
1909 | (zebra_interface_address_delete_read) collapsed into | |
1910 | zebra_interface_address_read. | |
1911 | (zebra_interface_address_delete_read) ditto. | |
1912 | (zebra_interface_address_read) read address add/delete messages | |
1913 | by way of type argument. Describe command message format. | |
1914 | (zebra_interface_add_read) Unconditionally read new ifmtu6 field. | |
1915 | Describe command message format. | |
1916 | (zebra_interface_state_read) Unconditionally read new ifmtu6 field. | |
1917 | (zclient_redistribute_set) Collapsed into zclient_redistribute | |
1918 | (zclient_redistribute_unset) ditto | |
1919 | (zclient_redistribute) set/unset redistribution. | |
1920 | (zclient_redistribute_default_set) Collapsed into | |
1921 | zclient_redistribute_default. | |
1922 | (zclient_redistribute_default_unset) ditto. | |
1923 | (zclient_redistribute_default) Redistribute default set/unset. | |
1924 | * zclient.h: delete zapi_ipv{4,6}_add, zapi_ipv{4,6}_delete. Add | |
1925 | zapi_ipv{4,6}_route. delete zclient_redistribute_set/unset. Add | |
1926 | zclient_redistribute. Ditto for | |
1927 | zclient_redistribute_default_{set/unset}. | |
1928 | ||
4a7aac1b | 1929 | 2004-05-08 Sowmini Varadhan <sowmini.varadhan@sun.com> |
1930 | ||
1931 | * if.h: Add mtu6 field to struct interface, IPv6 MTU may differ | |
1932 | from IPv4, and Solaris treats the MTU's differently. | |
1933 | Add connected_add_by_prefix, for use by later patch. | |
1934 | * if.c: (connected_add_by_prefix) Add prefix to connected list. | |
1935 | (if_flag_dump) Solaris: Dump IFF_IPv4/6 flag | |
1936 | (if_dump) Dump mtu6 flag, for HAVE_IPV6. | |
22528299 | 1937 | * command.c: (sockunion_getsockname) use socklen_t for len. |
1938 | (sockunion_getpeername) ditto. | |
0a589359 | 1939 | |
31fcdd3f | 1940 | 2004-04-21 Boris Kovalenko <boris@tagnet.ru> |
1941 | ||
1942 | * daemon.c: (daemon) fix check for error return from setsid | |
1943 | ||
c49b3069 | 1944 | 2004-01-19 Paul Jakma <paul@dishone.st> |
1945 | ||
1946 | * sigevent.{c,h}: New files, implement event handled signals. | |
1947 | see signal_init() in sigevent.h. | |
1948 | ||
c32e1b57 | 1949 | 2003-12-23 Vincent Jardin <jardin@6wind.com> |
1950 | ||
1951 | * {command.c, memory.c, vty.c, zebra.h}: Add isisd support | |
1952 | ||
3dbf9969 | 1953 | 2003-12-22 Greg Troxel <gdt@fnord.ir.bbn.com> |
1954 | ||
1955 | * vty.c (vty_use_backup_config): Don't free filenames before using | |
1956 | them for unlink. | |
1957 | ||
54aba54c | 1958 | 2003-08-20 Yasuhiro Ohara <yasu@sfc.wide.ad.jp> |
1959 | ||
1960 | * command.c: Fix <cr> display problem for command line | |
1961 | description | |
1962 | ||
e9af5c78 | 1963 | 2003-05-24 Anil Madhavapeddy |
1964 | ||
1965 | * (sockunion.c): Incorrect bounds specified in sockunion_log() | |
1966 | ||
445f1435 | 1967 | 2003-05-08 Sergiy Vyshnevetskiy <serg @ vostok.net> |
1968 | ||
1969 | * vty.c: -A option | |
1970 | ||
1971 | 2003-04-19 Hasso Tepper <hasso@estpak.ee> | |
1972 | ||
1973 | * rip_routemap.c: sync daemon's route-map commands to have same | |
1974 | syntax | |
1975 | ||
718e3744 | 1976 | 2002-09-28 Yasuhiro Ohara <yasu@sfc.wide.ad.jp> |
1977 | ||
1978 | * vty.c (vty_flush): One line more on vty. | |
1979 | ||
1980 | 2002-09-27 Kunihiro Ishiguro <kunihiro@ipinfusion.com> | |
1981 | ||
1982 | * vector.c (vector_lookup): Add new function. | |
1983 | ||
1984 | 2002-08-19 Kunihiro Ishiguro <kunihiro@ipinfusion.com> | |
1985 | ||
1986 | * thread.c (timeval_adjust): Fix unconditional crush due to | |
1987 | FreeBSD's select() system call timeval value check. | |
1988 | ||
1989 | 2002-07-07 Kunihiro Ishiguro <kunihiro@ipinfusion.com> | |
1990 | ||
1991 | * zebra-0.93 released. | |
1992 | ||
1993 | 2002-06-21 Kunihiro Ishiguro <kunihiro@ipinfusion.com> | |
1994 | ||
1995 | * if.c (ifc_pointopoint): Add ifc_pointopoint() accoding to Frank | |
1996 | van Maarseveen's suggestion. | |
1997 | ||
1998 | 2002-06-18 Kunihiro Ishiguro <kunihiro@zebra.org> | |
1999 | ||
2000 | * command.c: Change bcopy() to memcpy(). | |
2001 | ||
2002 | 2001-12-12 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2003 | ||
2004 | * command.c (config_password): Fix host.password clear bug. | |
2005 | Reported by Wang Jian <lark@linux.net.cn>. | |
2006 | ||
2007 | 2001-08-29 Kunihiro Ishiguro <kunihiro@ipinfusion.com> | |
2008 | ||
2009 | * thread.c (thread_should_yield): New function to check thread | |
2010 | should yeild it's execution to other thread. Suggested by: Rick | |
2011 | Payne <rickp@ayrnetworks.com> | |
2012 | ||
2013 | 2001-08-20 Kunihiro Ishiguro <kunihiro@ipinfusion.com> | |
2014 | ||
2015 | * thread.c (thread_timer_cmp): Rewrite function. | |
2016 | ||
2017 | * hash.c: Add hash_get(). Change hash_pull() to hash_release(). | |
2018 | ||
2019 | 2001-08-19 Kunihiro Ishiguro <kunihiro@ipinfusion.com> | |
2020 | ||
2021 | * zebra-0.92a released. | |
2022 | ||
2023 | 2001-08-15 Kunihiro Ishiguro <kunihiro@ipinfusion.com> | |
2024 | ||
2025 | * zebra-0.92 released. | |
2026 | ||
2027 | 2001-08-12 Akihiro Mizutani <mizutani@dml.com> | |
2028 | ||
2029 | * prefix.c (netmask_str2prefix_str): Convert "1.1.0.0 255.255.0.0" | |
2030 | string to "1.1.0.0/16". | |
2031 | ||
2032 | 2001-08-10 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2033 | ||
2034 | * filter.c (access_list_lookup): access_list_lookup's first | |
2035 | argument is changed from address family to AFI. | |
2036 | ||
2037 | * plist.c: (prefix_list_lookup): Likewise. | |
2038 | ||
2039 | 2001-07-27 Akihiro Mizutani <mizutani@dml.com> | |
2040 | ||
2041 | * plist.c: ge and le display order is changed. Old compatible | |
2042 | rule (len <= ge-value <= le-value) is removed. | |
2043 | ||
2044 | 2001-07-08 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2045 | ||
2046 | * prefix.h: Temporary fix for alignment of prefix problem. | |
2047 | ||
2048 | 2001-06-21 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2049 | ||
2050 | * prefix.h (struct prefix): Remove safi and padding field. | |
2051 | (struct prefix_ipv4): Likewise. | |
2052 | (struct prefix_ipv6): Likewise. | |
2053 | (struct prefix_ls): Likewise. | |
2054 | (struct prefix_rd): Likewise. | |
2055 | ||
2056 | * command.h (enum node_type): Preparation for BGP new config. | |
2057 | ||
2058 | * vty.c (vty_end_config): Likewise. | |
2059 | ||
2060 | 2001-06-17 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2061 | ||
2062 | * routemap.c (route_map_rule_delete): Call func_free when | |
2063 | route-map rule is deleted. | |
2064 | ||
2065 | 2001-06-14 "Akihiro Mizutani" <mizutani@dml.com> | |
2066 | ||
2067 | * routemap.c (route_map_index_lookup): Prevent to use deny and | |
2068 | permit for same route-map sequence. | |
2069 | ||
2070 | 2001-04-12 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2071 | ||
2072 | * vty.c (vty_read_config): Fix warning. | |
2073 | ||
2074 | 2001-03-08 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2075 | ||
2076 | * command.c (IPV6_PREFIX_STR): Add '.' and '%' for IPv6 address | |
2077 | strings. | |
2078 | ||
2079 | 2001-03-07 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2080 | ||
2081 | * zebra.h (_XPG4_2): Define _XPG4_2 and __EXTENSIONS__ for | |
2082 | CMSG_FIRSTHDR. | |
2083 | ||
2084 | 2001-03-07 Michael Rozhavsky <mrozhavsky@opticalaccess.com> | |
2085 | ||
2086 | * zebra.h (struct in_pktinfo): structure in_pktinfo declaration. | |
2087 | ||
2088 | 2001-02-19 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2089 | ||
2090 | * memory.c (memory_list_lib): Add MTYPE_NEXTHOP for "show memory | |
2091 | lib" member. | |
2092 | ||
2093 | 2001-02-13 Matthew Grant <grantma@anathoth.gen.nz> | |
2094 | ||
2095 | * vty.c (vty_read_config): Revert check of integrate_default when | |
2096 | VTYSH is defined. | |
2097 | ||
2098 | 2001-02-13 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2099 | ||
2100 | * vty.c (vty_read_config): Do not check integrate_default. That | |
2101 | should be used only by vtysh. | |
2102 | ||
2103 | 2001-02-08 Matthew Grant <grantma@anathoth.gen.nz> | |
2104 | ||
2105 | * vty.c (vty_serv_un): Set umask 0077. | |
2106 | (vty_read_config): Stat for vtysh Zebra.conf, if found startup and | |
2107 | wait for boot configuration. | |
2108 | ||
2109 | * if.c (if_lookup_address): Make it smart implementation. | |
2110 | ||
2111 | * sockopt.c (setsockopt_multicast_ipv4): Set up a multicast socket | |
2112 | options for IPv4 This is here so that people only have to do their | |
2113 | OS multicast mess in one place rather than all through zebra, | |
2114 | ospfd, and ripd . | |
2115 | ||
2116 | 2001-02-04 Akihiro Mizutani <mizutani@dml.com> | |
2117 | ||
2118 | * plist.c (vty_prefix_list_install): Even when argument is | |
2119 | invalid, new memory is allocated. Now memory allocation is done | |
2120 | after argument check. | |
2121 | ||
2122 | 2001-02-01 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2123 | ||
2124 | * zebra-0.91 is released. | |
2125 | ||
2126 | 2001-01-31 Akihiro Mizutani <mizutani@dml.com> | |
2127 | ||
2128 | * vty.c (vty_login): Add vty login command. | |
2129 | ||
2130 | 2001-01-31 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2131 | ||
2132 | * vty.c (vty_reset): Close accept socket. | |
2133 | ||
2134 | 2001-01-30 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2135 | ||
2136 | * memory.h (enum): MTYPE_ATTR_TRANSIT is added for unknown transit | |
2137 | attribute. | |
2138 | ||
2139 | 2001-01-22 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2140 | ||
2141 | * zclient.c (zebra_interface_address_add_read): Fetch interface | |
2142 | address flag. | |
2143 | (zebra_interface_address_delete_read): Likewise. | |
2144 | ||
2145 | 2001-01-16 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2146 | ||
2147 | * table.c (route_node_match_ipv4): Utility function for IPv4 | |
2148 | address lookup. | |
2149 | (route_node_match_ipv6): Utility function for IPv4 address lookup. | |
2150 | ||
2151 | 2001-01-15 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2152 | ||
2153 | * if.c: Delete RIP_API part until new implementation comes out. | |
2154 | ||
2155 | 2001-01-13 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2156 | ||
2157 | * hash.h (struct Hash): Rename alloc to count. Change type to | |
2158 | unsigned long. | |
2159 | ||
2160 | * stream.c (stream_getc_from): New function. | |
2161 | (stream_getw_from): Likewise. | |
2162 | ||
2163 | * zebra.h (ZEBRA_FLAG_STATIC): Add new flag for persistent route. | |
2164 | ||
2165 | 2001-01-11 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2166 | ||
2167 | * flap.c: File is removed. | |
2168 | ||
2169 | * flap.c: Likewise. | |
2170 | ||
2171 | * roken.h: Likewise. | |
2172 | ||
2173 | * buffer.c (buffer_new): Remove type option to buffer_new(). | |
2174 | ||
2175 | 2001-01-10 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2176 | ||
2177 | * zclient.c (zapi_ipv4_delete): Remove OLD_RIB part. | |
2178 | ||
2179 | 2001-01-09 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2180 | ||
2181 | * zebra-0.90 is released. | |
2182 | ||
2183 | * command.c: Update Copyright year. | |
2184 | ||
2185 | 2001-01-09 Matthew Grant <grantma@anathoth.gen.nz> | |
2186 | ||
2187 | * if.c (if_create): Register connected_free() function for | |
2188 | deletion. | |
2189 | (if_delete): Free connected information when the interface is | |
2190 | deleted. | |
2191 | (if_lookup_by_index): Fix argument type from int to unsigned int. | |
2192 | (connected_add): Keep list in order if old info found, essential | |
2193 | for repeatable operation in some daemons. | |
2194 | ||
2195 | 2001-01-09 endo@suri.co.jp (Masahiko Endo) | |
2196 | ||
2197 | * vty.c (vty_flush): When vty->statis is VTY_CLOSE do not add vty | |
2198 | read thread. | |
2199 | ||
2200 | 2001-01-08 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2201 | ||
2202 | * filter.c (access_list_delete): Access-list name is not freed. | |
2203 | ||
2204 | * plist.c (prefix_list_delete): Prefix-list name is not freed. | |
2205 | ||
2206 | 2000-12-29 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2207 | ||
2208 | * zclient.c (zclient_start): Change to use UNIX domain | |
2209 | socket for zebra communication. | |
2210 | ||
2211 | * vector.c (vector_init): vector_alloc and vector_data_alloc is | |
2212 | removed. All memory allocation count should be maintained by | |
2213 | XMALLOC and XFREE macros. | |
2214 | ||
2215 | 2000-12-28 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2216 | ||
2217 | * zebra.h (ZEBRA_NEXTHOP_IFINDEX): Define ZEBRA_NEXTHOP_* values. | |
2218 | ||
2219 | 2000-12-27 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2220 | ||
2221 | * zebra.h (ZEBRA_ERR_RTEXIST): Make zebra error code to negative | |
2222 | value. | |
2223 | ||
2224 | 2000-12-25 "Wataru Uno" <wataru@po.ntts.co.jp> | |
2225 | ||
2226 | * vty.c (vtysh_read): Don't allocate new buffer because buffer is | |
2227 | allocated in vty_new (). | |
2228 | ||
2229 | 2000-12-14 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2230 | ||
2231 | * memory.h (enum): Add MTYPE_AS_FILTER_STR. | |
2232 | ||
2233 | * command.c (config_write_terminal): Display "end" at the end of | |
2234 | configuration. | |
2235 | ||
2236 | * plist.c (vty_prefix_list_install): Use AF_INET to determine | |
2237 | lenum length. | |
2238 | ||
2239 | 2000-12-13 "Wataru Uno" <wataru@po.ntts.co.jp> | |
2240 | ||
2241 | * buffer.c (buffer_flush_vty): If IOV_MAX defined in the System, | |
2242 | then all lines write by IOV_MAX. | |
2243 | ||
2244 | 2000-12-12 Michael Rozhavsky <mrozhavsky@opticalaccess.com> | |
2245 | ||
2246 | * command.c (config_write_file): Robust method for writing | |
2247 | configuration file and recover from backing up config file. | |
2248 | ||
2249 | 2000-11-29 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2250 | ||
2251 | * smux.c (smux_connect): More fail check. | |
2252 | (smux_trap): When SMUX connection is not established, do nothing. | |
2253 | ||
2254 | 2000-11-28 Gleb Natapov <gleb@nbase.co.il> | |
2255 | ||
2256 | * thread.c (thread_fetch): Execut event list first. Old event | |
2257 | list is renamed to ready list. With this change, event thread is | |
2258 | executed before any other thread. | |
2259 | ||
2260 | * thread.h (struct thread_master): Add ready list. | |
2261 | ||
2262 | 2000-11-28 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2263 | ||
2264 | * linklist.c (listnode_add_after): Add node right after the | |
2265 | listnode pointer. | |
2266 | ||
2267 | 2000-11-27 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2268 | ||
2269 | * smux.h: Pass struct variable to WriteMethod. | |
2270 | ||
2271 | 2000-11-25 Frank van Maarseveen <F.vanMaarseveen@inter.NL.net> | |
2272 | ||
2273 | * if.c (if_lookup_address): When looking up interface with IP | |
2274 | address, Sometimes multiple interfaces will match. Now PtP | |
2275 | interfaces prevail in such a case which seem the right thing to | |
2276 | do: There will probably also be host routes which usually prevail | |
2277 | over network routes. | |
2278 | ||
2279 | 2000-11-25 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2280 | ||
2281 | * smux.c (smux_trap): SMUX trap implementation. | |
2282 | ||
2283 | 2000-11-19 Akihiro Mizutani <mizutani@dml.com> | |
2284 | ||
2285 | * plist.c: Add automatic conversion function of an old rule. | |
2286 | ex.) 10.0.0.0/8 ge 8 -> 10.0.0.0/8 le 32 | |
2287 | ||
2288 | 2000-11-16 Yon Uriarte <ukl2@rz.uni-karlsruhe.de> | |
2289 | ||
2290 | * zclient.c (zebra_interface_add_read): Read hardware address when | |
2291 | hw_addr_len is greater than 0. | |
2292 | ||
2293 | 2000-11-15 Akihiro Mizutani <mizutani@dml.com> | |
2294 | ||
2295 | * plist.c: The rule of "len <= ge-value <= le-value" | |
2296 | was changed to "len < ge-value <= le-value". | |
2297 | ||
2298 | 2000-11-09 Yasuhiro Ohara <yasu@sfc.wide.ad.jp> | |
2299 | ||
2300 | * memory.[ch]: Added #define and functions for ospf6d. | |
2301 | ||
2302 | * log.[ch]: some platform says that the data of used va_list | |
2303 | is undefined. Changed to hold list of va_list for each | |
2304 | vsnprintf. | |
2305 | ||
2306 | 2000-11-07 Rick Payne <rickp@rossfell.co.uk> | |
2307 | ||
2308 | * memory.h (enum): Add MTYPE_COMMUNITY_REGEXP. | |
2309 | ||
2310 | 2000-11-06 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2311 | ||
2312 | * command.c (config_exit): Fix bug of missing break after case | |
2313 | BGP_VPNV4_NODE. | |
2314 | ||
2315 | 2000-10-30 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2316 | ||
2317 | * vector.c (vector_unset): Check i is not nevative. | |
2318 | ||
2319 | 2000-10-24 Arkadiusz Miskiewicz <misiek@pld.org.pl> | |
2320 | ||
2321 | * smux.c (smux_sock): Set terminating '\0'. Check address family. | |
2322 | ||
2323 | * vty.c (vty_serv_sock_addrinfo): Set terminating '\0'. Use | |
2324 | gai_strerror. Check address family. | |
2325 | ||
2326 | 2000-10-23 Jochen Friedrich <jochen@scram.de> | |
2327 | ||
2328 | * smux.c: Use linklist rather than vector. | |
2329 | (smux_getnext): A SMUX subagent has to behave as if it manages the | |
2330 | whole SNMP MIB tree itself. It's the duty of the master agent to | |
2331 | collect the best answer and return it to the manager. See RFC 1227 | |
2332 | chapter 3.1.6 for the glory details :-). ucd-snmp really behaves | |
2333 | bad here as it actually might ask multiple times for the same | |
2334 | GETNEXT request as it throws away the answer when it expects it in | |
2335 | a different subtree and might come back later with the very same | |
2336 | request. | |
2337 | ||
2338 | 2000-10-23 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2339 | ||
2340 | * command.c (cmd_init): Log related command are only installed for | |
2341 | terminal mode. | |
2342 | ||
2343 | 2000-10-21 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2344 | ||
2345 | * Makefile.am (libzebra_a_SOURCES): Remove duplicated buffer.c. | |
2346 | ||
2347 | * zebra.h: Remove #warn directive. | |
2348 | ||
2349 | 2000-10-20 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2350 | ||
2351 | * keychain.c (keychain_init): Register "key chain" command to | |
2352 | KEYCHAIN_NODE and KEYCHAIN_KEY_NODE. | |
2353 | ||
2354 | * vty.c (vty_end_config): Fix missing vty_cinfig_unlock for other | |
2355 | CONFIG_NODE. | |
2356 | ||
2357 | * command.c (config_end): Likewise. | |
2358 | ||
2359 | * keychain.c (keychain_get): Key is sorted by it's identifier | |
2360 | value. | |
2361 | ||
2362 | 2000-10-19 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2363 | ||
2364 | * linklist.c (list_delete_all_node): Call delete function if it is | |
2365 | defined. | |
2366 | ||
2367 | * command.c (cmd_execute_command_strict): Add modification for | |
2368 | vtysh. | |
2369 | (cmd_execute_command_strict): Remove first argument cmdvec because | |
2370 | it is global varibale in command.c. | |
2371 | ||
2372 | 2000-10-18 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2373 | ||
2374 | * command.c (cmd_init): Install | |
2375 | copy_runningconfig_startupconfig_cmd only in terminal mode. | |
2376 | ||
2377 | * linklist.c (list_delete_node): Simplify the function. | |
2378 | (listnode_lookup): Renamed from list_lookup_node. | |
2379 | ||
2380 | 2000-10-17 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2381 | ||
2382 | * stream.h: Undef stream_read and stream_write without | |
2383 | parenthesis. | |
2384 | ||
2385 | * newlist.c: File removed. | |
2386 | ||
2387 | * newlist.h: Likewise. | |
2388 | ||
2389 | * linklist.c (list_new): Remove list_init(). To allocate new | |
2390 | linked list, please use list_new(). | |
2391 | (listnode_add): Remove list_add_node(). To add new node to linked | |
2392 | list, please use listnode_add(). | |
2393 | (list_delete_by_val): Revemove fucntion. | |
2394 | ||
2395 | 2000-10-16 Nobuaki Tanaka <nobby@po.ntts.co.jp> | |
2396 | ||
2397 | * table.c (route_table_free): Reimplement route_table_free(). | |
2398 | ||
2399 | 2000-10-11 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2400 | ||
2401 | * keychain.c (keychain_get): Register key_delete_func to key | |
2402 | list's delete function. Use linklist.c instead of newlist.c. | |
2403 | ||
2404 | 2000-10-04 Akihiro Mizutani <mizutani@dml.com> | |
2405 | ||
2406 | * filter.c (access_list_remark): Add access-list's remark command. | |
2407 | (no_access_list): "no access-list 100 permit any" error message | |
2408 | bug is fixed. | |
2409 | ||
2410 | 2000-10-03 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2411 | ||
2412 | * memory.h (enum): Add MTYPE_SOCKUNION. | |
2413 | ||
2414 | 2000-10-02 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2415 | ||
2416 | * zebra-0.89 is released. | |
2417 | ||
2418 | 2000-10-01 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2419 | ||
2420 | * linklist.c (list_add_node_head): Delete unused function. | |
2421 | (list_add_node_tail): Likewise. | |
2422 | ||
2423 | 2000-09-26 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2424 | ||
2425 | * stream.c (stream_read_unblock): Add new function for unblocking | |
2426 | read. | |
2427 | ||
2428 | 2000-09-26 Jochen Friedrich <jochen@nwe.de> | |
2429 | ||
2430 | * smux.c (smux_register): Fix bug of can't register more than one | |
2431 | MIB with SMUX. | |
2432 | ||
2433 | 2000-09-26 Makoto Otsuka <otsuka@inl.ntts.co.jp> | |
2434 | ||
2435 | * vty.c (vty_close): Fix memory leak of sb_buffer. | |
2436 | (vty_new): Likewise. | |
2437 | ||
2438 | 2000-09-21 steve@Watt.COM (Steve Watt) | |
2439 | ||
2440 | * log.h: Do not declare zlog_priority[0] variable. | |
2441 | ||
2442 | 2000-09-12 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2443 | ||
2444 | * linklist.h (struct _list ): Add member cmp for compare function. | |
2445 | (struct _list ): Member up is deleted | |
2446 | ||
2447 | 2000-09-12 David Lipovkov <dlipovkov@OpticalAccess.com> | |
2448 | ||
2449 | * if.c: Include RIP_API header when RIP API is enabled. | |
2450 | ||
2451 | 2000-09-10 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2452 | ||
2453 | * prefix.c (prefix_free): Siplify prefix_free(). | |
2454 | ||
2455 | * keychain.c (key_match_for_accept): strncmp check bug is fixed. | |
2456 | ||
2457 | 2000-09-07 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2458 | ||
2459 | * zebra.h: Merge roken.h into zebra.h. | |
2460 | ||
2461 | 2000-09-05 Akihiro Mizutani <mizutani@dml.com> | |
2462 | ||
2463 | * routemap.c (route_map_init_vty): Install route-map command to | |
2464 | RMAP_NODE. | |
2465 | ||
2466 | 2000-08-22 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2467 | ||
2468 | * thread.c (thread_get_id): Remove pthread related garbage. | |
2469 | ||
2470 | * command.h (struct host): Likewise. | |
2471 | ||
2472 | * zebra.h: Likewise. | |
2473 | ||
2474 | 2000-08-20 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2475 | ||
2476 | * command.h (node_type ): Add AAA node for authentication. | |
2477 | ||
2478 | * vty.c (vty_close): Do not close stdout. | |
2479 | ||
2480 | 2000-08-18 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2481 | ||
2482 | * vty.c (vty_init_vtysh): Added for vtysh. | |
2483 | ||
2484 | * distribute.c (districute_list_prefix_all): Interface independent | |
2485 | filter can be set. | |
2486 | (distribute_list_all): Likewise. | |
2487 | (config_show_distribute): Display current distribute-list status | |
2488 | for "show ip protocols". | |
2489 | ||
2490 | 2000-08-18 Akihiro Mizutani <mizutani@dml.com> | |
2491 | ||
2492 | * command.c (config_terminal_no_length): no terminal monitor -> | |
2493 | terminal no monitor | |
2494 | (cmd_init): Do not install service_terminal_length_cmd into | |
2495 | ENABLE_NODE. | |
2496 | ||
2497 | * vty.c (terminal_no_monitor): no terminal length -> terminal no | |
2498 | length. | |
2499 | ||
2500 | 2000-08-17 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2501 | ||
2502 | * zebra-0.88 is released. | |
2503 | ||
2504 | 2000-08-17 Magnus Ahltorp <ahltorp@nada.kth.se> | |
2505 | ||
2506 | * vty.h (struct vty ): Add iac_sb_in_progress and sb_buffer for | |
2507 | better IAC handling. | |
2508 | ||
2509 | * vty.c (vty_telnet_option): Change telnet option handling. | |
2510 | ||
2511 | 2000-08-15 Gleb Natapov <gleb@nbase.co.il> | |
2512 | ||
2513 | * zclient.c (zclient_redistribute_unset): New function added. | |
2514 | ||
2515 | 2000-08-14 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2516 | ||
2517 | * zclient.c (zebra_interface_add_read): Change ifindex restore | |
2518 | size from two octet to four. | |
2519 | (zebra_interface_state_read): Likewise. | |
2520 | (zebra_interface_address_add_read): Likewise. | |
2521 | ||
2522 | 2000-08-13 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2523 | ||
2524 | * vty.c (vty_event): Use vector_set_index() instead of | |
2525 | vector_set(). | |
2526 | ||
2527 | 2000-08-07 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2528 | ||
2529 | * zebra.h (ZEBRA_XXX_DISTANCE_DEFAULT): Define Default | |
2530 | Administrative Distance of each protocol. | |
2531 | ||
2532 | 2000-08-07 Matthew Grant <grantma@anathoth.gen.nz> | |
2533 | ||
2534 | * if.h (struct interface ): Add new member bandwidth to struct | |
2535 | interface. | |
2536 | ||
2537 | * zclient.c (zebra_interface_add_read): Fetch bandwidth value. | |
2538 | (zebra_interface_state_read): Likewise. | |
2539 | ||
2540 | 2000-08-07 Gleb Natapov <gleb@nbase.co.il> | |
2541 | ||
2542 | * routemap.c (route_map_event_hook): New hook route_map_event_hook | |
2543 | is added. This hook is called when route-map is changed. The | |
2544 | parameters passed to the hook are 'event' and 'route-map name' | |
2545 | ||
2546 | * routemap.h: Add prototype for route_map_event_hook(). | |
2547 | ||
2548 | 2000-08-06 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2549 | ||
2550 | * zclient.c (zebra_ipv4_route): zebra_ipv4_route(), | |
2551 | zebra_ipv4_add(), zebra_ipv4_delete() are removed. | |
2552 | ||
2553 | * routemap.c (route_map_empty): Add new function. | |
2554 | (route_map_delete): Use route_map_index_delete() instead of | |
2555 | route_map_index_free(). | |
2556 | (route_map_index_free): Function removed. | |
2557 | ||
2558 | 2000-08-06 Gleb Natapov <gleb@nbase.co.il> | |
2559 | ||
2560 | * routemap.c (route_map_index_delete): Add check for route-map is | |
2561 | empty or not. | |
2562 | ||
2563 | 2000-08-03 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2564 | ||
2565 | * zclient.c (zebra_ipv4_add): Change socket arguemnt with struct | |
2566 | zclient. | |
2567 | ||
2568 | 2000-08-02 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2569 | ||
2570 | * zclient.h (struct zebra): Add obuf for output buffer. | |
2571 | ||
2572 | * if.c: Remove #ifdef NRL enclosing if_nametoindex() and | |
2573 | if_indextoname(). | |
2574 | ||
2575 | 2000-08-02 David Lipovkov <davidl@nbase.co.il> | |
2576 | ||
2577 | * if.h (IF_PSEUDO_UNSET): IF_PSEUDO related macro added. | |
2578 | (IF_UNKNOWN_SET): IF_UNKNOWN related macro deleted. | |
2579 | ||
2580 | * if.c (interface_pseudo): Add "pseudo" command to interface node. | |
2581 | (no_interface_pseudo): Add "no pseudo" command to interface node. | |
2582 | ||
2583 | * zclient.c (zebra_interface_add_read): Set pseudo flag when it is | |
2584 | send from zebra. | |
2585 | ||
2586 | 2000-08-01 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2587 | ||
2588 | * zebra.h (ZEBRA_IPV4_NEXTHOP_LOOKUP): Add new message. | |
2589 | (ZEBRA_IPV6_NEXTHOP_LOOKUP): Likewise. | |
2590 | ||
2591 | * vty.c (vty_serv_un): Use AF_UNIX for backward compatibility. | |
2592 | ||
2593 | 2000-07-31 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2594 | ||
2595 | * vty.c: Use vector for VTY server thread listing instead of | |
2596 | single value. | |
2597 | ||
2598 | 2000-07-30 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2599 | ||
2600 | * keychain.c (no_key_chain): "no key chain WORD" command is added. | |
2601 | ||
2602 | 2000-07-29 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2603 | ||
2604 | * command.c (config_from_file): If command fail in | |
2605 | KEYCHAIN_KEY_NODE, down to KEYCHAIN_NODE. | |
2606 | ||
2607 | * vty.h (struct vty ): Add index_sub member. | |
2608 | ||
2609 | 2000-07-27 Akihiro Mizutani <mizutani@dml.com> | |
2610 | ||
2611 | * if.c: Help strings updates. | |
2612 | ||
2613 | 2000-07-11 Akihiro Mizutani <mizutani@dml.com> | |
2614 | ||
2615 | * command.c (no_config_enable_password): Add "no enable password" | |
2616 | command. | |
2617 | (config_write_host): Display password string. | |
2618 | ||
2619 | * routemap.c (route_map_delete_match): Add support for delete | |
2620 | match without argument. | |
2621 | (route_map_delete_set): Likewise. | |
2622 | ||
2623 | 2000-07-09 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2624 | ||
2625 | * command.h (node_type ): Change KEYCHAIN_NODE and | |
2626 | KEYCHAIN_KEY_NODE place just before INTERFACE_NODE. | |
2627 | ||
2628 | 2000-07-09 Jochen Friedrich <jochen@scram.de> | |
2629 | ||
2630 | * smux.c (config_write_smux): Fixes the option to override OID and | |
2631 | password for SMUX. | |
2632 | ||
2633 | 2000-07-09 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2634 | ||
2635 | * command.h (node_type ): Add SMUX_NODE for SMUX configuration. | |
2636 | ||
2637 | 2000-07-09 Toshiaki Takada <takada@zebra.org> | |
2638 | ||
2639 | * command.c: Sort descvec command's help. | |
2640 | ||
2641 | * vty.c (vty_describe_command): Display '<cr>' at the end of | |
2642 | descriptions. | |
2643 | ||
2644 | 2000-07-05 Toshiaki Takada <takada@zebra.org> | |
2645 | ||
2646 | * command.c (cmd_ipv6_match), (cmd_ipv6_prefix_match): Fix bug | |
2647 | treatment of double colon. | |
2648 | ||
2649 | 2000-07-04 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2650 | ||
2651 | * zclient.h: Add zclient_redistribute_default_{set,unset}(). | |
2652 | ||
2653 | * keychain.c: New file for authentication key management. | |
2654 | * keychain.h: Likewise. | |
2655 | ||
2656 | * tcpfilter.c: New file for TCP/UDP base filtering using ipfw or | |
2657 | ipchains. | |
2658 | * tcpfilter.h: Likewise. | |
2659 | ||
2660 | * flap.h: New file for route flap dampening. | |
2661 | * flap.c: Likewise. | |
2662 | ||
2663 | 2000-07-04 Toshiaki Takada <takada@zebra.org> | |
2664 | ||
2665 | * filter.c (struct filter): Add exact flag. | |
2666 | (access_list): Add exact-match command. | |
2667 | (ipv6_access_list): Add exact-match command. | |
2668 | ||
2669 | 2000-07-03 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2670 | ||
2671 | * zebra.h (ZEBRA_REDISTRIBUTE_DEFAULT_ADD): New message for | |
2672 | request default route. | |
2673 | ||
2674 | 2000-07-01 Hideaki YOSHIFUJI (\e$B5HF#1QL@\e(B) <yoshfuji@ecei.tohoku.ac.jp> | |
2675 | ||
2676 | * smux.c: Add IPv6 smux connection code. | |
2677 | ||
2678 | 2000-06-15 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2679 | ||
2680 | * vty.c (vty_complete_command): To cooperate readline library, | |
2681 | returned string is newly allocated. So some match function case | |
2682 | need, free of memory. | |
2683 | ||
2684 | 2000-06-12 Akihiro Mizutani <mizutani@dml.com> | |
2685 | ||
2686 | * distribute.c: Fix help strings. | |
2687 | ||
2688 | 2000-06-11 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2689 | ||
2690 | * command.c (cmd_complete_command): Add check for vector_slot | |
2691 | (vline, index) is not NULL when calculating lcd. | |
2692 | (cmd_entry_function): First check variable arguemnt to prevent it | |
2693 | from completion. | |
2694 | ||
2695 | 2000-06-10 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2696 | ||
2697 | * vty.h (struct vty ): Add output_count member for displaying | |
2698 | output route count. Remove arugment arg from output_func because | |
2699 | the value is passed by vty argument. Change output to output_rn. | |
2700 | Add output_clean function pointer member. Add output_type member. | |
2701 | ||
2702 | 2000-06-10 Toshiaki Takada <takada@zebra.org> | |
2703 | ||
2704 | * command.c (show_startup_config): Add "show startup-config" | |
2705 | command. | |
2706 | ||
2707 | 2000-06-06 Akihiro Mizutani <mizutani@dml.com> | |
2708 | ||
2709 | * filter.c: Fix help strings. | |
2710 | ||
2711 | 2000-06-05 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2712 | ||
2713 | * prefix.h (struct prefix_rd): New prefix structure for routing | |
2714 | distinguisher. | |
2715 | (struct prefix): Add padding to every prefix structure. | |
2716 | ||
2717 | ||
2718 | * routemap.c (route_map_add_match): When completely same match | |
2719 | statement exists, don't duplicate it. | |
2720 | ||
2721 | 2000-06-05 Akihiro Mizutani <mizutani@dml.com> | |
2722 | ||
2723 | * routemap.c: Change NAME to WORD. | |
2724 | ||
2725 | * plist.c: Fix help strings. | |
2726 | ||
2727 | 2000-06-02 Akihiro Mizutani <mizutani@dml.com> | |
2728 | ||
2729 | * routemap.c: Fix route-map help strings. | |
2730 | ||
2731 | 2000-06-01 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2732 | ||
2733 | * command.c (cmd_filter_by_completion): Fix CMD_VARARG treatment | |
2734 | to filter other non vararg commands. | |
2735 | ||
2736 | * routemap.c (route_map_init_vty): Use install_default() for | |
2737 | install common commands into route-map node.. | |
2738 | ||
2739 | 2000-06-01 Akihiro Mizutani <mizutani@dml.com> | |
2740 | ||
2741 | * command.h (OSPF_STR): Macro added. | |
2742 | ||
2743 | 2000-05-31 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2744 | ||
2745 | * command.c (cmd_complete_command): LCD completion must not modify | |
2746 | installed command string. | |
2747 | ||
2748 | * plist.c (ipv6_prefix_list): Fix wrong syntax definition. Change | |
2749 | X:X::X:X to X:X::X:X/M. | |
2750 | ||
2751 | 2000-05-31 Toshiaki Takada <takada@zebra.org> | |
2752 | ||
2753 | * vty.c (show_history): New defun added. | |
2754 | ||
2755 | 2000-05-30 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2756 | ||
2757 | * command.h (CMD_COMPLETE_LIST_MATCH): New define for completion | |
2758 | list. CMD_COMPLETE_MATCH is used for LCD completion. | |
2759 | ||
2760 | * vty.c (vty_complete_command): Matched string's LCD is completed. | |
2761 | ||
2762 | * command.c (cmd_lcd): New function for calculate LCD of matched | |
2763 | strings. | |
2764 | ||
2765 | 2000-05-26 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2766 | ||
2767 | * command.c (install_default): config_write_terminal_cmd, | |
2768 | config_write_file_cmd, config_write_memory_cmd are added to | |
2769 | default node. | |
2770 | ||
2771 | * memory.c (memory_init): Divide show memory command into each | |
2772 | sort. | |
2773 | ||
2774 | * command.c (cmd_init): config_write_terminal_cmd, | |
2775 | config_write_file_cmd, config_write_memory_cmd are added to | |
2776 | CONFIG_NODE. | |
2777 | ||
2778 | * routemap.c (route_map_index_free): New function. | |
2779 | (no_route_map_all): New DEFUN for "no route-map NAME". | |
2780 | ||
2781 | * filter.c (no_access_list_all): New DEFUN for delete access-list | |
2782 | with NAME. | |
2783 | (no_ipv6_access_list_all): Likewise. | |
2784 | ||
2785 | 2000-05-23 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2786 | ||
2787 | * plist.c: Change IPV6_PREFIX to X:X::X:X. When "any" is | |
2788 | specified, user can not use "ge" and "le" statement. | |
2789 | ||
2790 | 2000-05-22 Thomas Molkenbur <tmo@datus.datus.com> | |
2791 | ||
2792 | * routemap.c (route_map_add_set): Fix bug of next pointer missing. | |
2793 | ||
2794 | * table.c (route_table_free): Like wise. | |
2795 | ||
2796 | 2000-05-22 Toshiaki Takada <takada@zebra.org> | |
2797 | ||
2798 | * vty.c (vty_stop_input): Set history pointer to the latest one. | |
2799 | ||
2800 | * vty.c (vty_hist_add): Do not add command line history when input | |
2801 | is as same as previous one. | |
2802 | ||
2803 | 2000-05-14 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2804 | ||
2805 | * memory.h (enum): Add MTYPE_ECOMMUNITY and MTYPE_ECOMMUNITY_VAL. | |
2806 | ||
2807 | 2000-05-13 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2808 | ||
2809 | * command.h (node_type ): Add BGP_VPNV4_NODE. | |
2810 | ||
2811 | 2000-05-08 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2812 | ||
2813 | * vty.c (vtysh_accept): Add cast of struct sockaddr * to bind | |
2814 | argument. Reported by: Vesselin Mladenov <mladenov@netbg.com>. | |
2815 | ||
2816 | * filter.c (ipv6_access_list): Add IPv6 prefix example instead of | |
2817 | IPv4 example. Reported by: Love <lha@s3.kth.se>. | |
2818 | ||
2819 | * command.c (cmd_complete_command): Make it sure last element of | |
2820 | matchvec is NULL. This fix problem which cause crush in | |
2821 | vty_complete_command(). Reported by: JINMEI Tatuya | |
2822 | <jinmei@isl.rdc.toshiba.co.jp>. | |
2823 | ||
2824 | 2000-04-28 Love <lha@s3.kth.se> | |
2825 | ||
2826 | * prefix.h (struct prefix): Add padding. | |
2827 | ||
2828 | 2000-04-28 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2829 | ||
2830 | * command.c (show_version): Update copyright year. | |
2831 | ||
2832 | 2000-04-27 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2833 | ||
2834 | * routemap.c (route_map_apply): When map is NULL, return deny. | |
2835 | ||
2836 | 2000-04-26 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2837 | ||
2838 | * filter.c (access_list_apply): When access is NULL, return deny. | |
2839 | ||
2840 | * plist.c (prefix_list_apply): When plist is NULL, return deny. | |
2841 | ||
2842 | 2000-04-23 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2843 | ||
2844 | * command.h (node_type ): Change RDISC_NODE to IRDP_NODE. | |
2845 | ||
2846 | 2000-04-18 Toshiaki Takada <takada@zebra.org> | |
2847 | ||
2848 | * filter.[ch] (access_list_add_hook), (access_list_delete_hook): | |
2849 | Add argument for hook function to give struct access_list *. | |
2850 | ||
2851 | 2000-04-17 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2852 | ||
2853 | * plist.c (prefix_list_entry_match): In case of le nor ge is | |
2854 | specified, exact match is performed. | |
2855 | (prefix_list_entry_match): Add any entry matching check. | |
2856 | ||
2857 | 2000-04-09 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2858 | ||
2859 | * vty.c (exec_timeout): Separate timeout setting to minutes and | |
2860 | seconds. | |
2861 | (no_exec_timeout): Add "no exec-timeout" command. | |
2862 | ||
2863 | * vty.h (VTY_TIMEOUT_DEFAULT): Change default value from 300 to | |
2864 | 600. | |
2865 | ||
2866 | 2000-03-31 Jochen Friedrich <jochen@scram.de> | |
2867 | ||
2868 | * smux.h (SMUX_CLOSE): The SMUX_CLOSE PDU is implicit integer, so | |
2869 | it is a primitive encoding and not constructed. | |
2870 | ||
2871 | 2000-03-28 Toshiaki Takada <takada@zebra.org> | |
2872 | ||
2873 | * memory.[ch] (enum): Add MTYPE_OSPF_EXTERNAL_INFO. | |
2874 | ||
2875 | 2000-03-26 Love <lha@s3.kth.se> | |
2876 | ||
2877 | * zclient.c (zclient_read): Add nbytes size check for | |
2878 | ZEBRA_HEADER_SIZE. Check return value of steam_read (). | |
2879 | ||
2880 | 2000-03-26 Rick Payne <rickp@rossfell.co.uk> | |
2881 | ||
2882 | * routemap.c: Add flexible route-map commands such as on-match | |
2883 | next, on-match goto N. | |
2884 | ||
2885 | * routemap.h: Likewise | |
2886 | ||
2887 | 2000-03-23 Adrian Bool <aid@u.net.uk> | |
2888 | ||
2889 | * command.c (config_log_trap): Add new command "log trap | |
2890 | PRIORITY". | |
2891 | ||
2892 | 2000-03-14 Toshiaki Takada <takada@zebra.org> | |
2893 | ||
2894 | * memory.c (struct memory_list): Add Link List and Link Node | |
2895 | to view. | |
2896 | ||
2897 | * memory.h (enum): Remove MTYPE_OSPF_EXTERNAL_ROUTE. | |
2898 | ||
2899 | 2000-01-20 Hideto Yamakawa <hideto.yamakawa@soliton.co.jp> | |
2900 | ||
2901 | * str.c (snprintf): Fix bug of calling sprintf instead of | |
2902 | vsprintf. | |
2903 | ||
2904 | 2000-01-16 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2905 | ||
2906 | * memory.h (enum): Add MTYPE_RIP_PEER. | |
2907 | ||
2908 | 2000-01-15 Toshiaki Takada <takada@zebra.org> | |
2909 | ||
2910 | * memory.h (enum): Add MTYPE_OSPF_CRYPT_KEY. | |
2911 | ||
2912 | 2000-01-15 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2913 | ||
2914 | * command.h (node_type ): Add MASC_NODE for masc. | |
2915 | ||
2916 | 2000-01-09 Wang Jianliang <wangjl@soim.net> | |
2917 | ||
2918 | * routemap.c (route_map_index_add): When route_map_index is not | |
2919 | empty and insert new item at the head, it can cause core dump. | |
2920 | Fix "if (index == map->head)" to "if (point == map->head). | |
2921 | (route_map_add_set): If there is an old set command, override old | |
2922 | set command with new one. | |
2923 | (route_map_index_delete): Use while() instead of for for() for | |
2924 | logical correctness. | |
2925 | ||
2926 | 1999-12-26 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2927 | ||
2928 | * memory.h (enum): Add MTYPE_BGP_STATIC. | |
2929 | ||
2930 | 1999-12-23 Alex Zinin <zinin@amt.ru> | |
2931 | * zebra.h, zclient.*: dynamic int up/down message | |
2932 | support | |
2933 | ||
2934 | 1999-12-10 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2935 | ||
2936 | * thread.c (thread_cancel_event): Add a function for clean up | |
2937 | events. | |
2938 | ||
2939 | 1999-12-09 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2940 | ||
2941 | * dropline.c: Delete file. | |
2942 | dropline.h: Linewise. | |
2943 | ||
2944 | 1999-12-14 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2945 | ||
2946 | * filter.c (access_list_filter_delete): Wrong pointer | |
2947 | access->master was pointed out after access is freed. I store | |
2948 | master value at the beginning of the function. | |
2949 | ||
2950 | 1999-12-08 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2951 | ||
2952 | * vty.c (exec_timeout): Change of VTY timeout affect to current | |
2953 | VTY connection. | |
2954 | (vty_accept): Instead of immediate exit() return -1. | |
2955 | ||
2956 | 1999-12-07 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2957 | ||
2958 | * vty.c (vty_configure_lock): Configuration lock function added. | |
2959 | Only one VTY can use CONFI_NODE at the same time. | |
2960 | ||
2961 | * log.c: Delete zvlog_* functions. Now zlog_* does the same | |
2962 | thing. | |
2963 | ||
2964 | * log.c (log_init): Function removed. | |
2965 | (log_close): Likewise. | |
2966 | (log_flush): Likewise. | |
2967 | (log_open): Likewise. | |
2968 | ||
2969 | * vty.c (terminal_monitor): Add new command. | |
2970 | (no_terminal_monitor): Likewise. | |
2971 | ||
2972 | * log.c (old_log): Function removed. | |
2973 | (old_log2): Likewise. | |
2974 | (old_log_warn): Likewise. | |
2975 | ||
2976 | 1999-12-04 Toshiaki Takada <takada@zebra.org> | |
2977 | ||
2978 | * command.c (cmd_ipv6_match): New function added. | |
2979 | (cmd_ipv6_prefix_match): Likewise. | |
2980 | ||
2981 | 1999-12-04 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2982 | ||
2983 | * command.c (cmd_ipv6_match): | |
2984 | ||
2985 | * table.c: Delete #ifdef HAVE_MBGPV4. | |
2986 | ||
2987 | * prefix.h (struct prefix): Add safi member. | |
2988 | (struct prefix_ipv4): Likewise. | |
2989 | (struct prefix_ipv6): Likewise. | |
2990 | ||
2991 | 1999-12-04 Rumen Svobodnikov <rumen@linux.tu-varna.acad.bg> | |
2992 | ||
2993 | * memory.c (struct mstat): Revert to support MEMORY_LOG. | |
2994 | ||
2995 | 1999-11-25 Kunihiro Ishiguro <kunihiro@zebra.org> | |
2996 | ||
2997 | * version.h: Bump up to 0.81c for testing new kernel codes. | |
2998 | ||
2999 | 1999-11-21 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3000 | ||
3001 | * thread.h (struct thread): Pthread support is disabled all | |
3002 | platform. | |
3003 | ||
3004 | 1999-11-21 Michael Handler <handler@sub-rosa.com> | |
3005 | ||
3006 | * Include <limits.h> and <strings.h> under SUNOS_5. | |
3007 | ||
3008 | 1999-11-21 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3009 | ||
3010 | * sockunion.c (in6addr_cmp): Enclosed by #define HAVE_IPV6 | |
3011 | 1999-11-13 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3012 | ||
3013 | * command.h (node_type ): Add BGP_IPV4_NODE and BGP_IPV6_NODE. | |
3014 | ||
3015 | 1999-11-12 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3016 | ||
3017 | * command.c (disable): Add `disable' command. | |
3018 | ||
3019 | 1999-11-09 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3020 | ||
3021 | * plist.c (vty_prefix_list_install): Add any check. | |
3022 | ||
3023 | 1999-11-04 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3024 | ||
3025 | * command.h (node_type ): Add DUMP_NODE. | |
3026 | ||
3027 | 1999-11-03 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3028 | ||
3029 | * smux.c: Change default SMUX oid to compatible with gated. | |
3030 | ||
3031 | 1999-10-30 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3032 | ||
3033 | * if_rmap.c: New file added. | |
3034 | ||
3035 | * if_rmap.h: New file added. | |
3036 | ||
3037 | 1999-10-29 Alex Zinin <zinin@amt.ru> | |
3038 | ||
3039 | * hash.c: add hash_free() function | |
3040 | ||
3041 | 1999-10-25 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3042 | ||
3043 | * hash.c (hash_clean): Add clean function. | |
3044 | ||
3045 | * plist.c (prefix_list_reset): Add reset function. | |
3046 | ||
3047 | * filter.c (access_list_reset): Add reset function. | |
3048 | ||
3049 | 1999-10-17 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3050 | ||
3051 | * client.c: Merged with zclient.c. | |
3052 | * client.h: Merged with zclient.h. | |
3053 | ||
3054 | 1999-10-15 Jordan Mendelson <jordy@wserv.com> | |
3055 | ||
3056 | * md5.c: Imported from GNU C Library. | |
3057 | * md5-gnu.h: Likewise. | |
3058 | ||
3059 | 1999-10-15 Jochen Friedrich <jochen@scram.de> | |
3060 | ||
3061 | * smux.c (smux_getresp_send): SMUX_GETRSP codes improvement. | |
3062 | ||
3063 | 1999-10-06 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3064 | ||
3065 | * smux.h: New file added. | |
3066 | ||
3067 | * snmp.c: Rename to smux.c. | |
3068 | ||
3069 | 1999-10-02 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3070 | ||
3071 | * command.c (cmd_execute_command_strict): Filter ambious commands. | |
3072 | (cmd_filter_by_string): Change to return enum match_type. | |
3073 | ||
3074 | 1999-10-01 Toshiaki Takada <takada@zebra.org> | |
3075 | ||
3076 | * vty.c (vty_describe_fold): New function which does VTY | |
3077 | description line fold. | |
3078 | * vty.c (vty_describe_command): Set description column. | |
3079 | ||
3080 | 1999-09-30 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3081 | ||
3082 | * plist.c (prefix_list_init_ipv4): VTY user interface is improved. | |
3083 | ||
3084 | 1999-09-26 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3085 | ||
3086 | * command.c (cmd_filter_by_string): Fix bug of CMD_IPV4 and | |
3087 | CMD_IPV4_PREFIX check. Both return type must be exact_match. | |
3088 | ||
3089 | 1999-09-24 Toshiaki Takada <takada@zebra.org> | |
3090 | ||
3091 | * command.c (cmd_filter_by_completion), | |
3092 | (is_cmd_ambiguous): Check IPv4 address, IPv4 prefix and range | |
3093 | parameter matches range. | |
3094 | ||
3095 | 1999-09-22 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3096 | ||
3097 | * routemap.c (route_map_apply): Returm RM_DENYMATCH when no match | |
3098 | is performed. | |
3099 | ||
3100 | 1999-09-21 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3101 | ||
3102 | * vty.c (vty_read): Control-C stop VTY_MORE mode. | |
3103 | ||
3104 | 1999-09-20 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3105 | ||
3106 | * command.h (node_type ): Add ACCESS_IPV6_NODE and | |
3107 | PREFIX_IPV6_NODE. | |
3108 | ||
3109 | * distribute.h: New file added. | |
3110 | ||
3111 | * command.h (node_type ): Delete DISTRIBUTE_NODE. | |
3112 | ||
3113 | 1999-09-18 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3114 | ||
3115 | * vty.c (vty_terminate_all): New function added for reload | |
3116 | support. | |
3117 | ||
3118 | 1999-09-06 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3119 | ||
3120 | * memory.h (enum): Add new type MTYPE_OSPF_EXTERNAL_ROUTE. | |
3121 | ||
3122 | 1999-08-31 Janos Farkas <chexum@shadow.banki.hu> | |
3123 | ||
3124 | * vty.c (vty_read): Handle also 0x7f (alt-backspace), just like | |
3125 | esc-ctrl-h (delete word backwards). | |
3126 | ||
3127 | 1999-08-24 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3128 | ||
3129 | * if.h: Add if_nametoindex for NRL. | |
3130 | ||
3131 | 1999-08-23 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3132 | ||
3133 | * if.c (if_create): New function. | |
3134 | ||
3135 | 1999-08-22 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3136 | ||
3137 | * snmp.c: New file. | |
3138 | ||
3139 | 1999-08-21 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3140 | ||
3141 | * stream.c (stream_put): stream_memcpy () is changed to stream_put | |
3142 | (). stream_get () is added. | |
3143 | ||
3144 | 1999-08-18 Toshiaki Takada <takada@zebra.org> | |
3145 | ||
3146 | * memory.h (enum): Add MTYPE_OSPF_LSA_DATA. | |
3147 | ||
3148 | 1999-08-18 Yasuhiro Ohara <yasu@sfc.wide.ad.jp> | |
3149 | ||
3150 | * table.c (route_table_finish): add function frees table. | |
3151 | ||
3152 | 1999-08-12 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3153 | ||
3154 | * memory.h (enum): Add MTYPE_RTADV_PREFIX. | |
3155 | ||
3156 | 1999-08-11 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3157 | ||
3158 | * if.h (struct interface ): hw_address, hw_address_len added. | |
3159 | ||
3160 | 1999-08-10 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3161 | ||
3162 | * if.h (struct interface ): Change structure member if_data to | |
3163 | info, index to ifindex. | |
3164 | ||
3165 | 1999-08-08 Rick Payne <rickp@rossfell.co.uk> | |
3166 | ||
3167 | * routemap.c: Multi protocol route-map modification. | |
3168 | ||
3169 | * routemap.c (route_map_apply): Route match process bug is fixed. | |
3170 | ||
3171 | 1999-08-05 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3172 | ||
3173 | * thread.c (thread_fetch): When signal comes, goto retry point. | |
3174 | ||
3175 | 1999-08-04 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3176 | ||
3177 | * Makefile.am: Add sockopt.c and sockopt.h | |
3178 | * sockopt.c: New file. | |
3179 | * sockopt.h: New file. | |
3180 | ||
3181 | 1999-08-02 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3182 | ||
3183 | * version.h (ZEBRA_VERSION): Release zebra-0.75 | |
3184 | ||
3185 | 1999-08-01 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3186 | ||
3187 | * memory.h (enum): Add MTYPE_RIPNG_AGGREGATE. | |
3188 | ||
3189 | 1999-07-31 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3190 | ||
3191 | * sockunion.h: Add sockunion_getpeername (). | |
3192 | ||
3193 | 1999-07-27 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3194 | ||
3195 | * version.h: Release zebra-0.74 | |
3196 | ||
3197 | 1999-07-26 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3198 | ||
3199 | * command.h (struct host): Delete lines from struct host. Add | |
3200 | lines to struct vty. | |
3201 | ||
3202 | * command.c: Delete `lines LINES'. Terminal display line settings | |
3203 | should be done by `terminal length' command. | |
3204 | ||
3205 | 1999-07-24 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3206 | ||
3207 | * memory.h (enum): MTYPE_OSPF_PATH are added. | |
3208 | ||
3209 | 1999-07-22 Toshiaki Takada <takada@zebra.org> | |
3210 | ||
3211 | * memory.h (enum): MTYPE_OSPF_NEXTHOP is added. | |
3212 | ||
3213 | 1999-07-21 Toshiaki Takada <takada@zebra.org> | |
3214 | ||
3215 | * linklist.c (list_add_node_prev), (list_add_node_next), | |
3216 | (list_add_list): New function added. | |
3217 | ||
3218 | * table.c (route_table_free): New function added. | |
3219 | ||
3220 | 1999-07-21 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3221 | ||
3222 | * plist.c (config_write_prefix): Set write flag when configuration | |
3223 | is written. | |
3224 | ||
3225 | 1999-07-15 Yasuhiro Ohara <yasu@sfc.wide.ad.jp> | |
3226 | ||
3227 | * prefix.c : prefix_cmp() added. change apply_mask() to | |
3228 | apply_mask_ipv4(), and new apply_mask() added. | |
3229 | ||
3230 | 1999-07-14 Yasuhiro Ohara <yasu@sfc.wide.ad.jp> | |
3231 | ||
3232 | * prefix.c (prefix2str): append prefixlen. | |
3233 | ||
3234 | 1999-07-13 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3235 | ||
3236 | * command.c (config_terminal): Change "config terminal" to | |
3237 | "configure terminal". Reported by Georg Hitsch | |
3238 | <georg@atnet.at>. | |
3239 | (config_terminal_length): `terminal length <0-512>' is added. At | |
3240 | this moment this command is only usef for vty interface. | |
3241 | Suggested by Georg Hitsch <georg@atnet.at>. | |
3242 | ||
3243 | 1999-07-12 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3244 | ||
3245 | * routemap.c (rulecmp): Add wrapper function of strcmp. | |
3246 | ||
3247 | 1999-07-08 Rick Payne <rickp@rossfell.co.uk> | |
3248 | ||
3249 | * sockunion.c (inet_aton): Fix bug of inet_aton. | |
3250 | ||
3251 | 1999-07-08 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3252 | ||
3253 | * version.h (ZEBRA_VERSION): Start zebra-0.73 | |
3254 | ||
3255 | 1999-07-06 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3256 | ||
3257 | * version.h: Bump up to 0.72. | |
3258 | ||
3259 | 1999-07-05 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3260 | ||
3261 | * command.c (install_default): New function for install default | |
3262 | commands to the node. | |
3263 | ||
3264 | * memory.h (enum): MTYPE_NEXTHOP is added. | |
3265 | ||
3266 | 1999-07-01 <kunihiro@zebra.org> | |
3267 | ||
3268 | * command.c (no_banner_motd): `no banner motd' command added. | |
3269 | ||
3270 | 1999-06-30 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3271 | ||
3272 | * regex.c: Update to glibc-2.1.1's posix/regex.c | |
3273 | ||
3274 | * regex-gnu.h: Update to glibc-2.1.1's posix/regex.h | |
3275 | ||
3276 | * prefix.h (IPV4_ADDR_SAME): Macro added. | |
3277 | (IPV6_ADDR_SAME): Likewise. | |
3278 | ||
3279 | 1999-06-29 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3280 | ||
3281 | * memory.h (enum): Add MTYPE_OSPF_VERTEX | |
3282 | ||
3283 | * version.h: Bump up to 0.71. | |
3284 | ||
3285 | * vty.c (vty_serv_sock_addrinfo): Use addrinfo function to bind | |
3286 | VTY socket when IPv6 is enabled. | |
3287 | ||
3288 | 1999-06-28 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3289 | ||
3290 | * vty.c (vty_serv_sock): Change vty_serv_sock determine which | |
3291 | address family to bind. | |
3292 | ||
3293 | * command.c: Add quit command. | |
3294 | ||
3295 | 1999-06-26 NOGUCHI kay <kay@dti.ad.jp> | |
3296 | ||
3297 | * vty.c (vty_read_config): Fix bug of configuration file path | |
3298 | detection. | |
3299 | ||
3300 | 1999-06-25 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3301 | ||
3302 | * version.h: Bump up to 0.70. | |
3303 | ||
3304 | 1999-06-17 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3305 | ||
3306 | * buffer.h (GETL): Remove GETL macro. | |
3307 | ||
3308 | * version.h: Bump up to 0.69. | |
3309 | ||
3310 | 1999-06-14 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3311 | ||
3312 | * if.c (connected_add): Commented out connected_log. | |
3313 | ||
3314 | 1999-06-13 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3315 | ||
3316 | * command.h (struct cmd_element ): strvec and descvec is combined | |
3317 | into newstrvec. | |
3318 | ||
3319 | * command.c (desc_make): Function removed. | |
3320 | (desc_next): Function removed. | |
3321 | ||
3322 | * command.h (struct cmd_element ): docvec is removed from struct | |
3323 | cmd_element. | |
3324 | ||
3325 | 1999-06-12 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3326 | ||
3327 | * command.c (cmd_execute_command): Remove command NULL check. | |
3328 | ||
3329 | * command.h (struct cmd_element ): Add newstrvec entry to struct | |
3330 | cmd_element. | |
3331 | (DEFUN2): DEFUN2 macro is removed. DEFUN is extended to support | |
3332 | (a|b|c) statement. | |
3333 | (DESC): DESC macro is removed. | |
3334 | ||
3335 | * vty.c (vty_complete_command): When return value is | |
3336 | CMD_ERR_NO_MATCH, don't display error message. | |
3337 | ||
3338 | 1999-06-08 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3339 | ||
3340 | * table.c (route_next_until): New function. | |
3341 | ||
3342 | * version.h: Bump up to 0.68. | |
3343 | ||
3344 | 1999-06-06 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3345 | ||
3346 | * vty.c (vty_close): Free vty->buf when vty is closed. | |
3347 | ||
3348 | * memory.h (enum): Add MTYPE_COMMUNITY_ENTRY and | |
3349 | MTYPE_COMMUNITY_LIST. | |
3350 | ||
3351 | * vty.h (struct vty ): Change buf from static length buffer to | |
3352 | variable length buffer. | |
3353 | ||
3354 | * vty.c (vty_ensure): New function added. | |
3355 | ||
3356 | 1999-06-04 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3357 | ||
3358 | * command.h (node_type ): Add COMMUNITY_LIST_NODE. | |
3359 | ||
3360 | * command.c (config_enable_password): Freeing host.enable bug is | |
3361 | fixed. | |
3362 | (config_enable_password): Add argc count check. | |
3363 | ||
3364 | 1999-05-31 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3365 | ||
3366 | * version.h: Bump up to 0.67. | |
3367 | ||
3368 | 1999-05-30 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3369 | ||
3370 | * command.c (zencrypt): New function for encrypt password. | |
3371 | ||
3372 | * command.h (struct host): Add password_encrypt and | |
3373 | enable_encrypt. | |
3374 | ||
3375 | 1999-05-30 Jochen Friedrich <jochen@scram.de> | |
3376 | ||
3377 | * command.h (struct host): New member encrypt is added for | |
3378 | encrypted password. | |
3379 | ||
3380 | 1999-05-30 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3381 | ||
3382 | * vty.c: Remove all_digit_check function. Instead use all_digit. | |
3383 | ||
3384 | * prefix.c (all_digit): New function for checking string is made | |
3385 | from digit character. | |
3386 | ||
3387 | 1999-05-25 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3388 | ||
3389 | * Makefile.am (libzebra_a_SOURCES): Add zclient.c. | |
3390 | (noinst_HEADERS): Add zclient.h | |
3391 | ||
3392 | * zclient.[ch]: New file for zebra client routine. | |
3393 | ||
3394 | * memory.h (enum): Add MTYPE_ZEBRA. | |
3395 | ||
3396 | 1999-05-19 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3397 | ||
3398 | * version.h (ZEBRA_VERSION): Update to 0.66. | |
3399 | ||
3400 | 1999-05-15 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3401 | ||
3402 | * buffer.h (GETC,GETW): Macro deleted. | |
3403 | ||
3404 | 1999-05-15 Carlos Alberto Barcenilla <barce@frlp.utn.edu.ar> | |
3405 | ||
3406 | * prefix.h (IPV4_NET0, IPV4_NET127): Macro added. | |
3407 | ||
3408 | 1999-05-15 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3409 | ||
3410 | * vty.c (service_advanced_vty): New command added. | |
3411 | (no_service_advanced_vty): Likewise. | |
3412 | ||
3413 | 1999-05-14 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3414 | ||
3415 | * vty.c (vty_auth): If advanced flag is set and enable password is | |
3416 | not set, directly login to the ENABLE_NODE. This feature is | |
3417 | originally designed and implemented by Stephen R. van den Berg | |
3418 | <srb@cuci.nl>. | |
3419 | ||
3420 | * command.h (host): Add advanced flag to struct host for advanced | |
3421 | vty terminal interface. | |
3422 | ||
3423 | * version.h (ZEBRA_VERSION): Update to 0.65 for next beta release. | |
3424 | ||
3425 | 1999-05-14 Stephen R. van den Berg <srb@cuci.nl> | |
3426 | ||
3427 | * command.h (node_type ): Add TABLE_NODE. | |
3428 | ||
3429 | * vty.c (vty_telnet_option): Check host.lines value. | |
3430 | ||
3431 | * command.c (config_lines): DEFUN for 'lines LINES' command. | |
3432 | ||
3433 | * zebra.h: Include <sys/utsname.h> for uname(). | |
3434 | (RT_TABLE_MAIN): Defined as 0 if OS does not support multiple | |
3435 | routing table. | |
3436 | ||
3437 | * vty.c (vty_auth): Directly login to the ENABLE_NODE when enable | |
3438 | password is not set. | |
3439 | (vty_prompt): Get machine's hostname when hostname is not set. | |
3440 | ||
3441 | 1999-05-11 James Willard <james@whispering.org> | |
3442 | ||
3443 | * command.c (config_exit): Close connection when `exit' command is | |
3444 | executed at ENABLE_NODE. | |
3445 | ||
3446 | 1999-05-10 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3447 | ||
3448 | * vty.c (vty_stop_input): `C-c' key change node to ENABLE_NODE. | |
3449 | ||
3450 | * command.c (cmd_execute_command_strict): Matched command size | |
3451 | check added. | |
3452 | (cmd_make_desc_line): New function for DEFUN2. | |
3453 | ||
3454 | * command.h (struct cmd_element ): Add descsize. | |
3455 | ||
3456 | 1999-05-09 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3457 | ||
3458 | * command.h (struct cmd_element ): Remame descvec to docvec. | |
3459 | (struct cmd_element ): Add descvec for new description system. | |
3460 | ||
3461 | * command.c (desc_make): Check cmd->descvec. | |
3462 | ||
3463 | 1999-05-06 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3464 | ||
3465 | * memory.h (enum): Add MTYPE_CLUSTER, MTYPE_CLUSTER_VAL. | |
3466 | ||
3467 | 1999-05-05 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3468 | ||
3469 | * version.h (ZEBRA_VERSION): Bump up to 0.64 for next beta | |
3470 | release. | |
3471 | ||
3472 | 1999-05-04 Yasuhiro Ohara <yasu@sfc.wide.ad.jp> | |
3473 | ||
3474 | * linklist.c (list_delete_all_node): bug fix. | |
3475 | previous code loses current position when node | |
3476 | is deleted. | |
3477 | ||
3478 | 1999-05-03 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3479 | ||
3480 | * command.h (DESC): Macro added. | |
3481 | (struct cmd_element2): Delete struct cmd_element2. | |
3482 | ||
3483 | * plist.c (prefix_list): Sequential number option check is added. | |
3484 | ||
3485 | 1999-05-02 Yasuhiro Ohara <yasu@sfc.wide.ad.jp> | |
3486 | ||
3487 | * log.c (zvlog_{debug,info,notice,warn,err}): have been | |
3488 | added. now we can log both console and file, but still | |
3489 | need some fix about config write. | |
3490 | ||
3491 | 1999-05-02 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3492 | ||
3493 | * log.c (zvlog_debug): Fix yasu's change. | |
3494 | ||
3495 | 1999-05-01 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3496 | ||
3497 | * plist.c (prefix_list): Fix typo. | |
3498 | ||
3499 | 1999-04-30 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3500 | ||
3501 | * Set version to 0.63 for first beta package. | |
3502 | ||
3503 | 1999-04-27 Carlos Barcenilla <barce@frlp.utn.edu.ar> | |
3504 | ||
3505 | * prefix.c (str2prefix_ipv4): Fix prefix length check. | |
3506 | (str2prefix_ipv6): Likewise. | |
3507 | ||
3508 | 1999-04-25 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3509 | ||
3510 | * memory.h (enum): Add MTPYE_PREFIX_LIST and | |
3511 | MTYPE_PREFIX_LIST_ENTRY. | |
3512 | ||
3513 | * command.h (node_type ): Add PREFIX_NODE. | |
3514 | ||
3515 | 1999-04-25 Carlos Barcenilla <barce@frlp.utn.edu.ar> | |
3516 | ||
3517 | * command.c: ALIAS (config_write_memory_cmd) and ALIAS | |
3518 | (copy_runningconfig_startupconfig_cmd) is added. | |
3519 | ||
3520 | * table.c (route_node_lookup): Unused match variable deletion. | |
3521 | ||
3522 | 1999-04-24 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3523 | ||
3524 | * Makefile.am (libzebra_a_SOURCES): plist.c added. | |
3525 | (noinst_HEADERS): plist.h added. | |
3526 | ||
3527 | * plist.c, plist.h: New file added. | |
3528 | ||
3529 | * memory.h (enum): Rename MTYPE_AS_PASN to MTYPE_AS_STR. | |
3530 | * memory.c: Likewise. | |
3531 | ||
3532 | 1999-04-19 Carlos Alberto Barcenilla <barce@frlp.utn.edu.ar> | |
3533 | ||
3534 | * command.c (show_version): `show version' command added. | |
3535 | ||
3536 | 1999-04-19 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3537 | ||
3538 | * prefix.c (str2prefix_ipv6): Prefix length overflow check. | |
3539 | ||
3540 | 1999-04-19 Carlos Alberto Barcenilla <barce@frlp.utn.edu.ar> | |
3541 | ||
3542 | * prefix.c (str2prefix_ipv4): Prefix length overflow check. | |
3543 | ||
3544 | 1999-04-19 Alex Bligh <amb@gxn.net> | |
3545 | ||
3546 | * prefix.c (sockunion2hostprefix): Function added. | |
3547 | (sockunion2prefix): Address family was not set. Now it is set. | |
3548 | ||
3549 | * vty.c: VTY access-class command is added. | |
3550 | ||
3551 | 1999-04-18 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3552 | ||
3553 | * memory.c: Change xmalloc to zmalloc. xcalloc, xrealloc, xfree, | |
3554 | xstrdup are likewise. | |
3555 | ||
3556 | 1999-04-18 Yasuhiro Ohara <yasu@sfc.wide.ad.jp> | |
3557 | ||
3558 | * thread.c: Add thread_execute for other routing daemon. | |
3559 | OSPF tasks need to be generated by "sheduled" and "executed". | |
3560 | ||
3561 | 1999-04-13 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3562 | ||
3563 | * buffer.c: Rewrite buffer_write and buffer_flush related | |
3564 | functions for fixing bugs. Reason of the problem and fix is | |
3565 | suggested by Alex Bligh <amb@gxn.net>. | |
3566 | ||
3567 | 1999-04-12 Alex Bligh <amb@gxn.net> | |
3568 | ||
3569 | * command.c (cmd_entry_function_descr): Added for variable | |
3570 | argument help display. | |
3571 | ||
3572 | 1999-04-07 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3573 | ||
3574 | * regex.c, regex-gnu.h: Imported from GNU sed-3.02 distribution. | |
3575 | ||
3576 | 1999-03-24 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3577 | ||
3578 | * stream.c: stream_fifo_free bug is fixed. | |
3579 | ||
3580 | 1999-03-19 Toshiaki Takada <takada@zebra.org> | |
3581 | ||
3582 | * stream.c (stream_strncpy): Added for getting any length bytes | |
3583 | from stream. | |
3584 | ||
3585 | 1999-03-16 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3586 | ||
3587 | * version.h (ZEBRA_BUG_ADDRESS): New macro added. | |
3588 | ||
3589 | 1999-03-14 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3590 | ||
3591 | * buffer.c (buffer_flush_window): If ep is same as buffer's size | |
3592 | length and lp is overrun one octet. | |
3593 | ||
3594 | 1999-03-13 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3595 | ||
3596 | * vty.h: add VTY's timeout function. | |
3597 | ||
3598 | 1999-03-05 <kunihiro@zebra.org> | |
3599 | ||
3600 | * command.h (node_type ): Add OSPF6_node. | |
3601 | ||
3602 | 1999-03-04 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3603 | ||
3604 | * zebra.h: Check HAVE_SYS_SELECT_H when include <sys/select.h> | |
3605 | ||
3606 | 1999-03-03 Jeroen Ruigrok/Asmodai <asmodai@wxs.nl> | |
3607 | ||
3608 | * zebra.h: Include <net/if_var.h> if it exists. | |
3609 | ||
3610 | 1999-03-02 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3611 | ||
3612 | * getopt.[ch],getopt1.c: Sync with glibc-2.1. | |
3613 | ||
3614 | * log.c (zlog): Tempolary ZLOG_STDOUT feature added. | |
3615 | ||
3616 | * command.h: Include vector.h and vty.h | |
3617 | ||
3618 | 1999-02-25 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3619 | ||
3620 | * routemap.h (struct route_map_rule_cmd): Add prefix arguemnt. | |
3621 | ||
3622 | * routemap.c (route_map_apply_index): Add prefix argument. | |
3623 | (route_map_apply): Likewise. | |
3624 | ||
3625 | * memory.h (enum): Add MTYPE_ROUTE_MAP_COMPILED. | |
3626 | ||
3627 | * stream.c: Add stream_fifo related functions. | |
3628 | ||
3629 | 1999-02-24 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3630 | ||
3631 | * daemon.c: Return integer value. File descriptor close is added. | |
3632 | ||
3633 | * memory.h (enum): add MTYPE_OSPF_LSA. | |
3634 | ||
3635 | 1999-02-23 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3636 | ||
3637 | * rsh.c: Remove empty file. | |
3638 | ||
3639 | 1999-02-22 <kunihiro@zebra.org> | |
3640 | ||
3641 | * routemap.c: Add add/delete hook to route_map_master. | |
3642 | ||
3643 | 1999-02-19 Peter Galbavy <Peter.Galbavy@knowledge.com> | |
3644 | ||
3645 | * str.[ch] added to supply wrappers for snprintf(), strlcat() and | |
3646 | strlcpy on system without these. | |
3647 | ||
3648 | 1999-02-18 Peter Galbavy <Peter.Galbavy@knowledge.com> | |
3649 | ||
3650 | * syslog support added | |
3651 | ||
3652 | 1999-02-02 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3653 | ||
3654 | * filter.c (access_list_add_hook): added for hook function management. | |
3655 | * filter.c (access_list_delete_hook): Likewise. | |
3656 | ||
3657 | 1999-01-19 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3658 | ||
3659 | * stream.c: New file. | |
3660 | * stream.h: New file. | |
3661 | * Divide stream related fucntions from buffer.[ch] into stream.[ch]. | |
3662 | ||
3663 | 1999-01-14 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3664 | ||
3665 | * memory.h (enum): add MTYPE_STREAM, MTYPE_STREAM_DATA | |
3666 | ||
3667 | * buffer.c (stream_new): Set MTYPE_STREAM to XMALLOC argument. | |
3668 | ||
3669 | 1998-12-23 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3670 | ||
3671 | * routemap.c: route_map_index_delete() added. | |
3672 | ||
3673 | 1998-12-22 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3674 | ||
3675 | * buffer.c (buffer_empty): check cp instead of sp. | |
3676 | ||
3677 | 1998-12-17 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3678 | ||
3679 | * radix.[ch]: Deleted. | |
3680 | ||
3681 | 1998-12-15 Magnus Ahltorp <map@stacken.kth.se> | |
3682 | ||
3683 | * buffer.c: Prototype fixes. | |
3684 | * prefix.c: Likewise. | |
3685 | * sockunion.c: Likewise. | |
3686 | * sockunion.h: Likewise. | |
3687 | ||
3688 | 1998-12-14 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3689 | ||
3690 | * vty.c (vty_read): DELETE key works as vty_delete_char. | |
3691 | ||
3692 | 1998-12-13 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3693 | ||
3694 | * log.c (time_print): chane %y to %Y. | |
3695 | ||
3696 | 1998-12-10 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3697 | ||
3698 | * distribute.c: new file. | |
3699 | ||
3700 | 1998-12-09 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3701 | ||
3702 | * filter.c: Remove all of struct prefix_{ipv4,ipv6} and add | |
3703 | complete support of IPv6 access list. | |
3704 | ||
3705 | * command.c (config_write_element): function delete. | |
3706 | (config_write_host): function add. password and enable password | |
3707 | isn't printed to vty interface. | |
3708 | ||
3709 | 1998-12-08 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3710 | ||
3711 | * filter.c: Change prefix_ipv4 to prefix and add support of | |
3712 | prefix_ipv6 filtering. | |
3713 | ||
3714 | 1998-12-07 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3715 | ||
3716 | * Makefile.am (INCLUDES): add @INCLUDES@ for Linux IPv6 inet6-apps | |
3717 | header includes. | |
3718 | ||
3719 | 1998-12-05 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3720 | ||
3721 | * log.c (log_flush): fix function name typo. | |
3722 | ||
3723 | 1998-12-04 Yasuhiro Ohara <yasu@sfc.wide.ad.jp> | |
3724 | ||
3725 | * memory.h: OSPF memory type is added. | |
3726 | ||
3727 | 1998-11-15 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3728 | ||
3729 | * command.c (sort_node): add sort_node() for pretty printing of | |
3730 | command on vty interface. | |
3731 | (config_password): delete the restriction of charaster of password | |
3732 | string. | |
3733 | ||
3734 | 1998-09-05 Kunihiro Ishiguro <kunihiro@debian.zebra.org> | |
3735 | ||
3736 | * prefix.c (prefix_ipv4_any): add prefix_ipv4_any(). | |
3737 | ||
3738 | 1998-08-25 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3739 | ||
3740 | * network.h: New file. | |
3741 | ||
3742 | 1998-08-24 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3743 | ||
3744 | * vty.c (vty_will_echo): function name change from vty_off_echo. | |
3745 | ||
3746 | 1998-08-18 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3747 | ||
3748 | * buffer.h: add PUTC,PUTW,PUTL macros. | |
3749 | ||
3750 | 1998-07-22 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3751 | ||
3752 | * route.[ch]: renamed to prefix.[ch] | |
3753 | ||
3754 | 1998-06-09 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3755 | ||
3756 | * prefix_in, prefix_in6 is replaced by prefix_ipv4, prefix_ipv6. | |
3757 | ||
3758 | * Makefile.am: @INCLUDES@ is deleted from INCLUDES. | |
3759 | ||
3760 | 1998-06-07 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3761 | ||
3762 | * host.[ch]: merged with command.[ch] | |
3763 | ||
3764 | 1998-05-08 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3765 | ||
3766 | * Makefile.am (libzebra_a_SOURCES): add route.c to libzebra_a_SOURCES. | |
3767 | ||
3768 | 1998-05-07 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3769 | ||
3770 | * route.c (str2prefix): str2prefix () is gone. | |
3771 | ||
3772 | 1998-05-03 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3773 | ||
3774 | * vty.c (vty_read_config): change CONDIR to SYSCONFDIR. | |
3775 | ||
3776 | * .cvsignore: add file. | |
3777 | ||
3778 | * memory.c (xerror): add arguent `type' and `size'. | |
3779 | ||
3780 | * socket.c: deleted. | |
3781 | ||
3782 | 1998-05-02 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3783 | ||
3784 | * vector.c: malloc,free,realloc -> XMALLOC,XFREE,XREALLOC. | |
3785 | * linklist.c: same as above. | |
3786 | ||
3787 | 1998-04-30 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3788 | ||
3789 | * filter.[ch]: added. | |
3790 | ||
3791 | 1998-04-01 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3792 | ||
3793 | * vty.c (config_who): return CMD_SUCCESS | |
3794 | ||
3795 | 1998-04-01 Jochen Friedrich <jochen@scram.de> | |
3796 | ||
3797 | * table.c (route_dump_node): route_dump_node is IPv6 specific | |
3798 | function so move #ifdef to the end of route_dump_node (). | |
3799 | ||
3800 | 1998-03-05 "Hannes R. Boehm" <hannes@boehm.org> | |
3801 | ||
3802 | * if.c: DEFUN(interface_desc) added. | |
3803 | ||
3804 | 1998-03-05 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3805 | ||
3806 | * if.c: separated from ripd/rip_interface.c | |
3807 | ||
3808 | 1998-03-04 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3809 | ||
3810 | * thread.[ch] : added. | |
3811 | ||
3812 | 1998-02-14 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3813 | ||
3814 | * vty.c (vty_delete_char): fix size bug. | |
3815 | (vty_backward_pure_word): function added. | |
3816 | (vty_read): ESC + 'f' perform vty_forward_word. | |
3817 | (vty_read): ESC + 'b' perform vty_backward_word. | |
3818 | ||
3819 | 1998-02-11 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3820 | ||
3821 | * radix.c (radix_lookup_rt): add mask check. | |
3822 | (radix_delete_duproute): add mask check. | |
3823 | ||
3824 | 1998-02-10 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3825 | ||
3826 | * command.c (config_write_file): fix vty -> file_vty. | |
3827 | ||
3828 | 1998-02-06 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3829 | ||
3830 | * command.c (cmd_filter_ambiguous): add complex type treatment. | |
3831 | ||
3832 | 1998-02-05 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3833 | ||
3834 | * vty.c (vty_time_print): function added. | |
3835 | (vty_complete_command): now [...] element isn't shown by completion. | |
3836 | ||
3837 | 1998-01-26 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3838 | ||
3839 | * command.c : change from cmd_install_node() to install_node(). | |
3840 | ||
3841 | 1998-01-16 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3842 | ||
3843 | * route.[ch]: struct rt{} is replaced by struct prefix{}. | |
3844 | ||
3845 | 1998-01-06 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3846 | ||
3847 | * command.c (cmd_execute_command): check command length. | |
3848 | ||
3849 | * timer.c (zebra_timer_set): add zebra_timer_set. | |
3850 | ||
3851 | 1998-01-05 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3852 | ||
3853 | * command.h (node_type ): add ZEBRA_NODE. | |
3854 | ||
3855 | * command.c (config_exit): add RIP_NODE. | |
3856 | (config_write_file): add RIP_NODE. | |
3857 | ||
3858 | 1998-01-04 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3859 | ||
3860 | * print_version.c (print_version): Now Copyright is 1996-1998. | |
3861 | ||
3862 | * sockunion.c (sockunion_log): moved from ../zebra/route.c | |
3863 | ||
3864 | 1997-12-30 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3865 | ||
3866 | * host.c (config_logfile): change 'log PATH' to 'logfile PATH'. | |
3867 | ||
3868 | * sockunion.c (sockunion_sameprefix): add same prefix for | |
3869 | sockunion. | |
3870 | ||
3871 | 1997-12-29 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3872 | ||
3873 | * radix.[ch] : are moved from ../zebra directroy. | |
3874 | ||
3875 | * command.c (config_from_file): if command execution failed down | |
3876 | level to CONFIG_NODE. | |
3877 | ||
3878 | * host.c: config_log function which enable 'log FILENAME' command. | |
3879 | ||
3880 | 1997-12-23 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3881 | ||
3882 | * vty.c: add vty_transpose_chars (). Now you can use '^T' to | |
3883 | transpose character. | |
3884 | ||
3885 | * command.c: cmd_cmdsize add, this is useful to check incomplete | |
3886 | command. | |
3887 | ||
3888 | 1997-12-07 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3889 | ||
3890 | * fd.h: add family for address family | |
3891 | ||
3892 | 1997-12-06 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3893 | ||
3894 | * command.o | |
3895 | * vty.o | |
3896 | * host.o is moved from ../zebra | |
3897 | ||
3898 | 1997-08-14 Kunihiro Ishiguro <kunihiro@zebra.org> | |
3899 | ||
3900 | * make library directory. | |
3901 |