[FFmpeg-devel] [PATCH v10 2/2] avformat: add demuxer for Pro Pinball Series' Soundbanks

Zane van Iperen zane at zanevaniperen.com
Sun Apr 26 02:50:03 EEST 2020


On Sun, 26 Apr 2020 00:07:52 +0200
"Michael Niedermayer" <michael at niedermayer.cc> wrote:

> On Sat, Apr 25, 2020 at 01:10:53PM +0000, Zane van Iperen wrote:
> > On Sat, 25 Apr 2020 13:15:25 +0200
> > "Michael Niedermayer" <michael at niedermayer.cc> wrote:
> >  
> > > > +static int pp_bnk_probe(const AVProbeData *p)
> > > > +{
> > > > +    uint32_t sample_rate = AV_RL32(p->buf +  4);
> > > > +    uint32_t track_count = AV_RL32(p->buf + 12);
> > > > +    uint32_t flags       = AV_RL32(p->buf + 16);
> > > > +
> > > > +    if (track_count == 0 || sample_rate == 0)
> > > > +        return 0;  
> > >
> > > the header code checks these also for INT_MAX
> > >
> > >  
> >
> > See below I check both track_count and sample_rate for sane upper
> > limits. Is it worth adding an INT_MAX check too?  
> 
> why not ? its rejected by the header reading code
> 

Done.
> 
> >
> >
> >     /* These limits are based on analysing the game files. */
> >     if (track_count > 113)
> >         return 10;
> >
> >     if ((sample_rate !=  5512) && (sample_rate != 11025) &&
> >         (sample_rate != 22050) && (sample_rate != 44100))
> >         return 10;
> >
> >
> >  
> > > > +
> > > > +    /* Sometimes we have the first track header, so check that
> > > > too. */
> > > > +    if (p->buf_size >= 32 && AV_RL32(p->buf + 28) !=
> > > > sample_rate)
> > > > +        return 0;  
> > >
> > > are files with 32 or less bytes valid ?
> > > If not its probably better to not recognize such small pieces
> > >  
> >
> > A file needs at least one track and the first track header is
> > immediately after the file header, so I guess the minimum valid size
> > would be 40 (assuming an empty track).
> >
> > Would removing the "p->buf_size >= 32" check be alright?  
> 
> yes, that should be ok due to AVPROBE_PADDING_SIZE
> 

Done.

> also iam not sure it makes sense or if it goes to far but the probe
> code could check all tracks which are within the buffer
> all these low 10 scores are a bit ugly, some more solid "yes iam sure
> this is / is not" instead of such really low scores.
> 
> low scores which get returned based on few weak checks have the
> problem of more often producing errors in detection. Random non
> multimedia files being detected as something they are not or if 2
> demuxers have such a low score detection then its more likely the
> wrong one will be choosen
> 

I agree it's ugly. Checking all the tracks seems rather messy imo, and
would only work for the smaller files anyway.

One thing that might be possible (but is still ugly) is to check for
file extension as well. These files are only ever be seen with
a ".{5,11,22,44}c" extension. If it matches, the score could be bumped
a bit higher.

A more-forceful option is to change the "return 10" checks to "return
0". Although technically valid files, there are none that exist in
the wild with these cases. I'd prefer this solution and can just leave a
comment if it needs to be changed in the future.

Zane



More information about the ffmpeg-devel mailing list