[CORE] Parametrize Video Buffer size
Video Buffer size (max_frames) is hardcoded to the value of 10, which leads to overflow the buffer quite quickly, especially for higher resolutions or harder to encoded video scenes (e.g. high motion ones). With this change, video buffer size can be configured via video-jb-size-factor parameter in switch.conf within boundaries 10 - 100.
This commit is contained in:
parent
7f86d25c6c
commit
d679e6aa7e
|
@ -2393,6 +2393,8 @@ static void switch_load_core_config(const char *file)
|
||||||
}
|
}
|
||||||
} else if (!strcasecmp(var, "max-audio-channels") && !zstr(val)) {
|
} else if (!strcasecmp(var, "max-audio-channels") && !zstr(val)) {
|
||||||
switch_core_max_audio_channels(atoi(val));
|
switch_core_max_audio_channels(atoi(val));
|
||||||
|
} else if (!strcasecmp(var, "video-jb-size-factor") && !zstr(val)) {
|
||||||
|
switch_core_set_variable("video_jb_size_factor", val);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -89,6 +89,9 @@ static const switch_payload_t INVALID_PT = 255;
|
||||||
* characters when sending, but an implementation MUST accept up to 256
|
* characters when sending, but an implementation MUST accept up to 256
|
||||||
* characters when receiving." */
|
* characters when receiving." */
|
||||||
|
|
||||||
|
#define MAX_VIDEO_BUFFER_SIZE_FACTOR 100
|
||||||
|
#define MIN_VIDEO_BUFFER_SIZE_FACTOR 10
|
||||||
|
|
||||||
static switch_port_t START_PORT = RTP_START_PORT;
|
static switch_port_t START_PORT = RTP_START_PORT;
|
||||||
static switch_port_t END_PORT = RTP_END_PORT;
|
static switch_port_t END_PORT = RTP_END_PORT;
|
||||||
static switch_mutex_t *port_lock = NULL;
|
static switch_mutex_t *port_lock = NULL;
|
||||||
|
@ -4761,6 +4764,13 @@ SWITCH_DECLARE(switch_status_t) switch_rtp_get_video_buffer_size(switch_rtp_t *r
|
||||||
|
|
||||||
SWITCH_DECLARE(switch_status_t) switch_rtp_set_video_buffer_size(switch_rtp_t *rtp_session, uint32_t frames, uint32_t max_frames)
|
SWITCH_DECLARE(switch_status_t) switch_rtp_set_video_buffer_size(switch_rtp_t *rtp_session, uint32_t frames, uint32_t max_frames)
|
||||||
{
|
{
|
||||||
|
char *tmp;
|
||||||
|
int vb_size_factor = 0;
|
||||||
|
|
||||||
|
if ((tmp = switch_core_get_variable("video_jb_size_factor"))) {
|
||||||
|
vb_size_factor = atoi(tmp);
|
||||||
|
}
|
||||||
|
|
||||||
if (!switch_rtp_ready(rtp_session)) {
|
if (!switch_rtp_ready(rtp_session)) {
|
||||||
return SWITCH_STATUS_FALSE;
|
return SWITCH_STATUS_FALSE;
|
||||||
}
|
}
|
||||||
|
@ -4770,7 +4780,13 @@ SWITCH_DECLARE(switch_status_t) switch_rtp_set_video_buffer_size(switch_rtp_t *r
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!max_frames || frames >= max_frames) {
|
if (!max_frames || frames >= max_frames) {
|
||||||
max_frames = frames * 10;
|
if (vb_size_factor && vb_size_factor < MAX_VIDEO_BUFFER_SIZE_FACTOR + 1 && vb_size_factor > MIN_VIDEO_BUFFER_SIZE_FACTOR) {
|
||||||
|
max_frames = frames * vb_size_factor;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
max_frames = frames * MIN_VIDEO_BUFFER_SIZE_FACTOR;
|
||||||
|
}
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(rtp_session->session), SWITCH_LOG_DEBUG, "Set video buffer to %d\n", max_frames);
|
||||||
}
|
}
|
||||||
|
|
||||||
rtp_session->last_max_vb_frames = max_frames;
|
rtp_session->last_max_vb_frames = max_frames;
|
||||||
|
|
Loading…
Reference in New Issue