blob: a849c30d3ef6dbd921a6d36fe1026d0dea8bb863 [file] [log] [blame]
Harald Weltedb44f602011-02-11 18:36:18 +01001/* Ericsson RBS-2xxx specific code */
2
3/* (C) 2011 by Harald Welte <laforge@gnumonks.org>
4 *
5 * All Rights Reserved
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU Affero General Public License as published by
9 * the Free Software Foundation; either version 3 of the License, or
10 * (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU Affero General Public License for more details.
16 *
17 * You should have received a copy of the GNU Affero General Public License
18 * along with this program. If not, see <http://www.gnu.org/licenses/>.
19 *
20 */
21
22#include <sys/types.h>
23
24#include <osmocore/tlv.h>
25
26#include <openbsc/debug.h>
27#include <openbsc/gsm_data.h>
Harald Welte9a311ec2011-02-12 12:33:06 +010028#include <openbsc/abis_om2000.h>
Harald Weltedb44f602011-02-11 18:36:18 +010029#include <openbsc/e1_input.h>
30#include <openbsc/signal.h>
31
Harald Welte9a311ec2011-02-12 12:33:06 +010032#include "input/lapd.h"
Harald Weltedb44f602011-02-11 18:36:18 +010033
34static struct gsm_bts_model model_rbs2k = {
35 .type = GSM_BTS_TYPE_RBS2000,
Harald Welte9a311ec2011-02-12 12:33:06 +010036 .name = "rbs2000",
37 .oml_rcvmsg = &abis_om2k_rcvmsg,
Harald Weltedb44f602011-02-11 18:36:18 +010038};
39
40static void bootstrap_om_rbs2k(struct gsm_bts *bts)
41{
42 LOGP(DNM, LOGL_NOTICE, "bootstrapping OML for BTS %u\n", bts->nr);
Harald Welte73541072011-02-12 13:44:14 +010043 abis_om2k_tx_start_req(bts, &om2k_mo_cf);
Harald Weltedb44f602011-02-11 18:36:18 +010044 /* FIXME */
45}
46
47static int shutdown_om(struct gsm_bts *bts)
48{
49 /* FIXME */
50 return 0;
51}
52
53/* Callback function to be called every time we receive a signal from INPUT */
54static int gbl_sig_cb(unsigned int subsys, unsigned int signal,
55 void *handler_data, void *signal_data)
56{
57 struct gsm_bts *bts;
58
59 if (subsys != SS_GLOBAL)
60 return 0;
61
62 switch (signal) {
63 case S_GLOBAL_BTS_CLOSE_OM:
64 bts = signal_data;
65 if (bts->type == GSM_BTS_TYPE_RBS2000)
66 shutdown_om(signal_data);
67 break;
68 }
69
70 return 0;
71}
72
73static void sabm_timer_cb(void *_line);
74
Harald Welteb80e14e2011-02-11 19:04:44 +010075/* FIXME: we need one per bts (or rather: per signalling TS, not one global! */
Harald Weltedb44f602011-02-11 18:36:18 +010076struct timer_list sabm_timer = {
77 .cb = &sabm_timer_cb,
78};
79
80static void sabm_timer_cb(void *_line)
81{
82 struct e1inp_ts *e1i_ts = _line;
83
Harald Welteb80e14e2011-02-11 19:04:44 +010084 /* FIXME: use the TEI that was configured via vty */
Harald Welte03cc8a82011-02-11 18:59:31 +010085 lapd_send_sabm(e1i_ts->driver.dahdi.lapd, 62, 62);
Harald Weltedb44f602011-02-11 18:36:18 +010086
87 bsc_schedule_timer(&sabm_timer, 0, 50);
88}
89
90/* Callback function to be called every time we receive a signal from INPUT */
91static int inp_sig_cb(unsigned int subsys, unsigned int signal,
92 void *handler_data, void *signal_data)
93{
94 struct input_signal_data *isd = signal_data;
95
96 if (subsys != SS_INPUT)
97 return 0;
98
99 switch (signal) {
100 case S_INP_TEI_UP:
101 switch (isd->link_type) {
102 case E1INP_SIGN_OML:
Harald Welteb80e14e2011-02-11 19:04:44 +0100103 if (isd->trx->bts->type == GSM_BTS_TYPE_RBS2000) {
104 /* FIXME: only disable the timer that belong sto this timeslot */
105 bsc_del_timer(&sabm_timer);
Harald Weltedb44f602011-02-11 18:36:18 +0100106 bootstrap_om_rbs2k(isd->trx->bts);
Harald Welteb80e14e2011-02-11 19:04:44 +0100107 }
Harald Weltedb44f602011-02-11 18:36:18 +0100108 break;
109 }
Harald Welte03cc8a82011-02-11 18:59:31 +0100110 break;
Harald Weltedb44f602011-02-11 18:36:18 +0100111 case S_INP_LINE_INIT:
112 /* Right now Ericsson RBS are only supported on DAHDI */
113 if (strcasecmp(isd->line->driver->name, "DAHDI"))
114 break;
Harald Welteb80e14e2011-02-11 19:04:44 +0100115 /* FIXME: properly determine the OML signalling timeslot,
116 * or rather: all signalling timeslots and start one timer each */
Harald Weltedb44f602011-02-11 18:36:18 +0100117 sabm_timer.data = &isd->line->ts[1-1];
118 bsc_schedule_timer(&sabm_timer, 0, 50);
119 break;
120 }
121
122 return 0;
123}
124
125int bts_model_rbs2k_init(void)
126{
127 model_rbs2k.features.data = &model_rbs2k._features_data[0];
128 model_rbs2k.features.data_len = sizeof(model_rbs2k._features_data);
129
130 gsm_btsmodel_set_feature(&model_rbs2k, BTS_FEAT_HOPPING);
131 gsm_btsmodel_set_feature(&model_rbs2k, BTS_FEAT_HSCSD);
132
133 register_signal_handler(SS_INPUT, inp_sig_cb, NULL);
134 register_signal_handler(SS_GLOBAL, gbl_sig_cb, NULL);
135
136 return gsm_bts_model_register(&model_rbs2k);
137}