| #ifndef _GSM_DATA_H |
| #define _GSM_DATA_H |
| |
| #include <sys/types.h> |
| |
| struct osmo_msc_data; |
| struct osmo_bsc_sccp_con; |
| struct gsm_sms_queue; |
| |
| enum gsm_phys_chan_config { |
| GSM_PCHAN_NONE, |
| GSM_PCHAN_CCCH, |
| GSM_PCHAN_CCCH_SDCCH4, |
| GSM_PCHAN_TCH_F, |
| GSM_PCHAN_TCH_H, |
| GSM_PCHAN_SDCCH8_SACCH8C, |
| GSM_PCHAN_PDCH, /* GPRS PDCH */ |
| GSM_PCHAN_TCH_F_PDCH, /* TCH/F if used, PDCH otherwise */ |
| GSM_PCHAN_UNKNOWN, |
| }; |
| |
| enum gsm_chan_t { |
| GSM_LCHAN_NONE, |
| GSM_LCHAN_SDCCH, |
| GSM_LCHAN_TCH_F, |
| GSM_LCHAN_TCH_H, |
| GSM_LCHAN_UNKNOWN, |
| }; |
| |
| /* RRLP mode of operation */ |
| enum rrlp_mode { |
| RRLP_MODE_NONE, |
| RRLP_MODE_MS_BASED, |
| RRLP_MODE_MS_PREF, |
| RRLP_MODE_ASS_PREF, |
| }; |
| |
| /* Channel Request reason */ |
| enum gsm_chreq_reason_t { |
| GSM_CHREQ_REASON_EMERG, |
| GSM_CHREQ_REASON_PAG, |
| GSM_CHREQ_REASON_CALL, |
| GSM_CHREQ_REASON_LOCATION_UPD, |
| GSM_CHREQ_REASON_OTHER, |
| }; |
| |
| #include <osmocore/timer.h> |
| #include <openbsc/system_information.h> |
| #include <openbsc/rest_octets.h> |
| #include <openbsc/mncc.h> |
| |
| #include <osmocore/tlv.h> |
| #include <osmocore/bitvec.h> |
| #include <osmocore/statistics.h> |
| #include <osmocore/gsm_utils.h> |
| #include <osmocore/utils.h> |
| #include <osmocore/rxlev_stat.h> |
| |
| #include <osmocore/protocol/gsm_08_58.h> |
| |
| |
| #define TRX_NR_TS 8 |
| #define TS_MAX_LCHAN 8 |
| |
| #define HARDCODED_ARFCN 123 |
| #define HARDCODED_TSC 7 |
| #define HARDCODED_BSIC 0x3f /* NCC = 7 / BCC = 7 */ |
| |
| /* for multi-drop config */ |
| #define HARDCODED_BTS0_TS 1 |
| #define HARDCODED_BTS1_TS 6 |
| #define HARDCODED_BTS2_TS 11 |
| |
| /* reserved according to GSM 03.03 ยง 2.4 */ |
| #define GSM_RESERVED_TMSI 0xFFFFFFFF |
| |
| enum gsm_hooks { |
| GSM_HOOK_NM_SWLOAD, |
| GSM_HOOK_RR_PAGING, |
| GSM_HOOK_RR_SECURITY, |
| }; |
| |
| enum gsm_paging_event { |
| GSM_PAGING_SUCCEEDED, |
| GSM_PAGING_EXPIRED, |
| GSM_PAGING_OOM, |
| GSM_PAGING_BUSY, |
| }; |
| |
| enum bts_gprs_mode { |
| BTS_GPRS_NONE = 0, |
| BTS_GPRS_GPRS = 1, |
| BTS_GPRS_EGPRS = 2, |
| }; |
| |
| #define OBSC_NM_W_ACK_CB(__msgb) (__msgb)->cb[3] |
| |
| /* the data structure stored in msgb->cb for openbsc apps */ |
| struct openbsc_msgb_cb { |
| unsigned char *bssgph; |
| unsigned char *llch; |
| |
| /* Cell Identifier */ |
| unsigned char *bssgp_cell_id; |
| |
| /* Identifiers of a BTS, equal to 'struct bssgp_bts_ctx' */ |
| u_int16_t nsei; |
| u_int16_t bvci; |
| |
| /* Identifier of a MS (inside BTS), equal to 'struct sgsn_mm_ctx' */ |
| u_int32_t tlli; |
| } __attribute__((packed)); |
| #define OBSC_MSGB_CB(__msgb) ((struct openbsc_msgb_cb *)&((__msgb)->cb[0])) |
| #define msgb_tlli(__x) OBSC_MSGB_CB(__x)->tlli |
| #define msgb_nsei(__x) OBSC_MSGB_CB(__x)->nsei |
| #define msgb_bvci(__x) OBSC_MSGB_CB(__x)->bvci |
| #define msgb_gmmh(__x) (__x)->l3h |
| #define msgb_bssgph(__x) OBSC_MSGB_CB(__x)->bssgph |
| #define msgb_bssgp_len(__x) ((__x)->tail - (uint8_t *)msgb_bssgph(__x)) |
| #define msgb_bcid(__x) OBSC_MSGB_CB(__x)->bssgp_cell_id |
| #define msgb_llch(__x) OBSC_MSGB_CB(__x)->llch |
| |
| #define OBSC_LINKID_CB(__msgb) (__msgb)->cb[3] |
| |
| enum gsm_security_event { |
| GSM_SECURITY_NOAVAIL, |
| GSM_SECURITY_AUTH_FAILED, |
| GSM_SECURITY_SUCCEEDED, |
| }; |
| |
| struct msgb; |
| typedef int gsm_cbfn(unsigned int hooknum, |
| unsigned int event, |
| struct msgb *msg, |
| void *data, void *param); |
| |
| /* Real authentication information containing Ki */ |
| enum gsm_auth_algo { |
| AUTH_ALGO_NONE, |
| AUTH_ALGO_XOR, |
| AUTH_ALGO_COMP128v1, |
| }; |
| |
| struct gsm_auth_info { |
| enum gsm_auth_algo auth_algo; |
| unsigned int a3a8_ki_len; |
| u_int8_t a3a8_ki[16]; |
| }; |
| |
| struct gsm_auth_tuple { |
| int use_count; |
| int key_seq; |
| u_int8_t rand[16]; |
| u_int8_t sres[4]; |
| u_int8_t kc[8]; |
| }; |
| #define GSM_KEY_SEQ_INVAL 7 /* GSM 04.08 - 10.5.1.2 */ |
| |
| |
| struct gsm_lchan; |
| struct gsm_subscriber; |
| struct gsm_mncc; |
| struct rtp_socket; |
| struct bsc_api; |
| |
| /* Network Management State */ |
| struct gsm_nm_state { |
| u_int8_t operational; |
| u_int8_t administrative; |
| u_int8_t availability; |
| }; |
| |
| /* |
| * LOCATION UPDATING REQUEST state |
| * |
| * Our current operation is: |
| * - Get imei/tmsi |
| * - Accept/Reject according to global policy |
| */ |
| struct gsm_loc_updating_operation { |
| struct timer_list updating_timer; |
| unsigned int waiting_for_imsi : 1; |
| unsigned int waiting_for_imei : 1; |
| unsigned int key_seq : 4; |
| }; |
| |
| /* |
| * AUTHENTICATION/CIPHERING state |
| */ |
| struct gsm_security_operation { |
| struct gsm_auth_tuple atuple; |
| gsm_cbfn *cb; |
| void *cb_data; |
| }; |
| |
| /* |
| * A dummy to keep a connection up for at least |
| * a couple of seconds to work around MSC issues. |
| */ |
| struct gsm_anchor_operation { |
| struct timer_list timeout; |
| }; |
| |
| /* Maximum number of neighbor cells whose average we track */ |
| #define MAX_NEIGH_MEAS 10 |
| /* Maximum size of the averaging window for neighbor cells */ |
| #define MAX_WIN_NEIGH_AVG 10 |
| |
| /* processed neighbor measurements for one cell */ |
| struct neigh_meas_proc { |
| u_int16_t arfcn; |
| u_int8_t bsic; |
| u_int8_t rxlev[MAX_WIN_NEIGH_AVG]; |
| unsigned int rxlev_cnt; |
| u_int8_t last_seen_nr; |
| }; |
| |
| #define MAX_A5_KEY_LEN (128/8) |
| #define A38_XOR_MIN_KEY_LEN 12 |
| #define A38_XOR_MAX_KEY_LEN 16 |
| #define A38_COMP128_KEY_LEN 16 |
| #define RSL_ENC_ALG_A5(x) (x+1) |
| |
| /* is the data link established? who established it? */ |
| #define LCHAN_SAPI_UNUSED 0 |
| #define LCHAN_SAPI_MS 1 |
| #define LCHAN_SAPI_NET 2 |
| |
| /* state of a logical channel */ |
| enum gsm_lchan_state { |
| LCHAN_S_NONE, /* channel is not active */ |
| LCHAN_S_ACT_REQ, /* channel activatin requested */ |
| LCHAN_S_ACTIVE, /* channel is active and operational */ |
| LCHAN_S_REL_REQ, /* channel release has been requested */ |
| LCHAN_S_REL_ERR, /* channel is in an error state */ |
| LCHAN_S_INACTIVE, /* channel is set inactive */ |
| }; |
| |
| /* the per subscriber data for lchan */ |
| struct gsm_subscriber_connection { |
| struct llist_head entry; |
| |
| /* To whom we are allocated at the moment */ |
| struct gsm_subscriber *subscr; |
| |
| /* |
| * Operations that have a state and might be pending |
| */ |
| struct gsm_loc_updating_operation *loc_operation; |
| struct gsm_security_operation *sec_operation; |
| struct gsm_anchor_operation *anch_operation; |
| |
| /* Are we part of a special "silent" call */ |
| int silent_call; |
| int put_channel; |
| |
| /* bsc structures */ |
| struct osmo_bsc_sccp_con *sccp_con; |
| |
| /* back pointers */ |
| int in_release; |
| struct gsm_lchan *lchan; |
| struct gsm_lchan *ho_lchan; |
| struct gsm_bts *bts; |
| |
| /* for assignment handling */ |
| struct timer_list T10; |
| struct gsm_lchan *secondary_lchan; |
| |
| }; |
| |
| struct gsm_lchan { |
| /* The TS that we're part of */ |
| struct gsm_bts_trx_ts *ts; |
| /* The logical subslot number in the TS */ |
| u_int8_t nr; |
| /* The logical channel type */ |
| enum gsm_chan_t type; |
| /* RSL channel mode */ |
| enum rsl_cmod_spd rsl_cmode; |
| /* If TCH, traffic channel mode */ |
| enum gsm48_chan_mode tch_mode; |
| /* State */ |
| enum gsm_lchan_state state; |
| /* Power levels for MS and BTS */ |
| u_int8_t bs_power; |
| u_int8_t ms_power; |
| /* Encryption information */ |
| struct { |
| u_int8_t alg_id; |
| u_int8_t key_len; |
| u_int8_t key[MAX_A5_KEY_LEN]; |
| } encr; |
| |
| struct timer_list T3101; |
| struct timer_list T3111; |
| struct timer_list error_timer; |
| |
| /* AMR bits */ |
| struct gsm48_multi_rate_conf mr_conf; |
| |
| /* Established data link layer services */ |
| u_int8_t sapis[8]; |
| int sach_deact; |
| int release_reason; |
| |
| /* GSM Random Access data */ |
| struct gsm48_req_ref *rqd_ref; |
| uint8_t rqd_ta; |
| |
| /* cache of last measurement reports on this lchan */ |
| struct gsm_meas_rep meas_rep[6]; |
| int meas_rep_idx; |
| |
| /* table of neighbor cell measurements */ |
| struct neigh_meas_proc neigh_meas[MAX_NEIGH_MEAS]; |
| |
| struct { |
| u_int32_t bound_ip; |
| u_int32_t connect_ip; |
| u_int16_t bound_port; |
| u_int16_t connect_port; |
| u_int16_t conn_id; |
| u_int8_t rtp_payload; |
| u_int8_t rtp_payload2; |
| u_int8_t speech_mode; |
| struct rtp_socket *rtp_socket; |
| } abis_ip; |
| |
| struct gsm_subscriber_connection *conn; |
| }; |
| |
| struct gsm_e1_subslot { |
| /* Number of E1 link */ |
| u_int8_t e1_nr; |
| /* Number of E1 TS inside E1 link */ |
| u_int8_t e1_ts; |
| /* Sub-slot within the E1 TS, 0xff if full TS */ |
| u_int8_t e1_ts_ss; |
| }; |
| |
| #define TS_F_PDCH_MODE 0x1000 |
| /* One Timeslot in a TRX */ |
| struct gsm_bts_trx_ts { |
| struct gsm_bts_trx *trx; |
| /* number of this timeslot at the TRX */ |
| u_int8_t nr; |
| |
| enum gsm_phys_chan_config pchan; |
| |
| unsigned int flags; |
| struct gsm_nm_state nm_state; |
| struct tlv_parsed nm_attr; |
| u_int8_t nm_chan_comb; |
| |
| struct { |
| /* Parameters below are configured by VTY */ |
| int enabled; |
| u_int8_t maio; |
| u_int8_t hsn; |
| struct bitvec arfcns; |
| u_int8_t arfcns_data[1024/8]; |
| /* This is the pre-computed MA for channel assignments */ |
| struct bitvec ma; |
| u_int8_t ma_len; /* part of ma_data that is used */ |
| u_int8_t ma_data[8]; /* 10.5.2.21: max 8 bytes value part */ |
| } hopping; |
| |
| /* To which E1 subslot are we connected */ |
| struct gsm_e1_subslot e1_link; |
| |
| struct gsm_lchan lchan[TS_MAX_LCHAN]; |
| }; |
| |
| /* One TRX in a BTS */ |
| struct gsm_bts_trx { |
| /* list header in bts->trx_list */ |
| struct llist_head list; |
| |
| struct gsm_bts *bts; |
| /* number of this TRX in the BTS */ |
| u_int8_t nr; |
| /* human readable name / description */ |
| char *description; |
| /* how do we talk RSL with this TRX? */ |
| struct gsm_e1_subslot rsl_e1_link; |
| u_int8_t rsl_tei; |
| struct e1inp_sign_link *rsl_link; |
| /* Some BTS (specifically Ericsson RBS) have a per-TRX OML Link */ |
| struct e1inp_sign_link *oml_link; |
| |
| struct gsm_nm_state nm_state; |
| struct tlv_parsed nm_attr; |
| struct { |
| struct gsm_nm_state nm_state; |
| } bb_transc; |
| |
| u_int16_t arfcn; |
| int nominal_power; /* in dBm */ |
| unsigned int max_power_red; /* in actual dB */ |
| |
| union { |
| struct { |
| struct { |
| struct gsm_nm_state nm_state; |
| } bbsig; |
| struct { |
| struct gsm_nm_state nm_state; |
| } pa; |
| } bs11; |
| struct { |
| unsigned int test_state; |
| u_int8_t test_nr; |
| struct rxlev_stats rxlev_stat; |
| } ipaccess; |
| }; |
| struct gsm_bts_trx_ts ts[TRX_NR_TS]; |
| }; |
| |
| #define GSM_BTS_SI(bts, i) (void *)(bts->si_buf[i]) |
| |
| enum gsm_bts_type { |
| GSM_BTS_TYPE_UNKNOWN, |
| GSM_BTS_TYPE_BS11, |
| GSM_BTS_TYPE_NANOBTS, |
| GSM_BTS_TYPE_RBS2000, |
| }; |
| |
| struct gsm_bts_model { |
| struct llist_head list; |
| |
| enum gsm_bts_type type; |
| const char *name; |
| |
| int (*oml_rcvmsg)(struct msgb *msg); |
| |
| struct tlv_definition nm_att_tlvdef; |
| |
| struct bitvec features; |
| uint8_t _features_data[128/8]; |
| }; |
| |
| enum gsm_bts_features { |
| BTS_FEAT_HSCSD, |
| BTS_FEAT_GPRS, |
| BTS_FEAT_EGPRS, |
| BTS_FEAT_ECSD, |
| BTS_FEAT_HOPPING, |
| }; |
| |
| /* |
| * This keeps track of the paging status of one BTS. It |
| * includes a number of pending requests, a back pointer |
| * to the gsm_bts, a timer and some more state. |
| */ |
| struct gsm_bts_paging_state { |
| /* pending requests */ |
| struct llist_head pending_requests; |
| struct gsm_bts *bts; |
| |
| struct timer_list work_timer; |
| struct timer_list credit_timer; |
| |
| /* free chans needed */ |
| int free_chans_need; |
| |
| /* load */ |
| u_int16_t available_slots; |
| }; |
| |
| struct gsm_envabtse { |
| struct gsm_nm_state nm_state; |
| }; |
| |
| struct gsm_bts_gprs_nsvc { |
| struct gsm_bts *bts; |
| /* data read via VTY config file, to configure the BTS |
| * via OML from BSC */ |
| int id; |
| u_int16_t nsvci; |
| u_int16_t local_port; /* on the BTS */ |
| u_int16_t remote_port; /* on the SGSN */ |
| u_int32_t remote_ip; /* on the SGSN */ |
| |
| struct gsm_nm_state nm_state; |
| }; |
| |
| /* One BTS */ |
| struct gsm_bts { |
| /* list header in net->bts_list */ |
| struct llist_head list; |
| |
| struct gsm_network *network; |
| /* number of ths BTS in network */ |
| u_int8_t nr; |
| /* human readable name / description */ |
| char *description; |
| /* Cell Identity */ |
| u_int16_t cell_identity; |
| /* location area code of this BTS */ |
| u_int16_t location_area_code; |
| /* Training Sequence Code */ |
| u_int8_t tsc; |
| /* Base Station Identification Code (BSIC) */ |
| u_int8_t bsic; |
| /* type of BTS */ |
| enum gsm_bts_type type; |
| struct gsm_bts_model *model; |
| enum gsm_band band; |
| /* should the channel allocator allocate channels from high TRX to TRX0, |
| * rather than starting from TRX0 and go upwards? */ |
| int chan_alloc_reverse; |
| /* maximum Tx power that the MS is permitted to use in this cell */ |
| int ms_max_power; |
| |
| /* how do we talk OML with this TRX? */ |
| struct gsm_e1_subslot oml_e1_link; |
| u_int8_t oml_tei; |
| struct e1inp_sign_link *oml_link; |
| |
| /* Abis network management O&M handle */ |
| struct abis_nm_h *nmh; |
| struct gsm_nm_state nm_state; |
| struct tlv_parsed nm_attr; |
| |
| /* number of this BTS on given E1 link */ |
| u_int8_t bts_nr; |
| |
| /* paging state and control */ |
| struct gsm_bts_paging_state paging; |
| |
| /* CCCH is on C0 */ |
| struct gsm_bts_trx *c0; |
| |
| struct { |
| struct gsm_nm_state nm_state; |
| } site_mgr; |
| |
| int neigh_list_manual_mode; |
| /* parameters from which we build SYSTEM INFORMATION */ |
| struct { |
| struct gsm48_rach_control rach_control; |
| u_int8_t ncc_permitted; |
| struct gsm48_cell_sel_par cell_sel_par; |
| struct gsm48_si_selection_params cell_ro_sel_par; /* rest octet */ |
| struct gsm48_cell_options cell_options; |
| struct gsm48_control_channel_descr chan_desc; |
| struct bitvec neigh_list; |
| struct bitvec cell_alloc; |
| struct { |
| /* bitmask large enough for all possible ARFCN's */ |
| u_int8_t neigh_list[1024/8]; |
| u_int8_t cell_alloc[1024/8]; |
| } data; |
| } si_common; |
| |
| /* do we use static (user-defined) system information messages? (bitmask) */ |
| uint32_t si_mode_static; |
| /* bitmask of all SI that are present/valid in si_buf */ |
| uint32_t si_valid; |
| /* buffers where we put the pre-computed SI */ |
| sysinfo_buf_t si_buf[_MAX_SYSINFO_TYPE]; |
| |
| /* ip.accesss Unit ID's have Site/BTS/TRX layout */ |
| union { |
| struct { |
| u_int16_t site_id; |
| u_int16_t bts_id; |
| u_int32_t flags; |
| } ip_access; |
| struct { |
| struct { |
| struct gsm_nm_state nm_state; |
| } cclk; |
| struct { |
| struct gsm_nm_state nm_state; |
| } rack; |
| struct gsm_envabtse envabtse[4]; |
| } bs11; |
| struct { |
| struct { |
| struct llist_head conn_groups; |
| } is; |
| } rbs2000; |
| }; |
| |
| /* Not entirely sure how ip.access specific this is */ |
| struct { |
| enum bts_gprs_mode mode; |
| struct { |
| struct gsm_nm_state nm_state; |
| u_int16_t nsei; |
| uint8_t timer[7]; |
| } nse; |
| struct { |
| struct gsm_nm_state nm_state; |
| u_int16_t bvci; |
| uint8_t timer[11]; |
| } cell; |
| struct gsm_bts_gprs_nsvc nsvc[2]; |
| u_int8_t rac; |
| } gprs; |
| |
| /* RACH NM values */ |
| int rach_b_thresh; |
| int rach_ldavg_slots; |
| |
| /* transceivers */ |
| int num_trx; |
| struct llist_head trx_list; |
| |
| /* Abis NM queue */ |
| struct llist_head abis_queue; |
| int abis_nm_pend; |
| }; |
| |
| /* Some statistics of our network */ |
| struct gsmnet_stats { |
| struct { |
| struct counter *total; |
| struct counter *no_channel; |
| } chreq; |
| struct { |
| struct counter *attempted; |
| struct counter *no_channel; /* no channel available */ |
| struct counter *timeout; /* T3103 timeout */ |
| struct counter *completed; /* HO COMPL received */ |
| struct counter *failed; /* HO FAIL received */ |
| } handover; |
| struct { |
| struct counter *attach; |
| struct counter *normal; |
| struct counter *periodic; |
| struct counter *detach; |
| } loc_upd_type; |
| struct { |
| struct counter *reject; |
| struct counter *accept; |
| } loc_upd_resp; |
| struct { |
| struct counter *attempted; |
| struct counter *detached; |
| struct counter *completed; |
| struct counter *expired; |
| } paging; |
| struct { |
| struct counter *submitted; /* MO SMS submissions */ |
| struct counter *no_receiver; |
| struct counter *delivered; /* MT SMS deliveries */ |
| struct counter *rp_err_mem; |
| struct counter *rp_err_other; |
| } sms; |
| struct { |
| struct counter *mo_setup; |
| struct counter *mo_connect_ack; |
| struct counter *mt_setup; |
| struct counter *mt_connect; |
| } call; |
| struct { |
| struct counter *rf_fail; |
| struct counter *rll_err; |
| } chan; |
| struct { |
| struct counter *oml_fail; |
| struct counter *rsl_fail; |
| } bts; |
| }; |
| |
| enum gsm_auth_policy { |
| GSM_AUTH_POLICY_CLOSED, /* only subscribers authorized in DB */ |
| GSM_AUTH_POLICY_ACCEPT_ALL, /* accept everyone, even if not authorized in DB */ |
| GSM_AUTH_POLICY_TOKEN, /* accept first, send token per sms, then revoke authorization */ |
| }; |
| |
| #define GSM_T3101_DEFAULT 10 |
| #define GSM_T3113_DEFAULT 60 |
| |
| struct gsm_network { |
| /* global parameters */ |
| u_int16_t country_code; |
| u_int16_t network_code; |
| char *name_long; |
| char *name_short; |
| enum gsm_auth_policy auth_policy; |
| enum gsm48_reject_value reject_cause; |
| int a5_encryption; |
| int neci; |
| int send_mm_info; |
| struct { |
| int active; |
| /* Window RXLEV averaging */ |
| unsigned int win_rxlev_avg; /* number of SACCH frames */ |
| /* Window RXQUAL averaging */ |
| unsigned int win_rxqual_avg; /* number of SACCH frames */ |
| /* Window RXLEV neighbouring cells averaging */ |
| unsigned int win_rxlev_avg_neigh; /* number of SACCH frames */ |
| |
| /* how often should we check for power budget HO */ |
| unsigned int pwr_interval; /* SACCH frames */ |
| /* how much better does a neighbor cell have to be ? */ |
| unsigned int pwr_hysteresis; /* dBm */ |
| /* maximum distacne before we try a handover */ |
| unsigned int max_distance; /* TA values */ |
| } handover; |
| |
| struct gsmnet_stats stats; |
| |
| /* layer 4 */ |
| int (*mncc_recv) (struct gsm_network *net, struct msgb *msg); |
| struct llist_head upqueue; |
| struct llist_head trans_list; |
| struct bsc_api *bsc_api; |
| |
| unsigned int num_bts; |
| struct llist_head bts_list; |
| |
| /* timer values */ |
| int T3101; |
| int T3103; |
| int T3105; |
| int T3107; |
| int T3109; |
| int T3111; |
| int T3113; |
| int T3115; |
| int T3117; |
| int T3119; |
| int T3122; |
| int T3141; |
| |
| /* Radio Resource Location Protocol (TS 04.31) */ |
| struct { |
| enum rrlp_mode mode; |
| } rrlp; |
| |
| /* enable the DTXu and DTXd for this network */ |
| int dtx_enabled; |
| |
| enum gsm_chan_t ctype_by_chreq[16]; |
| |
| /* Use a TCH for handling requests of type paging any */ |
| int pag_any_tch; |
| |
| /* MSC data in case we are a true BSC */ |
| struct osmo_msc_data *msc_data; |
| int hardcoded_rtp_payload; |
| |
| /* subscriber related features */ |
| int keep_subscr; |
| struct gsm_sms_queue *sms_queue; |
| }; |
| |
| #define SMS_HDR_SIZE 128 |
| #define SMS_TEXT_SIZE 256 |
| struct gsm_sms { |
| unsigned long long id; |
| struct gsm_subscriber *sender; |
| struct gsm_subscriber *receiver; |
| |
| unsigned long validity_minutes; |
| u_int8_t reply_path_req; |
| u_int8_t status_rep_req; |
| u_int8_t ud_hdr_ind; |
| u_int8_t protocol_id; |
| u_int8_t data_coding_scheme; |
| u_int8_t msg_ref; |
| char dest_addr[20+1]; /* DA LV is 12 bytes max, i.e. 10 bytes |
| * BCD == 20 bytes string */ |
| u_int8_t user_data_len; |
| u_int8_t user_data[SMS_TEXT_SIZE]; |
| |
| char text[SMS_TEXT_SIZE]; |
| }; |
| |
| |
| struct gsm_network *gsm_network_init(u_int16_t country_code, u_int16_t network_code, |
| int (*mncc_recv)(struct gsm_network *, struct msgb *)); |
| struct gsm_bts *gsm_bts_alloc(struct gsm_network *net, enum gsm_bts_type type, |
| u_int8_t tsc, u_int8_t bsic); |
| struct gsm_bts_trx *gsm_bts_trx_alloc(struct gsm_bts *bts); |
| int gsm_set_bts_type(struct gsm_bts *bts, enum gsm_bts_type type); |
| |
| struct gsm_bts *gsm_bts_num(struct gsm_network *net, int num); |
| |
| /* Get reference to a neighbor cell on a given BCCH ARFCN */ |
| struct gsm_bts *gsm_bts_neighbor(const struct gsm_bts *bts, |
| u_int16_t arfcn, u_int8_t bsic); |
| |
| struct gsm_bts_trx *gsm_bts_trx_num(struct gsm_bts *bts, int num); |
| |
| const char *gsm_pchan_name(enum gsm_phys_chan_config c); |
| enum gsm_phys_chan_config gsm_pchan_parse(const char *name); |
| const char *gsm_lchant_name(enum gsm_chan_t c); |
| const char *gsm_chreq_name(enum gsm_chreq_reason_t c); |
| char *gsm_trx_name(struct gsm_bts_trx *trx); |
| char *gsm_ts_name(struct gsm_bts_trx_ts *ts); |
| char *gsm_lchan_name(struct gsm_lchan *lchan); |
| const char *gsm_lchans_name(enum gsm_lchan_state s); |
| |
| void set_ts_e1link(struct gsm_bts_trx_ts *ts, u_int8_t e1_nr, |
| u_int8_t e1_ts, u_int8_t e1_ts_ss); |
| enum gsm_bts_type parse_btstype(const char *arg); |
| const char *btstype2str(enum gsm_bts_type type); |
| struct gsm_bts_trx *gsm_bts_trx_by_nr(struct gsm_bts *bts, int nr); |
| struct gsm_bts *gsm_bts_by_lac(struct gsm_network *net, unsigned int lac, |
| struct gsm_bts *start_bts); |
| |
| extern void *tall_bsc_ctx; |
| extern int ipacc_rtp_direct; |
| |
| static inline int is_ipaccess_bts(struct gsm_bts *bts) |
| { |
| switch (bts->type) { |
| case GSM_BTS_TYPE_NANOBTS: |
| return 1; |
| default: |
| break; |
| } |
| return 0; |
| } |
| |
| static inline int is_siemens_bts(struct gsm_bts *bts) |
| { |
| switch (bts->type) { |
| case GSM_BTS_TYPE_BS11: |
| return 1; |
| default: |
| break; |
| } |
| |
| return 0; |
| } |
| |
| |
| enum gsm_auth_policy gsm_auth_policy_parse(const char *arg); |
| const char *gsm_auth_policy_name(enum gsm_auth_policy policy); |
| |
| enum rrlp_mode rrlp_mode_parse(const char *arg); |
| const char *rrlp_mode_name(enum rrlp_mode mode); |
| |
| enum bts_gprs_mode bts_gprs_mode_parse(const char *arg); |
| const char *bts_gprs_mode_name(enum bts_gprs_mode mode); |
| |
| void gsm_trx_lock_rf(struct gsm_bts_trx *trx, int locked); |
| |
| int gsm48_ra_id_by_bts(u_int8_t *buf, struct gsm_bts *bts); |
| void gprs_ra_id_by_bts(struct gprs_ra_id *raid, struct gsm_bts *bts); |
| struct gsm_meas_rep *lchan_next_meas_rep(struct gsm_lchan *lchan); |
| |
| int gsm_btsmodel_set_feature(struct gsm_bts_model *model, enum gsm_bts_features feat); |
| int gsm_bts_has_feature(struct gsm_bts *bts, enum gsm_bts_features feat); |
| int gsm_bts_model_register(struct gsm_bts_model *model); |
| |
| struct gsm_subscriber_connection *subscr_con_allocate(struct gsm_lchan *lchan); |
| void subscr_con_free(struct gsm_subscriber_connection *conn); |
| |
| #endif |