|
| |||||||||||||||||
There should be one node per PIM instance. There should be one instance per address family.
| PimNode (int family, x_module_id module_id, EventLoop& event_loop)
| PimNode |
Constructor for a given address family, module ID, and event loop.
Parameters:
| family | the address family (AF_INET or AF_INET6 for IPv4 and IPv6 respectively). |
| module_id | the module ID (x_module_id). Should be X_MODULE_PIMSM Note: if/after PIM-DM is implemented, X_MODULE_PIMDM would be allowed as well. |
| event_loop | the event loop to use. |
| ~PimNode ()
| ~PimNode |
[virtual]
Destructor
| int set_proto_version (int proto_version)
| set_proto_version |
Set the current protocol version.
The protocol version must be in the interval [PIM_VERSION_MIN, PIM_VERSION_MAX].
Parameters:
| proto_version | the protocol version to set. |
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int start ()
| start |
Start the node operation.
Returns: XORP_OK on success, otherwise XORP_ERROR.
Reimplemented from ProtoNode.
| int stop ()
| stop |
Stop the node operation.
Gracefully stop the PIM protocol. The graceful stop will attempt to send Join/Prune, Assert, etc. messages for all multicast routing entries to gracefully clean-up state with neighbors. After the multicast routing entries cleanup is completed, PimNode::final_stop() is called to complete the job. If this method is called one-after-another, the second one will force calling immediately PimNode::final_stop() to quickly finish the job. This function, unlike start(), will stop the protocol operation on all interfaces.
Returns: XORP_OK on success, otherwise XORP_ERROR.
Reimplemented from ProtoNode.
| int final_stop ()
| final_stop |
Completely stop the node operation.
This method should be called after PimNode::stop() to complete the job.
Returns: XORP_OK on success, otherwise XORP_ERROR.
| bool has_pending_down_units ()
| has_pending_down_units |
Test if there is an unit that is in PENDING_DOWN state.
Returns: true if there is an unit that is in PENDING_DOWN state, otherwise false.
| int add_vif (const Vif& vif)
| add_vif |
Install a new PIM vif.
Parameters:
| vif | vif information about new PimVif to install. |
Returns: XORP_OK on success, otherwise XORP_ERROR.
Reimplemented from ProtoNode.
| int add_vif (const char *vif_name, uint16_t vif_index)
| add_vif |
Install a new PIM vif.
Parameters:
| vif_name | the name of the new vif. |
| vif_index | the vif index of the new vif. |
Returns: XORP_OK on success, otherwise XORP_ERROR.
Reimplemented from ProtoNode.
| int delete_vif (const char *vif_name)
| delete_vif |
Delete an existing PIM vif.
Parameters:
| vif_name | the name of the vif to delete. |
Returns: XORP_OK on success, otherwise XORP_ERROR.
Reimplemented from ProtoNode.
| int set_vif_flags (const char *vif_name,
bool is_pim_register, bool is_p2p,
bool is_loopback, bool is_multicast,
bool is_broadcast, bool is_up)
| set_vif_flags |
Set flags to a vif.
Parameters:
| vif_name | the name of the vif. |
| is_pim_register | true if this is a PIM Register vif. |
| is_p2p | true if this is a point-to-point vif. |
| is_loopback | true if this is a loopback interface. |
| is_multicast | rue if the vif is multicast-capable. |
| is_broadcast | true if the vif is broadcast-capable. |
| is_up | true if the vif is UP and running. |
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int add_vif_addr (const char *vif_name,
const IPvX& addr,
const IPvXNet& subnet_addr,
const IPvX& broadcast_addr,
const IPvX& peer_addr)
| add_vif_addr |
Add an address to a vif.
Parameters:
| vif_name | the name of the vif. |
| addr | the unicast address to add. |
| subnet_addr | the subnet address to add. |
| broadcast_addr | the broadcast address (when applicable). |
| peer_addr | the peer address (when applicable). |
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int delete_vif_addr (const char *vif_name,
const IPvX& addr)
| delete_vif_addr |
Delete an address from a vif.
Parameters:
| vif_name | the name of the vif. |
| addr | the unicast address to delete. |
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int start_all_vifs ()
| start_all_vifs |
Start PIM on all enabled interfaces.
Returns: the number of virtual interfaces PIM was started on, or XORP_ERROR if error occured.
| int stop_all_vifs ()
| stop_all_vifs |
Stop PIM on all interfaces it was running on.
Returns: he number of virtual interfaces PIM was stopped on, or XORP_ERROR if error occured.
| int enable_all_vifs ()
| enable_all_vifs |
Enable PIM on all interfaces.
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int disable_all_vifs ()
| disable_all_vifs |
Disable PIM on all interfaces.
Returns: XORP_OK on success, otherwise XORP_ERROR.
| void delete_all_vifs ()
| delete_all_vifs |
Delete all PIM vifs.
| int proto_recv (const string& src_module_instance_name,
x_module_id src_module_id,
uint16_t vif_index,
const IPvX& src, const IPvX& dst,
int ip_ttl, int ip_tos, bool router_alert_bool,
const uint8_t *rcvbuf, size_t rcvlen)
| proto_recv |
Receive a protocol message.
Parameters:
| src_module_instance_name | the module instance name of the module-origin of the message. |
| src_module_id | the module ID (x_module_id) of the module-origin of the message. |
| vif_index | the vif index of the interface used to receive this message. |
| src | the source address of the message. |
| dst | the destination address of the message. |
| ip_ttl | the IP TTL of the message. If it has a negative value, it should be ignored. |
| ip_tos | the IP TOS of the message. If it has a negative value, it should be ignored. |
| router_alert_bool | if true, the IP Router Alert option in the IP packet was set (when applicable). |
| rcvbuf | the data buffer with the received message. |
| rcvlen | the data length in rcvbuf. |
Returns: XORP_OK on success, otherwise XORP_ERROR.
Reimplemented from ProtoNode.
| int pim_send (uint16_t vif_index,
const IPvX& src, const IPvX& dst,
int ip_ttl, int ip_tos, bool router_alert_bool,
buffer_t *buffer)
| pim_send |
Send a protocol message.
Note: this method uses the pure virtual ProtoNode::proto_send() method that is implemented somewhere else (in a class that inherits this one).
Parameters:
| vif_index | the vif index of the vif to send the message. |
| src | the source address of the message. |
| dst | the destination address of the message. |
| ip_ttl | the TTL of the IP packet to send. If it has a negative value, the TTL will be set by the lower layers. |
| ip_tos | the TOS of the IP packet to send. If it has a negative value, the TOS will be set by the lower layers. |
| router_alert_bool | if true, set the IP Router Alert option in the IP packet to send (when applicable). |
| buffer | the data buffer with the message to send. |
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int signal_message_recv (const string& src_module_instance_name,
x_module_id src_module_id,
int message_type,
uint16_t vif_index,
const IPvX& src,
const IPvX& dst,
const uint8_t *rcvbuf,
size_t rcvlen)
| signal_message_recv |
Receive a signal message from the kernel.
#define MFEA_UNIX_KERNEL_MESSAGE_NOCACHE 1 #define MFEA_UNIX_KERNEL_MESSAGE_WRONGVIF 2 #define MFEA_UNIX_KERNEL_MESSAGE_WHOLEPKT 3 |
Parameters:
| src_module_instance_name | the module instance name of the module-origin of the message. |
| src_module_id | the module ID (x_module_id) of the module-origin of the message. |
| message_type | the message type. Currently, the type of messages received from the kernel are: |
| vif_index | the vif index of the related interface (message-specific relation). |
| src | the source address in the message. |
| dst | the destination address in the message. |
| rcvbuf | the data buffer with the additional information in the message. |
| rcvlen | the data length in rcvbuf. |
Returns: XORP_OK on success, otherwise XORP_ERROR.
Reimplemented from ProtoNode.
| int signal_message_send (const string&,
x_module_id ,
int ,
uint16_t ,
const IPvX& ,
const IPvX& ,
const uint8_t * ,
size_t
)
| signal_message_send |
Send signal message: not used by PIM.
Reimplemented from ProtoNode.
| int start_protocol_kernel ()
| start_protocol_kernel |
[pure virtual]
Start the protocol with the kernel.
This is a pure virtual function, and it must be implemented by the communication-wrapper class that inherits this base class.
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int stop_protocol_kernel ()
| stop_protocol_kernel |
[pure virtual]
Stop the protocol with the kernel.
This is a pure virtual function, and it must be implemented by the communication-wrapper class that inherits this base class.
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int start_protocol_kernel_vif (uint16_t vif_index)
| start_protocol_kernel_vif |
[pure virtual]
Start a protocol vif with the kernel.
This is a pure virtual function, and it must be implemented by the communication-wrapper class that inherits this base class.
Parameters:
| vif_index | the vif index of the interface to start. |
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int stop_protocol_kernel_vif (uint16_t vif_index)
| stop_protocol_kernel_vif |
[pure virtual]
Stop a protocol vif with the kernel.
This is a pure virtual function, and it must be implemented by the communication-wrapper class that inherits this base class.
Parameters:
| vif_index | the vif index of the interface to stop. |
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int join_multicast_group (uint16_t vif_index,
const IPvX& multicast_group)
| join_multicast_group |
[pure virtual]
Join a multicast group on an interface.
This is a pure virtual function, and it must be implemented by the communication-wrapper class that inherits this base class.
TODO: add a source address as well!!
Parameters:
| vif_index | the vif index of the interface to join. |
| multicast_group | the multicast group address. |
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int leave_multicast_group (uint16_t vif_index,
const IPvX& multicast_group)
| leave_multicast_group |
[pure virtual]
Leave a multicast group on an interface.
This is a pure virtual function, and it must be implemented by the communication-wrapper class that inherits this base class.
TODO: add a source address as well!!
Parameters:
| vif_index | the vif index of the interface to leave. |
| multicast_group | the multicast group address. |
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int add_mfc_to_kernel (const PimMfc& pim_mfc)
| add_mfc_to_kernel |
[pure virtual]
Add a Multicast Forwarding Cache to the kernel.
This is a pure virtual function, and it must be implemented by the communication-wrapper class that inherits this base class.
Parameters:
| pim_mfc | the PimMfc entry to add. |
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int delete_mfc_from_kernel (const PimMfc& pim_mfc)
| delete_mfc_from_kernel |
[pure virtual]
Delete a Multicast Forwarding Cache to the kernel.
This is a pure virtual function, and it must be implemented by the communication-wrapper class that inherits this base class.
Parameters:
| pim_mfc | the PimMfc entry to delete. |
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int add_dataflow_monitor (const IPvX& source_addr,
const IPvX& group_addr,
uint32_t threshold_interval_sec,
uint32_t threshold_interval_usec,
uint32_t threshold_packets,
uint32_t threshold_bytes,
bool is_threshold_in_packets,
bool is_threshold_in_bytes,
bool is_geq_upcall,
bool is_leq_upcall)
| add_dataflow_monitor |
[pure virtual]
Add a dataflow monitor to the MFEA.
This is a pure virtual function, and it must be implemented by the communication-wrapper class that inherits this base class.
Note: either is_threshold_in_packets or is_threshold_in_bytes (or both) must be true. Note: either is_geq_upcall or is_leq_upcall (but not both) must be true.
Parameters:
| source | the source address. |
| group | the group address. |
| threshold_interval_sec | the dataflow threshold interval (seconds). |
| threshold_interval_usec | the dataflow threshold interval (microseconds). |
| threshold_packets | the threshold (in number of packets) to compare against. |
| threshold_bytes | the threshold (in number of bytes) to compare against. |
| is_threshold_in_packets | if true, threshold_packets is valid. |
| is_threshold_in_bytes | if true, threshold_bytes is valid. |
| is_geq_upcall | if true, the operation for comparison is ">=". |
| is_leq_upcall | if true, the operation for comparison is "<=". |
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int delete_dataflow_monitor (const IPvX& source_addr,
const IPvX& group_addr,
uint32_t threshold_interval_sec,
uint32_t threshold_interval_usec,
uint32_t threshold_packets,
uint32_t threshold_bytes,
bool is_threshold_in_packets,
bool is_threshold_in_bytes,
bool is_geq_upcall,
bool is_leq_upcall)
| delete_dataflow_monitor |
[pure virtual]
Delete a dataflow monitor from the MFEA.
This is a pure virtual function, and it must be implemented by the communication-wrapper class that inherits this base class.
Note: either is_threshold_in_packets or is_threshold_in_bytes (or both) must be true. Note: either is_geq_upcall or is_leq_upcall (but not both) must be true.
Parameters:
| source | the source address. |
| group | the group address. |
| threshold_interval_sec | the dataflow threshold interval (seconds). |
| threshold_interval_usec | the dataflow threshold interval (microseconds). |
| threshold_packets | the threshold (in number of packets) to compare against. |
| threshold_bytes | the threshold (in number of bytes) to compare against. |
| is_threshold_in_packets | if true, threshold_packets is valid. |
| is_threshold_in_bytes | if true, threshold_bytes is valid. |
| is_geq_upcall | if true, the operation for comparison is ">=". |
| is_leq_upcall | if true, the operation for comparison is "<=". |
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int delete_all_dataflow_monitor (const IPvX& source_addr,
const IPvX& group_addr)
| delete_all_dataflow_monitor |
[pure virtual]
Delete all dataflow monitors for a given source and group address from the MFEA.
This is a pure virtual function, and it must be implemented by the communication-wrapper class that inherits this base class.
Parameters:
| source_addr | the source address. |
| group_addr | the group address. |
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int add_protocol_mld6igmp (uint16_t vif_index)
| add_protocol_mld6igmp |
[pure virtual]
Register this protocol with the MLD/IGMP module.
This is a pure virtual function, and it must be implemented by the communication-wrapper class that inherits this base class.
By registering this protocol with the MLD/IGMP module, it will be notified about multicast group membership events.
Parameters:
| vif_index | the vif index of the interface to register with the MLD/IGMP module. |
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int delete_protocol_mld6igmp (uint16_t vif_index)
| delete_protocol_mld6igmp |
[pure virtual]
Deregister this protocol with the MLD/IGMP module.
This is a pure virtual function, and it must be implemented by the communication-wrapper class that inherits this base class.
Parameters:
| vif_index | the vif index of the interface to deregister with the MLD/IGMP module. |
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int add_membership (uint16_t vif_index, const IPvX& source,
const IPvX& group)
| add_membership |
Receive "add membership" from the MLD/IGMP module.
Parameters:
| vif_index | the vif index of the interface with membership change. |
| source | the source address of the (S,G) or (*,G) entry that has changed membership. In case of Any-Source Multicast, it is IPvX::ZERO(). |
| group | the group address. |
Returns: XORP_OK on success, otherwise XORP_ERROR.
| int delete_membership (uint16_t vif_index, const IPvX& source,
const IPvX& group)
| delete_membership |
Receive "delete membership" from the MLD/IGMP module.
Parameters:
| vif_index | the vif index of the interface with membership change. |
| source | the source address of the (S,G) or (*,G) entry that has changed membership. In case of Any-Source Multicast, it is IPvX::ZERO(). |
| group | the group address. |
Returns: XORP_OK on success, otherwise XORP_ERROR.
| void add_mrib_entry (const Mrib& mrib)
| add_mrib_entry |
Add an entry to the MRIB table (MribTable).
Parameters:
| mrib | the Mrib entry to add. |
| void delete_mrib_entry (const Mrib& mrib)
| delete_mrib_entry |
Delete an entry from the MRIB table (MribTable).
Parameters:
| mrib | the Mrib entry to delete. |
| PimVif * vif_find_pim_register ()
| vif_find_pim_register |
[const]
Get the PIM-Register virtual interface.
Returns: the PIM-Register virtual interface if exists, otherwise NULL.
| uint16_t pim_register_vif_index ()
| pim_register_vif_index |
[const]
Get the vif index of the PIM-Register virtual interface.
Returns: the vif index of the PIM-Register virtual interface if exists, otherwise Vif::VIF_INDEX_INVALID.
| PimMrt& pim_mrt ()
| pim_mrt |
Get the PIM Multicast Routing Table.
Returns: a reference to the PIM Multicast Routing Table (PimMrt).
| PimMribTable& pim_mrib_table ()
| pim_mrib_table |
Get the table with the Multicast Routing Information Base used by PIM.
Returns: a reference to the table with the Multicast Routing Information Base used by PIM (PimMribTable).
| PimBsr& pim_bsr ()
| pim_bsr |
Get the PIM Bootstrap entity.
Returns: a reference to the PIM Bootstrap entity (PimBsr).
| RpTable& rp_table ()
| rp_table |
Get the PIM RP table.
Returns: a reference to the PIM RP table (RpTable).
| PimScopeZoneTable& pim_scope_zone_table ()
| pim_scope_zone_table |
Get the PIM Scope-Zone table.
Returns: a reference to the PIM Scope-Zone table.
| Mifset& pim_vifs_dr ()
| pim_vifs_dr |
Get the set of vifs for which this PIM note is a Designated Router.
Returns: the Mifset indicating the vifs for which this PIM node is a Designated Router.
| void set_pim_vifs_dr (uint16_t vif_index, bool v)
| set_pim_vifs_dr |
Set/reset a virtual interface as a Designated Router.
Parameters:
| vif_index | the vif index of the virtual interface to set/reset as a Designated Router. |
| v | if true, set the virtual interface as a Designated Router, otherwise reset it. |
| PimNbr * pim_nbr_rpf_find (const IPvX& dst_addr)
| pim_nbr_rpf_find |
Find the RPF PIM neighbor for a given destination address.
Parameters:
| dst_addr | the destination address to lookup. |
Returns: the RPF PIM neighbor (PimNbr) toward dst_addr if found, otherwise NULL.
| PimNbr * pim_nbr_rpf_find (const IPvX& dst_addr, const Mrib *mrib)
| pim_nbr_rpf_find |
Find the RPF PIM neighbor for a given destination address, and already known Mrib entry.
Parameters:
| dst_addr | the destination address to lookup. |
| mrib | the already known Mrib entry. |
Returns: the RPF PIM neighbor (PimNbr) toward dst_addr if found, otherwise NULL.
| PimNbr * pim_nbr_find (const IPvX& nbr_addr)
| pim_nbr_find |
Find a PIM neighbor.
Parameters:
| nbr_addr | the address of the PIM neighbor. |
Returns: the PIM neighbor (PimNbr) if found, otherwise NULL.
| void enable_bsr ()
| enable_bsr |
Enable the PIM Bootstrap mechanism.
| void disable_bsr ()
| disable_bsr |
Disable the PIM Bootstrap mechanism.
| int start_bsr ()
| start_bsr |
Start the Bootstrap mechanism.
Returns: XORP_OK if a new address, otherwise XORP_ERROR.
| int stop_bsr ()
| stop_bsr |
Stop the Bootstrap mechanism.
Returns: XORP_OK if a new address, otherwise XORP_ERROR.
| int set_vif_proto_version (const string& vif_name,
int proto_version)
| set_vif_proto_version |
| int reset_vif_proto_version (const string& vif_name)
| reset_vif_proto_version |
| int set_vif_hello_triggered_delay (const string& vif_name,
uint16_t hello_triggered_delay)
| set_vif_hello_triggered_delay |
| int reset_vif_hello_triggered_delay (const string vif_name)
| reset_vif_hello_triggered_delay |
| int set_vif_hello_period (const string& vif_name,
uint16_t hello_period)
| set_vif_hello_period |
| int reset_vif_hello_period (const string& vif_name)
| reset_vif_hello_period |
| int set_vif_hello_holdtime (const string& vif_name,
uint16_t hello_holdtime)
| set_vif_hello_holdtime |
| int reset_vif_hello_holdtime (const string& vif_name)
| reset_vif_hello_holdtime |
| int set_vif_dr_priority (const string& vif_name,
uint32_t dr_priority)
| set_vif_dr_priority |
| int reset_vif_dr_priority (const string& vif_name)
| reset_vif_dr_priority |
| int set_vif_lan_delay (const string& vif_name, uint16_t lan_delay)
| set_vif_lan_delay |
| int reset_vif_lan_delay (const string& vif_name)
| reset_vif_lan_delay |
| int set_vif_override_interval (const string& vif_name,
uint16_t override_interval)
| set_vif_override_interval |
| int reset_vif_override_interval (const string& vif_name)
| reset_vif_override_interval |
| int set_vif_is_tracking_support_disabled (const string& vif_name,
bool is_tracking_support_disabled)
| set_vif_is_tracking_support_disabled |
| int reset_vif_is_tracking_support_disabled (const string& vif_name)
| reset_vif_is_tracking_support_disabled |
| int set_vif_accept_nohello_neighbors (const string& vif_name,
bool accept_nohello_neighbors)
| set_vif_accept_nohello_neighbors |
| int reset_vif_accept_nohello_neighbors (const string& vif_name)
| reset_vif_accept_nohello_neighbors |
| int set_vif_join_prune_period (const string& vif_name,
uint16_t join_prune_period)
| set_vif_join_prune_period |
| int reset_vif_join_prune_period (const string& vif_name)
| reset_vif_join_prune_period |
| int add_config_scope_zone_by_vif_name (const IPvXNet &scope_zone_id,
const string& vif_name)
| add_config_scope_zone_by_vif_name |
| int add_config_scope_zone_by_vif_addr (const IPvXNet &scope_zone_id,
const IPvX& vif_addr)
| add_config_scope_zone_by_vif_addr |
| int delete_config_scope_zone_by_vif_name (const IPvXNet &scope_zone_id,
const string& vif_name)
| delete_config_scope_zone_by_vif_name |
| int delete_config_scope_zone_by_vif_addr (const IPvXNet &scope_zone_id,
const IPvX& vif_addr)
| delete_config_scope_zone_by_vif_addr |
| int add_config_cand_bsr_by_vif_name (const IPvXNet& scope_zone_id,
bool is_scope_zone,
const string& vif_name,
uint8_t bsr_priority,
uint8_t hash_masklen)
| add_config_cand_bsr_by_vif_name |
| int add_config_cand_bsr_by_addr (const IPvXNet& scope_zone_id,
bool is_scope_zone,
const IPvX& my_cand_bsr_addr,
uint8_t bsr_priority,
uint8_t hash_masklen)
| add_config_cand_bsr_by_addr |
| int delete_config_cand_bsr (const IPvXNet& scope_zone_id,
bool is_scope_zone)
| delete_config_cand_bsr |
| int add_config_cand_rp_by_vif_name (const IPvXNet& group_prefix,
bool is_scope_zone,
const string& vif_name,
uint8_t rp_priority,
uint16_t rp_holdtime)
| add_config_cand_rp_by_vif_name |
| int add_config_cand_rp_by_addr (const IPvXNet& group_prefix,
bool is_scope_zone,
const IPvX& my_cand_rp_addr,
uint8_t rp_priority,
uint16_t rp_holdtime)
| add_config_cand_rp_by_addr |
| int delete_config_cand_rp_by_vif_name (const IPvXNet& group_prefix,
bool is_scope_zone,
const string& vif_name)
| delete_config_cand_rp_by_vif_name |
| int delete_config_cand_rp_by_addr (const IPvXNet& group_prefix,
bool is_scope_zone,
const IPvX& my_cand_rp_addr)
| delete_config_cand_rp_by_addr |
| int add_config_rp (const IPvXNet& group_prefix,
const IPvX& rp_addr,
uint8_t rp_priority,
uint8_t hash_masklen)
| add_config_rp |
| int delete_config_rp (const IPvXNet& group_prefix,
const IPvX& rp_addr)
| delete_config_rp |
| int config_rp_done ()
| config_rp_done |
| bool is_log_trace ()
| is_log_trace |
[const]
| void set_log_trace (bool is_enabled)
| set_log_trace |
| int add_test_jp_entry (const IPvX& source_addr,
const IPvX& group_addr,
uint32_t group_masklen,
mrt_entry_type_t mrt_entry_type,
action_jp_t action_jp, uint16_t holdtime,
bool new_group_bool)
| add_test_jp_entry |
| int send_test_jp_entry (const IPvX& nbr_addr)
| send_test_jp_entry |
| int send_test_assert (const string& vif_name,
const IPvX& source_addr,
const IPvX& group_addr,
bool rpt_bit,
uint32_t metric_preference,
uint32_t metric)
| send_test_assert |
| int add_test_bsr_zone (const PimScopeZoneId& zone_id,
const IPvX& bsr_addr,
uint8_t bsr_priority,
uint8_t hash_masklen,
uint16_t fragment_tag)
| add_test_bsr_zone |
| int add_test_bsr_group_prefix (const PimScopeZoneId& zone_id,
const IPvXNet& group_prefix,
bool is_scope_zone,
uint8_t expected_rp_count)
| add_test_bsr_group_prefix |
| int add_test_bsr_rp (const PimScopeZoneId& zone_id,
const IPvXNet& group_prefix,
const IPvX& rp_addr,
uint8_t rp_priority,
uint16_t rp_holdtime)
| add_test_bsr_rp |
| int send_test_bootstrap (const string& vif_name)
| send_test_bootstrap |
| int send_test_bootstrap_by_dest (const string& vif_name,
const IPvX& dest_addr)
| send_test_bootstrap_by_dest |
| int send_test_cand_rp_adv ()
| send_test_cand_rp_adv |
| void add_pim_mre_no_pim_nbr (PimMre *pim_mre)
| add_pim_mre_no_pim_nbr |
| void delete_pim_mre_no_pim_nbr (PimMre *pim_mre)
| delete_pim_mre_no_pim_nbr |
| list<PimNbr *>& processing_pim_nbr_list ()
| processing_pim_nbr_list |
| void init_processing_pim_mre_rp (uint16_t vif_index,
const IPvX& pim_nbr_addr)
| init_processing_pim_mre_rp |
| void init_processing_pim_mre_wc (uint16_t vif_index,
const IPvX& pim_nbr_addr)
| init_processing_pim_mre_wc |
| void init_processing_pim_mre_sg (uint16_t vif_index,
const IPvX& pim_nbr_addr)
| init_processing_pim_mre_sg |
| void init_processing_pim_mre_sg_rpt (uint16_t vif_index,
const IPvX& pim_nbr_addr)
| init_processing_pim_mre_sg_rpt |
| PimNbr * find_processing_pim_mre_rp (uint16_t vif_index,
const IPvX& pim_nbr_addr)
| find_processing_pim_mre_rp |
| PimNbr * find_processing_pim_mre_wc (uint16_t vif_index,
const IPvX& pim_nbr_addr)
| find_processing_pim_mre_wc |
| PimNbr * find_processing_pim_mre_sg (uint16_t vif_index,
const IPvX& pim_nbr_addr)
| find_processing_pim_mre_sg |
| PimNbr * find_processing_pim_mre_sg_rpt (uint16_t vif_index,
const IPvX& pim_nbr_addr)
| find_processing_pim_mre_sg_rpt |
| Generated by: pavlin on possum.icir.org on Mon Mar 10 19:34:55 2003, using kdoc 2.0a54+XORP. |