This is merely a historical archive of years 2008-2021, before the migration to mailman3.
A maintained and still updated list archive can be found at https://lists.osmocom.org/hyperkitty/list/gerrit-log@lists.osmocom.org/.
dexter gerrit-no-reply at lists.osmocom.org
Review at https://gerrit.osmocom.org/2184
gsm0808: Add create functions for BSS_MAP_MSG_ASSIGMENT_RQST
gsm0808.h/c lacks functionality to generate BSS_MAP_MSG_ASSIGMENT_RQST messages.
These messages are required if the code is used in an MSC implementation.
This commit adds a gsm0808_create_assignment() function, that generates an
A/AoiP BSS_MAP_MSG_PAGING message.
Change-Id: I4d1d455a1e1cf95407e23ded7b7defbcf2dd6ff0
---
M include/osmocom/gsm/gsm0808.h
M src/gsm/gsm0808.c
M src/gsm/libosmogsm.map
M tests/gsm0808/gsm0808_test.c
M tests/gsm0808/gsm0808_test.ok
5 files changed, 138 insertions(+), 0 deletions(-)
git pull ssh://gerrit.osmocom.org:29418/libosmocore refs/changes/84/2184/1
diff --git a/include/osmocom/gsm/gsm0808.h b/include/osmocom/gsm/gsm0808.h
index 6cd933b..aa8148a 100644
--- a/include/osmocom/gsm/gsm0808.h
+++ b/include/osmocom/gsm/gsm0808.h
@@ -41,6 +41,11 @@
struct msgb *gsm0808_create_classmark_update(const uint8_t *cm2, uint8_t cm2_len,
const uint8_t *cm3, uint8_t cm3_len);
struct msgb *gsm0808_create_sapi_reject(uint8_t link_id);
+struct msgb *gsm0808_create_assignment(struct gsm0808_channel_type *ct,
+ uint16_t *cic,
+ struct sockaddr_storage *ss,
+ struct llist_head *scl,
+ uint32_t *ci);
struct msgb *gsm0808_create_assignment_completed_aoip(uint8_t rr_cause,
uint8_t chosen_channel,
uint8_t encr_alg_id,
diff --git a/src/gsm/gsm0808.c b/src/gsm/gsm0808.c
index b6ae0fa..b43e2eb 100644
--- a/src/gsm/gsm0808.c
+++ b/src/gsm/gsm0808.c
@@ -255,6 +255,86 @@
return msg;
}
+struct msgb *gsm0808_create_assignment(struct gsm0808_channel_type *ct,
+ uint16_t *cic,
+ struct sockaddr_storage *ss,
+ struct llist_head *scl, uint32_t *ci)
+{
+ /* See also: 3GPP TS 48.008 3.2.1.1 ASSIGNMENT REQUEST */
+ struct msgb *msg;
+ struct msgb *ct_encoded;
+ uint16_t cic_sw;
+ struct msgb *ss_encoded;
+ struct msgb *scl_encoded;
+ uint32_t ci_sw;
+
+ /* Mandatory emelent! */
+ OSMO_ASSERT(ct);
+
+ msg =
+ msgb_alloc_headroom(BSSMAP_MSG_SIZE, BSSMAP_MSG_HEADROOM,
+ "bssmap: ass req");
+ if (!msg)
+ return NULL;
+
+ /* Message Type 3.2.2.1 */
+ msgb_v_put(msg, BSS_MAP_MSG_ASSIGMENT_RQST);
+
+ /* Channel Type 3.2.2.11 */
+ ct_encoded = gsm0808_enc_channel_type(ct);
+ if (!ct_encoded) {
+ msgb_free(msg);
+ return NULL;
+ }
+ msgb_tlv_put(msg, GSM0808_IE_CHANNEL_TYPE, ct_encoded->len,
+ ct_encoded->data);
+ msgb_free(ct_encoded);
+
+ /* Circuit Identity Code 3.2.2.2 */
+ if (cic) {
+ cic_sw = htons(*cic);
+ msgb_tv_fixed_put(msg, GSM0808_IE_CIRCUIT_IDENTITY_CODE,
+ sizeof(cic_sw), (uint8_t *) & cic_sw);
+ }
+
+ /* AoIP: AoIP Transport Layer Address (MGW) 3.2.2.102 */
+ if (ss) {
+ ss_encoded = gsm0808_enc_aoip_trasp_addr(ss);
+ if (!ss_encoded) {
+ msgb_free(msg);
+ return NULL;
+ }
+ msgb_tlv_put(msg, GSM0808_IE_AOIP_TRASP_ADDR,
+ ss_encoded->len, ss_encoded->data);
+ msgb_free(ss_encoded);
+ }
+
+ /* AoIP: Codec List (MSC Preferred) 3.2.2.103 */
+ if (scl) {
+ scl_encoded = gsm0808_enc_speech_codec_list(scl);
+ if (!scl_encoded) {
+ msgb_free(msg);
+ return NULL;
+ }
+ msgb_tlv_put(msg, GSM0808_IE_SPEECH_CODEC_LIST,
+ scl_encoded->len, scl_encoded->data);
+ msgb_free(scl_encoded);
+ }
+
+ /* AoIP: Call Identifier 3.2.2.105 */
+ if (ci) {
+ ci_sw = htonl(*ci);
+ msgb_tv_fixed_put(msg, GSM0808_IE_CALL_ID, sizeof(ci_sw),
+ (uint8_t *) & ci_sw);
+ }
+
+ /* push the bssmap header */
+ msg->l3h =
+ msgb_tv_push(msg, BSSAP_MSG_BSS_MANAGEMENT, msgb_length(msg));
+
+ return msg;
+}
+
struct msgb *gsm0808_create_assignment_completed_aoip(uint8_t rr_cause,
uint8_t chosen_channel,
uint8_t encr_alg_id,
diff --git a/src/gsm/libosmogsm.map b/src/gsm/libosmogsm.map
index fb06bff..fcd13d1 100644
--- a/src/gsm/libosmogsm.map
+++ b/src/gsm/libosmogsm.map
@@ -124,6 +124,7 @@
gsm0808_att_tlvdef;
gsm0808_bssap_name;
gsm0808_bssmap_name;
+gsm0808_create_assignment;
gsm0808_create_assignment_completed;
gsm0808_create_assignment_completed_aoip;
gsm0808_create_assignment_failure;
diff --git a/tests/gsm0808/gsm0808_test.c b/tests/gsm0808/gsm0808_test.c
index 4743658..549229b 100644
--- a/tests/gsm0808/gsm0808_test.c
+++ b/tests/gsm0808/gsm0808_test.c
@@ -280,6 +280,56 @@
msgb_free(msg);
}
+static void test_create_ass(const void *ctx)
+{
+ static const uint8_t res1[] =
+ { 0x00, 0x0a, 0x01, 0x0b, 0x04, 0x01, 0x0b, 0xa1, 0x25, 0x01, 0x00,
+ 0x04 };
+ static const uint8_t res2[] =
+ { 0x00, 0x20, 0x01, 0x0b, 0x04, 0x01, 0x0b, 0xa1, 0x25, 0x01, 0x00,
+ 0x04, GSM0808_IE_AOIP_TRASP_ADDR, 0x06, 0xc0, 0xa8, 0x64, 0x17,
+ 0x04, 0xd2, GSM0808_IE_SPEECH_CODEC_LIST, 0x07, 0x5f, 0xab, 0xcd,
+ 0xef, 0xa5, 0x9f, 0xf2, GSM0808_IE_CALL_ID, 0xaa, 0xbb, 0xcc,
+ 0xdd };
+
+ struct msgb *msg;
+ struct gsm0808_channel_type ct;
+ uint16_t cic = 0004;
+ struct sockaddr_storage ss;
+ struct sockaddr_in sin;
+ struct llist_head *sc_list;
+ uint32_t call_id = 0xAABBCCDD;
+
+ memset(&ct, 0, sizeof(ct));
+ ct.ch_indctr = GSM0808_CHAN_SPEECH;
+ ct.ch_rate_type = GSM0808_SPEECH_HALF_PREF;
+ ct.perm_spch[0] = GSM0808_PERM_FR3;
+ ct.perm_spch[1] = GSM0808_PERM_HR3;
+ ct.perm_spch_len = 2;
+
+ memset(&sin, 0, sizeof(sin));
+ sin.sin_family = AF_INET;
+ sin.sin_port = htons(1234);
+ inet_aton("192.168.100.23", &sin.sin_addr);
+
+ memset(&ss, 0, sizeof(ss));
+ memcpy(&ss, &sin, sizeof(sin));
+
+ sc_list = setup_codec_list(ctx);
+
+ printf("Testing creating Assignment Request\n");
+ msg = gsm0808_create_assignment(&ct, &cic, NULL, NULL, NULL);
+ OSMO_ASSERT(msg);
+ VERIFY(msg, res1, ARRAY_SIZE(res1));
+ msgb_free(msg);
+
+ msg = gsm0808_create_assignment(&ct, &cic, &ss, sc_list, &call_id);
+ OSMO_ASSERT(msg);
+ VERIFY(msg, res2, ARRAY_SIZE(res2));
+ msgb_free(msg);
+ talloc_free(sc_list);
+}
+
static void test_create_ass_compl()
{
static const uint8_t res1[] = {
@@ -839,6 +889,7 @@
test_create_cipher_reject();
test_create_cm_u();
test_create_sapi_reject();
+ test_create_ass(ctx);
test_create_ass_compl();
test_create_ass_compl_aoip(ctx);
test_create_ass_fail();
diff --git a/tests/gsm0808/gsm0808_test.ok b/tests/gsm0808/gsm0808_test.ok
index 6170a7a..52af134 100644
--- a/tests/gsm0808/gsm0808_test.ok
+++ b/tests/gsm0808/gsm0808_test.ok
@@ -9,6 +9,7 @@
Testing creating Cipher Reject
Testing creating CM U
Testing creating SAPI Reject
+Testing creating Assignment Request
Testing creating Assignment Complete
Testing creating Assignment Complete (AoIP)
Testing creating Assignment Failure
--
To view, visit https://gerrit.osmocom.org/2184
To unsubscribe, visit https://gerrit.osmocom.org/settings
Gerrit-MessageType: newchange
Gerrit-Change-Id: I4d1d455a1e1cf95407e23ded7b7defbcf2dd6ff0
Gerrit-PatchSet: 1
Gerrit-Project: libosmocore
Gerrit-Branch: master
Gerrit-Owner: dexter <pmaier at sysmocom.de>