blob: b58d83bd8c215d1213502832fa3fe0e3281d35d5 [file] [log] [blame]
Harald Welte39315c42010-01-10 18:01:52 +01001/* ip.access nanoBTS specific code */
2
3/* (C) 2009-2010 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 General Public License as published by
9 * the Free Software Foundation; either version 2 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 General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License along
18 * with this program; if not, write to the Free Software Foundation, Inc.,
19 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
20 *
21 */
22
23#include <sys/types.h>
24
25#include <openbsc/gsm_data.h>
Harald Weltedfe6c7d2010-02-20 16:24:02 +010026#include <osmocore/tlv.h>
Harald Welte39315c42010-01-10 18:01:52 +010027#include <openbsc/abis_nm.h>
28
29static struct gsm_bts_model model_nanobts = {
30 .type = GSM_BTS_TYPE_NANOBTS,
31 .nm_att_tlvdef = {
32 .def = {
33 /* ip.access specifics */
34 [NM_ATT_IPACC_DST_IP] = { TLV_TYPE_FIXED, 4 },
35 [NM_ATT_IPACC_DST_IP_PORT] = { TLV_TYPE_FIXED, 2 },
36 [NM_ATT_IPACC_STREAM_ID] = { TLV_TYPE_TV, },
37 [NM_ATT_IPACC_FREQ_CTRL] = { TLV_TYPE_TV, },
38 [NM_ATT_IPACC_SEC_OML_CFG] = { TLV_TYPE_FIXED, 6 },
39 [NM_ATT_IPACC_IP_IF_CFG] = { TLV_TYPE_FIXED, 8 },
40 [NM_ATT_IPACC_IP_GW_CFG] = { TLV_TYPE_FIXED, 12 },
41 [NM_ATT_IPACC_IN_SERV_TIME] = { TLV_TYPE_FIXED, 4 },
42 [NM_ATT_IPACC_LOCATION] = { TLV_TYPE_TL16V },
43 [NM_ATT_IPACC_PAGING_CFG] = { TLV_TYPE_FIXED, 2 },
44 [NM_ATT_IPACC_UNIT_ID] = { TLV_TYPE_TL16V },
45 [NM_ATT_IPACC_UNIT_NAME] = { TLV_TYPE_TL16V },
46 [NM_ATT_IPACC_SNMP_CFG] = { TLV_TYPE_TL16V },
47 [NM_ATT_IPACC_PRIM_OML_CFG_LIST] = { TLV_TYPE_TL16V },
48 [NM_ATT_IPACC_NV_FLAGS] = { TLV_TYPE_TL16V },
49 [NM_ATT_IPACC_FREQ_CTRL] = { TLV_TYPE_FIXED, 2 },
50 [NM_ATT_IPACC_PRIM_OML_FB_TOUT] = { TLV_TYPE_TL16V },
51 [NM_ATT_IPACC_CUR_SW_CFG] = { TLV_TYPE_TL16V },
52 [NM_ATT_IPACC_TIMING_BUS] = { TLV_TYPE_TL16V },
53 [NM_ATT_IPACC_CGI] = { TLV_TYPE_TL16V },
54 [NM_ATT_IPACC_RAC] = { TLV_TYPE_TL16V },
55 [NM_ATT_IPACC_OBJ_VERSION] = { TLV_TYPE_TL16V },
56 [NM_ATT_IPACC_GPRS_PAGING_CFG]= { TLV_TYPE_TL16V },
57 [NM_ATT_IPACC_NSEI] = { TLV_TYPE_TL16V },
58 [NM_ATT_IPACC_BVCI] = { TLV_TYPE_TL16V },
59 [NM_ATT_IPACC_NSVCI] = { TLV_TYPE_TL16V },
60 [NM_ATT_IPACC_NS_CFG] = { TLV_TYPE_TL16V },
61 [NM_ATT_IPACC_BSSGP_CFG] = { TLV_TYPE_TL16V },
62 [NM_ATT_IPACC_NS_LINK_CFG] = { TLV_TYPE_TL16V },
63 [NM_ATT_IPACC_RLC_CFG] = { TLV_TYPE_TL16V },
64 [NM_ATT_IPACC_ALM_THRESH_LIST]= { TLV_TYPE_TL16V },
65 [NM_ATT_IPACC_MONIT_VAL_LIST] = { TLV_TYPE_TL16V },
66 [NM_ATT_IPACC_TIB_CONTROL] = { TLV_TYPE_TL16V },
67 [NM_ATT_IPACC_SUPP_FEATURES] = { TLV_TYPE_TL16V },
68 [NM_ATT_IPACC_CODING_SCHEMES] = { TLV_TYPE_TL16V },
69 [NM_ATT_IPACC_RLC_CFG_2] = { TLV_TYPE_TL16V },
70 [NM_ATT_IPACC_HEARTB_TOUT] = { TLV_TYPE_TL16V },
71 [NM_ATT_IPACC_UPTIME] = { TLV_TYPE_TL16V },
72 [NM_ATT_IPACC_RLC_CFG_3] = { TLV_TYPE_TL16V },
73 [NM_ATT_IPACC_SSL_CFG] = { TLV_TYPE_TL16V },
74 [NM_ATT_IPACC_SEC_POSSIBLE] = { TLV_TYPE_TL16V },
75 [NM_ATT_IPACC_IML_SSL_STATE] = { TLV_TYPE_TL16V },
76 [NM_ATT_IPACC_REVOC_DATE] = { TLV_TYPE_TL16V },
77 },
78 },
79};
80
81int bts_model_nanobts_init(void)
82{
Holger Hans Peter Freytherc8bf3c12010-06-21 18:11:37 +080083 model_nanobts.features.data = &model_nanobts._features_data[0];
Harald Weltef3d8e922010-06-14 22:44:42 +020084 model_nanobts.features.data_len = sizeof(model_nanobts._features_data);
85
86 gsm_btsmodel_set_feature(&model_nanobts, BTS_FEAT_GPRS);
87 gsm_btsmodel_set_feature(&model_nanobts, BTS_FEAT_EGPRS);
88
Harald Welte39315c42010-01-10 18:01:52 +010089 return gsm_bts_model_register(&model_nanobts);
90}