blob: 1dde267728b015244edb4e02a48b519c1eea43c8 [file] [log] [blame]
Holger Freyther2b2d2e32009-02-14 22:51:00 +00001/* Generic signalling/notification infrastructure */
Holger Hans Peter Freytherb1008952015-05-02 19:55:38 +02002/* (C) 2009-2010, 2015 by Holger Hans Peter Freyther <zecke@selfish.org>
Harald Welte595ad7b2009-02-16 22:05:44 +00003 * (C) 2009 by Harald Welte <laforge@gnumonks.org>
Holger Hans Peter Freyther0d711632010-09-16 02:30:36 +08004 * (C) 2010 by On-Waves
Holger Freyther2b2d2e32009-02-14 22:51:00 +00005 * All Rights Reserved
6 *
7 * This program is free software; you can redistribute it and/or modify
Harald Welte9af6ddf2011-01-01 15:25:50 +01008 * 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
Holger Freyther2b2d2e32009-02-14 22:51:00 +000010 * (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
Harald Welte9af6ddf2011-01-01 15:25:50 +010015 * GNU Affero General Public License for more details.
Holger Freyther2b2d2e32009-02-14 22:51:00 +000016 *
Harald Welte9af6ddf2011-01-01 15:25:50 +010017 * 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/>.
Holger Freyther2b2d2e32009-02-14 22:51:00 +000019 *
20 */
21
22#ifndef OPENBSC_SIGNAL_H
23#define OPENBSC_SIGNAL_H
24
Harald Welte595ad7b2009-02-16 22:05:44 +000025#include <stdlib.h>
26#include <errno.h>
27
Neels Hofmeyrc0164792017-09-04 15:15:32 +020028#include <osmocom/bsc/gsm_data.h>
Holger Freyther2b2d2e32009-02-14 22:51:00 +000029
Pablo Neira Ayuso136f4532011-03-22 16:47:59 +010030#include <osmocom/core/signal.h>
Holger Freyther2b2d2e32009-02-14 22:51:00 +000031
32/*
Harald Welte595ad7b2009-02-16 22:05:44 +000033 * Signalling subsystems
Holger Freyther2b2d2e32009-02-14 22:51:00 +000034 */
Harald Welte167df882009-02-17 14:35:45 +000035enum signal_subsystems {
36 SS_PAGING,
Harald Welte167df882009-02-17 14:35:45 +000037 SS_ABISIP,
Harald Weltef9a8cc32009-05-01 15:39:49 +000038 SS_NM,
Holger Freyther7c19f742009-06-06 13:54:35 +000039 SS_LCHAN,
Harald Weltec0d83b02010-03-28 15:58:03 +080040 SS_CHALLOC,
Harald Welte549faad2010-03-05 19:36:20 +010041 SS_IPAC_NWL,
Holger Hans Peter Freyther12b917d2010-07-29 02:27:27 +080042 SS_RF,
Holger Hans Peter Freyther0d711632010-09-16 02:30:36 +080043 SS_MSC,
Holger Hans Peter Freyther6c4d2442011-01-06 13:31:41 +010044 SS_HO,
Holger Hans Peter Freyther54fa2c72012-02-03 20:26:25 +010045 SS_CCCH,
Harald Welte167df882009-02-17 14:35:45 +000046};
Holger Freyther2b2d2e32009-02-14 22:51:00 +000047
Harald Welte595ad7b2009-02-16 22:05:44 +000048/* SS_PAGING signals */
49enum signal_paging {
Sylvain Munautef24dff2009-12-19 12:38:10 +010050 S_PAGING_SUCCEEDED,
51 S_PAGING_EXPIRED,
Holger Freyther2b2d2e32009-02-14 22:51:00 +000052};
53
Harald Welte167df882009-02-17 14:35:45 +000054/* SS_ABISIP signals */
55enum signal_abisip {
Holger Hans Peter Freyther231163d2009-11-18 21:06:12 +010056 S_ABISIP_CRCX_ACK,
Harald Welte5e3d91b2009-12-19 16:42:06 +010057 S_ABISIP_MDCX_ACK,
Holger Hans Peter Freyther231163d2009-11-18 21:06:12 +010058 S_ABISIP_DLCX_IND,
Harald Welte167df882009-02-17 14:35:45 +000059};
60
Harald Weltef9a8cc32009-05-01 15:39:49 +000061/* SS_NM signals */
62enum signal_nm {
63 S_NM_SW_ACTIV_REP, /* GSM 12.21 software activated report */
64 S_NM_FAIL_REP, /* GSM 12.21 failure event report */
Holger Hans Peter Freyther500f3ca2009-06-10 10:48:14 +020065 S_NM_NACK, /* GSM 12.21 various NM_MT_*_NACK happened */
Holger Hans Peter Freythera7cd9fc2009-07-07 12:40:07 +020066 S_NM_IPACC_NACK, /* GSM 12.21 nanoBTS extensions NM_MT_IPACC_*_*_NACK happened */
Holger Hans Peter Freyther086ffa52009-12-29 11:26:38 +010067 S_NM_IPACC_ACK, /* GSM 12.21 nanoBTS extensions NM_MT_IPACC_*_*_ACK happened */
Holger Hans Peter Freyther1356c082009-12-30 09:00:01 +010068 S_NM_IPACC_RESTART_ACK, /* nanoBTS has send a restart ack */
69 S_NM_IPACC_RESTART_NACK,/* nanoBTS has send a restart ack */
Harald Weltec7310382009-08-08 00:02:36 +020070 S_NM_TEST_REP, /* GSM 12.21 Test Report */
Harald Weltef338a032011-01-14 15:55:42 +010071 S_NM_STATECHG_OPER, /* Operational State changed*/
72 S_NM_STATECHG_ADM, /* Administrative State changed */
Harald Welte40d1c3f2011-03-06 23:20:28 +010073 S_NM_OM2K_CONF_RES, /* OM2K Configuration Result */
Neels Hofmeyrbf709922018-05-03 16:11:28 +020074 S_NM_OPSTART_ACK, /* Received OPSTART ACK, arg is struct abis_om_fom_hdr* */
Harald Weltef9a8cc32009-05-01 15:39:49 +000075};
76
Holger Freyther7c19f742009-06-06 13:54:35 +000077/* SS_LCHAN signals */
78enum signal_lchan {
79 /*
80 * The lchan got freed with an use_count != 0 and error
81 * recovery needs to be carried out from within the
82 * signal handler.
83 */
84 S_LCHAN_UNEXPECTED_RELEASE,
Harald Welted011e8b2009-11-29 22:45:52 +010085 S_LCHAN_ACTIVATE_ACK, /* 08.58 Channel Activate ACK */
86 S_LCHAN_ACTIVATE_NACK, /* 08.58 Channel Activate NACK */
87 S_LCHAN_HANDOVER_COMPL, /* 04.08 Handover Completed */
88 S_LCHAN_HANDOVER_FAIL, /* 04.08 Handover Failed */
Andreas Eversberge0cba562013-06-02 20:46:32 +020089 S_LCHAN_ASSIGNMENT_COMPL, /* 04.08 Assignment Completed */
90 S_LCHAN_ASSIGNMENT_FAIL, /* 04.08 Assignment Failed */
Harald Welted011e8b2009-11-29 22:45:52 +010091 S_LCHAN_HANDOVER_DETECT, /* 08.58 Handover Detect */
Harald Weltedbb1d882009-11-30 19:16:47 +010092 S_LCHAN_MEAS_REP, /* 08.58 Measurement Report */
Holger Freyther7c19f742009-06-06 13:54:35 +000093};
94
Harald Weltec0d83b02010-03-28 15:58:03 +080095/* SS_CHALLOC signals */
96enum signal_challoc {
97 S_CHALLOC_ALLOC_FAIL, /* allocation of lchan has failed */
98 S_CHALLOC_FREED, /* lchan has been successfully freed */
99};
100
Harald Welte549faad2010-03-05 19:36:20 +0100101/* SS_IPAC_NWL signals */
102enum signal_ipaccess {
103 S_IPAC_NWL_COMPLETE,
104};
105
Harald Welte3961fcc2009-11-30 19:37:18 +0100106enum signal_global {
Harald Weltef338a032011-01-14 15:55:42 +0100107 S_GLOBAL_BTS_CLOSE_OM,
Harald Welte3961fcc2009-11-30 19:37:18 +0100108};
109
Holger Hans Peter Freyther12b917d2010-07-29 02:27:27 +0800110/* SS_RF signals */
111enum signal_rf {
112 S_RF_OFF,
113 S_RF_ON,
114 S_RF_GRACE,
115};
116
Holger Hans Peter Freyther2e837822009-12-30 08:38:43 +0100117struct ipacc_ack_signal_data {
Holger Hans Peter Freyther52fd4e42010-05-12 23:34:51 +0800118 struct gsm_bts_trx *trx;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200119 uint8_t msg_type;
Holger Hans Peter Freyther2e837822009-12-30 08:38:43 +0100120};
121
Harald Welteaf9b8102011-03-06 21:20:38 +0100122struct abis_om2k_mo;
123
Harald Weltef338a032011-01-14 15:55:42 +0100124struct nm_statechg_signal_data {
Harald Weltef38ca9a2011-03-06 22:11:32 +0100125 struct gsm_bts *bts;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200126 uint8_t obj_class;
Harald Weltef338a032011-01-14 15:55:42 +0100127 void *obj;
128 struct gsm_nm_state *old_state;
129 struct gsm_nm_state *new_state;
Harald Welteaf9b8102011-03-06 21:20:38 +0100130
131 /* This pointer is vaold for TS 12.21 MO */
Harald Weltef338a032011-01-14 15:55:42 +0100132 struct abis_om_obj_inst *obj_inst;
Harald Welteaf9b8102011-03-06 21:20:38 +0100133 /* This pointer is vaold for RBS2000 MO */
134 struct abis_om2k_mo *om2k_mo;
Harald Weltef338a032011-01-14 15:55:42 +0100135};
136
Harald Welte40d1c3f2011-03-06 23:20:28 +0100137struct nm_om2k_signal_data {
138 struct gsm_bts *bts;
139 void *obj;
140 struct abis_om2k_mo *om2k_mo;
141
142 uint8_t accordance_ind;
143};
144
Holger Hans Peter Freyther6d2b66e2010-07-14 02:08:35 +0800145struct nm_nack_signal_data {
146 struct msgb *msg;
Holger Hans Peter Freytherde1674a2012-11-11 18:26:23 +0100147 struct gsm_bts *bts;
Holger Hans Peter Freyther6d2b66e2010-07-14 02:08:35 +0800148 uint8_t mt;
149};
150
Harald Weltec0d83b02010-03-28 15:58:03 +0800151struct challoc_signal_data {
152 struct gsm_bts *bts;
153 struct gsm_lchan *lchan;
154 enum gsm_chan_t type;
155};
156
Holger Hans Peter Freyther12b917d2010-07-29 02:27:27 +0800157struct rf_signal_data {
158 struct gsm_network *net;
159};
160
Holger Hans Peter Freyther08eebd52010-12-27 13:28:20 +0100161struct lchan_signal_data {
162 /* The lchan the signal happened on */
163 struct gsm_lchan *lchan;
164 /* Measurement reports on this lchan */
165 struct gsm_meas_rep *mr;
166};
167
Holger Hans Peter Freyther0d711632010-09-16 02:30:36 +0800168/* MSC signals */
169enum signal_msc {
170 S_MSC_LOST,
171 S_MSC_CONNECTED,
Holger Hans Peter Freythered0374f2011-08-17 17:37:16 +0200172 S_MSC_AUTHENTICATED,
Holger Hans Peter Freyther0d711632010-09-16 02:30:36 +0800173};
174
Neels Hofmeyra369e242017-02-23 21:57:23 +0100175struct bsc_msc_data;
Holger Hans Peter Freyther0d711632010-09-16 02:30:36 +0800176struct msc_signal_data {
Neels Hofmeyra369e242017-02-23 21:57:23 +0100177 struct bsc_msc_data *data;
Holger Hans Peter Freyther0d711632010-09-16 02:30:36 +0800178};
179
Holger Hans Peter Freyther54fa2c72012-02-03 20:26:25 +0100180/* SS_CCCH signals */
181enum signal_ccch {
182 S_CCCH_PAGING_LOAD,
183 S_CCCH_RACH_LOAD,
184};
185
186struct ccch_signal_data {
187 struct gsm_bts *bts;
188 uint16_t pg_buf_space;
189 uint16_t rach_slot_count;
190 uint16_t rach_busy_count;
191 uint16_t rach_access_count;
192};
193
Holger Freyther2b2d2e32009-02-14 22:51:00 +0000194#endif