Commit b6112c2c authored by andoma's avatar andoma

Allow the UDP socket buffer size to be adjusted using a

'buffer_size' URL option. 

Patch by Jindrich Makovicka, makovick at gmail dot com



git-svn-id: file:///var/local/repositories/ffmpeg/trunk@15807 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 321cbac8
...@@ -44,6 +44,7 @@ ...@@ -44,6 +44,7 @@
typedef struct { typedef struct {
int udp_fd; int udp_fd;
int ttl; int ttl;
int buffer_size;
int is_multicast; int is_multicast;
int local_port; int local_port;
int reuse_socket; int reuse_socket;
...@@ -358,6 +359,8 @@ static int udp_open(URLContext *h, const char *uri, int flags) ...@@ -358,6 +359,8 @@ static int udp_open(URLContext *h, const char *uri, int flags)
h->priv_data = s; h->priv_data = s;
s->ttl = 16; s->ttl = 16;
s->buffer_size = is_output ? UDP_TX_BUF_SIZE : UDP_MAX_PKT_SIZE;
p = strchr(uri, '?'); p = strchr(uri, '?');
if (p) { if (p) {
s->reuse_socket = find_info_tag(buf, sizeof(buf), "reuse", p); s->reuse_socket = find_info_tag(buf, sizeof(buf), "reuse", p);
...@@ -370,6 +373,9 @@ static int udp_open(URLContext *h, const char *uri, int flags) ...@@ -370,6 +373,9 @@ static int udp_open(URLContext *h, const char *uri, int flags)
if (find_info_tag(buf, sizeof(buf), "pkt_size", p)) { if (find_info_tag(buf, sizeof(buf), "pkt_size", p)) {
h->max_packet_size = strtol(buf, NULL, 10); h->max_packet_size = strtol(buf, NULL, 10);
} }
if (find_info_tag(buf, sizeof(buf), "buffer_size", p)) {
s->buffer_size = strtol(buf, NULL, 10);
}
} }
/* fill the dest addr */ /* fill the dest addr */
...@@ -416,7 +422,7 @@ static int udp_open(URLContext *h, const char *uri, int flags) ...@@ -416,7 +422,7 @@ static int udp_open(URLContext *h, const char *uri, int flags)
if (is_output) { if (is_output) {
/* limit the tx buf size to limit latency */ /* limit the tx buf size to limit latency */
tmp = UDP_TX_BUF_SIZE; tmp = s->buffer_size;
if (setsockopt(udp_fd, SOL_SOCKET, SO_SNDBUF, &tmp, sizeof(tmp)) < 0) { if (setsockopt(udp_fd, SOL_SOCKET, SO_SNDBUF, &tmp, sizeof(tmp)) < 0) {
av_log(NULL, AV_LOG_ERROR, "setsockopt(SO_SNDBUF): %s\n", strerror(errno)); av_log(NULL, AV_LOG_ERROR, "setsockopt(SO_SNDBUF): %s\n", strerror(errno));
goto fail; goto fail;
...@@ -424,8 +430,10 @@ static int udp_open(URLContext *h, const char *uri, int flags) ...@@ -424,8 +430,10 @@ static int udp_open(URLContext *h, const char *uri, int flags)
} else { } else {
/* set udp recv buffer size to the largest possible udp packet size to /* set udp recv buffer size to the largest possible udp packet size to
* avoid losing data on OSes that set this too low by default. */ * avoid losing data on OSes that set this too low by default. */
tmp = UDP_MAX_PKT_SIZE; tmp = s->buffer_size;
setsockopt(udp_fd, SOL_SOCKET, SO_RCVBUF, &tmp, sizeof(tmp)); if (setsockopt(udp_fd, SOL_SOCKET, SO_RCVBUF, &tmp, sizeof(tmp)) < 0) {
av_log(NULL, AV_LOG_WARNING, "setsockopt(SO_RECVBUF): %s\n", strerror(errno));
}
} }
s->udp_fd = udp_fd; s->udp_fd = udp_fd;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment