libosmo-sigtran 2.1.0.165-6ea6
Osmocom SIGTRAN library
|
#include <stdint.h>
#include <stdbool.h>
#include <osmocom/core/linuxlist.h>
Go to the source code of this file.
Data Structures | |
struct | osmo_ss7_route |
Macros | |
#define | OSMO_SS7_ROUTE_PRIO_DEFAULT 5 |
#define | LOGPRT(rt, subsys, level, fmt, args ...) |
Enumerations | |
enum | osmo_ss7_route_status { OSMO_SS7_ROUTE_STATUS_UNAVAILABLE , OSMO_SS7_ROUTE_STATUS_AVAILABLE , OSMO_SS7_ROUTE_STATUS_RESTRICTED } |
Functions | |
static const char * | ss7_route_status_name (enum osmo_ss7_route_status val) |
struct osmo_ss7_route * | ss7_route_alloc (struct osmo_ss7_route_table *rtbl, uint32_t pc, uint32_t mask, bool dynamic) |
Allocate a route entry. More... | |
struct osmo_ss7_route * | ss7_route_create (struct osmo_ss7_route_table *rtbl, uint32_t dpc, uint32_t mask, bool dynamic, const char *linkset_name) |
Create a new route in the given routing table. More... | |
void | ss7_route_destroy (struct osmo_ss7_route *rt) |
Destroy a given SS7 route. More... | |
struct osmo_ss7_route * | ss7_route_find_dpc (struct osmo_ss7_route_table *rtbl, uint32_t dpc) |
struct osmo_ss7_route * | ss7_route_find_dpc_mask (struct osmo_ss7_route_table *rtbl, uint32_t dpc, uint32_t mask) |
int | ss7_route_set_linkset (struct osmo_ss7_route *rt, const char *linkset_name) |
Set linkset on route entry. More... | |
int | ss7_route_insert (struct osmo_ss7_route *rt) |
Insert route into its routing table. More... | |
bool | ss7_route_dest_is_available (const struct osmo_ss7_route *rt) |
bool | ss7_route_is_available (const struct osmo_ss7_route *rt) |
bool | ss7_route_is_fully_qualified (const struct osmo_ss7_route *rt) |
static bool | ss7_route_is_summary (const struct osmo_ss7_route *rt) |
void | ss7_route_update_route_status (struct osmo_ss7_route *rt, enum osmo_ss7_route_status status) |
Variables | |
const struct value_string | ss7_route_status_names [] |
#define LOGPRT | ( | rt, | |
subsys, | |||
level, | |||
fmt, | |||
args ... | |||
) |
#define OSMO_SS7_ROUTE_PRIO_DEFAULT 5 |
struct osmo_ss7_route * ss7_route_alloc | ( | struct osmo_ss7_route_table * | rtbl, |
uint32_t | pc, | ||
uint32_t | mask, | ||
bool | dynamic | ||
) |
Allocate a route entry.
[in] | rtbl | Routing Table where the route belongs |
[in] | pc | Point Code of the destination of the route |
[in] | mask | Mask of the destination Point Code pc |
[in] | dynamic | Whether the route is dynamic |
The returned route has no linkset associated yet, user must associate it using API ss7_route_set_linkset() before inserting the route into its routing table.
Fields priority and qos_class may be set before inserting the route into its routing table:
Use API ss7_route_insert() to insert the route into its routing table.
The route entry allocated with this API can be destroyed/freed at any point using API ss7_route_destroy(), regardless of it being already inserted or not in its routing table.
Dynamic routes are not configured by the user (VTY), and hence cannot be removed by the user. Dynamic routes are not stored in the config and hence they don't show up in eg "show running-config"; they can be listed using specific VTY commands like "show cs7 instance 0 route".
References osmo_ss7_instance::cfg, osmo_ss7_route::cfg, osmo_ss7_route::dyn_allocated, osmo_ss7_route_table::inst, osmo_ss7_route::list, osmo_ss7_route::mask, NULL, osmo_ss7_pc_normalize(), OSMO_SS7_ROUTE_PRIO_DEFAULT, OSMO_SS7_ROUTE_STATUS_AVAILABLE, osmo_ss7_route::pc, osmo_ss7_instance::pc_fmt, osmo_ss7_route::priority, osmo_ss7_route::rtable, ss7_initialized, and osmo_ss7_route::status.
Referenced by DEFUN_ATTR(), and ss7_route_create().
struct osmo_ss7_route * ss7_route_create | ( | struct osmo_ss7_route_table * | rtbl, |
uint32_t | pc, | ||
uint32_t | mask, | ||
bool | dynamic, | ||
const char * | linkset_name | ||
) |
Create a new route in the given routing table.
[in] | rtbl | Routing Table in which the route is to be created |
[in] | pc | Point Code of the destination of the route |
[in] | mask | Mask of the destination Point Code pc |
[in] | dynamic | Whether the route is dynamic |
[in] | linkset_name | string name of the linkset to be used |
The route allocated and returned by this API is already inserted into the routing table, with priority and qos-class set to 0. If you plan to use different values for priority and qos-class, avoid using this API and use ss7_route_alloc() + ss7_route_set_linkset() + ss7_route_insert() instead.
References osmo_ss7_route::linkset_name, osmo_ss7_route::mask, NULL, osmo_ss7_route::pc, ss7_route_alloc(), ss7_route_insert(), ss7_route_set_linkset(), and ss7_route_table_find_route_by_dpc_mask().
Referenced by handle_rkey_reg(), osmo_sccp_simple_client_on_ss7_id(), osmo_sccp_simple_server_add_clnt(), and xua_snm_srm_pc_available_single().
bool ss7_route_dest_is_available | ( | const struct osmo_ss7_route * | rt | ) |
References osmo_ss7_route::as, osmo_ss7_route::dest, osmo_ss7_route::linkset, osmo_ss7_as_active(), and ss7_linkset_is_available().
Referenced by ss7_route_is_available(), and vty_dump_rtable().
void ss7_route_destroy | ( | struct osmo_ss7_route * | rt | ) |
Destroy a given SS7 route.
References LOGPRT, osmo_ss7_route_name(), ss7_combined_linkset_del_route(), ss7_initialized, and ss7_route_inserted().
Referenced by DEFUN_ATTR(), handle_rkey_dereg(), osmo_sccp_simple_client_on_ss7_id(), osmo_sccp_simple_server_add_clnt(), ss7_route_table_del_routes_by_as(), and ss7_route_table_del_routes_by_linkset().
struct osmo_ss7_route * ss7_route_find_dpc | ( | struct osmo_ss7_route_table * | rtbl, |
uint32_t | dpc | ||
) |
struct osmo_ss7_route * ss7_route_find_dpc_mask | ( | struct osmo_ss7_route_table * | rtbl, |
uint32_t | dpc, | ||
uint32_t | mask | ||
) |
int ss7_route_insert | ( | struct osmo_ss7_route * | rt | ) |
Insert route into its routing table.
[in] | rt | Route to be inserted into its routing table |
A route is only really used once it has been inserted into its routing table.
References osmo_ss7_route::cfg, osmo_ss7_route::clset, osmo_ss7_route::dyn_allocated, osmo_ss7_route::linkset_name, osmo_ss7_route::list, LOGPRT, osmo_ss7_route::mask, osmo_ss7_route::pc, osmo_ss7_route::priority, osmo_ss7_combined_linkset::routes, osmo_ss7_route::rtable, ss7_combined_linkset_add_route(), ss7_combined_linkset_alloc(), ss7_route_inserted(), and ss7_route_table_find_combined_linkset().
Referenced by DEFUN_ATTR(), and ss7_route_create().
bool ss7_route_is_available | ( | const struct osmo_ss7_route * | rt | ) |
References OSMO_SS7_ROUTE_STATUS_AVAILABLE, ss7_route_dest_is_available(), and osmo_ss7_route::status.
Referenced by current_rt(), DEFUN(), ss7_combined_linkset_is_available(), ss7_combined_linkset_lookup_route(), ss7_combined_linkset_select_route_roundrobin(), ss7_route_table_dpc_is_accessible_skip_as(), and ss7_route_table_dpc_is_accessible_via_as().
bool ss7_route_is_fully_qualified | ( | const struct osmo_ss7_route * | rt | ) |
References osmo_ss7_instance::cfg, osmo_ss7_route::cfg, osmo_ss7_route_table::inst, osmo_ss7_route::mask, osmo_ss7_instance::pc_fmt, osmo_ss7_route::rtable, and ss7_pc_full_mask().
Referenced by ss7_route_is_summary().
|
inlinestatic |
References ss7_route_is_fully_qualified().
Referenced by as_snm_pc_available(), as_snm_pc_unavailable(), and ss7_route_table_update_route_status_by_as().
int ss7_route_set_linkset | ( | struct osmo_ss7_route * | rt, |
const char * | linkset_name | ||
) |
Set linkset on route entry.
[in] | rt | Route to be configured |
[in] | linkset_name | string name of the linkset to be used |
References osmo_ss7_route::as, osmo_ss7_route::cfg, osmo_ss7_route::dest, osmo_ss7_route_table::inst, osmo_ss7_route::linkset, osmo_ss7_route::linkset_name, LOGPRT, NULL, osmo_ss7_as_find_by_name(), osmo_ss7_route_name(), osmo_ss7_route::rtable, ss7_linkset_find_by_name(), and ss7_route_inserted().
Referenced by DEFUN_ATTR(), and ss7_route_create().
|
inlinestatic |
References ss7_route_status_names.
Referenced by ss7_route_update_route_status(), and xua_snm_srm_pc_available_single().
void ss7_route_update_route_status | ( | struct osmo_ss7_route * | rt, |
enum osmo_ss7_route_status | status | ||
) |
References LOGPRT, ss7_route_status_name(), and osmo_ss7_route::status.
Referenced by ss7_route_table_update_route_status_by_as(), and xua_snm_srm_pc_available_single().
|
extern |
Referenced by ss7_route_status_name().