aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorAlexander Couzens <lynxis@fe80.eu>2020-10-11 21:22:42 +0200
committerAlexander Couzens <lynxis@fe80.eu>2020-10-12 15:54:21 +0200
commit125298f2b5484912d805c2d152a94341ddee3d69 (patch)
tree1629f48d9d18a75df1ea48d8fbd2584b04dc0400 /src
parent979f5f5449909c1b779258e5c5ec66f5de02a3b2 (diff)
gprs_ns2: add gprs_ns2_nse_sns_remote() returns the initial SNS address
Allows the PCU to get the SNS remote address. Change-Id: I54f110acc3acccb362f6e554324d08cc42b7c328
Diffstat (limited to 'src')
-rw-r--r--src/gb/gprs_ns2_sns.c15
-rw-r--r--src/gb/libosmogb.map1
2 files changed, 16 insertions, 0 deletions
diff --git a/src/gb/gprs_ns2_sns.c b/src/gb/gprs_ns2_sns.c
index d4de8ae2..1afd4b7c 100644
--- a/src/gb/gprs_ns2_sns.c
+++ b/src/gb/gprs_ns2_sns.c
@@ -194,6 +194,21 @@ static struct gprs_ns2_vc *nsvc_by_ip6_elem(struct gprs_ns2_nse *nse,
return gprs_ns2_nsvc_by_sockaddr_nse(nse, &sa);
}
+/*! Return the initial SNS remote socket address
+ * \param nse NS Entity
+ * \return address of the initial SNS connection; NULL in case of error
+ */
+const struct osmo_sockaddr *gprs_ns2_nse_sns_remote(struct gprs_ns2_nse *nse)
+{
+ struct ns2_sns_state *gss;
+
+ if (!nse->bss_sns_fi)
+ return NULL;
+
+ gss = (struct ns2_sns_state *) nse->bss_sns_fi->priv;
+ return &gss->initial;
+}
+
/*! called when a nsvc is beeing freed */
void ns2_sns_free_nsvc(struct gprs_ns2_vc *nsvc)
{
diff --git a/src/gb/libosmogb.map b/src/gb/libosmogb.map
index f542496d..e6557b7e 100644
--- a/src/gb/libosmogb.map
+++ b/src/gb/libosmogb.map
@@ -102,6 +102,7 @@ gprs_ns2_ll_str_buf;
gprs_ns2_ll_str_c;
gprs_ns2_nse_by_nsei;
gprs_ns2_nse_nsei;
+gprs_ns2_nse_sns_remote;
gprs_ns2_nsvc_by_nsvci;
gprs_ns2_nsvc_by_sockaddr;
gprs_ns2_recv_prim;