mgcp: make bts base port configurable
Currently the rtp base port of the BTS is hardcoded (4000) and not configurable. This patch adds VTY configuration options to make it adjustable. Change-Id: I76e008eb0bd95b2941b67ea2fbdc1a82eef3cc5f
This commit is contained in:
parent
62afc1467a
commit
2b3b4d407f
|
@ -26,6 +26,7 @@ struct mgcpgw_client_conf {
|
||||||
int remote_port;
|
int remote_port;
|
||||||
uint16_t first_endpoint;
|
uint16_t first_endpoint;
|
||||||
uint16_t last_endpoint;
|
uint16_t last_endpoint;
|
||||||
|
uint16_t bts_base;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct mgcp_response_head {
|
struct mgcp_response_head {
|
||||||
|
|
|
@ -45,6 +45,7 @@ void mgcpgw_client_conf_init(struct mgcpgw_client_conf *conf)
|
||||||
.remote_port = -1,
|
.remote_port = -1,
|
||||||
.first_endpoint = 0,
|
.first_endpoint = 0,
|
||||||
.last_endpoint = 0,
|
.last_endpoint = 0,
|
||||||
|
.bts_base = 0,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -342,6 +343,7 @@ struct mgcpgw_client *mgcpgw_client_init(void *ctx,
|
||||||
|
|
||||||
mgcp->actual.first_endpoint = conf->first_endpoint > 0 ? (uint16_t)conf->first_endpoint : 0;
|
mgcp->actual.first_endpoint = conf->first_endpoint > 0 ? (uint16_t)conf->first_endpoint : 0;
|
||||||
mgcp->actual.last_endpoint = conf->last_endpoint > 0 ? (uint16_t)conf->last_endpoint : 0;
|
mgcp->actual.last_endpoint = conf->last_endpoint > 0 ? (uint16_t)conf->last_endpoint : 0;
|
||||||
|
mgcp->actual.bts_base = conf->bts_base > 0 ? (uint16_t)conf->bts_base : 4000;
|
||||||
|
|
||||||
return mgcp;
|
return mgcp;
|
||||||
}
|
}
|
||||||
|
|
|
@ -99,12 +99,26 @@ DEFUN(cfg_mgcpgw_endpoint_range, cfg_mgcpgw_endpoint_range_cmd,
|
||||||
return CMD_SUCCESS;
|
return CMD_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define BTS_START_STR "First UDP port allocated for the BTS side\n"
|
||||||
|
#define UDP_PORT_STR "UDP Port number\n"
|
||||||
|
DEFUN(cfg_mgcp_rtp_bts_base_port,
|
||||||
|
cfg_mgcp_rtp_bts_base_port_cmd,
|
||||||
|
"mgcpgw bts-base <0-65534>",
|
||||||
|
MGCPGW_STR
|
||||||
|
BTS_START_STR
|
||||||
|
UDP_PORT_STR)
|
||||||
|
{
|
||||||
|
global_mgcpgw_client_conf->bts_base = atoi(argv[0]);
|
||||||
|
return CMD_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
int mgcpgw_client_config_write(struct vty *vty, const char *indent)
|
int mgcpgw_client_config_write(struct vty *vty, const char *indent)
|
||||||
{
|
{
|
||||||
const char *addr;
|
const char *addr;
|
||||||
int port;
|
int port;
|
||||||
uint16_t first_endpoint;
|
uint16_t first_endpoint;
|
||||||
uint16_t last_endpoint;
|
uint16_t last_endpoint;
|
||||||
|
uint16_t bts_base;
|
||||||
|
|
||||||
addr = global_mgcpgw_client_conf->local_addr;
|
addr = global_mgcpgw_client_conf->local_addr;
|
||||||
if (addr)
|
if (addr)
|
||||||
|
@ -131,6 +145,12 @@ int mgcpgw_client_config_write(struct vty *vty, const char *indent)
|
||||||
first_endpoint, last_endpoint, VTY_NEWLINE);
|
first_endpoint, last_endpoint, VTY_NEWLINE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bts_base = global_mgcpgw_client_conf->bts_base;
|
||||||
|
if (bts_base) {
|
||||||
|
vty_out(vty, "%smgcpgw bts-base %u%s", indent,
|
||||||
|
bts_base, VTY_NEWLINE);
|
||||||
|
}
|
||||||
|
|
||||||
return CMD_SUCCESS;
|
return CMD_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -143,4 +163,5 @@ void mgcpgw_client_vty_init(int node, struct mgcpgw_client_conf *conf)
|
||||||
install_element(node, &cfg_mgcpgw_remote_ip_cmd);
|
install_element(node, &cfg_mgcpgw_remote_ip_cmd);
|
||||||
install_element(node, &cfg_mgcpgw_remote_port_cmd);
|
install_element(node, &cfg_mgcpgw_remote_port_cmd);
|
||||||
install_element(node, &cfg_mgcpgw_endpoint_range_cmd);
|
install_element(node, &cfg_mgcpgw_endpoint_range_cmd);
|
||||||
|
install_element(node, &cfg_mgcp_rtp_bts_base_port_cmd);
|
||||||
}
|
}
|
||||||
|
|
|
@ -195,6 +195,7 @@ static int conn_iu_rab_act_cs(struct gsm_trans *trans)
|
||||||
struct mgcpgw_client *mgcp = conn->network->mgcpgw.client;
|
struct mgcpgw_client *mgcp = conn->network->mgcpgw.client;
|
||||||
struct msgb *msg;
|
struct msgb *msg;
|
||||||
struct msgb *msg_dlcx;
|
struct msgb *msg_dlcx;
|
||||||
|
uint16_t bts_base;
|
||||||
|
|
||||||
/* HACK. where to scope the RAB Id? At the conn / subscriber /
|
/* HACK. where to scope the RAB Id? At the conn / subscriber /
|
||||||
* ue_conn_ctx? */
|
* ue_conn_ctx? */
|
||||||
|
@ -203,9 +204,14 @@ static int conn_iu_rab_act_cs(struct gsm_trans *trans)
|
||||||
|
|
||||||
conn->iu.mgcp_rtp_endpoint =
|
conn->iu.mgcp_rtp_endpoint =
|
||||||
mgcpgw_client_next_endpoint(conn->network->mgcpgw.client);
|
mgcpgw_client_next_endpoint(conn->network->mgcpgw.client);
|
||||||
/* HACK: the addresses should be known from CRCX response
|
|
||||||
* and config. */
|
/* This will calculate the port we assign to the BTS via AoIP
|
||||||
conn->iu.mgcp_rtp_port_ue = 4000 + 2 * conn->iu.mgcp_rtp_endpoint;
|
* assignment command (or rab-assignment on 3G) The BTS will send
|
||||||
|
* its RTP traffic to that port on the MGCPGW side. The MGCPGW only
|
||||||
|
* gets the endpoint ID via the CRCX. It will do the same calculation
|
||||||
|
* on his side too to get knowledge of the rtp port. */
|
||||||
|
bts_base = mgcp->actual.bts_base;
|
||||||
|
conn->iu.mgcp_rtp_port_ue = bts_base + 2 * conn->iu.mgcp_rtp_endpoint;
|
||||||
|
|
||||||
/* Since we know now the endpoint number, we enforce a DLCX on tha
|
/* Since we know now the endpoint number, we enforce a DLCX on tha
|
||||||
* endpoint in order to ensure that this endpoint is not occupied
|
* endpoint in order to ensure that this endpoint is not occupied
|
||||||
|
|
Loading…
Reference in New Issue