[FFmpeg-devel] [PATCH] Speex parser
Måns Rullgård
mans
Mon Sep 21 04:07:59 CEST 2009
Michael Niedermayer <michaelni at gmx.at> writes:
> On Mon, Sep 21, 2009 at 12:23:45AM +0100, M?ns Rullg?rd wrote:
>> Michael Niedermayer <michaelni at gmx.at> writes:
>>
>> > On Sun, Sep 20, 2009 at 10:05:36PM +0100, M?ns Rullg?rd wrote:
>> >> "Ronald S. Bultje" <rsbultje at gmail.com> writes:
>> >>
>> >> > Hi,
>> >> >
>> >> > 2009/9/20 M?ns Rullg?rd <mans at mansr.com>:
>> >> >> What I would like is a raw demuxer returning exactly what is in the
>> >> >> file, no decoding, no parsing. ?This can be done separately if
>> >> >> needed.
>> >> >
>> >> > Isn't that av_read_packet() (instead of av_read_frame())?
>> >>
>> >> Sort of, except that av_read_packet() doesn't actually work. During
>> >> file opening, some packets are read, analysed, and placed in a queue.
>> >> This queue is bypassed by av_read_packet() so you miss the first few
>> >> packets of the file.
>> >>
>> >> It is possible to open a file without having it analysed, but then yet
>> >> other things stop working, e.g. the list of streams might not be
>> >> populated for an mpeg-ps file.
>> >
>> > iam trying to implement what you want but iam hitting a wall here
>> > there really are so many things filled in and you clearly do want many
>> > to be kept. I cant read your mind, please say clearly which values you
>> > want not to be filled in by lavf?
>>
>> I don't need this urgently or anything, so don't spend your time on
>> this unless you really want to.
>
> it should be easy to implement, if i run into some problems ill
> put it aside and maybe post a patch for others to finish ...
>
>> I'm sure there are more pressing
>> things in need of attention (such as my patches ;-).
>>
>> > please correct below:
>> > pts/dts: no
>> > frame boundaries: no
>> > start_time: ?
>> > file duration: ?
>> > packet duration: (pretty much meaningless without parsers)
>> > stream array: yes
>
>> > extradata: (unreliable without parsers)
>>
>> Why is that? If a file header contains extradata, it should be
>> returned, otherwise not. The ogg abomination is of course a special
>> case.
>
> its because its convenient ...
> some formats (mpeg4, aac, ...) can have their global headers in stream or
> in a seperate field in the container
> if now the parser extracts that stuff from in stream in av_find_stream_info()
> that has several advantages
> 1. the decoder only has to look at extradata
> 2. when doing stream copy the global headers will always be in extradata, a
> muxer can store them or ignore them as it sees fit
> 3. when a file is cut and the global headers occur later, av_find_stream_info()
> will look ahead until these headers and put them in extradata. The
> application will then have them available for the first frame even if they
> are stored after the first frame
>
>>
>> > fps: (unreliable without parsers)
>> > values that need decoding: (unreliable without parsers)
>>
>> I want whatever fields are provided by global headers. If fps is
>> provided, return it unchecked, otherwise leave undefined. Any
>> decoding/parsing required to determine missing values I can do myself.
>
> but what is with the stream array then? av_find_stream_info() does look
> ahead and its the demuxers itself that fill it based on packets found
> for new streams not a global header.
For the few formats (I can only think of MPEG-PS) that don't have any
kind of header mandated, the something will of course have to look
ahead to populate the stream array.
> And indeed the global header is in some cases (flv for example) not
> reliable.
> Basically, to me it seems everything that av_find_stream_info() does
> would fall under the "dont do it" category, if there really is a
> global header that lists all streams the demuxer should already have
> used that to create streams when read_header() was called.
Some formats list all streams in a global header, but this header
might not contain all stream parameters, only enough to allow later
stages to do the right thing, e.g. select the correct decoder.
>> I'm mentioning these things because, although I'm not working on
>> anything lavf-based at the moment, whenever I do, I often find these
>> raw access functions lacking. I know others who use lavf share this
>> experience.
>
> maybe somehow keeping track of what is straight from the container and
> what is inferred from other values would be a good idea, but i dont know
> how to do that cleanly and efficiently, a struct of int64_t and a enum
> would of course do but it seems a little ugly ...
I don't see the point in that. What I'm looking for is a way to avoid
the overhead of all the extra processing in lavf when it's not needed.
>> Another thing I didn't mention earlier: it seems that packets returned
>> by av_read_frame() must be consumed by application before calling it
>> again. In other words, it is impossible to buffer frames for later
>> decoding without copying the data out of the AVPacket.
>
> did you try av_dup_packet() ?
That function looks like it makes a copy of the packet, which is
exactly what I wanted to avoid.
--
M?ns Rullg?rd
mans at mansr.com
More information about the ffmpeg-devel
mailing list