diff options
author | Martin Storsjö <martin@martin.st> | 2013-01-17 15:29:12 +0200 |
---|---|---|
committer | Martin Storsjö <martin@martin.st> | 2013-01-20 18:20:42 +0200 |
commit | c6f1dc8e4cd967ae056698eafb891a08003c211c (patch) | |
tree | e2793b6089cc2908f7d52803af23e8d1aa15fdea /libavformat/rtpdec_mpeg12.c | |
parent | a9c847c1baff09f954b12c1dcc832b4f601f6f6e (diff) | |
download | ffmpeg-c6f1dc8e4cd967ae056698eafb891a08003c211c.tar.gz |
rtpdec: Move setting the parsing flags to the actual depacketizers
This gets rid of almost all the codec specific details from the
generic rtpdec code.
Signed-off-by: Martin Storsjö <martin@martin.st>
Diffstat (limited to 'libavformat/rtpdec_mpeg12.c')
-rw-r--r-- | libavformat/rtpdec_mpeg12.c | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/libavformat/rtpdec_mpeg12.c b/libavformat/rtpdec_mpeg12.c index d111469364..4dd98fba35 100644 --- a/libavformat/rtpdec_mpeg12.c +++ b/libavformat/rtpdec_mpeg12.c @@ -22,6 +22,14 @@ #include "rtpdec_formats.h" #include "libavutil/intreadwrite.h" +static int mpeg_init(AVFormatContext *ctx, int st_index, PayloadContext *data) +{ + if (st_index < 0) + return 0; + ctx->streams[st_index]->need_parsing = AVSTREAM_PARSE_FULL; + return 0; +} + static int mpeg_parse_packet(AVFormatContext *ctx, PayloadContext *data, AVStream *st, AVPacket *pkt, uint32_t *timestamp, const uint8_t *buf, int len, uint16_t seq, @@ -50,6 +58,7 @@ static int mpeg_parse_packet(AVFormatContext *ctx, PayloadContext *data, RTPDynamicProtocolHandler ff_mpeg_audio_dynamic_handler = { .codec_type = AVMEDIA_TYPE_AUDIO, .codec_id = AV_CODEC_ID_MP3, + .init = mpeg_init, .parse_packet = mpeg_parse_packet, .static_payload_id = 14, }; @@ -57,6 +66,7 @@ RTPDynamicProtocolHandler ff_mpeg_audio_dynamic_handler = { RTPDynamicProtocolHandler ff_mpeg_video_dynamic_handler = { .codec_type = AVMEDIA_TYPE_VIDEO, .codec_id = AV_CODEC_ID_MPEG2VIDEO, + .init = mpeg_init, .parse_packet = mpeg_parse_packet, .static_payload_id = 32, }; |