2 * (C) 2010 by Andreas Eversberg <jolly@eversberg.eu>
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License along
17 * with this program; if not, write to the Free Software Foundation, Inc.,
18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
28 #include <osmocore/msgb.h>
29 #include <osmocore/utils.h>
30 #include <osmocore/gsm48.h>
31 #include <osmocore/talloc.h>
33 #include <osmocom/bb/common/logging.h>
34 #include <osmocom/bb/common/osmocom_data.h>
35 #include <osmocom/bb/mobile/mncc.h>
36 #include <osmocom/bb/mobile/transaction.h>
37 #include <osmocom/bb/mobile/gsm48_cc.h>
41 static int gsm48_cc_tx_release(struct gsm_trans *trans, void *arg);
42 static int gsm48_rel_null_free(struct gsm_trans *trans);
43 int mncc_release_ind(struct osmocom_ms *ms, struct gsm_trans *trans,
44 u_int32_t callref, int location, int value);
45 static int gsm48_cc_tx_disconnect(struct gsm_trans *trans, void *arg);
46 static int gsm48_cc_tx_connect_ack(struct gsm_trans *trans, void *arg);
52 int gsm48_cc_init(struct osmocom_ms *ms)
54 struct gsm48_cclayer *cc = &ms->cclayer;
58 if (!cc->mncc_upqueue.next == 0)
61 LOGP(DCC, LOGL_INFO, "init Call Control\n");
63 INIT_LLIST_HEAD(&cc->mncc_upqueue);
68 int gsm48_cc_exit(struct osmocom_ms *ms)
70 struct gsm48_cclayer *cc = &ms->cclayer;
71 struct gsm_trans *trans, *trans2;
74 LOGP(DCC, LOGL_INFO, "exit Call Control processes for %s\n", ms->name);
76 llist_for_each_entry_safe(trans, trans2, &ms->trans_list, entry) {
77 if (trans->protocol == GSM48_PDISC_CC)
78 LOGP(DCC, LOGL_NOTICE, "Free pendig CC-transaction.\n");
82 while ((msg = msgb_dequeue(&cc->mncc_upqueue)))
92 /* names of MNCC-SAP */
93 static const struct value_string gsm_mncc_names[] = {
94 { MNCC_SETUP_REQ, "MNCC_SETUP_REQ" },
95 { MNCC_SETUP_IND, "MNCC_SETUP_IND" },
96 { MNCC_SETUP_RSP, "MNCC_SETUP_RSP" },
97 { MNCC_SETUP_CNF, "MNCC_SETUP_CNF" },
98 { MNCC_SETUP_COMPL_REQ, "MNCC_SETUP_COMPL_REQ" },
99 { MNCC_SETUP_COMPL_IND, "MNCC_SETUP_COMPL_IND" },
100 { MNCC_CALL_CONF_IND, "MNCC_CALL_CONF_IND" },
101 { MNCC_CALL_PROC_REQ, "MNCC_CALL_PROC_REQ" },
102 { MNCC_PROGRESS_REQ, "MNCC_PROGRESS_REQ" },
103 { MNCC_ALERT_REQ, "MNCC_ALERT_REQ" },
104 { MNCC_ALERT_IND, "MNCC_ALERT_IND" },
105 { MNCC_NOTIFY_REQ, "MNCC_NOTIFY_REQ" },
106 { MNCC_NOTIFY_IND, "MNCC_NOTIFY_IND" },
107 { MNCC_DISC_REQ, "MNCC_DISC_REQ" },
108 { MNCC_DISC_IND, "MNCC_DISC_IND" },
109 { MNCC_REL_REQ, "MNCC_REL_REQ" },
110 { MNCC_REL_IND, "MNCC_REL_IND" },
111 { MNCC_REL_CNF, "MNCC_REL_CNF" },
112 { MNCC_FACILITY_REQ, "MNCC_FACILITY_REQ" },
113 { MNCC_FACILITY_IND, "MNCC_FACILITY_IND" },
114 { MNCC_START_DTMF_IND, "MNCC_START_DTMF_IND" },
115 { MNCC_START_DTMF_RSP, "MNCC_START_DTMF_RSP" },
116 { MNCC_START_DTMF_REJ, "MNCC_START_DTMF_REJ" },
117 { MNCC_STOP_DTMF_IND, "MNCC_STOP_DTMF_IND" },
118 { MNCC_STOP_DTMF_RSP, "MNCC_STOP_DTMF_RSP" },
119 { MNCC_MODIFY_REQ, "MNCC_MODIFY_REQ" },
120 { MNCC_MODIFY_IND, "MNCC_MODIFY_IND" },
121 { MNCC_MODIFY_RSP, "MNCC_MODIFY_RSP" },
122 { MNCC_MODIFY_CNF, "MNCC_MODIFY_CNF" },
123 { MNCC_MODIFY_REJ, "MNCC_MODIFY_REJ" },
124 { MNCC_HOLD_IND, "MNCC_HOLD_IND" },
125 { MNCC_HOLD_CNF, "MNCC_HOLD_CNF" },
126 { MNCC_HOLD_REJ, "MNCC_HOLD_REJ" },
127 { MNCC_RETRIEVE_IND, "MNCC_RETRIEVE_IND" },
128 { MNCC_RETRIEVE_CNF, "MNCC_RETRIEVE_CNF" },
129 { MNCC_RETRIEVE_REJ, "MNCC_RETRIEVE_REJ" },
130 { MNCC_USERINFO_REQ, "MNCC_USERINFO_REQ" },
131 { MNCC_USERINFO_IND, "MNCC_USERINFO_IND" },
132 { MNCC_REJ_REQ, "MNCC_REJ_REQ" },
133 { MNCC_REJ_IND, "MNCC_REJ_IND" },
134 { MNCC_PROGRESS_IND, "MNCC_PROGRESS_IND" },
135 { MNCC_CALL_PROC_IND, "MNCC_CALL_PROC_IND" },
136 { MNCC_CALL_CONF_REQ, "MNCC_CALL_CONF_REQ" },
137 { MNCC_START_DTMF_REQ, "MNCC_START_DTMF_REQ" },
138 { MNCC_STOP_DTMF_REQ, "MNCC_STOP_DTMF_REQ" },
139 { MNCC_HOLD_REQ, "MNCC_HOLD_REQ " },
140 { MNCC_RETRIEVE_REQ, "MNCC_RETRIEVE_REQ" },
144 const char *get_mncc_name(int value)
146 return get_value_string(gsm_mncc_names, value);
149 /* push MMCC header and send to MM */
150 static int gsm48_cc_to_mm(struct msgb *msg, struct gsm_trans *trans,
153 struct gsm48_hdr *gh = msgb_l3(msg);
154 struct gsm48_mmxx_hdr *mmh;
157 /* Add protocol type and transaction ID */
158 gh->proto_discr = trans->protocol | (trans->transaction_id << 4);
160 /* indicate emergency setup to MM layer */
161 if (gh->msg_type == GSM48_MT_CC_EMERG_SETUP)
165 msgb_push(msg, sizeof(struct gsm48_mmxx_hdr));
166 mmh = (struct gsm48_mmxx_hdr *)msg->data;
167 mmh->msg_type = msg_type;
168 mmh->ref = trans->callref;
169 mmh->transaction_id = trans->transaction_id;
170 mmh->emergency = emergency;
172 /* send message to MM */
173 LOGP(DCC, LOGL_INFO, "Sending '%s' using %s (callref=%x, "
174 "transaction_id=%d)\n", gsm48_cc_msg_name(gh->msg_type),
175 get_mmxx_name(msg_type), trans->callref, trans->transaction_id);
176 return gsm48_mmxx_downmsg(trans->ms, msg);
179 /* enqueue message to application (MNCC-SAP) */
180 static int mncc_recvmsg(struct osmocom_ms *ms, struct gsm_trans *trans,
181 int msg_type, struct gsm_mncc *mncc)
183 struct gsm48_cclayer *cc = &ms->cclayer;
187 LOGP(DCC, LOGL_INFO, "(ms %s ti %x) Sending '%s' to MNCC.\n",
188 ms->name, trans->transaction_id,
189 get_mncc_name(msg_type));
191 LOGP(DCC, LOGL_INFO, "(ms %s ti -) Sending '%s' to MNCC.\n",
192 ms->name, get_mncc_name(msg_type));
194 mncc->msg_type = msg_type;
196 msg = msgb_alloc(sizeof(struct gsm_mncc), "MNCC");
199 memcpy(msg->data, mncc, sizeof(struct gsm_mncc));
200 msgb_enqueue(&cc->mncc_upqueue, msg);
205 /* dequeue messages to layer 4 */
206 int mncc_dequeue(struct osmocom_ms *ms)
208 struct gsm48_cclayer *cc = &ms->cclayer;
209 struct gsm_mncc *mncc;
213 while ((msg = msgb_dequeue(&cc->mncc_upqueue))) {
214 mncc = (struct gsm_mncc *)msg->data;
216 cc->mncc_recv(ms, mncc->msg_type, mncc);
217 work = 1; /* work done */
229 static void new_cc_state(struct gsm_trans *trans, int state)
231 if (state > 31 || state < 0)
234 DEBUGP(DCC, "new state %s -> %s\n",
235 gsm48_cc_state_name(trans->cc.state),
236 gsm48_cc_state_name(state));
238 trans->cc.state = state;
245 /* timeout events of all timers */
246 static void gsm48_cc_timeout(void *arg)
248 struct gsm_trans *trans = arg;
249 int disconnect = 0, release = 0, abort = 1;
250 int mo_cause = GSM48_CC_CAUSE_RECOVERY_TIMER;
251 int mo_location = GSM48_CAUSE_LOC_PRN_S_LU;
252 int l4_cause = GSM48_CC_CAUSE_NORMAL_UNSPEC;
253 int l4_location = GSM48_CAUSE_LOC_PRN_S_LU;
254 struct gsm_mncc mo_rel, l4_rel;
256 memset(&mo_rel, 0, sizeof(struct gsm_mncc));
257 mo_rel.callref = trans->callref;
258 memset(&l4_rel, 0, sizeof(struct gsm_mncc));
259 l4_rel.callref = trans->callref;
261 LOGP(DCC, LOGL_INFO, "Timer T%x has fired.\n", trans->cc.Tcurrent);
263 switch(trans->cc.Tcurrent) {
265 /* abort if connection is not already esablished */
266 if (trans->cc.state == GSM_CSTATE_MM_CONNECTION_PEND)
270 l4_cause = GSM48_CC_CAUSE_USER_NOTRESPOND;
274 mo_cause = trans->cc.msg.cause.value;
275 mo_location = trans->cc.msg.cause.location;
278 if (!trans->cc.T308_second) {
279 /* restart T308 a second time */
280 gsm48_cc_tx_release(trans, &trans->cc.msg);
281 trans->cc.T308_second = 1;
282 break; /* stay in release state */
284 /* release MM conn, got NULL state, free trans */
285 gsm48_rel_null_free(trans);
290 l4_cause = GSM48_CC_CAUSE_USER_NOTRESPOND;
294 /* unknown, did not find it in the specs */
300 if ((release || abort) && trans->callref) {
301 /* process release towards layer 4 */
302 mncc_release_ind(trans->ms, trans, trans->callref,
303 l4_location, l4_cause);
306 if (disconnect && trans->callref) {
307 /* process disconnect towards layer 4 */
308 mncc_set_cause(&l4_rel, l4_location, l4_cause);
309 mncc_recvmsg(trans->ms, trans, MNCC_DISC_IND, &l4_rel);
312 /* process disconnect towards mobile station */
313 if (disconnect || release || abort) {
314 mncc_set_cause(&mo_rel, mo_location, mo_cause);
315 mo_rel.cause.diag[0] =
316 ((trans->cc.Tcurrent & 0xf00) >> 8) + '0';
317 mo_rel.cause.diag[1] =
318 ((trans->cc.Tcurrent & 0x0f0) >> 4) + '0';
319 mo_rel.cause.diag[2] = (trans->cc.Tcurrent & 0x00f) + '0';
320 mo_rel.cause.diag_len = 3;
323 gsm48_cc_tx_disconnect(trans, &mo_rel);
325 gsm48_cc_tx_release(trans, &mo_rel);
327 /* release MM conn, got NULL state, free trans */
328 gsm48_rel_null_free(trans);
333 /* start various timers */
334 static void gsm48_start_cc_timer(struct gsm_trans *trans, int current,
337 LOGP(DCC, LOGL_INFO, "starting timer T%x with %d seconds\n", current,
339 trans->cc.timer.cb = gsm48_cc_timeout;
340 trans->cc.timer.data = trans;
341 bsc_schedule_timer(&trans->cc.timer, sec, micro);
342 trans->cc.Tcurrent = current;
345 /* stop various timers */
346 static void gsm48_stop_cc_timer(struct gsm_trans *trans)
348 if (bsc_timer_pending(&trans->cc.timer)) {
349 LOGP(DCC, LOGL_INFO, "stopping pending timer T%x\n",
351 bsc_del_timer(&trans->cc.timer);
352 trans->cc.Tcurrent = 0;
357 * process handlers (misc)
360 /* Call Control Specific transaction release.
361 * gets called by trans_free, DO NOT CALL YOURSELF!
363 void _gsm48_cc_trans_free(struct gsm_trans *trans)
365 gsm48_stop_cc_timer(trans);
367 /* send release to L4, if callref still exists */
368 if (trans->callref) {
369 /* Ressource unavailable */
370 mncc_release_ind(trans->ms, trans, trans->callref,
371 GSM48_CAUSE_LOC_PRN_S_LU,
372 GSM48_CC_CAUSE_RESOURCE_UNAVAIL);
374 if (trans->cc.state != GSM_CSTATE_NULL)
375 new_cc_state(trans, GSM_CSTATE_NULL);
378 /* release MM connection, go NULL state, free transaction */
379 static int gsm48_rel_null_free(struct gsm_trans *trans)
383 /* release MM connection */
384 nmsg = gsm48_mmxx_msgb_alloc(GSM48_MMCC_REL_REQ, trans->callref,
385 trans->transaction_id);
388 LOGP(DCC, LOGL_INFO, "Sending MMCC_REL_REQ\n");
389 gsm48_mmxx_downmsg(trans->ms, nmsg);
391 new_cc_state(trans, GSM_CSTATE_NULL);
399 void mncc_set_cause(struct gsm_mncc *data, int loc, int val)
401 data->fields |= MNCC_F_CAUSE;
402 data->cause.coding = 0x3;
403 data->cause.location = loc;
404 data->cause.value = val;
407 /* send release indication to upper layer */
408 int mncc_release_ind(struct osmocom_ms *ms, struct gsm_trans *trans,
409 u_int32_t callref, int location, int value)
413 memset(&rel, 0, sizeof(rel));
414 rel.callref = callref;
415 mncc_set_cause(&rel, location, value);
416 return mncc_recvmsg(ms, trans, MNCC_REL_IND, &rel);
419 /* sending status message in response to unknown message */
420 static int gsm48_cc_tx_status(struct gsm_trans *trans, int cause)
423 struct gsm48_hdr *gh;
424 uint8_t *cause_ie, *call_state_ie;
426 LOGP(DCC, LOGL_INFO, "sending STATUS (cause %d)\n", cause);
428 nmsg = gsm48_l3_msgb_alloc();
431 gh = (struct gsm48_hdr *) msgb_put(nmsg, sizeof(*gh));
433 gh->msg_type = GSM48_MT_CC_STATUS;
435 cause_ie = msgb_put(nmsg, 3);
437 cause_ie[1] = GSM48_CAUSE_CS_GSM | GSM48_CAUSE_LOC_PRN_S_LU;
438 cause_ie[2] = 0x80 | cause;
440 call_state_ie = msgb_put(nmsg, 1);
441 call_state_ie[0] = 0xc0 | trans->cc.state;
443 return gsm48_cc_to_mm(nmsg, trans, GSM48_MMCC_DATA_REQ);
446 /* reply status enquiry */
447 static int gsm48_cc_rx_status_enq(struct gsm_trans *trans, struct msgb *msg)
449 LOGP(DCC, LOGL_INFO, "received STATUS ENQUIREY\n");
451 return gsm48_cc_tx_status(trans, GSM48_CC_CAUSE_RESP_STATUS_INQ);
455 * process handlers (mobile originating call establish)
458 /* on SETUP request from L4, init MM connection */
459 static int gsm48_cc_init_mm(struct gsm_trans *trans, void *arg)
462 struct gsm_mncc *data = arg;
463 struct gsm48_mmxx_hdr *nmmh;
465 /* store setup message */
466 memcpy(&trans->cc.msg, data, sizeof(struct gsm_mncc));
468 new_cc_state(trans, GSM_CSTATE_MM_CONNECTION_PEND);
470 /* establish MM connection */
471 nmsg = gsm48_mmxx_msgb_alloc(GSM48_MMCC_EST_REQ, trans->callref,
472 trans->transaction_id);
475 nmmh = (struct gsm48_mmxx_hdr *) nmsg->data;
478 LOGP(DCC, LOGL_INFO, "Sending MMCC_EST_REQ\n");
479 return gsm48_mmxx_downmsg(trans->ms, nmsg);
482 /* abort connection prior SETUP */
483 static int gsm48_cc_abort_mm(struct gsm_trans *trans, void *arg)
487 /* abort MM connection */
488 nmsg = gsm48_mmxx_msgb_alloc(GSM48_MMCC_REL_REQ, trans->callref,
489 trans->transaction_id);
492 LOGP(DCC, LOGL_INFO, "Sending MMCC_REL_REQ\n");
493 gsm48_mmxx_downmsg(trans->ms, nmsg);
495 new_cc_state(trans, GSM_CSTATE_NULL);
503 /* setup message from upper layer */
504 static int gsm48_cc_tx_setup(struct gsm_trans *trans)
507 struct gsm48_hdr *gh;
508 struct gsm_mncc *setup = &trans->cc.msg;
509 int rc, transaction_id;
512 LOGP(DCC, LOGL_INFO, "sending SETUP\n");
514 nmsg = gsm48_l3_msgb_alloc();
517 gh = (struct gsm48_hdr *) msgb_put(nmsg, sizeof(*gh));
519 /* transaction id must not be assigned */
520 if (trans->transaction_id != 0xff) { /* unasssigned */
521 LOGP(DCC, LOGL_NOTICE, "TX Setup with assigned transaction. "
522 "This is not allowed!\n");
523 /* Temporarily out of order */
524 rc = mncc_release_ind(trans->ms, trans, trans->callref,
525 GSM48_CAUSE_LOC_PRN_S_LU,
526 GSM48_CC_CAUSE_NORMAL_UNSPEC);
532 /* Get free transaction_id */
533 transaction_id = trans_assign_trans_id(trans->ms, GSM48_PDISC_CC, 0);
534 if (transaction_id < 0) {
535 /* no free transaction ID */
536 rc = mncc_release_ind(trans->ms, trans, trans->callref,
537 GSM48_CAUSE_LOC_PRN_S_LU,
538 GSM48_CC_CAUSE_RESOURCE_UNAVAIL);
543 trans->transaction_id = transaction_id;
545 gh->msg_type = (setup->emergency) ? GSM48_MT_CC_EMERG_SETUP :
548 /* actually we have to start it when CM SERVICE REQUEST has been sent,
549 * but there is no primitive for that defined. i think it is ok to
550 * do it here rather than inventing MMCC-NOTIFY-IND.
552 gsm48_start_cc_timer(trans, 0x303, GSM48_T303_MS);
554 /* bearer capability (optional for emergency calls only) */
555 if (setup->fields & MNCC_F_BEARER_CAP)
556 gsm48_encode_bearer_cap(nmsg, 0, &setup->bearer_cap);
557 if (!setup->emergency) {
559 if (setup->fields & MNCC_F_FACILITY)
560 gsm48_encode_facility(nmsg, 0, &setup->facility);
561 /* called party BCD number */
562 if (setup->fields & MNCC_F_CALLED)
563 gsm48_encode_called(nmsg, &setup->called);
565 if (setup->fields & MNCC_F_USERUSER)
566 gsm48_encode_useruser(nmsg, 0, &setup->useruser);
568 if (setup->fields & MNCC_F_SSVERSION)
569 gsm48_encode_ssversion(nmsg, &setup->ssversion);
570 /* CLIR suppression */
571 if (setup->clir.sup) {
572 ie = msgb_put(nmsg, 1);
573 ie[0] = GSM48_IE_CLIR_SUPP;
575 /* CLIR invocation */
576 if (setup->clir.inv) {
577 ie = msgb_put(nmsg, 1);
578 ie[0] = GSM48_IE_CLIR_INVOC;
581 if (setup->fields & MNCC_F_CCCAP)
582 gsm48_encode_cccap(nmsg, &setup->cccap);
585 /* actually MM CONNECTION PENDING */
586 new_cc_state(trans, GSM_CSTATE_INITIATED);
588 return gsm48_cc_to_mm(nmsg, trans, GSM48_MMCC_DATA_REQ);
591 /* progress is received from lower layer */
592 static int gsm48_cc_rx_progress(struct gsm_trans *trans, struct msgb *msg)
594 struct gsm48_hdr *gh = msgb_l3(msg);
595 unsigned int payload_len = msgb_l3len(msg) - sizeof(*gh);
596 struct tlv_parsed tp;
597 struct gsm_mncc progress;
599 LOGP(DCC, LOGL_INFO, "received PROGRESS\n");
601 memset(&progress, 0, sizeof(struct gsm_mncc));
602 progress.callref = trans->callref;
603 tlv_parse(&tp, &gsm48_att_tlvdef, gh->data, payload_len,
604 GSM48_IE_PROGR_IND, 0);
606 if (TLVP_PRESENT(&tp, GSM48_IE_PROGR_IND)) {
607 progress.fields |= MNCC_F_PROGRESS;
608 gsm48_decode_progress(&progress.progress,
609 TLVP_VAL(&tp, GSM48_IE_PROGR_IND)-1);
610 /* store last progress indicator */
611 trans->cc.prog_ind = progress.progress.descr;
614 if (TLVP_PRESENT(&tp, GSM48_IE_USER_USER)) {
615 progress.fields |= MNCC_F_USERUSER;
616 gsm48_decode_useruser(&progress.useruser,
617 TLVP_VAL(&tp, GSM48_IE_USER_USER)-1);
620 return mncc_recvmsg(trans->ms, trans, MNCC_PROGRESS_IND, &progress);
623 /* call proceeding is received from lower layer */
624 static int gsm48_cc_rx_call_proceeding(struct gsm_trans *trans,
627 struct gsm48_hdr *gh = msgb_l3(msg);
628 unsigned int payload_len = msgb_l3len(msg) - sizeof(*gh);
629 struct tlv_parsed tp;
630 struct gsm_mncc call_proc;
632 LOGP(DCC, LOGL_INFO, "sending CALL PROCEEDING\n");
634 gsm48_stop_cc_timer(trans);
636 memset(&call_proc, 0, sizeof(struct gsm_mncc));
637 call_proc.callref = trans->callref;
638 tlv_parse(&tp, &gsm48_att_tlvdef, gh->data, payload_len, 0, 0);
641 if (TLVP_PRESENT(&tp, GSM48_IE_REPEAT_CIR))
642 call_conf.repeat = 1;
643 if (TLVP_PRESENT(&tp, GSM48_IE_REPEAT_SEQ))
644 call_conf.repeat = 2;
646 /* bearer capability */
647 if (TLVP_PRESENT(&tp, GSM48_IE_BEARER_CAP)) {
648 call_proc.fields |= MNCC_F_BEARER_CAP;
649 gsm48_decode_bearer_cap(&call_proc.bearer_cap,
650 TLVP_VAL(&tp, GSM48_IE_BEARER_CAP)-1);
653 if (TLVP_PRESENT(&tp, GSM48_IE_FACILITY)) {
654 call_proc.fields |= MNCC_F_FACILITY;
655 gsm48_decode_facility(&call_proc.facility,
656 TLVP_VAL(&tp, GSM48_IE_FACILITY)-1);
660 if (TLVP_PRESENT(&tp, GSM48_IE_PROGR_IND)) {
661 call_proc.fields |= MNCC_F_PROGRESS;
662 gsm48_decode_progress(&call_proc.progress,
663 TLVP_VAL(&tp, GSM48_IE_PROGR_IND)-1);
664 /* store last progress indicator */
665 trans->cc.prog_ind = call_proc.progress.descr;
668 /* start T310, if last progress indicator was 1 or 2 or 64 */
669 if (trans->cc.prog_ind == 1
670 || trans->cc.prog_ind == 2
671 || trans->cc.prog_ind == 64)
672 gsm48_start_cc_timer(trans, 0x310, GSM48_T310_MS);
674 new_cc_state(trans, GSM_CSTATE_MO_CALL_PROC);
676 return mncc_recvmsg(trans->ms, trans, MNCC_CALL_PROC_IND,
680 /* alerting is received by the lower layer */
681 static int gsm48_cc_rx_alerting(struct gsm_trans *trans, struct msgb *msg)
683 struct gsm48_hdr *gh = msgb_l3(msg);
684 unsigned int payload_len = msgb_l3len(msg) - sizeof(*gh);
685 struct tlv_parsed tp;
686 struct gsm_mncc alerting;
688 LOGP(DCC, LOGL_INFO, "sending ALERTING\n");
690 gsm48_stop_cc_timer(trans);
691 /* no T301 in MS call control */
693 memset(&alerting, 0, sizeof(struct gsm_mncc));
694 alerting.callref = trans->callref;
695 tlv_parse(&tp, &gsm48_att_tlvdef, gh->data, payload_len, 0, 0);
697 if (TLVP_PRESENT(&tp, GSM48_IE_FACILITY)) {
698 alerting.fields |= MNCC_F_FACILITY;
699 gsm48_decode_facility(&alerting.facility,
700 TLVP_VAL(&tp, GSM48_IE_FACILITY)-1);
704 if (TLVP_PRESENT(&tp, GSM48_IE_PROGR_IND)) {
705 alerting.fields |= MNCC_F_PROGRESS;
706 gsm48_decode_progress(&alerting.progress,
707 TLVP_VAL(&tp, GSM48_IE_PROGR_IND)-1);
710 if (TLVP_PRESENT(&tp, GSM48_IE_USER_USER)) {
711 alerting.fields |= MNCC_F_USERUSER;
712 gsm48_decode_useruser(&alerting.useruser,
713 TLVP_VAL(&tp, GSM48_IE_USER_USER)-1);
716 new_cc_state(trans, GSM_CSTATE_CALL_DELIVERED);
718 return mncc_recvmsg(trans->ms, trans, MNCC_ALERT_IND,
722 /* connect is received from lower layer */
723 static int gsm48_cc_rx_connect(struct gsm_trans *trans, struct msgb *msg)
725 struct gsm48_hdr *gh = msgb_l3(msg);
726 unsigned int payload_len = msgb_l3len(msg) - sizeof(*gh);
727 struct tlv_parsed tp;
728 struct gsm_mncc connect;
730 LOGP(DCC, LOGL_INFO, "received CONNECT\n");
732 gsm48_stop_cc_timer(trans);
734 memset(&connect, 0, sizeof(struct gsm_mncc));
735 connect.callref = trans->callref;
736 tlv_parse(&tp, &gsm48_att_tlvdef, gh->data, payload_len, 0, 0);
738 if (TLVP_PRESENT(&tp, GSM48_IE_FACILITY)) {
739 connect.fields |= MNCC_F_FACILITY;
740 gsm48_decode_facility(&connect.facility,
741 TLVP_VAL(&tp, GSM48_IE_FACILITY)-1);
744 if (TLVP_PRESENT(&tp, GSM48_IE_CONN_BCD)) {
745 connect.fields |= MNCC_F_CONNECTED;
746 gsm48_decode_connected(&connect.connected,
747 TLVP_VAL(&tp, GSM48_IE_CONN_BCD)-1);
750 if (TLVP_PRESENT(&tp, GSM48_IE_PROGR_IND)) {
751 connect.fields |= MNCC_F_PROGRESS;
752 gsm48_decode_progress(&connect.progress,
753 TLVP_VAL(&tp, GSM48_IE_PROGR_IND)-1);
756 if (TLVP_PRESENT(&tp, GSM48_IE_USER_USER)) {
757 connect.fields |= MNCC_F_USERUSER;
758 gsm48_decode_useruser(&connect.useruser,
759 TLVP_VAL(&tp, GSM48_IE_USER_USER)-1);
762 /* ACTIVE state is set during this: */
763 gsm48_cc_tx_connect_ack(trans, NULL);
765 return mncc_recvmsg(trans->ms, trans, MNCC_SETUP_CNF, &connect);
768 /* connect ack message from upper layer */
769 static int gsm48_cc_tx_connect_ack(struct gsm_trans *trans, void *arg)
772 struct gsm48_hdr *gh;
774 LOGP(DCC, LOGL_INFO, "sending CONNECT ACKNOWLEDGE\n");
776 nmsg = gsm48_l3_msgb_alloc();
779 gh = (struct gsm48_hdr *) msgb_put(nmsg, sizeof(*gh));
781 gh->msg_type = GSM48_MT_CC_CONNECT_ACK;
783 new_cc_state(trans, GSM_CSTATE_ACTIVE);
785 return gsm48_cc_to_mm(nmsg, trans, GSM48_MMCC_DATA_REQ);
789 * process handlers (mobile terminating call establish)
792 /* setup is received from lower layer */
793 static int gsm48_cc_rx_setup(struct gsm_trans *trans, struct msgb *msg)
795 struct gsm48_hdr *gh = msgb_l3(msg);
796 unsigned int payload_len = msgb_l3len(msg) - sizeof(*gh);
797 struct tlv_parsed tp;
798 struct gsm_mncc setup;
800 LOGP(DCC, LOGL_INFO, "received SETUP\n");
802 memset(&setup, 0, sizeof(struct gsm_mncc));
803 setup.callref = trans->callref;
804 tlv_parse(&tp, &gsm48_att_tlvdef, gh->data, payload_len, 0, 0);
806 /* bearer capability */
807 if (TLVP_PRESENT(&tp, GSM48_IE_BEARER_CAP)) {
808 setup.fields |= MNCC_F_BEARER_CAP;
809 gsm48_decode_bearer_cap(&setup.bearer_cap,
810 TLVP_VAL(&tp, GSM48_IE_BEARER_CAP)-1);
813 if (TLVP_PRESENT(&tp, GSM48_IE_FACILITY)) {
814 setup.fields |= MNCC_F_FACILITY;
815 gsm48_decode_facility(&setup.facility,
816 TLVP_VAL(&tp, GSM48_IE_FACILITY)-1);
819 if (TLVP_PRESENT(&tp, GSM48_IE_PROGR_IND)) {
820 setup.fields |= MNCC_F_PROGRESS;
821 gsm48_decode_progress(&setup.progress,
822 TLVP_VAL(&tp, GSM48_IE_PROGR_IND)-1);
825 if (TLVP_PRESENT(&tp, GSM48_IE_SIGNAL)) {
826 setup.fields |= MNCC_F_SIGNAL;
827 gsm48_decode_signal(&setup.signal,
828 TLVP_VAL(&tp, GSM48_IE_SIGNAL)-1);
830 /* calling party bcd number */
831 if (TLVP_PRESENT(&tp, GSM48_IE_CALLING_BCD)) {
832 setup.fields |= MNCC_F_CALLING;
833 gsm48_decode_calling(&setup.calling,
834 TLVP_VAL(&tp, GSM48_IE_CALLING_BCD)-1);
836 /* called party bcd number */
837 if (TLVP_PRESENT(&tp, GSM48_IE_CALLED_BCD)) {
838 setup.fields |= MNCC_F_CALLED;
839 gsm48_decode_called(&setup.called,
840 TLVP_VAL(&tp, GSM48_IE_CALLED_BCD)-1);
842 /* redirecting party bcd number */
843 if (TLVP_PRESENT(&tp, GSM48_IE_REDIR_BCD)) {
844 setup.fields |= MNCC_F_REDIRECTING;
845 gsm48_decode_redirecting(&setup.redirecting,
846 TLVP_VAL(&tp, GSM48_IE_REDIR_BCD)-1);
849 if (TLVP_PRESENT(&tp, GSM48_IE_USER_USER)) {
850 setup.fields |= MNCC_F_USERUSER;
851 gsm48_decode_useruser(&setup.useruser,
852 TLVP_VAL(&tp, GSM48_IE_USER_USER)-1);
855 new_cc_state(trans, GSM_CSTATE_CALL_PRESENT);
857 /* indicate setup to MNCC */
858 mncc_recvmsg(trans->ms, trans, MNCC_SETUP_IND, &setup);
863 /* call conf message from upper layer */
864 static int gsm48_cc_tx_call_conf(struct gsm_trans *trans, void *arg)
866 struct gsm_mncc *confirm = arg;
868 struct gsm48_hdr *gh;
870 LOGP(DCC, LOGL_INFO, "sending CALL CONFIRMED (proceeding)\n");
872 nmsg = gsm48_l3_msgb_alloc();
875 gh = (struct gsm48_hdr *) msgb_put(nmsg, sizeof(*gh));
877 gh->msg_type = GSM48_MT_CC_CALL_CONF;
879 new_cc_state(trans, GSM_CSTATE_MO_TERM_CALL_CONF);
881 /* bearer capability */
882 if (confirm->fields & MNCC_F_BEARER_CAP)
883 gsm48_encode_bearer_cap(nmsg, 0, &confirm->bearer_cap);
885 if (confirm->fields & MNCC_F_CAUSE)
886 gsm48_encode_cause(nmsg, 0, &confirm->cause);
888 if (confirm->fields & MNCC_F_CCCAP)
889 gsm48_encode_cccap(nmsg, &confirm->cccap);
891 return gsm48_cc_to_mm(nmsg, trans, GSM48_MMCC_DATA_REQ);
894 /* alerting message from upper layer */
895 static int gsm48_cc_tx_alerting(struct gsm_trans *trans, void *arg)
897 struct gsm_mncc *alerting = arg;
899 struct gsm48_hdr *gh;
901 LOGP(DCC, LOGL_INFO, "sending ALERTING\n");
903 nmsg = gsm48_l3_msgb_alloc();
906 gh = (struct gsm48_hdr *) msgb_put(nmsg, sizeof(*gh));
908 gh->msg_type = GSM48_MT_CC_ALERTING;
911 if (alerting->fields & MNCC_F_FACILITY)
912 gsm48_encode_facility(nmsg, 0, &alerting->facility);
914 if (alerting->fields & MNCC_F_USERUSER)
915 gsm48_encode_useruser(nmsg, 0, &alerting->useruser);
917 if (alerting->fields & MNCC_F_SSVERSION)
918 gsm48_encode_ssversion(nmsg, &alerting->ssversion);
920 new_cc_state(trans, GSM_CSTATE_CALL_RECEIVED);
922 return gsm48_cc_to_mm(nmsg, trans, GSM48_MMCC_DATA_REQ);
925 /* connect message from upper layer */
926 static int gsm48_cc_tx_connect(struct gsm_trans *trans, void *arg)
928 struct gsm_mncc *connect = arg;
930 struct gsm48_hdr *gh;
932 LOGP(DCC, LOGL_INFO, "sending CONNECT\n");
934 nmsg = gsm48_l3_msgb_alloc();
937 gh = (struct gsm48_hdr *) msgb_put(nmsg, sizeof(*gh));
939 gh->msg_type = GSM48_MT_CC_CONNECT;
941 gsm48_stop_cc_timer(trans);
942 gsm48_start_cc_timer(trans, 0x313, GSM48_T313_MS);
945 if (connect->fields & MNCC_F_FACILITY)
946 gsm48_encode_facility(nmsg, 0, &connect->facility);
948 if (connect->fields & MNCC_F_USERUSER)
949 gsm48_encode_useruser(nmsg, 0, &connect->useruser);
951 if (connect->fields & MNCC_F_SSVERSION)
952 gsm48_encode_ssversion(nmsg, &connect->ssversion);
954 new_cc_state(trans, GSM_CSTATE_CONNECT_REQUEST);
956 return gsm48_cc_to_mm(nmsg, trans, GSM48_MMCC_DATA_REQ);
959 /* connect ack is received from lower layer */
960 static int gsm48_cc_rx_connect_ack(struct gsm_trans *trans, struct msgb *msg)
962 struct gsm_mncc connect_ack;
964 LOGP(DCC, LOGL_INFO, "received CONNECT ACKNOWLEDGE\n");
966 gsm48_stop_cc_timer(trans);
968 new_cc_state(trans, GSM_CSTATE_ACTIVE);
970 memset(&connect_ack, 0, sizeof(struct gsm_mncc));
971 connect_ack.callref = trans->callref;
972 return mncc_recvmsg(trans->ms, trans, MNCC_SETUP_COMPL_IND,
977 * process handlers (during active state)
980 /* notify message from upper layer */
981 static int gsm48_cc_tx_notify(struct gsm_trans *trans, void *arg)
983 struct gsm_mncc *notify = arg;
985 struct gsm48_hdr *gh;
987 LOGP(DCC, LOGL_INFO, "sending NOTIFY\n");
989 nmsg = gsm48_l3_msgb_alloc();
992 gh = (struct gsm48_hdr *) msgb_put(nmsg, sizeof(*gh));
994 gh->msg_type = GSM48_MT_CC_NOTIFY;
997 gsm48_encode_notify(nmsg, notify->notify);
999 return gsm48_cc_to_mm(nmsg, trans, GSM48_MMCC_DATA_REQ);
1002 /* notify is received from lower layer */
1003 static int gsm48_cc_rx_notify(struct gsm_trans *trans, struct msgb *msg)
1005 struct gsm48_hdr *gh = msgb_l3(msg);
1006 unsigned int payload_len = msgb_l3len(msg) - sizeof(*gh);
1007 struct gsm_mncc notify;
1009 LOGP(DCC, LOGL_INFO, "received NOTIFY\n");
1011 memset(¬ify, 0, sizeof(struct gsm_mncc));
1012 notify.callref = trans->callref;
1014 if (payload_len < 1) {
1015 LOGP(DCC, LOGL_NOTICE, "Short read of notify message error.\n");
1018 gsm48_decode_notify(¬ify.notify, gh->data);
1020 return mncc_recvmsg(trans->ms, trans, MNCC_NOTIFY_IND, ¬ify);
1023 /* start dtmf message from upper layer */
1024 static int gsm48_cc_tx_start_dtmf(struct gsm_trans *trans, void *arg)
1026 struct gsm_mncc *dtmf = arg;
1028 struct gsm48_hdr *gh;
1030 LOGP(DCC, LOGL_INFO, "sending START DTMF\n");
1032 nmsg = gsm48_l3_msgb_alloc();
1035 gh = (struct gsm48_hdr *) msgb_put(nmsg, sizeof(*gh));
1037 gh->msg_type = GSM48_MT_CC_START_DTMF;
1040 gsm48_encode_keypad(nmsg, dtmf->keypad);
1042 return gsm48_cc_to_mm(nmsg, trans, GSM48_MMCC_DATA_REQ);
1045 /* start dtmf ack is received from lower layer */
1046 static int gsm48_cc_rx_start_dtmf_ack(struct gsm_trans *trans, struct msgb *msg)
1048 struct gsm48_hdr *gh = msgb_l3(msg);
1049 unsigned int payload_len = msgb_l3len(msg) - sizeof(*gh);
1050 struct tlv_parsed tp;
1051 struct gsm_mncc dtmf;
1053 LOGP(DCC, LOGL_INFO, "received START DTMF ACKNOWLEDGE\n");
1055 memset(&dtmf, 0, sizeof(struct gsm_mncc));
1056 dtmf.callref = trans->callref;
1057 tlv_parse(&tp, &gsm48_att_tlvdef, gh->data, payload_len, 0, 0);
1058 /* keypad facility */
1059 if (TLVP_PRESENT(&tp, GSM48_IE_KPD_FACILITY)) {
1060 dtmf.fields |= MNCC_F_KEYPAD;
1061 gsm48_decode_keypad(&dtmf.keypad,
1062 TLVP_VAL(&tp, GSM48_IE_KPD_FACILITY)-1);
1065 return mncc_recvmsg(trans->ms, trans, MNCC_START_DTMF_RSP, &dtmf);
1068 /* start dtmf rej is received from lower layer */
1069 static int gsm48_cc_rx_start_dtmf_rej(struct gsm_trans *trans, struct msgb *msg)
1071 struct gsm48_hdr *gh = msgb_l3(msg);
1072 unsigned int payload_len = msgb_l3len(msg) - sizeof(*gh);
1073 struct gsm_mncc dtmf;
1075 LOGP(DCC, LOGL_INFO, "received START DTMF REJECT\n");
1077 memset(&dtmf, 0, sizeof(struct gsm_mncc));
1078 dtmf.callref = trans->callref;
1080 if (payload_len < 1) {
1081 LOGP(DCC, LOGL_NOTICE, "Short read of dtmf reject message "
1085 gsm48_decode_cause(&dtmf.cause, gh->data);
1087 return mncc_recvmsg(trans->ms, trans, MNCC_START_DTMF_REJ, &dtmf);
1090 /* stop dtmf message from upper layer */
1091 static int gsm48_cc_tx_stop_dtmf(struct gsm_trans *trans, void *arg)
1094 struct gsm48_hdr *gh;
1096 LOGP(DCC, LOGL_INFO, "sending STOP DTMF\n");
1098 nmsg = gsm48_l3_msgb_alloc();
1101 gh = (struct gsm48_hdr *) msgb_put(nmsg, sizeof(*gh));
1103 gh->msg_type = GSM48_MT_CC_STOP_DTMF;
1105 return gsm48_cc_to_mm(nmsg, trans, GSM48_MMCC_DATA_REQ);
1108 /* stop dtmf ack is received from lower layer */
1109 static int gsm48_cc_rx_stop_dtmf_ack(struct gsm_trans *trans, struct msgb *msg)
1111 struct gsm48_hdr *gh = msgb_l3(msg);
1112 unsigned int payload_len = msgb_l3len(msg) - sizeof(*gh);
1113 struct tlv_parsed tp;
1114 struct gsm_mncc dtmf;
1116 LOGP(DCC, LOGL_INFO, "received STOP DTMF ACKNOWLEDGE\n");
1118 memset(&dtmf, 0, sizeof(struct gsm_mncc));
1119 dtmf.callref = trans->callref;
1120 tlv_parse(&tp, &gsm48_att_tlvdef, gh->data, payload_len, 0, 0);
1122 return mncc_recvmsg(trans->ms, trans, MNCC_STOP_DTMF_RSP, &dtmf);
1125 /* hold message from upper layer */
1126 static int gsm48_cc_tx_hold(struct gsm_trans *trans, void *arg)
1129 struct gsm48_hdr *gh;
1131 LOGP(DCC, LOGL_INFO, "sending HOLD\n");
1133 nmsg = gsm48_l3_msgb_alloc();
1136 gh = (struct gsm48_hdr *) msgb_put(nmsg, sizeof(*gh));
1138 gh->msg_type = GSM48_MT_CC_HOLD;
1140 return gsm48_cc_to_mm(nmsg, trans, GSM48_MMCC_DATA_REQ);
1143 /* hold ack is received from lower layer */
1144 static int gsm48_cc_rx_hold_ack(struct gsm_trans *trans, struct msgb *msg)
1146 struct gsm_mncc hold;
1148 LOGP(DCC, LOGL_INFO, "received HOLD ACKNOWLEDGE\n");
1150 memset(&hold, 0, sizeof(struct gsm_mncc));
1151 hold.callref = trans->callref;
1153 return mncc_recvmsg(trans->ms, trans, MNCC_HOLD_CNF, &hold);
1156 /* hold rej is received from lower layer */
1157 static int gsm48_cc_rx_hold_rej(struct gsm_trans *trans, struct msgb *msg)
1159 struct gsm48_hdr *gh = msgb_l3(msg);
1160 unsigned int payload_len = msgb_l3len(msg) - sizeof(*gh);
1161 struct gsm_mncc hold;
1163 LOGP(DCC, LOGL_INFO, "received HOLD REJECT\n");
1165 memset(&hold, 0, sizeof(struct gsm_mncc));
1166 hold.callref = trans->callref;
1168 if (payload_len < 1) {
1169 LOGP(DCC, LOGL_NOTICE, "Short read of hold reject message "
1173 gsm48_decode_cause(&hold.cause, gh->data);
1175 return mncc_recvmsg(trans->ms, trans, MNCC_HOLD_REJ, &hold);
1178 /* retrieve message from upper layer */
1179 static int gsm48_cc_tx_retrieve(struct gsm_trans *trans, void *arg)
1182 struct gsm48_hdr *gh;
1184 LOGP(DCC, LOGL_INFO, "sending RETRIEVE\n");
1186 nmsg = gsm48_l3_msgb_alloc();
1189 gh = (struct gsm48_hdr *) msgb_put(nmsg, sizeof(*gh));
1191 gh->msg_type = GSM48_MT_CC_RETR;
1193 return gsm48_cc_to_mm(nmsg, trans, GSM48_MMCC_DATA_REQ);
1196 /* retrieve ack is received from lower layer */
1197 static int gsm48_cc_rx_retrieve_ack(struct gsm_trans *trans, struct msgb *msg)
1199 struct gsm_mncc retrieve;
1201 LOGP(DCC, LOGL_INFO, "received RETRIEVE ACKNOWLEDGE\n");
1203 memset(&retrieve, 0, sizeof(struct gsm_mncc));
1204 retrieve.callref = trans->callref;
1206 return mncc_recvmsg(trans->ms, trans, MNCC_RETRIEVE_CNF, &retrieve);
1209 /* retrieve rej is received from lower layer */
1210 static int gsm48_cc_rx_retrieve_rej(struct gsm_trans *trans, struct msgb *msg)
1212 struct gsm48_hdr *gh = msgb_l3(msg);
1213 unsigned int payload_len = msgb_l3len(msg) - sizeof(*gh);
1214 struct gsm_mncc retrieve;
1216 LOGP(DCC, LOGL_INFO, "received RETRIEVE REJECT\n");
1218 memset(&retrieve, 0, sizeof(struct gsm_mncc));
1219 retrieve.callref = trans->callref;
1221 if (payload_len < 1) {
1222 LOGP(DCC, LOGL_NOTICE, "Short read of retrieve reject message "
1226 gsm48_decode_cause(&retrieve.cause, gh->data);
1228 return mncc_recvmsg(trans->ms, trans, MNCC_RETRIEVE_REJ, &retrieve);
1231 /* facility message from upper layer or from timer event */
1232 static int gsm48_cc_tx_facility(struct gsm_trans *trans, void *arg)
1234 struct gsm_mncc *fac = arg;
1236 struct gsm48_hdr *gh;
1238 LOGP(DCC, LOGL_INFO, "sending FACILITY\n");
1240 nmsg = gsm48_l3_msgb_alloc();
1243 gh = (struct gsm48_hdr *) msgb_put(nmsg, sizeof(*gh));
1245 gh->msg_type = GSM48_MT_CC_FACILITY;
1248 gsm48_encode_facility(nmsg, 1, &fac->facility);
1250 if (fac->fields & MNCC_F_SSVERSION)
1251 gsm48_encode_ssversion(nmsg, &fac->ssversion);
1253 return gsm48_cc_to_mm(nmsg, trans, GSM48_MMCC_DATA_REQ);
1256 /* facility is received from lower layer */
1257 static int gsm48_cc_rx_facility(struct gsm_trans *trans, struct msgb *msg)
1259 struct gsm48_hdr *gh = msgb_l3(msg);
1260 unsigned int payload_len = msgb_l3len(msg) - sizeof(*gh);
1261 struct gsm_mncc fac;
1263 LOGP(DCC, LOGL_INFO, "received FACILITY\n");
1265 memset(&fac, 0, sizeof(struct gsm_mncc));
1266 fac.callref = trans->callref;
1267 if (payload_len < 1) {
1268 LOGP(DCC, LOGL_NOTICE, "Short read of facility message "
1273 gsm48_decode_facility(&fac.facility, gh->data);
1275 return mncc_recvmsg(trans->ms, trans, MNCC_FACILITY_IND, &fac);
1278 /* user info message from upper layer or from timer event */
1279 static int gsm48_cc_tx_userinfo(struct gsm_trans *trans, void *arg)
1281 struct gsm_mncc *user = arg;
1283 struct gsm48_hdr *gh;
1285 LOGP(DCC, LOGL_INFO, "sending USERINFO\n");
1287 nmsg = gsm48_l3_msgb_alloc();
1290 gh = (struct gsm48_hdr *) msgb_put(nmsg, sizeof(*gh));
1292 gh->msg_type = GSM48_MT_CC_USER_INFO;
1295 if (user->fields & MNCC_F_USERUSER)
1296 gsm48_encode_useruser(nmsg, 1, &user->useruser);
1299 gsm48_encode_more(nmsg);
1301 return gsm48_cc_to_mm(nmsg, trans, GSM48_MMCC_DATA_REQ);
1304 /* user info is received from lower layer */
1305 static int gsm48_cc_rx_userinfo(struct gsm_trans *trans, struct msgb *msg)
1307 struct gsm48_hdr *gh = msgb_l3(msg);
1308 unsigned int payload_len = msgb_l3len(msg) - sizeof(*gh);
1309 struct tlv_parsed tp;
1310 struct gsm_mncc user;
1312 LOGP(DCC, LOGL_INFO, "received USERINFO\n");
1314 memset(&user, 0, sizeof(struct gsm_mncc));
1315 user.callref = trans->callref;
1316 if (payload_len < 1) {
1317 LOGP(DCC, LOGL_NOTICE, "Short read of userinfo message "
1321 tlv_parse(&tp, &gsm48_att_tlvdef, gh->data, payload_len,
1322 GSM48_IE_USER_USER, 0);
1324 gsm48_decode_useruser(&user.useruser,
1325 TLVP_VAL(&tp, GSM48_IE_USER_USER)-1);
1327 if (TLVP_PRESENT(&tp, GSM48_IE_MORE_DATA))
1330 return mncc_recvmsg(trans->ms, trans, MNCC_USERINFO_IND, &user);
1333 /* modify message from upper layer or from timer event */
1334 static int gsm48_cc_tx_modify(struct gsm_trans *trans, void *arg)
1336 struct gsm_mncc *modify = arg;
1338 struct gsm48_hdr *gh;
1340 LOGP(DCC, LOGL_INFO, "sending MODIFY\n");
1342 nmsg = gsm48_l3_msgb_alloc();
1345 gh = (struct gsm48_hdr *) msgb_put(nmsg, sizeof(*gh));
1347 gh->msg_type = GSM48_MT_CC_MODIFY;
1349 gsm48_start_cc_timer(trans, 0x323, GSM48_T323_MS);
1351 /* bearer capability */
1352 gsm48_encode_bearer_cap(nmsg, 1, &modify->bearer_cap);
1354 new_cc_state(trans, GSM_CSTATE_MO_TERM_MODIFY);
1356 return gsm48_cc_to_mm(nmsg, trans, GSM48_MMCC_DATA_REQ);
1359 /* modify complete is received from lower layer */
1360 static int gsm48_cc_rx_modify_complete(struct gsm_trans *trans,
1363 struct gsm48_hdr *gh = msgb_l3(msg);
1364 unsigned int payload_len = msgb_l3len(msg) - sizeof(*gh);
1365 struct gsm_mncc modify;
1367 LOGP(DCC, LOGL_INFO, "received MODIFY COMPLETE\n");
1369 gsm48_stop_cc_timer(trans);
1371 memset(&modify, 0, sizeof(struct gsm_mncc));
1372 modify.callref = trans->callref;
1373 if (payload_len < 1) {
1374 LOGP(DCC, LOGL_NOTICE, "Short read of modify complete message "
1378 /* bearer capability */
1379 gsm48_decode_bearer_cap(&modify.bearer_cap, gh->data);
1381 new_cc_state(trans, GSM_CSTATE_ACTIVE);
1383 return mncc_recvmsg(trans->ms, trans, MNCC_MODIFY_CNF, &modify);
1386 /* modify reject is received from lower layer */
1387 static int gsm48_cc_rx_modify_reject(struct gsm_trans *trans, struct msgb *msg)
1389 struct gsm48_hdr *gh = msgb_l3(msg);
1390 unsigned int payload_len = msgb_l3len(msg) - sizeof(*gh);
1391 struct tlv_parsed tp;
1392 struct gsm_mncc modify;
1394 LOGP(DCC, LOGL_INFO, "received MODIFY REJECT\n");
1396 gsm48_stop_cc_timer(trans);
1398 memset(&modify, 0, sizeof(struct gsm_mncc));
1399 modify.callref = trans->callref;
1400 if (payload_len < 1) {
1401 LOGP(DCC, LOGL_NOTICE, "Short read of modify reject message "
1405 tlv_parse(&tp, &gsm48_att_tlvdef, gh->data, payload_len,
1406 GSM48_IE_BEARER_CAP, GSM48_IE_CAUSE);
1407 /* bearer capability */
1408 if (TLVP_PRESENT(&tp, GSM48_IE_BEARER_CAP)) {
1409 modify.fields |= MNCC_F_BEARER_CAP;
1410 gsm48_decode_bearer_cap(&modify.bearer_cap,
1411 TLVP_VAL(&tp, GSM48_IE_BEARER_CAP)-1);
1414 if (TLVP_PRESENT(&tp, GSM48_IE_CAUSE)) {
1415 modify.fields |= MNCC_F_CAUSE;
1416 gsm48_decode_cause(&modify.cause,
1417 TLVP_VAL(&tp, GSM48_IE_CAUSE)-1);
1420 new_cc_state(trans, GSM_CSTATE_ACTIVE);
1422 return mncc_recvmsg(trans->ms, trans, MNCC_MODIFY_REJ, &modify);
1425 /* modify is received from lower layer */
1426 static int gsm48_cc_rx_modify(struct gsm_trans *trans, struct msgb *msg)
1428 struct gsm48_hdr *gh = msgb_l3(msg);
1429 unsigned int payload_len = msgb_l3len(msg) - sizeof(*gh);
1430 struct gsm_mncc modify;
1432 LOGP(DCC, LOGL_INFO, "received MODIFY\n");
1434 memset(&modify, 0, sizeof(struct gsm_mncc));
1435 modify.callref = trans->callref;
1436 if (payload_len < 1) {
1437 LOGP(DCC, LOGL_NOTICE, "Short read of modify message error.\n");
1440 /* bearer capability */
1441 gsm48_decode_bearer_cap(&modify.bearer_cap, gh->data);
1443 new_cc_state(trans, GSM_CSTATE_MO_ORIG_MODIFY);
1445 return mncc_recvmsg(trans->ms, trans, MNCC_MODIFY_IND, &modify);
1448 /* modify complete message from upper layer or from timer event */
1449 static int gsm48_cc_tx_modify_complete(struct gsm_trans *trans, void *arg)
1451 struct gsm_mncc *modify = arg;
1453 struct gsm48_hdr *gh;
1455 LOGP(DCC, LOGL_INFO, "sending MODIFY COMPLETE\n");
1457 nmsg = gsm48_l3_msgb_alloc();
1460 gh = (struct gsm48_hdr *) msgb_put(nmsg, sizeof(*gh));
1462 gh->msg_type = GSM48_MT_CC_MODIFY_COMPL;
1464 /* bearer capability */
1465 gsm48_encode_bearer_cap(nmsg, 1, &modify->bearer_cap);
1467 new_cc_state(trans, GSM_CSTATE_ACTIVE);
1469 return gsm48_cc_to_mm(nmsg, trans, GSM48_MMCC_DATA_REQ);
1472 /* modify reject message from upper layer or from timer event */
1473 static int gsm48_cc_tx_modify_reject(struct gsm_trans *trans, void *arg)
1475 struct gsm_mncc *modify = arg;
1477 struct gsm48_hdr *gh;
1479 LOGP(DCC, LOGL_INFO, "sending MODIFY REJECT\n");
1481 nmsg = gsm48_l3_msgb_alloc();
1484 gh = (struct gsm48_hdr *) msgb_put(nmsg, sizeof(*gh));
1486 gh->msg_type = GSM48_MT_CC_MODIFY_REJECT;
1488 /* bearer capability */
1489 gsm48_encode_bearer_cap(nmsg, 1, &modify->bearer_cap);
1491 gsm48_encode_cause(nmsg, 1, &modify->cause);
1493 new_cc_state(trans, GSM_CSTATE_ACTIVE);
1495 return gsm48_cc_to_mm(nmsg, trans, GSM48_MMCC_DATA_REQ);
1499 * process handlers (call clearing)
1502 static struct gsm_mncc_cause default_cause = {
1503 .location = GSM48_CAUSE_LOC_PRN_S_LU,
1507 .value = GSM48_CC_CAUSE_NORMAL_UNSPEC,
1512 /* disconnect message from upper layer or from timer event */
1513 static int gsm48_cc_tx_disconnect(struct gsm_trans *trans, void *arg)
1515 struct gsm_mncc *disc = arg;
1517 struct gsm48_hdr *gh;
1519 LOGP(DCC, LOGL_INFO, "sending DISCONNECT\n");
1521 nmsg = gsm48_l3_msgb_alloc();
1524 gh = (struct gsm48_hdr *) msgb_put(nmsg, sizeof(*gh));
1526 gh->msg_type = GSM48_MT_CC_DISCONNECT;
1528 gsm48_stop_cc_timer(trans);
1529 gsm48_start_cc_timer(trans, 0x305, GSM48_T305_MS);
1532 if (disc->fields & MNCC_F_CAUSE)
1533 gsm48_encode_cause(nmsg, 1, &disc->cause);
1535 gsm48_encode_cause(nmsg, 1, &default_cause);
1538 if (disc->fields & MNCC_F_FACILITY)
1539 gsm48_encode_facility(nmsg, 0, &disc->facility);
1541 if (disc->fields & MNCC_F_PROGRESS)
1542 gsm48_encode_progress(nmsg, 0, &disc->progress);
1544 if (disc->fields & MNCC_F_USERUSER)
1545 gsm48_encode_useruser(nmsg, 0, &disc->useruser);
1547 if (disc->fields & MNCC_F_SSVERSION)
1548 gsm48_encode_ssversion(nmsg, &disc->ssversion);
1550 new_cc_state(trans, GSM_CSTATE_DISCONNECT_REQ);
1552 return gsm48_cc_to_mm(nmsg, trans, GSM48_MMCC_DATA_REQ);
1555 /* release message from upper layer or from timer event */
1556 static int gsm48_cc_tx_release(struct gsm_trans *trans, void *arg)
1558 struct gsm_mncc *rel = arg;
1560 struct gsm48_hdr *gh;
1562 LOGP(DCC, LOGL_INFO, "sending RELEASE\n");
1564 nmsg = gsm48_l3_msgb_alloc();
1567 gh = (struct gsm48_hdr *) msgb_put(nmsg, sizeof(*gh));
1569 gh->msg_type = GSM48_MT_CC_RELEASE;
1571 gsm48_stop_cc_timer(trans);
1572 gsm48_start_cc_timer(trans, 0x308, GSM48_T308_MS);
1575 if (rel->fields & MNCC_F_CAUSE)
1576 gsm48_encode_cause(nmsg, 0, &rel->cause);
1578 if (rel->fields & MNCC_F_FACILITY)
1579 gsm48_encode_facility(nmsg, 0, &rel->facility);
1581 if (rel->fields & MNCC_F_USERUSER)
1582 gsm48_encode_useruser(nmsg, 0, &rel->useruser);
1584 if (rel->fields & MNCC_F_SSVERSION)
1585 gsm48_encode_ssversion(nmsg, &rel->ssversion);
1587 trans->cc.T308_second = 0;
1588 memcpy(&trans->cc.msg, rel, sizeof(struct gsm_mncc));
1590 if (trans->cc.state != GSM_CSTATE_RELEASE_REQ)
1591 new_cc_state(trans, GSM_CSTATE_RELEASE_REQ);
1593 gsm48_cc_to_mm(nmsg, trans, GSM48_MMCC_DATA_REQ);
1596 /* release without sending MMCC_REL_REQ */
1597 new_cc_state(trans, GSM_CSTATE_NULL);
1605 /* reject message from upper layer */
1606 static int gsm48_cc_tx_release_compl(struct gsm_trans *trans, void *arg)
1608 struct gsm_mncc *rel = arg;
1610 struct gsm48_hdr *gh;
1612 LOGP(DCC, LOGL_INFO, "sending RELEASE COMPLETE\n");
1614 nmsg = gsm48_l3_msgb_alloc();
1617 gh = (struct gsm48_hdr *) msgb_put(nmsg, sizeof(*gh));
1619 gh->msg_type = GSM48_MT_CC_RELEASE_COMPL;
1621 gsm48_stop_cc_timer(trans);
1624 if (rel->fields & MNCC_F_CAUSE)
1625 gsm48_encode_cause(nmsg, 0, &rel->cause);
1627 if (rel->fields & MNCC_F_FACILITY)
1628 gsm48_encode_facility(nmsg, 0, &rel->facility);
1630 if (rel->fields & MNCC_F_USERUSER)
1631 gsm48_encode_useruser(nmsg, 0, &rel->useruser);
1633 if (rel->fields & MNCC_F_SSVERSION)
1634 gsm48_encode_ssversion(nmsg, &rel->ssversion);
1636 /* release without sending MMCC_REL_REQ */
1637 new_cc_state(trans, GSM_CSTATE_NULL);
1644 /* disconnect is received from lower layer */
1645 static int gsm48_cc_rx_disconnect(struct gsm_trans *trans, struct msgb *msg)
1647 struct gsm48_hdr *gh = msgb_l3(msg);
1648 unsigned int payload_len = msgb_l3len(msg) - sizeof(*gh);
1649 struct tlv_parsed tp;
1650 struct gsm_mncc disc;
1652 LOGP(DCC, LOGL_INFO, "received DISCONNECT\n");
1654 gsm48_stop_cc_timer(trans);
1656 new_cc_state(trans, GSM_CSTATE_DISCONNECT_IND);
1658 memset(&disc, 0, sizeof(struct gsm_mncc));
1659 disc.callref = trans->callref;
1660 tlv_parse(&tp, &gsm48_att_tlvdef, gh->data, payload_len,
1663 if (TLVP_PRESENT(&tp, GSM48_IE_CAUSE)) {
1664 disc.fields |= MNCC_F_CAUSE;
1665 gsm48_decode_cause(&disc.cause,
1666 TLVP_VAL(&tp, GSM48_IE_CAUSE)-1);
1669 if (TLVP_PRESENT(&tp, GSM48_IE_FACILITY)) {
1670 disc.fields |= MNCC_F_FACILITY;
1671 gsm48_decode_facility(&disc.facility,
1672 TLVP_VAL(&tp, GSM48_IE_FACILITY)-1);
1675 if (TLVP_PRESENT(&tp, GSM48_IE_PROGR_IND)) {
1676 disc.fields |= MNCC_F_PROGRESS;
1677 gsm48_decode_progress(&disc.progress,
1678 TLVP_VAL(&tp, GSM48_IE_PROGR_IND)-1);
1681 if (TLVP_PRESENT(&tp, GSM48_IE_USER_USER)) {
1682 disc.fields |= MNCC_F_USERUSER;
1683 gsm48_decode_useruser(&disc.useruser,
1684 TLVP_VAL(&tp, GSM48_IE_USER_USER)-1);
1687 /* store disconnect cause for T305 expiry */
1688 memcpy(&trans->cc.msg, &disc, sizeof(struct gsm_mncc));
1690 return mncc_recvmsg(trans->ms, trans, MNCC_DISC_IND, &disc);
1693 /* release is received from lower layer */
1694 static int gsm48_cc_rx_release(struct gsm_trans *trans, struct msgb *msg)
1696 struct gsm48_hdr *gh = msgb_l3(msg);
1697 unsigned int payload_len = msgb_l3len(msg) - sizeof(*gh);
1698 struct tlv_parsed tp;
1699 struct gsm_mncc rel;
1701 LOGP(DCC, LOGL_INFO, "received RELEASE\n");
1703 gsm48_stop_cc_timer(trans);
1705 memset(&rel, 0, sizeof(struct gsm_mncc));
1706 rel.callref = trans->callref;
1707 tlv_parse(&tp, &gsm48_att_tlvdef, gh->data, payload_len, 0, 0);
1709 if (TLVP_PRESENT(&tp, GSM48_IE_CAUSE)) {
1710 rel.fields |= MNCC_F_CAUSE;
1711 gsm48_decode_cause(&rel.cause,
1712 TLVP_VAL(&tp, GSM48_IE_CAUSE)-1);
1715 if (TLVP_PRESENT(&tp, GSM48_IE_FACILITY)) {
1716 rel.fields |= MNCC_F_FACILITY;
1717 gsm48_decode_facility(&rel.facility,
1718 TLVP_VAL(&tp, GSM48_IE_FACILITY)-1);
1721 if (TLVP_PRESENT(&tp, GSM48_IE_USER_USER)) {
1722 rel.fields |= MNCC_F_USERUSER;
1723 gsm48_decode_useruser(&rel.useruser,
1724 TLVP_VAL(&tp, GSM48_IE_USER_USER)-1);
1727 /* in case we receive a relase, when we are already in NULL state */
1728 if (trans->cc.state == GSM_CSTATE_NULL) {
1729 LOGP(DCC, LOGL_INFO, "ignoring RELEASE in NULL state\n");
1730 /* release MM conn, free trans */
1731 return gsm48_rel_null_free(trans);
1733 if (trans->cc.state == GSM_CSTATE_RELEASE_REQ) {
1734 /* release collision 5.4.5 */
1735 mncc_recvmsg(trans->ms, trans, MNCC_REL_CNF, &rel);
1739 /* forward cause only */
1740 LOGP(DCC, LOGL_INFO, "sending RELEASE COMPLETE\n");
1742 nmsg = gsm48_l3_msgb_alloc();
1745 gh = (struct gsm48_hdr *) msgb_put(nmsg, sizeof(*gh));
1747 gh->msg_type = GSM48_MT_CC_RELEASE_COMPL;
1749 if (rel.fields & MNCC_F_CAUSE)
1750 gsm48_encode_cause(nmsg, 0, &rel.cause);
1752 gsm48_cc_to_mm(nmsg, trans, GSM48_MMCC_DATA_REQ);
1754 /* release indication */
1755 mncc_recvmsg(trans->ms, trans, MNCC_REL_IND, &rel);
1758 /* release MM conn, got NULL state, free trans */
1759 return gsm48_rel_null_free(trans);
1762 /* release complete is received from lower layer */
1763 static int gsm48_cc_rx_release_compl(struct gsm_trans *trans, struct msgb *msg)
1765 struct gsm48_hdr *gh = msgb_l3(msg);
1766 unsigned int payload_len = msgb_l3len(msg) - sizeof(*gh);
1767 struct tlv_parsed tp;
1768 struct gsm_mncc rel;
1770 LOGP(DCC, LOGL_INFO, "received RELEASE COMPLETE\n");
1772 gsm48_stop_cc_timer(trans);
1774 memset(&rel, 0, sizeof(struct gsm_mncc));
1775 rel.callref = trans->callref;
1776 tlv_parse(&tp, &gsm48_att_tlvdef, gh->data, payload_len, 0, 0);
1778 if (TLVP_PRESENT(&tp, GSM48_IE_CAUSE)) {
1779 rel.fields |= MNCC_F_CAUSE;
1780 gsm48_decode_cause(&rel.cause,
1781 TLVP_VAL(&tp, GSM48_IE_CAUSE)-1);
1784 if (TLVP_PRESENT(&tp, GSM48_IE_FACILITY)) {
1785 rel.fields |= MNCC_F_FACILITY;
1786 gsm48_decode_facility(&rel.facility,
1787 TLVP_VAL(&tp, GSM48_IE_FACILITY)-1);
1790 if (TLVP_PRESENT(&tp, GSM48_IE_USER_USER)) {
1791 rel.fields |= MNCC_F_USERUSER;
1792 gsm48_decode_useruser(&rel.useruser,
1793 TLVP_VAL(&tp, GSM48_IE_USER_USER)-1);
1796 if (trans->callref) {
1797 switch (trans->cc.state) {
1798 case GSM_CSTATE_CALL_PRESENT:
1799 mncc_recvmsg(trans->ms, trans,
1800 MNCC_REJ_IND, &rel);
1802 case GSM_CSTATE_RELEASE_REQ:
1803 mncc_recvmsg(trans->ms, trans,
1804 MNCC_REL_CNF, &rel);
1807 mncc_recvmsg(trans->ms, trans,
1808 MNCC_REL_IND, &rel);
1812 /* release MM conn, got NULL state, free trans */
1813 return gsm48_rel_null_free(trans);
1820 /* state trasitions for MNCC messages (upper layer) */
1821 static struct downstate {
1824 int (*rout) (struct gsm_trans *trans, void *arg);
1825 } downstatelist[] = {
1826 /* mobile originating call establishment */
1827 {SBIT(GSM_CSTATE_NULL), /* 5.2.1 */
1828 MNCC_SETUP_REQ, gsm48_cc_init_mm},
1830 {SBIT(GSM_CSTATE_MM_CONNECTION_PEND), /* 5.2.1 */
1831 MNCC_REL_REQ, gsm48_cc_abort_mm},
1833 /* mobile terminating call establishment */
1834 {SBIT(GSM_CSTATE_CALL_PRESENT), /* 5.2.2.3.1 */
1835 MNCC_CALL_CONF_REQ, gsm48_cc_tx_call_conf},
1837 {SBIT(GSM_CSTATE_MO_TERM_CALL_CONF), /* 5.2.2.3.2 */
1838 MNCC_ALERT_REQ, gsm48_cc_tx_alerting},
1840 {SBIT(GSM_CSTATE_MO_TERM_CALL_CONF) |
1841 SBIT(GSM_CSTATE_CALL_RECEIVED), /* 5.2.2.5 */
1842 MNCC_SETUP_RSP, gsm48_cc_tx_connect},
1844 /* signalling during call */
1845 {SBIT(GSM_CSTATE_ACTIVE), /* 5.3.1 */
1846 MNCC_NOTIFY_REQ, gsm48_cc_tx_notify},
1848 {ALL_STATES, /* 5.5.7.1 */
1849 MNCC_START_DTMF_REQ, gsm48_cc_tx_start_dtmf},
1851 {ALL_STATES, /* 5.5.7.3 */
1852 MNCC_STOP_DTMF_REQ, gsm48_cc_tx_stop_dtmf},
1854 {SBIT(GSM_CSTATE_ACTIVE),
1855 MNCC_HOLD_REQ, gsm48_cc_tx_hold},
1857 {SBIT(GSM_CSTATE_ACTIVE),
1858 MNCC_RETRIEVE_REQ, gsm48_cc_tx_retrieve},
1860 {ALL_STATES - SBIT(GSM_CSTATE_NULL) - SBIT(GSM_CSTATE_RELEASE_REQ),
1861 MNCC_FACILITY_REQ, gsm48_cc_tx_facility},
1863 {SBIT(GSM_CSTATE_ACTIVE),
1864 MNCC_USERINFO_REQ, gsm48_cc_tx_userinfo},
1867 {ALL_STATES - SBIT(GSM_CSTATE_NULL) - SBIT(GSM_CSTATE_DISCONNECT_IND) -
1868 SBIT(GSM_CSTATE_RELEASE_REQ) -
1869 SBIT(GSM_CSTATE_DISCONNECT_REQ), /* 5.4.3.1 */
1870 MNCC_DISC_REQ, gsm48_cc_tx_disconnect},
1872 {SBIT(GSM_CSTATE_INITIATED),
1873 MNCC_REJ_REQ, gsm48_cc_tx_release_compl},
1875 {ALL_STATES - SBIT(GSM_CSTATE_NULL) -
1876 SBIT(GSM_CSTATE_RELEASE_REQ), /* ??? */
1877 MNCC_REL_REQ, gsm48_cc_tx_release},
1880 {SBIT(GSM_CSTATE_ACTIVE),
1881 MNCC_MODIFY_REQ, gsm48_cc_tx_modify},
1883 {SBIT(GSM_CSTATE_MO_ORIG_MODIFY),
1884 MNCC_MODIFY_RSP, gsm48_cc_tx_modify_complete},
1886 {SBIT(GSM_CSTATE_MO_ORIG_MODIFY),
1887 MNCC_MODIFY_REJ, gsm48_cc_tx_modify_reject},
1891 (sizeof(downstatelist) / sizeof(struct downstate))
1893 int mncc_send(struct osmocom_ms *ms, int msg_type, void *arg)
1895 struct gsm_mncc *data = arg;
1896 struct gsm_trans *trans;
1900 trans = trans_find_by_callref(ms, data->callref);
1903 /* check for SETUP message */
1904 if (msg_type != MNCC_SETUP_REQ) {
1905 /* Invalid call reference */
1906 LOGP(DCC, LOGL_NOTICE, "transaction not found\n");
1907 return mncc_release_ind(ms, NULL, data->callref,
1908 GSM48_CAUSE_LOC_PRN_S_LU,
1909 GSM48_CC_CAUSE_INVAL_TRANS_ID);
1911 if (data->callref >= 0x40000000) {
1912 LOGP(DCC, LOGL_FATAL, "MNCC ref wrong.\n");
1913 return mncc_release_ind(ms, NULL, data->callref,
1914 GSM48_CAUSE_LOC_PRN_S_LU,
1915 GSM48_CC_CAUSE_INVAL_TRANS_ID);
1918 /* Create transaction */
1919 trans = trans_alloc(ms, GSM48_PDISC_CC, 0xff, data->callref);
1921 /* No memory or whatever */
1922 return mncc_release_ind(ms, NULL, data->callref,
1923 GSM48_CAUSE_LOC_PRN_S_LU,
1924 GSM48_CC_CAUSE_RESOURCE_UNAVAIL);
1929 case GSM_TCHF_FRAME:
1930 printf("TCH/F frame ignored!\n");
1934 /* Find function for current state and message */
1935 for (i = 0; i < DOWNSLLEN; i++)
1936 if ((msg_type == downstatelist[i].type)
1937 && ((1 << trans->cc.state) & downstatelist[i].states))
1939 if (i == DOWNSLLEN) {
1940 LOGP(DCC, LOGL_NOTICE, "Message unhandled at this "
1945 rc = downstatelist[i].rout(trans, arg);
1950 /* state trasitions for call control messages (lower layer) */
1951 static struct datastate {
1954 int (*rout) (struct gsm_trans *trans, struct msgb *msg);
1955 } datastatelist[] = {
1956 /* mobile originating call establishment */
1957 {SBIT(GSM_CSTATE_INITIATED), /* 5.2.1.3 */
1958 GSM48_MT_CC_CALL_PROC, gsm48_cc_rx_call_proceeding},
1960 {SBIT(GSM_CSTATE_INITIATED) | SBIT(GSM_CSTATE_MO_CALL_PROC) |
1961 SBIT(GSM_CSTATE_CALL_DELIVERED), /* 5.2.1.4.1 */
1962 GSM48_MT_CC_PROGRESS, gsm48_cc_rx_progress},
1964 {SBIT(GSM_CSTATE_INITIATED) |
1965 SBIT(GSM_CSTATE_MO_CALL_PROC), /* 5.2.1.5 */
1966 GSM48_MT_CC_ALERTING, gsm48_cc_rx_alerting},
1968 {SBIT(GSM_CSTATE_INITIATED) | SBIT(GSM_CSTATE_MO_CALL_PROC) |
1969 SBIT(GSM_CSTATE_CALL_DELIVERED), /* 5.2.1.6 */
1970 GSM48_MT_CC_CONNECT, gsm48_cc_rx_connect},
1972 /* mobile terminating call establishment */
1973 {SBIT(GSM_CSTATE_NULL), /* 5.2.2.1 */
1974 GSM48_MT_CC_SETUP, gsm48_cc_rx_setup},
1976 {SBIT(GSM_CSTATE_CONNECT_REQUEST), /* 5.2.2.6 */
1977 GSM48_MT_CC_CONNECT_ACK, gsm48_cc_rx_connect_ack},
1979 /* signalling during call */
1980 {SBIT(GSM_CSTATE_ACTIVE), /* 5.3.1 */
1981 GSM48_MT_CC_NOTIFY, gsm48_cc_rx_notify},
1983 {ALL_STATES, /* 8.4 */
1984 GSM48_MT_CC_STATUS_ENQ, gsm48_cc_rx_status_enq},
1986 {ALL_STATES, /* 5.5.7.2 */
1987 GSM48_MT_CC_START_DTMF_ACK, gsm48_cc_rx_start_dtmf_ack},
1989 {ALL_STATES, /* 5.5.7.2 */
1990 GSM48_MT_CC_START_DTMF_REJ, gsm48_cc_rx_start_dtmf_rej},
1992 {ALL_STATES, /* 5.5.7.4 */
1993 GSM48_MT_CC_STOP_DTMF_ACK, gsm48_cc_rx_stop_dtmf_ack},
1995 {SBIT(GSM_CSTATE_ACTIVE),
1996 GSM48_MT_CC_HOLD_ACK, gsm48_cc_rx_hold_ack},
1998 {SBIT(GSM_CSTATE_ACTIVE),
1999 GSM48_MT_CC_HOLD_REJ, gsm48_cc_rx_hold_rej},
2001 {SBIT(GSM_CSTATE_ACTIVE),
2002 GSM48_MT_CC_RETR_ACK, gsm48_cc_rx_retrieve_ack},
2004 {SBIT(GSM_CSTATE_ACTIVE),
2005 GSM48_MT_CC_RETR_REJ, gsm48_cc_rx_retrieve_rej},
2007 {ALL_STATES - SBIT(GSM_CSTATE_NULL),
2008 GSM48_MT_CC_FACILITY, gsm48_cc_rx_facility},
2010 {SBIT(GSM_CSTATE_ACTIVE),
2011 GSM48_MT_CC_USER_INFO, gsm48_cc_rx_userinfo},
2014 {ALL_STATES - SBIT(GSM_CSTATE_NULL) - SBIT(GSM_CSTATE_RELEASE_REQ) -
2015 SBIT(GSM_CSTATE_DISCONNECT_IND), /* 5.4.4.1.1 */
2016 GSM48_MT_CC_DISCONNECT, gsm48_cc_rx_disconnect},
2018 {ALL_STATES, /* 5.4.3.3 & 5.4.5!!!*/
2019 GSM48_MT_CC_RELEASE, gsm48_cc_rx_release},
2021 {ALL_STATES, /* 5.4.4.1.3 */
2022 GSM48_MT_CC_RELEASE_COMPL, gsm48_cc_rx_release_compl},
2025 {SBIT(GSM_CSTATE_ACTIVE),
2026 GSM48_MT_CC_MODIFY, gsm48_cc_rx_modify},
2028 {SBIT(GSM_CSTATE_MO_TERM_MODIFY),
2029 GSM48_MT_CC_MODIFY_COMPL, gsm48_cc_rx_modify_complete},
2031 {SBIT(GSM_CSTATE_MO_TERM_MODIFY),
2032 GSM48_MT_CC_MODIFY_REJECT, gsm48_cc_rx_modify_reject},
2036 (sizeof(datastatelist) / sizeof(struct datastate))
2038 static int gsm48_cc_data_ind(struct gsm_trans *trans, struct msgb *msg)
2040 struct osmocom_ms *ms = trans->ms;
2041 struct gsm48_hdr *gh = msgb_l3(msg);
2042 int msg_type = gh->msg_type & 0xbf;
2043 uint8_t transaction_id = ((gh->proto_discr & 0xf0) ^ 0x80) >> 4;
2045 int msg_supported = 0; /* determine, if message is supported at all */
2048 /* set transaction ID, if not already */
2049 trans->transaction_id = transaction_id;
2051 /* pull the MMCC header */
2052 msgb_pull(msg, sizeof(struct gsm48_mmxx_hdr));
2054 LOGP(DCC, LOGL_INFO, "(ms %s) Received '%s' in CC state %s\n", ms->name,
2055 gsm48_cc_msg_name(msg_type),
2056 gsm48_cc_state_name(trans->cc.state));
2058 /* find function for current state and message */
2059 for (i = 0; i < DATASLLEN; i++) {
2060 if (msg_type == datastatelist[i].type)
2062 if ((msg_type == datastatelist[i].type)
2063 && ((1 << trans->cc.state) & datastatelist[i].states))
2066 if (i == DATASLLEN) {
2067 if (msg_supported) {
2068 LOGP(DCC, LOGL_NOTICE, "Message unhandled at this "
2070 return gsm48_cc_tx_status(trans,
2071 GSM48_REJECT_MSG_TYPE_NOT_COMPATIBLE);
2073 LOGP(DCC, LOGL_NOTICE, "Message not supported.\n");
2074 return gsm48_cc_tx_status(trans,
2075 GSM48_REJECT_MSG_TYPE_NOT_IMPLEMENTED);
2079 rc = datastatelist[i].rout(trans, msg);
2084 /* receive message from MM layer */
2085 int gsm48_rcv_cc(struct osmocom_ms *ms, struct msgb *msg)
2087 struct gsm48_mmxx_hdr *mmh = (struct gsm48_mmxx_hdr *)msg->data;
2088 int msg_type = mmh->msg_type;
2089 struct gsm_trans *trans;
2092 trans = trans_find_by_callref(ms, mmh->ref);
2094 trans = trans_alloc(ms, GSM48_PDISC_CC, mmh->transaction_id,
2100 LOGP(DCC, LOGL_INFO, "(ms %s) Received '%s' in CC state %s\n", ms->name,
2101 get_mmxx_name(msg_type),
2102 gsm48_cc_state_name(trans->cc.state));
2105 case GSM48_MMCC_EST_IND:
2107 rc = gsm48_cc_data_ind(trans, msg);
2109 case GSM48_MMCC_EST_CNF:
2110 /* send setup after confirm */
2111 if (trans->cc.state == GSM_CSTATE_MM_CONNECTION_PEND)
2112 rc = gsm48_cc_tx_setup(trans);
2114 LOGP(DCC, LOGL_ERROR, "Oops, MMCC-EST-CONF in state "
2115 "%d?\n", trans->cc.state);
2117 case GSM48_MMCC_ERR_IND: /* no supporting re-establishment */
2118 case GSM48_MMCC_REL_IND:
2119 /* release L4, release transaction */
2120 mncc_release_ind(trans->ms, trans, trans->callref,
2121 GSM48_CAUSE_LOC_PRN_S_LU, mmh->cause);
2122 /* release without sending MMCC_REL_REQ */
2123 new_cc_state(trans, GSM_CSTATE_NULL);
2127 case GSM48_MMCC_DATA_IND:
2128 rc = gsm48_cc_data_ind(trans, msg);
2130 case GSM48_MMCC_UNIT_DATA_IND:
2132 case GSM48_MMCC_SYNC_IND:
2135 LOGP(DCC, LOGL_NOTICE, "Message unhandled.\n");