[FFmpeg-devel] [PATCH 4/8] lavf/tcp: add tcp_accept
Stephan Holljes
klaxa1337 at googlemail.com
Tue Jul 21 05:58:24 CEST 2015
On Tue, Jul 21, 2015 at 5:45 AM, Stephan Holljes
<klaxa1337 at googlemail.com> wrote:
> Signed-off-by: Stephan Holljes <klaxa1337 at googlemail.com>
> ---
> libavformat/tcp.c | 18 ++++++++++++++++++
> 1 file changed, 18 insertions(+)
>
> diff --git a/libavformat/tcp.c b/libavformat/tcp.c
> index f24cad2..6f5e175 100644
> --- a/libavformat/tcp.c
> +++ b/libavformat/tcp.c
> @@ -19,6 +19,7 @@
> * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
> */
> #include "avformat.h"
> +#include "libavutil/avassert.h"
> #include "libavutil/parseutils.h"
> #include "libavutil/opt.h"
> #include "libavutil/time.h"
> @@ -163,6 +164,22 @@ static int tcp_open(URLContext *h, const char *uri, int flags)
> return ret;
> }
>
> +static int tcp_accept(URLContext *s, URLContext **c)
> +{
> + TCPContext *sc = s->priv_data;
> + TCPContext *cc;
> + int ret;
> + av_assert0(sc->listen);
> + if ((ret = ffurl_alloc(c, s->filename, s->flags & AVIO_FLAG_READ_WRITE, &s->interrupt_callback)) < 0)
> + return ret;
> + cc = (*c)->priv_data;
> + ret = ff_accept(sc->fd, sc->listen_timeout, s);
> + if (ret < 0)
> + return ff_neterrno();
> + cc->fd = ret;
> + return 0;
> +}
> +
> static int tcp_read(URLContext *h, uint8_t *buf, int size)
> {
> TCPContext *s = h->priv_data;
> @@ -223,6 +240,7 @@ static int tcp_get_file_handle(URLContext *h)
> URLProtocol ff_tcp_protocol = {
> .name = "tcp",
> .url_open = tcp_open,
> + .url_accept = tcp_accept,
> .url_read = tcp_read,
> .url_write = tcp_write,
> .url_close = tcp_close,
> --
> 2.1.0
>
I forgot to filter the correct flags. Attached patch is identical, but
uses "s->flags & (AVIO_FLAG_READ_WRITE | AVIO_FLAG_DIRECT)" in
ffurl_alloc()
-------------- next part --------------
A non-text attachment was scrubbed...
Name: 0006-lavf-tcp-add-tcp_accept.patch
Type: text/x-patch
Size: 3538 bytes
Desc: not available
URL: <http://ffmpeg.org/pipermail/ffmpeg-devel/attachments/20150721/31ca77e8/attachment.bin>
More information about the ffmpeg-devel
mailing list