summaryrefslogtreecommitdiffstats
path: root/include/osmocom/gsm
diff options
context:
space:
mode:
authorNeels Hofmeyr <neels@hofmeyr.de>2018-04-16 22:41:51 +0200
committerHarald Welte <laforge@gnumonks.org>2018-05-08 20:32:56 +0000
commitafacc2be9ff2fccf6ff7c9c00849081627754ace (patch)
tree2bc2f87209101d8f0cd9bd6a229ba97409df2157 /include/osmocom/gsm
parent1284c3e96170b1622106097e944e07354549bb2e (diff)
add gsm0808 channel enum to IE val conversion functions
Add: - gsm0808_current_channel_type_1() - gsm0808_permitted_speech() - gsm0808_chosen_channel() - gsm0808_channel_type_name() gsm0808_permitted_speech() is moved from osmo-bsc's bssap_speech_from_lchan(); gsm0808_chosen_channel() is moved from osmo-bsc's lchan_to_chosen_channel(); Rationale: will be re-used by inter-BSC handover, makes sense to keep with the other gsm0808 utils. Related: OS#2283 (inter-BSC handover, BSC side) Change-Id: I8a3cc5d4548e9a78d945d54c69ccced251edcec9
Diffstat (limited to 'include/osmocom/gsm')
-rw-r--r--include/osmocom/gsm/gsm0808_utils.h107
1 files changed, 107 insertions, 0 deletions
diff --git a/include/osmocom/gsm/gsm0808_utils.h b/include/osmocom/gsm/gsm0808_utils.h
index 8cdb74bb..24c139a8 100644
--- a/include/osmocom/gsm/gsm0808_utils.h
+++ b/include/osmocom/gsm/gsm0808_utils.h
@@ -26,7 +26,9 @@
struct sockaddr_storage;
#include <osmocom/gsm/protocol/gsm_08_08.h>
+#include <osmocom/gsm/protocol/gsm_04_08.h>
#include <osmocom/gsm/gsm23003.h>
+#include <osmocom/gsm/gsm_utils.h>
/*! (225-1)/2 is the maximum number of elements in a cell identifier list. */
#define GSM0808_CELL_ID_LIST2_MAXLEN 127
@@ -102,4 +104,109 @@ int gsm0808_chan_type_to_speech_codec(uint8_t perm_spch);
int gsm0808_speech_codec_from_chan_type(struct gsm0808_speech_codec *sc,
uint8_t perm_spch);
+/*! Return 3GPP TS 48.008 3.2.2.49 Current Channel Type 1 from enum gsm_chan_t. */
+static inline uint8_t gsm0808_current_channel_type_1(enum gsm_chan_t type)
+{
+ switch (type) {
+ default:
+ return 0;
+ case GSM_LCHAN_SDCCH:
+ return 0x01;
+ case GSM_LCHAN_TCH_F:
+ return 0x18;
+ case GSM_LCHAN_TCH_H:
+ return 0x19;
+ }
+}
+
+/*! Return 3GPP TS 48.008 3.2.2.51 Speech Version aka permitted speech version indication in 3.2.2.11
+ * Channel Type. */
+static inline enum gsm0808_permitted_speech gsm0808_permitted_speech(enum gsm_chan_t type,
+ enum gsm48_chan_mode mode)
+{
+ switch (mode) {
+ case GSM48_CMODE_SPEECH_V1:
+ switch (type) {
+ case GSM_LCHAN_TCH_F:
+ return GSM0808_PERM_FR1;
+ case GSM_LCHAN_TCH_H:
+ return GSM0808_PERM_HR1;
+ default:
+ return 0;
+ }
+ case GSM48_CMODE_SPEECH_EFR:
+ switch (type) {
+ case GSM_LCHAN_TCH_F:
+ return GSM0808_PERM_FR2;
+ case GSM_LCHAN_TCH_H:
+ return GSM0808_PERM_HR2;
+ default:
+ return 0;
+ }
+ case GSM48_CMODE_SPEECH_AMR:
+ switch (type) {
+ case GSM_LCHAN_TCH_F:
+ return GSM0808_PERM_HR3;
+ case GSM_LCHAN_TCH_H:
+ return GSM0808_PERM_HR3;
+ default:
+ return 0;
+ }
+ default:
+ return 0;
+ }
+}
+
+/*! Return 3GPP TS 48.008 3.2.2.33 Chosen Channel. */
+static inline uint8_t gsm0808_chosen_channel(enum gsm_chan_t type, enum gsm48_chan_mode mode)
+{
+ uint8_t channel_mode = 0, channel = 0;
+
+ switch (mode) {
+ case GSM48_CMODE_SPEECH_V1:
+ case GSM48_CMODE_SPEECH_EFR:
+ case GSM48_CMODE_SPEECH_AMR:
+ channel_mode = 0x9;
+ break;
+ case GSM48_CMODE_SIGN:
+ channel_mode = 0x8;
+ break;
+ case GSM48_CMODE_DATA_14k5:
+ channel_mode = 0xe;
+ break;
+ case GSM48_CMODE_DATA_12k0:
+ channel_mode = 0xb;
+ break;
+ case GSM48_CMODE_DATA_6k0:
+ channel_mode = 0xc;
+ break;
+ case GSM48_CMODE_DATA_3k6:
+ channel_mode = 0xd;
+ break;
+ default:
+ return 0;
+ }
+
+ switch (type) {
+ case GSM_LCHAN_NONE:
+ channel = 0x0;
+ break;
+ case GSM_LCHAN_SDCCH:
+ channel = 0x1;
+ break;
+ case GSM_LCHAN_TCH_F:
+ channel = 0x8;
+ break;
+ case GSM_LCHAN_TCH_H:
+ channel = 0x9;
+ break;
+ default:
+ return 0;
+ }
+
+ return channel_mode << 4 | channel;
+}
+
+const char *gsm0808_channel_type_name(const struct gsm0808_channel_type *ct);
+
/*! @} */