blob: 6ff8fe362380f33e72378a8d81a3a2b2cb72c331 [file] [log] [blame]
Neels Hofmeyrac85b342018-07-12 21:23:26 +02001/* osmo-bsc API to manage lchans, logical channels in GSM cells. */
2#pragma once
3
4#define LOG_LCHAN_RTP(lchan, level, fmt, args...) do { \
5 if (lchan->fi_rtp) \
6 LOGPFSML(lchan->fi_rtp, level, fmt, ## args); \
7 else \
8 LOGP(DLMGCP, level, "%s (not initialized) " fmt, gsm_lchan_name(lchan), \
9 ## args); \
10 } while(0)
11
12struct gsm_lchan;
Neels Hofmeyrf14aaa42019-04-23 18:37:37 +020013struct mgcp_conn_peer;
Neels Hofmeyrac85b342018-07-12 21:23:26 +020014
15enum lchan_rtp_fsm_state {
16 LCHAN_RTP_ST_WAIT_MGW_ENDPOINT_AVAILABLE,
17 LCHAN_RTP_ST_WAIT_LCHAN_READY,
18 LCHAN_RTP_ST_WAIT_IPACC_CRCX_ACK,
19 LCHAN_RTP_ST_WAIT_IPACC_MDCX_ACK,
20 LCHAN_RTP_ST_WAIT_READY_TO_SWITCH_RTP,
21 LCHAN_RTP_ST_WAIT_MGW_ENDPOINT_CONFIGURED,
22 LCHAN_RTP_ST_READY,
23 LCHAN_RTP_ST_ROLLBACK,
24 LCHAN_RTP_ST_ESTABLISHED,
25};
26
27enum lchan_rtp_fsm_event {
28 LCHAN_RTP_EV_LCHAN_READY,
29 LCHAN_RTP_EV_READY_TO_SWITCH_RTP,
30 LCHAN_RTP_EV_MGW_ENDPOINT_AVAILABLE,
31 LCHAN_RTP_EV_MGW_ENDPOINT_ERROR,
32 LCHAN_RTP_EV_IPACC_CRCX_ACK,
33 LCHAN_RTP_EV_IPACC_CRCX_NACK,
34 LCHAN_RTP_EV_IPACC_MDCX_ACK,
35 LCHAN_RTP_EV_IPACC_MDCX_NACK,
36 LCHAN_RTP_EV_READY_TO_SWITCH,
37 LCHAN_RTP_EV_MGW_ENDPOINT_CONFIGURED,
38 LCHAN_RTP_EV_ROLLBACK, /*< Give the RTP back to the old lchan, if any */
39 LCHAN_RTP_EV_ESTABLISHED, /*< All done, forget about the old lchan, if any */
40 LCHAN_RTP_EV_RELEASE,
41};
42
43void lchan_rtp_fsm_start(struct gsm_lchan *lchan);
Neels Hofmeyrf14aaa42019-04-23 18:37:37 +020044struct osmo_mgcpc_ep_ci *lchan_use_mgw_endpoint_ci_bts(struct gsm_lchan *lchan);
Neels Hofmeyrac85b342018-07-12 21:23:26 +020045bool lchan_rtp_established(struct gsm_lchan *lchan);
46void lchan_forget_mgw_endpoint(struct gsm_lchan *lchan);
Neels Hofmeyrf14aaa42019-04-23 18:37:37 +020047
48void mgcp_pick_codec(struct mgcp_conn_peer *verb_info, const struct gsm_lchan *lchan, bool bss_side);