diff options
author | Max <msuraev@sysmocom.de> | 2016-06-07 14:31:36 +0200 |
---|---|---|
committer | Max <msuraev@sysmocom.de> | 2016-06-10 14:43:55 +0200 |
commit | a6ee8245923ee907a18a062c8a36a523ddfe36b0 (patch) | |
tree | f62626141682e2b70e05948f0e1d12bfb5f45df3 | |
parent | 30e7737bc25be637c4281f3a14ed64eacdf59691 (diff) |
Move common TCH code into src/common/tch.c
Move gen_empty_tch_msg() into src/common/ to make adding DTXd support
easier.
Change-Id: Ia0d4d0f9848fc2ab54f975a3b6d1815fbcdf78a7
Related: OS#1563
-rw-r--r-- | src/common/Makefile.am | 2 | ||||
-rw-r--r-- | src/common/tch.c | 67 | ||||
-rw-r--r-- | src/osmo-bts-litecell15/tch.c | 40 | ||||
-rw-r--r-- | src/osmo-bts-sysmo/tch.c | 40 |
4 files changed, 68 insertions, 81 deletions
diff --git a/src/common/Makefile.am b/src/common/Makefile.am index 8df65138..5c84ade4 100644 --- a/src/common/Makefile.am +++ b/src/common/Makefile.am @@ -4,7 +4,7 @@ LDADD = $(LIBOSMOCORE_LIBS) $(LIBOSMOTRAU_LIBS) noinst_LIBRARIES = libbts.a libl1sched.a libbts_a_SOURCES = gsm_data_shared.c sysinfo.c logging.c abis.c oml.c bts.c \ - rsl.c vty.c paging.c measurement.c amr.c lchan.c \ + rsl.c vty.c paging.c measurement.c amr.c tch.c lchan.c \ load_indication.c pcu_sock.c handover.c msg_utils.c \ load_indication.c pcu_sock.c handover.c msg_utils.c \ tx_power.c bts_ctrl_commands.c bts_ctrl_lookup.c \ diff --git a/src/common/tch.c b/src/common/tch.c new file mode 100644 index 00000000..d31b04ef --- /dev/null +++ b/src/common/tch.c @@ -0,0 +1,67 @@ +/* OsmoBTS common TCH code */ + +/* (C) 2011-2012 by Harald Welte <laforge@gnumonks.org> + * + * All Rights Reserved + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as published by + * the Free Software Foundation; either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + * + */ + +#include <osmo-bts/gsm_data.h> + +extern struct msgb *l1p_msgb_alloc(void); +extern uint8_t *get_payload_addr(struct msgb *msg); +extern void set_payload_type(struct msgb *msg, struct gsm_lchan *lchan); +extern void set_payload_size(struct msgb *msg, uint8_t size); + +struct msgb *gen_empty_tch_msg(struct gsm_lchan *lchan) +{ + struct msgb *msg; + uint8_t *l1_payload; + + msg = l1p_msgb_alloc(); + if (!msg) + return NULL; + + l1_payload = get_payload_addr(msg); + + switch (lchan->tch_mode) { + case GSM48_CMODE_SPEECH_AMR: + set_payload_type(msg, lchan); + if (lchan->tch.last_sid.len) { + memcpy(l1_payload, lchan->tch.last_sid.buf, + lchan->tch.last_sid.len); + set_payload_size(msg, lchan->tch.last_sid.len + 1); + } else { + /* FIXME: decide if we should send SPEECH_BAD or + * SID_BAD */ +#if 0 + *payload_type = GsmL1_TchPlType_Amr_SidBad; + memset(l1_payload, 0xFF, 5); + msu_param->u8Size = 5 + 3; +#else + /* send an all-zero SID */ + set_payload_size(msg, 8); +#endif + } + break; + default: + msgb_free(msg); + msg = NULL; + break; + } + + return msg; +} diff --git a/src/osmo-bts-litecell15/tch.c b/src/osmo-bts-litecell15/tch.c index 2c42ef57..d09264ad 100644 --- a/src/osmo-bts-litecell15/tch.c +++ b/src/osmo-bts-litecell15/tch.c @@ -530,43 +530,3 @@ err_payload_match: get_value_string(lc15bts_tch_pl_names, payload_type)); return -EINVAL; } - -struct msgb *gen_empty_tch_msg(struct gsm_lchan *lchan) -{ - struct msgb *msg; - uint8_t *l1_payload; - - msg = l1p_msgb_alloc(); - if (!msg) - return NULL; - - l1_payload = get_payload_addr(msg); - - switch (lchan->tch_mode) { - case GSM48_CMODE_SPEECH_AMR: - set_payload_type(msg, lchan); - if (lchan->tch.last_sid.len) { - memcpy(l1_payload, lchan->tch.last_sid.buf, - lchan->tch.last_sid.len); - set_payload_size(msg, lchan->tch.last_sid.len + 1); - } else { - /* FIXME: decide if we should send SPEECH_BAD or - * SID_BAD */ -#if 0 - *payload_type = GsmL1_TchPlType_Amr_SidBad; - memset(l1_payload, 0xFF, 5); - msu_param->u8Size = 5 + 3; -#else - /* send an all-zero SID */ - set_payload_size(msg, 8); -#endif - } - break; - default: - msgb_free(msg); - msg = NULL; - break; - } - - return msg; -} diff --git a/src/osmo-bts-sysmo/tch.c b/src/osmo-bts-sysmo/tch.c index 3b9fe36a..13f9ec67 100644 --- a/src/osmo-bts-sysmo/tch.c +++ b/src/osmo-bts-sysmo/tch.c @@ -625,43 +625,3 @@ err_payload_match: get_value_string(femtobts_tch_pl_names, payload_type)); return -EINVAL; } - -struct msgb *gen_empty_tch_msg(struct gsm_lchan *lchan) -{ - struct msgb *msg; - uint8_t *l1_payload; - - msg = l1p_msgb_alloc(); - if (!msg) - return NULL; - - l1_payload = get_payload_addr(msg); - - switch (lchan->tch_mode) { - case GSM48_CMODE_SPEECH_AMR: - set_payload_type(msg, lchan); - if (lchan->tch.last_sid.len) { - memcpy(l1_payload, lchan->tch.last_sid.buf, - lchan->tch.last_sid.len); - set_payload_size(msg, lchan->tch.last_sid.len + 1); - } else { - /* FIXME: decide if we should send SPEECH_BAD or - * SID_BAD */ -#if 0 - *payload_type = GsmL1_TchPlType_Amr_SidBad; - memset(l1_payload, 0xFF, 5); - msu_param->u8Size = 5 + 3; -#else - /* send an all-zero SID */ - set_payload_size(msg, 8); -#endif - } - break; - default: - msgb_free(msg); - msg = NULL; - break; - } - - return msg; -} |