1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
|
/*
* Redistribution Handler
* Copyright (C) 1999 Kunihiro Ishiguro
*
* This file is part of GNU Zebra.
*
* GNU Zebra is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the
* Free Software Foundation; either version 2, or (at your option) any
* later version.
*
* GNU Zebra is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; see the file COPYING; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifndef _ZEBRA_REDISTRIBUTE_H
#define _ZEBRA_REDISTRIBUTE_H
#include "table.h"
#include "vty.h"
#include "vrf.h"
#include "zebra/zserv.h"
#include "zebra/rib.h"
#ifdef __cplusplus
extern "C" {
#endif
/* ZAPI command handlers */
extern void zebra_redistribute_add(ZAPI_HANDLER_ARGS);
extern void zebra_redistribute_delete(ZAPI_HANDLER_ARGS);
extern void zebra_redistribute_default_add(ZAPI_HANDLER_ARGS);
extern void zebra_redistribute_default_delete(ZAPI_HANDLER_ARGS);
/* ----------------- */
extern void redistribute_update(const struct route_node *rn,
const struct route_entry *re,
const struct route_entry *prev_re);
/*
* During a route delete, where 'new_re' is NULL, redist a delete to all
* clients registered for the type of 'old_re'.
* During a route update, redist a delete to any clients who will not see
* an update when the new route is installed. There are cases when a client
* may have seen a redist for 'old_re', but will not see
* the redist for 'new_re'.
*/
void redistribute_delete(const struct route_node *rn,
const struct route_entry *old_re,
const struct route_entry *new_re);
extern void zebra_interface_up_update(struct interface *ifp);
extern void zebra_interface_down_update(struct interface *ifp);
extern void zebra_interface_add_update(struct interface *ifp);
extern void zebra_interface_delete_update(struct interface *ifp);
extern void zebra_interface_address_add_update(struct interface *ifp,
struct connected *c);
extern void zebra_interface_address_delete_update(struct interface *ifp,
struct connected *c);
extern void zebra_interface_parameters_update(struct interface *ifp);
extern void zebra_interface_vrf_update_del(struct interface *ifp,
vrf_id_t new_vrf_id);
extern void zebra_interface_vrf_update_add(struct interface *ifp,
vrf_id_t old_vrf_id);
extern int zebra_import_table(afi_t afi, vrf_id_t vrf_id,
uint32_t table_id, uint32_t distance,
const char *rmap_name, int add);
extern int zebra_add_import_table_entry(struct zebra_vrf *zvrf,
struct route_node *rn,
struct route_entry *re,
const char *rmap_name);
extern int zebra_del_import_table_entry(struct zebra_vrf *zvrf,
struct route_node *rn,
struct route_entry *re);
extern int is_zebra_import_table_enabled(afi_t, vrf_id_t vrf_id,
uint32_t table_id);
extern int zebra_import_table_config(struct vty *, vrf_id_t vrf_id);
extern void zebra_import_table_rm_update(const char *rmap);
#ifdef __cplusplus
}
#endif
#endif /* _ZEBRA_REDISTRIBUTE_H */
|