mirror of
https://git.proxmox.com/git/mirror_frr
synced 2025-05-02 16:41:55 +00:00

In order to provide Link State Traffic Engineering features to IS-IS, this patch adds some modifications to base IS-IS: - Solve bug in lsp iterate function to avoid infinite loop in isis_lsp.c by adding condition to recurse call - Add new trigger event to parse LSP in isis_lsp.c - Add new TE debug flag to track Traffic Engineering events in isisd.[c,h] - Correct small bug in isis_tlvs.c where delay and min/max delay are not correctly handle - Handle Opaque LSA Traffic Engineering Zebra API in isis_zebra.[c,h] Signed-off-by: Olivier Dugeon <olivier.dugeon@orange.com>
73 lines
2.7 KiB
C
73 lines
2.7 KiB
C
/*
|
|
* IS-IS Rout(e)ing protocol - isis_zebra.h
|
|
*
|
|
* Copyright (C) 2001,2002 Sampo Saaristo
|
|
* Tampere University of Technology
|
|
* Institute of Communications Engineering
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU General Public Licenseas published by the Free
|
|
* Software Foundation; either version 2 of the License, or (at your option)
|
|
* any later version.
|
|
*
|
|
* This program 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_ISIS_ZEBRA_H
|
|
#define _ZEBRA_ISIS_ZEBRA_H
|
|
|
|
#include "isisd.h"
|
|
|
|
extern struct zclient *zclient;
|
|
|
|
struct label_chunk {
|
|
uint32_t start;
|
|
uint32_t end;
|
|
uint64_t used_mask;
|
|
};
|
|
#define CHUNK_SIZE 64
|
|
|
|
void isis_zebra_init(struct thread_master *master, int instance);
|
|
void isis_zebra_stop(void);
|
|
|
|
struct isis_route_info;
|
|
struct sr_adjacency;
|
|
|
|
void isis_zebra_route_add_route(struct isis *isis,
|
|
struct prefix *prefix,
|
|
struct prefix_ipv6 *src_p,
|
|
struct isis_route_info *route_info);
|
|
void isis_zebra_route_del_route(struct isis *isis,
|
|
struct prefix *prefix,
|
|
struct prefix_ipv6 *src_p,
|
|
struct isis_route_info *route_info);
|
|
void isis_zebra_prefix_sid_install(struct isis_area *area,
|
|
struct prefix *prefix,
|
|
struct isis_route_info *rinfo,
|
|
struct isis_sr_psid_info *psid);
|
|
void isis_zebra_prefix_sid_uninstall(struct isis_area *area,
|
|
struct prefix *prefix,
|
|
struct isis_route_info *rinfo,
|
|
struct isis_sr_psid_info *psid);
|
|
void isis_zebra_send_adjacency_sid(int cmd, const struct sr_adjacency *sra);
|
|
int isis_distribute_list_update(int routetype);
|
|
void isis_zebra_redistribute_set(afi_t afi, int type, vrf_id_t vrf_id);
|
|
void isis_zebra_redistribute_unset(afi_t afi, int type, vrf_id_t vrf_id);
|
|
int isis_zebra_rlfa_register(struct isis_spftree *spftree, struct rlfa *rlfa);
|
|
void isis_zebra_rlfa_unregister_all(struct isis_spftree *spftree);
|
|
bool isis_zebra_label_manager_ready(void);
|
|
int isis_zebra_label_manager_connect(void);
|
|
int isis_zebra_request_label_range(uint32_t base, uint32_t chunk_size);
|
|
int isis_zebra_release_label_range(uint32_t start, uint32_t end);
|
|
void isis_zebra_vrf_register(struct isis *isis);
|
|
void isis_zebra_vrf_deregister(struct isis *isis);
|
|
int isis_zebra_ls_register(bool up);
|
|
|
|
#endif /* _ZEBRA_ISIS_ZEBRA_H */
|