mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-23 12:43:46 +02:00
aacdec: Don't count probed ADTS frames if there are false positives
If a portion of the probe buffer seem to resemble ADTS frames, but some data at the end is a mismatch, disregard the whole probing attempt. If it actually is ADTS data, there shouldn't be any mismatches within the sequential frame data. Signed-off-by: Martin Storsjö <martin@martin.st>
This commit is contained in:
parent
a84c8af042
commit
0412cb67cd
@ -42,8 +42,16 @@ static int adts_aac_probe(AVProbeData *p)
|
||||
|
||||
for (frames = 0; buf2 < end; frames++) {
|
||||
uint32_t header = AV_RB16(buf2);
|
||||
if ((header & 0xFFF6) != 0xFFF0)
|
||||
if ((header & 0xFFF6) != 0xFFF0) {
|
||||
if (buf != buf0) {
|
||||
// Found something that isn't an ADTS header, starting
|
||||
// from a position other than the start of the buffer.
|
||||
// Discard the count we've accumulated so far since it
|
||||
// probably was a false positive.
|
||||
frames = 0;
|
||||
}
|
||||
break;
|
||||
}
|
||||
fsize = (AV_RB32(buf2 + 3) >> 13) & 0x1FFF;
|
||||
if (fsize < 7)
|
||||
break;
|
||||
|
Loading…
Reference in New Issue
Block a user