mirror of https://git.ffmpeg.org/ffmpeg.git
Merge branch 'flac' of https://github.com/FernetMenta/FFmpeg
Merged-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
commit
3df787a1ef
|
@ -489,6 +489,14 @@ static int get_best_header(FLACParseContext* fpc, const uint8_t **poutbuf,
|
||||||
&fpc->wrap_buf,
|
&fpc->wrap_buf,
|
||||||
&fpc->wrap_buf_allocated_size);
|
&fpc->wrap_buf_allocated_size);
|
||||||
|
|
||||||
|
|
||||||
|
if (fpc->pc->flags & PARSER_FLAG_USE_CODEC_TS){
|
||||||
|
if (header->fi.is_var_size)
|
||||||
|
fpc->pc->pts = header->fi.frame_or_sample_num;
|
||||||
|
else if (header->best_child)
|
||||||
|
fpc->pc->pts = header->fi.frame_or_sample_num * header->fi.blocksize;
|
||||||
|
}
|
||||||
|
|
||||||
fpc->best_header_valid = 0;
|
fpc->best_header_valid = 0;
|
||||||
fpc->last_fi_valid = 1;
|
fpc->last_fi_valid = 1;
|
||||||
fpc->last_fi = header->fi;
|
fpc->last_fi = header->fi;
|
||||||
|
@ -516,6 +524,11 @@ static int flac_parse(AVCodecParserContext *s, AVCodecContext *avctx,
|
||||||
s->duration = fi.blocksize;
|
s->duration = fi.blocksize;
|
||||||
if (!avctx->sample_rate)
|
if (!avctx->sample_rate)
|
||||||
avctx->sample_rate = fi.samplerate;
|
avctx->sample_rate = fi.samplerate;
|
||||||
|
if (fpc->pc->flags & PARSER_FLAG_USE_CODEC_TS){
|
||||||
|
fpc->pc->pts = fi.frame_or_sample_num;
|
||||||
|
if (!fi.is_var_size)
|
||||||
|
fpc->pc->pts *= fi.blocksize;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
*poutbuf = buf;
|
*poutbuf = buf;
|
||||||
*poutbuf_size = buf_size;
|
*poutbuf_size = buf_size;
|
||||||
|
|
|
@ -162,12 +162,57 @@ static int flac_probe(AVProbeData *p)
|
||||||
return AVPROBE_SCORE_EXTENSION;
|
return AVPROBE_SCORE_EXTENSION;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static av_unused int64_t flac_read_timestamp(AVFormatContext *s, int stream_index,
|
||||||
|
int64_t *ppos, int64_t pos_limit)
|
||||||
|
{
|
||||||
|
AVPacket pkt, out_pkt;
|
||||||
|
AVStream *st = s->streams[stream_index];
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
if (avio_seek(s->pb, *ppos, SEEK_SET) < 0)
|
||||||
|
return AV_NOPTS_VALUE;
|
||||||
|
|
||||||
|
av_init_packet(&pkt);
|
||||||
|
st->parser = av_parser_init(st->codec->codec_id);
|
||||||
|
if (!st->parser){
|
||||||
|
return AV_NOPTS_VALUE;
|
||||||
|
}
|
||||||
|
st->parser->flags |= PARSER_FLAG_USE_CODEC_TS;
|
||||||
|
|
||||||
|
for (;;){
|
||||||
|
ret = ff_raw_read_partial_packet(s, &pkt);
|
||||||
|
if (ret < 0){
|
||||||
|
if (ret == AVERROR(EAGAIN))
|
||||||
|
continue;
|
||||||
|
else
|
||||||
|
return AV_NOPTS_VALUE;
|
||||||
|
}
|
||||||
|
av_init_packet(&out_pkt);
|
||||||
|
ret = av_parser_parse2(st->parser, st->codec,
|
||||||
|
&out_pkt.data, &out_pkt.size, pkt.data, pkt.size,
|
||||||
|
pkt.pts, pkt.dts, *ppos);
|
||||||
|
|
||||||
|
if (out_pkt.size){
|
||||||
|
int size = out_pkt.size;
|
||||||
|
av_free_packet(&out_pkt);
|
||||||
|
if (st->parser->pts != AV_NOPTS_VALUE){
|
||||||
|
// seeking may not have started from beginning of a frame
|
||||||
|
// calculate frame start position from next frame backwards
|
||||||
|
*ppos = st->parser->next_frame_offset - size;
|
||||||
|
return st->parser->pts;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return AV_NOPTS_VALUE;
|
||||||
|
}
|
||||||
|
|
||||||
AVInputFormat ff_flac_demuxer = {
|
AVInputFormat ff_flac_demuxer = {
|
||||||
.name = "flac",
|
.name = "flac",
|
||||||
.long_name = NULL_IF_CONFIG_SMALL("raw FLAC"),
|
.long_name = NULL_IF_CONFIG_SMALL("raw FLAC"),
|
||||||
.read_probe = flac_probe,
|
.read_probe = flac_probe,
|
||||||
.read_header = flac_read_header,
|
.read_header = flac_read_header,
|
||||||
.read_packet = ff_raw_read_partial_packet,
|
.read_packet = ff_raw_read_partial_packet,
|
||||||
|
.read_timestamp = flac_read_timestamp,
|
||||||
.flags = AVFMT_GENERIC_INDEX,
|
.flags = AVFMT_GENERIC_INDEX,
|
||||||
.extensions = "flac",
|
.extensions = "flac",
|
||||||
.raw_codec_id = AV_CODEC_ID_FLAC,
|
.raw_codec_id = AV_CODEC_ID_FLAC,
|
||||||
|
|
|
@ -5,14 +5,16 @@ ret: 0 st:-1 flags:1 ts: 1.894167
|
||||||
ret: 0 st: 0 flags:1 dts: 1.880816 pts: 1.880816 pos: 86742 size: 2191
|
ret: 0 st: 0 flags:1 dts: 1.880816 pts: 1.880816 pos: 86742 size: 2191
|
||||||
ret: 0 st: 0 flags:0 ts: 0.788345
|
ret: 0 st: 0 flags:0 ts: 0.788345
|
||||||
ret: 0 st: 0 flags:1 dts: 0.809796 pts: 0.809796 pos: 27366 size: 615
|
ret: 0 st: 0 flags:1 dts: 0.809796 pts: 0.809796 pos: 27366 size: 615
|
||||||
ret:-1 st: 0 flags:1 ts:-0.317506
|
ret: 0 st: 0 flags:1 ts:-0.317506
|
||||||
|
ret: 0 st: 0 flags:1 dts: 0.000000 pts: 0.000000 pos: 8256 size: 614
|
||||||
ret: 0 st:-1 flags:0 ts: 2.576668
|
ret: 0 st:-1 flags:0 ts: 2.576668
|
||||||
ret: 0 st: 0 flags:1 dts: 2.586122 pts: 2.586122 pos: 145606 size: 2384
|
ret: 0 st: 0 flags:1 dts: 2.586122 pts: 2.586122 pos: 145606 size: 2384
|
||||||
ret: 0 st:-1 flags:1 ts: 1.470835
|
ret: 0 st:-1 flags:1 ts: 1.470835
|
||||||
ret: 0 st: 0 flags:1 dts: 1.462857 pts: 1.462857 pos: 53388 size: 1851
|
ret: 0 st: 0 flags:1 dts: 1.462857 pts: 1.462857 pos: 53388 size: 1851
|
||||||
ret: 0 st: 0 flags:0 ts: 0.365011
|
ret: 0 st: 0 flags:0 ts: 0.365011
|
||||||
ret: 0 st: 0 flags:1 dts: 0.365714 pts: 0.365714 pos: 16890 size: 614
|
ret: 0 st: 0 flags:1 dts: 0.365714 pts: 0.365714 pos: 16890 size: 614
|
||||||
ret:-1 st: 0 flags:1 ts:-0.740839
|
ret: 0 st: 0 flags:1 ts:-0.740839
|
||||||
|
ret: 0 st: 0 flags:1 dts: 0.000000 pts: 0.000000 pos: 8256 size: 614
|
||||||
ret: 0 st:-1 flags:0 ts: 2.153336
|
ret: 0 st:-1 flags:0 ts: 2.153336
|
||||||
ret: 0 st: 0 flags:1 dts: 2.168163 pts: 2.168163 pos: 110531 size: 2143
|
ret: 0 st: 0 flags:1 dts: 2.168163 pts: 2.168163 pos: 110531 size: 2143
|
||||||
ret: 0 st:-1 flags:1 ts: 1.047503
|
ret: 0 st:-1 flags:1 ts: 1.047503
|
||||||
|
@ -39,11 +41,13 @@ ret: 0 st: 0 flags:1 ts: 1.989184
|
||||||
ret: 0 st: 0 flags:1 dts: 1.985306 pts: 1.985306 pos: 95508 size: 2169
|
ret: 0 st: 0 flags:1 dts: 1.985306 pts: 1.985306 pos: 95508 size: 2169
|
||||||
ret: 0 st:-1 flags:0 ts: 0.883340
|
ret: 0 st:-1 flags:0 ts: 0.883340
|
||||||
ret: 0 st: 0 flags:1 dts: 0.888163 pts: 0.888163 pos: 29211 size: 620
|
ret: 0 st: 0 flags:1 dts: 0.888163 pts: 0.888163 pos: 29211 size: 620
|
||||||
ret:-1 st:-1 flags:1 ts:-0.222493
|
ret: 0 st:-1 flags:1 ts:-0.222493
|
||||||
|
ret: 0 st: 0 flags:1 dts: 0.000000 pts: 0.000000 pos: 8256 size: 614
|
||||||
ret: 0 st: 0 flags:0 ts: 2.671678
|
ret: 0 st: 0 flags:0 ts: 2.671678
|
||||||
ret: 0 st: 0 flags:1 dts: 2.690612 pts: 2.690612 pos: 155154 size: 2394
|
ret: 0 st: 0 flags:1 dts: 2.690612 pts: 2.690612 pos: 155154 size: 2394
|
||||||
ret: 0 st: 0 flags:1 ts: 1.565850
|
ret: 0 st: 0 flags:1 ts: 1.565850
|
||||||
ret: 0 st: 0 flags:1 dts: 1.541224 pts: 1.541224 pos: 59082 size: 1974
|
ret: 0 st: 0 flags:1 dts: 1.541224 pts: 1.541224 pos: 59082 size: 1974
|
||||||
ret: 0 st:-1 flags:0 ts: 0.460008
|
ret: 0 st:-1 flags:0 ts: 0.460008
|
||||||
ret: 0 st: 0 flags:1 dts: 0.470204 pts: 0.470204 pos: 19353 size: 608
|
ret: 0 st: 0 flags:1 dts: 0.470204 pts: 0.470204 pos: 19353 size: 608
|
||||||
ret:-1 st:-1 flags:1 ts:-0.645825
|
ret: 0 st:-1 flags:1 ts:-0.645825
|
||||||
|
ret: 0 st: 0 flags:1 dts: 0.000000 pts: 0.000000 pos: 8256 size: 614
|
||||||
|
|
Loading…
Reference in New Issue