]> git.proxmox.com Git - mirror_frr.git/blobdiff - pimd/pim_rp.h
Merge pull request #5498 from mjstapp/sharp_with_labels
[mirror_frr.git] / pimd / pim_rp.h
index 672a69631907c0d12ae4375e2b4d36eca7d8deb7..6dc26c07a95ca63e362a7a28f6ef3c26a883af2f 100644 (file)
 #include "pim_iface.h"
 #include "pim_rpf.h"
 
+enum rp_source {
+       RP_SRC_NONE = 0,
+       RP_SRC_STATIC,
+       RP_SRC_BSR
+};
+
 struct rp_info {
        struct prefix group;
        struct pim_rpf rp;
+       enum rp_source rp_src;
        int i_am_rp;
        char *plist;
 };
@@ -39,10 +46,18 @@ void pim_rp_free(struct pim_instance *pim);
 
 void pim_rp_list_hash_clean(void *data);
 
-int pim_rp_new(struct pim_instance *pim, const char *rp, const char *group,
-              const char *plist);
-int pim_rp_del(struct pim_instance *pim, const char *rp, const char *group,
-              const char *plist);
+int pim_rp_new_config(struct pim_instance *pim, const char *rp,
+                     const char *group, const char *plist);
+int pim_rp_new(struct pim_instance *pim, struct in_addr rp_addr,
+              struct prefix group, const char *plist,
+              enum rp_source rp_src_flag);
+int pim_rp_del_config(struct pim_instance *pim, const char *rp,
+                     const char *group, const char *plist);
+int pim_rp_del(struct pim_instance *pim, struct in_addr rp_addr,
+              struct prefix group, const char *plist,
+              enum rp_source rp_src_flag);
+int pim_rp_change(struct pim_instance *pim, struct in_addr new_rp_addr,
+                 struct prefix group, enum rp_source rp_src_flag);
 void pim_rp_prefix_list_update(struct pim_instance *pim,
                               struct prefix_list *plist);
 
@@ -55,9 +70,8 @@ int pim_rp_i_am_rp(struct pim_instance *pim, struct in_addr group);
 void pim_rp_check_on_if_add(struct pim_interface *pim_ifp);
 void pim_i_am_rp_re_evaluate(struct pim_instance *pim);
 
-int pim_rp_check_is_my_ip_address(struct pim_instance *pim,
-                                 struct in_addr group,
-                                 struct in_addr dest_addr);
+bool pim_rp_check_is_my_ip_address(struct pim_instance *pim,
+                                  struct in_addr dest_addr);
 
 int pim_rp_set_upstream_addr(struct pim_instance *pim, struct in_addr *up,
                             struct in_addr source, struct in_addr group);
@@ -69,6 +83,9 @@ struct pim_rpf *pim_rp_g(struct pim_instance *pim, struct in_addr group);
 
 void pim_rp_show_information(struct pim_instance *pim, struct vty *vty,
                             bool uj);
-void pim_resolve_rp_nh(struct pim_instance *pim);
+void pim_resolve_rp_nh(struct pim_instance *pim, struct pim_neighbor *nbr);
 int pim_rp_list_cmp(void *v1, void *v2);
+struct rp_info *pim_rp_find_match_group(struct pim_instance *pim,
+                                       const struct prefix *group);
+void pim_upstream_update(struct pim_instance *pim, struct pim_upstream *up);
 #endif