You've already forked FFmpeg
mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-08-15 14:13:16 +02:00
set pts in flv demuxer
Originally committed as revision 15841 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
@@ -26,6 +26,10 @@
|
|||||||
#include "avformat.h"
|
#include "avformat.h"
|
||||||
#include "flv.h"
|
#include "flv.h"
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
int wrong_dts; ///< wrong dts due to negative cts
|
||||||
|
} FLVContext;
|
||||||
|
|
||||||
static int flv_probe(AVProbeData *p)
|
static int flv_probe(AVProbeData *p)
|
||||||
{
|
{
|
||||||
const uint8_t *d;
|
const uint8_t *d;
|
||||||
@@ -299,9 +303,10 @@ static int flv_get_extradata(AVFormatContext *s, AVStream *st, int size)
|
|||||||
|
|
||||||
static int flv_read_packet(AVFormatContext *s, AVPacket *pkt)
|
static int flv_read_packet(AVFormatContext *s, AVPacket *pkt)
|
||||||
{
|
{
|
||||||
|
FLVContext *flv = s->priv_data;
|
||||||
int ret, i, type, size, flags, is_audio;
|
int ret, i, type, size, flags, is_audio;
|
||||||
int64_t next, pos;
|
int64_t next, pos;
|
||||||
unsigned dts;
|
int64_t dts, pts = AV_NOPTS_VALUE;
|
||||||
AVStream *st = NULL;
|
AVStream *st = NULL;
|
||||||
|
|
||||||
retry:
|
retry:
|
||||||
@@ -401,9 +406,14 @@ static int flv_read_packet(AVFormatContext *s, AVPacket *pkt)
|
|||||||
int type = get_byte(s->pb);
|
int type = get_byte(s->pb);
|
||||||
size--;
|
size--;
|
||||||
if (st->codec->codec_id == CODEC_ID_H264) {
|
if (st->codec->codec_id == CODEC_ID_H264) {
|
||||||
// cts offset ignored because it might to be signed
|
int32_t cts = (get_be24(s->pb)+0xff800000)^0xff800000; // sign extension
|
||||||
// and would cause pts < dts
|
pts = dts + cts;
|
||||||
get_be24(s->pb);
|
if (cts < 0) { // dts are wrong
|
||||||
|
flv->wrong_dts = 1;
|
||||||
|
av_log(s, AV_LOG_WARNING, "negative cts, previous timestamps might be wrong\n");
|
||||||
|
}
|
||||||
|
if (flv->wrong_dts)
|
||||||
|
dts = AV_NOPTS_VALUE;
|
||||||
}
|
}
|
||||||
if (type == 0) {
|
if (type == 0) {
|
||||||
if ((ret = flv_get_extradata(s, st, size)) < 0)
|
if ((ret = flv_get_extradata(s, st, size)) < 0)
|
||||||
@@ -420,6 +430,7 @@ static int flv_read_packet(AVFormatContext *s, AVPacket *pkt)
|
|||||||
packet */
|
packet */
|
||||||
pkt->size = ret;
|
pkt->size = ret;
|
||||||
pkt->dts = dts;
|
pkt->dts = dts;
|
||||||
|
pkt->pts = pts == AV_NOPTS_VALUE ? dts : pts;
|
||||||
pkt->stream_index = st->index;
|
pkt->stream_index = st->index;
|
||||||
|
|
||||||
if (is_audio || ((flags & FLV_VIDEO_FRAMETYPE_MASK) == FLV_FRAME_KEY))
|
if (is_audio || ((flags & FLV_VIDEO_FRAMETYPE_MASK) == FLV_FRAME_KEY))
|
||||||
@@ -431,7 +442,7 @@ static int flv_read_packet(AVFormatContext *s, AVPacket *pkt)
|
|||||||
AVInputFormat flv_demuxer = {
|
AVInputFormat flv_demuxer = {
|
||||||
"flv",
|
"flv",
|
||||||
NULL_IF_CONFIG_SMALL("FLV format"),
|
NULL_IF_CONFIG_SMALL("FLV format"),
|
||||||
0,
|
sizeof(FLVContext),
|
||||||
flv_probe,
|
flv_probe,
|
||||||
flv_read_header,
|
flv_read_header,
|
||||||
flv_read_packet,
|
flv_read_packet,
|
||||||
|
Reference in New Issue
Block a user