git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@4881 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Anthony Minessale 2007-04-07 03:07:43 +00:00
parent 951e771524
commit 3f6520a559
5 changed files with 70 additions and 2 deletions

View File

@ -7,6 +7,9 @@
<settings> <settings>
<!--Most channels to allow at once --> <!--Most channels to allow at once -->
<param name="max-sessions" value="1000"/> <param name="max-sessions" value="1000"/>
<!--RTP port range -->
<!--<param name="rtp-start-port" value="16384"/>-->
<!--<param name="rtp-end-port" value="32768"/>-->
</settings> </settings>
<!--Any variables defined here will be available in every channel, in the dialplan etc --> <!--Any variables defined here will be available in every channel, in the dialplan etc -->
<variables> <variables>

View File

@ -2,6 +2,9 @@
<settings> <settings>
<!--Most channels to allow at once --> <!--Most channels to allow at once -->
<param name="max-sessions" value="1000"/> <param name="max-sessions" value="1000"/>
<!--RTP port range -->
<!--<param name="rtp-start-port" value="16384"/>-->
<!--<param name="rtp-end-port" value="32768"/>-->
</settings> </settings>
<!--Any variables defined here will be available in every channel, in the dialplan etc --> <!--Any variables defined here will be available in every channel, in the dialplan etc -->
<variables> <variables>

View File

@ -27,6 +27,7 @@
* *
* *
* switch_channel.h -- Media Channel Interface * switch_channel.h -- Media Channel Interface
* Marcel Barbulescu <marcelbarbulescu@gmail.com>
* *
*/ */
/** /**
@ -53,6 +54,20 @@ typedef void (*switch_rtp_invalid_handler_t) (switch_rtp_t *rtp_session,
*/ */
SWITCH_DECLARE(void) switch_rtp_init(switch_memory_pool_t *pool); SWITCH_DECLARE(void) switch_rtp_init(switch_memory_pool_t *pool);
/*!
\brief Set/Get RTP start port
\param port new value (if > 0)
\return the current RTP start port
*/
SWITCH_DECLARE(switch_port_t) switch_rtp_set_start_port(switch_port_t port);
/*!
\brief Set/Get RTP end port
\param port new value (if > 0)
\return the current RTP end port
*/
SWITCH_DECLARE(switch_port_t) switch_rtp_set_end_port(switch_port_t port);
/*! /*!
\brief Request a new port to be used for media \brief Request a new port to be used for media
\return the new port to use \return the new port to use

View File

@ -26,6 +26,7 @@
* Anthony Minessale II <anthmct@yahoo.com> * Anthony Minessale II <anthmct@yahoo.com>
* Michael Jerris <mike@jerris.com> * Michael Jerris <mike@jerris.com>
* Paul D. Tinsley <pdt at jackhammer.org> * Paul D. Tinsley <pdt at jackhammer.org>
* Marcel Barbulescu <marcelbarbulescu@gmail.com>
* *
* *
* switch_core.c -- Main Core Library * switch_core.c -- Main Core Library
@ -445,6 +446,12 @@ SWITCH_DECLARE(switch_status_t) switch_core_init(char *console, const char **err
if (!strcasecmp(var, "max-sessions")) { if (!strcasecmp(var, "max-sessions")) {
switch_core_session_limit(atoi(val)); switch_core_session_limit(atoi(val));
} }
else if (!strcasecmp(var, "rtp-start-port")) {
switch_rtp_set_start_port(atoi(val));
}
else if (!strcasecmp(var, "rtp-end-port")) {
switch_rtp_set_end_port(atoi(val));
}
} }
} }

View File

@ -24,6 +24,7 @@
* Contributor(s): * Contributor(s):
* *
* Anthony Minessale II <anthmct@yahoo.com> * Anthony Minessale II <anthmct@yahoo.com>
* Marcel Barbulescu <marcelbarbulescu@gmail.com>
* *
* *
* switch_rtp.c -- RTP * switch_rtp.c -- RTP
@ -50,6 +51,8 @@
#define MASTER_KEY_LEN 30 #define MASTER_KEY_LEN 30
#define RTP_MAGIC_NUMBER 42 #define RTP_MAGIC_NUMBER 42
static switch_port_t START_PORT = RTP_START_PORT;
static switch_port_t END_PORT = RTP_END_PORT;
static switch_port_t NEXT_PORT = RTP_START_PORT; static switch_port_t NEXT_PORT = RTP_START_PORT;
static switch_mutex_t *port_lock = NULL; static switch_mutex_t *port_lock = NULL;
@ -263,6 +266,43 @@ SWITCH_DECLARE(void) switch_rtp_init(switch_memory_pool_t *pool)
global_init = 1; global_init = 1;
} }
SWITCH_DECLARE(switch_port_t) switch_rtp_set_start_port(switch_port_t port)
{
if (port) {
if (port_lock) {
switch_mutex_lock(port_lock);
}
if (NEXT_PORT == START_PORT) {
NEXT_PORT = port;
}
START_PORT = port;
if (NEXT_PORT < START_PORT) {
NEXT_PORT = START_PORT;
}
if (port_lock) {
switch_mutex_unlock(port_lock);
}
}
return START_PORT;
}
SWITCH_DECLARE(switch_port_t) switch_rtp_set_end_port(switch_port_t port)
{
if (port) {
if (port_lock) {
switch_mutex_lock(port_lock);
}
END_PORT = port;
if (NEXT_PORT > END_PORT) {
NEXT_PORT = START_PORT;
}
if (port_lock) {
switch_mutex_unlock(port_lock);
}
}
return END_PORT;
}
SWITCH_DECLARE(switch_port_t) switch_rtp_request_port(void) SWITCH_DECLARE(switch_port_t) switch_rtp_request_port(void)
{ {
switch_port_t port; switch_port_t port;
@ -270,8 +310,8 @@ SWITCH_DECLARE(switch_port_t) switch_rtp_request_port(void)
switch_mutex_lock(port_lock); switch_mutex_lock(port_lock);
port = NEXT_PORT; port = NEXT_PORT;
NEXT_PORT += 2; NEXT_PORT += 2;
if (NEXT_PORT > RTP_END_PORT) { if (NEXT_PORT > END_PORT) {
NEXT_PORT = RTP_START_PORT; NEXT_PORT = START_PORT;
} }
switch_mutex_unlock(port_lock); switch_mutex_unlock(port_lock);
return port; return port;