FFmpeg
rtpenc_chain.c
Go to the documentation of this file.
1 /*
2  * RTP muxer chaining code
3  * Copyright (c) 2010 Martin Storsjo
4  *
5  * This file is part of FFmpeg.
6  *
7  * FFmpeg is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Lesser General Public
9  * License as published by the Free Software Foundation; either
10  * version 2.1 of the License, or (at your option) any later version.
11  *
12  * FFmpeg is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15  * Lesser General Public License for more details.
16  *
17  * You should have received a copy of the GNU Lesser General Public
18  * License along with FFmpeg; if not, write to the Free Software
19  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20  */
21 
22 #include "avformat.h"
23 #include "avio_internal.h"
24 #include "rtpenc_chain.h"
25 #include "rtp.h"
26 #include "url.h"
27 #include "libavutil/opt.h"
28 
30  AVStream *st, URLContext *handle, int packet_size,
31  int idx)
32 {
33  AVFormatContext *rtpctx = NULL;
34  int ret;
35  const AVOutputFormat *rtp_format = av_guess_format("rtp", NULL, NULL);
36  uint8_t *rtpflags;
38 
39  if (!rtp_format) {
40  ret = AVERROR(ENOSYS);
41  goto fail;
42  }
43 
44  /* Allocate an AVFormatContext for each output stream */
45  rtpctx = avformat_alloc_context();
46  if (!rtpctx) {
47  ret = AVERROR(ENOMEM);
48  goto fail;
49  }
50 
51  rtpctx->oformat = rtp_format;
52  if (!avformat_new_stream(rtpctx, NULL)) {
53  ret = AVERROR(ENOMEM);
54  goto fail;
55  }
56  /* Pass the interrupt callback on */
57  rtpctx->interrupt_callback = s->interrupt_callback;
58  /* Copy the max delay setting; the rtp muxer reads this. */
59  rtpctx->max_delay = s->max_delay;
60  /* Copy other stream parameters. */
62  rtpctx->flags |= s->flags & AVFMT_FLAG_BITEXACT;
63  rtpctx->strict_std_compliance = s->strict_std_compliance;
64 
65  /* Get the payload type from the codec */
66  if (st->id < RTP_PT_PRIVATE)
67  rtpctx->streams[0]->id =
69  else
70  rtpctx->streams[0]->id = st->id;
71 
72 
73  if (av_opt_get(s, "rtpflags", AV_OPT_SEARCH_CHILDREN, &rtpflags) >= 0)
74  av_dict_set(&opts, "rtpflags", rtpflags, AV_DICT_DONT_STRDUP_VAL);
75 
76  /* Set the synchronized start time. */
77  rtpctx->start_time_realtime = s->start_time_realtime;
78 
80  rtpctx->streams[0]->time_base = st->time_base;
81 
82  if (handle) {
83  ret = ffio_fdopen(&rtpctx->pb, handle);
84  if (ret < 0)
85  ffurl_close(handle);
86  } else
87  ret = ffio_open_dyn_packet_buf(&rtpctx->pb, packet_size);
88  if (!ret)
89  ret = avformat_write_header(rtpctx, &opts);
91 
92  if (ret) {
93  if (handle && rtpctx->pb) {
94  avio_closep(&rtpctx->pb);
95  } else if (rtpctx->pb) {
96  ffio_free_dyn_buf(&rtpctx->pb);
97  }
98  avformat_free_context(rtpctx);
99  return ret;
100  }
101 
102  *out = rtpctx;
103  return 0;
104 
105 fail:
106  avformat_free_context(rtpctx);
107  if (handle)
108  ffurl_close(handle);
109  return ret;
110 }
AVERROR
Filter the word “frame” indicates either a video frame or a group of audio as stored in an AVFrame structure Format for each input and each output the list of supported formats For video that means pixel format For audio that means channel sample they are references to shared objects When the negotiation mechanism computes the intersection of the formats supported at each end of a all references to both lists are replaced with a reference to the intersection And when a single format is eventually chosen for a link amongst the remaining all references to the list are updated That means that if a filter requires that its input and output have the same format amongst a supported all it has to do is use a reference to the same list of formats query_formats can leave some formats unset and return AVERROR(EAGAIN) to cause the negotiation mechanism toagain later. That can be used by filters with complex requirements to use the format negotiated on one link to set the formats supported on another. Frame references ownership and permissions
opt.h
out
FILE * out
Definition: movenc.c:54
avformat_new_stream
AVStream * avformat_new_stream(AVFormatContext *s, const struct AVCodec *c)
Add a new stream to a media file.
AVFormatContext::streams
AVStream ** streams
A list of all streams in the file.
Definition: avformat.h:1183
AVFormatContext::strict_std_compliance
int strict_std_compliance
Allow non-standard and experimental extension.
Definition: avformat.h:1411
ffurl_close
int ffurl_close(URLContext *h)
Definition: avio.c:462
AVDictionary
Definition: dict.c:34
ffio_fdopen
int ffio_fdopen(AVIOContext **s, struct URLContext *h)
Create and initialize a AVIOContext for accessing the resource referenced by the URLContext h.
Definition: aviobuf.c:974
AVFormatContext::interrupt_callback
AVIOInterruptCB interrupt_callback
Custom interrupt callbacks for the I/O layer.
Definition: avformat.h:1381
RTPMuxContext::st
AVStream * st
Definition: rtpenc.h:30
fail
#define fail()
Definition: checkasm.h:138
rtpenc_chain.h
AV_DICT_DONT_STRDUP_VAL
#define AV_DICT_DONT_STRDUP_VAL
Take ownership of a value that's been allocated with av_malloc() or another memory allocation functio...
Definition: dict.h:79
s
#define s(width, name)
Definition: cbs_vp9.c:198
AVFormatContext::flags
int flags
Flags modifying the (de)muxer behaviour.
Definition: avformat.h:1233
avformat_write_header
av_warn_unused_result int avformat_write_header(AVFormatContext *s, AVDictionary **options)
Allocate the stream private data and write the stream header to an output media file.
Definition: mux.c:477
AVFormatContext
Format I/O context.
Definition: avformat.h:1115
opts
AVDictionary * opts
Definition: movenc.c:50
AVStream::codecpar
AVCodecParameters * codecpar
Codec parameters associated with this stream.
Definition: avformat.h:864
RTP_PT_PRIVATE
#define RTP_PT_PRIVATE
Definition: rtp.h:79
AVStream::time_base
AVRational time_base
This is the fundamental unit of time (in seconds) in terms of which frame timestamps are represented.
Definition: avformat.h:880
NULL
#define NULL
Definition: coverity.c:32
AVFormatContext::pb
AVIOContext * pb
I/O context.
Definition: avformat.h:1157
avformat_alloc_context
AVFormatContext * avformat_alloc_context(void)
Allocate an AVFormatContext.
Definition: options.c:166
AVStream::sample_aspect_ratio
AVRational sample_aspect_ratio
sample aspect ratio (0 if unknown)
Definition: avformat.h:919
AV_OPT_SEARCH_CHILDREN
#define AV_OPT_SEARCH_CHILDREN
Search in possible children of the given object first.
Definition: opt.h:563
ffio_open_dyn_packet_buf
int ffio_open_dyn_packet_buf(AVIOContext **s, int max_packet_size)
Open a write only packetized memory stream with a maximum packet size of 'max_packet_size'.
Definition: aviobuf.c:1512
av_dict_free
void av_dict_free(AVDictionary **pm)
Free all the memory allocated for an AVDictionary struct and all keys and values.
Definition: dict.c:225
rtp.h
avio_closep
int avio_closep(AVIOContext **s)
Close the resource accessed by the AVIOContext *s, free it and set the pointer pointing to it to NULL...
Definition: aviobuf.c:1304
URLContext
Definition: url.h:37
AVOutputFormat
Definition: avformat.h:510
avio_internal.h
url.h
AVFormatContext::max_delay
int max_delay
Definition: avformat.h:1227
ffio_free_dyn_buf
void ffio_free_dyn_buf(AVIOContext **s)
Free a dynamic buffer.
Definition: aviobuf.c:1580
AVStream::id
int id
Format-specific stream ID.
Definition: avformat.h:853
AVFMT_FLAG_BITEXACT
#define AVFMT_FLAG_BITEXACT
When muxing, try to avoid writing any random/volatile data to the output.
Definition: avformat.h:1250
ret
ret
Definition: filter_design.txt:187
AVStream
Stream structure.
Definition: avformat.h:841
AVFormatContext::oformat
const struct AVOutputFormat * oformat
The output container format.
Definition: avformat.h:1134
avformat.h
ff_rtp_chain_mux_open
int ff_rtp_chain_mux_open(AVFormatContext **out, AVFormatContext *s, AVStream *st, URLContext *handle, int packet_size, int idx)
Definition: rtpenc_chain.c:29
avformat_free_context
void avformat_free_context(AVFormatContext *s)
Free an AVFormatContext and all its streams.
Definition: avformat.c:102
av_guess_format
const AVOutputFormat * av_guess_format(const char *short_name, const char *filename, const char *mime_type)
Return the output format in the list of registered output formats which best matches the provided par...
Definition: format.c:79
AVFormatContext::start_time_realtime
int64_t start_time_realtime
Start time of the stream in real world time, in microseconds since the Unix epoch (00:00 1st January ...
Definition: avformat.h:1356
av_dict_set
int av_dict_set(AVDictionary **pm, const char *key, const char *value, int flags)
Set the given entry in *pm, overwriting an existing entry.
Definition: dict.c:88
av_opt_get
int av_opt_get(void *obj, const char *name, int search_flags, uint8_t **out_val)
Definition: opt.c:837
ff_rtp_get_payload_type
int ff_rtp_get_payload_type(const AVFormatContext *fmt, const AVCodecParameters *par, int idx)
Return the payload type for a given stream used in the given format context.
Definition: rtp.c:93
avcodec_parameters_copy
int avcodec_parameters_copy(AVCodecParameters *dst, const AVCodecParameters *src)
Copy the contents of src to dst.
Definition: codec_par.c:106