1 /* RIP related values and structures.
2 * Copyright (C) 1997, 1998, 1999 Kunihiro Ishiguro <kunihiro@zebra.org>
4 * This file is part of GNU Zebra.
6 * GNU Zebra is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU General Public License as published by the
8 * Free Software Foundation; either version 2, or (at your option) any
11 * GNU Zebra is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with GNU Zebra; see the file COPYING. If not, write to the Free
18 * Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
27 #include "rip_memory.h"
29 /* RIP version number. */
32 /* N.B. stuff will break if
33 (RIPv1 != RI_RIP_VERSION_1) || (RIPv2 != RI_RIP_VERSION_2) */
36 /* RIP command list. */
38 #define RIP_RESPONSE 2
39 #define RIP_TRACEON 3 /* Obsolete */
40 #define RIP_TRACEOFF 4 /* Obsolete */
42 #define RIP_POLL_ENTRY 6
43 #define RIP_COMMAND_MAX 7
45 /* RIP metric infinity value.*/
46 #define RIP_METRIC_INFINITY 16
48 /* Normal RIP packet min and max size. */
49 #define RIP_PACKET_MINSIZ 4
50 #define RIP_PACKET_MAXSIZ 512
52 #define RIP_HEADER_SIZE 4
53 #define RIP_RTE_SIZE 20
55 /* Max count of routing table entry in one rip packet. */
56 #define RIP_MAX_RTE ((RIP_PACKET_MAXSIZ - RIP_HEADER_SIZE) / RIP_RTE_SIZE)
58 /* RIP version 2 multicast address. */
59 #ifndef INADDR_RIP_GROUP
60 #define INADDR_RIP_GROUP 0xe0000009 /* 224.0.0.9 */
64 #define RIP_UPDATE_TIMER_DEFAULT 30
65 #define RIP_TIMEOUT_TIMER_DEFAULT 180
66 #define RIP_GARBAGE_TIMER_DEFAULT 120
68 /* RIP peer timeout value. */
69 #define RIP_PEER_TIMER_DEFAULT 180
71 /* RIP port number. */
72 #define RIP_PORT_DEFAULT 520
73 #define RIP_VTY_PORT 2602
75 /* Default configuration file name. */
76 #define RIPD_DEFAULT_CONFIG "ripd.conf"
78 /* RIP route types. */
79 #define RIP_ROUTE_RTE 0
80 #define RIP_ROUTE_STATIC 1
81 #define RIP_ROUTE_DEFAULT 2
82 #define RIP_ROUTE_REDISTRIBUTE 3
83 #define RIP_ROUTE_INTERFACE 4
85 /* RIPv2 special RTE family types */
86 #define RIP_FAMILY_AUTH 0xffff
88 /* RIPv2 authentication types, for RIP_FAMILY_AUTH RTE's */
90 #define RIP_AUTH_DATA 1
91 #define RIP_AUTH_SIMPLE_PASSWORD 2
92 #define RIP_AUTH_MD5 3
94 /* RIPv2 Simple authentication */
95 #define RIP_AUTH_SIMPLE_SIZE 16
97 /* RIPv2 MD5 authentication. */
98 #define RIP_AUTH_MD5_SIZE 16
99 #define RIP_AUTH_MD5_COMPAT_SIZE RIP_RTE_SIZE
106 /* Default version of rip instance. */
107 int version_send
; /* version 1 or 2 (but not both) */
108 int version_recv
; /* version 1 or 2 or both */
110 /* Output buffer of RIP. */
113 /* RIP routing information base. */
114 struct route_table
*table
;
116 /* RIP only static routing information. */
117 struct route_table
*route
;
120 struct route_table
*neighbor
;
123 struct thread
*t_read
;
125 /* Update and garbage timer. */
126 struct thread
*t_update
;
128 /* Triggered update hack. */
130 struct thread
*t_triggered_update
;
131 struct thread
*t_triggered_interval
;
133 /* RIP timer values. */
134 unsigned long update_time
;
135 unsigned long timeout_time
;
136 unsigned long garbage_time
;
138 /* RIP default metric. */
141 /* RIP default-information originate. */
142 u_char default_information
;
143 char *default_information_route_map
;
145 /* RIP default distance. */
147 struct route_table
*distance_table
;
152 /* For redistribute route map. */
155 struct route_map
*map
;
158 } route_map
[ZEBRA_ROUTE_MAX
];
162 DECLARE_QOBJ_TYPE(rip
)
164 /* RIP routing table entry which belong to rip_packet. */
166 u_int16_t family
; /* Address family of this route. */
167 u_int16_t tag
; /* Route Tag which included in RIP2 packet. */
168 struct in_addr prefix
; /* Prefix of rip route. */
169 struct in_addr mask
; /* Netmask of rip route. */
170 struct in_addr nexthop
; /* Next hop of rip route. */
171 u_int32_t metric
; /* Metric value of rip route. */
174 /* RIP packet structure. */
176 unsigned char command
; /* Command type of RIP packet. */
177 unsigned char version
; /* RIP version which coming from peer. */
178 unsigned char pad1
; /* Padding of RIP packet header. */
179 unsigned char pad2
; /* Same as above. */
180 struct rte rte
[1]; /* Address structure. */
183 /* Buffer to read RIP packet. */
185 struct rip_packet rip_packet
;
186 char buf
[RIP_PACKET_MAXSIZ
];
189 /* RIP route information. */
191 /* This route's type. */
198 struct in_addr nexthop
;
201 /* Which interface does this route come from. */
204 /* Metric of this route. */
207 /* External metric of this route.
208 if learnt from an externalm proto */
209 u_int32_t external_metric
;
211 /* Tag information of this route. */
214 /* Flags of RIP route. */
215 #define RIP_RTF_FIB 1
216 #define RIP_RTF_CHANGED 2
219 /* Garbage collect timer. */
220 struct thread
*t_timeout
;
221 struct thread
*t_garbage_collect
;
223 /* Route-map futures - this variables can be changed. */
224 struct in_addr nexthop_out
;
226 u_int32_t metric_out
;
228 ifindex_t ifindex_out
;
230 struct route_node
*rp
;
235 struct rip_info
*next
;
236 struct rip_info
*prev
;
237 #endif /* NEW_RIP_TABLE */
241 RIP_NO_SPLIT_HORIZON
= 0,
243 RIP_SPLIT_HORIZON_POISONED_REVERSE
244 } split_horizon_policy_t
;
246 /* RIP specific interface configuration. */
247 struct rip_interface
{
248 /* RIP is enabled on this interface. */
250 int enable_interface
;
252 /* RIP is running on this interface. */
255 /* RIP version control. */
259 /* RIPv2 broadcast mode */
262 /* RIPv2 authentication type. */
265 /* RIPv2 authentication string. */
268 /* RIPv2 authentication key chain. */
271 /* value to use for md5->auth_len */
272 u_int8_t md5_auth_len
;
274 /* Split horizon flag. */
275 split_horizon_policy_t split_horizon
;
276 split_horizon_policy_t split_horizon_default
;
278 /* For filter type slot. */
279 #define RIP_FILTER_IN 0
280 #define RIP_FILTER_OUT 1
281 #define RIP_FILTER_MAX 2
284 struct access_list
*list
[RIP_FILTER_MAX
];
287 struct prefix_list
*prefix
[RIP_FILTER_MAX
];
290 struct route_map
*routemap
[RIP_FILTER_MAX
];
292 /* Wake up thread. */
293 struct thread
*t_wakeup
;
295 /* Interface statistics. */
300 /* Passive interface. */
304 /* RIP peer information. */
309 /* Peer RIP tag value. */
312 /* Last update time. */
315 /* Peer RIP version. */
322 /* Timeout thread. */
323 struct thread
*t_timeout
;
326 struct rip_md5_info
{
329 u_int16_t packet_len
;
337 struct rip_md5_data
{
343 /* RIP accepet/announce methods. */
344 #define RI_RIP_UNSPEC 0
345 #define RI_RIP_VERSION_1 1
346 #define RI_RIP_VERSION_2 2
347 #define RI_RIP_VERSION_1_AND_2 3
348 #define RI_RIP_VERSION_NONE 4
349 /* N.B. stuff will break if
350 (RIPv1 != RI_RIP_VERSION_1) || (RIPv2 != RI_RIP_VERSION_2) */
352 /* Default value for "default-metric" command. */
353 #define RIP_DEFAULT_METRIC_DEFAULT 1
359 RIP_TRIGGERED_UPDATE
,
362 /* Macro for timer turn on. */
363 #define RIP_TIMER_ON(T, F, V) \
366 (T) = thread_add_timer(master, (F), rinfo, (V)); \
369 /* Macro for timer turn off. */
370 #define RIP_TIMER_OFF(X) THREAD_TIMER_OFF(X)
373 extern void rip_init(void);
374 extern void rip_reset(void);
375 extern void rip_clean(void);
376 extern void rip_clean_network(void);
377 extern void rip_interfaces_clean(void);
378 extern void rip_interfaces_reset(void);
379 extern void rip_passive_nondefault_clean(void);
380 extern void rip_if_init(void);
381 extern void rip_if_down_all(void);
382 extern void rip_route_map_init(void);
383 extern void rip_route_map_reset(void);
384 extern void rip_zclient_init(struct thread_master
*);
385 extern void rip_zclient_reset(void);
386 extern void rip_offset_init(void);
387 extern int if_check_address(struct in_addr addr
);
389 extern int rip_request_send(struct sockaddr_in
*, struct interface
*, u_char
,
391 extern int rip_neighbor_lookup(struct sockaddr_in
*);
393 extern int rip_redistribute_check(int);
394 extern void rip_redistribute_add(int, int, struct prefix_ipv4
*, ifindex_t
,
395 struct in_addr
*, unsigned int, unsigned char,
397 extern void rip_redistribute_delete(int, int, struct prefix_ipv4
*, ifindex_t
);
398 extern void rip_redistribute_withdraw(int);
399 extern void rip_zebra_ipv4_add(struct route_node
*);
400 extern void rip_zebra_ipv4_delete(struct route_node
*);
401 extern void rip_interface_multicast_set(int, struct connected
*);
402 extern void rip_distribute_update_interface(struct interface
*);
403 extern void rip_if_rmap_update_interface(struct interface
*);
405 extern int config_write_rip_network(struct vty
*, int);
406 extern int config_write_rip_offset_list(struct vty
*);
407 extern int config_write_rip_redistribute(struct vty
*, int);
409 extern void rip_peer_init(void);
410 extern void rip_peer_update(struct sockaddr_in
*, u_char
);
411 extern void rip_peer_bad_route(struct sockaddr_in
*);
412 extern void rip_peer_bad_packet(struct sockaddr_in
*);
413 extern void rip_peer_display(struct vty
*);
414 extern struct rip_peer
*rip_peer_lookup(struct in_addr
*);
415 extern struct rip_peer
*rip_peer_lookup_next(struct in_addr
*);
417 extern int rip_offset_list_apply_in(struct prefix_ipv4
*, struct interface
*,
419 extern int rip_offset_list_apply_out(struct prefix_ipv4
*, struct interface
*,
421 extern void rip_offset_clean(void);
423 extern void rip_info_free(struct rip_info
*);
424 extern u_char
rip_distance_apply(struct rip_info
*);
425 extern void rip_redistribute_clean(void);
427 extern struct rip_info
*rip_ecmp_add(struct rip_info
*);
428 extern struct rip_info
*rip_ecmp_replace(struct rip_info
*);
429 extern struct rip_info
*rip_ecmp_delete(struct rip_info
*);
431 /* There is only one rip strucutre. */
432 extern struct rip
*rip
;
434 /* Master thread strucutre. */
435 extern struct thread_master
*master
;
437 /* RIP statistics for SNMP. */
438 extern long rip_global_route_changes
;
439 extern long rip_global_queries
;
441 DECLARE_HOOK(rip_ifaddr_add
, (struct connected
* ifc
), (ifc
))
442 DECLARE_HOOK(rip_ifaddr_del
, (struct connected
* ifc
), (ifc
))
444 #endif /* _ZEBRA_RIP_H */